Features

Updating Assets

The update authority of an asset can update its Metadata account using the Update instruction as long as the Is Mutable attribute is set to true. The Update instruction requires the Update Authority to sign the transaction and can update the following attributes of the Metadata account:

Updatable Fields

Note that certain delegated authorities can also update the Metadata account of assets as discussed in the "Delegated Authorities" page.

Below is an explanation of all the individual fields available for update in the UpdateV1 instruction.

The Data Object

The object that defines the Name, Symbol, URI, Seller Fee Basis Points and the array of Creators of the asset. Note that the update authority can only add and/or remove unverified creators from the Creators array. The only exception is if the creator is the update authority, in which case the added or removed creators can be verified.

Data Object

const data = {
name: 'New Name',
symbol: 'New Symbol',
uri: 'https://newuri.com',
sellerFeeBasisPoints: 500,
creators: [],
}

Primary Sale Happened

Primary Sale Happened: A boolean that indicates whether the asset has been sold before.

Primary Sale Happened

primarySaleHappened: true

Is Mutable

A boolean that indicates whether the asset can be updated again. When changing this to false, any future updates will fail.

Is Mutable

isMutable: true

Collection

This attribute enables us to set or clear the collection of the asset. Note that when setting a new collection, the verified boolean must be set to false and verified using another instruction.

Setting A Collection

Setting A Collection

collection: collectionToggle('Set', [
{
key: publicKey('11111111111111111111111111111111'),
verified: false,
},
])

Clearing a Collection

Clearing a Collection

collection: collectionToggle("Clear"),

New Update Authority

A new update authority can be assigned to an Asset by passing in the newUpdateAuthority field.

New Update Authority

newUpdateAuthority: publicKey('1111111111111111111111111111111')

Programable RuleSets

This attribute enables us to set or clear the rule set of the asset. This is only relevant for Programmable Non-Fungibles.

Programable RuleSets

ruleSet: publicKey('1111111111111111111111111111111')

Here is how you can use our SDKs to update an asset on Token Metadata.

Update As Update Authority

NFT Asset

This example shows you how to update an NFT Asset as the update Authority of the Asset.

1import { publicKey, none, some } from '@metaplex-foundation/umi';
2import { updateV1 } from '@metaplex-foundation/mpl-token-metadata';
3
4// Assuming umi is set up with mplTokenMetadata plugin
5// See getting-started for full setup
6
7const mintAddress = publicKey('mintAddress...');
8
9// Update the NFT metadata
10await updateV1(umi, {
11 mint: mintAddress,
12 authority: umi.identity,
13 // Only specify fields you want to update
14 data: some({
15 name: 'Updated NFT Name',
16 symbol: '', // Keep existing
17 uri: '', // Keep existing
18 sellerFeeBasisPoints: 0, // Keep existing
19 creators: none(),
20 }),
21}).sendAndConfirm(umi);
22
23console.log('NFT metadata updated');

pNFT Asset

This example shows you how to update a Programable NFT (pNFT) Asset as the update Authority of the Asset.

pNFTs may require additional accounts to be passed in for the instruction to work. These include: tokenAccount, tokenRecord, authorizationRules, and authorizationRulesProgram.

1import { publicKey, none, some } from '@metaplex-foundation/umi';
2import { updateV1 } from '@metaplex-foundation/mpl-token-metadata';
3
4// Assuming umi is set up with mplTokenMetadata plugin
5
6const mintAddress = publicKey('mintAddress...');
7
8// Update the Programmable NFT metadata
9// Note: pNFTs may have rule sets that restrict updates
10await updateV1(umi, {
11 mint: mintAddress,
12 authority: umi.identity,
13 data: some({
14 name: 'Updated pNFT Name',
15 symbol: '',
16 uri: '',
17 sellerFeeBasisPoints: 0,
18 creators: none(),
19 }),
20}).sendAndConfirm(umi);
21
22console.log('pNFT metadata updated');