How Can We Help?
Search for answers or browse our knowledge base.
How to use the GNY JavaScript API
API
The @gny/client acts as a wrapper for all HTTP endpoints and signs transactions

Account API
Open account
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.openAccount(publicKey);| Name | Type | Required | Description | 
|---|---|---|---|
| publicKey | string | N | gny account publicKey | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | Whether login is successful | 
| account | json | Account information | 
JSON Response Example:
{
  "account": {
    "address": "G2QEzc5BndQ2h6BsSNqimCWbSBV9L",
    "balance": '20000000000',
    "secondPublicKey": null,
    "lockHeight": '0',
    "lockAmount": '0',
    "isDelegate": 0,
    "username": null,
    "publicKey": "a87c7230d9ade987dbf612605aab652667e6303d2a1c6b2ec91a13733593bb75"
  },
  "latestBlock": {
    "height": 53,
    "timestamp": 3471490
  },
  "version": {
    "version": "1.0.0",
    "build": "Sun Feb 02 2020 19:42:18 GMT+0100 (Central European Standard Time)",
    "net": "testnet"
  }
}Get balance
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.getBalance(address);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | Client’s address | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | Whether request is successful | 
| count | integer | the number of balances owned by this address | 
| balances | Array | balance list of GNY | 
JSON Response Example:
{
  "count": 1,
  "balances":  [
  {
    "gny": "400000000000"
  }
  ]
}Get balance by address and currency
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.getAddressCurrencyBalance(
  address,
  currency
);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | Client’s address | 
| currency | string | Y | currency | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| balance | string | balance | 
JSON Response Example:
{
  "success": true,
  "balance": "0"
}Get the account by address
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.getAccountByAddress(address);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | Client’s address | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | whether response data can be returned | 
| account | json | account information | 
| latestBlock | json | latest block information | 
| version | json | version information | 
Get account by username
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.getAccountByUsername(username);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| username | string | Y | Client username | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | whether response data can be returned | 
| account | json | account information | 
| latestBlock | json | latest block information | 
| version | json | version information | 
Get voted delegates
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.getVotedDelegates(
  address,
  username
);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | Client’s address | 
| username | string | Y | Client username | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| delegates | Array | A list of (currently forging) delegates for which this account has voted for | 
JSON Response Example:
{
    "success": true,
    "delegates": [{
        "username": "wgl_002",
        "address": "GJX8DYKb7mF3M6JCUhBqYnLiha6y",
        "publicKey": "ae256559d06409435c04bd62628b3e7ea3894c43298556f52b1cfb01fb3e3dc7",
        "vote": 9901985415600500,
        "producedblocks": 1373,
        "missedblocks": 6,
        "rate": 1,
        "approval": "98.54",
        "productivity": "99.56"
    },
    {
        "username": "wgl_003",
        "address": "G318FKKb7mF3M6JCUhBqYnLiha6y",
        "publicKey": "c292db6ea14d518bc29e37cb227ff260be21e2e164ca575028835a1f499e4fe2",
        "vote": 9891995435600500,
        "producedblocks": 1371,
        "missedblocks": 8,
        "rate": 2,
        "approval": "98.44",
        "productivity": "99.41"
    },
    {
        "username": "wgl_001",
        "address": "1869971419039689816",
        "publicKey": "c547df2dde6cbb4508aabcb5970d8f9132e5a1d1c422632da6bc20bf1df165b8",
        "vote": 32401577128413,
        "producedblocks": 969,
        "missedblocks": 8,
        "rate": 102,
        "approval": "0.32",
        "productivity": 0
    }]
}Count the number of accounts
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.countAccounts();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| count | number | the total number of accounts | 
Get publicKey
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Account.getPublicKey(address);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | Client’s address, minimum length:1 | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| publicKey | string | public key | 
Block API
Get block by id
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getBlockById(id);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| id | string | Y | block id | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| block | json | the block detail information | 
JSON Response Example:
{
  "block":{
    "version":0,
    "payloadHash":"3d2215b8d226b5a38ace219d0ab3f4d84830fd54a832dc05540e20ef81a00547",
    "timestamp":0,
    "delegate":"61ca23509390845f06ccaa43384e889074dfd0c821e4ba3894f8e62b6a31895a",
    "height":"0",
    "count":203,
    "fees":"0",
    "reward":"0",
    "signature":"d49b0d08b164c8df402dc1f24430d51126a05a9d1c4012fbdf89272ab95740454b11fd4b44dbf7c60d4757760d8015146433ae21e2e418fd0d7b3aa03adc5503",
    "id":"fed53e3ad0a1405f73122708ee53dfed2e9eccc34693d52043bdb6aec4751a8c"
  }
}Get block by height
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getBlockByHeight(height);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| height | string | Y | block height | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| block | json | the block detail information | 
Get blocks
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getBlocks(
  offset,
  limit,
  orderBy,
  transactions
);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| limit | integer | N | maximum number of returned records, between 0 and 100 | 
| offset | integer | N | default is 0 | 
| orderBy | string | N | sort by a field in the table, for example, specify height:descto sort descending, default isheight:asc. You can only sort by theheightproperty | 
| transactions | boolean | N | When transactions=true then | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| blocks | Array | a list of JSON objects containing block detail | 
| count | integer | block height | 
JSON Response Example:
{"count":56,
"blocks":[
  {
    "version":0,
    "delegate":"ee9191dff690c0a5b74bba5ab4bddeff60042154d66f2d5c7111123ae8cb4396",
    "height":"55",
    "prevBlockId":"f8d9d54ab0fbbeec1063472a9296e24e8336866de3b0ad5d514fd92ddc73b539",
    "timestamp":3621850,
    "count":0,
    "fees":"0",
    "payloadHash":"e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
    "reward":"0",
    "signature":"81b0090adc75346c8985ebe2c6341ba36eeb4b48a2a66ec69b701d55e35577f0dbdd5a633627098a7a64cb81dd1a9d6fbf13f7c0983fd162f46ef12c5468840f",
    "id":"e70c0b569ca877d262dadcd1967a02427a9996d8c189ee32b7c8bcff7fa3cff2"
  },
  {
    "version":0,
    "delegate":"adc2fdf3174278b2d88f9a37d795fb720ab7530f72367e0aae863143b4b90259",
    "height":"54",
    "prevBlockId":"c3e75c7862a7cbe7f1933837704700bd158c2bd9fc6d1228327323003a0cdd15",
    "timestamp":3620770,
    "count":0,
    "fees":"0",
    "payloadHash":"e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
    "reward":"0",
    "signature":"a17bf15385b65dd84e94a7be6ccd635dc291f63b8128dd4951f7544fafa0632fc281e70dd597ae2770b228bdb581fd182f98fda7dc4a2d82cf8e94ff344ef604",
    "id":"f8d9d54ab0fbbeec1063472a9296e24e8336866de3b0ad5d514fd92ddc73b539"
  }
]}Get block height
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getHeight();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| height | string | block height | 
JSON Response Example:
{
  "success":true,
  "height": "140569"
}Get milestone
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getMilestone();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| milestone | integer | 
JSON Response Example:
{
  "success":true,
  "milestone":0
}Get reward information of a block
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getReward();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| reward | integer | the reward of the block | 
JSON Response Example:
{
  "success":true,
  "reward":200000000
}Get current maximum supply of the blockchain
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getSupply();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| supply | integer | the total amount of XAS in the whole network | 
JSON Response Example:
{
  "supply":"10000000000000000"
}Get current status of blockchain
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Block.getStatus();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| height | string | blockchain height | 
| fee | string | transaction fee | 
| milestone | integer | |
| reward | integer | block reward | 
| supply | BigNumber | total amount of XAS in the whole network | 
JSON Response Example:
{
  "height":"11",
  "fee":"10000000",
  "milestone":0,
  "reward":0,
  "supply":"10000000000000000"
}Delegate
Count the number of delegates
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.count();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| count | integer | total number of delegates | 
JSON Response Example:
{
    "success":true,
    "count":234
}Get the voters by username
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.getVoters(username);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| username | string | Y | username of the delegate | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| accounts | Array | a JSON object list of account | 
JSON Response Example:
{
    "success": true,
    "accounts": [{
        "address": "G3kkkSaJNVY87AhVPyxXVGFpR61VB",
        "publicKey": "85b4c2efe56642398dad3f1ec338e87e712063cfaee4a836cb58b673cdb820f4",
        "balance": "1338227722727",
        "weight": 0.013316660647014596
    },
    {
        "address": "GmCQ2xoGv5bWWtaxQfiBNuTUvaoe",
        "publicKey": "fffd516f0748ead6720440e94da58ed3afd686b546f5d36a3c5b52cfed834371",
        "balance": "2109297623765",
        "weight": 0.020989552213127274
    }]
}Get own votes with username or address
Get votes with username:
import { Connection } from "@gny/client";
const params = { username: "a1300" };
const connection = new Connection();
const result = await connection.api.Delegate.getOwnVotes(params);Get votes with address:
import { Connection } from "@gny/client";
const params = { address: "GtnevSTQqPUcZNAMFJmc8DLUXHFz" };
const connection = new Connection();
const result = await connection.api.Delegate.getOwnVotes(params);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| username | string | N | username of the account | 
| address | string | N | address of the account | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| delegates | Array | a JSON object list of account | 
JSON Response Example:
{
   "success":true,
   "delegates":[
      {
         "address":"G3yguB3tazFf6bia3CU1RjXtv2iV6",
         "username":"gny_d72",
         "tid":"ce6fced7d207e7e55f92a3b68a2394f34b2404cba5c35ea31bf80d2bc871efd5",
         "publicKey":"feda901bb63e494e2f30865734e40aa0464f59f2a526a61648c86ba2faf1a952",
         "votes":"900000000000",
         "producedBlocks":"0",
         "missedBlocks":"0",
         "fees":"0",
         "rewards":"0",
         "_version_":2,
         "rate":1,
         "approval":"0.00225",
         "productivity":"100.00"
      },
      {
         "address":"GtZDocCVQ6iNR6JzjPCqgJPzmoRN",
         "username":"gny_d58",
         "tid":"aeb8ae1404985bb38c18d695ce9c336b65382c94fa85d38db3d575f03d3ff84f",
         "publicKey":"fbc95173f63a02239ff37f81236e283504d247d551143d16c2fee80c692b25bd",
         "votes":"900000000000",
         "producedBlocks":"1",
         "missedBlocks":"0",
         "fees":"0",
         "rewards":"0",
         "_version_":3,
         "rate":2,
         "approval":"0.00225",
         "productivity":"100.00"
      }
   ]
}Get delegate by public key
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.getDelegateByPubKey(publicKey);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| publickey | string | Y | delegate’s public key | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| delegate | JSON | the detail information of this delegate | 
JSON Response Example:
{
  "delegate":{
    "address":"G3kkkSaJNVY87AhVPyxXVGFpR61VB",
    "username":"gny_d1",
    "transactionId":"156c950d69dda92214fa26d37baff860990fad43d40ba74a342fabf9adaaa2dc",
    "publicKey":"85b4c2efe56642398dad3f1ec338e87e712063cfaee4a836cb58b673cdb820f4",
    "votes":"0",
    "producedBlocks":"0",
    "missedBlocks":"0",
    "fees":"0",
    "rewards":"0",
    "_version_":1,
    "rate":47,
    "approval":"0",
    "productivity":"0.00",
    "vote":0,
  }
}Get delegate by user name
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.getDelegateByUsername(username);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| username | string | Y | delegate’s user name | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| delegate | JSON | the detail information of this delegate | 
Get delegate by address
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.getDelegateByAddress(address);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | delegate’s address | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| delegate | JSON | the detail information of this delegate | 
Get the list of Delegates
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.getDelegates(offset, limit);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| offset | int | N | maximum return records | 
| limit | integer | N | offset, minimum: 0 | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| delegates | Array | a list containing delegates’ detail information | 
| totalCount | number | How many delegates exist overall? | 
JSON Response Example:
{
  "totalCount":101,
  "delegates":[{
    "address":"G3kkkSaJNVY87AhVPyxXVGFpR61VB",
    "username":"gny_d1",
    "transactionId":"156c950d69dda92214fa26d37baff860990fad43d40ba74a342fabf9adaaa2dc",
    "publicKey":"85b4c2efe56642398dad3f1ec338e87e712063cfaee4a836cb58b673cdb820f4",
    "votes":"0",
    "producedBlocks":"0",
    "missedBlocks":"0",
    "fees":"0",
    "rewards":"0",
    "_version_":1,
    "rate":47,
    "approval":"0",
    "productivity":"0.00",
    "vote":0,
  },
  {
    "address":"G94UbHjRnd6Em1o3FxQAqkMXA2RV",
    "username":"gny_d10",
    "transactionId":"9f9a6818b467dcc73c71c24ff622babeb63850263626dfc7472c1f87f58ebbe9",
    "publicKey":"ff47c9e9bafcf28ae8528c2b259661ade96a3030ab73ddde82b52ee44c9122b5",
    "votes":"0",
    "producedBlocks":"0",
    "missedBlocks":"0",
    "fees":"0",
    "rewards":"0",
    "_version_":1,
    "rate":2,
    "approval":0,
    "productivity":"0.00",
    "vote":0,
  }
]}Enable forging
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.forgingEnable(secret, pulicKey);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| secret | string | Y | gny account password | 
| publickey | string | Y | delegate’s public key | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
Disable forging
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.forgingDisable(secret, pulicKey);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| secret | string | Y | gny account password | 
| publickey | string | Y | delegate’s public key | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
Get forging status
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Delegate.forgingStatus(pulicKey);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| publickey | string | Y | delegate’s public key | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| enabled | bool | true: forging is enabled | 
Loader
Get blockchain status
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Loader.getStatus();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| loaded | bool | true: the blockchain is loaded successfully | 
Sync blockchain status
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Loader.getStatus();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| syncing | bool | true: the blockchain is syncing | 
| blocks | number | the number of blocks to be synced | 
| height | string | the height of last block | 
Peer
Get peers
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Peer.getPeers();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| peers | Array | A list of peer information | 
| count | bool | The number of peers | 
JSON Response Example:
{
  "success": true,
  "peers": [
    {
      "id": {
        "id": "QmeDn2SETzxuENnAiynzWXjw78eDRiNLmwzNDtwb2XhVsi",
        "pubKey": "CAASpgIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDo9QnqRUmrO3uAqyoAAnjmDB7+lCSA9a7tAKv0vsq0fnq0/espA70e7sJZSjmHqOpP5Jyse3pjezMfSsBR80vQJheb0dOwCsZu/dJ2kA0nuXRZwOd7ZUUsRUh5oj5NFBrY3tuScq/HtbXDqMs0MZdlKIBkEseTnF1rLZw8fhIiY3AFwlJFUCNGKyrk2rk6IvrwMWshyBkr+r1pPfGp6W46/fw5gwdvRTgxCvmqkQq35uncosBbV2+lAimvviTfT7NR6SuLdkAb5TqC0kh7XJV2eu44TtHwI/rTQw0lfCg/WnRKA+uFyedeg3BcTzqjdnhkxP8v7KAMnxi8Z/3q50jbAgMBAAE="
      },
      "multiaddrs": [
        "/ip4/13.80.136.143/tcp/4097/p2p/QmeDn2SETzxuENnAiynzWXjw78eDRiNLmwzNDtwb2XhVsi"
      ],
      "simple": {
        "host": "13.80.136.143",
        "port": 4097
      }
    },
    {
      "id": {
        "id": "QmPiFnYYNeuYBxqzA77bPPrpJ8AaGJQujMVFXYJEGbpMRR",
        "pubKey": "CAASpgIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDghE7wWvJxLW2KFTgfaBQ6Yh5hpSrxZqlOu/M4kWFcZ87S81053So92CCcTLdJPaE6mvip3/PTHpzzvfsiEhk7/1oTHDonKjbx44L39dqzvVht+q8LyU3XYo8qw6mJd4Ry69+89V1RmgJGdEtR+G2sBQxZ/m+subcHKfy6jvG2Zw8BkJdcyjlAXaH4mw9ZO5lkrN8E0aI32GwipVBu37Wts7ZYIcJxZ9zxGGVwNb7B8Utq2DVSpmqguM9M1DsBDJZ+yZg3vF435zLcmMS7eRLCB0PIXrZ5HPYsDKk/FMyF3sDy05xtGTUgF75L7zeMYxoEUg6BtgM9HV5T2cWtcDDXAgMBAAE="
      },
      "multiaddrs": [
        "/ip4/174.129.53.40/tcp/4097/p2p/QmPiFnYYNeuYBxqzA77bPPrpJ8AaGJQujMVFXYJEGbpMRR"
      ],
      "simple": {
        "host": "174.129.53.40",
        "port": 4097
      }
    }
  ],
  "count": 2
}Get version
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Peer.getVersion();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| version | string | Version of blockchain | 
| build | string | Build version | 
| net | string | Net version | 
JSON Response Example:
{
  "success": true,
  "version": "1.0.5",
  "build": "Tue Jan 28 2020 12:44:42 GMT+0000 (Coordinated Universal Time)",
  "net": "localnet"
}Get info
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Peer.getInfo();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| id | string of peerId | libp2p peer-id | 
| multiaddrs | string[] | Array of multiaddrs strings which is used for p2p communcation | 
| publicIp | string | own public ip | 
| address | string | ip address on which the server is listening. Normal this is a private ip address | 
JSON Response Example:
{
  "success": true,
  "id": "QmQbVdde9AeXSP3FoLyVNd3Fi3BjCe2tFyJV43bNWEBYSA",
  "multiaddrs": [
    "/ip4/20.188.42.0/tcp/4097/p2p/QmQbVdde9AeXSP3FoLyVNd3Fi3BjCe2tFyJV43bNWEBYSA"
  ],
  "publicIp": "20.188.42.0",
  "address": "10.0.3.4"
}System
Get version
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.System.getSystemInfo();Request Parameter Description: none
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| os | string | Operating system information | 
| version | string | Version of blockchain | 
| timestamp | string | the time right now | 
| lastBlock | json | Basic information about last block | 
Transaction
Get transactions
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Transaction.getTransactions(query);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| query.limit | integer | N | the limitation of returned records,minimum:0,maximum:100 | 
| query.offset | integer | N | offset, minimum 0 | 
| query.id | string | N | transaction id | 
| query.senderId | N | GNY address of sender | |
| query.senderPublicKey | string | N | sender’s public key | 
| query.blockId | string | N | block id | 
| query.height | integer | specific block height | |
| query.type | interger | N | Transaction type, see https://github.com/GNYIO/gny-general/wiki/Transactions for futher information | 
| query.message | string | Transaction message | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| transactions | Array | A JSON object list containing multiple transactions’ detail | 
| count | int | the total number of retrieved transactions | 
JSON Response Example:
{
  "transactions":[
    {
      "transactionId":"42254052d4bc1e1132c316469194e6b756a6c0f086a24b00c05a91ced5502046",
      "senderId":"G25AKCRu8mK2b4QXq8Jk8bFiNfxeY",
      "recipientId":"G2MdtJJPCWTFGZ75QoP7Z5KowRhst",
      "recipientName":null,
      "currency":"gny",
      "amount":"10000000000000000",
      "timestamp":0,
      "height":"0",
      "_version_":1
    }
  ],
  "count":1
}Get unconfirmed transactions by transaction id
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Transaction.getUnconfirmedTransaction(id);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| id | string | Y | unconfirmed transaction id | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| transaction | json | unconfirmed transaction detail inforamtion | 
JSON Response Example:
{
  "transactionId":"42254052d4bc1e1132c316469194e6b756a6c0f086a24b00c05a91ced5502046",
  "senderId":"G25AKCRu8mK2b4QXq8Jk8bFiNfxeY",
  "recipientId":"G2MdtJJPCWTFGZ75QoP7Z5KowRhst",
  "recipientName":null,
  "currency":"gny",
  "amount":"10000000000000000",
  "timestamp":0,
  "height":"0",
  "_version_":1
}Get unconfirmed transactions by sender public key or address
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Transaction.getUnconfirmedTransaction(
  publicKey,
  address
);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| senderPublicKey | string | N | sender’s public key | 
| address | string | N | address | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| transactions | Array | a list containing all unconfirmed transactions | 
JSON Response Example:
{
    "success": true,
    "transactions": []      //Currently there is no unconfirmed transaction in the whole network
}Create a batch of transactions
import { Connection } from "@gny/client";
const connection = new Connection();
const genesisSecret =
  "grow pencil ten junk bomb right describe trade rich valid tuna service";
