Files
gocryptotrader/gctrpc/rpc.proto
Andrew 39bbd8dfc9 (Feature) OHLCV data storage and retrieval (#522)
* WIP

* end of day WIP started migration of trade history

* added kline support to hitbtc huobi lbank

* added exchangehistory to all supported exchanges started work on coinbase 300 candles/request method

* end of day WIP

* removed unused ta and misc changes to flag ready for review

* yobit cleanup

* revert coinbase changES

* general code clean up and added zb support

* poloniex support added

* renamed method to FormatExchangeKlineInterval other misc fixes

* linter fixes

* linter fixes

* removed verbose

* fixed poloniex test coverage

* revert poloniex mock data

* regenerated poloniex mock data

* a very verbose clean up

* binance mock clean up

* removed unneeded t.Log()

* setting verbose to true to debug CI issue

* first pass changes addressed

* common.ErrNotYetImplemented implemented :D

* comments added

* WIP-addressed exchange requests and reverted previous GetExchangeHistory changes

* WIP-addressed exchange requests and reverted previous GetExchangeHistory changes

* increased test coverage added kraken support

* OKGroup support completed started work on address GetExchangeHistory feedback and migrating to own PR under https://github.com/xtda/gocryptotrader/tree/exchange_history

* convert zb ratelimits

* gofmt run on okcoin

* increased delay on rate limit

* gofmt package

* fixed panic with coinbene and bithumb if conversion fails

* very broken end of day WIP

* added support for GetHistoricCandlesEx to coinbase and binance

* gofmt package

* coinbase, btcmarkets, zb ex wrapper function added

* added all exchange support for ex regenerated mock data

* update bithumb to return wrapper method

* gofmt package

* end of day started work on changes

* models created for exchange/asset/currency/currencypair, new seed system created

* reworked test coverage added okgroup support general fixes/change requests addressed

* Added OneMonth

* limit checks on supportedexchanges

* reverted getexchangehistory

* started work on currency seeding and insertion

* reworked binance tesT

* added workaround for kraken panic

* :D extremely broken WIP

* renamed command to extended removed interval check on non-implemented commands

* added wrapperconfig back

* increased test coverage for FormatExchangeKlineInterval

* WIP

* increased test coverage for FormatExchangeKlineInterval bitfinex/gateio/huobi

* linter fixes

* zb kraken lbank coinbene btcmarkets support added

* removed verbose

* OK group support for other asset types added

* swapped margin to use spot endpoint

* index support added test coverage added for asset types

* added asset type to okcoin test

* gofmt

* add asset to extended method

* removed verbose

* Very broken WIP models need to be regenerated

* add support for coinbene swap increase test coverage

* removed verbose

* small clean up of okgroup wrapper functions

* verbose to troubleshoot CI issues

* removed verbose

* added error check reverted coinbasechanges

* attempting to fix broken model generation

* readme updated

* :D i broke so much

* model regeneration fixed & complete

* candle model filled out

* removed unused start/finish started work on decoupling api requests from kline package

* restructured coinbene, bithumb methods, added bitstamp support

* kraken time fix

* BTCMarkets restructure

* typo fix

* removed test for futures due to contact changing

* removed test for futures due to contact changing

* added start/end date to extended method over range

* WIP

* added sync option to candles

* converted to assettranslator

* removed verbose

* removed verbose

* removed invalid char

* reverted incorrectly removed return

* added import

* further template updates

* macos hates my keyboard :D

* misc canges

* started work on creating kline from databases eed

* x -> i

* removed verbose

* updated fixCasing to allocate var before checks

* sqlite3 supported work started

* removed time conversion

* further work on tets

* sort all outgoing kline candles

* fixCasing fix

* after/before checks added

* added parallel to test

* logic check on BTCmarkets

* removed unused param, used correct iterator

* converted HitBTC to use time.Time

* test update

* add iszero false check to candle times

* Seed exchange & OHCLV data for test usage

* updated resultlimit to 5000

* new line added

* added comment to exported const

* move date forward

* use configured ratelimit

* fixed pair for test

* panic fixed WIP on fixCasing

* fixCasing rework, started work on readme docs

* enable rate limiter for wrapper issues tool

* docs updated

* removed unused vars from tests

* removed err from return and formatted currency

* updated Yobit supported status

* Updated HitBTC to use onehour candles due to test exeuction times

* added further details to gctcli output

* added link to docs

* added link to tempalte

* disable FTX websocket in config_example

* fix poloneix

* regenerated poloniex mock data

* removed recording flag

* format on package

* moved exchange var outside of method scope

* reworked seeding into package

* verbose output improved

* removed verbose from candles

* Added comments to exported functions

* removed verbose output

* Reworking of tests

* end of day commit

* added SQLite migration for asset, test updates for exchange, added support for withdrawal for new exchange_name_id relation

* regenerated database models

* WIP

* test rework, sqlite migration updates for withdrawal

* Reworked error returns to stop duplications, format all output to UTC, changed gctscript OHLCV output to be unix timestmap, started work on seeding tool

* gofmt

* dbseed command for seeding exchanges added, removed seed from dbmigrate, LoadCSV method added for exchange

* go mod tidy

* added import candle from csv command to dbseed

* Removed reset & duplicate migrate command from helper, renamed struct to Item/Candle over Candle/Tick, added test coverage to dbseed, improved withdraw tests

* remove broken tests due to ORM generation of Fk, removed go unneeded goroutine for inserting records

* removed t.Cleanup usage because appveyor

* added test coverage to StoreInDatabase()

* removed unneeded data from config for test

* added new line

* Added down migration support to candle/asset removal, return original error and display rollback error

* removed unneeded err assignment, break out of loop on error

* add err check to method for test

* first pass changes

* WIP

* Updated migrations for both sqlite3 & postgres to create exchanges if any withdrawal_history records are found, removed migrate command

* removed argusage as usage information is provided by flags

* added inserted records return count and test coverage

* new line added

* Database: comment config details out to disable local postgresl testing by default

* added asset support

* Database: added error return when no exchanges are found, title exchange name across queries

* Fixed test data

* Database: removed migration bool from ConnectToDatabase(), removed empty line, insert asset on test

* Database: verbose linter :D

* Database/OHLCV: removed go module from dbseed command and reverted back to main module, converted interval to int64 to match other parts of code base, provided migrations to update database, poloniex fix to skip first candle

* dbseed: add completed message to output

* Database: added migration to add asset to uniq index for candle table

* Database: database -> exchange

* Database: add asset to upsert conflict

* Poloneix: fix for invalid interval

* regenerated poloniex mock data

* Database: added down migration for candle interval update

* OHCLV/Database: WIP

* OHLCV/Datastore: added new ValidateKline() method to check that asset, pair, interval are enabled/supported by exchange and updated tests

* revert configtest changes

* OHCLV/Kline: pointer assignment to ErrorKline & format pairs on check

* goimports

* migration updates

* Database/Candle: updated tests

* revert configtest changes

* ZB: updaed defaults to use uppercase pairs

* ZB: updaed defaults to use uppercase pairs

* revert pair formatting

* Switch over to .Cotains() method from pairManagement

* Added comment & ftx back 😆

* OHLCV/Datastore: (Candles): added not null to asset, (WithdrawalHistory): added not null to exchange_name_id), reworked KlineError return

