com.coinbase.api.Coinbase Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of coinbase-java Show documentation
Show all versions of coinbase-java Show documentation
A first-party java wrapper around the Coinbase API
package com.coinbase.api;
import java.io.IOException;
import java.math.BigDecimal;
import java.net.URI;
import java.util.List;
import java.util.Map;
import org.joda.money.CurrencyUnit;
import org.joda.money.Money;
import com.coinbase.api.entity.Account;
import com.coinbase.api.entity.AccountChangesResponse;
import com.coinbase.api.entity.AccountsResponse;
import com.coinbase.api.entity.Address;
import com.coinbase.api.entity.AddressResponse;
import com.coinbase.api.entity.AddressesResponse;
import com.coinbase.api.entity.Application;
import com.coinbase.api.entity.ApplicationsResponse;
import com.coinbase.api.entity.Button;
import com.coinbase.api.entity.ContactsResponse;
import com.coinbase.api.entity.HistoricalPrice;
import com.coinbase.api.entity.OAuthCodeRequest;
import com.coinbase.api.entity.OAuthTokensResponse;
import com.coinbase.api.entity.Order;
import com.coinbase.api.entity.OrdersResponse;
import com.coinbase.api.entity.PaymentMethodsResponse;
import com.coinbase.api.entity.Quote;
import com.coinbase.api.entity.RecurringPayment;
import com.coinbase.api.entity.RecurringPaymentsResponse;
import com.coinbase.api.entity.Report;
import com.coinbase.api.entity.ReportsResponse;
import com.coinbase.api.entity.Token;
import com.coinbase.api.entity.Transaction;
import com.coinbase.api.entity.TransactionsResponse;
import com.coinbase.api.entity.Transfer;
import com.coinbase.api.entity.TransfersResponse;
import com.coinbase.api.entity.User;
import com.coinbase.api.entity.UserResponse;
import com.coinbase.api.exception.CoinbaseException;
import com.coinbase.api.exception.CredentialsIncorrectException;
import com.coinbase.api.exception.TwoFactorIncorrectException;
import com.coinbase.api.exception.TwoFactorRequiredException;
import com.coinbase.api.exception.UnauthorizedDeviceException;
import com.coinbase.api.exception.UnspecifiedAccount;
public interface Coinbase {
/**
* Retrieve the current user and their settings.
*
* Also includes buy/sell levels (1, 2, or 3) and daily buy/sell limits (actual fiat amount).
*
* @return the current user and their settings
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public User getUser() throws IOException, CoinbaseException;
/**
* Retrieve details of an individual transaction.
*
* @param id the transaction id or idem field value
* @return the transaction details
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Transaction getTransaction(String id) throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's recent transactions
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public TransactionsResponse getTransactions() throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's recent transactions
*
* @param page the page of transactions to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public TransactionsResponse getTransactions(int page) throws IOException, CoinbaseException;
/**
* Send an invoice/money request to an email address.
*
* @param transaction a Transaction object containing the parameters for a money request
*
* @return the newly created transaction
* @throws IOException
*
* @see Online Documentation
*/
public Transaction requestMoney(Transaction transaction) throws CoinbaseException, IOException;
/**
* Resend emails for a money request.
*
* @param transactionId the id of the request money transaction to be resent
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public void resendRequest(String transactionId) throws CoinbaseException, IOException;
/**
* Cancel a money request.
*
* @param transactionId the id of the request money transaction to be canceled
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public void deleteRequest(String transactionId) throws CoinbaseException, IOException;
/**
* Complete a money request.
*
* @param transactionId the id of the request money transaction to be completed
* @return the completed transaction
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Transaction completeRequest(String transactionId) throws CoinbaseException, IOException;
/**
* Send money to an email address or bitcoin address
*
* @param transaction a Transaction object containing the send money parameters
* @return the newly created transaction
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Transaction sendMoney(Transaction transaction) throws CoinbaseException, IOException;
/**
* Retrieve details of an individual merchant order
*
* @param idOrCustom the order id or custom field value
* @return the details of the merchant order
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Order getOrder(String idOrCustom) throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's recently received merchant orders
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public OrdersResponse getOrders() throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's recently received merchant orders
*
* @param page the page of orders to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public OrdersResponse getOrders(int page) throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's recent transfers (buys/sales)
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public TransfersResponse getTransfers() throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's recent transfers (buys/sales)
*
* @param page the page of transfers to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public TransfersResponse getTransfers(int page) throws IOException, CoinbaseException;
/**
* Retrieve a list of bitcoin addresses associated with this account
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public AddressesResponse getAddresses() throws IOException, CoinbaseException;
/**
* Retrieve a list of bitcoin addresses associated with this account
*
* @param page the page of addresses to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public AddressesResponse getAddresses(int page) throws IOException, CoinbaseException;
/**
* Retrieve a list of accounts belonging to this user
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public AccountsResponse getAccounts() throws IOException, CoinbaseException;
/**
* Retrieve a list of active accounts belonging to this user
*
* @param page the page of accounts to retrieve
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public AccountsResponse getAccounts(int page) throws IOException, CoinbaseException;
/**
* Retrieve a list of active accounts belonging to this user
*
* @param page the page of accounts to retrieve
* @param limit the number of accounts to retrieve per page
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public AccountsResponse getAccounts(int page, int limit) throws IOException, CoinbaseException;
/**
* Retrieve a list of accounts belonging to this user
*
* @param page the page of accounts to retrieve
* @param limit the number of accounts to retrieve per page
* @param includeInactive include inactive accounts in the response
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public AccountsResponse getAccounts(int page, int limit, boolean includeInactive) throws IOException, CoinbaseException;
// TODO re-introduce limit param when BUGS-263 is fixed
/**
* Retrieve a list of the user's contacts
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public ContactsResponse getContacts() throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's contacts
*
* @param page the page of accounts to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public ContactsResponse getContacts(int page) throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's contacts
*
* @param query partial string match to filter contacts.
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public ContactsResponse getContacts(String query) throws IOException, CoinbaseException;
/**
* Retrieve a list of the user's contacts
*
* @param page the page of accounts to retrieve
* @param query partial string match to filter contacts.
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public ContactsResponse getContacts(String query, int page) throws IOException, CoinbaseException;
/**
* Retrieve the balance of the current account
*
* @throws UnspecifiedAccount if the account was not specified during the creation of the client
* @return the balance of the current account
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public Money getBalance() throws UnspecifiedAccount, IOException, CoinbaseException;
/**
* Retrieve the balance of the specified account
*
* @param accountId the id of the account for which to retrieve the balance
* @return the balance of the specified account
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public Money getBalance(String accountId) throws IOException, CoinbaseException;
/**
* Set the current account as primary
*
* @throws UnspecifiedAccount if the account was not specified during the creation of the client
* @throws IOException
*
* @see Online Documentation
*/
public void setPrimaryAccount() throws UnspecifiedAccount, CoinbaseException, IOException;
/**
* Set the specified account as primary
*
* @param accountId the id of the account to set as primary
* @throws IOException
*
* @see Online Documentation
*/
public void setPrimaryAccount(String accountId) throws CoinbaseException, IOException;
/**
* Delete the current account
*
* @throws UnspecifiedAccount if the account was not specified during the creation of the client
* @throws IOException
*
* @see Online Documentation
*/
public void deleteAccount() throws UnspecifiedAccount, CoinbaseException, IOException;
/**
* Delete the specified account
*
* @param accountId the id of the account to delete
* @throws IOException
*
* @see Online Documentation
*/
public void deleteAccount(String accountId) throws CoinbaseException, IOException;
/**
* Update the settings of the current account
*
* @param account an Account object containing the parameters to be updated
* @throws UnspecifiedAccount if the account was not specified during the creation of the client
* @throws IOException
*
* @see Online Documentation
*/
public void updateAccount(Account account) throws UnspecifiedAccount, CoinbaseException, IOException;
/**
* Update the settings of the current account
*
* @param accountId the id of the account to update
* @param account an Account object containing the parameters to be updated
*
* @see Online Documentation
*/
public void updateAccount(String accountId, Account account) throws CoinbaseException, IOException;
/**
* Create a new account
*
* @param account an Account object containing the parameters to create an account
* @return the details of the created account
* @throws IOException
*
* @see Online Documentation
*/
public Account createAccount(Account account) throws CoinbaseException, IOException;
/**
* Retrieve the current spot price of 1 BTC
*
* @param currency the currency in which to retrieve the price
* @return the spot price of 1 BTC in the specified currency
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public Money getSpotPrice(CurrencyUnit currency) throws IOException, CoinbaseException;
/**
* Get a quote for purchasing a given amount of BTC
*
* @param amount the amount for which to retrieve a quote. Can be either bitcoin or native currency
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public Quote getBuyQuote(Money amount) throws IOException, CoinbaseException;
/**
* Get a quote for selling a given amount of BTC
*
* @param amount the amount for which to retrieve a quote. Can be either bitcoin or native currency
* @throws IOException
* @throws CoinbaseException
*
* @see Online Documentation
*/
public Quote getSellQuote(Money amount) throws IOException, CoinbaseException;
/**
* Create a new payment button, page, or iFrame.
*
* @param button a Button object containing the parameters for creating a button
* @return the created Button
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Button createButton(Button button) throws CoinbaseException, IOException;
/**
* Create an order for a new button
*
* @param button a Button object containing the parameters for creating a button
* @return the created Order
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Order createOrder(Button button) throws CoinbaseException, IOException;
/**
* Create an order for an existing button
*
* @param buttonCode the code of the button for which to create an order
* @return the created Order
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Order createOrderForButton(String buttonCode) throws CoinbaseException, IOException;
/**
* Sell a given quantity of BTC to Coinbase
*
* @param amount the quantity of BTC to sell
* @return the resulting Transfer object
* @throws IOException
*
* @see Online Documentation
*/
public Transfer sell(Money amount) throws CoinbaseException, IOException;
/**
* Sell a given quantity of BTC to Coinbase
*
* @param amount the quantity of BTC to sell
* @param paymentMethodId the ID of the payment method to credit with the proceeds of the sale
* @return the resulting Transfer object
* @throws IOException
*
* @see Online Documentation
*/
public Transfer sell(Money amount, String paymentMethodId) throws CoinbaseException, IOException;
/**
* Sell a given quantity of BTC to Coinbase
*
* @param amount the quantity of BTC to sell
* @param paymentMethodId the ID of the payment method to credit with the proceeds of the sale
* @param commit create the transfer in 'created' state
* @return the resulting Transfer object
* @throws IOException
*
* @see Online Documentation
*/
public Transfer sell(Money amount, String paymentMethodId, Boolean commit) throws CoinbaseException, IOException;
/**
* Buy a given quantity of BTC from Coinbase
*
* @param amount the quantity of BTC to buy
* @return the resulting Transfer object
* @throws IOException
*
* @see Online Documentation
*/
public Transfer buy(Money amount) throws CoinbaseException, IOException;
/**
* Buy a given quantity of BTC from Coinbase
*
* @param amount the quantity of BTC to buy
* @param paymentMethodId the ID of the payment method to debit for the purchase
* @return the resulting Transfer object
* @throws IOException
*
* @see Online Documentation
*/
public Transfer buy(Money amount, String paymentMethodId) throws CoinbaseException, IOException;
/**
* Buy a given quantity of BTC from Coinbase
*
* @param amount the quantity of BTC to buy
* @param paymentMethodId the ID of the payment method to debit for the purchase
* @param commit create the transfer in 'created' state
* @return the resulting Transfer object
* @throws IOException
*
* @see Online Documentation
*/
public Transfer buy(Money amount, String paymentMethodId, Boolean commit) throws CoinbaseException, IOException;
/**
* Commit a transaction to make sure it is in created state
*
* @return the resulting Transfer object
* @throws IOException
*
* @see Online Documentation
*/
public Transfer commitTransfer(String transferId) throws CoinbaseException, IOException;
/**
* Get the user's payment methods
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public PaymentMethodsResponse getPaymentMethods() throws IOException, CoinbaseException;
/**
* Retrieve all the recurring payments (scheduled buys, sells, and subscriptions) you've created with merchants.
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
* @see About recurring payments
*/
public RecurringPaymentsResponse getRecurringPayments() throws IOException, CoinbaseException;
/**
* Retrieve all the recurring payments (scheduled buys, sells, and subscriptions) you've created with merchants.
*
* @param page the page of recurring payments to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
* @see About recurring payments
*/
public RecurringPaymentsResponse getRecurringPayments(int page) throws IOException, CoinbaseException;
/**
* Retrieve all the subscriptions customers have made with you
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
* @see About recurring payments
*/
public RecurringPaymentsResponse getSubscribers() throws IOException, CoinbaseException;
/**
* Retrieve all the subscriptions customers have made with you
*
* @param page the page of subscribers to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
* @see About recurring payments
*/
public RecurringPaymentsResponse getSubscribers(int page) throws IOException, CoinbaseException;
/**
* Unauthenticated resource that returns BTC to fiat (and vice versus) exchange rates in various currencies.
*
* It has keys for both btc_to_xxx and xxx_to_btc so you can convert either way. The key always contains downcase representations of the currency ISO.
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*/
public Map getExchangeRates() throws IOException, CoinbaseException;
/**
* Unauthenticated resource that returns currencies supported on Coinbase
* @throws CoinbaseException
* @throws IOException
*
*/
public List getSupportedCurrencies() throws IOException, CoinbaseException;
/**
* Unauthenticated resource that creates a user with an email and password.
*
* @param userParams a User object containing the parameters to create a new User
*
* @return the created user
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public User createUser(User userParams) throws CoinbaseException, IOException;
/**
* Unauthenticated resource that creates a user with an email and password.
*
* @param userParams a User object containing the parameters to create a new User
* @param clientId your OAuth application's client id
* @param scope a space-separated list of Coinbase OAuth permissions
*
* @return the created user
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
* @see Permissions Reference
*
*/
public User createUser(User userParams, String clientId, String scope) throws CoinbaseException, IOException;
/**
* Authenticated resource that creates a user with an email and password and gets the OAuth
* tokens from the server.
*
* @param userParams a User object containing the parameters to create a new User
* @param clientId your OAuth application's client id
* @param scope a space-separated list of Coinbase OAuth permissions
*
* @return the user response
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
* @see Permissions Reference
*
*/
public UserResponse createUserWithOAuth(User userParams, String clientId, String scope) throws CoinbaseException, IOException;
/**
* Updates account settings for the current user
*
* @param userId the user's id
* @param userParams a User object containing the parameters to update
*
* @return the updated user
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public User updateUser(String userId, User userParams) throws CoinbaseException, IOException;
/**
* Retrieves the details of a recurring payment
*
* @param id the id of the recurring payment
*
* @return the recurring payment details
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public RecurringPayment getRecurringPayment(String id) throws CoinbaseException, IOException;
/**
* Retrieves the details of a subscriber's recurring payment
*
* @param id the id of the recurring payment
*
* @return the recurring payment details
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public RecurringPayment getSubscriber(String id) throws CoinbaseException, IOException;
/**
* Create a token which can be redeemed for bitcoin
*
* @return the newly created token
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public Token createToken() throws CoinbaseException, IOException;
/**
* Redeem a token, claiming its address and all its bitcoins
*
* @param tokenId the id of the token
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public void redeemToken(String tokenId) throws CoinbaseException, IOException;
/**
* Generate a new receive address
*
* @param addressParams an Address object containing any arguments for the new address
*
* @return the generated address
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public AddressResponse generateReceiveAddress(Address addressParams) throws CoinbaseException, IOException;
/**
* Generate a new receive address
*
* @return the generated address
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public AddressResponse generateReceiveAddress() throws CoinbaseException, IOException;
/**
* Retrieve details for an individual OAuth application.
*
* @param id the id of the OAuth application
*
* @return the details for the OAuth application
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public Application getApplication(String id) throws CoinbaseException, IOException;
/**
* List OAuth applications on your account.
*
* @param id the id of the OAuth application
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public ApplicationsResponse getApplications() throws CoinbaseException, IOException;
/**
* Create a new OAuth application
*
* @param applicationParams an Application object containing the arguments for creating an OAuth application
*
* @return the newly created OAuth application including client id and client secret
*
* @throws CoinbaseException on error
* @throws IOException
*
* @see Online Documentation
*
*/
public Application createApplication(Application application) throws CoinbaseException, IOException;
/**
* Get the historical spot price of bitcoin in USD.
*
* @param page the page of results to retrieve
*
* @return a list of HistoricalPrice
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public List getHistoricalPrices(int page) throws CoinbaseException, IOException;
/**
* Get the historical spot price of bitcoin in USD.
*
* @return a list of HistoricalPrice
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public List getHistoricalPrices() throws CoinbaseException, IOException;
/**
* Create a new report
*
* @return the newly created report
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public Report createReport(Report reportParams) throws CoinbaseException, IOException;
/**
* Retrieve details for a report
*
* @param reportId the id of the report to retrieve
* @return the requested report
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public Report getReport(String reportId) throws CoinbaseException, IOException;
/**
* Retrieve all reports
*
* @param page the page of results to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public ReportsResponse getReports(int page) throws CoinbaseException, IOException;
/**
* Retrieve all reports
*
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public ReportsResponse getReports() throws CoinbaseException, IOException;
/**
* Retrieve account changes
*
* @param page the page of results to retrieve
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public AccountChangesResponse getAccountChanges(int page) throws CoinbaseException, IOException;
/**
* Retrieve account changes
*
* @throws CoinbaseException
* @throws IOException
*
* @see Online Documentation
*
*/
public AccountChangesResponse getAccountChanges() throws CoinbaseException, IOException;
/**
* Obtain OAuth Authorization Code
*
* @throws CredentialsIncorrectException if the username/password are incorrect
* @throws TwoFactorRequiredException if the user has 2fa enabled but a 2fa code was not provided
* @throws TwoFactorIncorrectException if the provided two factor code is incorrect or expired
* @throws CoinbaseException
* @throws IOException
*
*/
public String getAuthCode(OAuthCodeRequest request)
throws CredentialsIncorrectException, TwoFactorRequiredException, TwoFactorIncorrectException, CoinbaseException, IOException;
/**
* Exchange OAuth Authorization Code for OAuth token
*
* @param redirectUri required iff a redirectUri was set when the auth code was obtained
*
* @throws UnauthorizedDeviceException if the authCode was obtained using email/password and device verification has not yet been completed by the user
* @throws CoinbaseException
* @throws IOException
*
*/
public OAuthTokensResponse getTokens(String clientId, String clientSecret, String authCode, String redirectUri) throws UnauthorizedDeviceException, CoinbaseException, IOException;
/**
* Revoke current access token.
*
* This client must have previously been initialized with an access token.
* Future methods requiring authentication will fail.
*
* @throws CoinbaseException
* @throws IOException
*/
public void revokeToken() throws CoinbaseException, IOException;
/**
* Refresh OAuth tokens
*
* @throws CoinbaseException
* @throws IOException
*
*/
public OAuthTokensResponse refreshTokens(String clientId, String clientSecret, String refreshToken) throws CoinbaseException, IOException;
/**
* Send 2FA token to user via SMS
*
* @throws CoinbaseException
* @throws IOException
*/
public void sendSMS(String clientId, String clientSecret, String email, String password) throws CoinbaseException, IOException;
/**
* Get Three-Legged OAuth Authorization URI
*
* @throws CoinbaseException
* @throws IOException
*/
public URI getAuthorizationUri(OAuthCodeRequest params) throws CoinbaseException, IOException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy