XChange is a Java library providing a streamlined API for interacting with 60+ Bitcoin and Altcoin exchanges providing a consistent interface for trading and accessing market data.
Java
timmolter Merge pull request #2714 from cymp/develop
[Bitfinex] v2api: replaced v1 copy/pasted services with v2 services
Latest commit 40b95c2 Jul 23, 2018
Permalink
Failed to load latest commit information.
etc remove some random, reformat Apr 4, 2018
xchange-abucoins [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-acx [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-anx [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bibox [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-binance Merge pull request #2715 from KapitalTrading/develop Jul 23, 2018
xchange-bitbay [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitcoinaverage [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitcoincharts [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitcoincore [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitcoinde [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitcoinium [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitcointoyou [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitfinex v2 api: BitfinexExchange init was done with v1 services Jul 21, 2018
xchange-bitflyer Fix Bitflyer last traded price Jul 11, 2018
xchange-bitmarket [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitmex Merge remote-tracking branch 'upstream/develop' into develop Jul 4, 2018
xchange-bitso [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bitstamp Merge pull request #2697 from dsx-tech/develop Jul 20, 2018
xchange-bittrex [Bittrex] Add QTUM withdrawal fee Jul 19, 2018
xchange-bitz [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bleutrade [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-blockchain [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-btcc [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-btcmarkets [btcmarkets] Added getOrder support to TradeService Jul 12, 2018
xchange-btctrade [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-btcturk [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-bx [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-campbx [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-ccex [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-cexio [Cexio] Update resource file Jul 19, 2018
xchange-cobinhood [Cobinhood] Integration with Cobinhood exchange Jul 4, 2018
xchange-coinbase [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-coinbene [Coinbene] Integration with Coinbene exchange Jul 11, 2018
xchange-coindirect [coindirect] trade service release Jul 12, 2018
xchange-coinegg [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-coinfloor [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-coingi [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-coinmarketcap [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-coinmate [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-coinone [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-core [Binance] Implement getOpenOrders without a pair, allowing to get all… Jul 19, 2018
xchange-cryptofacilities [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-cryptonit [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-cryptopia [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-dsx fixed mapping of DSX currency pairs Jul 4, 2018
xchange-examples Merge branch 'develop' into develop Jul 16, 2018
xchange-exmo [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-fcoin [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-gatecoin [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-gateio Cancel Order fixed Jul 6, 2018
xchange-gdax [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-gemini [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-hitbtc [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-huobi [Huobi] Adapt funding history status Jul 19, 2018
xchange-idex [IDEX] Jul 8, 2018
xchange-independentreserve [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-itbit [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-koineks [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-koinim [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-kraken [Kraken] Increase rate limit Jul 19, 2018
xchange-kucoin [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-kuna [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-lakebtc [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-liqui [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-livecoin Livecoin allows a maximum of 30 days history Jul 6, 2018
xchange-luno [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-mercadobitcoin [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-okcoin [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-openexchangerates [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-paribu [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-paymium Merge pull request #2692 from trixprod/paymium-private-api Jul 9, 2018
xchange-poloniex [Poloniex] Update OMG withdrawal fee Jul 19, 2018
xchange-quadrigacx [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-quoine [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-ripple [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-therock [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-truefx [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-upbit [Upbit] version up 4.3.9 Jul 9, 2018
xchange-vaultoro [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-vircurex [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-wex [Wex] Fix dash adapting Jul 19, 2018
xchange-yobit [maven-release-plugin] prepare for next development iteration Jul 3, 2018
xchange-zaif [maven-release-plugin] prepare for next development iteration Jul 3, 2018
.gitattributes this will reduce whitespace churn Apr 3, 2018
.gitignore [resolves #1205] Update Coinbase Api to use the new Coinbase Exchange… Dec 27, 2017
.travis.yml Move settings.xml for travis-ci to the main branch Feb 15, 2018
CONTRIBUTORS prepare for 4.3.8 release Jul 3, 2018
LICENSE update copyright Apr 6, 2018
README.md prepare for 4.3.8 release Jul 3, 2018
pom.xml Merge branch 'develop' into develop Jul 16, 2018

README.md

XChange XChange

Join the chat at https://gitter.im/Java-XChange/Lobby

XChange is a Java library providing a simple and consistent API for interacting with 60+ Bitcoin and other crypto currency exchanges providing a consistent interface for trading and accessing market data.

Important!

The world of Bitcoin changes quickly and XChange is no exception. For the latest bugfixes and features you should use the [snapshot jars] (https://oss.sonatype.org/content/groups/public/org/knowm/xchange/) or build yourself from the DEVELOP branch. See below for more details about building with Maven. To report bugs and see what issues people are currently working on see the issues page.

Description

XChange is a library providing a simple and consistent API for interacting with a diverse set of crypto currency exchanges, including support for Bitcoin.

A complete list of implemented exchanges, data providers and brokers can be found on our Exchange Support page.

Usage is very simple: Create an Exchange instance, get the appropriate service, and request data.

Example 1: Public Market Data

Exchange bitstamp = ExchangeFactory.INSTANCE.createExchange(BitstampExchange.class.getName());

MarketDataService marketDataService = bitstamp.getMarketDataService();

Ticker ticker = marketDataService.getTicker(CurrencyPair.BTC_USD);

System.out.println(ticker.toString());

Example 2: Private Account Info

To use the private API services, AccountService and TradeService, create an ExchangeSpecification with a unique API key and secret key (in some cases more info is required), which you obtain through the exchange's web interface. For more examples of adding the keys to the ExchangeSpecification including storing them in a configuration file, see Frequently Asked Questions.

ExchangeSpecification exSpec = new BitstampExchange().getDefaultExchangeSpecification();
exSpec.setUserName("34387");
exSpec.setApiKey("a4SDmpl9s6xWJS5fkKRT6yn41vXuY0AM");
exSpec.setSecretKey("sisJixU6Xd0d1yr6w02EHCb9UwYzTNuj");
Exchange bitstamp = ExchangeFactory.INSTANCE.createExchange(exSpec);

// Get the account information
AccountService accountService = bitstamp.getAccountService();
AccountInfo accountInfo = accountService.getAccountInfo();
System.out.println(accountInfo.toString());

All exchange implementations expose the same API, but you can also directly access the underlying "raw" data from the individual exchanges if you need to.

Now go ahead and study some more examples, download the thing and provide feedback.

Features

  • MIT license
  • consistent API across all implemented exchanges
  • active development
  • very minimal 3rd party dependencies
  • modular components

More Info

Project Site: http://knowm.org/open-source/xchange
Example Code: http://knowm.org/open-source/xchange/xchange-example-code
Change Log: http://knowm.org/open-source/xchange/xchange-change-log/
Java Docs: http://knowm.org/javadocs/xchange/index.html

Looking for streaming API? Use library xchange-stream based on XChange.

Wiki

Continuous Integration

Build Status Build History

Getting Started

Non-Maven

Download XChange Release Jars: http://search.maven.org/#search%7Cga%7C1%7Cknowm%20xchange

Download XChange Snapshot Jars: https://oss.sonatype.org/content/groups/public/org/knowm/xchange/

Maven

The XChange release artifacts are hosted on Maven Central.

Add the following dependencies in your pom.xml file. You will need at least xchange-core. Add the additional dependencies for the exchange modules you are interested in (XYZ shown only for a placeholder). There is example code for all the modules in xchange-examples.

<dependency>
  <groupId>org.knowm.xchange</groupId>
  <artifactId>xchange-core</artifactId>
  <version>4.3.8</version>
</dependency>
<dependency>
  <groupId>org.knowm.xchange</groupId>
  <artifactId>xchange-examples</artifactId>
  <version>4.3.8</version>
</dependency>
<dependency>
  <groupId>org.knowm.xchange</groupId>
  <artifactId>xchange-XYZ</artifactId>
  <version>4.3.8</version>
</dependency>

For snapshots, add the following repository to your pom.xml file.

<repository>
  <id>sonatype-oss-snapshot</id>
  <snapshots/>
  <url>https://oss.sonatype.org/content/repositories/snapshots</url>
</repository>

The current snapshot version is:

4.3.9-SNAPSHOT

Building with Maven

run unit tests: mvn clean test
run unit and integration tests: mvn clean verify -DskipIntegrationTests=false
install in local Maven repo: mvn clean install
create project javadocs: mvn javadoc:aggregate
generate dependency tree: mvn dependency:tree
check for dependency updates: mvn versions:display-dependency-updates
check for plugin updates: mvn versions:display-plugin-updates
code format: mvn com.coveo:fmt-maven-plugin:format

Bugs

Please report any bugs or submit feature requests to XChange's Github issue tracker.

Contributing

If you'd like to submit a new implementation for another exchange, please take a look at New Implementation Best Practices first, as there are lots of time-saving tips!

For more information such as a contributor list and a list of known projects depending on XChange, visit the Main Project Wiki.