Merchants might decide to sell or gift NFTs. Currently, NFTs are most popularly being used to demonstrate ownership of media such as digital art, but they have many other uses for both merchants and customers. Merchants might consider using NFTs on their Shopify store in the following ways: - [Sell NFTs through their Shopify store](https://help.shopify.com/manual/products/digital-service-product/nfts#sell-nfts). - [Offer free NFTs](https://help.shopify.com/manual/products/digital-service-product/nfts#offer-free-nfts-to-your-customers) to reward their customers for purchases, engagement, and loyalty. - Offer exclusive products, discounts, or early access to product launches based on ownership of certain NFTs through [tokengated commerce](https://help.shopify.com/manual/products/digital-service-product/nfts#tokengated-commerce). - Increase potential audience through [tokengated](https://help.shopify.com/manual/products/digital-service-product/nfts#tokengated-commerce) collaborations with other brands through your online stores, or in person events. - Create [customer segments](https://help.shopify.com/manual/customers/customer-segmentation/customer-segments) based on NFT ownership for marketing acquisition and retention campaigns. - Provide a certificate of authenticity or an NFT receipt with a customer’s purchase. NFTs and blockchain technology are continually evolving, and the full impact and use cases are still being explored. Merchants who are selling NFTs are required to get approval from Shopify before selling through [Shopify Payments](https://help.shopify.com/manual/payments/shopify-payments). Developers who support merchants with NFT distribution are required to gate this functionality and restrict the ability to mint, gift, or list NFTs for sale to approved merchants. Learn more about [merchant eligibility](/docs/apps/build/blockchain/nft-distribution/check-merchant-eligibility). ## Developers listing and minting NFTs on behalf of merchants Developers who support merchants in minting, gifting, or listing NFTs for sale must meet the following requirements: - **Block merchants from listing NFTs while Shopify Payments is active** in the shop until the merchant is [SellApproved](/docs/apps/build/blockchain/nft-distribution/check-nft-sales-eligibility#possible-api-responses) (`sellApproved`: true) and/or [GiftingApproved](/docs/apps/build/blockchain/nft-distribution/check-nft-sales-eligibility#possible-api-responses) (`giftingApproved`: true). - The NFT Sales Eligibility Application form is enabled for NFT Distribution apps, with no further development work required. Merchants using Shopify Payments who haven't yet completed the application are prompted with the application after installing an NFT distribution app, and the results are reflected in the [NFT Sales Eligibility API](/docs/apps/build/blockchain/nft-distribution/check-nft-sales-eligibility). - Comply with the [blockchain app requirements](/docs/apps/launch/app-requirements-checklist#a-blockchain-app-requirements). - Review best practices for designing merchant and customer NFT distribution experiences provided in the [NFT distribution UX guidelines](/docs/apps/build/blockchain/nft-distribution/ux-for-nft-distribution). - All NFT variants must have a programmatic representation of their NFT status using product metafields with the following specifications ## NFT distribution product metafields requirements Any products that contain one or more NFT variants must list the NFT variant IDs within the [`Product`](/docs/api/admin-graphql/latest/objects/product) object using product metafields. The following code example uses the [`productUpdate`](/docs/api/admin-graphql/latest/mutations/productupdate) mutation to update a product metafields with variant IDs: <p> <div class="react-code-block" data-preset="terminal"> <div class="react-code-block-preload ThemeMode-dim"> <div class="react-code-block-preload-bar "></div> <div class="react-code-block-preload-placeholder-container"> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> <div class="react-code-block-preload-code-container"> <div class="react-code-block-preload-codeline-number"></div> <div class="react-code-block-preload-codeline"></div> </div> </div> </div> <script data-option="title" data-value="NFT product metafields GraphQL mutation"></script> <script type="text/plain" data-language="graphql" data-title="GraphQL mutation"> RAW_MD_CONTENTmutation($input: ProductInput!) { productUpdate(input: $input) { product { metafields(first: 100) { edges { node { namespace key value } } } } } } END_RAW_MD_CONTENT</script> <script type="text/plain" data-language="json" data-title="Input"> RAW_MD_CONTENT{ "input": { "id": "gid://shopify/Product/{$product_id}", "metafields": [ { "namespace": "web_3", "key": "nft_variants", "value": [ "{$product_variant_id}", "{$product_variant_id}" ], "type": "list.single_line_text_field", } ] } } END_RAW_MD_CONTENT</script> </div> </p> ## Next steps - Learn how to [check a merchant's eligibility to sell NFTs by using the GraphQL Admin API](/docs/apps/build/blockchain/nft-distribution/check-nft-sales-eligibility). - Learn more about how [merchant’s are leveraging NFTs](https://www.youtube.com/watch?v=D3Mrg3iSMRY).