cic-internal-integration/apps/cic-eth/cic_eth/server/openapi/server.yaml

396 lines
11 KiB
YAML
Raw Normal View History

2021-11-12 09:14:40 +01:00
openapi: 3.0.3
info:
title: Grassroots Economics
description: CIC ETH API
2021-12-08 12:33:37 +01:00
termsOfService: https://www.grassrootseconomics.org/pages/terms-and-conditions.html
2021-11-12 09:14:40 +01:00
contact:
name: Grassroots Economics
url: https://www.grassrootseconomics.org
email: will@grassecon.org
license:
name: GPLv3
2021-12-08 12:32:56 +01:00
version: 0.0.1
2021-11-12 09:14:40 +01:00
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"
2021-11-22 10:28:09 +01:00
/default_token:
2021-11-12 09:14:40 +01:00
get:
tags:
- Token
description: Retrieves the default fallback token of the custodial network.
2021-11-12 09:14:40 +01:00
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
2021-11-12 09:14:40 +01:00
operationId: account_balance
parameters:
- name: address
in: query
required: true
schema:
2021-11-12 10:42:12 +01:00
type: string
example: "0xe88ba386f0efc7117e8d0d17a750fce492516ecb"
2021-11-12 09:14:40 +01:00
- 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:
2021-11-17 13:21:23 +01:00
type: array
items:
$ref: "#/components/schemas/TokenBalance"
2021-11-22 10:28:09 +01:00
2021-11-12 09:14:40 +01:00
/transactions:
get:
tags:
- Account
description: Retrieve an aggregate list of latest transactions of internal and (optionally) external origin in reverse chronological order.
2021-11-12 09:14:40 +01:00
operationId: list_transactions
parameters:
- name: address
in: query
required: true
schema:
2021-11-12 10:42:12 +01:00
type: string
example: "0xe88ba386f0efc7117e8d0d17a750fce492516ecb"
2021-11-12 09:14:40 +01:00
- name: limit
in: query
required: false
schema:
type: integer
default: 10
responses:
"200":
description: OK.
content:
application/json:
schema:
2021-11-17 13:21:23 +01:00
type: array
items:
$ref: "#/components/schemas/Transaction"
2021-11-12 09:14:40 +01:00
/create_account:
post:
tags:
- Account
description: Creates a new blockchain address encrypted with the given password and returns the new address
2021-11-12 09:14:40 +01:00
operationId: create_account_post
parameters:
- name: password
in: query
2021-11-16 14:37:16 +01:00
required: false
2021-11-12 09:14:40 +01:00
allowReserved: true
schema:
type: string
- name: register
in: query
2021-11-16 14:37:16 +01:00
required: false
2021-11-12 09:14:40 +01:00
allowReserved: true
schema:
type: boolean
default: true
responses:
"200":
2021-11-16 14:37:16 +01:00
description: Address of the new account
2021-11-12 09:14:40 +01:00
content:
application/json:
schema:
type: string
2021-11-16 14:37:16 +01:00
example: "bea54d37f1a469515bda96e116695cedd323c182"
2021-11-12 09:14:40 +01:00
/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:
2021-11-12 10:42:12 +01:00
type: string
2021-11-16 14:37:16 +01:00
example: "0xbea54d37f1a469515bda96e116695cedd323c182"
2021-11-12 09:14:40 +01:00
- name: to_address
in: query
required: true
schema:
2021-11-12 10:42:12 +01:00
type: string
2021-11-16 14:37:16 +01:00
example: "0x8264d4c224d0c74c98295bfab2f216c2d7b18c8c"
2021-11-12 09:14:40 +01:00
- name: value
in: query
required: true
schema:
type: integer
- name: token_symbol
in: query
required: true
schema:
type: string
responses:
"200":
2021-11-16 14:37:16 +01:00
description: Transaction hash for transfer operation
2021-11-12 09:14:40 +01:00
content:
application/json:
schema:
2021-11-16 14:37:16 +01:00
type: string
2021-11-12 09:14:40 +01:00
/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:
2021-11-12 10:42:12 +01:00
type: string
2021-11-12 09:14:40 +01:00
- name: to_address
in: query
description: Ethereum address of recipient
required: true
schema:
2021-11-12 10:42:12 +01:00
type: string
2021-11-12 09:14:40 +01:00
- 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:
2021-11-12 10:42:12 +01:00
type: string
2021-11-12 09:14:40 +01:00
responses:
"200":
2021-11-16 14:37:16 +01:00
description: Transaction hash for transfer operation
2021-11-12 09:14:40 +01:00
content:
application/json:
schema:
2021-11-16 14:37:16 +01:00
type: string
2021-11-12 09:14:40 +01:00
components:
schemas:
2021-11-12 10:42:12 +01:00
Transaction:
type: object
properties:
2021-11-22 10:28:09 +01:00
block_number:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 24531
2021-11-22 10:28:09 +01:00
date_checked:
2021-11-12 10:42:12 +01:00
type: string
example: 2021-11-12T09:36:40.725296
2021-11-22 10:28:09 +01:00
date_created:
2021-11-12 10:42:12 +01:00
type: string
example: 2021-11-12T09:36:40.131292
2021-11-22 10:28:09 +01:00
date_updated:
2021-11-12 10:42:12 +01:00
type: string
example: 2021-11-12T09:36:40.131292
2021-11-22 10:28:09 +01:00
destination_token:
2021-11-12 10:42:12 +01:00
type: string
example: 0x3ff776b6f888980def9d4220858803f9dc5e341e
2021-11-22 10:28:09 +01:00
destination_token_decimals:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 6
2021-11-22 10:28:09 +01:00
destination_token_symbol:
2021-11-12 10:42:12 +01:00
type: string
example: COFE
2021-11-22 10:28:09 +01:00
from_value:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 100000000
2021-11-22 10:28:09 +01:00
hash:
2021-11-12 10:42:12 +01:00
type: string
example: 0xc7d160b4f1c89f09cbccbc2c4f6a72760bc3c1634a88438870c31b2e4d9e2bf3
2021-11-22 10:28:09 +01:00
nonce:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 1
2021-11-22 10:28:09 +01:00
recipient:
2021-11-12 10:42:12 +01:00
type: string
example: 872e1ec9d499b242ebfcfd0a279a4c3e0cd472c0
2021-11-22 10:28:09 +01:00
sender:
2021-11-12 10:42:12 +01:00
type: string
example: 1a92b05e0b880127a4c26ac0f68a52df3ac6b89d
2021-11-22 10:28:09 +01:00
signed_tx:
2021-11-12 10:42:12 +01:00
type: string
example: 0xf8aa018310c8e0837a1200943ff776b6f888980def9d4220858803f9dc5e341e80b844a9059cbb000000000000000000000000872e1ec9d499b242ebfcfd0a279a4c3e0cd472c00000000000000000000000000000000000000000000000000000000005f5e10082466ca0617d50ea726dfe61d6dc5e8a4a85cf7469514f394250cecb019006317cfb94d3a04930e14524f0a87db623a80e0f841ab613f693f5031c6a136873052ae7bba08e
2021-11-22 10:28:09 +01:00
source_token:
2021-11-12 10:42:12 +01:00
type: string
example: 0x3ff776b6f888980def9d4220858803f9dc5e341e
2021-11-22 10:28:09 +01:00
source_token_decimals:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 6
2021-11-22 10:28:09 +01:00
source_token_symbol:
2021-11-12 10:42:12 +01:00
type: string
example: COFE
2021-11-22 10:28:09 +01:00
status:
2021-11-12 10:42:12 +01:00
type: string
example: SUCCESS
2021-11-22 10:28:09 +01:00
status_code:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 4104
2021-11-22 10:28:09 +01:00
timestamp:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 1636709800
2021-11-22 10:28:09 +01:00
to_value:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 100000000
2021-11-22 10:28:09 +01:00
tx_hash:
2021-11-12 10:42:12 +01:00
type: string
example: 0xc7d160b4f1c89f09cbccbc2c4f6a72760bc3c1634a88438870c31b2e4d9e2bf3
2021-11-22 10:28:09 +01:00
tx_index:
2021-11-12 10:42:12 +01:00
type: integer
format: int32
example: 0
2021-11-12 09:14:40 +01:00
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:
2021-11-22 10:28:09 +01:00
symbol: "GTF"
address: "3FF776B6f888980DEf9d4220858803f9dC5e341e"
2021-11-12 09:14:40 +01:00
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