解析 Solana NFT 元数据和更新元数据的代码示例

Code sample for parsing metadata for Solana NFT and updating the metadata

在 Solana 上,NFT 元数据存储在共享合约 Token Metadata Program 所拥有的帐户中,地址为 metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s

我需要一个清晰、简洁的代码示例来说明我如何使用一些现有的库来获取特定 NFT 的元数据。我们以这个 NFT 为例:a SolStone 4itgFt6tSotypyVAaUkLJzpGQ5KXsJNhwpKBANMv49mf

到目前为止,我所做的最深入的工作是复制 metaplex 库并使用这样的调用

 await getProgramAccounts(connection, METADATA_PROGRAM_ID, 'finalized');

然而,这将加载所有现有 NFT 的元数据。相反,我需要使用一些过滤器而不是 'finalized' 作为承诺参数。

metaplex codebase 中,我相信他们有一个按创建者地址过滤的示例。

filters: [
    {
        memcmp: {
            offset:
            1 + // key
            32 + // update auth
            32 + // mint
            4 + // name string length
            MAX_NAME_LENGTH + // name
            4 + // uri string length
            MAX_URI_LENGTH + // uri
            4 + // symbol string length
            MAX_SYMBOL_LENGTH + // symbol
            2 + // seller fee basis points
            1 + // whether or not there is a creators vec
            4 + // creators vec length
            i * MAX_CREATOR_LEN,
            bytes: whitelistedCreators[j].info.address,
        }
    }
]

所以理论上我应该能够更新这个过滤器,而不是通过 NFT 自己的地址来过滤,但我不确定如何在此处获得正确的位偏移以使过滤器准确。

在我能够读取 nft 元数据之后,接下来我需要一个代码示例来更新元数据。特别是 URI 字段。

您几乎完成了大部分内容!

地址 4itgFt6tSotypyVAaUkLJzpGQ5KXsJNhwpKBANMv49mf 实际上是代币铸币厂,如浏览器中所见:https://explorer.solana.com/address/4itgFt6tSotypyVAaUkLJzpGQ5KXsJNhwpKBANMv49mf

这意味着您将使用与您找到的示例非常相似的调用,但不是在 whitelistedCreators 数组上进行过滤,而是在 mint 的位置进行过滤,即字节1 + 32,假设我们可以信任代码中的注释。这给出了一个函数调用:

getProgramAccounts(connection, METADATA_PROGRAM_ID, {
  filters: [
    {
      memcmp: {
        offset:
          1 + // key
          32 // update auth
        bytes: mintAddress.toBytes(),
      },
    },
  ],
})

要更新元数据,您可能需要使用 UpdateMetadata 指令。看起来 Metaplex JS 库有一个实用函数可以做到这一点:https://github.com/metaplex-foundation/metaplex/blob/9d5a5c6d668cd9c597cff8c63dfba00dee2f72f0/js/packages/common/src/actions/metadata.ts#L481