* set verbose to false

* updated btc markets test

* Updated readme

* removed ability to have blank exchange name as indexing requires it

* remove old usedb and empty exchange check, return error on no data instead

* Updated kline test to match date range

* Renamed candles.exchange_id column to candles.xchange_name_id to match withdrawal table, return err on unwrap, zb fix revert

* regenerated sqlite3 models

* force UTC for sqlite.... because sqlite

* OHLCV/Datastore: upper case pairs on insert for consistency, remove unneeded rollback call on commit failure as it has no effect, move rollback outside of insertsqlite/insertpsql methods

* add error check for no candles

* nil length/cap is 0 in golang :D

* OHLCV/Datastore: updated wording on examples, removed duplicate testfile

* OHLCV/Datastore: updated README with links to dbseed

* dbtool -> dbseed
2020-09-03 17:13:53 +10:00

1204 lines
27 KiB
Protocol Buffer

syntax = "proto3";
import "google/api/annotations.proto";
import "google/protobuf/timestamp.proto";
package gctrpc;
message GetInfoRequest {}
message GetInfoResponse {
string uptime = 1;
int64 available_exchanges = 2;
int64 enabled_exchanges = 3;
string default_forex_provider = 4;
string default_fiat_currency = 5;
map<string, bool> subsystem_status = 6;
map<string, RPCEndpoint> rpc_endpoints = 7;
}
message GetCommunicationRelayersRequest {}
message CommunicationRelayer {
bool enabled = 1;
bool connected = 2;
}
message GetCommunicationRelayersResponse {
map<string, CommunicationRelayer> communication_relayers = 1;
}
message GenericSubsystemRequest {
string subsystem = 1;
}
message GetSubsystemsRequest {}
message GetSusbsytemsResponse {
map<string, bool> subsystems_status = 1;
}
message GetRPCEndpointsRequest{}
message RPCEndpoint {
bool started = 1;
string listen_address = 2;
}
message GetRPCEndpointsResponse {
map<string, RPCEndpoint> endpoints = 1;
}
message GenericExchangeNameRequest {
string exchange = 1;
}
message GetExchangesRequest {
bool enabled = 1;
}
message GetExchangesResponse {
string exchanges = 1;
}
message GetExchangeOTPReponse {
string otp_code = 1;
}
message GetExchangeOTPsRequest {}
message GetExchangeOTPsResponse {
map<string, string> otp_codes = 1;
}
message DisableExchangeRequest {
string exchange = 1;
}
message PairsSupported {
string available_pairs = 1;
string enabled_pairs = 2;
}
message GetExchangeInfoResponse {
string name = 1;
bool enabled = 2;
bool verbose = 3;
bool using_sandbox = 4;
string http_timeout = 5;
string http_useragent = 6;
string http_proxy = 7;
string base_currencies = 8;
map<string, PairsSupported> supported_assets = 9;
bool authenticated_api = 10;
}
message GetTickerRequest {
string exchange = 1;
CurrencyPair pair = 2;
string asset_type = 3;
}
message CurrencyPair {
string delimiter = 1;
string base = 2;
string quote = 3;
}
message TickerResponse {
CurrencyPair pair = 1;
int64 last_updated = 2;
string currency_pair = 3;
double last = 4;
double high = 5;
double low = 6;
double bid = 7;
double ask = 8;
double volume = 9;
double price_ath = 10;
}
message GetTickersRequest {}
message Tickers {
string exchange = 1;
repeated TickerResponse tickers = 2;
}
message GetTickersResponse {
repeated Tickers tickers = 1;
}
message GetOrderbookRequest {
string exchange = 1;
CurrencyPair pair = 2;
string asset_type = 3;
}
message OrderbookItem {
double amount = 1;
double price = 2;
int64 id = 3;
}
message OrderbookResponse {
CurrencyPair pair = 1;
string currency_pair = 2;
repeated OrderbookItem bids = 3;
repeated OrderbookItem asks = 4;
int64 last_updated = 5;
string asset_type = 6;
}
message GetOrderbooksRequest {}
message Orderbooks {
string exchange = 1;
repeated OrderbookResponse orderbooks = 2;
}
message GetOrderbooksResponse {
repeated Orderbooks orderbooks = 1;
}
message GetAccountInfoRequest {
string exchange = 1;
}
message Account {
string id = 1;
repeated AccountCurrencyInfo currencies = 2;
}
message AccountCurrencyInfo {
string currency = 1;
double total_value = 2;
double hold = 3;
}
message GetAccountInfoResponse {
string exchange = 1;
repeated Account accounts = 2;
}
message GetConfigRequest {}
message GetConfigResponse {
bytes data = 1;
}
message PortfolioAddress {
string address = 1;
string coin_type = 2;
string description = 3;
double balance = 4;
}
message GetPortfolioRequest {}
message GetPortfolioResponse {
repeated PortfolioAddress portfolio = 1;
}
message GetPortfolioSummaryRequest {}
message Coin {
string coin = 1;
double balance = 2;
string address = 3;
double percentage = 4;
}
message OfflineCoinSummary {
string address = 1;
double balance = 2;
double percentage = 3;
}
message OnlineCoinSummary {
double balance = 1;
double percentage = 2;
}
message OfflineCoins {
repeated OfflineCoinSummary addresses = 1;
}
message OnlineCoins {
map<string, OnlineCoinSummary> coins = 1;
}
message GetPortfolioSummaryResponse {
repeated Coin coin_totals = 1;
repeated Coin coins_offline = 2;
map<string, OfflineCoins> coins_offline_summary = 3;
repeated Coin coins_online = 4;
map<string, OnlineCoins> coins_online_summary = 5;
}
message AddPortfolioAddressRequest {
string address = 1;
string coin_type = 2;
string description = 3;
double balance = 4;
string supported_exchanges = 5;
bool cold_storage = 6;
}
message RemovePortfolioAddressRequest {
string address = 1;
string coin_type = 2;
string description = 3;
}
message GetForexProvidersRequest {}
message ForexProvider {
string name = 1;
bool enabled = 2;
bool verbose = 3;
string rest_polling_delay = 4;
string api_key = 5;
int64 api_key_level =6;
bool primary_provider = 7;
}
message GetForexProvidersResponse {
repeated ForexProvider forex_providers = 1;
}
message GetForexRatesRequest {}
message ForexRatesConversion {
string from = 1;
string to = 2;
double rate = 3;
double inverse_rate = 4;
}
message GetForexRatesResponse {
repeated ForexRatesConversion forex_rates = 1;
}
message OrderDetails {
string exchange = 1;
string id = 2;
string base_currency = 3;
string quote_currency = 4;
string asset_type = 5;
string order_side = 6;
string order_type = 7;
int64 creation_time = 8;
string status = 9;
double price = 10;
double amount = 11;
double open_volume = 12;
double fee = 13;
repeated TradeHistory trades = 14;
}
message TradeHistory {
int64 creation_time = 1;
string id = 2;
double price = 3;
double amount = 4;
string exchange = 5;
string asset_type = 6;
string order_side = 7;
double fee = 8;
}
message GetOrdersRequest {
string exchange = 1;
string asset_type = 2;
CurrencyPair pair = 3;
}
message GetOrdersResponse {
repeated OrderDetails orders = 1;
}
message GetOrderRequest {
string exchange = 1;
string order_id = 2;
}
message SubmitOrderRequest {
string exchange = 1;
CurrencyPair pair = 2;
string side = 3;
string order_type = 4;
double amount = 5;
double price = 6;
string client_id = 7;
}
message SubmitOrderResponse {
bool order_placed = 1;
string order_id = 2;
}
message SimulateOrderRequest {
string exchange = 1;
CurrencyPair pair = 2;
double amount = 3;
string side = 4;
}
message SimulateOrderResponse {
repeated OrderbookItem orders = 1;
double amount = 2;
double minimum_price = 3;
double maximum_price = 4;
double percentage_gain_loss = 5;
string status = 6;
}
message WhaleBombRequest {
string exchange = 1;
CurrencyPair pair = 2;
double price_target = 3;
string side = 4;
}
message CancelOrderRequest {
string exchange = 1;
string account_id = 2;
string order_id = 3;
CurrencyPair pair = 4;
string asset_type = 5;
string wallet_address = 6;
string side = 7;
}
message CancelAllOrdersRequest {
string exchange = 1;
}
message CancelAllOrdersResponse {
message Orders {
string exchange = 1;
map<string, string> order_status = 2;
}
repeated Orders orders = 1;
}
message GetEventsRequest {}
message ConditionParams {
string condition = 1;
double price = 2;
bool check_bids = 3;
bool check_bids_and_asks = 4;
double orderbook_amount = 5;
}
message GetEventsResponse {
int64 id = 1;
string exchange = 2;
string item = 3;
ConditionParams condition_params = 4;
CurrencyPair pair = 5;
string action = 6;
bool executed = 7;
}
message AddEventRequest {
string exchange = 1;
string item = 2;
ConditionParams condition_params = 3;
CurrencyPair pair = 4;
string asset_type = 5;
string action = 6;
}
message AddEventResponse {
int64 id = 1;
}
message RemoveEventRequest {
int64 id = 1;
}
message GetCryptocurrencyDepositAddressesRequest {
string exchange = 1;
}
message GetCryptocurrencyDepositAddressesResponse {
map<string, string> addresses = 1;
}
message GetCryptocurrencyDepositAddressRequest {
string exchange = 1;
string cryptocurrency = 2;
}
message GetCryptocurrencyDepositAddressResponse {
string address = 1;
}
message WithdrawFiatRequest {
string exchange = 1;
string currency = 2;
double amount = 3;
string description = 4;
string bank_account_id = 5;
}
message WithdrawCryptoRequest {
string exchange = 1;
string address = 2;
string address_tag = 3;
string currency = 4;
double amount = 5;
double fee = 6;
string description = 7;
}
message WithdrawResponse {
string id = 1;
string status = 2;
}
message WithdrawalEventByIDRequest {
string id = 1;
}
message WithdrawalEventByIDResponse {
WithdrawalEventResponse event = 2;
}
message WithdrawalEventsByExchangeRequest {
string exchange = 1;
string id = 2;
int32 limit = 3;
}
message WithdrawalEventsByDateRequest {
string exchange = 1;
string start = 2;
string end = 3;
int32 limit = 4;
}
message WithdrawalEventsByExchangeResponse {
repeated WithdrawalEventResponse event = 2;
}
message WithdrawalEventResponse {
string id = 2;
WithdrawlExchangeEvent exchange = 3;
WithdrawalRequestEvent request = 4;
google.protobuf.Timestamp created_at = 5;
google.protobuf.Timestamp updated_at = 6;
}
message WithdrawlExchangeEvent {
string name = 1;
string id = 2;
string status = 3;
}
message WithdrawalRequestEvent {
string currency = 2;
string description = 3;
double amount = 4;
int32 type = 5;
FiatWithdrawalEvent fiat = 6;
CryptoWithdrawalEvent crypto = 7;
}
message FiatWithdrawalEvent {
string bank_name = 1;
string account_name = 2;
string account_number = 3;
string bsb = 4;
string swift = 5;
string iban = 6;
}
message CryptoWithdrawalEvent {
string address = 1;
string address_tag = 2;
double fee = 3;
}
message GetLoggerDetailsRequest {
string logger = 1;
}
message GetLoggerDetailsResponse{
bool info = 1;
bool debug = 2;
bool warn = 3;
bool error = 4;
}
message SetLoggerDetailsRequest {
string logger = 1;
string level = 2;
}
message GetExchangePairsRequest {
string exchange = 1;
string asset = 2;
}
message GetExchangePairsResponse {
map<string, PairsSupported> supported_assets = 1;
}
message SetExchangePairRequest {
string exchange = 1;
string asset_type = 2;
repeated CurrencyPair pairs = 3;
bool enable = 4;
}
message GetOrderbookStreamRequest {
string exchange = 1;
CurrencyPair pair = 2;
string asset_type = 3;
}
message GetExchangeOrderbookStreamRequest {
string exchange = 1;
}
message GetTickerStreamRequest {
string exchange = 1;
CurrencyPair pair = 2;
string asset_type = 3;
}
message GetExchangeTickerStreamRequest {
string exchange = 1;
}
message GetAuditEventRequest {
string start_date = 1;
string end_date = 2;
string order_by = 3;
int32 limit = 4;
int32 offset = 5;
}
message GetAuditEventResponse {
repeated AuditEvent events = 1;
}
message GetHistoricCandlesRequest {
string exchange = 1;
CurrencyPair pair = 2;
string asset_type = 3;
int64 start = 4;
int64 end = 5;
int64 time_interval = 6;
bool ex_request = 7;
bool sync = 8;
bool use_db = 9;
}
message GetHistoricCandlesResponse {
string exchange = 1;
CurrencyPair pair = 2;
int64 start = 3;
int64 end = 4;
string interval = 6;
repeated Candle candle = 5;
}
message Candle {
int64 time = 1;
double low = 2;
double high = 3;
double open = 4;
double close = 5;
double volume = 6;
}
message AuditEvent {
string type = 1;
string identifier = 2;
string message = 3;
string timestamp = 4;
}
message GCTScript {
string UUID = 1;
string name = 2;
string path = 3;
string next_run = 4;
}
message GCTScriptExecuteRequest {
GCTScript script = 1;
}
message GCTScriptStopRequest {
GCTScript script = 1;
}
message GCTScriptStopAllRequest{}
message GCTScriptStatusRequest {}
message GCTScriptListAllRequest{}
message GCTScriptUploadRequest {
string script_name = 1;
string script_data = 2;
bytes data = 3;
bool archived = 4;
bool overwrite = 5;
}
message GCTScriptReadScriptRequest{
GCTScript script = 1;
}
message GCTScriptQueryRequest{
GCTScript script = 1;
}
message GCTScriptAutoLoadRequest{
string script = 1;
bool status = 2;
}
message GCTScriptStatusResponse{
string status = 1;
repeated GCTScript scripts = 2;
}
message GCTScriptQueryResponse{
string status = 1;
GCTScript script = 2;
string data = 3;
}
message GenericResponse {
string status = 1;
string data = 2;
}
message SetExchangeAssetRequest {
string exchange = 1;
string asset = 2;
bool enable = 3;
}
message SetExchangeAllPairsRequest {
string exchange = 1;
bool enable = 2;
}
message UpdateExchangeSupportedPairsRequest {
string exchange = 1;
}
message GetExchangeAssetsRequest {
string exchange = 1;
}
message GetExchangeAssetsResponse {
string assets = 1;
}
message WebsocketGetInfoRequest {
string exchange = 1;
}
message WebsocketGetInfoResponse {
string exchange = 1;
bool supported = 2;
bool enabled = 3;
bool authenticated_supported = 4;
bool authenticated = 5;
string running_url = 6;
string proxy_address = 7;
}
message WebsocketSetEnabledRequest {
string exchange = 1;
bool enable = 2;
}
message WebsocketGetSubscriptionsRequest {
string exchange = 1;
}
message WebsocketSubscription {
string channel = 1;
string currency = 2;
string asset = 3;
string params = 4;
}
message WebsocketGetSubscriptionsResponse {
string exchange = 1;
repeated WebsocketSubscription subscriptions = 2;
}
message WebsocketSetProxyRequest {
string exchange = 1;
string proxy = 2;
}
message WebsocketSetURLRequest {
string exchange = 1;
string url = 2;
}
service GoCryptoTrader {
rpc GetInfo (GetInfoRequest) returns (GetInfoResponse) {
option (google.api.http) = {
get :"/v1/getinfo"
};
}
rpc GetSubsystems (GetSubsystemsRequest) returns (GetSusbsytemsResponse) {
option (google.api.http) = {
get: "/v1/getsubsystems"
};
}
rpc EnableSubsystem (GenericSubsystemRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/enablesubsystem"
};
}
rpc DisableSubsystem (GenericSubsystemRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/disablesubsystem"
};
}
rpc GetRPCEndpoints (GetRPCEndpointsRequest) returns (GetRPCEndpointsResponse) {
option (google.api.http) = {
get: "/v1/getrpcendpoints"
};
}
rpc GetCommunicationRelayers (GetCommunicationRelayersRequest) returns (GetCommunicationRelayersResponse) {
option (google.api.http) = {
get: "/v1/getcommunicationrelayers"
};
}
rpc GetExchanges (GetExchangesRequest) returns (GetExchangesResponse) {
option (google.api.http) = {
get: "/v1/getexchanges"
};
}
rpc DisableExchange (GenericExchangeNameRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/disableexchange"
body: "*"
};
}
rpc GetExchangeInfo (GenericExchangeNameRequest) returns (GetExchangeInfoResponse) {
option (google.api.http) = {
get: "/v1/getexchangeinfo"
};
}
rpc GetExchangeOTPCode (GenericExchangeNameRequest) returns (GetExchangeOTPReponse) {
option (google.api.http) = {
get: "/v1/getexchangeotp"
};
}
rpc GetExchangeOTPCodes (GetExchangeOTPsRequest) returns (GetExchangeOTPsResponse) {
option (google.api.http) = {
get: "/v1/getexchangeotps"
};
}
rpc EnableExchange (GenericExchangeNameRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/enableexchange"
body: "*"
};
}
rpc GetTicker (GetTickerRequest) returns (TickerResponse) {
option (google.api.http) = {
post: "/v1/getticker"
body: "*"
};
}
rpc GetTickers (GetTickersRequest) returns (GetTickersResponse) {
option (google.api.http) = {
get: "/v1/gettickers"
};
}
rpc GetOrderbook (GetOrderbookRequest) returns (OrderbookResponse) {
option (google.api.http) = {
post: "/v1/getorderbook"
body: "*"
};
}
rpc GetOrderbooks (GetOrderbooksRequest) returns (GetOrderbooksResponse) {
option (google.api.http) = {
get: "/v1/getorderbooks"
};
}
rpc GetAccountInfo (GetAccountInfoRequest) returns (GetAccountInfoResponse) {
option (google.api.http) = {
get: "/v1/getaccountinfo"
};
}
rpc GetAccountInfoStream (GetAccountInfoRequest) returns (stream GetAccountInfoResponse) {
option (google.api.http) = {
get: "/v1/getaccountinfostream"
};
}
rpc GetConfig (GetConfigRequest) returns (GetConfigResponse) {
option (google.api.http) = {
get: "/v1/getconfig"
};
}
rpc GetPortfolio (GetPortfolioRequest) returns (GetPortfolioResponse) {
option (google.api.http) = {
get: "/v1/getportfolio"
};
}
rpc GetPortfolioSummary (GetPortfolioSummaryRequest) returns (GetPortfolioSummaryResponse) {
option (google.api.http) = {
get: "/v1/getportfoliosummary"
};
}
rpc AddPortfolioAddress (AddPortfolioAddressRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/addportfolioaddress"
body: "*"
};
}
rpc RemovePortfolioAddress (RemovePortfolioAddressRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/removeportfolioaddress"
body: "*"
};
}
rpc GetForexProviders (GetForexProvidersRequest) returns (GetForexProvidersResponse) {
option (google.api.http) = {
get: "/v1/getforexproviders"
};
}
rpc GetForexRates (GetForexRatesRequest) returns (GetForexRatesResponse) {
option (google.api.http) = {
get: "/v1/getforexrates"
};
}
rpc GetOrders (GetOrdersRequest) returns (GetOrdersResponse) {
option (google.api.http) = {
post: "/v1/getorders"
body: "*"
};
}
rpc GetOrder (GetOrderRequest) returns (OrderDetails) {
option (google.api.http) = {
post: "/v1/getorder"
body: "*"
};
}
rpc SubmitOrder (SubmitOrderRequest) returns (SubmitOrderResponse) {
option (google.api.http) = {
post: "/v1/submitorder"
body: "*"
};
}
rpc SimulateOrder (SimulateOrderRequest) returns (SimulateOrderResponse) {
option (google.api.http) = {
post: "/v1/simulateorder"
body: "*"
};
}
rpc WhaleBomb (WhaleBombRequest) returns (SimulateOrderResponse) {
option (google.api.http) = {
post: "/v1/whalebomb"
body: "*"
};
}
rpc CancelOrder (CancelOrderRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/cancelorder"
body: "*"
};
}
rpc CancelAllOrders (CancelAllOrdersRequest) returns (CancelAllOrdersResponse) {
option (google.api.http) = {
post: "/v1/cancelallorders"
body: "*"
};
}
rpc GetEvents(GetEventsRequest) returns (GetEventsResponse) {
option (google.api.http) = {
get: "/v1/getevents"
};
}
rpc AddEvent(AddEventRequest) returns (AddEventResponse) {
option (google.api.http) = {
post: "/v1/addevent"
body: "*"
};
}
rpc RemoveEvent(RemoveEventRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/removeevent"
body: "*"
};
}
rpc GetCryptocurrencyDepositAddresses(GetCryptocurrencyDepositAddressesRequest) returns (GetCryptocurrencyDepositAddressesResponse) {
option (google.api.http) = {
post: "/v1/getcryptodepositaddresses"
body: "*"
};
}
rpc GetCryptocurrencyDepositAddress(GetCryptocurrencyDepositAddressRequest) returns (GetCryptocurrencyDepositAddressResponse) {
option (google.api.http) = {
post: "/v1/getcryptodepositaddress"
body: "*"
};
}
rpc WithdrawFiatFunds(WithdrawFiatRequest) returns (WithdrawResponse) {
option (google.api.http) = {
post: "/v1/withdrawfiatfunds"
body: "*"
};
}
rpc WithdrawCryptocurrencyFunds(WithdrawCryptoRequest) returns (WithdrawResponse) {
option (google.api.http) = {
post: "/v1/withdrawithdrawcryptofundswfiatfunds"
body: "*"
};
}
rpc WithdrawalEventByID(WithdrawalEventByIDRequest) returns (WithdrawalEventByIDResponse) {
option (google.api.http) = {
post: "/v1/withdrawaleventbyid"
body: "*"
};
}
rpc WithdrawalEventsByExchange(WithdrawalEventsByExchangeRequest) returns (WithdrawalEventsByExchangeResponse) {
option (google.api.http) = {
post: "/v1/withdrawaleventbyid"
body: "*"
};
}
rpc WithdrawalEventsByDate(WithdrawalEventsByDateRequest) returns (WithdrawalEventsByExchangeResponse) {
option (google.api.http) = {
post: "/v1/withdrawaleventbydate"
body: "*"
};
}
rpc GetLoggerDetails(GetLoggerDetailsRequest) returns (GetLoggerDetailsResponse) {
option (google.api.http) = {
get: "/v1/getloggerdetails"
};
}
rpc SetLoggerDetails(SetLoggerDetailsRequest) returns (GetLoggerDetailsResponse) {
option (google.api.http) = {
post: "/v1/setloggerdetails",
body: "*"
};
}
rpc GetExchangePairs(GetExchangePairsRequest) returns (GetExchangePairsResponse) {
option (google.api.http) = {
post: "/v1/getexchangepairs",
body: "*"
};
}
rpc SetExchangePair(SetExchangePairRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/setexchangepair",
body: "*"
};
}
rpc GetOrderbookStream(GetOrderbookStreamRequest) returns (stream OrderbookResponse) {
option (google.api.http) = {
get: "/v1/getorderbookstream"
};
}
rpc GetExchangeOrderbookStream(GetExchangeOrderbookStreamRequest) returns (stream OrderbookResponse) {
option (google.api.http) = {
get: "/v1/getexchangeorderbookstream"
};
}
rpc GetTickerStream(GetTickerStreamRequest) returns (stream TickerResponse) {
option (google.api.http) = {
get: "/v1/gettickerstream"
};
}
rpc GetExchangeTickerStream(GetExchangeTickerStreamRequest) returns (stream TickerResponse) {
option (google.api.http) = {
get: "/v1/getexchangetickerstream",
};
}
rpc GetAuditEvent(GetAuditEventRequest) returns (GetAuditEventResponse) {
option (google.api.http) = {
get: "/v1/getauditevent",
};
}
rpc GCTScriptExecute(GCTScriptExecuteRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/gctscript/execute",
};
}
rpc GCTScriptUpload(GCTScriptUploadRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/gctscript/upload",
body: "*"
};
}
rpc GCTScriptReadScript(GCTScriptReadScriptRequest) returns (GCTScriptQueryResponse) {
option (google.api.http) = {
post: "/v1/gctscript/read",
body: "*"
};
}
rpc GCTScriptStatus(GCTScriptStatusRequest) returns (GCTScriptStatusResponse) {
option (google.api.http) = {
get: "/v1/gctscript/status",
};
}
rpc GCTScriptQuery(GCTScriptQueryRequest) returns (GCTScriptQueryResponse) {
option (google.api.http) = {
get: "/v1/gctscript/query",
};
}
rpc GCTScriptStop(GCTScriptStopRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/gctscript/stop",
body: "*"
};
}
rpc GCTScriptStopAll(GCTScriptStopAllRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/gctscript/stop",
body: "*"
};
}
rpc GCTScriptListAll(GCTScriptListAllRequest) returns (GCTScriptStatusResponse) {
option (google.api.http) = {
post: "/v1/gctscript/stop",
body: "*"
};
}
rpc GCTScriptAutoLoadToggle(GCTScriptAutoLoadRequest) returns (GenericResponse) {
option (google.api.http) = {
post: "/v1/gctscript/autoload",
body: "*"
};
}
rpc GetHistoricCandles(GetHistoricCandlesRequest) returns (GetHistoricCandlesResponse) {
option (google.api.http) = {
get: "/v1/gethistoriccandles"
};
}
rpc SetExchangeAsset(SetExchangeAssetRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/setexchangeasset"
};
}
rpc SetAllExchangePairs(SetExchangeAllPairsRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/setallexchangepairs"
};
}
rpc UpdateExchangeSupportedPairs(UpdateExchangeSupportedPairsRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/updateexchangesupportedpairs"
};
}
rpc GetExchangeAssets(GetExchangeAssetsRequest) returns (GetExchangeAssetsResponse) {
option (google.api.http) = {
get: "/v1/getexchangeassets"
};
}
rpc WebsocketGetInfo(WebsocketGetInfoRequest) returns (WebsocketGetInfoResponse) {
option (google.api.http) = {
get: "/v1/websocketgetinfo"
};
}
rpc WebsocketSetEnabled(WebsocketSetEnabledRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/websocketsetenabled"
};
}
rpc WebsocketGetSubscriptions(WebsocketGetSubscriptionsRequest) returns (WebsocketGetSubscriptionsResponse) {
option (google.api.http) = {
get: "/v1/websocketgetsubscriptions"
};
}
rpc WebsocketSetProxy(WebsocketSetProxyRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/websocketsetproxy"
};
}
rpc WebsocketSetURL(WebsocketSetURLRequest) returns (GenericResponse) {
option (google.api.http) = {
get: "/v1/websocketseturl"
};
}
}