Documentation ¶
Index ¶
- Constants
- type Account
- type AccountHold
- type AccountHoldsOptions
- func (opts *AccountHoldsOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *AccountHoldsOptions) EncodeQuery(req *http.Request)
- func (opts *AccountHoldsOptions) SetAfter(After string) *AccountHoldsOptions
- func (opts *AccountHoldsOptions) SetBefore(Before string) *AccountHoldsOptions
- func (opts *AccountHoldsOptions) SetLimit(Limit int) *AccountHoldsOptions
- type AccountLedger
- type AccountLedgerDetails
- type AccountLedgerOptions
- func (opts *AccountLedgerOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *AccountLedgerOptions) EncodeQuery(req *http.Request)
- func (opts *AccountLedgerOptions) SetAfter(After int) *AccountLedgerOptions
- func (opts *AccountLedgerOptions) SetBefore(Before int) *AccountLedgerOptions
- func (opts *AccountLedgerOptions) SetEndDate(EndDate string) *AccountLedgerOptions
- func (opts *AccountLedgerOptions) SetLimit(Limit int) *AccountLedgerOptions
- func (opts *AccountLedgerOptions) SetProfileID(ProfileID string) *AccountLedgerOptions
- func (opts *AccountLedgerOptions) SetStartDate(StartDate string) *AccountLedgerOptions
- type AccountTransferDetails
- type AccountTransfersOptions
- func (opts *AccountTransfersOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *AccountTransfersOptions) EncodeQuery(req *http.Request)
- func (opts *AccountTransfersOptions) SetAfter(After string) *AccountTransfersOptions
- func (opts *AccountTransfersOptions) SetBefore(Before string) *AccountTransfersOptions
- func (opts *AccountTransfersOptions) SetLimit(Limit int) *AccountTransfersOptions
- func (opts *AccountTransfersOptions) SetType(Type scalar.TransferMethod) *AccountTransfersOptions
- type AsyncTicker
- type Auction
- type AvailableBalance
- type Balance
- type BankCountry
- type Book
- type BookOptions
- type CancelOpenOrdersOptions
- func (opts *CancelOpenOrdersOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CancelOpenOrdersOptions) EncodeQuery(req *http.Request)
- func (opts *CancelOpenOrdersOptions) SetProductID(ProductID string) *CancelOpenOrdersOptions
- func (opts *CancelOpenOrdersOptions) SetProfileID(ProfileID string) *CancelOpenOrdersOptions
- type Candles
- type CandlesOptions
- func (opts *CandlesOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CandlesOptions) EncodeQuery(req *http.Request)
- func (opts *CandlesOptions) SetEnd(End string) *CandlesOptions
- func (opts *CandlesOptions) SetGranularity(Granularity scalar.Granularity) *CandlesOptions
- func (opts *CandlesOptions) SetStart(Start string) *CandlesOptions
- type Client
- func (c *Client) Account(accountId string) (m *Account, _ error)
- func (c *Client) AccountHolds(accountId string, opts *AccountHoldsOptions) (m []*AccountHold, _ error)
- func (c *Client) AccountLedger(accountId string, opts *AccountLedgerOptions) (m []*AccountLedger, _ error)
- func (c *Client) AccountTransfers(accountId string, opts *AccountTransfersOptions) (m []*Transfer, _ error)
- func (c *Client) Accounts() (m []*Account, _ error)
- func (c *Client) Book(productId string, opts *BookOptions) (m *Book, _ error)
- func (c *Client) CancelOpenOrders(opts *CancelOpenOrdersOptions) (m []*string, _ error)
- func (c *Client) CancelOrder(orderId string) (m string, _ error)
- func (c *Client) Candles(productId string, opts *CandlesOptions) (m *Candles, _ error)
- func (c *Client) CoinbaseAccountDeposit(opts *CoinbaseAccountDepositOptions) (m *Deposit, _ error)
- func (c *Client) CoinbaseAccountWithdrawal(opts *CoinbaseAccountWithdrawalOptions) (m *Withdrawal, _ error)
- func (c *Client) ConvertCurrency(opts *ConvertCurrencyOptions) (m *CurrencyConversion, _ error)
- func (c *Client) CreateOrder(opts *CreateOrderOptions) (m *CreateOrder, _ error)
- func (c *Client) CreateProfile(opts *CreateProfileOptions) (m *Profile, _ error)
- func (c *Client) CreateProfileTransfer(opts *CreateProfileTransferOptions) error
- func (c *Client) CreateReport(opts *CreateReportOptions) (m *CreateReport, _ error)
- func (c *Client) CryptoWithdrawal(opts *CryptoWithdrawalOptions) (m *Withdrawal, _ error)
- func (c *Client) Currencies() (m []*Currency, _ error)
- func (c *Client) Currency(currencyId string) (m *Currency, _ error)
- func (c *Client) CurrencyConversion(conversionId string, opts *CurrencyConversionOptions) (m *CurrencyConversion, _ error)
- func (c *Client) DeleteProfile(profileId string, opts *DeleteProfileOptions) error
- func (c *Client) ExchangeLimits(userId string) (m *ExchangeLimits, _ error)
- func (c *Client) Fees() (m *Fees, _ error)
- func (c *Client) Fills(opts *FillsOptions) (m []*Fill, _ error)
- func (c *Client) GenerateCryptoAddress(accountId string) (m *CryptoAddress, _ error)
- func (c *Client) Order(orderId string) (m *Order, _ error)
- func (c *Client) Orders(opts *OrdersOptions) (m []*Order, _ error)
- func (c *Client) PaymentMethodDeposit(opts *PaymentMethodDepositOptions) (m *Deposit, _ error)
- func (c *Client) PaymentMethodWithdrawal(opts *PaymentMethodWithdrawalOptions) (m *Withdrawal, _ error)
- func (c *Client) PaymentMethods() (m []*PaymentMethod, _ error)
- func (c *Client) Product(productId string) (m *Product, _ error)
- func (c *Client) ProductStats(productId string) (m *ProductStats, _ error)
- func (c *Client) ProductTicker(productId string) (m *ProductTicker, _ error)
- func (c *Client) Products(opts *ProductsOptions) (m []*Product, _ error)
- func (c *Client) Profile(profileId string, opts *ProfileOptions) (m *Profile, _ error)
- func (c *Client) Profiles(opts *ProfilesOptions) (m []*Profile, _ error)
- func (c *Client) RenameProfile(profileId string, opts *RenameProfileOptions) (m *Profile, _ error)
- func (c *Client) Report(reportId string) (m *Report, _ error)
- func (c *Client) Reports(opts *ReportsOptions) (m []*Report, _ error)
- func (c *Client) SignedPrices() (m *Oracle, _ error)
- func (c *Client) Trades(productId string, opts *TradesOptions) (m []*Trade, _ error)
- func (c *Client) Transfer(transferId string) (m *Transfer, _ error)
- func (c *Client) Transfers() (m []*Transfer, _ error)
- func (c *Client) Wallets() (m []*Wallet, _ error)
- func (c *Client) WithdrawalFeeEstimate(opts *WithdrawalFeeEstimateOptions) (m *WithdrawalFeeEstimate, _ error)
- type CoinbaseAccountDepositOptions
- func (opts *CoinbaseAccountDepositOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CoinbaseAccountDepositOptions) EncodeQuery(req *http.Request)
- func (opts *CoinbaseAccountDepositOptions) SetAmount(Amount float64) *CoinbaseAccountDepositOptions
- func (opts *CoinbaseAccountDepositOptions) SetCoinbaseAccountID(CoinbaseAccountID string) *CoinbaseAccountDepositOptions
- func (opts *CoinbaseAccountDepositOptions) SetCurrency(Currency string) *CoinbaseAccountDepositOptions
- func (opts *CoinbaseAccountDepositOptions) SetProfileID(ProfileID string) *CoinbaseAccountDepositOptions
- type CoinbaseAccountWithdrawalOptions
- func (opts *CoinbaseAccountWithdrawalOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CoinbaseAccountWithdrawalOptions) EncodeQuery(req *http.Request)
- func (opts *CoinbaseAccountWithdrawalOptions) SetAmount(Amount float64) *CoinbaseAccountWithdrawalOptions
- func (opts *CoinbaseAccountWithdrawalOptions) SetCoinbaseAccountID(CoinbaseAccountID string) *CoinbaseAccountWithdrawalOptions
- func (opts *CoinbaseAccountWithdrawalOptions) SetCurrency(Currency string) *CoinbaseAccountWithdrawalOptions
- func (opts *CoinbaseAccountWithdrawalOptions) SetProfileID(ProfileID string) *CoinbaseAccountWithdrawalOptions
- type ConvertCurrencyOptions
- func (opts *ConvertCurrencyOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *ConvertCurrencyOptions) EncodeQuery(req *http.Request)
- func (opts *ConvertCurrencyOptions) SetAmount(Amount float64) *ConvertCurrencyOptions
- func (opts *ConvertCurrencyOptions) SetFrom(From string) *ConvertCurrencyOptions
- func (opts *ConvertCurrencyOptions) SetNonce(Nonce string) *ConvertCurrencyOptions
- func (opts *ConvertCurrencyOptions) SetProfileID(ProfileID string) *ConvertCurrencyOptions
- func (opts *ConvertCurrencyOptions) SetTo(To string) *ConvertCurrencyOptions
- type CreateOrder
- type CreateOrderOptions
- func (opts *CreateOrderOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CreateOrderOptions) EncodeQuery(req *http.Request)
- func (opts *CreateOrderOptions) SetCancelAfter(CancelAfter scalar.CancelAfter) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetClientOid(ClientOid string) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetFunds(Funds float64) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetPostOnly(PostOnly bool) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetPrice(Price float64) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetProductID(ProductID string) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetProfileID(ProfileID string) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetSTP(STP scalar.OrderSTP) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetSide(Side scalar.OrderSide) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetSize(Size float64) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetStop(Stop scalar.OrderStop) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetStopPrice(StopPrice float64) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetTimeInForce(TimeInForce scalar.TimeInForce) *CreateOrderOptions
- func (opts *CreateOrderOptions) SetType(Type scalar.OrderType) *CreateOrderOptions
- type CreateProfileOptions
- type CreateProfileTransferOptions
- func (opts *CreateProfileTransferOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CreateProfileTransferOptions) EncodeQuery(req *http.Request)
- func (opts *CreateProfileTransferOptions) SetAmount(Amount string) *CreateProfileTransferOptions
- func (opts *CreateProfileTransferOptions) SetCurrency(Currency string) *CreateProfileTransferOptions
- func (opts *CreateProfileTransferOptions) SetFrom(From string) *CreateProfileTransferOptions
- func (opts *CreateProfileTransferOptions) SetTo(To string) *CreateProfileTransferOptions
- type CreateReport
- type CreateReportOptions
- func (opts *CreateReportOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CreateReportOptions) EncodeQuery(req *http.Request)
- func (opts *CreateReportOptions) SetAccountID(AccountID string) *CreateReportOptions
- func (opts *CreateReportOptions) SetEmail(Email string) *CreateReportOptions
- func (opts *CreateReportOptions) SetEndDate(EndDate string) *CreateReportOptions
- func (opts *CreateReportOptions) SetFormat(Format scalar.Format) *CreateReportOptions
- func (opts *CreateReportOptions) SetProductID(ProductID string) *CreateReportOptions
- func (opts *CreateReportOptions) SetProfileID(ProfileID string) *CreateReportOptions
- func (opts *CreateReportOptions) SetStartDate(StartDate string) *CreateReportOptions
- func (opts *CreateReportOptions) SetType(Type scalar.ReportType) *CreateReportOptions
- func (opts *CreateReportOptions) SetYear(Year string) *CreateReportOptions
- type CryptoAccount
- type CryptoAddress
- type CryptoAddressInfo
- type CryptoAddressWarning
- type CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *CryptoWithdrawalOptions) EncodeQuery(req *http.Request)
- func (opts *CryptoWithdrawalOptions) SetAmount(Amount float64) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetCryptoAddress(CryptoAddress string) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetCurrency(Currency string) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetDestinationTag(DestinationTag string) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetFee(Fee float64) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetNoDestinationTag(NoDestinationTag bool) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetNonce(Nonce int) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetProfileID(ProfileID string) *CryptoWithdrawalOptions
- func (opts *CryptoWithdrawalOptions) SetTwoFactorCode(TwoFactorCode string) *CryptoWithdrawalOptions
- type Currency
- type CurrencyConversion
- type CurrencyConversionOptions
- type CurrencyDetails
- type CurrencyTransferLimit
- type CurrencyTransferLimits
- type DeleteProfileOptions
- type Deposit
- type ExchangeLimits
- type FIATAccount
- type Fees
- type Fill
- type FillsOptions
- func (opts *FillsOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *FillsOptions) EncodeQuery(req *http.Request)
- func (opts *FillsOptions) SetAfter(After int) *FillsOptions
- func (opts *FillsOptions) SetBefore(Before int) *FillsOptions
- func (opts *FillsOptions) SetLimit(Limit int) *FillsOptions
- func (opts *FillsOptions) SetOrderID(OrderID string) *FillsOptions
- func (opts *FillsOptions) SetProductID(ProductID string) *FillsOptions
- func (opts *FillsOptions) SetProfileID(ProfileID string) *FillsOptions
- type Flags
- type Limits
- type Oracle
- type OraclePrices
- type Order
- type OrdersOptions
- func (opts *OrdersOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *OrdersOptions) EncodeQuery(req *http.Request)
- func (opts *OrdersOptions) SetAfter(After string) *OrdersOptions
- func (opts *OrdersOptions) SetBefore(Before string) *OrdersOptions
- func (opts *OrdersOptions) SetEndDate(EndDate string) *OrdersOptions
- func (opts *OrdersOptions) SetLimit(Limit int) *OrdersOptions
- func (opts *OrdersOptions) SetProductID(ProductID string) *OrdersOptions
- func (opts *OrdersOptions) SetProfileID(ProfileID string) *OrdersOptions
- func (opts *OrdersOptions) SetSortedBy(SortedBy string) *OrdersOptions
- func (opts *OrdersOptions) SetSorting(Sorting string) *OrdersOptions
- func (opts *OrdersOptions) SetStartDate(StartDate string) *OrdersOptions
- func (opts *OrdersOptions) SetStatus(Status []string) *OrdersOptions
- type PaymentMethod
- type PaymentMethodDepositOptions
- func (opts *PaymentMethodDepositOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *PaymentMethodDepositOptions) EncodeQuery(req *http.Request)
- func (opts *PaymentMethodDepositOptions) SetAmount(Amount float64) *PaymentMethodDepositOptions
- func (opts *PaymentMethodDepositOptions) SetCurrency(Currency string) *PaymentMethodDepositOptions
- func (opts *PaymentMethodDepositOptions) SetPaymentMethodID(PaymentMethodID string) *PaymentMethodDepositOptions
- func (opts *PaymentMethodDepositOptions) SetProfileID(ProfileID string) *PaymentMethodDepositOptions
- type PaymentMethodWithdrawalOptions
- func (opts *PaymentMethodWithdrawalOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *PaymentMethodWithdrawalOptions) EncodeQuery(req *http.Request)
- func (opts *PaymentMethodWithdrawalOptions) SetAmount(Amount float64) *PaymentMethodWithdrawalOptions
- func (opts *PaymentMethodWithdrawalOptions) SetCurrency(Currency string) *PaymentMethodWithdrawalOptions
- func (opts *PaymentMethodWithdrawalOptions) SetPaymentMethodID(PaymentMethodID string) *PaymentMethodWithdrawalOptions
- func (opts *PaymentMethodWithdrawalOptions) SetProfileID(ProfileID string) *PaymentMethodWithdrawalOptions
- type PickerData
- type Product
- type ProductStats
- type ProductTicker
- type ProductWebsocket
- type ProductsOptions
- type Profile
- type ProfileOptions
- type ProfilesOptions
- type RecurringOptions
- type RenameProfileOptions
- func (opts *RenameProfileOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *RenameProfileOptions) EncodeQuery(req *http.Request)
- func (opts *RenameProfileOptions) SetName(Name string) *RenameProfileOptions
- func (opts *RenameProfileOptions) SetProfileID(ProfileID string) *RenameProfileOptions
- type Report
- type ReportsOptions
- func (opts *ReportsOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *ReportsOptions) EncodeQuery(req *http.Request)
- func (opts *ReportsOptions) SetAfter(After string) *ReportsOptions
- func (opts *ReportsOptions) SetIgnoredExpired(IgnoredExpired bool) *ReportsOptions
- func (opts *ReportsOptions) SetLimit(Limit int) *ReportsOptions
- func (opts *ReportsOptions) SetPortfolioID(PortfolioID string) *ReportsOptions
- func (opts *ReportsOptions) SetType(Type scalar.ReportType) *ReportsOptions
- type ReportsParams
- type Role
- type SEPADepositInformation
- type SWIFTDepositInformation
- type Ticker
- type TickerChannel
- type Trade
- type TradesOptions
- func (opts *TradesOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *TradesOptions) EncodeQuery(req *http.Request)
- func (opts *TradesOptions) SetAfter(After int32) *TradesOptions
- func (opts *TradesOptions) SetBefore(Before int32) *TradesOptions
- func (opts *TradesOptions) SetLimit(Limit int32) *TradesOptions
- type Transfer
- type TransferLimits
- type UKDepositInformation
- type User
- type UserDetails
- type UserPreferences
- type Wallet
- type WireDepositInformation
- type Withdrawal
- type WithdrawalFeeEstimate
- type WithdrawalFeeEstimateOptions
- func (opts *WithdrawalFeeEstimateOptions) EncodeBody() (buf io.Reader, err error)
- func (opts *WithdrawalFeeEstimateOptions) EncodeQuery(req *http.Request)
- func (opts *WithdrawalFeeEstimateOptions) SetCryptoAddress(CryptoAddress string) *WithdrawalFeeEstimateOptions
- func (opts *WithdrawalFeeEstimateOptions) SetCurrency(Currency string) *WithdrawalFeeEstimateOptions
Examples ¶
- Client.Account
- Client.AccountHolds
- Client.AccountLedger
- Client.AccountTransfers
- Client.Accounts
- Client.Book
- Client.CancelOpenOrders
- Client.CancelOrder
- Client.Candles
- Client.CoinbaseAccountDeposit
- Client.CoinbaseAccountWithdrawal
- Client.ConvertCurrency
- Client.CreateOrder
- Client.CreateProfile
- Client.CreateProfileTransfer
- Client.CreateReport
- Client.CryptoWithdrawal
- Client.Currencies
- Client.Currency
- Client.DeleteProfile
- Client.ExchangeLimits
- Client.Fees
- Client.Fills
- Client.GenerateCryptoAddress
- Client.Order
- Client.Orders
- Client.PaymentMethodDeposit
- Client.PaymentMethodWithdrawal
- Client.PaymentMethods
- Client.Product
- Client.ProductStats
- Client.ProductTicker
- Client.Products
- Client.Profile
- Client.Profiles
- Client.RenameProfile
- Client.Report
- Client.Reports
- Client.SignedPrices
- Client.Trades
- Client.Transfer
- Client.Transfers
- Client.Wallets
- Client.WithdrawalFeeEstimate
- NewClient
- ProductWebsocket.Ticker
Constants ¶
const ( AccountHoldsPath rawPath AccountLedgerPath AccountPath AccountTransfersPath AccountsPath BookPath CancelOpenOrdersPath CancelOrderPath CandlesPath CoinbaseAccountDepositPath CoinbaseAccountWithdrawalPath ConvertCurrencyPath CreateOrderPath CreateProfilePath CreateProfileTransferPath CreateReportPath CryptoWithdrawalPath CurrenciesPath CurrencyConversionPath CurrencyPath DeleteProfilePath ExchangeLimitsPath FeesPath FillsPath GenerateCryptoAddressPath OrderPath OrdersPath PaymentMethodDepositPath PaymentMethodWithdrawalPath PaymentMethodsPath ProductPath ProductStatsPath ProductTickerPath ProductsPath ProfilePath ProfilesPath RenameProfilePath ReportPath ReportsPath SignedPricesPath TradesPath TransferPath TransfersPath WalletsPath WithdrawalFeeEstimatePath )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Account ¶
type Account struct { Available string `json:"available" bson:"available"` Balance string `json:"balance" bson:"balance"` Currency string `json:"currency" bson:"currency"` Hold string `json:"hold" bson:"hold"` ID string `json:"id" bson:"id"` ProfileID string `json:"profile_id" bson:"profile_id"` TradingEnabled bool `json:"trading_enabled" bson:"trading_enabled"` }
Account holds data for trading account from the profile of the API key
type AccountHold ¶
type AccountHold struct { CreatedAt time.Time `json:"created_at" bson:"created_at"` ID string `json:"id" bson:"id"` Ref string `json:"ref" bson:"ref"` Type string `json:"type" bson:"type"` UpdatedAt time.Time `json:"updated_at" bson:"updated_at"` }
AccountHold represents the hold on an account that belong to the same profile as the API key. Holds are placed on an account for any active orders or pending withdraw requests. As an order is filled, the hold amount is updated. If an order is canceled, any remaining hold is removed. For withdrawals, the hold is removed after it is completed.
type AccountHoldsOptions ¶
type AccountHoldsOptions struct { // After is used for pagination and sets end cursor to `after` date. After *string `json:"after" bson:"after"` // Before is used for pagination and sets start cursor to `before` date. Before *string `json:"before" bson:"before"` // Limit puts a limit on number of results to return. Limit *int `json:"limit" bson:"limit"` }
AccountHoldsOptions are options for API requests.
func (*AccountHoldsOptions) EncodeBody ¶
func (opts *AccountHoldsOptions) EncodeBody() (buf io.Reader, err error)
func (*AccountHoldsOptions) EncodeQuery ¶
func (opts *AccountHoldsOptions) EncodeQuery(req *http.Request)
func (*AccountHoldsOptions) SetAfter ¶
func (opts *AccountHoldsOptions) SetAfter(After string) *AccountHoldsOptions
SetAfter sets the After field on AccountHoldsOptions. After is used for pagination and sets end cursor to `after` date.
func (*AccountHoldsOptions) SetBefore ¶
func (opts *AccountHoldsOptions) SetBefore(Before string) *AccountHoldsOptions
SetBefore sets the Before field on AccountHoldsOptions. Before is used for pagination and sets start cursor to `before` date.
func (*AccountHoldsOptions) SetLimit ¶
func (opts *AccountHoldsOptions) SetLimit(Limit int) *AccountHoldsOptions
SetLimit sets the Limit field on AccountHoldsOptions. Limit puts a limit on number of results to return.
type AccountLedger ¶
type AccountLedger struct { Amount string `json:"amount" bson:"amount"` Balance string `json:"balance" bson:"balance"` CreatedAt time.Time `json:"created_at" bson:"created_at"` Details AccountLedgerDetails `json:"details" bson:"details"` ID string `json:"id" bson:"id"` Type scalar.EntryType `json:"type" bson:"type"` }
AccountLedger lists ledger activity for an account. This includes anything that would affect the accounts balance - transfers, trades, fees, etc.
type AccountLedgerDetails ¶
type AccountLedgerDetails struct { OrderID string `json:"order_id" bson:"order_id"` ProductID string `json:"product_id" bson:"product_id"` TradeID string `json:"trade_id" bson:"trade_id"` }
AccountLedgerDetails are the details for account history.
type AccountLedgerOptions ¶
type AccountLedgerOptions struct { // After is used for pagination. Sets end cursor to `after` date. After *int `json:"after" bson:"after"` // Before is used for pagination. Sets start cursor to `before` date. Before *int `json:"before" bson:"before"` // EndDate will filter results by maximum posted date. EndDate *string `json:"end_date" bson:"end_date"` // Limit puts a limit on number of results to return. Limit *int `json:"limit" bson:"limit"` // StartDate will filter results by minimum posted date. StartDate *string `json:"start_date" bson:"start_date"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
AccountLedgerOptions are options for API requests.
func (*AccountLedgerOptions) EncodeBody ¶
func (opts *AccountLedgerOptions) EncodeBody() (buf io.Reader, err error)
func (*AccountLedgerOptions) EncodeQuery ¶
func (opts *AccountLedgerOptions) EncodeQuery(req *http.Request)
func (*AccountLedgerOptions) SetAfter ¶
func (opts *AccountLedgerOptions) SetAfter(After int) *AccountLedgerOptions
SetAfter sets the After field on AccountLedgerOptions. After is used for pagination. Sets end cursor to `after` date.
func (*AccountLedgerOptions) SetBefore ¶
func (opts *AccountLedgerOptions) SetBefore(Before int) *AccountLedgerOptions
SetBefore sets the Before field on AccountLedgerOptions. Before is used for pagination. Sets start cursor to `before` date.
func (*AccountLedgerOptions) SetEndDate ¶
func (opts *AccountLedgerOptions) SetEndDate(EndDate string) *AccountLedgerOptions
SetEndDate sets the EndDate field on AccountLedgerOptions. EndDate will filter results by maximum posted date.
func (*AccountLedgerOptions) SetLimit ¶
func (opts *AccountLedgerOptions) SetLimit(Limit int) *AccountLedgerOptions
SetLimit sets the Limit field on AccountLedgerOptions. Limit puts a limit on number of results to return.
func (*AccountLedgerOptions) SetProfileID ¶
func (opts *AccountLedgerOptions) SetProfileID(ProfileID string) *AccountLedgerOptions
SetProfileID sets the ProfileID field on AccountLedgerOptions.
func (*AccountLedgerOptions) SetStartDate ¶
func (opts *AccountLedgerOptions) SetStartDate(StartDate string) *AccountLedgerOptions
SetStartDate sets the StartDate field on AccountLedgerOptions. StartDate will filter results by minimum posted date.
type AccountTransferDetails ¶
type AccountTransferDetails struct { CoinbaseAccountID string `json:"coinbase_account_id" bson:"coinbase_account_id"` CoinbasePaymentMethodID string `json:"coinbase_payment_method_id" bson:"coinbase_payment_method_id"` CoinbaseTransactionID string `json:"coinbase_transaction_id" bson:"coinbase_transaction_id"` }
AccountTransferDetails are the details for an account transfer.
type AccountTransfersOptions ¶
type AccountTransfersOptions struct { // After is used for pagination. Sets end cursor to `after` date. After *string `json:"after" bson:"after"` // Before is used for pagination. Sets start cursor to `before` date. Before *string `json:"before" bson:"before"` // Limit puts a limit on number of results to return. Limit *int `json:"limit" bson:"limit"` Type *scalar.TransferMethod `json:"type" bson:"type"` }
AccountTransfersOptions are options for API requests.
func (*AccountTransfersOptions) EncodeBody ¶
func (opts *AccountTransfersOptions) EncodeBody() (buf io.Reader, err error)
func (*AccountTransfersOptions) EncodeQuery ¶
func (opts *AccountTransfersOptions) EncodeQuery(req *http.Request)
func (*AccountTransfersOptions) SetAfter ¶
func (opts *AccountTransfersOptions) SetAfter(After string) *AccountTransfersOptions
SetAfter sets the After field on AccountTransfersOptions. After is used for pagination. Sets end cursor to `after` date.
func (*AccountTransfersOptions) SetBefore ¶
func (opts *AccountTransfersOptions) SetBefore(Before string) *AccountTransfersOptions
SetBefore sets the Before field on AccountTransfersOptions. Before is used for pagination. Sets start cursor to `before` date.
func (*AccountTransfersOptions) SetLimit ¶
func (opts *AccountTransfersOptions) SetLimit(Limit int) *AccountTransfersOptions
SetLimit sets the Limit field on AccountTransfersOptions. Limit puts a limit on number of results to return.
func (*AccountTransfersOptions) SetType ¶
func (opts *AccountTransfersOptions) SetType(Type scalar.TransferMethod) *AccountTransfersOptions
SetType sets the Type field on AccountTransfersOptions.
type AsyncTicker ¶
AsyncTicker is an object that helps maintain state when trying to stream product ticker data. It starts an underlying worker and queues versions of itself to stream from the websocket connection.
func (*AsyncTicker) Channel ¶
func (ticker *AsyncTicker) Channel() TickerChannel
Channel returns the ticker channel for streaming
func (*AsyncTicker) Close ¶
func (ticker *AsyncTicker) Close() error
Close unsubscribes the message from the websocket and closes the channel. The Close routine can be called multiple times safely. This method is run asyncronously, relying on the worker to not enqueue jobs where the previous iteration has not been closed. The asynchronous nature of the function allows the user to "Close" the job without waiting on the closing channel to be resolved.
func (*AsyncTicker) Open ¶
func (ticker *AsyncTicker) Open() *AsyncTicker
Open starts the websocket stream, streaming it into the AsyncTicker.channel. This method is idempotent, so if you call it multiple times successively without closing the websocket it will close the ws for you in each successive run and re-make the channels to stream over.f the calls need to return without starting the go-routing.
type Auction ¶
type Auction struct { AuctionState string `json:"auction_state" bson:"auction_state"` BestAskPrice string `json:"best_ask_price" bson:"best_ask_price"` BestAskSize string `json:"best_ask_size" bson:"best_ask_size"` BestBidPrice string `json:"best_bid_price" bson:"best_bid_price"` BestBidSize string `json:"best_bid_size" bson:"best_bid_size"` CanOpen string `json:"can_open" bson:"can_open"` OpenPrice string `json:"open_price" bson:"open_price"` OpenSize string `json:"open_size" bson:"open_size"` Time time.Time `json:"time" bson:"time"` }
Auction is an object of data concerning a book request.
type AvailableBalance ¶
type AvailableBalance struct { Amount string `json:"amount" bson:"amount"` Currency string `json:"currency" bson:"currency"` Scale string `json:"scale" bson:"scale"` }
AvailableBalance is the available balance on the coinbase account
type Balance ¶
type Balance struct { Amount string `json:"amount" bson:"amount"` Currency string `json:"currency" bson:"currency"` }
Balance is the balance for picker data
type BankCountry ¶
type BankCountry struct { Code string `json:"code" bson:"code"` Name string `json:"name" bson:"name"` }
BankCountry are the name and code for the bank's country associated with a wallet
type Book ¶
type Book struct { Asks scalar.BidAsk `json:"asks" bson:"asks"` Auction Auction `json:"auction" bson:"auction"` AuctionMode bool `json:"auction_mode" bson:"auction_mode"` Bids scalar.BidAsk `json:"bids" bson:"bids"` Sequence float64 `json:"sequence" bson:"sequence"` }
Book is a list of open orders for a product. The amount of detail shown can be customized with the level parameter.
type BookOptions ¶
type BookOptions struct { // Levels 1 and 2 are aggregated. The size field is the sum of the size of the orders at that price, and num-orders is // the count of orders at that price; size should not be multiplied by num-orders. Level 3 is non-aggregated and returns // the entire order book. While the book is in an auction, the L1, L2 and L3 book will also contain the most recent // indicative quote disseminated during the auction, and auction_mode will be set to true. These indicative quote // messages are sent on an interval basis (approximately once a second) during the collection phase of an auction and // includes information about the tentative price and size affiliated with the completion. Level 1 and Level 2 are // recommended for polling. For the most up-to-date data, consider using the websocket stream. Level 3 is only // recommended for users wishing to maintain a full real-time order book using the websocket stream. Abuse of Level 3 // via polling will cause your access to be limited or blocked. Level *int32 `json:"level" bson:"level"` }
BookOptions are options for API requests.
func (*BookOptions) EncodeBody ¶
func (opts *BookOptions) EncodeBody() (buf io.Reader, err error)
func (*BookOptions) EncodeQuery ¶
func (opts *BookOptions) EncodeQuery(req *http.Request)
func (*BookOptions) SetLevel ¶
func (opts *BookOptions) SetLevel(Level int32) *BookOptions
SetLevel sets the Level field on BookOptions. Levels 1 and 2 are aggregated. The size field is the sum of the size of the orders at that price, and num-orders is the count of orders at that price; size should not be multiplied by num-orders. Level 3 is non-aggregated and returns the entire order book. While the book is in an auction, the L1, L2 and L3 book will also contain the most recent indicative quote disseminated during the auction, and auction_mode will be set to true. These indicative quote messages are sent on an interval basis (approximately once a second) during the collection phase of an auction and includes information about the tentative price and size affiliated with the completion. Level 1 and Level 2 are recommended for polling. For the most up-to-date data, consider using the websocket stream. Level 3 is only recommended for users wishing to maintain a full real-time order book using the websocket stream. Abuse of Level 3 via polling will cause your access to be limited or blocked.
type CancelOpenOrdersOptions ¶
type CancelOpenOrdersOptions struct { ProductID *string `json:"product_id" bson:"product_id"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
CancelOpenOrdersOptions are options for API requests.
func (*CancelOpenOrdersOptions) EncodeBody ¶
func (opts *CancelOpenOrdersOptions) EncodeBody() (buf io.Reader, err error)
func (*CancelOpenOrdersOptions) EncodeQuery ¶
func (opts *CancelOpenOrdersOptions) EncodeQuery(req *http.Request)
func (*CancelOpenOrdersOptions) SetProductID ¶
func (opts *CancelOpenOrdersOptions) SetProductID(ProductID string) *CancelOpenOrdersOptions
SetProductID sets the ProductID field on CancelOpenOrdersOptions.
func (*CancelOpenOrdersOptions) SetProfileID ¶
func (opts *CancelOpenOrdersOptions) SetProfileID(ProfileID string) *CancelOpenOrdersOptions
SetProfileID sets the ProfileID field on CancelOpenOrdersOptions.
type Candles ¶
type Candles [][]float64
Candles are the historic rates for a product. Rates are returned in grouped buckets. Candle schema is of the form `[timestamp, price_low, price_high, price_open, price_close]`
type CandlesOptions ¶
type CandlesOptions struct { // End is a timestamp for ending range of aggregations. End *string `json:"end" bson:"end"` // Granularity is one of the following values: {60, 300, 900, 3600, 21600, 86400}. Otherwise, your request will be // rejected. These values correspond to timeslices representing one minute, five minutes, fifteen minutes, one hour, six // hours, and one day, respectively. Granularity *scalar.Granularity `json:"granularity" bson:"granularity"` // Start is a timestamp for starting range of aggregations. Start *string `json:"start" bson:"start"` }
CandlesOptions are options for API requests.
func (*CandlesOptions) EncodeBody ¶
func (opts *CandlesOptions) EncodeBody() (buf io.Reader, err error)
func (*CandlesOptions) EncodeQuery ¶
func (opts *CandlesOptions) EncodeQuery(req *http.Request)
func (*CandlesOptions) SetEnd ¶
func (opts *CandlesOptions) SetEnd(End string) *CandlesOptions
SetEnd sets the End field on CandlesOptions. End is a timestamp for ending range of aggregations.
func (*CandlesOptions) SetGranularity ¶
func (opts *CandlesOptions) SetGranularity(Granularity scalar.Granularity) *CandlesOptions
SetGranularity sets the Granularity field on CandlesOptions. Granularity is one of the following values: {60, 300, 900, 3600, 21600, 86400}. Otherwise, your request will be rejected. These values correspond to timeslices representing one minute, five minutes, fifteen minutes, one hour, six hours, and one day, respectively.
func (*CandlesOptions) SetStart ¶
func (opts *CandlesOptions) SetStart(Start string) *CandlesOptions
SetStart sets the Start field on CandlesOptions. Start is a timestamp for starting range of aggregations.
type Client ¶
Client is a wrapper for http.Client.
func NewClient ¶
NewClient will return a new HTTP client to interface with the Coinbase Pro API.
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatal(err) } fmt.Printf("A Coinbase Pro client: %v", client) }
Output:
func (*Client) Account ¶
Account will return data for a single account. Use this endpoint when you know the account_id. API key must belong to the same profile as the account.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getaccount
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get the account ID to look up. accountID := os.Getenv("CB_PRO_ACCOUNT_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } account, err := client.Account(accountID) if err != nil { log.Fatalf("Error fetching account: %v", err) } fmt.Printf("account: %+v\n", account) }
Output:
func (*Client) AccountHolds ¶
func (c *Client) AccountHolds(accountId string, opts *AccountHoldsOptions) (m []*AccountHold, _ error)
AccountHolds will return the holds of an account that belong to the same profile as the API key. Holds are placed on an account for any active orders or pending withdraw requests. As an order is filled, the hold amount is updated. If an order is canceled, any remaining hold is removed. For withdrawals, the hold is removed after it is completed.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getaccountholds
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get the account ID to look up. accountID := os.Getenv("CB_PRO_ACCOUNT_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Since the order above will forever be in an "active" status, we should // have a hold value waiting for us. holds, err := client.AccountHolds(accountID, new(coinbasepro.AccountHoldsOptions). SetLimit(1). SetBefore("2010-01-01"). SetAfter("2080-01-01")) if err != nil { log.Fatalf("Error fetching holds: %v", err) } fmt.Printf("holds: %+v\n", holds) }
Output:
func (*Client) AccountLedger ¶
func (c *Client) AccountLedger(accountId string, opts *AccountLedgerOptions) (m []*AccountLedger, _ error)
AccountLedger returns ledger activity for an account. This includes anything that would affect the accounts balance - transfers, trades, fees, etc. This endpoint requires either the "view" or "trade" permission.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getaccountledger
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get the account ID and profile ID for request. accountID := os.Getenv("CB_PRO_ACCOUNT_ID") profileID := os.Getenv("CB_PRO_PROFILE_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } ledger, err := client.AccountLedger(accountID, new(coinbasepro.AccountLedgerOptions). SetStartDate("2010-01-01"). SetEndDate("2080-01-01"). SetAfter(1526365354). SetLimit(1). SetProfileID(profileID)) if err != nil { log.Fatalf("Error fetching ledger: %v", err) } fmt.Printf("ledger: %+v\n", ledger) }
Output:
func (*Client) AccountTransfers ¶
func (c *Client) AccountTransfers(accountId string, opts *AccountTransfersOptions) (m []*Transfer, _ error)
AccountTransfers returns past withdrawals and deposits for an account.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getaccounttransfers
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/scalar" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get the account ID for request. accountID := os.Getenv("CB_PRO_ACCOUNT_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Get the resulting Account Transfers. transfers, err := client.AccountTransfers(accountID, new(coinbasepro.AccountTransfersOptions). SetBefore("2010-01-01"). SetAfter("2080-01-01"). SetType(scalar.TransferMethodDeposit). SetLimit(1)) if err != nil { log.Fatalf("Error fetching account transfers: %v", err) } fmt.Printf("account transfers: %+v\n", transfers) }
Output:
func (*Client) Accounts ¶
Accounts will return a list of trading accounts from the profile of the API key.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getaccounts
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } accounts, err := client.Accounts() if err != nil { log.Fatalf("Error fetching accounts: %v", err) } fmt.Printf("accounts: %+v\n", accounts) }
Output:
func (*Client) Book ¶
func (c *Client) Book(productId string, opts *BookOptions) (m *Book, _ error)
Book will return a list of open orders for a product. The amount of detail shown can be customized with the level parameter.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getproductbook
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } book, err := client.Book("BTC-USD", new(coinbasepro.BookOptions).SetLevel(1)) if err != nil { log.Fatalf("Error fetching book: %v", err) } fmt.Printf("book: %+v\n", book) }
Output:
func (*Client) CancelOpenOrders ¶
func (c *Client) CancelOpenOrders(opts *CancelOpenOrdersOptions) (m []*string, _ error)
CancelOpenOrders will try with best effort to cancel all open orders. This may require you to make the request multiple times until all of the open orders are deleted.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_deleteorders
Example ¶
package main import ( "context" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get the profile ID for request. profileID := os.Getenv("CB_PRO_PROFILE_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Cancel the order by simply cancelling all BTC-USD orders for some profile ID. _, err = client.CancelOpenOrders(new(coinbasepro.CancelOpenOrdersOptions). SetProductID("BTC-USD"). SetProfileID(profileID)) if err != nil { log.Fatalf("Error canceling open orders: %v", err) } }
Output:
func (*Client) CancelOrder ¶
CancelOrder will cancel a single open order by order id.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_deleteorder
Example ¶
package main import ( "context" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get an orderID for cancellation orderID := os.Getenv("CB_PRO_ORDER_ID_FOR_CANCELLATION") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Cancel the order by using the order's ID. _, err = client.CancelOrder(orderID) if err != nil { log.Fatalf("Error canceling order: %v", err) } }
Output:
func (*Client) Candles ¶
func (c *Client) Candles(productId string, opts *CandlesOptions) (m *Candles, _ error)
Candles will return historic rates for a product.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getproductcandles
Example ¶
package main import ( "context" "fmt" "log" "os" "time" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/scalar" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } startTimestamp := time.Date(2018, 11, 9, 17, 11, 8, 0, time.UTC).Format(time.RFC3339) endTimestamp := time.Date(2018, 11, 9, 18, 11, 8, 0, time.UTC).Format(time.RFC3339) candles, err := client.Candles("BTC-USD", new(coinbasepro.CandlesOptions). SetStart(startTimestamp). SetEnd(endTimestamp). SetGranularity(scalar.Seconds60)) if err != nil { log.Fatalf("Error canceling order: %v", err) } fmt.Printf("candles: %+v\n", candles) }
Output:
func (*Client) CoinbaseAccountDeposit ¶
func (c *Client) CoinbaseAccountDeposit(opts *CoinbaseAccountDepositOptions) (m *Deposit, _ error)
CoinbaseAccountDeposit funds from a www.coinbase.com wallet to the specified profile_id.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postdepositcoinbaseaccount
Example ¶
package main import ( "context" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID to deposit into and a wallet ID to withdraw from. accountCurrency := os.Getenv("CB_PRO_ACCOUNT_CURRENCY") profileID := os.Getenv("CB_PRO_PROFILE_ID") walletID := os.Getenv("CB_PRO_WALLET_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Make the deposit. _, err = client.CoinbaseAccountDeposit(new(coinbasepro.CoinbaseAccountDepositOptions). SetProfileID(profileID). SetCoinbaseAccountID(walletID). SetAmount(1). SetCurrency(accountCurrency)) if err != nil { log.Fatalf("Error making deposit: %v", err) } }
Output:
func (*Client) CoinbaseAccountWithdrawal ¶
func (c *Client) CoinbaseAccountWithdrawal(opts *CoinbaseAccountWithdrawalOptions) (m *Withdrawal, _ error)
AccountWithdraws funds from the specified profile_id to a www.coinbase.com wallet. Withdraw funds to a coinbase account. You can move funds between your Coinbase accounts and your Coinbase Exchange trading accounts within your daily limits. Moving funds between Coinbase and Coinbase Exchange is instant and free. See the Coinbase Accounts section for retrieving your Coinbase accounts. This endpoint requires the "transfer" permission.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postwithdrawcoinbaseaccount
Example ¶
package main import ( "context" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID to withdraw from and a wallet ID to deposit int. accountCurrency := os.Getenv("CB_PRO_ACCOUNT_CURRENCY") profileID := os.Getenv("CB_PRO_PROFILE_ID") walletID := os.Getenv("CB_PRO_WALLET_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Withdraw the deposit. _, err = client.CoinbaseAccountWithdrawal(new(coinbasepro.CoinbaseAccountWithdrawalOptions). SetProfileID(profileID). SetCoinbaseAccountID(walletID). SetAmount(1). SetCurrency(accountCurrency)) if err != nil { log.Fatalf("Error making withdrawal: %v", err) } }
Output:
func (*Client) ConvertCurrency ¶
func (c *Client) ConvertCurrency(opts *ConvertCurrencyOptions) (m *CurrencyConversion, _ error)
ConvertCurrency converts funds from from currency to to currency. Funds are converted on the from account in the profile_id profile. This endpoint requires the "trade" permission. A successful conversion will be assigned a conversion id. The corresponding ledger entries for a conversion will reference this conversion id
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postconversion
Example ¶
package main import ( "context" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID for the request. profileID := os.Getenv("CB_PRO_PROFILE_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Convert the USD into USDC. _, err = client.ConvertCurrency(new(coinbasepro.ConvertCurrencyOptions). SetAmount(1). SetFrom("USD"). SetTo("USDC"). SetProfileID(profileID)) if err != nil { log.Fatalf("Error converting currency: %v", err) } }
Output:
func (*Client) CreateOrder ¶
func (c *Client) CreateOrder(opts *CreateOrderOptions) (m *CreateOrder, _ error)
CreateOrder will create a new an order. You can place two types of orders: limit and market. Orders can only be placed if your account has sufficient funds. Once an order is placed, your account funds will be put on hold for the duration of the order. How much and which funds are put on hold depends on the order type and parameters specified.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postorders
Example ¶
package main import ( "context" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/scalar" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID for the request. profileID := os.Getenv("CB_PRO_PROFILE_ID") productID := os.Getenv("CB_PRO_PRODUCT_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } order, err := client.CreateOrder(new(coinbasepro.CreateOrderOptions). SetProfileID(profileID). SetType(scalar.OrderTypeLimit). SetSide(scalar.OrderSideSell). SetSTP(scalar.OrderSTP_DC). SetStop(scalar.OrderStopLoss). SetTimeInForce(scalar.TimeInForceGTC). SetCancelAfter(scalar.CancelAfterMin). SetProductID(productID). SetStopPrice(1.0). SetSize(1.0). SetPrice(1.0)) if err != nil { log.Fatal(err) } // Cancel the order since it will almost definitely never get filled. if _, err := client.CancelOrder(order.ID); err != nil { log.Fatal(err) } }
Output:
func (*Client) CreateProfile ¶
func (c *Client) CreateProfile(opts *CreateProfileOptions) (m *Profile, _ error)
CreateProfile will create a new profile. Will fail if no name is provided or if user already has max number of profiles.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postprofile
Example ¶
package main import () func main() { // TODO: Figure out why we get a 403 HTTP Status }
Output:
func (*Client) CreateProfileTransfer ¶
func (c *Client) CreateProfileTransfer(opts *CreateProfileTransferOptions) error
CreateProfileTransfer will transfer an amount of currency from one profile to another. This endpoint requires the "transfer" permission.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postprofiletransfer
Example ¶
package main import () func main() { // TODO: Figure out why we get a 403 HTTP Status }
Output:
func (*Client) CreateReport ¶
func (c *Client) CreateReport(opts *CreateReportOptions) (m *CreateReport, _ error)
CreateReport generates a report. Reports are either for past account history or past fills on either all accounts or one product's account.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postreports
Example ¶
package main import ( "context" "log" "os" "time" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/scalar" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID for the request. profileID := os.Getenv("CB_PRO_PROFILE_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } startTimestamp := time.Date(2018, 11, 9, 17, 11, 8, 0, time.UTC).Format(time.RFC3339) endTimestamp := time.Date(2018, 11, 9, 18, 11, 8, 0, time.UTC).Format(time.RFC3339) _, err = client.CreateReport(new(coinbasepro.CreateReportOptions). SetType(scalar.ReportTypeFills). SetFormat(scalar.FormatPDF). SetProfileID(profileID). SetProductID("BTC-USD"). SetStartDate(startTimestamp). SetEndDate(endTimestamp)) if err != nil { log.Fatalf("Error creating report: %v", err) } }
Output:
func (*Client) CryptoWithdrawal ¶
func (c *Client) CryptoWithdrawal(opts *CryptoWithdrawalOptions) (m *Withdrawal, _ error)
CryptoWithdrawal funds from the specified profile_id to an external crypto address. This endpoint requires the "transfer" permission. API key must belong to default profile.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postwithdrawcrypto
Example ¶
package main import ( "context" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a wallet ID for the request. walletID := os.Getenv("CB_PRO_WALLET_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Get an address for the target wallet. address, _ := client.GenerateCryptoAddress(walletID) // Withdraw the funds using the generated USDC wallet address. _, err = client.CryptoWithdrawal(new(coinbasepro.CryptoWithdrawalOptions). SetCryptoAddress(address.Address). SetAmount(1). SetCurrency("USDC")) if err != nil { log.Fatalf("Error withdrawing crypto: %v", err) } }
Output:
func (*Client) Currencies ¶
Currencies returns a list of all known currencies. Note: Not all currencies may be currently in use for trading.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getcurrencies
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } currencies, err := client.Currencies() if err != nil { log.Fatalf("Error listing currencies: %v", err) } fmt.Printf("currencies: %+v\n", currencies) }
Output:
func (*Client) Currency ¶
Currency returns a single currency by id.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getcurrency
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a valid currency. accountCurrency := os.Getenv("CB_PRO_ACCOUNT_CURRENCY") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } currency, err := client.Currency(accountCurrency) if err != nil { log.Fatalf("Error fetching currency by ID: %v", err) } fmt.Printf("currency: %+v\n", currency) }
Output:
func (*Client) CurrencyConversion ¶
func (c *Client) CurrencyConversion(conversionId string, opts *CurrencyConversionOptions) (m *CurrencyConversion, _ error)
CurrencyConversion returns the currency conversion by conversion id (i.e. USD -> USDC).
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getconversion
func (*Client) DeleteProfile ¶
func (c *Client) DeleteProfile(profileId string, opts *DeleteProfileOptions) error
DeleteProfile deletes the profile specified by profile_id and transfers all funds to the profile specified by to. Fails if there are any open orders on the profile to be deleted.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_putprofiledeactivate
Example ¶
package main import () func main() { // TODO: Figure out why we get a 403 HTTP Status }
Output:
func (*Client) ExchangeLimits ¶
func (c *Client) ExchangeLimits(userId string) (m *ExchangeLimits, _ error)
ExchangeLimits returns exchange limits information for a single user.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getuserexchangelimits
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a valid User ID from the account's profile. userID := os.Getenv("CB_PRO_USER_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } exchangeLimits, err := client.ExchangeLimits(userID) if err != nil { log.Fatalf("Error fetching exchange limits: %v", err) } fmt.Printf("exchange limits: %+v\n", exchangeLimits) }
Output:
func (*Client) Fees ¶
Fees returns fees rates and 30 days trailing volume.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getfees
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } fees, err := client.Fees() if err != nil { log.Fatalf("Error fetching fees: %v", err) } fmt.Printf("fees: %+v\n", fees) }
Output:
func (*Client) Fills ¶
func (c *Client) Fills(opts *FillsOptions) (m []*Fill, _ error)
Fills returns a list of fills. A fill is a partial or complete match on a specific order.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getfills
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID for the request. profileID := os.Getenv("CB_PRO_PROFILE_ID") productID := os.Getenv("CB_PRO_PRODUCT_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } fills, err := client.Fills(new(coinbasepro.FillsOptions). SetAfter(1526365354). SetBefore(1652574195). SetLimit(1). SetProductID(productID). SetProfileID(profileID)) if err != nil { log.Fatalf("Error fetching fills: %v", err) } fmt.Printf("fills: %+v\n", fills) }
Output:
func (*Client) GenerateCryptoAddress ¶
func (c *Client) GenerateCryptoAddress(accountId string) (m *CryptoAddress, _ error)
GenerateCryptoAddress will create a one-time crypto address for depositing crypto, using a wallet account id. This endpoint requires the "transfer" permission. API key must belong to default profile.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postcoinbaseaccountaddresses
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a wallet ID for the request. walletID := os.Getenv("CB_PRO_WALLET_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } address, err := client.GenerateCryptoAddress(walletID) if err != nil { log.Fatalf("Error fetching address: %v", err) } fmt.Printf("USD wallet address: %+v\n", address) }
Output:
func (*Client) Order ¶
Order returns a single order by id.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getorder
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Lookup the order. order, _ := client.Order("your-order-id") fmt.Printf("order: %+v\n", order) }
Output:
func (*Client) Orders ¶
func (c *Client) Orders(opts *OrdersOptions) (m []*Order, _ error)
Orders will return your current open orders. Only open or un-settled orders are returned by default. As soon as an order is no longer open and settled, it will no longer appear in the default request. Open orders may change state between the request and the response depending on market conditions.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getorders
Example ¶
package main import ( "context" "fmt" "log" "os" "time" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID for the request. profileID := os.Getenv("CB_PRO_PROFILE_ID") productID := os.Getenv("CB_PRO_PRODUCT_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } startTimestamp := time.Date(2018, 11, 9, 17, 11, 8, 0, time.UTC).Format(time.RFC3339) endTimestamp := time.Date(2025, 11, 9, 18, 11, 8, 0, time.UTC).Format(time.RFC3339) // Lookup the order. orders, err := client.Orders(new(coinbasepro.OrdersOptions). SetAfter("2023-01-01"). SetBefore("2010-01-01"). SetStartDate(startTimestamp). SetEndDate(endTimestamp). SetLimit(1). SetProductID(productID). SetProfileID(profileID)) if err != nil { log.Fatalf("Error fetching order: %v", err) } fmt.Printf("orders: %+v\n", orders) }
Output:
func (*Client) PaymentMethodDeposit ¶
func (c *Client) PaymentMethodDeposit(opts *PaymentMethodDepositOptions) (m *Deposit, _ error)
PaymentMethodDeposit will fund from a linked external payment method to the specified profile_id.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postdepositpaymentmethod
Example ¶
package main import () func main() { // TODO: Figure out why we get a 403 HTTP Status }
Output:
func (*Client) PaymentMethodWithdrawal ¶
func (c *Client) PaymentMethodWithdrawal(opts *PaymentMethodWithdrawalOptions) (m *Withdrawal, _ error)
PaymentMethodWithdrawal will fund from the specified profile_id to a linked external payment method. This endpoint requires the "transfer" permission. API key is restricted to the default profile.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_postwithdrawpaymentmethod
Example ¶
package main import () func main() { // TODO: Figure out why we get a 403 HTTP Status }
Output:
func (*Client) PaymentMethods ¶
func (c *Client) PaymentMethods() (m []*PaymentMethod, _ error)
PaymentMethods returns a list of the user's linked payment methods.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getpaymentmethods
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } paymentMethods, err := client.PaymentMethods() if err != nil { log.Fatalf("Error fetching payment methods: %v", err) } fmt.Printf("payment methods: %+v\n", paymentMethods) }
Output:
func (*Client) Product ¶
Product will return information on a single product.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getproduct
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } product, err := client.Product("BTC-USD") if err != nil { log.Fatalf("Error fetching product: %v", err) } fmt.Printf("product: %+v\n", product) }
Output:
func (*Client) ProductStats ¶
func (c *Client) ProductStats(productId string) (m *ProductStats, _ error)
ProductStats will return 30day and 24hour stats for a product.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getproductstats
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } stats, err := client.ProductStats("BTC-USD") if err != nil { log.Fatalf("Error fetching stats: %v", err) } fmt.Printf("stats: %+v\n", stats) }
Output:
func (*Client) ProductTicker ¶
func (c *Client) ProductTicker(productId string) (m *ProductTicker, _ error)
ProductTicker will return snapshot information about the last trade (tick), best bid/ask and 24h volume.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getproductticker
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } ticker, err := client.ProductTicker("BTC-USD") if err != nil { log.Fatalf("Error fetching ticker: %v", err) } fmt.Printf("ticker: %+v\n", ticker) }
Output:
func (*Client) Products ¶
func (c *Client) Products(opts *ProductsOptions) (m []*Product, _ error)
Products will return a list of available currency pairs for trading.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getproducts
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } products, err := client.Products(new(coinbasepro.ProductsOptions).SetType("USD-BTC")) if err != nil { log.Fatalf("Error fetching products: %v", err) } fmt.Printf("products: %+v\n", products) }
Output:
func (*Client) Profile ¶
func (c *Client) Profile(profileId string, opts *ProfileOptions) (m *Profile, _ error)
Profile returns information for a single profile. Use this endpoint when you know the profile_id. This endpoint requires the "view" permission and is accessible by any profile's API key.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getprofile
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID for the request. profileID := os.Getenv("CB_PRO_PROFILE_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } profile, err := client.Profile(profileID, new(coinbasepro.ProfileOptions).SetActive(true)) if err != nil { log.Fatalf("Error fetching profile: %v", err) } fmt.Printf("profile: %+v\n", profile) }
Output:
func (*Client) Profiles ¶
func (c *Client) Profiles(opts *ProfilesOptions) (m []*Profile, _ error)
Profiles returns a list of all of the current user's profiles.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getprofiles
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } profiles, err := client.Profiles(new(coinbasepro.ProfilesOptions).SetActive(true)) if err != nil { log.Fatalf("Error fetching profiles: %v", err) } fmt.Printf("profiles: %+v\n", profiles) }
Output:
func (*Client) RenameProfile ¶
func (c *Client) RenameProfile(profileId string, opts *RenameProfileOptions) (m *Profile, _ error)
RenameProfile will rename a profile. Names 'default' and 'margin' are reserved.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_putprofile
Example ¶
package main import () func main() { // TODO: Figure out why we get a 403 HTTP Status }
Output:
func (*Client) Report ¶
Report will return a specific report by report_id.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getreport
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } report, _ := client.Report("your-report-id") fmt.Printf("report: %+v\n", report) }
Output:
func (*Client) Reports ¶
func (c *Client) Reports(opts *ReportsOptions) (m []*Report, _ error)
Reports returns a list of past fills/account reports.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getreports
Example ¶
package main import ( "context" "fmt" "log" "os" "time" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/scalar" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a profile ID for the request. profileID := os.Getenv("CB_PRO_PROFILE_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } afterTimestamp := time.Date(2018, 11, 9, 17, 11, 8, 0, time.UTC).Format(time.RFC3339) reports, err := client.Reports(new(coinbasepro.ReportsOptions). SetAfter(afterTimestamp). SetIgnoredExpired(true). SetLimit(1). SetPortfolioID(profileID). SetType(scalar.ReportTypeAcccount)) if err != nil { log.Fatalf("Error fetching reports: %v", err) } fmt.Printf("reports: %+v\n", reports) }
Output:
func (*Client) SignedPrices ¶
SignedPrices returns cryptographically signed prices ready to be posted on-chain using Compound's Open Oracle smart contract.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getcoinbasepriceoracle
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } prices, err := client.SignedPrices() if err != nil { log.Fatalf("Error fetching prices: %v", err) } fmt.Printf("prices: %+v\n", prices) }
Output:
func (*Client) Trades ¶
func (c *Client) Trades(productId string, opts *TradesOptions) (m []*Trade, _ error)
Trades retruns a list the latest trades for a product.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getproducttrades
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } trades, err := client.Trades("BTC-USD", new(coinbasepro.TradesOptions). SetAfter(1526365354). SetBefore(1652574165). SetLimit(1)) if err != nil { log.Fatalf("Error fetching prices: %v", err) } fmt.Printf("prices: %+v\n", trades) }
Output:
func (*Client) Transfer ¶
AccountTransfer returns information on a single transfer.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_gettransfer
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } // Lookup the deposit. transfer, _ := client.Transfer("some-transfer-id") fmt.Printf("transfer: %+v\n", transfer) }
Output:
func (*Client) Transfers ¶
Transfers is a list of in-progress and completed transfers of funds in/out of any of the user's accounts.
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_gettransfers
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } transfers, err := client.Transfers() if err != nil { log.Fatalf("Error fetching transfers: %v", err) } fmt.Printf("transfers: %+v\n", transfers) }
Output:
func (*Client) Wallets ¶
Wallets will return all the user's available Coinbase wallets (These are the wallets/accounts that are used for buying and selling on www.coinbase.com)
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getcoinbaseaccounts
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } wallets, err := client.Wallets() if err != nil { log.Fatalf("Error fetching wallets: %v", err) } fmt.Printf("wallets: %+v\n", wallets) }
Output:
func (*Client) WithdrawalFeeEstimate ¶
func (c *Client) WithdrawalFeeEstimate(opts *WithdrawalFeeEstimateOptions) (m *WithdrawalFeeEstimate, _ error)
WithdrawalFeeEstimate will return the fee estimate for the crypto withdrawal to crypto address
source: https://docs.cloud.coinbase.com/exchange/reference/exchangerestapi_getwithdrawfeeestimate
Example ¶
package main import ( "context" "fmt" "log" "os" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/transport" ) func main() { // Read credentials from environment variables. url := os.Getenv("CB_PRO_URL") passphrase := os.Getenv("CB_PRO_ACCESS_PASSPHRASE") key := os.Getenv("CB_PRO_ACCESS_KEY") secret := os.Getenv("CB_PRO_SECRET") // Get a USD Wallet ID for the request. walletID := os.Getenv("CB_PRO_USDC_WALLET_ID") // Get a new client using an API Key for authentication. client, err := coinbasepro.NewClient(context.TODO(), transport.NewAPIKey(). SetKey(key). SetPassphrase(passphrase). SetSecret(secret). SetURL(url)) if err != nil { log.Fatalf("Error creating client: %v", err) } address, err := client.GenerateCryptoAddress(walletID) if err != nil { log.Fatalf("Error generating crypto address: %v", err) } estimates, err := client.WithdrawalFeeEstimate(new(coinbasepro.WithdrawalFeeEstimateOptions). SetCryptoAddress(address.Address). SetCurrency("USDC")) if err != nil { log.Fatalf("Error fetching estimates: %v", err) } fmt.Printf("estimates: %+v\n", estimates) }
Output:
type CoinbaseAccountDepositOptions ¶
type CoinbaseAccountDepositOptions struct { Amount float64 `json:"amount" bson:"amount"` CoinbaseAccountID string `json:"coinbase_account_id" bson:"coinbase_account_id"` Currency string `json:"currency" bson:"currency"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
CoinbaseAccountDepositOptions are options for API requests.
func (*CoinbaseAccountDepositOptions) EncodeBody ¶
func (opts *CoinbaseAccountDepositOptions) EncodeBody() (buf io.Reader, err error)
func (*CoinbaseAccountDepositOptions) EncodeQuery ¶
func (opts *CoinbaseAccountDepositOptions) EncodeQuery(req *http.Request)
func (*CoinbaseAccountDepositOptions) SetAmount ¶
func (opts *CoinbaseAccountDepositOptions) SetAmount(Amount float64) *CoinbaseAccountDepositOptions
SetAmount sets the Amount field on CoinbaseAccountDepositOptions.
func (*CoinbaseAccountDepositOptions) SetCoinbaseAccountID ¶
func (opts *CoinbaseAccountDepositOptions) SetCoinbaseAccountID(CoinbaseAccountID string) *CoinbaseAccountDepositOptions
SetCoinbaseAccountID sets the CoinbaseAccountID field on CoinbaseAccountDepositOptions.
func (*CoinbaseAccountDepositOptions) SetCurrency ¶
func (opts *CoinbaseAccountDepositOptions) SetCurrency(Currency string) *CoinbaseAccountDepositOptions
SetCurrency sets the Currency field on CoinbaseAccountDepositOptions.
func (*CoinbaseAccountDepositOptions) SetProfileID ¶
func (opts *CoinbaseAccountDepositOptions) SetProfileID(ProfileID string) *CoinbaseAccountDepositOptions
SetProfileID sets the ProfileID field on CoinbaseAccountDepositOptions.
type CoinbaseAccountWithdrawalOptions ¶
type CoinbaseAccountWithdrawalOptions struct { Amount float64 `json:"amount" bson:"amount"` CoinbaseAccountID string `json:"coinbase_account_id" bson:"coinbase_account_id"` Currency string `json:"currency" bson:"currency"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
CoinbaseAccountWithdrawalOptions are options for API requests.
func (*CoinbaseAccountWithdrawalOptions) EncodeBody ¶
func (opts *CoinbaseAccountWithdrawalOptions) EncodeBody() (buf io.Reader, err error)
func (*CoinbaseAccountWithdrawalOptions) EncodeQuery ¶
func (opts *CoinbaseAccountWithdrawalOptions) EncodeQuery(req *http.Request)
func (*CoinbaseAccountWithdrawalOptions) SetAmount ¶
func (opts *CoinbaseAccountWithdrawalOptions) SetAmount(Amount float64) *CoinbaseAccountWithdrawalOptions
SetAmount sets the Amount field on CoinbaseAccountWithdrawalOptions.
func (*CoinbaseAccountWithdrawalOptions) SetCoinbaseAccountID ¶
func (opts *CoinbaseAccountWithdrawalOptions) SetCoinbaseAccountID(CoinbaseAccountID string) *CoinbaseAccountWithdrawalOptions
SetCoinbaseAccountID sets the CoinbaseAccountID field on CoinbaseAccountWithdrawalOptions.
func (*CoinbaseAccountWithdrawalOptions) SetCurrency ¶
func (opts *CoinbaseAccountWithdrawalOptions) SetCurrency(Currency string) *CoinbaseAccountWithdrawalOptions
SetCurrency sets the Currency field on CoinbaseAccountWithdrawalOptions.
func (*CoinbaseAccountWithdrawalOptions) SetProfileID ¶
func (opts *CoinbaseAccountWithdrawalOptions) SetProfileID(ProfileID string) *CoinbaseAccountWithdrawalOptions
SetProfileID sets the ProfileID field on CoinbaseAccountWithdrawalOptions.
type ConvertCurrencyOptions ¶
type ConvertCurrencyOptions struct { Amount float64 `json:"amount" bson:"amount"` From string `json:"from" bson:"from"` Nonce *string `json:"nonce" bson:"nonce"` ProfileID *string `json:"profile_id" bson:"profile_id"` To string `json:"to" bson:"to"` }
ConvertCurrencyOptions are options for API requests.
func (*ConvertCurrencyOptions) EncodeBody ¶
func (opts *ConvertCurrencyOptions) EncodeBody() (buf io.Reader, err error)
func (*ConvertCurrencyOptions) EncodeQuery ¶
func (opts *ConvertCurrencyOptions) EncodeQuery(req *http.Request)
func (*ConvertCurrencyOptions) SetAmount ¶
func (opts *ConvertCurrencyOptions) SetAmount(Amount float64) *ConvertCurrencyOptions
SetAmount sets the Amount field on ConvertCurrencyOptions.
func (*ConvertCurrencyOptions) SetFrom ¶
func (opts *ConvertCurrencyOptions) SetFrom(From string) *ConvertCurrencyOptions
SetFrom sets the From field on ConvertCurrencyOptions.
func (*ConvertCurrencyOptions) SetNonce ¶
func (opts *ConvertCurrencyOptions) SetNonce(Nonce string) *ConvertCurrencyOptions
SetNonce sets the Nonce field on ConvertCurrencyOptions.
func (*ConvertCurrencyOptions) SetProfileID ¶
func (opts *ConvertCurrencyOptions) SetProfileID(ProfileID string) *ConvertCurrencyOptions
SetProfileID sets the ProfileID field on ConvertCurrencyOptions.
func (*ConvertCurrencyOptions) SetTo ¶
func (opts *ConvertCurrencyOptions) SetTo(To string) *ConvertCurrencyOptions
SetTo sets the To field on ConvertCurrencyOptions.
type CreateOrder ¶
type CreateOrder struct { CreatedAt time.Time `json:"created_at" bson:"created_at"` DoneAt time.Time `json:"done_at" bson:"done_at"` DoneReason string `json:"done_reason" bson:"done_reason"` ExpireTime time.Time `json:"expire_time" bson:"expire_time"` FillFees string `json:"fill_fees" bson:"fill_fees"` FilledSize string `json:"filled_size" bson:"filled_size"` FundingAmount string `json:"funding_amount" bson:"funding_amount"` Funds string `json:"funds" bson:"funds"` ID string `json:"id" bson:"id"` PostOnly bool `json:"post_only" bson:"post_only"` Price string `json:"price" bson:"price"` ProductID string `json:"product_id" bson:"product_id"` ProfileID string `json:"profile_id" bson:"profile_id"` RejectReason string `json:"reject_reason" bson:"reject_reason"` Settled bool `json:"settled" bson:"settled"` Side scalar.OrderSide `json:"side" bson:"side"` Size string `json:"size" bson:"size"` SpecificFunds string `json:"specific_funds" bson:"specific_funds"` Status string `json:"status" bson:"status"` Stop scalar.OrderStop `json:"stop" bson:"stop"` StopPrice string `json:"stop_price" bson:"stop_price"` TimeInForce scalar.TimeInForce `json:"time_in_force" bson:"time_in_force"` Type scalar.OrderType `json:"type" bson:"type"` }
CreateOrder is the server's response for placing a new order.
type CreateOrderOptions ¶
type CreateOrderOptions struct { CancelAfter *scalar.CancelAfter `json:"cancel_after" bson:"cancel_after"` ClientOid *string `json:"client_oid" bson:"client_oid"` Funds *float64 `json:"funds" bson:"funds"` PostOnly *bool `json:"post_only" bson:"post_only"` Price *float64 `json:"price" bson:"price"` ProductID string `json:"product_id" bson:"product_id"` ProfileID *string `json:"profile_id" bson:"profile_id"` STP *scalar.OrderSTP `json:"stp" bson:"stp"` Side scalar.OrderSide `json:"side" bson:"side"` Size *float64 `json:"size" bson:"size"` Stop *scalar.OrderStop `json:"stop" bson:"stop"` StopPrice *float64 `json:"stop_price" bson:"stop_price"` TimeInForce *scalar.TimeInForce `json:"time_in_force" bson:"time_in_force"` Type *scalar.OrderType `json:"type" bson:"type"` }
CreateOrderOptions are options for API requests.
func (*CreateOrderOptions) EncodeBody ¶
func (opts *CreateOrderOptions) EncodeBody() (buf io.Reader, err error)
func (*CreateOrderOptions) EncodeQuery ¶
func (opts *CreateOrderOptions) EncodeQuery(req *http.Request)
func (*CreateOrderOptions) SetCancelAfter ¶
func (opts *CreateOrderOptions) SetCancelAfter(CancelAfter scalar.CancelAfter) *CreateOrderOptions
SetCancelAfter sets the CancelAfter field on CreateOrderOptions.
func (*CreateOrderOptions) SetClientOid ¶
func (opts *CreateOrderOptions) SetClientOid(ClientOid string) *CreateOrderOptions
SetClientOid sets the ClientOid field on CreateOrderOptions.
func (*CreateOrderOptions) SetFunds ¶
func (opts *CreateOrderOptions) SetFunds(Funds float64) *CreateOrderOptions
SetFunds sets the Funds field on CreateOrderOptions.
func (*CreateOrderOptions) SetPostOnly ¶
func (opts *CreateOrderOptions) SetPostOnly(PostOnly bool) *CreateOrderOptions
SetPostOnly sets the PostOnly field on CreateOrderOptions.
func (*CreateOrderOptions) SetPrice ¶
func (opts *CreateOrderOptions) SetPrice(Price float64) *CreateOrderOptions
SetPrice sets the Price field on CreateOrderOptions.
func (*CreateOrderOptions) SetProductID ¶
func (opts *CreateOrderOptions) SetProductID(ProductID string) *CreateOrderOptions
SetProductID sets the ProductID field on CreateOrderOptions.
func (*CreateOrderOptions) SetProfileID ¶
func (opts *CreateOrderOptions) SetProfileID(ProfileID string) *CreateOrderOptions
SetProfileID sets the ProfileID field on CreateOrderOptions.
func (*CreateOrderOptions) SetSTP ¶
func (opts *CreateOrderOptions) SetSTP(STP scalar.OrderSTP) *CreateOrderOptions
SetSTP sets the STP field on CreateOrderOptions.
func (*CreateOrderOptions) SetSide ¶
func (opts *CreateOrderOptions) SetSide(Side scalar.OrderSide) *CreateOrderOptions
SetSide sets the Side field on CreateOrderOptions.
func (*CreateOrderOptions) SetSize ¶
func (opts *CreateOrderOptions) SetSize(Size float64) *CreateOrderOptions
SetSize sets the Size field on CreateOrderOptions.
func (*CreateOrderOptions) SetStop ¶
func (opts *CreateOrderOptions) SetStop(Stop scalar.OrderStop) *CreateOrderOptions
SetStop sets the Stop field on CreateOrderOptions.
func (*CreateOrderOptions) SetStopPrice ¶
func (opts *CreateOrderOptions) SetStopPrice(StopPrice float64) *CreateOrderOptions
SetStopPrice sets the StopPrice field on CreateOrderOptions.
func (*CreateOrderOptions) SetTimeInForce ¶
func (opts *CreateOrderOptions) SetTimeInForce(TimeInForce scalar.TimeInForce) *CreateOrderOptions
SetTimeInForce sets the TimeInForce field on CreateOrderOptions.
func (*CreateOrderOptions) SetType ¶
func (opts *CreateOrderOptions) SetType(Type scalar.OrderType) *CreateOrderOptions
SetType sets the Type field on CreateOrderOptions.
type CreateProfileOptions ¶
type CreateProfileOptions struct {
Name *string `json:"name" bson:"name"`
}
CreateProfileOptions are options for API requests.
func (*CreateProfileOptions) EncodeBody ¶
func (opts *CreateProfileOptions) EncodeBody() (buf io.Reader, err error)
func (*CreateProfileOptions) EncodeQuery ¶
func (opts *CreateProfileOptions) EncodeQuery(req *http.Request)
func (*CreateProfileOptions) SetName ¶
func (opts *CreateProfileOptions) SetName(Name string) *CreateProfileOptions
SetName sets the Name field on CreateProfileOptions.
type CreateProfileTransferOptions ¶
type CreateProfileTransferOptions struct { Amount *string `json:"amount" bson:"amount"` Currency *string `json:"currency" bson:"currency"` From *string `json:"from" bson:"from"` To *string `json:"to" bson:"to"` }
CreateProfileTransferOptions are options for API requests.
func (*CreateProfileTransferOptions) EncodeBody ¶
func (opts *CreateProfileTransferOptions) EncodeBody() (buf io.Reader, err error)
func (*CreateProfileTransferOptions) EncodeQuery ¶
func (opts *CreateProfileTransferOptions) EncodeQuery(req *http.Request)
func (*CreateProfileTransferOptions) SetAmount ¶
func (opts *CreateProfileTransferOptions) SetAmount(Amount string) *CreateProfileTransferOptions
SetAmount sets the Amount field on CreateProfileTransferOptions.
func (*CreateProfileTransferOptions) SetCurrency ¶
func (opts *CreateProfileTransferOptions) SetCurrency(Currency string) *CreateProfileTransferOptions
SetCurrency sets the Currency field on CreateProfileTransferOptions.
func (*CreateProfileTransferOptions) SetFrom ¶
func (opts *CreateProfileTransferOptions) SetFrom(From string) *CreateProfileTransferOptions
SetFrom sets the From field on CreateProfileTransferOptions.
func (*CreateProfileTransferOptions) SetTo ¶
func (opts *CreateProfileTransferOptions) SetTo(To string) *CreateProfileTransferOptions
SetTo sets the To field on CreateProfileTransferOptions.
type CreateReport ¶
type CreateReport struct { ID string `json:"id" bson:"id"` Status scalar.Status `json:"status" bson:"status"` Type scalar.ReportType `json:"type" bson:"type"` }
CreateReport represents information for a report created through the client.
type CreateReportOptions ¶
type CreateReportOptions struct { // Account - required for account-type reports AccountID *string `json:"account_id" bson:"account_id"` // Email to send generated report to Email *string `json:"email" bson:"email"` // End date for items to be included in report EndDate *string `json:"end_date" bson:"end_date"` // Portfolio - Which portfolio to generate the report for ProfileID *string `json:"profile_id" bson:"profile_id"` // Product - required for fills-type reports ProductID *string `json:"product_id" bson:"product_id"` // Start date for items to be included in report. StartDate *string `json:"start_date" bson:"start_date"` // required for 1099k-transaction-history-type reports Year *string `json:"year" bson:"year"` Format *scalar.Format `json:"format" bson:"format"` Type scalar.ReportType `json:"type" bson:"type"` }
CreateReportOptions are options for API requests.
func (*CreateReportOptions) EncodeBody ¶
func (opts *CreateReportOptions) EncodeBody() (buf io.Reader, err error)
func (*CreateReportOptions) EncodeQuery ¶
func (opts *CreateReportOptions) EncodeQuery(req *http.Request)
func (*CreateReportOptions) SetAccountID ¶
func (opts *CreateReportOptions) SetAccountID(AccountID string) *CreateReportOptions
SetAccountID sets the AccountID field on CreateReportOptions. Account - required for account-type reports
func (*CreateReportOptions) SetEmail ¶
func (opts *CreateReportOptions) SetEmail(Email string) *CreateReportOptions
SetEmail sets the Email field on CreateReportOptions. Email to send generated report to
func (*CreateReportOptions) SetEndDate ¶
func (opts *CreateReportOptions) SetEndDate(EndDate string) *CreateReportOptions
SetEndDate sets the EndDate field on CreateReportOptions. End date for items to be included in report
func (*CreateReportOptions) SetFormat ¶
func (opts *CreateReportOptions) SetFormat(Format scalar.Format) *CreateReportOptions
SetFormat sets the Format field on CreateReportOptions.
func (*CreateReportOptions) SetProductID ¶
func (opts *CreateReportOptions) SetProductID(ProductID string) *CreateReportOptions
SetProductID sets the ProductID field on CreateReportOptions. Product - required for fills-type reports
func (*CreateReportOptions) SetProfileID ¶
func (opts *CreateReportOptions) SetProfileID(ProfileID string) *CreateReportOptions
SetProfileID sets the ProfileID field on CreateReportOptions. Portfolio - Which portfolio to generate the report for
func (*CreateReportOptions) SetStartDate ¶
func (opts *CreateReportOptions) SetStartDate(StartDate string) *CreateReportOptions
SetStartDate sets the StartDate field on CreateReportOptions. Start date for items to be included in report.
func (*CreateReportOptions) SetType ¶
func (opts *CreateReportOptions) SetType(Type scalar.ReportType) *CreateReportOptions
SetType sets the Type field on CreateReportOptions.
func (*CreateReportOptions) SetYear ¶
func (opts *CreateReportOptions) SetYear(Year string) *CreateReportOptions
SetYear sets the Year field on CreateReportOptions. required for 1099k-transaction-history-type reports
type CryptoAccount ¶
type CryptoAccount struct { ID string `json:"id" bson:"id"` Resource string `json:"resource" bson:"resource"` ResourcePath string `json:"resource_path" bson:"resource_path"` }
CryptoAccount references a crypto account that a CoinbasePaymentMethod belongs to
type CryptoAddress ¶
type CryptoAddress struct { Address string `json:"address" bson:"address"` AddressInfo CryptoAddressInfo `json:"address_info" bson:"address_info"` CallbackURL string `json:"callback_url" bson:"callback_url"` CreateAt time.Time `json:"create_at" bson:"create_at"` DepositUri string `json:"deposit_uri" bson:"deposit_uri"` DestinationTag string `json:"destination_tag" bson:"destination_tag"` ID string `json:"id" bson:"id"` LegacyAddress string `json:"legacy_address" bson:"legacy_address"` Name string `json:"name" bson:"name"` Network string `json:"network" bson:"network"` Resource string `json:"resource" bson:"resource"` ResourcePath string `json:"resource_path" bson:"resource_path"` UpdatedAt time.Time `json:"updated_at" bson:"updated_at"` UriScheme string `json:"uri_scheme" bson:"uri_scheme"` Warnings []*CryptoAddressWarning `json:"warnings" bson:"warnings"` }
CryptoAddress is used for a one-time crypto address for depositing crypto.
type CryptoAddressInfo ¶
type CryptoAddressInfo struct { Address string `json:"address" bson:"address"` DestinationTag string `json:"destination_tag" bson:"destination_tag"` }
CryptoAddressInfo holds info for a crypto address
type CryptoAddressWarning ¶
type CryptoAddressWarning struct { Details string `json:"details" bson:"details"` ImageURL string `json:"image_url" bson:"image_url"` Title string `json:"title" bson:"title"` }
CryptoAddressWarning is a warning for generating a crypting address
type CryptoWithdrawalOptions ¶
type CryptoWithdrawalOptions struct { Amount float64 `json:"amount" bson:"amount"` CryptoAddress string `json:"crypto_address" bson:"crypto_address"` Currency string `json:"currency" bson:"currency"` DestinationTag *string `json:"destination_tag" bson:"destination_tag"` Fee *float64 `json:"fee" bson:"fee"` NoDestinationTag *bool `json:"no_destination_tag" bson:"no_destination_tag"` Nonce *int `json:"nonce" bson:"nonce"` ProfileID *string `json:"profile_id" bson:"profile_id"` TwoFactorCode *string `json:"two_factor_code" bson:"two_factor_code"` }
CryptoWithdrawalOptions are options for API requests.
func (*CryptoWithdrawalOptions) EncodeBody ¶
func (opts *CryptoWithdrawalOptions) EncodeBody() (buf io.Reader, err error)
func (*CryptoWithdrawalOptions) EncodeQuery ¶
func (opts *CryptoWithdrawalOptions) EncodeQuery(req *http.Request)
func (*CryptoWithdrawalOptions) SetAmount ¶
func (opts *CryptoWithdrawalOptions) SetAmount(Amount float64) *CryptoWithdrawalOptions
SetAmount sets the Amount field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetCryptoAddress ¶
func (opts *CryptoWithdrawalOptions) SetCryptoAddress(CryptoAddress string) *CryptoWithdrawalOptions
SetCryptoAddress sets the CryptoAddress field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetCurrency ¶
func (opts *CryptoWithdrawalOptions) SetCurrency(Currency string) *CryptoWithdrawalOptions
SetCurrency sets the Currency field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetDestinationTag ¶
func (opts *CryptoWithdrawalOptions) SetDestinationTag(DestinationTag string) *CryptoWithdrawalOptions
SetDestinationTag sets the DestinationTag field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetFee ¶
func (opts *CryptoWithdrawalOptions) SetFee(Fee float64) *CryptoWithdrawalOptions
SetFee sets the Fee field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetNoDestinationTag ¶
func (opts *CryptoWithdrawalOptions) SetNoDestinationTag(NoDestinationTag bool) *CryptoWithdrawalOptions
SetNoDestinationTag sets the NoDestinationTag field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetNonce ¶
func (opts *CryptoWithdrawalOptions) SetNonce(Nonce int) *CryptoWithdrawalOptions
SetNonce sets the Nonce field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetProfileID ¶
func (opts *CryptoWithdrawalOptions) SetProfileID(ProfileID string) *CryptoWithdrawalOptions
SetProfileID sets the ProfileID field on CryptoWithdrawalOptions.
func (*CryptoWithdrawalOptions) SetTwoFactorCode ¶
func (opts *CryptoWithdrawalOptions) SetTwoFactorCode(TwoFactorCode string) *CryptoWithdrawalOptions
SetTwoFactorCode sets the TwoFactorCode field on CryptoWithdrawalOptions.
type Currency ¶
type Currency struct { ConvertibleTo []string `json:"convertible_to" bson:"convertible_to"` Details CurrencyDetails `json:"details" bson:"details"` ID string `json:"id" bson:"id"` MaxPrecision string `json:"max_precision" bson:"max_precision"` Message string `json:"message" bson:"message"` MinSize string `json:"min_size" bson:"min_size"` Name string `json:"name" bson:"name"` Status string `json:"status" bson:"status"` }
Currency is a currency that coinbase knows about. Not al currencies may be currently in use for trading.
type CurrencyConversion ¶
type CurrencyConversion struct { Amount string `json:"amount" bson:"amount"` From string `json:"from" bson:"from"` FromAccountID string `json:"from_account_id" bson:"from_account_id"` ID string `json:"id" bson:"id"` To string `json:"to" bson:"to"` ToAccountID string `json:"to_account_id" bson:"to_account_id"` }
CurrencyConversion is the response that converts funds from from currency to to currency. Funds are converted on the from account in the profile_id profile.
type CurrencyConversionOptions ¶
type CurrencyConversionOptions struct {
ProfileID *string `json:"profile_id" bson:"profile_id"`
}
CurrencyConversionOptions are options for API requests.
func (*CurrencyConversionOptions) EncodeBody ¶
func (opts *CurrencyConversionOptions) EncodeBody() (buf io.Reader, err error)
func (*CurrencyConversionOptions) EncodeQuery ¶
func (opts *CurrencyConversionOptions) EncodeQuery(req *http.Request)
func (*CurrencyConversionOptions) SetProfileID ¶
func (opts *CurrencyConversionOptions) SetProfileID(ProfileID string) *CurrencyConversionOptions
SetProfileID sets the ProfileID field on CurrencyConversionOptions.
type CurrencyDetails ¶
type CurrencyDetails struct { CryptoAddressLink string `json:"crypto_address_link" bson:"crypto_address_link"` CryptoTransactionLink string `json:"crypto_transaction_link" bson:"crypto_transaction_link"` DisplayName string `json:"display_name" bson:"display_name"` GroupTypes []string `json:"group_types" bson:"group_types"` MaxWithdrawalAmount float64 `json:"max_withdrawal_amount" bson:"max_withdrawal_amount"` MinWithdrawalAmount float64 `json:"min_withdrawal_amount" bson:"min_withdrawal_amount"` NetworkConfirmations int `json:"network_confirmations" bson:"network_confirmations"` ProcessingTimeSeconds float64 `json:"processing_time_seconds" bson:"processing_time_seconds"` PushPaymentMethods []string `json:"push_payment_methods" bson:"push_payment_methods"` SortOrder int `json:"sort_order" bson:"sort_order"` Symbol string `json:"symbol" bson:"symbol"` Type string `json:"type" bson:"type"` }
CurrencyDetails are the details for a currency that coinbase knows about
type CurrencyTransferLimit ¶
type CurrencyTransferLimit struct { Max float64 `json:"max" bson:"max"` Remaining float64 `json:"remaining" bson:"remaining"` }
CurrencyTransferLimit encapsulates ACH data for a currency via Max/Remaining amounts.
type CurrencyTransferLimits ¶
type CurrencyTransferLimits map[string]CurrencyTransferLimit
CurrencyTransferLimits encapsulates ACH data for many currencies.
type DeleteProfileOptions ¶
type DeleteProfileOptions struct { ProfileID *string `json:"profile_id" bson:"profile_id"` To *string `json:"to" bson:"to"` }
DeleteProfileOptions are options for API requests.
func (*DeleteProfileOptions) EncodeBody ¶
func (opts *DeleteProfileOptions) EncodeBody() (buf io.Reader, err error)
func (*DeleteProfileOptions) EncodeQuery ¶
func (opts *DeleteProfileOptions) EncodeQuery(req *http.Request)
func (*DeleteProfileOptions) SetProfileID ¶
func (opts *DeleteProfileOptions) SetProfileID(ProfileID string) *DeleteProfileOptions
SetProfileID sets the ProfileID field on DeleteProfileOptions.
func (*DeleteProfileOptions) SetTo ¶
func (opts *DeleteProfileOptions) SetTo(To string) *DeleteProfileOptions
SetTo sets the To field on DeleteProfileOptions.
type Deposit ¶
type Deposit struct { Amount string `json:"amount" bson:"amount"` Currency string `json:"currency" bson:"currency"` Fee string `json:"fee" bson:"fee"` ID string `json:"id" bson:"id"` PayoutAt string `json:"payout_at" bson:"payout_at"` Subtotal string `json:"subtotal" bson:"subtotal"` }
Deposit is the response for deposited funds from a www.coinbase.com wallet to the specified profile_id.
type ExchangeLimits ¶
type ExchangeLimits struct { LimitCurrency string `json:"limit_currency" bson:"limit_currency"` TransferLimits TransferLimits `json:"transfer_limits" bson:"transfer_limits"` }
ExchangeLimits represents exchange limit information for a single user.
type FIATAccount ¶
type FIATAccount struct { ID string `json:"id" bson:"id"` Resource string `json:"resource" bson:"resource"` ResourcePath string `json:"resource_path" bson:"resource_path"` }
FIATAccount references a FIAT account thata CoinbasePaymentMethod belongs to
type Fees ¶
type Fees struct { MakerFeeRate string `json:"maker_fee_rate" bson:"maker_fee_rate"` TakerFeeRate string `json:"taker_fee_rate" bson:"taker_fee_rate"` UsdVolume string `json:"usd_volume" bson:"usd_volume"` }
Fees are fees rates and 30 days trailing volume.
type Fill ¶
type Fill struct { Fee string `json:"fee" bson:"fee"` Liquidity string `json:"liquidity" bson:"liquidity"` OrderID string `json:"order_id" bson:"order_id"` Price string `json:"price" bson:"price"` ProductID string `json:"product_id" bson:"product_id"` ProfileID string `json:"profile_id" bson:"profile_id"` Settled bool `json:"settled" bson:"settled"` Side string `json:"side" bson:"side"` Size string `json:"size" bson:"size"` TradeID int `json:"trade_id" bson:"trade_id"` UsdVolume string `json:"usd_volume" bson:"usd_volume"` UserID string `json:"user_id" bson:"user_id"` }
TODO: Get fill description
type FillsOptions ¶
type FillsOptions struct { After *int `json:"after" bson:"after"` Before *int `json:"before" bson:"before"` Limit *int `json:"limit" bson:"limit"` OrderID *string `json:"order_id" bson:"order_id"` ProductID *string `json:"product_id" bson:"product_id"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
FillsOptions are options for API requests.
func (*FillsOptions) EncodeBody ¶
func (opts *FillsOptions) EncodeBody() (buf io.Reader, err error)
func (*FillsOptions) EncodeQuery ¶
func (opts *FillsOptions) EncodeQuery(req *http.Request)
func (*FillsOptions) SetAfter ¶
func (opts *FillsOptions) SetAfter(After int) *FillsOptions
SetAfter sets the After field on FillsOptions.
func (*FillsOptions) SetBefore ¶
func (opts *FillsOptions) SetBefore(Before int) *FillsOptions
SetBefore sets the Before field on FillsOptions.
func (*FillsOptions) SetLimit ¶
func (opts *FillsOptions) SetLimit(Limit int) *FillsOptions
SetLimit sets the Limit field on FillsOptions.
func (*FillsOptions) SetOrderID ¶
func (opts *FillsOptions) SetOrderID(OrderID string) *FillsOptions
SetOrderID sets the OrderID field on FillsOptions.
func (*FillsOptions) SetProductID ¶
func (opts *FillsOptions) SetProductID(ProductID string) *FillsOptions
SetProductID sets the ProductID field on FillsOptions.
func (*FillsOptions) SetProfileID ¶
func (opts *FillsOptions) SetProfileID(ProfileID string) *FillsOptions
SetProfileID sets the ProfileID field on FillsOptions.
type Oracle ¶
type Oracle struct { // Messages are an array contains abi-encoded values [kind, timestamp, key, value], where kind always equals to // 'prices', timestamp is the time when the price was obtained, key is asset ticker (e.g. 'eth') and value is asset // price Messages []string `json:"messages" bson:"messages"` // Prices contains human-readable asset prices Prices OraclePrices `json:"prices" bson:"prices"` // Signatures are an array of Ethereum-compatible ECDSA signatures for each message Signatures []string `json:"signatures" bson:"signatures"` // Timestamp indicates when the latest datapoint was obtained Timestamp time.Time `json:"timestamp" bson:"timestamp"` }
Oracle is cryptographically signed price-info ready to be posted on-chain using Compound's Open Oracle smart contract.
func (*Oracle) UnmarshalJSON ¶
UnmarshalJSON will deserialize bytes into a Oracle model
type OraclePrices ¶
type OraclePrices struct {
AdditionalProp string `json:"additionalProp" bson:"additionalProp"`
}
OraclePrices contain human-readable asset prices.
type Order ¶
type Order struct { CreatedAt time.Time `json:"created_at" bson:"created_at"` DoneAt time.Time `json:"done_at" bson:"done_at"` DoneReason string `json:"done_reason" bson:"done_reason"` ExecutedValue string `json:"executed_value" bson:"executed_value"` ExpireTime time.Time `json:"expire_time" bson:"expire_time"` FillFees string `json:"fill_fees" bson:"fill_fees"` FilledSize string `json:"filled_size" bson:"filled_size"` FundingAmount string `json:"funding_amount" bson:"funding_amount"` Funds string `json:"funds" bson:"funds"` ID string `json:"id" bson:"id"` PostOnly bool `json:"post_only" bson:"post_only"` Price string `json:"price" bson:"price"` ProductID string `json:"product_id" bson:"product_id"` RejectReason string `json:"reject_reason" bson:"reject_reason"` Settled bool `json:"settled" bson:"settled"` Side scalar.OrderSide `json:"side" bson:"side"` Size string `json:"size" bson:"size"` SpecifiedFunds string `json:"specified_funds" bson:"specified_funds"` Status string `json:"status" bson:"status"` Stop string `json:"stop" bson:"stop"` StopPrice string `json:"stop_price" bson:"stop_price"` TimeInForce scalar.TimeInForce `json:"time_in_force" bson:"time_in_force"` Type scalar.OrderType `json:"type" bson:"type"` }
Order is an open order.
type OrdersOptions ¶
type OrdersOptions struct { After *string `json:"after" bson:"after"` Before *string `json:"before" bson:"before"` EndDate *string `json:"end_date" bson:"end_date"` Limit int `json:"limit" bson:"limit"` ProductID *string `json:"product_id" bson:"product_id"` ProfileID *string `json:"profile_id" bson:"profile_id"` SortedBy *string `json:"sortedBy" bson:"sortedBy"` Sorting *string `json:"sorting" bson:"sorting"` StartDate *string `json:"start_date" bson:"start_date"` Status []string `json:"status" bson:"status"` }
OrdersOptions are options for API requests.
func (*OrdersOptions) EncodeBody ¶
func (opts *OrdersOptions) EncodeBody() (buf io.Reader, err error)
func (*OrdersOptions) EncodeQuery ¶
func (opts *OrdersOptions) EncodeQuery(req *http.Request)
func (*OrdersOptions) SetAfter ¶
func (opts *OrdersOptions) SetAfter(After string) *OrdersOptions
SetAfter sets the After field on OrdersOptions.
func (*OrdersOptions) SetBefore ¶
func (opts *OrdersOptions) SetBefore(Before string) *OrdersOptions
SetBefore sets the Before field on OrdersOptions.
func (*OrdersOptions) SetEndDate ¶
func (opts *OrdersOptions) SetEndDate(EndDate string) *OrdersOptions
SetEndDate sets the EndDate field on OrdersOptions.
func (*OrdersOptions) SetLimit ¶
func (opts *OrdersOptions) SetLimit(Limit int) *OrdersOptions
SetLimit sets the Limit field on OrdersOptions.
func (*OrdersOptions) SetProductID ¶
func (opts *OrdersOptions) SetProductID(ProductID string) *OrdersOptions
SetProductID sets the ProductID field on OrdersOptions.
func (*OrdersOptions) SetProfileID ¶
func (opts *OrdersOptions) SetProfileID(ProfileID string) *OrdersOptions
SetProfileID sets the ProfileID field on OrdersOptions.
func (*OrdersOptions) SetSortedBy ¶
func (opts *OrdersOptions) SetSortedBy(SortedBy string) *OrdersOptions
SetSortedBy sets the SortedBy field on OrdersOptions.
func (*OrdersOptions) SetSorting ¶
func (opts *OrdersOptions) SetSorting(Sorting string) *OrdersOptions
SetSorting sets the Sorting field on OrdersOptions.
func (*OrdersOptions) SetStartDate ¶
func (opts *OrdersOptions) SetStartDate(StartDate string) *OrdersOptions
SetStartDate sets the StartDate field on OrdersOptions.
func (*OrdersOptions) SetStatus ¶
func (opts *OrdersOptions) SetStatus(Status []string) *OrdersOptions
SetStatus sets the Status field on OrdersOptions.
type PaymentMethod ¶
type PaymentMethod struct { AllowBuy bool `json:"allow_buy" bson:"allow_buy"` AllowDeposit bool `json:"allow_deposit" bson:"allow_deposit"` AllowSell bool `json:"allow_sell" bson:"allow_sell"` AllowWithdraw bool `json:"allow_withdraw" bson:"allow_withdraw"` AvailableBalance AvailableBalance `json:"available_balance" bson:"available_balance"` CdvStatus string `json:"cdv_status" bson:"cdv_status"` CreateAt time.Time `json:"create_at" bson:"create_at"` CryptoAccount CryptoAccount `json:"crypto_account" bson:"crypto_account"` Currency string `json:"currency" bson:"currency"` FIATAccount FIATAccount `json:"fiat_account" bson:"fiat_account"` HoldBusinessDays int `json:"hold_business_days" bson:"hold_business_days"` HoldDays int `json:"hold_days" bson:"hold_days"` ID string `json:"id" bson:"id"` InstantBuy bool `json:"instant_buy" bson:"instant_buy"` InstantSale bool `json:"instant_sale" bson:"instant_sale"` Limits Limits `json:"limits" bson:"limits"` Name string `json:"name" bson:"name"` PickerData PickerData `json:"picker_data" bson:"picker_data"` PrimaryBuy bool `json:"primary_buy" bson:"primary_buy"` PrimarySell bool `json:"primary_sell" bson:"primary_sell"` RecurringOptions []*RecurringOptions `json:"recurring_options" bson:"recurring_options"` Resource string `json:"resource" bson:"resource"` ResourcePath string `json:"resource_path" bson:"resource_path"` Type string `json:"type" bson:"type"` UpdatedAt time.Time `json:"updated_at" bson:"updated_at"` VerificationMethod string `json:"verification_method" bson:"verification_method"` Verified bool `json:"verified" bson:"verified"` }
PaymentMethod is a payment method used on coinbase
type PaymentMethodDepositOptions ¶
type PaymentMethodDepositOptions struct { Amount float64 `json:"amount" bson:"amount"` Currency string `json:"currency" bson:"currency"` PaymentMethodID string `json:"payment_method_id" bson:"payment_method_id"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
PaymentMethodDepositOptions are options for API requests.
func (*PaymentMethodDepositOptions) EncodeBody ¶
func (opts *PaymentMethodDepositOptions) EncodeBody() (buf io.Reader, err error)
func (*PaymentMethodDepositOptions) EncodeQuery ¶
func (opts *PaymentMethodDepositOptions) EncodeQuery(req *http.Request)
func (*PaymentMethodDepositOptions) SetAmount ¶
func (opts *PaymentMethodDepositOptions) SetAmount(Amount float64) *PaymentMethodDepositOptions
SetAmount sets the Amount field on PaymentMethodDepositOptions.
func (*PaymentMethodDepositOptions) SetCurrency ¶
func (opts *PaymentMethodDepositOptions) SetCurrency(Currency string) *PaymentMethodDepositOptions
SetCurrency sets the Currency field on PaymentMethodDepositOptions.
func (*PaymentMethodDepositOptions) SetPaymentMethodID ¶
func (opts *PaymentMethodDepositOptions) SetPaymentMethodID(PaymentMethodID string) *PaymentMethodDepositOptions
SetPaymentMethodID sets the PaymentMethodID field on PaymentMethodDepositOptions.
func (*PaymentMethodDepositOptions) SetProfileID ¶
func (opts *PaymentMethodDepositOptions) SetProfileID(ProfileID string) *PaymentMethodDepositOptions
SetProfileID sets the ProfileID field on PaymentMethodDepositOptions.
type PaymentMethodWithdrawalOptions ¶
type PaymentMethodWithdrawalOptions struct { Amount float64 `json:"amount" bson:"amount"` Currency string `json:"currency" bson:"currency"` PaymentMethodID string `json:"payment_method_id" bson:"payment_method_id"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
PaymentMethodWithdrawalOptions are options for API requests.
func (*PaymentMethodWithdrawalOptions) EncodeBody ¶
func (opts *PaymentMethodWithdrawalOptions) EncodeBody() (buf io.Reader, err error)
func (*PaymentMethodWithdrawalOptions) EncodeQuery ¶
func (opts *PaymentMethodWithdrawalOptions) EncodeQuery(req *http.Request)
func (*PaymentMethodWithdrawalOptions) SetAmount ¶
func (opts *PaymentMethodWithdrawalOptions) SetAmount(Amount float64) *PaymentMethodWithdrawalOptions
SetAmount sets the Amount field on PaymentMethodWithdrawalOptions.
func (*PaymentMethodWithdrawalOptions) SetCurrency ¶
func (opts *PaymentMethodWithdrawalOptions) SetCurrency(Currency string) *PaymentMethodWithdrawalOptions
SetCurrency sets the Currency field on PaymentMethodWithdrawalOptions.
func (*PaymentMethodWithdrawalOptions) SetPaymentMethodID ¶
func (opts *PaymentMethodWithdrawalOptions) SetPaymentMethodID(PaymentMethodID string) *PaymentMethodWithdrawalOptions
SetPaymentMethodID sets the PaymentMethodID field on PaymentMethodWithdrawalOptions.
func (*PaymentMethodWithdrawalOptions) SetProfileID ¶
func (opts *PaymentMethodWithdrawalOptions) SetProfileID(ProfileID string) *PaymentMethodWithdrawalOptions
SetProfileID sets the ProfileID field on PaymentMethodWithdrawalOptions.
type PickerData ¶
type PickerData struct { AccountName string `json:"account_name" bson:"account_name"` AccountNumber string `json:"account_number" bson:"account_number"` AccountType string `json:"account_type" bson:"account_type"` Balance Balance `json:"balance" bson:"balance"` BankName string `json:"bank_name" bson:"bank_name"` BranchName string `json:"branch_name" bson:"branch_name"` CustomerName string `json:"customer_name" bson:"customer_name"` Iban string `json:"iban" bson:"iban"` IconURL string `json:"icon_url" bson:"icon_url"` InstitutionCode string `json:"institution_code" bson:"institution_code"` InstitutionIdentifier string `json:"institution_identifier" bson:"institution_identifier"` InstitutionName string `json:"institution_name" bson:"institution_name"` PaypalEmail string `json:"paypal_email" bson:"paypal_email"` PaypalOwner string `json:"paypal_owner" bson:"paypal_owner"` RoutingNumber string `json:"routing_number" bson:"routing_number"` SWIFT string `json:"swift" bson:"swift"` Symbol string `json:"symbol" bson:"symbol"` }
PickerData ??
type Product ¶
type Product struct { AuctionMode bool `json:"auction_mode" bson:"auction_mode"` BaseCurrency string `json:"base_currency" bson:"base_currency"` BaseIncrement string `json:"base_increment" bson:"base_increment"` BaseMaxSize string `json:"base_max_size" bson:"base_max_size"` BaseMinSize string `json:"base_min_size" bson:"base_min_size"` CancelOnly bool `json:"cancel_only" bson:"cancel_only"` DisplayName string `json:"display_name" bson:"display_name"` FxStablecoin bool `json:"fx_stablecoin" bson:"fx_stablecoin"` ID string `json:"id" bson:"id"` LimitOnly bool `json:"limit_only" bson:"limit_only"` MarginEnabled bool `json:"margin_enabled" bson:"margin_enabled"` MaxMarketFunds string `json:"max_market_funds" bson:"max_market_funds"` MaxSlippagePercentage string `json:"max_slippage_percentage" bson:"max_slippage_percentage"` MinMarketFunds string `json:"min_market_funds" bson:"min_market_funds"` PostOnly bool `json:"post_only" bson:"post_only"` QuoteCurrency string `json:"quote_currency" bson:"quote_currency"` QuoteIncrement string `json:"quote_increment" bson:"quote_increment"` Status scalar.Status `json:"status" bson:"status"` StatusMessage string `json:"status_message" bson:"status_message"` TradingDisabled bool `json:"trading_disabled" bson:"trading_disabled"` }
Product represents a currency pair available for trading.
type ProductStats ¶
type ProductStats struct { High string `json:"high" bson:"high"` Last string `json:"last" bson:"last"` Low string `json:"low" bson:"low"` Open string `json:"open" bson:"open"` Volume string `json:"volume" bson:"volume"` Volume30day string `json:"volume_30day" bson:"volume_30day"` }
ProductStats are 30day and 24hour stats for a product.
type ProductTicker ¶
type ProductTicker struct { Ask string `json:"ask" bson:"ask"` Bid string `json:"bid" bson:"bid"` Price string `json:"price" bson:"price"` Size string `json:"size" bson:"size"` Time time.Time `json:"time" bson:"time"` TradeID int `json:"trade_id" bson:"trade_id"` Volume string `json:"volume" bson:"volume"` }
ProductTicker is a snapshot information about the last trade (tick), best bid/ask and 24h volume.
type ProductWebsocket ¶
type ProductWebsocket struct {
// contains filtered or unexported fields
}
func NewWebsocket ¶
func NewWebsocket(ws websocket.Creator) *ProductWebsocket
NewWebsocket will create a connection to the coinbase websocket and return a singleton that can be used to open channels that stream product data via a websocket.
func (*ProductWebsocket) Ticker ¶
func (productWebsocket *ProductWebsocket) Ticker(products ...string) *AsyncTicker
Ticker ticker uses the ProductWebsocket connection to query coinbase for ticket data, then it puts that data onto a channel for model.CoinbaseTicker
Example ¶
package main import ( "fmt" "time" "github.com/alpine-hodler/web/pkg/coinbasepro" "github.com/alpine-hodler/web/pkg/websocket" ) func main() { ws := coinbasepro.NewWebsocket(websocket.DefaultConnector) // initialize the ticker object to channel product messages ticker := ws.Ticker("ETH-USD") // start a go routine that passes product messages concerning ETH-USD currency pair to a channel on the ticker struct. ticker.Open() go func() { // Next we range over the product message channel and print the product messages. for productMsg := range ticker.Channel() { fmt.Printf("ETH-USD Price @ %v: %v\n", productMsg.Time, productMsg.Price) } }() // Let the product messages print for 5 seconds. time.Sleep(5 * time.Second) // Then close the ticker channel, this will unsubscribe from the websocket and close the underlying channel that the // messages read to. ticker.Close() }
Output:
type ProductsOptions ¶
type ProductsOptions struct {
Type *string `json:"type" bson:"type"`
}
ProductsOptions are options for API requests.
func (*ProductsOptions) EncodeBody ¶
func (opts *ProductsOptions) EncodeBody() (buf io.Reader, err error)
func (*ProductsOptions) EncodeQuery ¶
func (opts *ProductsOptions) EncodeQuery(req *http.Request)
func (*ProductsOptions) SetType ¶
func (opts *ProductsOptions) SetType(Type string) *ProductsOptions
SetType sets the Type field on ProductsOptions.
type Profile ¶
type Profile struct { Active bool `json:"active" bson:"active"` CreatedAt time.Time `json:"created_at" bson:"created_at"` HasMargin bool `json:"has_margin" bson:"has_margin"` ID string `json:"id" bson:"id"` IsDefault bool `json:"is_default" bson:"is_default"` Name string `json:"name" bson:"name"` UserID string `json:"user_id" bson:"user_id"` }
Profile represents a profile to interact with the API.
type ProfileOptions ¶
type ProfileOptions struct {
Active *bool `json:"active" bson:"active"`
}
ProfileOptions are options for API requests.
func (*ProfileOptions) EncodeBody ¶
func (opts *ProfileOptions) EncodeBody() (buf io.Reader, err error)
func (*ProfileOptions) EncodeQuery ¶
func (opts *ProfileOptions) EncodeQuery(req *http.Request)
func (*ProfileOptions) SetActive ¶
func (opts *ProfileOptions) SetActive(Active bool) *ProfileOptions
SetActive sets the Active field on ProfileOptions.
type ProfilesOptions ¶
type ProfilesOptions struct {
Active *bool `json:"active" bson:"active"`
}
ProfilesOptions are options for API requests.
func (*ProfilesOptions) EncodeBody ¶
func (opts *ProfilesOptions) EncodeBody() (buf io.Reader, err error)
func (*ProfilesOptions) EncodeQuery ¶
func (opts *ProfilesOptions) EncodeQuery(req *http.Request)
func (*ProfilesOptions) SetActive ¶
func (opts *ProfilesOptions) SetActive(Active bool) *ProfilesOptions
SetActive sets the Active field on ProfilesOptions.
type RecurringOptions ¶
type RecurringOptions struct { Label string `json:"label" bson:"label"` Period string `json:"period" bson:"period"` }
RecurringOptions ??
type RenameProfileOptions ¶
type RenameProfileOptions struct { Name *string `json:"name" bson:"name"` ProfileID *string `json:"profile_id" bson:"profile_id"` }
RenameProfileOptions are options for API requests.
func (*RenameProfileOptions) EncodeBody ¶
func (opts *RenameProfileOptions) EncodeBody() (buf io.Reader, err error)
func (*RenameProfileOptions) EncodeQuery ¶
func (opts *RenameProfileOptions) EncodeQuery(req *http.Request)
func (*RenameProfileOptions) SetName ¶
func (opts *RenameProfileOptions) SetName(Name string) *RenameProfileOptions
SetName sets the Name field on RenameProfileOptions.
func (*RenameProfileOptions) SetProfileID ¶
func (opts *RenameProfileOptions) SetProfileID(ProfileID string) *RenameProfileOptions
SetProfileID sets the ProfileID field on RenameProfileOptions.
type Report ¶
type Report struct { CreatedAt time.Time `json:"created_at" bson:"created_at"` ExpiresAt time.Time `json:"expires_at" bson:"expires_at"` FileCount string `json:"file_count" bson:"file_count"` FileURL string `json:"file_url" bson:"file_url"` ID string `json:"id" bson:"id"` Params ReportsParams `json:"params" bson:"params"` Status scalar.Status `json:"status" bson:"status"` Type scalar.ReportType `json:"type" bson:"type"` UpdatedAt time.Time `json:"updated_at" bson:"updated_at"` UserID string `json:"user_id" bson:"user_id"` }
Report represents a list of past fills/account reports.
type ReportsOptions ¶
type ReportsOptions struct { // Filter results after a specific date After *string `json:"after" bson:"after"` // Filter results by a specific profile_id PortfolioID *string `json:"portfolio_id" bson:"portfolio_id"` // Filter results by type of report (fills or account) - otc_fills: real string is otc-fills - // type_1099k_transaction_history: real string is 1099-transaction-history - tax_invoice: real string is tax-invoice Type *scalar.ReportType `json:"type" bson:"type"` // Ignore expired results IgnoredExpired *bool `json:"ignored_expired" bson:"ignored_expired"` // Limit results to a specific number Limit *int `json:"limit" bson:"limit"` }
ReportsOptions are options for API requests.
func (*ReportsOptions) EncodeBody ¶
func (opts *ReportsOptions) EncodeBody() (buf io.Reader, err error)
func (*ReportsOptions) EncodeQuery ¶
func (opts *ReportsOptions) EncodeQuery(req *http.Request)
func (*ReportsOptions) SetAfter ¶
func (opts *ReportsOptions) SetAfter(After string) *ReportsOptions
SetAfter sets the After field on ReportsOptions. Filter results after a specific date
func (*ReportsOptions) SetIgnoredExpired ¶
func (opts *ReportsOptions) SetIgnoredExpired(IgnoredExpired bool) *ReportsOptions
SetIgnoredExpired sets the IgnoredExpired field on ReportsOptions. Ignore expired results
func (*ReportsOptions) SetLimit ¶
func (opts *ReportsOptions) SetLimit(Limit int) *ReportsOptions
SetLimit sets the Limit field on ReportsOptions. Limit results to a specific number
func (*ReportsOptions) SetPortfolioID ¶
func (opts *ReportsOptions) SetPortfolioID(PortfolioID string) *ReportsOptions
SetPortfolioID sets the PortfolioID field on ReportsOptions. Filter results by a specific profile_id
func (*ReportsOptions) SetType ¶
func (opts *ReportsOptions) SetType(Type scalar.ReportType) *ReportsOptions
SetType sets the Type field on ReportsOptions. Filter results by type of report (fills or account) - otc_fills: real string is otc-fills - type_1099k_transaction_history: real string is 1099-transaction-history - tax_invoice: real string is tax-invoice
type ReportsParams ¶
type ReportsParams struct { AccountID string `json:"account_id" bson:"account_id"` Email string `json:"email" bson:"email"` EndDate time.Time `json:"end_date" bson:"end_date"` Format scalar.Format `json:"format" bson:"format"` NewYorkState bool `json:"new_york_state" bson:"new_york_state"` ProductID string `json:"product_id" bson:"product_id"` ProfileID string `json:"profile_id" bson:"profile_id"` StartDate time.Time `json:"start_date" bson:"start_date"` User User `json:"user" bson:"user"` }
TODO
type SEPADepositInformation ¶
type SEPADepositInformation struct { AccountAddress string `json:"account_address" bson:"account_address"` AccountName string `json:"account_name" bson:"account_name"` BankAddress string `json:"bank_address" bson:"bank_address"` BankCountry BankCountry `json:"bank_country" bson:"bank_country"` BankName string `json:"bank_name" bson:"bank_name"` Iban string `json:"iban" bson:"iban"` Reference string `json:"reference" bson:"reference"` SWIFT string `json:"swift" bson:"swift"` }
SEPADepositInformation information regarding a wallet's deposits. A SEPA credit transfer is a single transfer of Euros from one person or organisation to another. For example, this could be to pay the deposit for a holiday rental or to settle an invoice. A SEPA direct debit is a recurring payment, for example to pay monthly rent or for a service like a mobile phone contract.
type SWIFTDepositInformation ¶
type SWIFTDepositInformation struct { AccountAddress string `json:"account_address" bson:"account_address"` AccountName string `json:"account_name" bson:"account_name"` AccountNumber string `json:"account_number" bson:"account_number"` BankAddress string `json:"bank_address" bson:"bank_address"` BankCountry BankCountry `json:"bank_country" bson:"bank_country"` BankName string `json:"bank_name" bson:"bank_name"` Reference string `json:"reference" bson:"reference"` }
SWIFTDepositInformation information regarding a wallet's deposits. SWIFT stands for Society for Worldwide Interbank Financial Telecommunications. Basically, it's a computer network that connects over 900 banks around the world – and enables them to transfer money. ING is part of this network. There is no fee for accepting deposits into your account with ING.
type Ticker ¶
type Ticker struct { BestAsk string `json:"best_ask" bson:"best_ask"` BestBid string `json:"best_bid" bson:"best_bid"` LastSize string `json:"last_size" bson:"last_size"` Price string `json:"price" bson:"price"` ProductID string `json:"product_id" bson:"product_id"` Sequence int `json:"sequence" bson:"sequence"` Side string `json:"side" bson:"side"` Time time.Time `json:"time" bson:"time"` TradeID int `json:"trade_id" bson:"trade_id"` Type string `json:"type" bson:"type"` }
Ticker is real-time price updates every time a match happens. It batches updates in case of cascading matches, greatly reducing bandwidth requirements.
type TickerChannel ¶
type TickerChannel chan Ticker
type Trade ¶
type Trade struct { Price string `json:"price" bson:"price"` Side scalar.OrderSide `json:"side" bson:"side"` Size string `json:"size" bson:"size"` Time time.Time `json:"time" bson:"time"` TradeID int32 `json:"trade_id" bson:"trade_id"` }
Trade is the list the latest trades for a product.
type TradesOptions ¶
type TradesOptions struct { After *int32 `json:"after" bson:"after"` Before *int32 `json:"before" bson:"before"` Limit *int32 `json:"limit" bson:"limit"` }
TradesOptions are options for API requests.
func (*TradesOptions) EncodeBody ¶
func (opts *TradesOptions) EncodeBody() (buf io.Reader, err error)
func (*TradesOptions) EncodeQuery ¶
func (opts *TradesOptions) EncodeQuery(req *http.Request)
func (*TradesOptions) SetAfter ¶
func (opts *TradesOptions) SetAfter(After int32) *TradesOptions
SetAfter sets the After field on TradesOptions.
func (*TradesOptions) SetBefore ¶
func (opts *TradesOptions) SetBefore(Before int32) *TradesOptions
SetBefore sets the Before field on TradesOptions.
func (*TradesOptions) SetLimit ¶
func (opts *TradesOptions) SetLimit(Limit int32) *TradesOptions
SetLimit sets the Limit field on TradesOptions.
type Transfer ¶
type Transfer struct { Amount string `json:"amount" bson:"amount"` CanceledAt time.Time `json:"canceled_at" bson:"canceled_at"` CompletedAt time.Time `json:"completed_at" bson:"completed_at"` CreatedAt time.Time `json:"created_at" bson:"created_at"` Details AccountTransferDetails `json:"details" bson:"details"` ID string `json:"id" bson:"id"` ProcessedAt time.Time `json:"processed_at" bson:"processed_at"` Type string `json:"type" bson:"type"` UserNonce string `json:"user_nonce" bson:"user_nonce"` }
Transfer will lists past withdrawals and deposits for an account.
func (*Transfer) UnmarshalJSON ¶
UnmarshalJSON will deserialize bytes into a Transfer model
type TransferLimits ¶
type TransferLimits struct { ACH CurrencyTransferLimits `json:"ach" bson:"ach"` ACHNoBalance CurrencyTransferLimits `json:"ach_no_balance" bson:"ach_no_balance"` Buy CurrencyTransferLimits `json:"buy" bson:"buy"` CreditDebitCard CurrencyTransferLimits `json:"credit_debit_card" bson:"credit_debit_card"` ExchangeWithdraw CurrencyTransferLimits `json:"exchange_withdraw" bson:"exchange_withdraw"` IdealDeposit CurrencyTransferLimits `json:"ideal_deposit" bson:"ideal_deposit"` InstanceACHWithdrawal CurrencyTransferLimits `json:"instance_ach_withdrawal" bson:"instance_ach_withdrawal"` PaypalBuy CurrencyTransferLimits `json:"paypal_buy" bson:"paypal_buy"` PaypalWithdrawal CurrencyTransferLimits `json:"paypal_withdrawal" bson:"paypal_withdrawal"` Secure3dBuy CurrencyTransferLimits `json:"secure3d_buy" bson:"secure3d_buy"` Sell CurrencyTransferLimits `json:"sell" bson:"sell"` SofortDeposit CurrencyTransferLimits `json:"sofort_deposit" bson:"sofort_deposit"` }
TODO
type UKDepositInformation ¶
type UKDepositInformation struct { AccountAddress string `json:"account_address" bson:"account_address"` AccountName string `json:"account_name" bson:"account_name"` AccountNumber string `json:"account_number" bson:"account_number"` BankAddress string `json:"bank_address" bson:"bank_address"` BankCountry BankCountry `json:"bank_country" bson:"bank_country"` BankName string `json:"bank_name" bson:"bank_name"` Reference string `json:"reference" bson:"reference"` }
UKDepositInformation information regarding a wallet's deposits.
type User ¶
type User struct { ActiveAt time.Time `json:"active_at" bson:"active_at"` CbDataFromCache bool `json:"cb_data_from_cache" bson:"cb_data_from_cache"` CreatedAt time.Time `json:"created_at" bson:"created_at"` Details UserDetails `json:"details" bson:"details"` Flags Flags `json:"flags" bson:"flags"` FulfillsNewRequirements bool `json:"fulfills_new_requirements" bson:"fulfills_new_requirements"` HasClawbackPaymentPending bool `json:"has_clawback_payment_pending" bson:"has_clawback_payment_pending"` HasDefault bool `json:"has_default" bson:"has_default"` HasRestrictedAssets bool `json:"has_restricted_assets" bson:"has_restricted_assets"` ID string `json:"id" bson:"id"` IsBanned bool `json:"is_banned" bson:"is_banned"` LegalName string `json:"legal_name" bson:"legal_name"` Name string `json:"name" bson:"name"` Preferences UserPreferences `json:"preferences" bson:"preferences"` Roles []*Role `json:"roles" bson:"roles"` StateCode string `json:"state_code" bson:"state_code"` TermsAccepted time.Time `json:"terms_accepted" bson:"terms_accepted"` TwoFactorMethod string `json:"two_factor_method" bson:"two_factor_method"` UserType string `json:"user_type" bson:"user_type"` }
TODO
type Wallet ¶
type Wallet struct { Active bool `json:"active" bson:"active"` AvailableOnConsumer bool `json:"available_on_consumer" bson:"available_on_consumer"` Balance string `json:"balance" bson:"balance"` Currency string `json:"currency" bson:"currency"` DestinationTagName string `json:"destination_tag_name" bson:"destination_tag_name"` DestinationTagRegex string `json:"destination_tag_regex" bson:"destination_tag_regex"` HoldBalance string `json:"hold_balance" bson:"hold_balance"` HoldCurrency string `json:"hold_currency" bson:"hold_currency"` ID string `json:"id" bson:"id"` Name string `json:"name" bson:"name"` Primary bool `json:"primary" bson:"primary"` Ready bool `json:"ready" bson:"ready"` SEPADepositInformation SEPADepositInformation `json:"sepa_deposit_information" bson:"sepa_deposit_information"` SWIFTDepositInformation SWIFTDepositInformation `json:"swift_deposit_information" bson:"swift_deposit_information"` Type string `json:"type" bson:"type"` UKDepositInformation UKDepositInformation `json:"uk_deposit_information" bson:"uk_deposit_information"` WireDepositInformation WireDepositInformation `json:"wire_deposit_information" bson:"wire_deposit_information"` }
Wallet represents a user's available Coinbase wallet (These are the wallets/accounts that are used for buying and selling on www.coinbase.com)
type WireDepositInformation ¶
type WireDepositInformation struct { AccountAddress string `json:"account_address" bson:"account_address"` AccountName string `json:"account_name" bson:"account_name"` AccountNumber string `json:"account_number" bson:"account_number"` BankAddress string `json:"bank_address" bson:"bank_address"` BankCountry BankCountry `json:"bank_country" bson:"bank_country"` BankName string `json:"bank_name" bson:"bank_name"` Reference string `json:"reference" bson:"reference"` RoutingNumber string `json:"routing_number" bson:"routing_number"` }
WireDepositInformation information regarding a wallet's deposits
type Withdrawal ¶
type Withdrawal struct { Amount string `json:"amount" bson:"amount"` Currency string `json:"currency" bson:"currency"` Fee string `json:"fee" bson:"fee"` ID string `json:"id" bson:"id"` PayoutAt string `json:"payout_at" bson:"payout_at"` Subtotal string `json:"subtotal" bson:"subtotal"` }
Withdrawal is data concerning withdrawing funds from the specified profile_id to a www.coinbase.com wallet.
type WithdrawalFeeEstimate ¶
type WithdrawalFeeEstimate struct {
Fee float64 `json:"fee" bson:"fee"`
}
WithdrawalFeeEstimate is a fee estimate for the crypto withdrawal to crypto address
type WithdrawalFeeEstimateOptions ¶
type WithdrawalFeeEstimateOptions struct { CryptoAddress *string `json:"crypto_address" bson:"crypto_address"` Currency *string `json:"currency" bson:"currency"` }
WithdrawalFeeEstimateOptions are options for API requests.
func (*WithdrawalFeeEstimateOptions) EncodeBody ¶
func (opts *WithdrawalFeeEstimateOptions) EncodeBody() (buf io.Reader, err error)
func (*WithdrawalFeeEstimateOptions) EncodeQuery ¶
func (opts *WithdrawalFeeEstimateOptions) EncodeQuery(req *http.Request)
func (*WithdrawalFeeEstimateOptions) SetCryptoAddress ¶
func (opts *WithdrawalFeeEstimateOptions) SetCryptoAddress(CryptoAddress string) *WithdrawalFeeEstimateOptions
SetCryptoAddress sets the CryptoAddress field on WithdrawalFeeEstimateOptions.
func (*WithdrawalFeeEstimateOptions) SetCurrency ¶
func (opts *WithdrawalFeeEstimateOptions) SetCurrency(Currency string) *WithdrawalFeeEstimateOptions
SetCurrency sets the Currency field on WithdrawalFeeEstimateOptions.