mirror of
https://github.com/XRPLF/xrpl-dev-portal.git
synced 2026-04-29 15:37:48 +00:00
144 lines
8.5 KiB
Markdown
144 lines
8.5 KiB
Markdown
# Issue MPT with Metadata (JavaScript)
|
|
|
|
Creates a sample MPT issuance with metadata encoded as JSON according to the [XLS-89 standard](https://github.com/XRPLF/XRPL-Standards/tree/master/XLS-0089-multi-purpose-token-metadata-schema).
|
|
|
|
Quick setup and usage:
|
|
|
|
```sh
|
|
npm i
|
|
node issue-mpt-with-metadata.js
|
|
```
|
|
|
|
The script should output a validated transaction and decoded metadata, similar to the following:
|
|
|
|
```sh
|
|
=== Funding new wallet from faucet...===
|
|
Issuer address: r9fhoyac7uUM9XZFDJV9wXQ4pcJb6UDpJM
|
|
|
|
=== Encoding metadata...===
|
|
Encoded mpt_metadata_hex: 7B226163223A22727761222C226169223A7B226375736970223A22393132373936525830222C22696E7465726573745F72617465223A22352E303025222C22696E7465726573745F74797065223A227661726961626C65222C226D617475726974795F64617465223A22323034352D30362D3330222C227969656C645F736F75726365223A22552E532E2054726561737572792042696C6C73227D2C226173223A227472656173757279222C2264223A2241207969656C642D62656172696E6720737461626C65636F696E206261636B65642062792073686F72742D7465726D20552E532E205472656173757269657320616E64206D6F6E6579206D61726B657420696E737472756D656E74732E222C2269223A2268747470733A2F2F6578616D706C652E6F72672F7462696C6C2D69636F6E2E706E67222C22696E223A224578616D706C65205969656C6420436F2E222C226E223A22542D42696C6C205969656C6420546F6B656E222C2274223A225442494C4C222C227573223A5B7B2263223A2277656273697465222C2274223A2250726F647563742050616765222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F7462696C6C227D2C7B2263223A22646F6373222C2274223A225969656C6420546F6B656E20446F6373222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F646F6373227D5D7D
|
|
|
|
=== Sending MPTokenIssuanceCreate transaction...===
|
|
{
|
|
"TransactionType": "MPTokenIssuanceCreate",
|
|
"Account": "r9fhoyac7uUM9XZFDJV9wXQ4pcJb6UDpJM",
|
|
"AssetScale": 4,
|
|
"MaximumAmount": "50000000",
|
|
"TransferFee": 0,
|
|
"Flags": 48,
|
|
"MPTokenMetadata": "7B226163223A22727761222C226169223A7B226375736970223A22393132373936525830222C22696E7465726573745F72617465223A22352E303025222C22696E7465726573745F74797065223A227661726961626C65222C226D617475726974795F64617465223A22323034352D30362D3330222C227969656C645F736F75726365223A22552E532E2054726561737572792042696C6C73227D2C226173223A227472656173757279222C2264223A2241207969656C642D62656172696E6720737461626C65636F696E206261636B65642062792073686F72742D7465726D20552E532E205472656173757269657320616E64206D6F6E6579206D61726B657420696E737472756D656E74732E222C2269223A2268747470733A2F2F6578616D706C652E6F72672F7462696C6C2D69636F6E2E706E67222C22696E223A224578616D706C65205969656C6420436F2E222C226E223A22542D42696C6C205969656C6420546F6B656E222C2274223A225442494C4C222C227573223A5B7B2263223A2277656273697465222C2274223A2250726F647563742050616765222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F7462696C6C227D2C7B2263223A22646F6373222C2274223A225969656C6420546F6B656E20446F6373222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F646F6373227D5D7D"
|
|
}
|
|
|
|
=== Checking MPTokenIssuanceCreate results... ===
|
|
{
|
|
"close_time_iso": "2025-11-20T18:13:30Z",
|
|
"ctid": "C0148E8700000002",
|
|
"hash": "555FAFDB99B239567FDF30DDF22BA3B30F8E70D8D06833B1270AC600E1575948",
|
|
"ledger_hash": "A7010A2025989778420280F7F96B10F5D3C879E049BE5DA12500FFBB90D162C5",
|
|
"ledger_index": 1347207,
|
|
"meta": {
|
|
"AffectedNodes": [
|
|
{
|
|
"CreatedNode": {
|
|
"LedgerEntryType": "DirectoryNode",
|
|
"LedgerIndex": "33468621DEF32177E84C1EBC2C457C908567E245622CBDE03185C4ABC83B7F9D",
|
|
"NewFields": {
|
|
"Owner": "r9fhoyac7uUM9XZFDJV9wXQ4pcJb6UDpJM",
|
|
"RootIndex": "33468621DEF32177E84C1EBC2C457C908567E245622CBDE03185C4ABC83B7F9D"
|
|
}
|
|
}
|
|
},
|
|
{
|
|
"CreatedNode": {
|
|
"LedgerEntryType": "MPTokenIssuance",
|
|
"LedgerIndex": "6567EE49937AADAB4FC4D5DDBD6A4A6E179E0E5A9DF2FC7ED8B41B807F0DDBF2",
|
|
"NewFields": {
|
|
"AssetScale": 4,
|
|
"Flags": 48,
|
|
"Issuer": "r9fhoyac7uUM9XZFDJV9wXQ4pcJb6UDpJM",
|
|
"MPTokenMetadata": "7B226163223A22727761222C226169223A7B226375736970223A22393132373936525830222C22696E7465726573745F72617465223A22352E303025222C22696E7465726573745F74797065223A227661726961626C65222C226D617475726974795F64617465223A22323034352D30362D3330222C227969656C645F736F75726365223A22552E532E2054726561737572792042696C6C73227D2C226173223A227472656173757279222C2264223A2241207969656C642D62656172696E6720737461626C65636F696E206261636B65642062792073686F72742D7465726D20552E532E205472656173757269657320616E64206D6F6E6579206D61726B657420696E737472756D656E74732E222C2269223A2268747470733A2F2F6578616D706C652E6F72672F7462696C6C2D69636F6E2E706E67222C22696E223A224578616D706C65205969656C6420436F2E222C226E223A22542D42696C6C205969656C6420546F6B656E222C2274223A225442494C4C222C227573223A5B7B2263223A2277656273697465222C2274223A2250726F647563742050616765222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F7462696C6C227D2C7B2263223A22646F6373222C2274223A225969656C6420546F6B656E20446F6373222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F646F6373227D5D7D",
|
|
"MaximumAmount": "50000000",
|
|
"Sequence": 1347205
|
|
}
|
|
}
|
|
},
|
|
{
|
|
"ModifiedNode": {
|
|
"FinalFields": {
|
|
"Account": "r9fhoyac7uUM9XZFDJV9wXQ4pcJb6UDpJM",
|
|
"Balance": "99999999",
|
|
"Flags": 0,
|
|
"OwnerCount": 1,
|
|
"Sequence": 1347206
|
|
},
|
|
"LedgerEntryType": "AccountRoot",
|
|
"LedgerIndex": "AB5FC35110CED5BFD2CEA3E37B41E43CC4BBAF89AE66BA85942E04CBC38550FB",
|
|
"PreviousFields": {
|
|
"Balance": "100000000",
|
|
"OwnerCount": 0,
|
|
"Sequence": 1347205
|
|
},
|
|
"PreviousTxnID": "1CDF420134492607EC54838F91FA06A655E07DD296ED69CC7172C1AC356BF22B",
|
|
"PreviousTxnLgrSeq": 1347205
|
|
}
|
|
}
|
|
],
|
|
"TransactionIndex": 0,
|
|
"TransactionResult": "tesSUCCESS",
|
|
"mpt_issuance_id": "00148E8558E6AEAA301085FBFD01D615F059A7CCE6E38296"
|
|
},
|
|
"tx_json": {
|
|
"Account": "r9fhoyac7uUM9XZFDJV9wXQ4pcJb6UDpJM",
|
|
"AssetScale": 4,
|
|
"Fee": "1",
|
|
"Flags": 48,
|
|
"LastLedgerSequence": 1347225,
|
|
"MPTokenMetadata": "7B226163223A22727761222C226169223A7B226375736970223A22393132373936525830222C22696E7465726573745F72617465223A22352E303025222C22696E7465726573745F74797065223A227661726961626C65222C226D617475726974795F64617465223A22323034352D30362D3330222C227969656C645F736F75726365223A22552E532E2054726561737572792042696C6C73227D2C226173223A227472656173757279222C2264223A2241207969656C642D62656172696E6720737461626C65636F696E206261636B65642062792073686F72742D7465726D20552E532E205472656173757269657320616E64206D6F6E6579206D61726B657420696E737472756D656E74732E222C2269223A2268747470733A2F2F6578616D706C652E6F72672F7462696C6C2D69636F6E2E706E67222C22696E223A224578616D706C65205969656C6420436F2E222C226E223A22542D42696C6C205969656C6420546F6B656E222C2274223A225442494C4C222C227573223A5B7B2263223A2277656273697465222C2274223A2250726F647563742050616765222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F7462696C6C227D2C7B2263223A22646F6373222C2274223A225969656C6420546F6B656E20446F6373222C2275223A2268747470733A2F2F6578616D706C657969656C642E636F2F646F6373227D5D7D",
|
|
"MaximumAmount": "50000000",
|
|
"Sequence": 1347205,
|
|
"SigningPubKey": "ED1EC65DB85E686A55F8FD9BC6E405E8F2F8EA5E1712AED64E28C97350EB4EF6E7",
|
|
"TransactionType": "MPTokenIssuanceCreate",
|
|
"TransferFee": 0,
|
|
"TxnSignature": "3A671905D57342F051E3BF057CCF65B0D94114C04D255D4AE3CEE01C2D0B368118E94011CEB27EC9BB447D3498B24B750F2691B4D7AB71F82626BC6F49465806",
|
|
"ctid": "C0148E8700000002",
|
|
"date": 816977610,
|
|
"ledger_index": 1347207
|
|
},
|
|
"validated": true
|
|
}
|
|
|
|
- MPToken created successfully with issuance ID: 00148E8558E6AEAA301085FBFD01D615F059A7CCE6E38296
|
|
- Explorer URL: https://devnet.xrpl.org/mpt/00148E8558E6AEAA301085FBFD01D615F059A7CCE6E38296
|
|
|
|
=== Confirming MPT Issuance metadata in the validated ledger... ===
|
|
Decoded MPT metadata:
|
|
{
|
|
asset_class: 'rwa',
|
|
additional_info: {
|
|
cusip: '912796RX0',
|
|
interest_rate: '5.00%',
|
|
interest_type: 'variable',
|
|
maturity_date: '2045-06-30',
|
|
yield_source: 'U.S. Treasury Bills'
|
|
},
|
|
asset_subclass: 'treasury',
|
|
desc: 'A yield-bearing stablecoin backed by short-term U.S. Treasuries and money market instruments.',
|
|
icon: 'https://example.org/tbill-icon.png',
|
|
issuer_name: 'Example Yield Co.',
|
|
name: 'T-Bill Yield Token',
|
|
ticker: 'TBILL',
|
|
uris: [
|
|
{
|
|
category: 'website',
|
|
title: 'Product Page',
|
|
uri: 'https://exampleyield.co/tbill'
|
|
},
|
|
{
|
|
category: 'docs',
|
|
title: 'Yield Token Docs',
|
|
uri: 'https://exampleyield.co/docs'
|
|
}
|
|
]
|
|
}
|
|
```
|