396 lines
11 KiB
YAML
396 lines
11 KiB
YAML
openapi: 3.0.3
|
|
info:
|
|
title: Grassroots Economics
|
|
description: CIC ETH API
|
|
termsOfService: https://www.grassrootseconomics.org/pages/terms-and-conditions.html
|
|
contact:
|
|
name: Grassroots Economics
|
|
url: https://www.grassrootseconomics.org
|
|
email: will@grassecon.org
|
|
license:
|
|
name: GPLv3
|
|
version: 0.0.1
|
|
servers:
|
|
- url: /
|
|
paths:
|
|
/tokens:
|
|
get:
|
|
tags:
|
|
- Token
|
|
description: Perform a token data lookup from the token index. The token index will enforce unique associations between token symbol and contract address.
|
|
operationId: get_tokens
|
|
parameters:
|
|
- name: token_symbols
|
|
in: query
|
|
description: Token symbol to look up
|
|
required: true
|
|
schema:
|
|
type: array
|
|
example: ["GTF"]
|
|
items:
|
|
type: string
|
|
- name: proof
|
|
in: query
|
|
description: |
|
|
Proofs to add to signature verification for the token
|
|
- None (Default), in which case proof checks are skipped (although there may still be builtin proof checks being performed)
|
|
- Single string, where the same proof is used for each token lookup
|
|
- Array of strings, where the respective proof is used for the respective token. number of proofs must match the number of tokens.
|
|
- Array of lists, where the respective proofs in each list is used for the respective token. number of lists of proofs must match the number of tokens.
|
|
|
|
required: false
|
|
schema:
|
|
oneOf:
|
|
- type: array
|
|
items:
|
|
type: string
|
|
- type: string
|
|
|
|
responses:
|
|
"200":
|
|
description: OK.
|
|
content:
|
|
application/json:
|
|
schema:
|
|
$ref: "#/components/schemas/Token"
|
|
/token:
|
|
get:
|
|
tags:
|
|
- Token
|
|
description: Single-token alias for tokens method.
|
|
operationId: get_token
|
|
parameters:
|
|
- name: token_symbol
|
|
in: query
|
|
description: Token symbol to look up
|
|
required: true
|
|
schema:
|
|
type: string
|
|
example: "GFT"
|
|
- name: proof
|
|
in: query
|
|
description: Proofs to add to signature verification for the token
|
|
required: false
|
|
schema:
|
|
type: string
|
|
|
|
responses:
|
|
"200":
|
|
description: OK.
|
|
content:
|
|
application/json:
|
|
schema:
|
|
$ref: "#/components/schemas/Token"
|
|
/default_token:
|
|
get:
|
|
tags:
|
|
- Token
|
|
description: Retrieves the default fallback token of the custodial network.
|
|
operationId: get_default_token
|
|
responses:
|
|
"200":
|
|
description: OK.
|
|
content:
|
|
application/json:
|
|
schema:
|
|
$ref: "#/components/schemas/Token"
|
|
/balance:
|
|
get:
|
|
tags:
|
|
- Account
|
|
description: Retrieves the current token balance of the given address
|
|
operationId: account_balance
|
|
parameters:
|
|
- name: address
|
|
in: query
|
|
required: true
|
|
schema:
|
|
type: string
|
|
example: "0xe88ba386f0efc7117e8d0d17a750fce492516ecb"
|
|
- name: token_symbol
|
|
in: query
|
|
required: true
|
|
schema:
|
|
type: string
|
|
- name: include_pending
|
|
in: query
|
|
required: false
|
|
schema:
|
|
type: boolean
|
|
default: true
|
|
responses:
|
|
"200":
|
|
description: OK.
|
|
content:
|
|
application/json:
|
|
schema:
|
|
type: array
|
|
items:
|
|
$ref: "#/components/schemas/TokenBalance"
|
|
|
|
/transactions:
|
|
get:
|
|
tags:
|
|
- Account
|
|
description: Retrieve an aggregate list of latest transactions of internal and (optionally) external origin in reverse chronological order.
|
|
operationId: list_transactions
|
|
parameters:
|
|
- name: address
|
|
in: query
|
|
required: true
|
|
schema:
|
|
type: string
|
|
example: "0xe88ba386f0efc7117e8d0d17a750fce492516ecb"
|
|
- name: limit
|
|
in: query
|
|
required: false
|
|
schema:
|
|
type: integer
|
|
default: 10
|
|
responses:
|
|
"200":
|
|
description: OK.
|
|
content:
|
|
application/json:
|
|
schema:
|
|
type: array
|
|
items:
|
|
$ref: "#/components/schemas/Transaction"
|
|
/create_account:
|
|
post:
|
|
tags:
|
|
- Account
|
|
description: Creates a new blockchain address encrypted with the given password and returns the new address
|
|
operationId: create_account_post
|
|
parameters:
|
|
- name: password
|
|
in: query
|
|
required: false
|
|
allowReserved: true
|
|
schema:
|
|
type: string
|
|
- name: register
|
|
in: query
|
|
required: false
|
|
allowReserved: true
|
|
schema:
|
|
type: boolean
|
|
default: true
|
|
responses:
|
|
"200":
|
|
description: Address of the new account
|
|
content:
|
|
application/json:
|
|
schema:
|
|
type: string
|
|
example: "bea54d37f1a469515bda96e116695cedd323c182"
|
|
/transfer:
|
|
post:
|
|
tags:
|
|
- Account
|
|
description: Performs a transfer of ERC20 tokens from one address to another.
|
|
operationId: transfer
|
|
parameters:
|
|
- name: from_address
|
|
in: query
|
|
required: true
|
|
schema:
|
|
type: string
|
|
example: "0xbea54d37f1a469515bda96e116695cedd323c182"
|
|
- name: to_address
|
|
in: query
|
|
required: true
|
|
schema:
|
|
type: string
|
|
example: "0x8264d4c224d0c74c98295bfab2f216c2d7b18c8c"
|
|
- name: value
|
|
in: query
|
|
required: true
|
|
schema:
|
|
type: integer
|
|
- name: token_symbol
|
|
in: query
|
|
required: true
|
|
schema:
|
|
type: string
|
|
responses:
|
|
"200":
|
|
description: Transaction hash for transfer operation
|
|
content:
|
|
application/json:
|
|
schema:
|
|
type: string
|
|
/transfer_from:
|
|
post:
|
|
tags:
|
|
- Account
|
|
description:
|
|
Performs a transfer of ERC20 tokens by one address on behalf of
|
|
another address to a third party.
|
|
operationId: transfer_from
|
|
parameters:
|
|
- name: from_address
|
|
in: query
|
|
description: Ethereum address of sender
|
|
required: true
|
|
schema:
|
|
type: string
|
|
- name: to_address
|
|
in: query
|
|
description: Ethereum address of recipient
|
|
required: true
|
|
schema:
|
|
type: string
|
|
- name: value
|
|
in: query
|
|
description: Estimated return from conversion
|
|
required: true
|
|
schema:
|
|
type: integer
|
|
- name: token_symbol
|
|
in: query
|
|
description: ERC20 token symbol of token to send
|
|
required: true
|
|
schema:
|
|
type: string
|
|
- name: spender_address
|
|
in: query
|
|
description: Ethereum address of recipient
|
|
required: true
|
|
schema:
|
|
type: string
|
|
responses:
|
|
"200":
|
|
description: Transaction hash for transfer operation
|
|
content:
|
|
application/json:
|
|
schema:
|
|
type: string
|
|
components:
|
|
schemas:
|
|
Transaction:
|
|
type: object
|
|
properties:
|
|
block_number:
|
|
type: integer
|
|
format: int32
|
|
example: 24531
|
|
date_checked:
|
|
type: string
|
|
example: 2021-11-12T09:36:40.725296
|
|
date_created:
|
|
type: string
|
|
example: 2021-11-12T09:36:40.131292
|
|
date_updated:
|
|
type: string
|
|
example: 2021-11-12T09:36:40.131292
|
|
destination_token:
|
|
type: string
|
|
example: 0x3ff776b6f888980def9d4220858803f9dc5e341e
|
|
destination_token_decimals:
|
|
type: integer
|
|
format: int32
|
|
example: 6
|
|
destination_token_symbol:
|
|
type: string
|
|
example: COFE
|
|
from_value:
|
|
type: integer
|
|
format: int32
|
|
example: 100000000
|
|
hash:
|
|
type: string
|
|
example: 0xc7d160b4f1c89f09cbccbc2c4f6a72760bc3c1634a88438870c31b2e4d9e2bf3
|
|
nonce:
|
|
type: integer
|
|
format: int32
|
|
example: 1
|
|
recipient:
|
|
type: string
|
|
example: 872e1ec9d499b242ebfcfd0a279a4c3e0cd472c0
|
|
sender:
|
|
type: string
|
|
example: 1a92b05e0b880127a4c26ac0f68a52df3ac6b89d
|
|
signed_tx:
|
|
type: string
|
|
example: 0xf8aa018310c8e0837a1200943ff776b6f888980def9d4220858803f9dc5e341e80b844a9059cbb000000000000000000000000872e1ec9d499b242ebfcfd0a279a4c3e0cd472c00000000000000000000000000000000000000000000000000000000005f5e10082466ca0617d50ea726dfe61d6dc5e8a4a85cf7469514f394250cecb019006317cfb94d3a04930e14524f0a87db623a80e0f841ab613f693f5031c6a136873052ae7bba08e
|
|
source_token:
|
|
type: string
|
|
example: 0x3ff776b6f888980def9d4220858803f9dc5e341e
|
|
source_token_decimals:
|
|
type: integer
|
|
format: int32
|
|
example: 6
|
|
source_token_symbol:
|
|
type: string
|
|
example: COFE
|
|
status:
|
|
type: string
|
|
example: SUCCESS
|
|
status_code:
|
|
type: integer
|
|
format: int32
|
|
example: 4104
|
|
timestamp:
|
|
type: integer
|
|
format: int32
|
|
example: 1636709800
|
|
to_value:
|
|
type: integer
|
|
format: int32
|
|
example: 100000000
|
|
tx_hash:
|
|
type: string
|
|
example: 0xc7d160b4f1c89f09cbccbc2c4f6a72760bc3c1634a88438870c31b2e4d9e2bf3
|
|
tx_index:
|
|
type: integer
|
|
format: int32
|
|
example: 0
|
|
|
|
Token:
|
|
type: object
|
|
properties:
|
|
symbol:
|
|
type: string
|
|
description: Token Symbol
|
|
address:
|
|
type: string
|
|
description: Token Address
|
|
name:
|
|
type: string
|
|
description: Token Name
|
|
decimals:
|
|
type: integer
|
|
description: Decimals
|
|
example:
|
|
symbol: "GTF"
|
|
address: "3FF776B6f888980DEf9d4220858803f9dC5e341e"
|
|
decimals: 6
|
|
name: "Gift Token"
|
|
TokenBalance:
|
|
type: object
|
|
properties:
|
|
address:
|
|
type: string
|
|
converters:
|
|
type: array
|
|
items:
|
|
type: string
|
|
balance_network:
|
|
type: integer
|
|
balance_incoming:
|
|
type: integer
|
|
balance_outgoing:
|
|
type: integer
|
|
balance_available:
|
|
type: integer
|
|
example:
|
|
balance_network: 0
|
|
address: address
|
|
balance_incoming: 6
|
|
balance_available: 5
|
|
converters:
|
|
- converters
|
|
- converters
|
|
balance_outgoing: 1
|