dash-platform-sdk
    Preparing search index...

    dash-platform-sdk

    dash-platform-sdk v1.2.0

    GitHub license npm version a

    Javascript SDK for Dash Platform network that let you interact with the chain.

    Does not support Core chain by design

    It can be used to query network, create, sign and broadcast the transactions in any Javascript environment. It works both in Node.js, Browsers, and with modern frontend frameworks

    SDK uses a pre-defined set of seed nodes (public RPC) at the start, and then tries to switch to the latest list of nodes fetched from the Dash network through https://rpc.digitalcash.dev if possible

    Currently, only minimal features are included, such as document querying and creation of the documents, and all necessary related functions to do that There is no input validation and error handling implemented yet relying on a happy path, this is going to be fixed in next versions

    • Easy API for developers
    • Cryptographic proofs for DAPI (GRPC) queries
    • Create, Sign, and Broadcast transactions
    • Mainnet / Testnet support
    • Autogenerated documentation

    The SDK is isomorphic and works in both Node.js and web browsers without requiring polyfills. When using in browsers, make sure to include the library from CDN or bundle it with your application.

    https://pshenmic.github.io/dash-platform-sdk/index.html

    $ npm install dash-platform-sdk
    

    Alternatively, you could simply include the library from the CDN:

    https://unpkg.com/dash-platform-sdk/dist/main.js

    To use the SDK, simply import the library and instantiate an instance of DashPlatformSDK:

    // ES6 / EcmaScript
    import {DashPlatformSDK} from 'dash-platform-sdk'

    // CommonJS
    const {DashPlatformSDK} = require('dash-platform-sdk')

    const sdk = new DashPlatformSDK({network: 'testnet'})

    Or load it straight from the web page:

    <script src="https://unpkg.com/dash-platform-sdk/bundle.min.js"></script>
    <script>
    const {DashPlatformSDK} = window.DashPlatformSDK
    const sdk = new DashPlatformSDK.DashPlatformSDK({network: 'testnet'})
    </script>

    Now you're ready to make queries in the network and push your data!

    Before you start storing your data in the decentralized storage, you must provide the schema of your data contract. Very similar to traditional databases, you first define the schema, and then can start inserting data according the format you defined.

    https://docs.dash.org/projects/platform/en/stable/docs/protocol-ref/data-contract.html

    After you define your application schema, you may proceed to registering your data contract in the network:

    const owner = 'GARSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec' // identifier of your identity
    const identityNonce = await sdk.identities.getIdentityNonce(owner) // nonce

    const schema = {
    note: {
    type: 'object',
    properties: {
    message: { type: 'string', position: 0 }
    },
    additionalProperties: false
    }
    }

    // Create DataContractWASM instance
    const dataContract = await sdk.dataContracts.create(
    ownerIdentifier,
    identityNonce,
    schema,
    )

    // Turn it into StateTransitionWASM
    const stateTransition = await sdk.documents.createStateTransition(dataContract, 'create', identityNonce)

    // Broadcast in the network
    await sdk.stateTransitions.broadcast(stateTransition)

    After you have your Data Contract deployed in the network, you can start inserting your application data. This is done via creating a document in the network:

    const dataContractId = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'
    const ownerId = '9VSMojGcwpFHeWnAZzYxJipFt1t3mb34BWtHt8csizQS'
    const documentType = 'note'
    const revision = BigInt(1)

    const identityContractNonce = await sdk.docuemnts.getIdentityContractNonce(ownerId, dataContractId) // nonce

    const data = {
    "message": "Hello world!",
    }

    // Create DocumentWASM instance
    const document = await sdk.documents.create(dataContractId, documentType, data, ownerId, revision)

    // Turn it into StateTransitionWASM
    const stateTransition = await sdk.documents.createStateTransition(dataContract, 'create', identityContractNonce)

    // Broadcast transaction
    await sdk.stateTransitions.broadcast(stateTransition)

    It is possible to update your document if you wish to change the data in your document. This is done by creating a Document Replace Transition in the network:

    const dataContractId = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'
    const ownerId = '9VSMojGcwpFHeWnAZzYxJipFt1t3mb34BWtHt8csizQS'
    const documentType = 'note'

    // Get DocumentWASM from the network
    const [document] = await sdk.documents.query(
    dataContractId,
    documentType,
    [['ownerId', '==', ownerId]], // or any other query
    )

    // Get last identity contract nonce
    const identityContractNonce = await sdk.documents.query(ownerId, dataContractId) // nonce

    // Turn it into StateTransitionWASM
    const stateTransition = await sdk.documents.createStateTransition(document, 'replace', identityContractNonce + 1n)

    // Broadcast transaction
    await sdk.stateTransitions.broadcast(stateTransition)

    You can delete the document from the state, and it will not be longer available to query from DAPI.

    const dataContractId = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'
    const ownerId = '9VSMojGcwpFHeWnAZzYxJipFt1t3mb34BWtHt8csizQS'
    const documentType = 'note'
    const revision = BigInt(1)

    const identityContractNonce = await sdk.docuemnts.getIdentityContractNonce(ownerId, dataContractId) // nonce

    const data = {
    "message": "Hello world!",
    }

    // Create DocumentWASM instance
    const document = await sdk.documents.create(dataContractId, documentType, data, ownerId, revision)

    // Turn it into StateTransitionWASM
    const stateTransition = await sdk.documents.createStateTransition(dataContract, 'create', identityContractNonce)

    // Broadcast transaction
    await sdk.stateTransitions.broadcast(stateTransition)

    The full API documentation autogenerated by typedoc is available at GitHub Pages

    https://pshenmic.github.io/dash-platform-sdk/index.html

    Queries a DAPI for data contract and returns a DataContractWASM instance

    const dataContractIdentifier = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'

    const dataContract = await sdk.dataContracts.getByIdentifier(dataContractIdentifier)

    Create data contract from schema

    const ownerIdentifier = 'GARSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'
    const identityNonce = BigInt(11)

    const definitions = {
    def1: true
    }
    const schema = {
    note: {
    type: 'object',
    properties: {
    author: { type: 'string', position: 1 },
    message: { type: 'string', position: 0 }
    },
    additionalProperties: false
    }
    }

    const config = {
    $format_version: '0',
    canBeDeleted: true,
    readonly: false,
    keepsHistory: false,
    documentsKeepHistoryContractDefault: false,
    documentsMutableContractDefault: true,
    documentsCanBeDeletedContractDefault: true,
    requiresIdentityEncryptionBoundedKey: null,
    requiresIdentityDecryptionBoundedKey: null
    }

    // Optional: tokenConfiguration for creating token-based contracts
    const tokenConfiguration = {
    // token configuration properties
    }

    const dataContract = await sdk.dataContracts.create(
    ownerIdentifier,
    identityNonce,
    schema,
    definitions,
    true, // fullValidation
    tokenConfiguration, // optional
    config,
    )

    Create Data Contract Create Transition

    import { DataContractTransitionType } from 'dash-platform-sdk'

    const dataContract = // ... created data contract
    const identityNonce = BigInt(1)

    const transition = await sdk.dataContracts.createStateTransition(
    dataContract,
    'create',
    identityNonce
    )

    Create Data Contract Update Transition

    import { DataContractTransitionType } from 'dash-platform-sdk'

    const dataContract = // ... existing data contract with updates
    const identityNonce = BigInt(2)

    const transition = await sdk.dataContracts.createStateTransition(
    dataContract,
    'update',
    identityNonce
    )

    Creates a DocumentWASM instance that can be used for a state transition creation

    const dataContractId = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'
    const ownerId = '9VSMojGcwpFHeWnAZzYxJipFt1t3mb34BWtHt8csizQS'
    const documentType = 'domain'
    const data = {
    "label": "mydomain",
    "normalizedLabel": "mydomain",
    "normalizedParentDomainName": "dash",
    "records": {
    "dashUniqueIdentityId": ownerId
    }
    }
    const revision = BigInt(1) // optional, defaults to 1

    const document = await sdk.documents.create(dataContractId, documentType, data, ownerId, revision)

    console.log(document)

    Creates a DocumentWASM instance that can be used for a state transition creation

    // ...
    const document = sdk.documents.create(dataContract, documentType, data, identity)
    const identityContractNonce = await sdk.identities.getIdentityContractNonce(identity, dataContract)

    // 0.2 Dash typically
    const contestedFee = BigInt(20000000000)
    const indexName = 'parentNameAndLabel'

    const prefundedVotingBalance = { indexName, amount: contestedFee }

    const stateTransition = sdk.documents.createStateTransition(document, 'create', { identityContractNonce, prefundedVotingBalance })

    Some data contracts may define a cost for a document transition to be performed in the data contract.

    The token cost fee can be charged from either ContractOwner or Document Owner and it is specified in the data contract schema

    // ...
    const document = sdk.documents.create(dataContract, documentType, data, identity)
    const identityContractNonce = BigInt(1)

    const tokenPaymentInfo = {
    tokenContractId: '6hVQW16jyvZyGSQk2YVty4ND6bgFXozizYWnPt753uW5',
    tokenContractPosition: 0,
    minimumTokenCost: BigInt(1000),
    maximumTokenCost: BigInt(100000),
    gasFeesPaidBy: GasFeesPaidByWASM.ContractOwner
    }

    const stateTransition = sdk.documents.createStateTransition(document, 'create', { identityContractNonce, tokenPaymentInfo })

    Performs a query for documents and returns an array of DocumentWASM instances

    const dataContractId = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'
    const documentType = 'domain'
    const limit = 100
    const where = [['$ownerId', '==', ownerId]]
    const orderBy = [['$createdAt', 'desc']]

    // optional: pagination options (use only one)
    const startAt = document.id // for pagination
    const startAfter = document.id // for pagination

    const documents = await sdk.documents.query(
    dataContractId,
    documentType,
    where,
    orderBy,
    limit,
    startAt,
    startAfter
    )

    console.log(documents)

    This method allows creation of various document state transitions

    const document = // ... created or fetched document
    const identityContractNonce = BigInt(1)

    // Create transition
    const createTransition = await sdk.documents.createStateTransition(
    document,
    'create',
    identityContractNonce
    )

    // Replace transition
    const replaceTransition = await sdk.documents.createStateTransition(
    document,
    'replace',
    identityContractNonce
    )

    // Delete transition
    const deleteTransition = await sdk.documents.createStateTransition(
    document,
    'delete',
    identityContractNonce
    )

    // Purchase transition (requires price parameter)
    const purchaseTransition = await sdk.documents.createStateTransition(
    document,
    'purchase',
    identityContractNonce,
    { price: BigInt(100) }
    )

    // Transfer transition (requires recipient parameter)
    const transferTransition = await sdk.documents.createStateTransition(
    document,
    'transfer',
    identityContractNonce,
    { recipient: '8VSMojGcwpFHeWnAZzYxJipFt1t3mb34BWtHt8csizQS' }
    )

    // Update price transition (requires price parameter)
    const updatePriceTransition = await sdk.documents.createStateTransition(
    document,
    'updatePrice',
    identityContractNonce,
    { price: BigInt(200) }
    )

    This method allows to transfer a token to an identity

    const owner = 'HT3pUBM1Uv2mKgdPEN1gxa7A4PdsvNY89aJbdSKQb5wR'
    const recipient = '8GopLQQCViyroS2gHktesGaCMe2tueXWeQ6Y9vpMFTEC'
    const tokenId = '6niNoQpsT9zyVDJtXcbpV3tR3qEGi6BC6xoDdJyx1u7C'
    const amount = BigInt(10000)

    const privateKey = 'deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef'
    const publicKeyId = 5

    const tokenBaseTransition = await sdk.tokens.createBaseTransition(tokenId, owner)
    const stateTransition = sdk.tokens.createStateTransition(tokenBaseTransition, owner, 'transfer', { identityId: recipient, amount })

    stateTransition.signByPrivateKey(PrivateKeyWASM.fromHex(privateKey, 'testnet'), 'ECDSA_SECP256K1')
    stateTransition.signaturePublicKeyId = publicKeyId

    await sdk.stateTransitions.broadcast(stateTransition)

    Searches an identity by identifier (base58) and returns an IdentityWASM instance

    const identifier = 'QMfCRPcjXoTnZa9sA9JR2KWgGxZXMRJ4akgS3Uia1Qv'

    const identity = await sdk.identities.getIdentityByIdentifier(identifier)

    console.log(identity)
    const publicKeyHash = 'deadbeefdeadbeefdeadbeefdeadbeefdeadbeef'

    const identity = await sdk.identities.getIdentityByPublicKeyHash(publicKeyHash)

    console.log(identity)

    Returns the current balance in credits for a given Identity

    const identifier = 'QMfCRPcjXoTnZa9sA9JR2KWgGxZXMRJ4akgS3Uia1Qv'

    const balance = await sdk.identities.getIdentityBalance(identifier)

    console.log(balance) // BigInt value in credits

    Returns a current BigInt identity nonce for a given Identity

    const identifier = 'QMfCRPcjXoTnZa9sA9JR2KWgGxZXMRJ4akgS3Uia1Qv'

    const identityNonce = await sdk.identities.getIdentityNonce(identifier)

    console.log(identityNonce)

    Returns a current BigInt identity contract nonce for a given Identity and Data Contract

    const identifier = 'QMfCRPcjXoTnZa9sA9JR2KWgGxZXMRJ4akgS3Uia1Qv'
    const dataContractId = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'

    const identityContractNonce = await sdk.identities.getIdentityContractNonce(identifier, dataContractId)

    console.log(identityContractNonce)

    Return an array of IdentityPublicKeyWASM for a given identity if found

    const identifier = 'QMfCRPcjXoTnZa9sA9JR2KWgGxZXMRJ4akgS3Uia1Qv'

    const identityPublicKeys = await sdk.identities.getIdentityPublicKeys(identifier)

    console.log(identityPublicKeys)

    Creates a new Identity in blockchain and deposit it with the equivalent amount of credits sent from L1 chain.

    Requires Core chain AssetLock proof data.

    With InstantLock

    const assetLockPrivateKey = PrivateKeyWASM.fromHex('edd04a71bddb31e530f6c2314fd42ada333f6656bb853ece13f0577a8fd30612', 'testnet')
    const transaction = '03000800017dada5379e34ae1b59df35ba7acb879f3afaa12fa522f4b289a34d9fa2a68825010000006b48304502210093d609f65219e0d7ee694d271c4b7460ce89d298ef3e3670d5aef957e5551ead0220085d252e16cb3aae0d4e5d371e359e844fe82db93d8e4e26b5c61dc94676b7df0121037b86a1f7a11b4cc69fc7052e5cabdc625f3db47ee283ed4b87108f2cd879521effffffff0200e1f50500000000026a004054fa02000000001976a91416bbe230f46eea86fc4bf4dd550be45dc9adfcb488ac0000000024010100e1f505000000001976a914883bccdb8bfa44e55a19a1120ff2427537f7e92488ac'
    const instantLock = '01017dada5379e34ae1b59df35ba7acb879f3afaa12fa522f4b289a34d9fa2a688250100000060afc1323120f0a3b835dd113b3221e92dea56814369925f10dd3e8f6bcfaa6aa89ed4282521863d8eb72e7e0e7d80c86ca64cce9986ae8bb63657f43f0000009179b5d130fe69bd0f2ea7bc90e9ea904a7eeea515a2612045a70925a7c678b0b09499ea307575751e22f804c443d2e1105e1fd4e30aa894324a41cd983ffe58d5312ff8db11676bd530c6ab8af1f7d2980d356dd3c86d0386da7df70aa3a66b'
    const outputIndex = 0

    const privateKey1 = PrivateKeyWASM.fromHex('a1286dd195e2b8e1f6bdc946c56a53e0c544750d6452ddc0f4c593ef311f21af', 'testnet')
    const identityPublicKeyInCreation1: IdentityPublicKeyInCreation = {
    id: 0,
    purpose: Purpose.AUTHENTICATION,
    securityLevel: SecurityLevel.MASTER,
    keyType: KeyType.ECDSA_SECP256K1,
    readOnly: false,
    data: privateKey1.getPublicKey().bytes()
    }

    const privateKey2 = PrivateKeyWASM.fromHex('44a8195e242364b935e9d7ff2106ed109e9baf3800907f5e58a259fdfd1ca5e5', 'testnet')
    const identityPublicKeyInCreation2: IdentityPublicKeyInCreation = {
    id: 1,
    purpose: Purpose.AUTHENTICATION,
    securityLevel: SecurityLevel.HIGH,
    keyType: KeyType.ECDSA_SECP256K1,
    readOnly: false,
    data: privateKey2.getPublicKey().bytes()
    }
    let identityCreateStateTransition

    // Set identity public key signature for public key 0
    identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    transaction,
    instantLock,
    outputIndex,
    type: 'instantLock'
    }
    })
    identityCreateStateTransition.signByPrivateKey(privateKey1, KeyType.ECDSA_SECP256K1)
    identityPublicKeyInCreation1.signature = identityCreateStateTransition.signature

    // Set identity public key signature for public key 1
    identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    transaction,
    instantLock,
    outputIndex,
    type: 'instantLock'
    }
    })
    identityCreateStateTransition.signByPrivateKey(privateKey2, KeyType.ECDSA_SECP256K1)
    identityPublicKeyInCreation2.signature = identityCreateStateTransition.signature

    // Finalize
    identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    transaction,
    instantLock,
    outputIndex,
    type: 'instantLock'
    }
    })

    identityCreateStateTransition.signByPrivateKey(assetLockPrivateKey, KeyType.ECDSA_SECP256K1)

    With ChainLock

    const assetLockPrivateKey = PrivateKeyWASM.fromHex('edd04a71bddb31e530f6c2314fd42ada333f6656bb853ece13f0577a8fd30612', 'testnet')
    const txid = '61aede830477254876d435a317241ad46753c4b1350dc991a45ebcf19ab80a11'
    const outputIndex = 0
    const coreChainLockedHeight = 1337

    const privateKey1 = PrivateKeyWASM.fromHex('a1286dd195e2b8e1f6bdc946c56a53e0c544750d6452ddc0f4c593ef311f21af', 'testnet')
    const identityPublicKeyInCreation1: IdentityPublicKeyInCreation = {
    id: 0,
    purpose: Purpose.AUTHENTICATION,
    securityLevel: SecurityLevel.MASTER,
    keyType: KeyType.ECDSA_SECP256K1,
    readOnly: false,
    data: privateKey1.getPublicKey().bytes()
    }

    const privateKey2 = PrivateKeyWASM.fromHex('44a8195e242364b935e9d7ff2106ed109e9baf3800907f5e58a259fdfd1ca5e5', 'testnet')
    const identityPublicKeyInCreation2: IdentityPublicKeyInCreation = {
    id: 1,
    purpose: Purpose.AUTHENTICATION,
    securityLevel: SecurityLevel.HIGH,
    keyType: KeyType.ECDSA_SECP256K1,
    readOnly: false,
    data: privateKey2.getPublicKey().bytes()
    }

    let identityCreateStateTransition

    // Set identity public key signature for public key 0
    identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    txid,
    outputIndex,
    coreChainLockedHeight,
    type: 'chainLock'
    }
    })
    identityCreateStateTransition.signByPrivateKey(privateKey1, KeyType.ECDSA_SECP256K1)
    identityPublicKeyInCreation1.signature = identityCreateStateTransition.signature

    // Set identity public key signature for public key 1
    identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    txid,
    outputIndex,
    coreChainLockedHeight,
    type: 'chainLock'
    }
    })
    identityCreateStateTransition.signByPrivateKey(privateKey2, KeyType.ECDSA_SECP256K1)
    identityPublicKeyInCreation2.signature = identityCreateStateTransition.signature

    // Finalize
    identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    txid,
    outputIndex,
    coreChainLockedHeight,
    type: 'chainLock'
    }
    })

    identityCreateStateTransition.signByPrivateKey(assetLockPrivateKey, KeyType.ECDSA_SECP256K1)

    More detailed process can be seen in the Identity.spec.ts

    Deposits credits to the given Identity using AssetLock proof from Core chain

    Requires Core chain AssetLock proof data.

    With InstantLock

    const transaction = '03000800011a468e6a7cf1c5111b09b7bca6743f2571a9bf13d2ff6d21d3d230fd1dea1e97000000006b483045022100fceb25c45e77e1a273660e4f4c9a09042fb858a57704806e14bf80a734af232a02201929893dd720cf5855e31dda577cda16df29520a9774b4f3e813a4cc468fe086012103e16ede6dc5c99f28e3a5733f47a7494992bc6ce4f98551c092645910b9888b8fffffffff0200e1f50500000000026a004054fa02000000001976a91416bbe230f46eea86fc4bf4dd550be45dc9adfcb488ac0000000024010100e1f505000000001976a9147f78813975a3282e09e284d97d93c083b202e34188ac'
    const instantLock = '01011a468e6a7cf1c5111b09b7bca6743f2571a9bf13d2ff6d21d3d230fd1dea1e9700000000892304531821bcddfe960388f93e6e91bbae170987a5c6db33f0a4cf2d88ef148968a159512600791f94053e30f688aac43bf6e698fd78339a9ab5fd3b00000091ee77cadbf9683ca3d1fb1abcb2f561f0c745b26099fe5294885852a03a4f26770a3d437265f5f00ae21d0f681d0e1610a7ac47b6d463c3efdc5f7f922e310e6f3cd66c319e63e4f1c2cc70e97886e15485dba4f29b836bf55f0619837437e8'
    const outputIndex = 0

    const assetLockPrivateKey = PrivateKeyWASM.fromHex('3ca33236ab14f6df6cf87fcbb0551544fee7dcf4f251557af02c175725764a5a', 'testnet')
    const identityId = 'HT3pUBM1Uv2mKgdPEN1gxa7A4PdsvNY89aJbdSKQb5wR'

    const identityTopUpTransaction = sdk.identities.createStateTransition('topUp', {
    identityId,
    assetLockProof: {
    transaction,
    instantLock,
    outputIndex,
    type: 'instantLock'
    }
    })

    identityTopUpTransaction.signByPrivateKey(assetLockPrivateKey, undefined, KeyType.ECDSA_SECP256K1)

    With ChainLock

    const txid = '61aede830477254876d435a317241ad46753c4b1350dc991a45ebcf19ab80a11'
    const outputIndex = 0
    const coreChainLockedHeight = 1337

    const assetLockPrivateKey = PrivateKeyWASM.fromHex('3ca33236ab14f6df6cf87fcbb0551544fee7dcf4f251557af02c175725764a5a', 'testnet')
    const identityId = 'HT3pUBM1Uv2mKgdPEN1gxa7A4PdsvNY89aJbdSKQb5wR'

    const identityTopUpTransaction = sdk.identities.createStateTransition('topUp', {
    identityId,
    assetLockProof: {
    txid,
    outputIndex,
    coreChainLockedHeight,
    type: 'chainLock'
    }
    })

    identityTopUpTransaction.signByPrivateKey(assetLockPrivateKey, undefined, KeyType.ECDSA_SECP256K1)

    More detailed process can be seen in the Identity.spec.ts eate an Identity

    Creates a new Identity in blockchain and deposit it with the equivalent amount of credits sent from L1 chain.

    Requires Core chain AssetLock proof data.

    With InstantLock

    const assetLockPrivateKey = PrivateKeyWASM.fromHex('deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdead', 'testnet')
    const transaction = '03000800017dada5379e34ae1b59df35ba7acb879f3afaa12fa522f4b289a34d9fa2a68825010000006b48304502210093d609f65219e0d7ee694d271c4b7460ce89d298ef3e3670d5aef957e5551ead0220085d252e16cb3aae0d4e5d371e359e844fe82db93d8e4e26b5c61dc94676b7df0121037b86a1f7a11b4cc69fc7052e5cabdc625f3db47ee283ed4b87108f2cd879521effffffff0200e1f50500000000026a004054fa02000000001976a91416bbe230f46eea86fc4bf4dd550be45dc9adfcb488ac0000000024010100e1f505000000001976a914883bccdb8bfa44e55a19a1120ff2427537f7e92488ac'
    const instantLock = '01017dada5379e34ae1b59df35ba7acb879f3afaa12fa522f4b289a34d9fa2a688250100000060afc1323120f0a3b835dd113b3221e92dea56814369925f10dd3e8f6bcfaa6aa89ed4282521863d8eb72e7e0e7d80c86ca64cce9986ae8bb63657f43f0000009179b5d130fe69bd0f2ea7bc90e9ea904a7eeea515a2612045a70925a7c678b0b09499ea307575751e22f804c443d2e1105e1fd4e30aa894324a41cd983ffe58d5312ff8db11676bd530c6ab8af1f7d2980d356dd3c86d0386da7df70aa3a66b'
    const outputIndex = 0

    const identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    txid,
    instantLock,
    outputIndex,
    type: 'chainLock'
    }
    })

    With ChainLock

    const assetLockPrivateKey = PrivateKeyWASM.fromHex('deadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdead', 'testnet')
    const transaction = '03000800017dada5379e34ae1b59df35ba7acb879f3afaa12fa522f4b289a34d9fa2a68825010000006b48304502210093d609f65219e0d7ee694d271c4b7460ce89d298ef3e3670d5aef957e5551ead0220085d252e16cb3aae0d4e5d371e359e844fe82db93d8e4e26b5c61dc94676b7df0121037b86a1f7a11b4cc69fc7052e5cabdc625f3db47ee283ed4b87108f2cd879521effffffff0200e1f50500000000026a004054fa02000000001976a91416bbe230f46eea86fc4bf4dd550be45dc9adfcb488ac0000000024010100e1f505000000001976a914883bccdb8bfa44e55a19a1120ff2427537f7e92488ac'
    const instantLock = '01017dada5379e34ae1b59df35ba7acb879f3afaa12fa522f4b289a34d9fa2a688250100000060afc1323120f0a3b835dd113b3221e92dea56814369925f10dd3e8f6bcfaa6aa89ed4282521863d8eb72e7e0e7d80c86ca64cce9986ae8bb63657f43f0000009179b5d130fe69bd0f2ea7bc90e9ea904a7eeea515a2612045a70925a7c678b0b09499ea307575751e22f804c443d2e1105e1fd4e30aa894324a41cd983ffe58d5312ff8db11676bd530c6ab8af1f7d2980d356dd3c86d0386da7df70aa3a66b'
    const outputIndex = 0

    const identityCreateStateTransition = sdk.identities.createStateTransition('create', {
    publicKeys: [identityPublicKeyInCreation1, identityPublicKeyInCreation2],
    assetLockProof: {
    txid,
    outputIndex,
    coreChainLockedHeight,
    type: 'chainLock'
    }
    })

    More detailed process can be seen in the Identity.spec.ts

    This method allows you to manage public keys of your identity, such as creating and attaching new public keys to the Identity, or deleting one.

    const identityId = 'HT3pUBM1Uv2mKgdPEN1gxa7A4PdsvNY89aJbdSKQb5wR'
    const masterPrivateKey = PrivateKeyWASM.fromHex('16f614c6242580628d849e3616491dda1eccce99642a85667eb9a364dc85324a', 'testnet')
    const masterKeyId = 0

    const identity = await sdk.identities.getIdentityByIdentifier(identityId)

    const revision = identity.revision + BigInt(1)
    const identityNonce = await sdk.identities.getIdentityNonce(identityId) + BigInt(1)
    const keyId = identity.getPublicKeys()[identity.getPublicKeys().length - 1].keyId + 1
    const identityPrivateKey = PrivateKeyWASM.fromHex('16f614c6242580628d849e3616491dda1eccce99642a85667eb9a364dc85324a', 'testnet')

    const identityPublicKeyInCreation: IdentityPublicKeyInCreation = {
    id: keyId,
    purpose: Purpose.AUTHENTICATION,
    securityLevel: SecurityLevel.HIGH,
    keyType: KeyType.ECDSA_SECP256K1,
    readOnly: false,
    data: identityPrivateKey.getPublicKey().bytes()
    }

    let identityUpdateTransition = sdk.identities.createStateTransition('update', {
    identityId,
    revision,
    identityNonce,
    addPublicKeys: [identityPublicKeyInCreation]
    })
    identityUpdateTransition.signByPrivateKey(masterPrivateKey, masterKeyId, KeyType.ECDSA_SECP256K1)
    identityPublicKeyInCreation.signature = identityUpdateTransition.signature

    identityUpdateTransition = sdk.identities.createStateTransition('update', {
    identityId,
    revision,
    identityNonce,
    addPublicKeys: [identityPublicKeyInCreation]
    })

    identityUpdateTransition.signByPrivateKey(masterPrivateKey, masterKeyId, KeyType.ECDSA_SECP256K1)

    Broadcasts your state transition in the Dash Platform network

    const stateTransition = // ... created state transition

    await sdk.stateTransitions.broadcast(stateTransition)

    Waits for an execution of a state transition in the network

    const stateTransition = // ... created state transition

    await sdk.stateTransitions.waitForStateTransitionResult(stateTransition)
    const [document] = await sdk.names.search('xyz.dash')

    console.log(document)
    const status = await sdk.node.status()

    console.log(status.chain.latestBlockHash)
    console.log(status.time.epoch)
    // Base58 to bytes
    const base58String = 'GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec'
    const bytes = sdk.utils.base58ToBytes(base58String)

    // Bytes to Base58
    const base58 = sdk.utils.bytesToBase58(bytes)
    // Hex to bytes
    const hexString = 'deadbeef'
    const bytes = sdk.utils.hexToBytes(hexString)

    // Bytes to hex
    const hex = sdk.utils.bytesToHex(bytes)

    Converts a string to homograph-safe characters for DPNS names

    const str = 'alice'
    const normalizedString = sdk.utils.convertToHomographSafeChars(str) // al1ce

    Comprehensive node status information including version, chain, network, and time data.

    The SDK currently relies on a happy path and doesn't include comprehensive error handling. This will be improved in future versions. For now, wrap SDK calls in try-catch blocks:

    try {
    const identity = await sdk.identities.getIdentityByIdentifier('invalid-id')
    } catch (error) {
    console.error('Failed to fetch identity:', error)
    }