title |
---|
Local REST Server & REST API Quick Start |
Welcome to the Sui REST API quick start.
This document walks you through setting up your own local Sui REST Server and using the Sui REST API to interact with a local Sui network. This guide is useful for developers interested in Sui network interactions via API. For a similar guide on Sui network interactions via CLI, refer to the wallet documentation.
Full API documentation can be found on SwaggerHub.
Follow the instructions to install Sui binaries.
Follow the instructions to create and start the Sui network.
The genesis process will create a gateway.conf
configuration file, which will be used by the REST server.
Use the following command to start a local server:
rest_server
You will see output resembling:
INFO listening, local_addr: 127.0.0.1:5001
NOTE: For additional logs, set RUST_LOG=debug
before invoking rest_server
Export a local user variable to store the hardcoded hostname + port that the local REST server starts with to be used when issuing the curl commands that follow.
export SUI_GATEWAY_HOST=http://127.0.0.1:5001
In the following sections we will show how to use Sui's REST API using
the curl
command. You can also access it using
Postman which we describe in the Postman
setup section.
Retrieve OpenAPI documentation:
curl --location --request GET $SUI_GATEWAY_HOST/docs | json_pp
Synchronize client state with validators:
curl --location --request POST $SUI_GATEWAY_HOST/api/sync_account_state \
--header 'Content-Type: application/json' \
--data-raw '{
"address": "{{address}}"
}'
You should replace {{address}}
in the command above with an actual
address value, for example one obtained from wallet.conf
(without quotes).
This will fetch the latest information on all objects owned by each address that is managed by this server. This command has no output.
Return the list of objects owned by an address:
curl --location --request GET $SUI_GATEWAY_HOST'/api/objects?address={{address}}' | json_pp
You should replace {{address}}
in the command above with an actual
address value, you can retrieve the list of the addresses created during
genesis from wallet.conf
. Ensure you have run POST /api/sync_account_state
The output you see should resemble the following (abbreviated to show only two objects):
{
"objects" : [
{
"digest" : "0X4CjesLYhfXITheZHEasvmQXYrk92lvhUkxF7cKhvU=",
"objectId" : "75c660b4e115aa312b56d0e46898a1673a4649f3",
"version" : 0
},
{
"digest" : "zgfZRhRIzYGbadG3vYuF2I8MPDPPoJuEfEbj4nnW9hY=",
"objectId" : "84fb76c2ed58021ffdef956d9a6fd63852b2506d",
"version" : 0
},
...
}
Return the object information for a specified object, for example:
curl --location --request GET $SUI_GATEWAY_HOST'/api/object_info?objectId={{object_id}}' | json_pp
Replace {{object_id}}
in the command above with an
actual object ID, for example one obtained from GET /objects
(without quotes).
Return the schema for a specified object:
curl --location --request GET $SUI_GATEWAY_HOST'/object_schema?objectId={{object_id}}' | json_pp
Replace {{object_id}}
in the command above with an
actual object ID, for example one obtained from GET /objects
(without quotes).
curl --location --request POST $SUI_GATEWAY_HOST/api/new_transfer \
--header 'Content-Type: application/json' \
--data-raw '{
"fromAddress": "{{owner_address}}",
"objectId": "{{coin_object_id}}",
"toAddress": "{{to_address}}",
"gasObjectId": "{{gas_object_id}}",
"gasBudget" : 10000
}' | json_pp
A transaction data response will be returned from the gateway server.
{
"tx_bytes" : "VHJhbnNhY3Rpb25EYXRhOjoAACg4ZDZlMzM1ODIyYTA3MDk2MWUxZjU0ODk1OTEyZjViMzU0YjU1MzdkhPt2wu1YAh/975Vtmm/WOFKyUG0AAAAAAAAAACx6Z2ZaUmhSSXpZR2JhZEczdll1RjJJOE1QRFBQb0p1RWZFYmo0bm5XOWhZPSg4ZDZlMzM1ODIyYTA3MDk2MWUxZjU0ODk1OTEyZjViMzU0YjU1MzdkdcZgtOEVqjErVtDkaJihZzpGSfMAAAAAAAAAACwwWDRDamVzTFloZlhJVGhlWkhFYXN2bVFYWXJrOTJsdmhVa3hGN2NLaHZVPRAnAAAAAAAA"
}
sui signtool --address <owner_address> --data <tx_bytes>
The signing tool will create and print out the signature and public key information. You will see output resembling:
2022-04-04T21:42:44.915471Z INFO sui::sui_commands: Data to sign : VHJhbnNhY3Rpb25EYXRhOjoAACg4ZDZlMzM1ODIyYTA3MDk2MWUxZjU0ODk1OTEyZjViMzU0YjU1MzdkhPt2wu1YAh/975Vtmm/WOFKyUG0AAAAAAAAAACx6Z2ZaUmhSSXpZR2JhZEczdll1RjJJOE1QRFBQb0p1RWZFYmo0bm5XOWhZPSg4ZDZlMzM1ODIyYTA3MDk2MWUxZjU0ODk1OTEyZjViMzU0YjU1MzdkdcZgtOEVqjErVtDkaJihZzpGSfMAAAAAAAAAACwwWDRDamVzTFloZlhJVGhlWkhFYXN2bVFYWXJrOTJsdmhVa3hGN2NLaHZVPRAnAAAAAAAA
2022-04-04T21:42:44.915626Z INFO sui::sui_commands: Address : 8D6E335822A070961E1F54895912F5B354B5537D
2022-04-04T21:42:44.915915Z INFO sui::sui_commands: Public Key Base64: jAs+VmaKuEf4fpLNiLIHknEpft3zmy9b1v3AOYn/v4g=
2022-04-04T21:42:44.915919Z INFO sui::sui_commands: Signature : FULrl7iI1aQnb5OgCksYWJw6/Fv44wZZfeMXXN7CZJyooR2+Iu0WIVWUO61+r47aEidLeIewV8iLXFW7GPoYAw==
curl --location --request POST $SUI_GATEWAY_HOST/api/execute_transaction \
--header 'Content-Type: application/json' \
--data-raw '{
"tx_bytes": "{{tx_bytes}}",
"signature": "{{signature}}",
"pub_key": "{{public_key_base64}}"
}' | json_pp
Native transfer by POST /new_transfer
is supported for coin
objects only (including gas objects). Refer to
transactions documentation for
more information about a native transfer. Non-coin objects cannot be
transferred natively and require a Move call.
You should replace {{owner_address}}
and {{to_address}}
in the
command above with an actual address values, for example one obtained
from wallet.conf
. You should also replace
{{coin_object_id}}
and {{gas_object_id}}
in the command above with
an actual object ID, for example one obtained from objectId
in the output
of GET /objects
. You can see that all gas objects generated
during genesis are of Coin/SUI
type). For this call to work, objects
represented by both {{coin_object_id}}
and {{gas_object_id}}
must
be owned by the address represented by {{owner_address}}
.
the module of a given package (smart contracts in Sui are written in the Move language):
curl --location --request POST $SUI_GATEWAY_HOST/api/move_call \
--header 'Content-Type: application/json' \
--data-raw '{
"sender": "{{owner_address}}",
"packageObjectId": "0x2",
"module": "GAS",
"function": "transfer",
"args": [
"0x{{coin_object_id}}",
"0x{{to_address}}"
],
"gasObjectId": "{{gas_object_id}}",
"gasBudget": 2000
}' | json_pp
Follow the instructions to sign the transaction.
Follow the instructions to execute the transaction.
Arguments are passed in, and type will be inferred from function
signature. Gas usage is capped by the gas_budget. The transfer
function is described in more detail in
the Sui Wallet documentation.
Calling the transfer
function in the GAS
module serves the same
purpose as the native coin transfer (POST /api/transfer
), and is mostly used for illustration
purposes as native transfer is more efficient when it's applicable
(i.e., we are transferring coins rather than non-coin
objects). Consequently, you should fill out argument placeholders
({{owner_address}}
, {{coin_object_id}
, etc.) the same way you
would for POST /api/transfer
- please not additional
0x
prepended to function arguments.
NOTE: A Publish endpoint is in the works, but for now the only way to add a new module is to have it included as part of genesis. To do this, add your Move module to sui_programmability/framework/sources
before you hit the genesis endpoint. Once you have done this you will be able to use "packageObjectId": "0x2"
in the call endpoint to find your Move module.
To learn more about what args
are accepted in a Move call, refer to the SuiJSON documentation.
Publish Move module.
curl --location --request POST $SUI_GATEWAY_HOST/publish \
--header 'Content-Type: application/json' \
--data-raw '{
"sender": "{{owner_address}}",
"compiledModules": {{vector_of_compiled_modules}},
"gasObjectId": "{{gas_object_id}}",
"gasBudget": 10000
}' | json_pp
This endpoint will perform proper verification and linking to make sure the package is valid. If some modules have initializers, these initializers will also be executed in Move (which means new Move objects can be created in the process of publishing a Move package). Gas budget is required because of the need to execute module initializers.
You should replace {{owner_address}}
in the
command above with an actual address values, for example one obtained
from wallet.conf
. You should also replace {{gas_object_id}}
in the command above with
an actual object ID, for example one obtained from objectId
in the output
of GET /objects
. You can see that all gas objects generated
during genesis are of Coin/SUI
type). For this call to work, the object
represented by {{gas_object_id}}
must be owned by the address represented by
{{owner_address}}
.
To publish a Move module, you also need {{vector_of_compiled_modules}}
. To generate the value of this field, use the sui-move
command. The sui-move
command supports printing the bytecodes as base64 with the following option
sui-move --path <move-module-path> build --dump-bytecode-as-base64
Assuming that the location of the package's sources is in the PATH_TO_PACKAGE
environment variable an example command would resemble the following
sui-move --path $PATH_TO_PACKAGE/my_move_package build --dump-bytecode-as-base64
["oRzrCwUAAAAJAQAIAggUAxw3BFMKBV1yB88BdAjDAigK6wIFDPACQgAAAQEBAgEDAAACAAEEDAEAAQEBDAEAAQMDAgAABQABAAAGAgEAAAcDBAAACAUBAAEFBwEBAAEKCQoBAgMLCwwAAgwNAQEIAQcODwEAAQgQAQEABAYFBgcICAYJBgMHCwEBCAALAgEIAAcIAwABBwgDAwcLAQEIAAMHCAMBCwIBCAADCwEBCAAFBwgDAQgAAgsCAQkABwsBAQkAAQsBAQgAAgkABwgDAQsBAQkAAQYIAwEFAgkABQMDBwsBAQkABwgDAQsCAQkAAgsBAQkABQdNQU5BR0VEBENvaW4IVHJhbnNmZXIJVHhDb250ZXh0C1RyZWFzdXJ5Q2FwBGJ1cm4EaW5pdARtaW50DHRyYW5zZmVyX2NhcAtkdW1teV9maWVsZA9jcmVhdGVfY3VycmVuY3kGc2VuZGVyCHRyYW5zZmVyAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgACAQkBAAEAAAEECwELADgAAgEAAAAICwkSAAoAOAEMAQsBCwAuEQY4AgICAQAAAQULAQsACwI4AwIDAQAAAQQLAAsBOAQCAA==", "oRzrCwUAAAALAQAOAg4kAzJZBIsBHAWnAasBB9IC6QEIuwQoBuMECgrtBB0MigWzAQ29BgYAAAABAQIBAwEEAQUBBgAAAgAABwgAAgIMAQABBAQCAAEBAgAGBgIAAxAEAAISDAEAAQAIAAEAAAkCAwAACgQFAAALBgcAAAwEBQAADQQFAAIVCgUBAAIICwMBAAIWDQ4BAAIXERIBAgYYAhMAAhkCDgEABRoVAwEIAhsWAwEAAgsXDgEAAg0YBQEABgkHCQgMCA8JCQsMCw8MFAYPBgwNDA0PDgkPCQMHCAELAgEIAAcIBQILAgEIAwsCAQgEAQcIBQABBggBAQMEBwgBCwIBCAMLAgEIBAcIBQELAgEIAAMLAgEIBAMLAgEIAwEIAAEGCwIBCQACCwIBCQAHCwcBCQABCAMDBwsCAQkAAwcIBQELAgEJAAEIBAELBwEIAAIJAAcIBQELBwEJAAEIBgEIAQEJAAIHCwIBCQALAgEJAAMDBwsHAQkABwgFAQYLBwEJAAZCQVNLRVQHTUFOQUdFRARDb2luAklEA1NVSQhUcmFuc2ZlcglUeENvbnRleHQHUmVzZXJ2ZQRidXJuBGluaXQObWFuYWdlZF9zdXBwbHkEbWludApzdWlfc3VwcGx5DHRvdGFsX3N1cHBseQtkdW1teV9maWVsZAJpZAtWZXJzaW9uZWRJRAx0cmVhc3VyeV9jYXALVHJlYXN1cnlDYXADc3VpB21hbmFnZWQFdmFsdWUId2l0aGRyYXcPY3JlYXRlX2N1cnJlbmN5Bm5ld19pZAR6ZXJvDHNoYXJlX29iamVjdARqb2luAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAgMIAAAAAAAAAAAAAgEOAQECBA8IBhELBwEIABMLAgEIAxQLAgEIBAABAAAIFg4BOAAMBAsBCgAPADgBCgAPAQoECgI4AgwFCwAPAgsECwI4AwwDCwULAwIBAAAAEA8JEgAKADgEDAEKABEKCwEKADgFCwA4BhIBOAcCAgEAAAMECwAQAjgIAgMBAAAFHA4BOAkMBAoEDgI4CCEDDgsAAQsDAQcAJwoADwELATgKCgAPAgsCOAsLBAsADwALAzgMAgQBAAADBAsAEAE4CQIFAQAAAwQLABAAOA0CAQEBAgEDAA=="]
Build Successful
Copy the outputting base64 representation of the compiled Move module into the REST publish endpoint.
Follow the instructions to sign the transaction.
Follow the instructions to execute the transaction.
Below you can see a truncated sample output of POST /publish. One of the results of executing this command is generation of a package object representing the published Move code. An ID of the package object can be used as an argument for subsequent Move calls to functions defined in this package.
{
"package": [
"13e3ec7279060663e1bbc45aaf5859113fc164d2",
...
}
The recommended way to test the Sui REST API is to use Postman.
Postman is an API platform for building and using APIs. Postman provides an alternative solution to accessing APIs over issuing curl
commands in a terminal. You can use variables rather than copy-pasting addresses and object IDs for each call in a terminal. We have provided a sample Postman runbook for you to use.
Click Run in Postman, log in, import the collection into your workspace, and fire calls at the network.
Use:
- After clicking Run in Postman, create an account with Postman if you don't already have one. After doing so, you will be able to import the sample collection into your workspace.
- Running against localhost requires you to use the desktop version of Postman which is free to download.
- Our sample Postman runbook has test scripts set up to automatically strip the JSON response and set variables for future calls. (i.e. owner, gas_object_id, coin, object, to)
- Refer to Run in Postman documentation for more information on running the app.
- Refer to Postman documentation for more general usage information.
Coming soon - alternative ways of working with Sui's REST API. Connect to Sui devnet, testnet, or mainnet!