A spring boot based order matching service based on price-time-matching algorithm.
- Every incoming order whose side is sales will be matched with existing buy orders and vice-versa.
- For every new buy order, sales order with least amount will be given priority. If there are more than one order matched for that amount, priority will be given to order with earlier timestamp.(FIFO).
- For every new sales order, buy order with max amount will be given priority. If there are more than one order matched for that amount, priority will be given to order with earlier timestamp. (FIFO).
- Currently, just for simulation purpose, we have taken time(java.sql.time) instead of timestamp.
- New order will be fullfilled according to the size, only if there are suitable matching orders.
- For any new sell order, order can only be matched if its price is more than sell order's price.
- For any new buy order, order can only be matched if its price is less than buy order's price.
The problem has been realised as a HTTP REST services, with endpoints for adding new order and fetching list of orders.
- Install postgres server and create a database called as 'order_book'.
- Make sure Java 1.8 is installed on your machine.
- After cloning the repo, go to root of the project.
mvn clean install
mvn spring-boot:run
Endpoints are as follows.
- POST
http://localhost:8080/book/order
--> endpoint for creating new order. Request body:{ "size": 1000, "price": 98, "time": "08:50:00", "side": "SELL" }
Response object will have processed order and also txns involved(order consumed while matching).
- GET
http://localhost:8080/book/order?active=false
--> endpoint for fetching existing orders with an active filter.