Услуги по разработке NFT и цифровых активов

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 61 из 61 услугВсе 1306 услуг
Часто задаваемые вопросы
Направления блокчейн-разработки
Этапы блокчейн-разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1221
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1163
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    855
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1056
  • image_logo-advance_0.png
    Разработка логотипа компании B2B Advance
    561
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    828

Разработка NFT и цифровых активов

На первый взгляд NFT-контракт выглядит просто: ERC-721, mint(), IPFS для метаданных, всё. На практике именно в этой «простоте» прячется большинство проблем — от ботов, скупающих весь mint в первый блок, до сломанных royalties на вторичном рынке.

ERC-721 vs ERC-1155: когда что выбирать

ERC-721 — каждый токен уникален, один owner. Подходит для коллекций где каждый NFT имеет индивидуальные атрибуты и прямую привязку owner → tokenId.

ERC-1155 — multi-token стандарт: один контракт хранит и fungible, и non-fungible токены. balanceOf(address, tokenId) вместо ownerOf(tokenId). Одна транзакция может transferить несколько разных токенов через safeBatchTransferFrom. Это экономит газ при массовых операциях — важно для игровых айтемов, тикетов, edition-коллекций.

Конкретный кейс: игровой проект с 50 видами айтемов, каждый в тираже 10 000. ERC-721 — 500 000 уникальных токенов, огромный overhead на маппинги. ERC-1155 — 50 tokenId, balanceOf на каждого игрока. Газ на transfer ниже в 2–3 раза, деплой контракта дешевле.

Метаданные: on-chain vs IPFS vs centralized

Стандартный путь — tokenURI() возвращает ссылку на JSON с name, description, image, attributes. Три варианта хранения:

Centralized server — самый дешёвый и гибкий. Риск: сервер падает, компания закрывается — NFT теряет метаданные. Не подходит для коллекций с претензией на долгосрочную ценность.

IPFS + Pinning — контентно-адресуемое хранилище, ссылка привязана к хешу содержимого. Pinata или NFT.Storage обеспечивают pinning. Важно: IPFS не гарантирует доступность сам по себе — нужен активный pinning service. Если pinning service закроется, данные могут исчезнуть если никто не хранит копию.

On-chain metadata — base64-encoded SVG или JSON прямо в tokenURI. Максимальная надёжность, но дорого. Подходит для generative art проектов где визуал генерируется из on-chain атрибутов (Nouns, Loot).

Для большинства коллекций: IPFS с Pinata для images + on-chain атрибуты для трейтов — хороший баланс.

Dynamic NFT: метаданные которые меняются

Dynamic NFT обновляет метаданные в ответ на внешние события — результаты матчей, уровень персонажа, реальные данные через Chainlink. Архитектурно это связка: смарт-контракт хранит state → tokenURI() генерирует метаданные из state on-chain.

Проблема с кешированием: OpenSea и другие маркетплейсы агрессивно кешируют метаданные. Стандартный механизм инвалидации — MetadataUpdate(tokenId) event из ERC-4906. OpenSea слушает этот event и сбрасывает кеш. Без него обновленные метаданные могут не отображаться неделями.

Chainlink Automation (бывший Keepers) для автоматического обновления state на контракте по расписанию или по условию — стандартное решение.

Royalties: реальное состояние рынка

ERC-2981 — on-chain стандарт royalties. Контракт возвращает (recipient, amount) для любой sale price через royaltyInfo(tokenId, salePrice). Маркетплейсы опрашивают это при каждой продаже.

Проблема: соблюдение royalties — это добровольное решение маркетплейса. Blur запустился в 2022 с нулевыми royalties как конкурентным преимуществом, что вызвало волну других платформ. Сейчас ситуация частично стабилизировалась: OpenSea поддерживает ERC-2981, Blur добавил опциональные royalties.

Попытки enforce royalties on-chain через ограничение transfers только на approved маркетплейсы (operator filtering) OpenSea предлагал через OperatorFilterRegistry. Это ломает composability — нельзя передать NFT через кастомный контракт. Большинство серьёзных проектов отказались от этого подхода.

Для проектов где royalties критичны: кастомный маркетплейс внутри экосистемы + incentive structure для пользователей торговать именно там.

Mint механики и защита от ботов

Allowlist через merkle tree — стандарт. Список адресов хешируется в merkle root, хранится в контракте. При mint пользователь предоставляет merkle proof — контракт проверяет без хранения полного списка. OpenZeppelin MerkleProof library.

Reveal механика — при mint выдаётся placeholder, реальные трейты reveal-ятся после окончания продажи. Иначе боты могут сканировать pending транзакции и снайперить редкие трейты через frontrunning. Но reveal требует commitment scheme — случайный seed должен быть зафиксирован до mint или использовать Chainlink VRF.

Chainlink VRF для честной рандомизации трейтов. VRF request в момент mint → callback с verifiable random number → assign traits. Это добавляет ~2 транзакции и latency, но гарантирует честность.

Rate limitingrequire(mintedPerWallet[msg.sender] < maxPerWallet). Не защищает от мульти-кошельков, но поднимает стоимость атаки.

Lazy minting и gas-free mint

Gas-free mint через подпись: создатель подписывает voucher (tokenId, tokenURI, price, signature), покупатель предоставляет voucher в mint() — контракт верифицирует подпись через ECDSA.recover() и минтит. Работает на OpenSea через их Seaport протокол.

Seaport — оптимизированный контракт маркетплейса с минимальным gas usage. Понимание его механики важно при интеграции custom marketplace логики.

Стек для NFT-проектов

Контракты: Solidity 0.8.x, OpenZeppelin ERC721Enumerable или ERC721A (Azuki) для gas-оптимизированного batch mint, ERC1155 от OpenZeppelin

VRF и автоматизация: Chainlink VRF v2.5, Chainlink Automation

Хранение: Pinata (IPFS pinning), NFT.Storage, Arweave для постоянного хранения

Маркетплейс: OpenSea Seaport protocol, кастомная интеграция

Фронтенд: wagmi v2 + viem, RainbowKit для wallet connection, React + TypeScript

Процесс разработки

Проектирование mint механики — allowlist, public sale, price curve (Dutch auction или фиксированная), limits per wallet.

Контракты — с Foundry fuzz тестами на mint limits, merkle proof верификацию, royalty calculations.

IPFS деплой — загрузка метаданных и images до reveal, pinning на минимум двух сервисах.

Reveal — если используется Chainlink VRF, тест на testnet обязателен: VRF subscription должен быть funded LINK токенами.

Маркетплейс интеграция — верификация коллекции на OpenSea, настройка royalties, тест MetadataUpdate events.

Сроки

  • Базовый ERC-721 без reveal: 2–3 недели
  • NFT коллекция с allowlist, reveal, VRF: 4–7 недель
  • ERC-1155 с marketplace и royalties: 5–8 недель
  • Dynamic NFT с внешними данными: 6–10 недель