const trs = gnyClient.basic.transfer(
  "GuQr4DM3aiTD36EARqDpbfsEHoNF",
  50 * 1e8,
  undefined,
  genesisSecret,
  undefined
);
const transactions = [trs];
const result = await connection.api.Transaction.addTransactions(transactions);| Request Parameter Description: | Name | Type | Required | Description | 
|---|---|---|---|---|
| transactions | Array | Y | Array of transactions | 
JSON Response Example:
{
  "success": true,
  "transactions": [
    {
      "type": 0,
      "timestamp": 3619538,
      "fee": 10000000,
      "args": [
        5000000000,
        "GuQr4DM3aiTD36EARqDpbfsEHoNF"
      ],
      "senderPublicKey": "575bf8f32b941b9e6ae1af82539689198327b73d77d22a98cdef2460c9257f7b",
      "senderId": "G4GDW6G78sgQdSdVAQUXdm5xPS13t",
      "signatures": [
        "5fd14364bed18697f9c9ec1e03d66825af2cc9e716d5f6089dc265d99d5d6f3a79b778a48733e06b1353ea007036455ab4b9f0d4a3035a343584c4fb137e1400"
      ],
      "id": "0bd53c3a60b6746e4383dbafa8f63f2eaea7e167e0e754cbf9aaf419b3cb2eef"
    }
  ]
}Transfer
Get transfers
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Transfer.getRoot(query);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| query.limit | integer | N | the limitation of returned records,minimum:0,maximum:100 | 
| query.offset | integer | N | offset, minimum 0 | 
| query.ownId | string | N | public key related to transfers | 
| query.currency | string | N | gny UIA Assets | 
| query.senderId | string | N | GNY address of sender | 
| query.recipientId | string | N | recipient’s public key | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| count | string | the number of transfers | 
| transfers | Array | An array of transfers | 
Get total amount of transfers
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Transfer.getAmount(
  startTimestamp,
  endTimestamp
);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| startTimestamp | string | Y | start timestamp | 
| endTimestamp | string | Y | end timestamp | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| count | string | the number of transfers | 
| strTotalAmount | string | the total amout of transfers | 
Transport
Send unconfirmed transaction
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Transport.sendTransaction(transaction);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| transaction | json | Y | Unconfirmed transction | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | true: response data return successfully | 
| transactionId | string | transaction id | 
User Defined Asset UIA
Get all publishers
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getIssuers(limit, offset);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| limit | integer | N | maximum number of records to return, between 0 and 100 | 
| offset | integer | N | Offset, minimum 0 | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | true: response data return successfully | 
| issues | Array | Array of publishers | 
| count | integer | Total number of publishers | 
JSON Response:
{
  "count":1,
  "issues":[{
      "tid":"279ee5d155f25bd5eb7f09b63a6e096b89e22ff70b5b8a9858cfd19dc21149d3",
      "name":"AAA",
      "issuerId":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
      "desc":""some description"",
      "_version_":1
  }]
}Check if the address is a publisher
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.isIssuer(address);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | Can be the GNY account address | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | true: response data return successfully | 
| isIssuer | boolean | true: the address is an issuer | 
| issuerName | string | the publisher name | 
JSON Response:
{
  "success": true,
  "isIssuer": true,
  "issuerName": "AAA"
}Query information about a publisher
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getIssuer(publisherName | address);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| publisherName | string | Y | Can be GNY publisher name | 
| address | string | Y | Can be the GNY account address | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | Whether operation was successful | 
| issuer | JSON | Contains the publisher name, description and id (GNY address) | 
JSON Response:
{
  "issuer":{
    "tid":"c194bf2d4ccb1d07829f161165b307332d91a14f44a71a7a99a28dea8154e524",
    "name":"AAA",
    "issuerId":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
    "desc":""some description"",
    "_version_":1
  }
}View assets of a specified publisher
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getIssuerAssets(name, limit?, offset?);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| name | string | Y | Can be GNY publisher name | 
| limit | integer | N | maximum number of records to return, between 0 and 100 | 
| offset | integer | N | Offset, minimum 0 | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | true: response data return successfully | 
| assets | Array | Array of assets | 
| count | interger | The total number of assets registered by the publisher | 
JSON Response:
{
  "count":1,
  "assets":[{
    "tid":"4316b799601e15831bbd8514862e61b6b67754b8971938f90025723d1be9eb67",
    "name":"AAA.BBB",
    "timestamp":3714160,
    "maximum":"1000000000",
    "precision":8,
    "quantity":"500000000",
    "desc":"some description",
    "issuerId":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
    "_version_":2
  }]
}Get all assets
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getAssets(limit, offset);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| limit | integer | N | maximum number of records to return, between 0 and 100 | 
| offset | integer | N | Offset, minimum 0 | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | true: response data return successfully | 
| assets | Array | Array of assets | 
| count | integer | Number of all assets | 
JSON Response:
{
  "count":1,
  "assets":[{
    "tid":"44fd0eff16f2a39be263a3b77f34145c7039b16790265feef74c52538eff9cde",
    "name":"AAA.BBB",
    "timestamp":3714682,
    "maximum":"1000000000",
    "precision":8,
    "quantity":"500000000",
    "desc":"some description",
    "issuerId":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
    "_version_":2
  }]
}Get specified asset information
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getAsset(name);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| name | string | Y | Asset name | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | true: response data return successfully | 
| asset | JSON | Contains asset name, description, cap, precision, current circulation, issue height, publisher id | 
JSON Response:
{
  "asset":{
    "tid":"92bf426d9a517a35ac6a63ef210d0f062f5195b636f35878e949e7581355d5b8",
    "name":"AAA.BBB",
    "timestamp":3717011,
    "maximum":"1000000000",
    "precision":8,
    "quantity":"500000000",
    "desc":"some description",
    "issuerId":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
    "_version_":2
  }
}Get the balance of all UIA Assets for an account
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getBalances(address, limit?, offset?);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | GNY account address | 
| limit | integer | N | maximum number of records to return, between 0 and 100 | 
| offset | integer | N | Offset, minimum 0 | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | Whether operation was successful | 
| balances | Array | Asset array, details owned, each element is an asset, including asset name, balance, cap, precision, current circulation, whether to cancel (0: not cancelled, 1: cancelled) | 
| count | integer | The number of assets currently owned by this address | 
JSON Response:
{
  "count":1,
  "balances":[{
    "address":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
    "currency":"AAA.BBB",
    "balance":"500000000",
    "flag":2,
    "_version_":1
  }]
}Get balance of a specific UIA Asset for an account
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getBalance(address, currency);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| address | string | Y | GNY account address | 
| currency | string | Y | a specific UIA Asset | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | bool | Whether operation was successful | 
| balance | json | Asset array, details owned, each element is an asset, including asset name, balance, cap, precision, current circulation, whether to cancel (0: not cancelled, 1: cancelled) | 
JSON Response:
{
  "balance":{
    "address":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
    "currency":"AAA.BBB",
    "balance":"1000000000",
    "flag":2,
    "_version_":2
  }
}Get holders of a specific UIA Asset
import { Connection } from "@gny/client";
const connection = new Connection();
const result = await connection.api.Uia.getHolders(currency);Request Parameter Description:
| Name | Type | Required | Description | 
|---|---|---|---|
| currency | string | Y | a specific UIA Asset | 
| limit | integer | N | maximum number of records to return, between 0 and 100 | 
| offset | integer | N | Offset, minimum 0 | 
Response Parameter Description:
| Name | Type | Description | 
|---|---|---|
| success | boolean | Whether operation was successful | 
| holders | Array | Asset array, each element is an asset holder, including address, balance, currency | 
| count | integer | The number of holders owning this asset | 
JSON Response:
{
  "count":1,
  "holders":[{
    "address":"G4GDW6G78sgQdSdVAQUXdm5xPS13t",
    "currency":"AAA.BBB",
    "balance":"500000000",
  }]
}