cosmos-sdk/cmd/baseserver/README.md

4.0 KiB

baseserver

baseserver is the REST counterpart to basecli

Compiling and running it

$ go get -u -v github.com/tendermint/basecoin/cmd/baseserver
$ baseserver init
$ baseserver serve --port 8888

to run the server at localhost:8888, otherwise if you don't specify --port, by default the server will be run on port 8998.

Supported routes

Route Method Completed Description
/keys GET ✔️ Lists all keys
/keys POST ✔️ Generate a new key. It expects fields: "name", "algo", "passphrase"
/keys/{name} GET ✔️ Retrieves the specific key
/keys/{name} POST/PUT ✔️ Updates the named key
/keys/{name} DELETE ✔️ Deletes the named key
/build/send POST ✔️ Send a transaction
/sign POST ✔️ Sign a transaction
/tx POST ✖️ Post a transaction to the blockchain
/seeds/status GET ✖️ Returns the information on the last seed
/build/create_role POST ✔️ Creates a role. Please note that the role MUST be valid hex for example instead of sending "role", send its hex encoded equivalent "726f6c65"

Preamble:

In the examples below, we assume that URL is set to http://localhost:8889 which can be set for example URL=http://localhost:8889

Sample usage

  • Generate a key
$ curl -X POST $URL/keys --data '{"algo": "ed25519", "name": "SampleX", "passphrase": "Say no more"}'
{
  "key": {
    "name": "SampleX",
    "address": "603EE63C41E322FC7A247864A9CD0181282EB458",
    "pubkey": {
      "type": "ed25519",
      "data": "C050948CFC087F5E1068C7E244DDC30E03702621CC9442A28E6C9EDA7771AA0C"
    }
  },
  "seed_phrase": "border almost future parade speak soccer bulk orange real brisk caution body river chapter"
}
  • Sign a key
$ curl -X POST $URL/sign --data '{
    "name": "matt",
    "password": "Say no more",
    "tx": {
        "type": "sigs/multi",
        "data": {
            "tx": {"type":"coin/send","data":{"inputs":[{"address":{"chain":"","app":"role","addr":"62616E6B32"},"coins":[{"denom":"mycoin","amount":900000}]}],"outputs":[{"address":{"chain":"","app":"sigs","addr":"BDADF167E6CF2CDF2D621E590FF1FED2787A40E0"},"coins":[{"denom":"mycoin","amount":900000}]}]}},
            "signatures": null
        }
    }
}'
{
  "type": "sigs/multi",
  "data": {
    "tx": {
      "type": "coin/send",
      "data": {
        "inputs": [
          {
            "address": {
              "chain": "",
              "app": "role",
              "addr": "62616E6B32"
            },
            "coins": [
              {
                "denom": "mycoin",
                "amount": 900000
              }
            ]
          }
        ],
        "outputs": [
          {
            "address": {
              "chain": "",
              "app": "sigs",
              "addr": "BDADF167E6CF2CDF2D621E590FF1FED2787A40E0"
            },
            "coins": [
              {
                "denom": "mycoin",
                "amount": 900000
              }
            ]
          }
        ]
      }
    },
    "signatures": [
      {
        "Sig": {
          "type": "ed25519",
          "data": "F6FE3053F1E6C236F886A0D525C1AF840F7831B6E50F7E1108C345AA524303920F09945DA110AD5184B3F45717D7114E368B12AFE027FECECC2FC193D4906A0C"
        },
        "Pubkey": {
          "type": "ed25519",
          "data": "0D8D19E527BAE9D1256A3D03009E2708171CDCB71CCDEDA2DC52DD9AD23AEE25"
        }
      }
    ]
  }
}
  • Create a role
$ curl -X POST $URL/build/create_role --data \
'{
  "role": "deadbeef",
  "signers": [{
    "addr": "4FF759D47C81754D8F553DCCAC8651D0AF74C7F9",
    "app": "role"
  }],
  "min_sigs": 1,
  "seq": 1
}'
{
  "type": "chain/tx",
  "data": {
    "chain_id": "test_chain_id",
    "expires_at": 0,
    "tx": {
      "type": "role/create",
      "data": {
        "role": "DEADBEEF",
        "min_sigs": 1,
        "signers": [
          {
            "chain": "",
            "app": "role",
            "addr": "4FF759D47C81754D8F553DCCAC8651D0AF74C7F9"
          }
        ]
      }
    }
  }
}