Cette API permet aux clients de créer et d'échanger des actifs sur la chaîne X et d'autres instances de l'AVM.
La X-Chain, la plateforme native d'Avalanche pour la création et l'échange d'actifs, est une instance de la machine virtuelle Avalanche (AVM). Cette API permet aux clients de créer et d'échanger des actifs sur la chaîne X et d'autres instances de l'AVM.
Format
Cette API utilise le format RPC json 2.0. Pour plus d'informations sur les appels JSON RPC, cliquez ici.
Endpoints
/ext/bc/X pour interagir avec la X-Chain.
/ext/bc/blockchainID pour interagir avec d'autres instances AVM, où blockchainID est l'ID d'une blockchain exécutant l'AVM.
Methods
avm.buildGenesis
Étant donné une représentation JSON de l'état de genèse de cette machine virtuelle, créez la représentation octet de cet état.
Endpoint
Cet appel est effectué vers l'endpoint d'API statique d'AVM:
/ext/vm/avm
Remarque: les adresses ne doivent pas inclure de préfixe de chaîne (c'est-à-dire X-) dans les appels à l'endpoint API statique, car ces préfixes font référence à une chaîne spécifique.
{"genesisData" : {"assetAlias1": { // Each object defines an asset"name": "human readable name","symbol":"AVAL", // Symbol is between 0 and 4 characters"initialState": {"fixedCap" : [ // Choose the asset type. { // Can be "fixedCap", "variableCap", "limitedTransfer", "nonFungible""amount":1000, // At genesis, address A has"address":"A" // 1000 units of asset }, {"amount":5000, // At genesis, address B has"address":"B" // 1000 units of asset }, ... // Can have many initial holders ] } },"assetAliasCanBeAnythingUnique": { // Asset alias can be used in place of assetID in calls"name": "human readable name", // names need not be unique"symbol": "AVAL", // symbols need not be unique"initialState": {"variableCap" : [ // No units of the asset exist at genesis {"minters": [ // The signature of A or B can mint more of"A", // the asset."B" ],"threshold":1 }, {"minters": [ // The signatures of 2 of A, B and C can mint"A", // more of the asset"B","C" ],"threshold":2 }, ... // Can have many minter sets ] } }, ... // Can list more assets }}
Créez un nouvel actif fongible à plafond fixe. Une quantité de celui-ci est créée lors de l'initialisation, puis plus n'est jamais créée. L'élément peut être envoyé avec avm.send.
name est un nom lisible par l'homme pour l'actif. Pas nécessairement unique.
symbol est un symbole abrégé de l'actif. Entre 0 et 4 caractères. Pas nécessairement unique. Peut être omis.
denomination détermine la manière dont les soldes de cet actif sont affichés par les interfaces utilisateur. Si la dénomination est 0, 100 unités de cet actif sont affichées comme 100. Si la dénomination est 1, 100 unités de cet actif sont affichées comme 10,0. Si la dénomination est 2, 100 unités de cet actif sont affichées sous la forme .100, etc.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
username et passwordindiquent que l'utilisateur paie les frais de transaction.
Chaque élément de initialHolders spécifie que l'adresse contient les unités de montant de l'actif lors de la genèse.
amount est le nombre d'unités d'un assetID qui seront créer et utilisées par l'adresse to.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
usernameest l'utilisateur qui paie les frais de transaction. username doit détenir des clés lui donnant la permission de frapper davantage de cet actif. Autrement dit, il doit contrôler au moins les clés de thresold pour l'un des sets de minter.
txID est l'ID de cette transaction.
changeAddr dans le résultat est l'adresse à laquelle tout changement a été envoyé.
Créez un nouvel actif fongible à plafond variable. Aucune unité de l'actif n'existe à l'initialisation. Les minters peuvent frapper des unités de cet actif en utilisant mint.
Consultez ce tutoriel pour un exemple d'utilisation.
name est un nom lisible par l'homme pour l'actif. Pas nécessairement unique.
symbol est un symbole abrégé de l'actif. Entre 0 et 4 caractères. Pas nécessairement unique. Peut être omis.
denomination détermine la manière dont les soldes de cet actif sont affichés par les interfaces utilisateur. Si la dénomination est 0, 100 unités de cet actif sont affichées comme 100. Si la dénomination est 1, 100 unités de cet actif sont affichées comme 10,0. Si la dénomination est 2, 100 unités de cet actif sont affichées sous la forme .100, etc.
minterSets est une liste où chaque élément spécifie que le seuil threshold des adresses dans les minters peut ensemble minter plus de pièces de l'actif en signant une transaction de frappe.
Effectuer une transaction sur la X-Chain nécessite des frais de transaction payés en AVAX. username et password indiquent quel utilisateur paie les frais.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
Créez un nouvel actif non fongible. Aucune unité de l'actif n'existe à l'initialisation. Les minters peuvent frapper des unités de cet actif en utilisant mintNFT.
name est un nom lisible par l'homme pour l'actif. Pas nécessairement unique. Entre 0 et 128 caractères.
symbol est un symbole abrégé de l'actif. Entre 0 et 4 caractères. Pas nécessairement unique. Peut être omis.
minterSets est une liste où chaque élément spécifie que le seuil threshold des adresses dans les minters peut ensemble minter plus de pièces de l'actif en signant une transaction de frappe.
Effectuer une transaction sur la X-Chain nécessite des frais de transaction payés en AVAX. username et password indiquent quel utilisateur paie les frais.
Chaque élément de initialHolders spécifie que l'address contient les unités de montant de l'actif amount lors de la genèse.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
assetIDest le assetID de l'actif NFT nouvellement créé.
payload est une charge utile encodée CB58 payload jusqu'à 1024 octets.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
usernameest l'utilisateur qui paie les frais de transaction. username doit détenir des clés lui donnant la permission de frapper davantage de cet actif. Autrement dit, il doit contrôler au moins les clés de thresold pour l'un des sets de minter.
txID est l'ID de cette transaction.
changeAddr dans le résultat est l'adresse à laquelle tout changement a été envoyé.
Envoyez AVAX de la X-Chain à une autre chaîne.
Après avoir appelé cette méthode, vous devez appeler importAVAX sur l'autre chaîne pour terminer le transfert.
to est l'adresse P-Chain à laquelle l'AVAX est envoyé..
amount est la quantité de nAVAX à envoyer.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
Les AVAX est envoyé à partir d'adresses contrôlées username
txID est l'ID de cette transaction.
changeAddr dans le résultat est l'adresse à laquelle tout changement a été envoyé.
name est un nom lisible par l'homme pour l'actif. Pas nécessairement unique.
symbol est un symbole abrégé de l'actif. Entre 0 et 4 caractères. Pas nécessairement unique. Peut être omis.
denomination détermine la manière dont les soldes de cet actif sont affichés par les interfaces utilisateur. Si la dénomination est 0, 100 unités de cet actif sont affichées comme 100. Si la dénomination est 1, 100 unités de cet actif sont affichées comme 10,0. Si la dénomination est 2, 100 unités de cet actif sont affichées sous la forme .100, etc.
Obtient les UTXO qui référencent une adresse donnée. Si sourceChain est spécifié, il récupérera les UTXO atomiques exportés de cette chaîne vers la chaîne X.
utxos est une liste d'UTXOs telle que chaque UTXO référence au moins une adresse dans les adresses.
Au maximumlimit UTXOs sont renvoyées. Si limit est omise ou supérieure à 1024, elle est définie sur 1024.
Cette méthode prend en charge la pagination. endIndex désigne le dernier UTXO renvoyé. Pour obtenir le prochain ensemble d'UTXO, utilisez la valeur de endIndex comme startIndex lors de l'appel suivant.
Si startIndex est omis, on récupérera tous les UTXO jusqu'à la limit.
Lors de l'utilisation de la pagination (c'est-à-dire lorsquestartIndex est fourni), les UTXO ne sont pas garantis d'être uniques sur plusieurs appels. Autrement dit, un UTXO peut apparaître dans le résultat du premier appel, puis à nouveau dans le deuxième appel.
Lors de l'utilisation de la pagination, la cohérence n'est pas garantie sur plusieurs appels. Autrement dit, l'ensemble UTXO des adresses peut avoir changé entre les appels.
Exemple
Supposons que nous voulions tous les UTXO qui référencent au moins X-avax1yzt57wd8me6xmy3t42lz8m5lg6yruy79m6whsf et X-avax1x459sj0ssujguq723cljfty4jlae28evjzt7xz.
Puisque numFetched est le même que limit, nous pouvons dire qu'il peut y avoir plus d'UTXO qui n'ont pas été récupérés. Nous appelons à nouveau la méthode, cette fois avec startIndex:
CommenumFetched est inférieur à la limit, nous savons que nous avons fini de récupérer les UTXO et que nous n'avons pas besoin d'appeler à nouveau cette méthode.
Supposons que nous voulions récupérer les UTXO exportés de la P-Chain vers la X-Chain afin de construire un ImportTx. Ensuite, nous devons appeler GetUTXOs avec l'argument sourceChain afin de récupérer les UTXO atomiques:
Finalisez un transfert d'AVAX de la P-Chain vers la X-Chain. Avant d'appeler cette méthode, vous devez appeler la méthode P-Chain exportAVAX pour lancer le transfert.
Envoyer l' amount d'unités d'un asset assetID à l'adresse to. amount est libellé dans le plus petit incrément de l'actif. Pour AVAX, c'est 1 nAVAX (un milliardième de 1 AVAX.)
to est l'adresse X-Chain à laquelle l'élément est envoyé.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
Vous pouvez joindre un memo, dont la longueur peut aller jusqu'à 256 octets.
L'actif est envoyé à partir d'adresses contrôlées par l'utilisateurusername. (Bien sûr, cet utilisateur devra détenir au moins le solde de l'actif envoyé.)
outputs est un tableau d'objets littéraux contenant chacin un assetID, amount etto.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin.
changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
Vous pouvez joindre un memo, dont la longueur peut aller jusqu'à 256 octets.
L'actif est envoyé à partir d'adresses contrôlées par l'utilisateurusername. (Bien sûr, cet utilisateur devra détenir au moins le solde de l'actif envoyé.)
groupID st le groupe NFT à partir duquel envoyer le NFT. La création NFT permet plusieurs groupes sous chaque ID NFT. Vous pouvez émettre plusieurs NFT à chaque groupe.
to est l'adresse X-Chain à laquelle le NFT est envoyé.
from sont les adresses que vous souhaitez utiliser pour cette opération. En cas d'omission, utilise l'une de vos adresses au besoin. changeAddr est l'adresse à laquelle tout changement sera envoyé. En cas d'omission, la modification est envoyée à l'une des adresses contrôlées par l'utilisateur.
L'actif est envoyé à partir d'adresses contrôlées par l'utilisateur. username. (Bien sûr, cet utilisateur devra détenir au moins le solde du NFT envoyé.)