Read the contributing guide.
Orko is a fairly standard Maven build. If you're not using an IDE, perform a build using:
./build.sh
If you are using Eclipse, you need to configure M2E to enable annotation processing so that AutoValue works, but otherwise it should "just work".
Either way, run MonolithApplication
with the following arguments:
server example-config.yml
The file example-config.xml
works out-of-the-box with no authentication and a file-based database using H2.
Use the following VM arguments:
-server -Xmx186m -Xms186m -Xss256k -XX:MaxMetaspaceSize=96m -Dsun.net.inetaddr.ttl=60 -Dio.netty.leakDetectionLevel=advanced
This uses pre-packaged production front-end code without the need for a node environment.
You don't really need to know Java to work on the JS front-end. It's a simple, non-ejected create-react-app application.
Build the back end server so that you can run it separately, and launch it:
./build-backend-only.sh
./start.sh
Now setup the front end dev environment. You need node.js and npm
installed first (don't use the versions in deb/rpm package repositories - google them and follow the instructions on their websites). Once done:
cd orko-ui
npm install
npm start
You can now edit the JS code and enjoy hot reloading. It is assumed that the backend is running on port 8080 and the webpack dev loader on port 3000.
Start the back end in your IDE as detailed above, then simply:
cd orko-ui
npm install
npm start
You now have both the back end and front end running in dev together.
I used this project to teach myself JS/React, so the front-end side of things is nowhere near as clean as the back-end. It's mostly pretty conventional simple React/Redux, but having learned as I was going, it's a bit inconsistent and full of bad practices I haven't had time to clean up. It's also completely bereft of unit tests.
Orko definitely needs some attention from someone with a lot more Javascript experience. In particular, the performance of the UI leaves something to be desired (see #120).
- Check that XChange supports the exchange. If not, please ask there about adding support first. Until XChange supports it, Orko won't
- Check on streaming support at xchange-stream. This isn't necessary, but greatly improves the responsiveness of Orko if it's available.
- Add the XChange dependency to the parent POM and orko-common's POM. Don't add xchange-stream at first; it tends to be less reliable, and it can be unclear whether an issue is caused by XChange or xchange-stream if you use both at the same time.
- Check the name of the
Exchange
subclass for your exchange. If the exchange is calledFooExchange
then add a new constant inExchanges
. - Start the application and see if the public API components work. In particular, check that the order book is the right way around and ordered correctly (!), prices (ask/bid/etc) come through and market trades are correctly reported with the right direction.
- Add your exchange details and see if you get balances and trade history, and try placing trades (use a very low buy or very high sell so that it goes onto the exchange book but doesn't fill). Make sure the trade appears as an open trade. Try cancelling the trade, and make sure that works.
- Now try a trade that fills. Make sure the fill causes an alert, disappears from the open orders and appears in the trade history. Try both buys and sells.
- Now add the xchange-stream dependency and repeat the last 3 steps - they should all be more responsive but work just the same.
You will never get this far without problems. All exchanges have some quirk or other which requires tweaks. XChange is not 100% consistent and sometimes exchanges (particularly margin exchanges like Bitfinex or hunting grounds derivatives exchanges like Bitmex) have to be addressed differently. Generally, the best way to move quickly is to hack the necessary changes into Orko with a TODO, then follow up with a pull request to XChange or xchange-stream.
The scripting feature is barely more than a proof-of-concept right now. The scripting API itself is hardly easy to use. The plan right now is first to migrate from Nashorn (which only provides Javascript ES5) to a fully ES6 alternative (GraalVM or possibly Rhino) and layer a more when(this).then(that)
type of DSL over the low level API for less advanced users. However, alternative ideas are very welcome.
First, though, decent testing and debugging features are needed and the whole thing needs some security work - it's quite possible for a user to send the server into an endless loop.