decodepsbt (22.0.0 RPC)

decodepsbt "psbt"

Return a JSON object representing the serialized, base64-encoded partially signed Bitcoin transaction.

Note that for Elements, PSBTs (or PSET) follow the Partially Signed Elements Transaction specification.

Arguments:
1. psbt    (string, required) The PSBT base64 string

Result:
{                                                         (json object)
  "tx" : {                                                (json object) The decoded network-serialized unsigned transaction.
    ...                                                   The layout is the same as the output of decoderawtransaction.
  },
  "global_xpubs" : [                                      (json array)
    {                                                     (json object)
      "xpub" : "str",                                     (string) The extended public key this path corresponds to
      "master_fingerprint" : "hex",                       (string) The fingerprint of the master key
      "path" : "str"                                      (string) The path
    },
    ...
  ],
  "tx_version" : n,                                       (numeric) The version number of the unsigned transaction. Not to be confused with PSBT version
  "fallback_locktime" : n,                                (numeric) The locktime to fallback to if no inputs specify a required locktime.
  "input_count" : n,                                      (numeric) The number of inputs in this psbt
  "output_count" : n,                                     (numeric) The number of outputs in this psbt.
  "inputs_modifiable" : n,                                (numeric) Whether inputs can be modified
  "outputs_modifiable" : n,                               (numeric) Whether outputs can be modified
  "sighash_single_indexes" : [                            (json array) The indexes which have SIGHASH_SINGLE signatures
    n,                                                    (numeric) Index of an input with a SIGHASH_SINGLE signature
    ...
  ],
  "psbt_version" : n,                                     (numeric) The PSBT version number. Not to be confused with the unsigned transaction version
  "scalar_offsets" : {                                    (json object) The PSET scalar elements
    "scalar" : "hex",                                     (string) A scalar offset stored in the PSET
    ...
  },
  "proprietary" : {                                       (json object) The global proprietary map
    "" : {                                                (json object)
      "identifier" : "hex",                               (string) The hex string for the proprietary identifier
      "subtype" : n,                                      (numeric) The number for the subtype
      "key" : "hex",                                      (string) The hex for the key
      "value" : "hex"                                     (string) The hex for the value
    }
  },
  "unknown" : {                                           (json object) The unknown global fields
    "key" : "hex",                                        (string) (key-value pair) An unknown key-value pair
    ...
  },
  "inputs" : [                                            (json array)
    {                                                     (json object)
      "non_witness_utxo" : {                              (json object, optional) Decoded network transaction for non-witness UTXOs
        ...
      },
      "witness_utxo" : {                                  (json object, optional) Transaction output for witness UTXOs
        "amount" : n,                                     (numeric) The value in BTC
        "scriptPubKey" : {                                (json object)
          "asm" : "str",                                  (string) The asm
          "hex" : "hex",                                  (string) The hex
          "type" : "str",                                 (string) The type, eg 'pubkeyhash'
          "address" : "str"                               (string)  Bitcoin address if there is one
        }
      },
      "partial_signatures" : {                            (json object, optional)
        "pubkey" : "str",                                 (string) The public key and signature that corresponds to it.
        ...
      },
      "sighash" : "str",                                  (string, optional) The sighash type to be used
      "redeem_script" : {                                 (json object, optional)
        "asm" : "str",                                    (string) The asm
        "hex" : "hex",                                    (string) The hex
        "type" : "str"                                    (string) The type, eg 'pubkeyhash'
      },
      "witness_script" : {                                (json object, optional)
        "asm" : "str",                                    (string) The asm
        "hex" : "hex",                                    (string) The hex
        "type" : "str"                                    (string) The type, eg 'pubkeyhash'
      },
      "bip32_derivs" : [                                  (json array, optional)
        {                                                 (json object, optional) The public key with the derivation path as the value.
          "master_fingerprint" : "str",                   (string) The fingerprint of the master key
          "path" : "str"                                  (string) The path
        },
        ...
      ],
      "final_scriptsig" : {                               (json object, optional)
        "asm" : "str",                                    (string) The asm
        "hex" : "str"                                     (string) The hex
      },
      "final_scriptwitness" : [                           (json array)
        "hex",                                            (string) hex-encoded witness data (if any)
        ...
      ],
      "previous_txid" : "hex",                            (string) TXID of the transaction containing the output being spent by this input.
      "previous_vout" : n,                                (numeric) Index of the output being spent
      "sequence" : n,                                     (numeric) Sequence number for this inputs
      "time_locktime" : n,                                (numeric) Required time-based locktime for this input
      "height_locktime" : n,                              (numeric) Required height-based locktime for this input
      "issuance_value" : n,                               (numeric) The explicit value of the issuance in this input in BTC
      "issuance_value_commitment" : "hex",                (string) The commitment of the value of the issuance in this input.
      "issuance_value_rangeproof" : "hex",                (string) The rangeproof for the value commitment of the issuance in this input.
      "blind_issuance_value_proof" : "hex",               (string) Explicit value rangeproof that proves the issuance value commitment matches the value
      "issuance_reissuance_amount" : n,                   (numeric) The explicit amount available for the reissuance output.
      "issuance_reissuance_amount_commitment" : "hex",    (string) The commitment of the reissuance amount.
      "issuance_reissuance_amount_rangeproof" : "hex",    (string) The rangeproof for the amount commitment of the reissuance amount.
      "blind_reissuance_amount_proof" : "hex",            (string) Explicit value rangeproof that proves the reissuance value commitment matches the reissuance value
      "issuance_blinding_nonce" : "hex",                  (string) The blinding nonce for the issuance in this input.
      "issuance_asset_entropy" : "hex",                   (string) The asset entropy for the issuance in this input.
      "pegin_bitcoin_tx" : "hex",                         (string) The tx providing the peg-in in the format of the getrawtransaction RPC
      "pegin_claim_script" : "hex",                       (string) The claim script for the peg-in input
      "pegin_txout_proof" : "hex",                        (string) The tx providing the peg-in input
      "pegin_genesis_hash" : "hex",                       (string) The hash of the genesis block for this peg-in
      "pegin_value" : n,                                  (numeric) The value of this peg-in.
      "pegin_witness" : [                                 (json array)
        "hex",                                            (string) hex-encoded witness data (if any)
        ...
      ],
      "utxo_rangeproof" : "hex",                          (string) The rangeproof for the UTXO
      "explicit_value" : n,                               (numeric, optional) The explicit value for this input
      "value_proof" : "hex",                              (string, optional) The explicit value proof for this input
      "explicit_asset" : "hex",                           (string, optional) The explicit asset for this input
      "asset_proof" : "hex",                              (string, optional) The explicit asset proof for this input
      "blinded_issuance" : true|false,                    (boolean, optional) Whether the issuance should be blinded prior to signing
      "unknown" : {                                       (json object) The unknown global fields
        "key" : "hex",                                    (string) (key-value pair) An unknown key-value pair
        ...
      },
      "proprietary" : {                                   (json object) The global proprietary map
        "" : {                                            (json object)
          "identifier" : "hex",                           (string) The hex string for the proprietary identifier
          "subtype" : n,                                  (numeric) The number for the subtype
          "key" : "hex",                                  (string) The hex for the key
          "value" : "hex"                                 (string) The hex for the value
        }
      }
    },
    ...
  ],
  "outputs" : [                                           (json array)
    {                                                     (json object)
      "redeem_script" : {                                 (json object, optional)
        "asm" : "str",                                    (string) The asm
        "hex" : "hex",                                    (string) The hex
        "type" : "str"                                    (string) The type, eg 'pubkeyhash'
      },
      "witness_script" : {                                (json object, optional)
        "asm" : "str",                                    (string) The asm
        "hex" : "hex",                                    (string) The hex
        "type" : "str"                                    (string) The type, eg 'pubkeyhash'
      },
      "bip32_derivs" : [                                  (json array, optional)
        {                                                 (json object)
          "pubkey" : "str",                               (string) The public key this path corresponds to
          "master_fingerprint" : "str",                   (string) The fingerprint of the master key
          "path" : "str"                                  (string) The path
        },
        ...
      ],
      "amount" : n,                                       (numeric) The amount (nValue) for this output
      "script" : {                                        (json object) The output script (scriptPubKey) for this output
        ...                                               The layout is the same as the output of scriptPubKeys in decoderawtransaction.
      },
      "value_commitment" : "hex",                         (string) The blinded value of the output
      "asset_commiment" : "hex",                          (string) The blinded asset id of the output
      "asset" : "hex",                                    (string) The explicit asset for the output
      "rangeproof" : "hex",                               (string) The rangeproof for the output
      "surjection_proof" : "hex",                         (string) The surjection proof for the output
      "ecdh_pubkey" : "hex",                              (string) The ecdh pubkey for the output
      "blinding_pubkey" : "hex",                          (string) The blinding pubkey for the output
      "blind_value_proof" : "hex",                        (string) Explicit value rangeproof that proves the value commitment matches the value
      "blind_asset_proof" : "hex",                        (string) Assert surjection proof that proves the assert commitment matches the asset
      "status" : "str",                                   (string) information about how the output has been blinded, if available
      "unknown" : {                                       (json object) The unknown global fields
        "key" : "hex",                                    (string) (key-value pair) An unknown key-value pair
        ...
      },
      "proprietary" : {                                   (json object) The global proprietary map
        "" : {                                            (json object)
          "identifier" : "hex",                           (string) The hex string for the proprietary identifier
          "subtype" : n,                                  (numeric) The number for the subtype
          "key" : "hex",                                  (string) The hex for the key
          "value" : "hex"                                 (string) The hex for the value
        }
      }
    },
    ...
  ],
  "fee" : n                                               (numeric, optional) The transaction fee paid if all UTXOs slots in the PSBT have been filled.
}

Examples:
> elements-cli decodepsbt "psbt"