Skip to main content

invokescript Method

Returns the result after passing a script through the VM.

note
  • This method is to test your VM script as if they ran on the blockchain at that point in time. This RPC call does not affect the blockchain in any way.
  • You must install the plugin RpcServer before you can invoke the method.

Parameter Description#

  • script: A script runnable in the VM. This is the same script that is returned in invokefunction
  • signers: Optional. The list of contract signature accounts
    • account: signature account
    • scopes: signature's valid scopes, allowed values: FeeOnly, CalledByEntry, CustomContracts, CustomGroups, Global
    • allowedcontracts: contracts of the signature can take effect, if scopes is CustomContracts
    • allowedgroups: pubkeys of the signature can take effect, if scopes is CustomGroups

Example#

Request body:

{  "jsonrpc": "2.0",  "id": 1,  "method": "invokescript",  "params": [        "DAlqdXN0IHRlc3QRDBRWyI0UCtLMDykDfdEKfwBgorUoXAwU19eXMOJ4xtkG5uj2lb+th34/+pAUwB8MCHRyYW5zZmVyDBTPduKL0AYsSkeO41VhARMZ88+k0kFifVtS",    [         {          "account": "NfbEjVjhhpDsni716KVbuQWqSjVNHAUdTh",          "scopes": "CustomContracts",          "allowedcontracts":["0xd2a4cff31913016155e38e474a2c06d08be276cf","0xd2a4cff31913016155e38e474a2c06d08be276cf"],          "allowedgroups":[]        }    ]  ]}

Response body:

{    "jsonrpc": "2.0",    "id": 1,    "result": {        "script": "DAlqdXN0IHRlc3QRDBRWyI0UCtLMDykDfdEKfwBgorUoXAwU19eXMOJ4xtkG5uj2lb+th34/+pAUwB8MCHRyYW5zZmVyDBTPduKL0AYsSkeO41VhARMZ88+k0kFifVtS",        "state": "HALT",        "gasconsumed": "997796",        "exception": null,        "stack": [            {                "type": "Boolean",                "value": false            }        ]    }}
  • state: HALT means the vm executed successfully, andFAULT means the vm exited due to an exception.
  • gasconsumed: the system fee consumed for invocation.
  • stack: the contract execution result. If the value is String or ByteArray, it is encoded by Base64.