All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.coinbase.api.Coinbase Maven / Gradle / Ivy

package com.coinbase.api;

import java.io.IOException;
import java.math.BigDecimal;
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.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.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.exception.CoinbaseException;
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 btcAmount the amount of bitcoin for which to retrieve a quote
     * @throws IOException 
     * @throws CoinbaseException 
     * 
     * @see Online Documentation
     */
    public Quote getBuyQuote(Money btcAmount) throws IOException, CoinbaseException;
    
    /**
     * Get a quote for selling a given amount of BTC
     * 
     * @param btcAmount the amount of bitcoin for which to retrieve a quote
     * @throws IOException 
     * @throws CoinbaseException 
     * 
     * @see Online Documentation
     */
    public Quote getSellQuote(Money btcAmount) 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;

    /**
     * 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;

    /**
     * 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;
    
    /**
     * 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;

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy