solana-program-library/account-compression/sdk/idl/spl_account_compression.json

634 lines
16 KiB
JSON

{
"version": "0.1.4",
"name": "spl_account_compression",
"instructions": [
{
"name": "initEmptyMerkleTree",
"docs": [
"Creates a new merkle tree with maximum leaf capacity of `power(2, max_depth)`",
"and a minimum concurrency limit of `max_buffer_size`.",
"",
"Concurrency limit represents the # of replace instructions that can be successfully",
"executed with proofs dated for the same root. For example, a maximum buffer size of 1024",
"means that a minimum of 1024 replaces can be executed before a new proof must be",
"generated for the next replace instruction.",
"",
"Concurrency limit should be determined by empirically testing the demand for",
"state built on top of SPL Compression.",
"",
"For instructions on enabling the canopy, see [canopy]."
],
"accounts": [
{
"name": "merkleTree",
"isMut": true,
"isSigner": false
},
{
"name": "authority",
"isMut": false,
"isSigner": true,
"docs": [
"Authority that controls write-access to the tree",
"Typically a program, e.g., the Bubblegum contract validates that leaves are valid NFTs."
]
},
{
"name": "noop",
"isMut": false,
"isSigner": false,
"docs": [
"Program used to emit changelogs as cpi instruction data."
]
}
],
"args": [
{
"name": "maxDepth",
"type": "u32"
},
{
"name": "maxBufferSize",
"type": "u32"
}
]
},
{
"name": "replaceLeaf",
"docs": [
"Note:",
"Supporting this instruction open a security vulnerability for indexers.",
"This instruction has been deemed unusable for publicly indexed compressed NFTs.",
"Indexing batched data in this way requires indexers to read in the `uri`s onto physical storage",
"and then into their database. This opens up a DOS attack vector, whereby this instruction is",
"repeatedly invoked, causing indexers to fail.",
"",
"Because this instruction was deemed insecure, this instruction has been removed",
"until secure usage is available on-chain.",
"Executes an instruction that overwrites a leaf node.",
"Composing programs should check that the data hashed into previous_leaf",
"matches the authority information necessary to execute this instruction."
],
"accounts": [
{
"name": "merkleTree",
"isMut": true,
"isSigner": false
},
{
"name": "authority",
"isMut": false,
"isSigner": true,
"docs": [
"Authority that controls write-access to the tree",
"Typically a program, e.g., the Bubblegum contract validates that leaves are valid NFTs."
]
},
{
"name": "noop",
"isMut": false,
"isSigner": false,
"docs": [
"Program used to emit changelogs as cpi instruction data."
]
}
],
"args": [
{
"name": "root",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "previousLeaf",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "newLeaf",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "index",
"type": "u32"
}
]
},
{
"name": "transferAuthority",
"docs": [
"Transfers `authority`.",
"Requires `authority` to sign"
],
"accounts": [
{
"name": "merkleTree",
"isMut": true,
"isSigner": false
},
{
"name": "authority",
"isMut": false,
"isSigner": true,
"docs": [
"Authority that controls write-access to the tree",
"Typically a program, e.g., the Bubblegum contract validates that leaves are valid NFTs."
]
}
],
"args": [
{
"name": "newAuthority",
"type": "publicKey"
}
]
},
{
"name": "verifyLeaf",
"docs": [
"Verifies a provided proof and leaf.",
"If invalid, throws an error."
],
"accounts": [
{
"name": "merkleTree",
"isMut": false,
"isSigner": false
}
],
"args": [
{
"name": "root",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "leaf",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "index",
"type": "u32"
}
]
},
{
"name": "append",
"docs": [
"This instruction allows the tree's `authority` to append a new leaf to the tree",
"without having to supply a proof.",
"",
"Learn more about SPL",
"ConcurrentMerkleTree",
"[here](https://github.com/solana-labs/solana-program-library/tree/master/libraries/concurrent-merkle-tree)"
],
"accounts": [
{
"name": "merkleTree",
"isMut": true,
"isSigner": false
},
{
"name": "authority",
"isMut": false,
"isSigner": true,
"docs": [
"Authority that controls write-access to the tree",
"Typically a program, e.g., the Bubblegum contract validates that leaves are valid NFTs."
]
},
{
"name": "noop",
"isMut": false,
"isSigner": false,
"docs": [
"Program used to emit changelogs as cpi instruction data."
]
}
],
"args": [
{
"name": "leaf",
"type": {
"array": [
"u8",
32
]
}
}
]
},
{
"name": "insertOrAppend",
"docs": [
"This instruction takes a proof, and will attempt to write the given leaf",
"to the specified index in the tree. If the insert operation fails, the leaf will be `append`-ed",
"to the tree.",
"It is up to the indexer to parse the final location of the leaf from the emitted changelog."
],
"accounts": [
{
"name": "merkleTree",
"isMut": true,
"isSigner": false
},
{
"name": "authority",
"isMut": false,
"isSigner": true,
"docs": [
"Authority that controls write-access to the tree",
"Typically a program, e.g., the Bubblegum contract validates that leaves are valid NFTs."
]
},
{
"name": "noop",
"isMut": false,
"isSigner": false,
"docs": [
"Program used to emit changelogs as cpi instruction data."
]
}
],
"args": [
{
"name": "root",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "leaf",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "index",
"type": "u32"
}
]
},
{
"name": "closeEmptyTree",
"accounts": [
{
"name": "merkleTree",
"isMut": true,
"isSigner": false
},
{
"name": "authority",
"isMut": false,
"isSigner": true,
"docs": [
"Authority that controls write-access to the tree"
]
},
{
"name": "recipient",
"isMut": true,
"isSigner": false
}
],
"args": []
}
],
"types": [
{
"name": "ApplicationDataEventV1",
"type": {
"kind": "struct",
"fields": [
{
"name": "applicationData",
"type": "bytes"
}
]
}
},
{
"name": "ChangeLogEventV1",
"type": {
"kind": "struct",
"fields": [
{
"name": "id",
"docs": [
"Public key of the ConcurrentMerkleTree"
],
"type": "publicKey"
},
{
"name": "path",
"docs": [
"Nodes of off-chain merkle tree needed by indexer"
],
"type": {
"vec": {
"defined": "PathNode"
}
}
},
{
"name": "seq",
"docs": [
"Index corresponding to the number of successful operations on this tree.",
"Used by the off-chain indexer to figure out when there are gaps to be backfilled."
],
"type": "u64"
},
{
"name": "index",
"docs": [
"Bitmap of node parity (used when hashing)"
],
"type": "u32"
}
]
}
},
{
"name": "ConcurrentMerkleTreeHeader",
"docs": [
"Initialization parameters for an SPL ConcurrentMerkleTree.",
"",
"Only the following permutations are valid:",
"",
"| max_depth | max_buffer_size |",
"| --------- | --------------------- |",
"| 14 | (64, 256, 1024, 2048) |",
"| 20 | (64, 256, 1024, 2048) |",
"| 24 | (64, 256, 512, 1024, 2048) |",
"| 26 | (64, 256, 512, 1024, 2048) |",
"| 30 | (512, 1024, 2048) |",
""
],
"type": {
"kind": "struct",
"fields": [
{
"name": "accountType",
"docs": [
"Account type"
],
"type": {
"defined": "CompressionAccountType"
}
},
{
"name": "header",
"docs": [
"Versioned header"
],
"type": {
"defined": "ConcurrentMerkleTreeHeaderData"
}
}
]
}
},
{
"name": "ConcurrentMerkleTreeHeaderDataV1",
"type": {
"kind": "struct",
"fields": [
{
"name": "maxBufferSize",
"docs": [
"Buffer of changelogs stored on-chain.",
"Must be a power of 2; see above table for valid combinations."
],
"type": "u32"
},
{
"name": "maxDepth",
"docs": [
"Depth of the SPL ConcurrentMerkleTree to store.",
"Tree capacity can be calculated as power(2, max_depth).",
"See above table for valid options."
],
"type": "u32"
},
{
"name": "authority",
"docs": [
"Authority that validates the content of the trees.",
"Typically a program, e.g., the Bubblegum contract validates that leaves are valid NFTs."
],
"type": "publicKey"
},
{
"name": "creationSlot",
"docs": [
"Slot corresponding to when the Merkle tree was created.",
"Provides a lower-bound on what slot to start (re-)building a tree from."
],
"type": "u64"
},
{
"name": "padding",
"docs": [
"Needs padding for the account to be 8-byte aligned",
"8-byte alignment is necessary to zero-copy the SPL ConcurrentMerkleTree"
],
"type": {
"array": [
"u8",
6
]
}
}
]
}
},
{
"name": "PathNode",
"type": {
"kind": "struct",
"fields": [
{
"name": "node",
"type": {
"array": [
"u8",
32
]
}
},
{
"name": "index",
"type": "u32"
}
]
}
},
{
"name": "ApplicationDataEvent",
"type": {
"kind": "enum",
"variants": [
{
"name": "V1",
"fields": [
{
"defined": "ApplicationDataEventV1"
}
]
}
]
}
},
{
"name": "ChangeLogEvent",
"type": {
"kind": "enum",
"variants": [
{
"name": "V1",
"fields": [
{
"defined": "ChangeLogEventV1"
}
]
}
]
}
},
{
"name": "AccountCompressionEvent",
"type": {
"kind": "enum",
"variants": [
{
"name": "ChangeLog",
"fields": [
{
"defined": "ChangeLogEvent"
}
]
},
{
"name": "ApplicationData",
"fields": [
{
"defined": "ApplicationDataEvent"
}
]
}
]
}
},
{
"name": "CompressionAccountType",
"type": {
"kind": "enum",
"variants": [
{
"name": "Uninitialized"
},
{
"name": "ConcurrentMerkleTree"
}
]
}
},
{
"name": "ConcurrentMerkleTreeHeaderData",
"type": {
"kind": "enum",
"variants": [
{
"name": "V1",
"fields": [
{
"defined": "ConcurrentMerkleTreeHeaderDataV1"
}
]
}
]
}
}
],
"errors": [
{
"code": 6000,
"name": "IncorrectLeafLength",
"msg": "Incorrect leaf length. Expected vec of 32 bytes"
},
{
"code": 6001,
"name": "ConcurrentMerkleTreeError",
"msg": "Concurrent merkle tree error"
},
{
"code": 6002,
"name": "ZeroCopyError",
"msg": "Issue zero copying concurrent merkle tree data"
},
{
"code": 6003,
"name": "ConcurrentMerkleTreeConstantsError",
"msg": "An unsupported max depth or max buffer size constant was provided"
},
{
"code": 6004,
"name": "CanopyLengthMismatch",
"msg": "Expected a different byte length for the merkle tree canopy"
},
{
"code": 6005,
"name": "IncorrectAuthority",
"msg": "Provided authority does not match expected tree authority"
},
{
"code": 6006,
"name": "IncorrectAccountOwner",
"msg": "Account is owned by a different program, expected it to be owned by this program"
},
{
"code": 6007,
"name": "IncorrectAccountType",
"msg": "Account provided has incorrect account type"
},
{
"code": 6008,
"name": "LeafIndexOutOfBounds",
"msg": "Leaf index of concurrent merkle tree is out of bounds"
}
],
"metadata": {
"address": "cmtDvXumGCrqC1Age74AVPhSRVXJMd8PJS91L8KbNCK",
"origin": "anchor",
"binaryVersion": "0.25.0",
"libVersion": "0.25.0"
}
}