Skip to content

importmulti JSON-RPC command

importmulti "requests" ( "options" )

Import addresses/scripts (with private or public keys, redeem script (P2SH)), rescanning all addresses in one-shot-only (rescan can be disabled via options). Requires a new wallet backup.

Arguments

1. requests                                                         (json array, required) Data to be imported
     [
       {                                                            (json object)
         "scriptPubKey": "<script>" | { "address":"<address>" },    (string / json, required) Type of scriptPubKey (string for script, json for address)
         "timestamp": timestamp | "now",                            (integer / string, required) Creation time of the key in seconds since epoch (Jan 1 1970 GMT),
                                                                    or the string "now" to substitute the current synced blockchain time. The timestamp of the oldest
                                                                    key will determine how far back blockchain rescans need to begin for missing wallet transactions.
                                                                    "now" can be specified to bypass scanning, for keys which are known to never have been used, and
                                                                    0 can be specified to scan the entire blockchain. Blocks up to 2 hours before the earliest key
                                                                    creation time of all keys being imported by the importmulti call will be scanned.
         "redeemscript": "str",                                     (string, optional) Allowed only if the scriptPubKey is a P2SH address or P2SH scriptPubKey
         "pubkeys": [                                               (json array, optional) Array of strings giving pubkeys that must occur in the output or redeemscript
           "pubKey",                                                (string)
           ...
         ],
         "keys": [                                                  (json array, optional) Array of strings giving private keys whose corresponding public keys must occur in the output or redeemscript
           "key",                                                   (string)
           ...
         ],
         "internal": bool,                                          (boolean, optional, default=false) Stating whether matching outputs should be treated as not incoming payments aka change
         "watchonly": bool,                                         (boolean, optional, default=false) Stating whether matching outputs should be considered watched even when they're not spendable, only allowed if keys are empty
         "label": "str",                                            (string, optional, default='') Label to assign to the address, only allowed with internal=false
       },
       ...
     ]
2. options                                                          (json object, optional)
     {
       "rescan": bool,                                              (boolean, optional, default=true) Stating if should rescan the blockchain after all imports
     }

Note: This call can take over an hour to complete if rescan is true, during that time, other rpc calls
may report that the imported keys, addresses or scripts exists but related transactions are still missing.

Examples

> bitcoin-cli importmulti '[{ "scriptPubKey": { "address": "<my address>" }, "timestamp":1455191478 }, { "scriptPubKey": { "address": "<my 2nd address>" }, "label": "example 2", "timestamp": 1455191480 }]'
> bitcoin-cli importmulti '[{ "scriptPubKey": { "address": "<my address>" }, "timestamp":1455191478 }]' '{ "rescan": false}'

Response is an array with the same size as the input that has the execution result

  [{ "success": true } , { "success": false, "error": { "code": -1, "message": "Internal Server Error"} }, ... ]

Bitcoin Cash Node Daemon version v28.0.2-f57e7c8

Documentation on docs.bitcoincashnode.org reflects the current master branch in Git, and may include API changes that are not yet present in the latest release.