@quantform/core 0.5.13 → 0.5.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/adapter/adapter-aggregate.d.ts +8 -5
- package/dist/adapter/adapter-aggregate.js +18 -20
- package/dist/adapter/adapter-aggregate.js.map +1 -1
- package/dist/adapter/adapter.d.ts +20 -32
- package/dist/adapter/adapter.js +8 -43
- package/dist/adapter/adapter.js.map +1 -1
- package/dist/adapter/backtester/backtester-adapter.d.ts +11 -9
- package/dist/adapter/backtester/backtester-adapter.js +17 -16
- package/dist/adapter/backtester/backtester-adapter.js.map +1 -1
- package/dist/{tests → adapter/backtester}/backtester-adapter.spec.d.ts +0 -0
- package/dist/adapter/backtester/backtester-adapter.spec.js +83 -0
- package/dist/adapter/backtester/backtester-adapter.spec.js.map +1 -0
- package/dist/adapter/backtester/backtester-cursor.d.ts +3 -4
- package/dist/adapter/backtester/backtester-cursor.js +2 -1
- package/dist/adapter/backtester/backtester-cursor.js.map +1 -1
- package/dist/adapter/backtester/backtester-cursor.spec.js +19 -18
- package/dist/adapter/backtester/backtester-cursor.spec.js.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.d.ts +3 -1
- package/dist/adapter/backtester/backtester-streamer.js +25 -14
- package/dist/adapter/backtester/backtester-streamer.js.map +1 -1
- package/dist/adapter/backtester/backtester-streamer.spec.js +17 -16
- package/dist/adapter/backtester/backtester-streamer.spec.js.map +1 -1
- package/dist/adapter/error.d.ts +2 -0
- package/dist/adapter/error.js +12 -0
- package/dist/adapter/error.js.map +1 -0
- package/dist/adapter/paper/engine/paper-engine.d.ts +11 -0
- package/dist/adapter/paper/engine/paper-engine.js +104 -0
- package/dist/adapter/paper/engine/paper-engine.js.map +1 -0
- package/dist/adapter/paper/{simulator/paper-spot-simulator.spec.d.ts → engine/paper-engine.spec.d.ts} +0 -0
- package/dist/adapter/paper/engine/paper-engine.spec.js +54 -0
- package/dist/adapter/paper/engine/paper-engine.spec.js.map +1 -0
- package/dist/adapter/paper/index.d.ts +1 -2
- package/dist/adapter/paper/index.js +1 -2
- package/dist/adapter/paper/index.js.map +1 -1
- package/dist/adapter/paper/paper-adapter.d.ts +10 -9
- package/dist/adapter/paper/paper-adapter.js +26 -23
- package/dist/adapter/paper/paper-adapter.js.map +1 -1
- package/dist/adapter/paper/paper-adapter.spec.js +36 -17
- package/dist/adapter/paper/paper-adapter.spec.js.map +1 -1
- package/dist/bootstrap.js +11 -10
- package/dist/bootstrap.js.map +1 -1
- package/dist/cli/pull.js +8 -11
- package/dist/cli/pull.js.map +1 -1
- package/dist/cli/test.js +5 -1
- package/dist/cli/test.js.map +1 -1
- package/dist/domain/asset.d.ts +10 -9
- package/dist/domain/asset.js +26 -23
- package/dist/domain/asset.js.map +1 -1
- package/dist/domain/asset.spec.js +36 -36
- package/dist/domain/asset.spec.js.map +1 -1
- package/dist/domain/balance.d.ts +13 -13
- package/dist/domain/balance.js +38 -32
- package/dist/domain/balance.js.map +1 -1
- package/dist/domain/balance.operator.d.ts +6 -0
- package/dist/domain/balance.operator.js +10 -0
- package/dist/domain/balance.operator.js.map +1 -0
- package/dist/{indicator/truerange.spec.d.ts → domain/balance.operator.spec.d.ts} +0 -0
- package/dist/domain/balance.operator.spec.js +23 -0
- package/dist/domain/balance.operator.spec.js.map +1 -0
- package/dist/domain/balance.spec.js +73 -12
- package/dist/domain/balance.spec.js.map +1 -1
- package/dist/domain/candle.d.ts +8 -23
- package/dist/domain/candle.js +6 -72
- package/dist/domain/candle.js.map +1 -1
- package/dist/domain/candle.operator.d.ts +10 -0
- package/dist/domain/candle.operator.js +64 -0
- package/dist/domain/candle.operator.js.map +1 -0
- package/dist/{shared/policy.spec.d.ts → domain/candle.operator.spec.d.ts} +0 -0
- package/dist/domain/candle.operator.spec.js +112 -0
- package/dist/domain/candle.operator.spec.js.map +1 -0
- package/dist/domain/candle.spec.js +16 -58
- package/dist/domain/candle.spec.js.map +1 -1
- package/dist/domain/commission.d.ts +12 -8
- package/dist/domain/commission.js +6 -6
- package/dist/domain/commission.js.map +1 -1
- package/dist/{shared/topic.spec.d.ts → domain/commission.spec.d.ts} +0 -0
- package/dist/domain/commission.spec.js +31 -0
- package/dist/domain/commission.spec.js.map +1 -0
- package/dist/domain/component.d.ts +1 -0
- package/dist/domain/error.d.ts +6 -0
- package/dist/domain/error.js +24 -0
- package/dist/domain/error.js.map +1 -0
- package/dist/domain/index.d.ts +8 -1
- package/dist/domain/index.js +8 -1
- package/dist/domain/index.js.map +1 -1
- package/dist/domain/instrument.d.ts +3 -2
- package/dist/domain/instrument.js +17 -9
- package/dist/domain/instrument.js.map +1 -1
- package/dist/domain/instrument.operator.d.ts +6 -0
- package/dist/domain/instrument.operator.js +14 -0
- package/dist/domain/instrument.operator.js.map +1 -0
- package/dist/{store/event/store-balance.event.spec.d.ts → domain/instrument.operator.spec.d.ts} +0 -0
- package/dist/domain/instrument.operator.spec.js +24 -0
- package/dist/domain/instrument.operator.spec.js.map +1 -0
- package/dist/domain/instrument.spec.js +22 -30
- package/dist/domain/instrument.spec.js.map +1 -1
- package/dist/domain/order.d.ts +16 -18
- package/dist/domain/order.js +39 -27
- package/dist/domain/order.js.map +1 -1
- package/dist/domain/order.operator.d.ts +7 -0
- package/dist/domain/order.operator.js +14 -0
- package/dist/domain/order.operator.js.map +1 -0
- package/dist/{store/event/store-candle.event.spec.d.ts → domain/order.operator.spec.d.ts} +0 -0
- package/dist/domain/order.operator.spec.js +65 -0
- package/dist/domain/order.operator.spec.js.map +1 -0
- package/dist/{store/event/store-instrument.event.spec.d.ts → domain/order.spec.d.ts} +0 -0
- package/dist/domain/order.spec.js +34 -0
- package/dist/domain/order.spec.js.map +1 -0
- package/dist/domain/orderbook.d.ts +19 -6
- package/dist/domain/orderbook.js +6 -4
- package/dist/domain/orderbook.js.map +1 -1
- package/dist/domain/orderbook.operator.d.ts +6 -0
- package/dist/domain/orderbook.operator.js +10 -0
- package/dist/domain/orderbook.operator.js.map +1 -0
- package/dist/{store/event/store-order.event.spec.d.ts → domain/orderbook.operator.spec.d.ts} +0 -0
- package/dist/domain/orderbook.operator.spec.js +22 -0
- package/dist/domain/orderbook.operator.spec.js.map +1 -0
- package/dist/{store/event/store-trade.event.spec.d.ts → domain/orderbook.spec.d.ts} +0 -0
- package/dist/domain/orderbook.spec.js +13 -0
- package/dist/domain/orderbook.spec.js.map +1 -0
- package/dist/domain/position.d.ts +9 -14
- package/dist/domain/position.js +9 -31
- package/dist/domain/position.js.map +1 -1
- package/dist/domain/position.operator.d.ts +11 -0
- package/dist/domain/position.operator.js +38 -0
- package/dist/domain/position.operator.js.map +1 -0
- package/dist/domain/position.operator.spec.d.ts +1 -0
- package/dist/domain/position.operator.spec.js +49 -0
- package/dist/domain/position.operator.spec.js.map +1 -0
- package/dist/domain/position.spec.js +22 -17
- package/dist/domain/position.spec.js.map +1 -1
- package/dist/domain/session.d.ts +15 -18
- package/dist/domain/session.js +21 -31
- package/dist/domain/session.js.map +1 -1
- package/dist/domain/session.spec.js +2 -2
- package/dist/domain/session.spec.js.map +1 -1
- package/dist/domain/trade.d.ts +4 -3
- package/dist/domain/trade.js +1 -0
- package/dist/domain/trade.js.map +1 -1
- package/dist/domain/trade.operator.d.ts +6 -0
- package/dist/domain/trade.operator.js +10 -0
- package/dist/domain/trade.operator.js.map +1 -0
- package/dist/domain/trade.operator.spec.d.ts +1 -0
- package/dist/domain/trade.operator.spec.js +24 -0
- package/dist/domain/trade.operator.spec.js.map +1 -0
- package/dist/domain/trade.spec.d.ts +1 -0
- package/dist/domain/trade.spec.js +13 -0
- package/dist/domain/trade.spec.js.map +1 -0
- package/dist/indicator/atr.d.ts +2 -1
- package/dist/indicator/atr.js +3 -3
- package/dist/indicator/atr.js.map +1 -1
- package/dist/indicator/cross.d.ts +3 -2
- package/dist/indicator/cross.js +13 -13
- package/dist/indicator/cross.js.map +1 -1
- package/dist/indicator/cross.spec.js +23 -22
- package/dist/indicator/cross.spec.js.map +1 -1
- package/dist/indicator/donchian.d.ts +3 -2
- package/dist/indicator/donchian.js.map +1 -1
- package/dist/indicator/drawdown.d.ts +2 -1
- package/dist/indicator/drawdown.js +3 -2
- package/dist/indicator/drawdown.js.map +1 -1
- package/dist/indicator/ema.d.ts +2 -1
- package/dist/indicator/ema.js +3 -2
- package/dist/indicator/ema.js.map +1 -1
- package/dist/indicator/ema.spec.js +4 -3
- package/dist/indicator/ema.spec.js.map +1 -1
- package/dist/indicator/envelope.d.ts +4 -3
- package/dist/indicator/envelope.js +4 -4
- package/dist/indicator/envelope.js.map +1 -1
- package/dist/indicator/index.d.ts +1 -1
- package/dist/indicator/index.js +1 -1
- package/dist/indicator/index.js.map +1 -1
- package/dist/indicator/macd.d.ts +2 -1
- package/dist/indicator/macd.js +1 -1
- package/dist/indicator/macd.js.map +1 -1
- package/dist/indicator/min-max.d.ts +4 -3
- package/dist/indicator/min-max.js +5 -4
- package/dist/indicator/min-max.js.map +1 -1
- package/dist/indicator/rma.d.ts +2 -1
- package/dist/indicator/rma.js +3 -2
- package/dist/indicator/rma.js.map +1 -1
- package/dist/indicator/sma.d.ts +2 -1
- package/dist/indicator/sma.js +4 -6
- package/dist/indicator/sma.js.map +1 -1
- package/dist/indicator/sma.spec.js +4 -3
- package/dist/indicator/sma.spec.js.map +1 -1
- package/dist/indicator/swma.d.ts +2 -1
- package/dist/indicator/swma.js +5 -1
- package/dist/indicator/swma.js.map +1 -1
- package/dist/indicator/tma.d.ts +2 -1
- package/dist/indicator/tma.js.map +1 -1
- package/dist/indicator/tma.spec.js +4 -3
- package/dist/indicator/tma.spec.js.map +1 -1
- package/dist/indicator/trailing.d.ts +8 -7
- package/dist/indicator/trailing.js +12 -11
- package/dist/indicator/trailing.js.map +1 -1
- package/dist/indicator/trailing.spec.js +15 -14
- package/dist/indicator/trailing.spec.js.map +1 -1
- package/dist/indicator/true-range.d.ts +4 -0
- package/dist/indicator/true-range.js +20 -0
- package/dist/indicator/true-range.js.map +1 -0
- package/dist/indicator/true-range.spec.d.ts +1 -0
- package/dist/indicator/true-range.spec.js +28 -0
- package/dist/indicator/true-range.spec.js.map +1 -0
- package/dist/indicator/window.d.ts +1 -1
- package/dist/indicator/window.js +1 -1
- package/dist/indicator/window.js.map +1 -1
- package/dist/indicator/wma.d.ts +2 -1
- package/dist/indicator/wma.js +6 -5
- package/dist/indicator/wma.js.map +1 -1
- package/dist/indicator/wma.spec.js +4 -3
- package/dist/indicator/wma.spec.js.map +1 -1
- package/dist/shared/collections.d.ts +26 -0
- package/dist/shared/collections.js +115 -0
- package/dist/shared/collections.js.map +1 -0
- package/dist/shared/collections.spec.d.ts +1 -0
- package/dist/shared/collections.spec.js +28 -0
- package/dist/shared/collections.spec.js.map +1 -0
- package/dist/shared/datetime.d.ts +0 -1
- package/dist/shared/datetime.js +1 -12
- package/dist/shared/datetime.js.map +1 -1
- package/dist/shared/decimals.d.ts +15 -6
- package/dist/shared/decimals.js +22 -36
- package/dist/shared/decimals.js.map +1 -1
- package/dist/shared/decimals.spec.js +18 -22
- package/dist/shared/decimals.spec.js.map +1 -1
- package/dist/shared/index.d.ts +2 -1
- package/dist/shared/index.js +2 -1
- package/dist/shared/index.js.map +1 -1
- package/dist/shared/io.js.map +1 -1
- package/dist/shared/pipe.d.ts +4 -0
- package/dist/shared/pipe.js +9 -0
- package/dist/shared/pipe.js.map +1 -0
- package/dist/shared/policy.d.ts +0 -1
- package/dist/shared/policy.js +1 -11
- package/dist/shared/policy.js.map +1 -1
- package/dist/storage/cache.js +1 -1
- package/dist/storage/cache.js.map +1 -1
- package/dist/storage/cache.spec.d.ts +1 -0
- package/dist/storage/cache.spec.js +18 -0
- package/dist/storage/cache.spec.js.map +1 -0
- package/dist/storage/feed.d.ts +7 -4
- package/dist/storage/feed.js +55 -8
- package/dist/storage/feed.js.map +1 -1
- package/dist/storage/storage.d.ts +2 -7
- package/dist/storage/storage.js +6 -11
- package/dist/storage/storage.js.map +1 -1
- package/dist/store/index.d.ts +8 -2
- package/dist/store/index.js +8 -2
- package/dist/store/index.js.map +1 -1
- package/dist/store/store-balance.event.d.ts +33 -0
- package/dist/store/store-balance.event.js +90 -0
- package/dist/store/store-balance.event.js.map +1 -0
- package/dist/store/store-balance.event.spec.d.ts +1 -0
- package/dist/store/{event/store-balance.event.spec.js → store-balance.event.spec.js} +10 -10
- package/dist/store/store-balance.event.spec.js.map +1 -0
- package/dist/store/{event/store-instrument.event.d.ts → store-instrument.event.d.ts} +5 -8
- package/dist/store/store-instrument.event.js +52 -0
- package/dist/store/store-instrument.event.js.map +1 -0
- package/dist/store/store-instrument.event.spec.d.ts +1 -0
- package/dist/store/store-instrument.event.spec.js +22 -0
- package/dist/store/store-instrument.event.spec.js.map +1 -0
- package/dist/store/store-order.event.d.ts +59 -0
- package/dist/store/store-order.event.js +181 -0
- package/dist/store/store-order.event.js.map +1 -0
- package/dist/store/store-order.event.spec.d.ts +1 -0
- package/dist/store/{event/store-order.event.spec.js → store-order.event.spec.js} +8 -8
- package/dist/store/store-order.event.spec.js.map +1 -0
- package/dist/store/store-orderbook.event.d.ts +12 -0
- package/dist/store/store-orderbook.event.js +42 -0
- package/dist/store/store-orderbook.event.js.map +1 -0
- package/dist/store/store-orderbook.event.spec.d.ts +1 -0
- package/dist/store/store-orderbook.event.spec.js +28 -0
- package/dist/store/store-orderbook.event.spec.js.map +1 -0
- package/dist/store/store-position.event.d.ts +21 -0
- package/dist/store/store-position.event.js +89 -0
- package/dist/store/store-position.event.js.map +1 -0
- package/dist/store/store-state.d.ts +27 -0
- package/dist/store/store-state.js +29 -0
- package/dist/store/store-state.js.map +1 -0
- package/dist/store/store-trade.event.d.ts +12 -0
- package/dist/store/store-trade.event.js +25 -0
- package/dist/store/store-trade.event.js.map +1 -0
- package/dist/store/store-trade.event.spec.d.ts +1 -0
- package/dist/store/store-trade.event.spec.js +44 -0
- package/dist/store/store-trade.event.spec.js.map +1 -0
- package/dist/store/store.d.ts +4 -25
- package/dist/store/store.event.d.ts +6 -0
- package/dist/store/{event/store.event.js → store.event.js} +0 -0
- package/dist/store/store.event.js.map +1 -0
- package/dist/store/store.js +7 -195
- package/dist/store/store.js.map +1 -1
- package/dist/store/store.spec.d.ts +1 -0
- package/dist/store/store.spec.js +119 -0
- package/dist/store/store.spec.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/{jestconfig.unit.json → jestconfig.json} +2 -2
- package/package.json +4 -6
- package/src/adapter/adapter-aggregate.ts +39 -38
- package/src/adapter/adapter.ts +39 -71
- package/src/adapter/backtester/backtester-adapter.spec.ts +133 -0
- package/src/adapter/backtester/backtester-adapter.ts +41 -21
- package/src/adapter/backtester/backtester-cursor.spec.ts +19 -18
- package/src/adapter/backtester/backtester-cursor.ts +7 -7
- package/src/adapter/backtester/backtester-streamer.spec.ts +23 -22
- package/src/adapter/backtester/backtester-streamer.ts +28 -15
- package/src/adapter/error.ts +9 -0
- package/src/adapter/paper/engine/paper-engine.spec.ts +99 -0
- package/src/adapter/paper/engine/paper-engine.ts +142 -0
- package/src/adapter/paper/index.ts +1 -2
- package/src/adapter/paper/paper-adapter.spec.ts +65 -20
- package/src/adapter/paper/paper-adapter.ts +42 -27
- package/src/bootstrap.ts +26 -19
- package/src/cli/pull.ts +11 -6
- package/src/cli/test.ts +5 -2
- package/src/domain/asset.spec.ts +37 -33
- package/src/domain/asset.ts +33 -34
- package/src/domain/balance.operator.spec.ts +25 -0
- package/src/domain/balance.operator.ts +15 -0
- package/src/domain/balance.spec.ts +101 -12
- package/src/domain/balance.ts +57 -51
- package/src/domain/candle.operator.spec.ts +126 -0
- package/src/domain/candle.operator.ts +107 -0
- package/src/domain/candle.spec.ts +18 -73
- package/src/domain/candle.ts +9 -121
- package/src/domain/commission.spec.ts +34 -0
- package/src/domain/commission.ts +13 -11
- package/src/domain/component.ts +1 -0
- package/src/domain/error.ts +27 -0
- package/src/domain/index.ts +8 -1
- package/src/domain/instrument.operator.spec.ts +28 -0
- package/src/domain/instrument.operator.ts +25 -0
- package/src/domain/instrument.spec.ts +22 -30
- package/src/domain/instrument.ts +20 -11
- package/src/domain/order.operator.spec.ts +82 -0
- package/src/domain/order.operator.ts +23 -0
- package/src/domain/order.spec.ts +44 -0
- package/src/domain/order.ts +55 -55
- package/src/domain/orderbook.operator.spec.ts +28 -0
- package/src/domain/orderbook.operator.ts +15 -0
- package/src/domain/orderbook.spec.ts +17 -0
- package/src/domain/orderbook.ts +18 -9
- package/src/domain/position.operator.spec.ts +59 -0
- package/src/domain/position.operator.ts +64 -0
- package/src/domain/position.spec.ts +28 -23
- package/src/domain/position.ts +17 -49
- package/src/domain/session.spec.ts +4 -4
- package/src/domain/session.ts +42 -134
- package/src/domain/trade.operator.spec.ts +31 -0
- package/src/domain/trade.operator.ts +15 -0
- package/src/domain/trade.spec.ts +17 -0
- package/src/domain/trade.ts +7 -4
- package/src/indicator/atr.ts +6 -5
- package/src/indicator/cross.spec.ts +33 -48
- package/src/indicator/cross.ts +18 -10
- package/src/indicator/donchian.ts +5 -4
- package/src/indicator/drawdown.ts +7 -5
- package/src/indicator/ema.spec.ts +5 -4
- package/src/indicator/ema.ts +7 -6
- package/src/indicator/envelope.ts +11 -6
- package/src/indicator/index.ts +1 -1
- package/src/indicator/macd.ts +5 -4
- package/src/indicator/min-max.ts +10 -7
- package/src/indicator/rma.ts +7 -6
- package/src/indicator/sma.spec.ts +5 -4
- package/src/indicator/sma.ts +9 -8
- package/src/indicator/swma.ts +8 -4
- package/src/indicator/tma.spec.ts +5 -4
- package/src/indicator/tma.ts +4 -3
- package/src/indicator/trailing.spec.ts +29 -16
- package/src/indicator/trailing.ts +22 -16
- package/src/indicator/true-range.spec.ts +32 -0
- package/src/indicator/true-range.ts +32 -0
- package/src/indicator/window.ts +3 -3
- package/src/indicator/wma.spec.ts +5 -4
- package/src/indicator/wma.ts +8 -7
- package/src/shared/collections.spec.ts +30 -0
- package/src/shared/collections.ts +141 -0
- package/src/shared/datetime.ts +0 -12
- package/src/shared/decimals.spec.ts +19 -24
- package/src/shared/decimals.ts +22 -55
- package/src/shared/index.ts +2 -1
- package/src/shared/io.ts +0 -2
- package/src/shared/pipe.ts +12 -0
- package/src/shared/policy.ts +0 -13
- package/src/storage/cache.spec.ts +18 -0
- package/src/storage/cache.ts +1 -1
- package/src/storage/feed.ts +88 -23
- package/src/storage/storage.ts +9 -13
- package/src/store/index.ts +8 -2
- package/src/store/{event/store-balance.event.spec.ts → store-balance.event.spec.ts} +10 -10
- package/src/store/store-balance.event.ts +124 -0
- package/src/store/store-instrument.event.spec.ts +25 -0
- package/src/store/store-instrument.event.ts +72 -0
- package/src/store/store-order.event.spec.ts +28 -0
- package/src/store/store-order.event.ts +214 -0
- package/src/store/store-orderbook.event.spec.ts +37 -0
- package/src/store/store-orderbook.event.ts +54 -0
- package/src/store/store-position.event.ts +114 -0
- package/src/store/store-state.ts +48 -0
- package/src/store/store-trade.event.spec.ts +60 -0
- package/src/store/store-trade.event.ts +36 -0
- package/src/store/store.event.ts +8 -0
- package/src/store/store.spec.ts +180 -0
- package/src/store/store.ts +10 -208
- package/dist/adapter/paper/simulator/paper-margin-simulator.d.ts +0 -10
- package/dist/adapter/paper/simulator/paper-margin-simulator.js +0 -69
- package/dist/adapter/paper/simulator/paper-margin-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-simulator.d.ts +0 -16
- package/dist/adapter/paper/simulator/paper-simulator.js +0 -93
- package/dist/adapter/paper/simulator/paper-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-spot-simulator.d.ts +0 -13
- package/dist/adapter/paper/simulator/paper-spot-simulator.js +0 -81
- package/dist/adapter/paper/simulator/paper-spot-simulator.js.map +0 -1
- package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js +0 -49
- package/dist/adapter/paper/simulator/paper-spot-simulator.spec.js.map +0 -1
- package/dist/domain/statement.d.ts +0 -4
- package/dist/domain/statement.js +0 -87
- package/dist/domain/statement.js.map +0 -1
- package/dist/indicator/truerange.d.ts +0 -3
- package/dist/indicator/truerange.js +0 -19
- package/dist/indicator/truerange.js.map +0 -1
- package/dist/indicator/truerange.spec.js +0 -28
- package/dist/indicator/truerange.spec.js.map +0 -1
- package/dist/shared/policy.spec.js +0 -22
- package/dist/shared/policy.spec.js.map +0 -1
- package/dist/shared/topic.d.ts +0 -14
- package/dist/shared/topic.js +0 -40
- package/dist/shared/topic.js.map +0 -1
- package/dist/shared/topic.spec.js +0 -43
- package/dist/shared/topic.spec.js.map +0 -1
- package/dist/store/event/index.d.ts +0 -8
- package/dist/store/event/index.js +0 -25
- package/dist/store/event/index.js.map +0 -1
- package/dist/store/event/store-balance.event.d.ts +0 -37
- package/dist/store/event/store-balance.event.js +0 -119
- package/dist/store/event/store-balance.event.js.map +0 -1
- package/dist/store/event/store-balance.event.spec.js.map +0 -1
- package/dist/store/event/store-candle.event.d.ts +0 -18
- package/dist/store/event/store-candle.event.js +0 -63
- package/dist/store/event/store-candle.event.js.map +0 -1
- package/dist/store/event/store-candle.event.spec.js +0 -23
- package/dist/store/event/store-candle.event.spec.js.map +0 -1
- package/dist/store/event/store-instrument.event.js +0 -78
- package/dist/store/event/store-instrument.event.js.map +0 -1
- package/dist/store/event/store-instrument.event.spec.js +0 -21
- package/dist/store/event/store-instrument.event.spec.js.map +0 -1
- package/dist/store/event/store-order.event.d.ts +0 -61
- package/dist/store/event/store-order.event.js +0 -205
- package/dist/store/event/store-order.event.js.map +0 -1
- package/dist/store/event/store-order.event.spec.js.map +0 -1
- package/dist/store/event/store-orderbook.event.d.ts +0 -15
- package/dist/store/event/store-orderbook.event.js +0 -65
- package/dist/store/event/store-orderbook.event.js.map +0 -1
- package/dist/store/event/store-position.event.d.ts +0 -23
- package/dist/store/event/store-position.event.js +0 -97
- package/dist/store/event/store-position.event.js.map +0 -1
- package/dist/store/event/store-trade.event.d.ts +0 -13
- package/dist/store/event/store-trade.event.js +0 -47
- package/dist/store/event/store-trade.event.js.map +0 -1
- package/dist/store/event/store-trade.event.spec.js +0 -44
- package/dist/store/event/store-trade.event.spec.js.map +0 -1
- package/dist/store/event/store.event.d.ts +0 -5
- package/dist/store/event/store.event.js.map +0 -1
- package/dist/store/store.state.d.ts +0 -21
- package/dist/store/store.state.js +0 -21
- package/dist/store/store.state.js.map +0 -1
- package/dist/tests/backtester-adapter.spec.js +0 -61
- package/dist/tests/backtester-adapter.spec.js.map +0 -1
- package/dist/tests/session.spec.d.ts +0 -0
- package/dist/tests/session.spec.js +0 -1
- package/dist/tests/session.spec.js.map +0 -1
- package/jestconfig.integration.json +0 -12
- package/src/adapter/paper/simulator/paper-margin-simulator.ts +0 -108
- package/src/adapter/paper/simulator/paper-simulator.ts +0 -121
- package/src/adapter/paper/simulator/paper-spot-simulator.spec.ts +0 -87
- package/src/adapter/paper/simulator/paper-spot-simulator.ts +0 -134
- package/src/domain/statement.ts +0 -119
- package/src/indicator/truerange.spec.ts +0 -32
- package/src/indicator/truerange.ts +0 -31
- package/src/shared/policy.spec.ts +0 -25
- package/src/shared/topic.spec.ts +0 -34
- package/src/shared/topic.ts +0 -43
- package/src/store/event/index.ts +0 -8
- package/src/store/event/store-balance.event.ts +0 -161
- package/src/store/event/store-candle.event.spec.ts +0 -30
- package/src/store/event/store-candle.event.ts +0 -71
- package/src/store/event/store-instrument.event.spec.ts +0 -25
- package/src/store/event/store-instrument.event.ts +0 -84
- package/src/store/event/store-order.event.spec.ts +0 -28
- package/src/store/event/store-order.event.ts +0 -218
- package/src/store/event/store-orderbook.event.ts +0 -70
- package/src/store/event/store-position.event.ts +0 -109
- package/src/store/event/store-trade.event.spec.ts +0 -60
- package/src/store/event/store-trade.event.ts +0 -52
- package/src/store/event/store.event.ts +0 -6
- package/src/store/store.state.ts +0 -43
- package/src/tests/backtester-adapter.spec.ts +0 -88
- package/src/tests/session.spec.ts +0 -121
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.orders = exports.order = void 0;
|
|
4
|
+
const rxjs_1 = require("rxjs");
|
|
5
|
+
const order_1 = require("./order");
|
|
6
|
+
function order(selector) {
|
|
7
|
+
return (source$) => source$.pipe((0, rxjs_1.filter)(it => it instanceof order_1.Order && it.instrument.id == selector.id), (0, rxjs_1.map)(it => it));
|
|
8
|
+
}
|
|
9
|
+
exports.order = order;
|
|
10
|
+
function orders(selector, state) {
|
|
11
|
+
return (source$) => source$.pipe((0, rxjs_1.filter)(it => it instanceof order_1.Order && it.instrument.id == selector.id), (0, rxjs_1.map)(() => state.order.get(selector.id).asReadonlyArray()), (0, rxjs_1.startWith)(state.order.get(selector.id).asReadonlyArray()));
|
|
12
|
+
}
|
|
13
|
+
exports.orders = orders;
|
|
14
|
+
//# sourceMappingURL=order.operator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"order.operator.js","sourceRoot":"","sources":["../../src/domain/order.operator.ts"],"names":[],"mappings":";;;AAAA,+BAA0D;AAK1D,mCAAgC;AAEhC,SAAgB,KAAK,CAAC,QAA4B;IAChD,OAAO,CAAC,OAA8B,EAAE,EAAE,CACxC,OAAO,CAAC,IAAI,CACV,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,aAAK,IAAI,EAAE,CAAC,UAAU,CAAC,EAAE,IAAI,QAAQ,CAAC,EAAE,CAAC,EACpE,IAAA,UAAG,EAAC,EAAE,CAAC,EAAE,CAAC,EAAW,CAAC,CACvB,CAAC;AACN,CAAC;AAND,sBAMC;AAED,SAAgB,MAAM,CAAC,QAA4B,EAAE,KAAY;IAC/D,OAAO,CAAC,OAA8B,EAAE,EAAE,CACxC,OAAO,CAAC,IAAI,CACV,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,aAAK,IAAI,EAAE,CAAC,UAAU,CAAC,EAAE,IAAI,QAAQ,CAAC,EAAE,CAAC,EACpE,IAAA,UAAG,EAAC,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,eAAe,EAAE,CAAC,EACzD,IAAA,gBAAS,EAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,eAAe,EAAE,CAAC,CAC1D,CAAC;AACN,CAAC;AAPD,wBAOC"}
|
|
File without changes
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const rxjs_1 = require("rxjs");
|
|
4
|
+
const shared_1 = require("../shared");
|
|
5
|
+
const store_1 = require("../store");
|
|
6
|
+
const asset_1 = require("./asset");
|
|
7
|
+
const instrument_1 = require("./instrument");
|
|
8
|
+
const order_1 = require("./order");
|
|
9
|
+
const order_operator_1 = require("./order.operator");
|
|
10
|
+
const instrument = new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def');
|
|
11
|
+
describe('order', () => {
|
|
12
|
+
test('should pipe an order', done => {
|
|
13
|
+
new rxjs_1.BehaviorSubject(order_1.Order.market(instrument, (0, shared_1.d)(-100)))
|
|
14
|
+
.pipe((0, order_operator_1.order)(instrument))
|
|
15
|
+
.subscribe({
|
|
16
|
+
next: it => {
|
|
17
|
+
expect(it.instrument).toEqual(instrument);
|
|
18
|
+
expect(it.quantity).toEqual((0, shared_1.d)(-100));
|
|
19
|
+
done();
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
test('should skip a pipe', done => {
|
|
24
|
+
new rxjs_1.BehaviorSubject(instrument).pipe((0, order_operator_1.order)(instrument)).subscribe({
|
|
25
|
+
next: () => fail(),
|
|
26
|
+
complete: done()
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
describe('positions', () => {
|
|
31
|
+
let state;
|
|
32
|
+
let order1, order2, order3;
|
|
33
|
+
beforeEach(() => {
|
|
34
|
+
state = new store_1.State();
|
|
35
|
+
order1 = order_1.Order.market(instrument, (0, shared_1.d)(-100));
|
|
36
|
+
order2 = order_1.Order.limit(instrument, (0, shared_1.d)(100), (0, shared_1.d)(10));
|
|
37
|
+
order3 = order_1.Order.market(instrument, (0, shared_1.d)(100));
|
|
38
|
+
state.order.upsert(new store_1.InnerSet(instrument.id, [order1, order2, order3]));
|
|
39
|
+
});
|
|
40
|
+
test('should pipe all orders on subscription start', done => {
|
|
41
|
+
order1.state = 'NEW';
|
|
42
|
+
order2.state = 'NEW';
|
|
43
|
+
order3.state = 'NEW';
|
|
44
|
+
new rxjs_1.Subject().pipe((0, order_operator_1.orders)(instrument, state)).subscribe({
|
|
45
|
+
next: it => {
|
|
46
|
+
expect(it.length).toEqual(3);
|
|
47
|
+
done();
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
test('should pipe pending orders on subscription start', done => {
|
|
52
|
+
order1.state = 'NEW';
|
|
53
|
+
order2.state = 'PENDING';
|
|
54
|
+
order3.state = 'PENDING';
|
|
55
|
+
new rxjs_1.Subject()
|
|
56
|
+
.pipe((0, order_operator_1.orders)(instrument, state), (0, rxjs_1.map)(it => it.filter(order => order.state === 'PENDING')))
|
|
57
|
+
.subscribe({
|
|
58
|
+
next: it => {
|
|
59
|
+
expect(it.length).toEqual(2);
|
|
60
|
+
done();
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
//# sourceMappingURL=order.operator.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"order.operator.spec.js","sourceRoot":"","sources":["../../src/domain/order.operator.spec.ts"],"names":[],"mappings":";;AAAA,+BAAqD;AAErD,sCAA8B;AAC9B,oCAA2C;AAC3C,mCAAgC;AAEhC,6CAA0C;AAC1C,mCAAgC;AAChC,qDAAiD;AAEjD,MAAM,UAAU,GAAG,IAAI,uBAAU,CAC/B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;AAEF,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;IACrB,IAAI,CAAC,sBAAsB,EAAE,IAAI,CAAC,EAAE;QAClC,IAAI,sBAAe,CAAY,aAAK,CAAC,MAAM,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aAC9D,IAAI,CAAC,IAAA,sBAAK,EAAC,UAAU,CAAC,CAAC;aACvB,SAAS,CAAC;YACT,IAAI,EAAE,EAAE,CAAC,EAAE;gBACT,MAAM,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;gBAC1C,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBACrC,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,EAAE;QAChC,IAAI,sBAAe,CAAY,UAAU,CAAC,CAAC,IAAI,CAAC,IAAA,sBAAK,EAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;YAC3E,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE;YAClB,QAAQ,EAAE,IAAI,EAAE;SACjB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,IAAI,KAAY,CAAC;IACjB,IAAI,MAAa,EAAE,MAAa,EAAE,MAAa,CAAC;IAEhD,UAAU,CAAC,GAAG,EAAE;QACd,KAAK,GAAG,IAAI,aAAK,EAAE,CAAC;QAEpB,MAAM,GAAG,aAAK,CAAC,MAAM,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC3C,MAAM,GAAG,aAAK,CAAC,KAAK,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC,EAAE,IAAA,UAAC,EAAC,EAAE,CAAC,CAAC,CAAC;QAChD,MAAM,GAAG,aAAK,CAAC,MAAM,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,CAAC;QAE1C,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,gBAAQ,CAAQ,UAAU,CAAC,EAAE,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;IACnF,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8CAA8C,EAAE,IAAI,CAAC,EAAE;QAC1D,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QAErB,IAAI,cAAO,EAAa,CAAC,IAAI,CAAC,IAAA,uBAAM,EAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;YACjE,IAAI,EAAE,EAAE,CAAC,EAAE;gBACT,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC7B,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kDAAkD,EAAE,IAAI,CAAC,EAAE;QAC9D,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,MAAM,CAAC,KAAK,GAAG,SAAS,CAAC;QACzB,MAAM,CAAC,KAAK,GAAG,SAAS,CAAC;QAEzB,IAAI,cAAO,EAAa;aACrB,IAAI,CACH,IAAA,uBAAM,EAAC,UAAU,EAAE,KAAK,CAAC,EACzB,IAAA,UAAG,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CACzD;aACA,SAAS,CAAC;YACT,IAAI,EAAE,EAAE,CAAC,EAAE;gBACT,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC7B,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
File without changes
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const shared_1 = require("../shared");
|
|
4
|
+
const asset_1 = require("./asset");
|
|
5
|
+
const instrument_1 = require("./instrument");
|
|
6
|
+
const order_1 = require("./order");
|
|
7
|
+
describe('Order', () => {
|
|
8
|
+
const instrument = new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def');
|
|
9
|
+
test('should construct a market buy order', () => {
|
|
10
|
+
const sut = order_1.Order.market(instrument, (0, shared_1.d)(100));
|
|
11
|
+
expect(sut.quantity).toEqual((0, shared_1.d)(100));
|
|
12
|
+
expect(sut.rate).toEqual(undefined);
|
|
13
|
+
expect(sut.type).toEqual('MARKET');
|
|
14
|
+
});
|
|
15
|
+
test('should construct a market sell order', () => {
|
|
16
|
+
const sut = order_1.Order.market(instrument, (0, shared_1.d)(-100));
|
|
17
|
+
expect(sut.quantity).toEqual((0, shared_1.d)(-100));
|
|
18
|
+
expect(sut.rate).toEqual(undefined);
|
|
19
|
+
expect(sut.type).toEqual('MARKET');
|
|
20
|
+
});
|
|
21
|
+
test('should construct a limit buy order', () => {
|
|
22
|
+
const sut = order_1.Order.limit(instrument, (0, shared_1.d)(100), (0, shared_1.d)(2000));
|
|
23
|
+
expect(sut.quantity).toEqual((0, shared_1.d)(100));
|
|
24
|
+
expect(sut.rate).toEqual((0, shared_1.d)(2000));
|
|
25
|
+
expect(sut.type).toEqual('LIMIT');
|
|
26
|
+
});
|
|
27
|
+
test('should construct a limit sell order', () => {
|
|
28
|
+
const sut = order_1.Order.limit(instrument, (0, shared_1.d)(-100), (0, shared_1.d)(2000));
|
|
29
|
+
expect(sut.quantity).toEqual((0, shared_1.d)(-100));
|
|
30
|
+
expect(sut.rate).toEqual((0, shared_1.d)(2000));
|
|
31
|
+
expect(sut.type).toEqual('LIMIT');
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=order.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"order.spec.js","sourceRoot":"","sources":["../../src/domain/order.spec.ts"],"names":[],"mappings":";;AAAA,sCAA8B;AAC9B,mCAAgC;AAChC,6CAA0C;AAC1C,mCAAgC;AAEhC,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;IACrB,MAAM,UAAU,GAAG,IAAI,uBAAU,CAC/B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;IAEF,IAAI,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC/C,MAAM,GAAG,GAAG,aAAK,CAAC,MAAM,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,CAAC;QAE7C,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACpC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAChD,MAAM,GAAG,GAAG,aAAK,CAAC,MAAM,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAE9C,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACpC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC9C,MAAM,GAAG,GAAG,aAAK,CAAC,KAAK,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,GAAG,CAAC,EAAE,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC;QAErD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,GAAG,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC/C,MAAM,GAAG,GAAG,aAAK,CAAC,KAAK,CAAC,UAAU,EAAE,IAAA,UAAC,EAAC,CAAC,GAAG,CAAC,EAAE,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC;QAEtD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,IAAI,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,15 +1,28 @@
|
|
|
1
1
|
import { Instrument } from '../domain';
|
|
2
|
-
import { timestamp } from '../shared';
|
|
2
|
+
import { decimal, timestamp } from '../shared';
|
|
3
3
|
import { Component } from './component';
|
|
4
|
+
export interface Liquidity {
|
|
5
|
+
rate: decimal;
|
|
6
|
+
quantity: decimal;
|
|
7
|
+
next: this;
|
|
8
|
+
}
|
|
9
|
+
export declare const LiquidityAskComparer: (lhs: {
|
|
10
|
+
rate: decimal;
|
|
11
|
+
}, rhs: {
|
|
12
|
+
rate: decimal;
|
|
13
|
+
}) => number;
|
|
14
|
+
export declare const LiquidityBidComparer: (lhs: {
|
|
15
|
+
rate: decimal;
|
|
16
|
+
}, rhs: {
|
|
17
|
+
rate: decimal;
|
|
18
|
+
}) => number;
|
|
4
19
|
export declare class Orderbook implements Component {
|
|
5
20
|
readonly instrument: Instrument;
|
|
21
|
+
id: string;
|
|
6
22
|
kind: string;
|
|
7
23
|
timestamp: timestamp;
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
bestBidRate: number;
|
|
11
|
-
bestBidQuantity: number;
|
|
12
|
-
get midRate(): number;
|
|
24
|
+
asks: Liquidity;
|
|
25
|
+
bids: Liquidity;
|
|
13
26
|
constructor(instrument: Instrument);
|
|
14
27
|
toString(): string;
|
|
15
28
|
}
|
package/dist/domain/orderbook.js
CHANGED
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Orderbook = void 0;
|
|
3
|
+
exports.Orderbook = exports.LiquidityBidComparer = exports.LiquidityAskComparer = void 0;
|
|
4
|
+
const LiquidityAskComparer = (lhs, rhs) => lhs.rate.comparedTo(rhs.rate);
|
|
5
|
+
exports.LiquidityAskComparer = LiquidityAskComparer;
|
|
6
|
+
const LiquidityBidComparer = (lhs, rhs) => rhs.rate.comparedTo(lhs.rate);
|
|
7
|
+
exports.LiquidityBidComparer = LiquidityBidComparer;
|
|
4
8
|
class Orderbook {
|
|
5
9
|
constructor(instrument) {
|
|
6
10
|
this.instrument = instrument;
|
|
7
11
|
this.kind = 'orderbook';
|
|
8
|
-
|
|
9
|
-
get midRate() {
|
|
10
|
-
return this.instrument.quote.fixed((this.bestAskRate + this.bestBidRate) / 2);
|
|
12
|
+
this.id = instrument.id;
|
|
11
13
|
}
|
|
12
14
|
toString() {
|
|
13
15
|
return this.instrument.toString();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"orderbook.js","sourceRoot":"","sources":["../../src/domain/orderbook.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"orderbook.js","sourceRoot":"","sources":["../../src/domain/orderbook.ts"],"names":[],"mappings":";;;AAUO,MAAM,oBAAoB,GAAG,CAAC,GAAsB,EAAE,GAAsB,EAAE,EAAE,CACrF,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AADnB,QAAA,oBAAoB,wBACD;AACzB,MAAM,oBAAoB,GAAG,CAAC,GAAsB,EAAE,GAAsB,EAAE,EAAE,CACrF,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AADnB,QAAA,oBAAoB,wBACD;AAKhC,MAAa,SAAS;IAQpB,YAA4B,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QANlD,SAAI,GAAG,WAAW,CAAC;QAOjB,IAAI,CAAC,EAAE,GAAG,UAAU,CAAC,EAAE,CAAC;IAC1B,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;CACF;AAfD,8BAeC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Observable } from 'rxjs';
|
|
2
|
+
import { State } from '../store';
|
|
3
|
+
import { Component } from './component';
|
|
4
|
+
import { InstrumentSelector } from './instrument';
|
|
5
|
+
import { Orderbook } from './orderbook';
|
|
6
|
+
export declare function orderbook(selector: InstrumentSelector, state: State): (source$: Observable<Component>) => Observable<Orderbook>;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.orderbook = void 0;
|
|
4
|
+
const rxjs_1 = require("rxjs");
|
|
5
|
+
const orderbook_1 = require("./orderbook");
|
|
6
|
+
function orderbook(selector, state) {
|
|
7
|
+
return (source$) => source$.pipe((0, rxjs_1.startWith)(state.orderbook.get(selector.id)), (0, rxjs_1.filter)(it => it instanceof orderbook_1.Orderbook && it.instrument.id == selector.id), (0, rxjs_1.map)(it => it));
|
|
8
|
+
}
|
|
9
|
+
exports.orderbook = orderbook;
|
|
10
|
+
//# sourceMappingURL=orderbook.operator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"orderbook.operator.js","sourceRoot":"","sources":["../../src/domain/orderbook.operator.ts"],"names":[],"mappings":";;;AAAA,+BAA0D;AAK1D,2CAAwC;AAExC,SAAgB,SAAS,CAAC,QAA4B,EAAE,KAAY;IAClE,OAAO,CAAC,OAA8B,EAAE,EAAE,CACxC,OAAO,CAAC,IAAI,CACV,IAAA,gBAAS,EAAC,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,EAC3C,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,qBAAS,IAAI,EAAE,CAAC,UAAU,CAAC,EAAE,IAAI,QAAQ,CAAC,EAAE,CAAC,EACxE,IAAA,UAAG,EAAC,EAAE,CAAC,EAAE,CAAC,EAAe,CAAC,CAC3B,CAAC;AACN,CAAC;AAPD,8BAOC"}
|
package/dist/{store/event/store-order.event.spec.d.ts → domain/orderbook.operator.spec.d.ts}
RENAMED
|
File without changes
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const rxjs_1 = require("rxjs");
|
|
4
|
+
const store_1 = require("../store");
|
|
5
|
+
const asset_1 = require("./asset");
|
|
6
|
+
const instrument_1 = require("./instrument");
|
|
7
|
+
const orderbook_1 = require("./orderbook");
|
|
8
|
+
const orderbook_operator_1 = require("./orderbook.operator");
|
|
9
|
+
describe('orderbook', () => {
|
|
10
|
+
const instrument = new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def');
|
|
11
|
+
test('should pipe an orderbook on subscription', done => {
|
|
12
|
+
const state = new store_1.State();
|
|
13
|
+
state.orderbook.upsert(new orderbook_1.Orderbook(instrument));
|
|
14
|
+
new rxjs_1.Subject().pipe((0, orderbook_operator_1.orderbook)(instrument, state)).subscribe({
|
|
15
|
+
next: it => {
|
|
16
|
+
expect(it.id).toEqual(instrument.id);
|
|
17
|
+
done();
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
//# sourceMappingURL=orderbook.operator.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"orderbook.operator.spec.js","sourceRoot":"","sources":["../../src/domain/orderbook.operator.spec.ts"],"names":[],"mappings":";;AAAA,+BAA+B;AAE/B,oCAAiC;AACjC,mCAAgC;AAEhC,6CAA0C;AAC1C,2CAAwC;AACxC,6DAAiD;AAEjD,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,UAAU,GAAG,IAAI,uBAAU,CAC/B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;IAEF,IAAI,CAAC,0CAA0C,EAAE,IAAI,CAAC,EAAE;QACtD,MAAM,KAAK,GAAG,IAAI,aAAK,EAAE,CAAC;QAC1B,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,qBAAS,CAAC,UAAU,CAAC,CAAC,CAAC;QAElD,IAAI,cAAO,EAAa,CAAC,IAAI,CAAC,IAAA,8BAAS,EAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;YACpE,IAAI,EAAE,EAAE,CAAC,EAAE;gBACT,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;gBACrC,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
File without changes
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const asset_1 = require("./asset");
|
|
4
|
+
const instrument_1 = require("./instrument");
|
|
5
|
+
const orderbook_1 = require("./orderbook");
|
|
6
|
+
describe('Orderbook', () => {
|
|
7
|
+
const instrument = new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def');
|
|
8
|
+
test('should construct an empty orderbook', () => {
|
|
9
|
+
const sut = new orderbook_1.Orderbook(instrument);
|
|
10
|
+
expect(sut.id).toEqual(instrument.id);
|
|
11
|
+
});
|
|
12
|
+
});
|
|
13
|
+
//# sourceMappingURL=orderbook.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"orderbook.spec.js","sourceRoot":"","sources":["../../src/domain/orderbook.spec.ts"],"names":[],"mappings":";;AAAA,mCAAgC;AAChC,6CAA0C;AAC1C,2CAAwC;AAExC,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,UAAU,GAAG,IAAI,uBAAU,CAC/B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;IAEF,IAAI,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC/C,MAAM,GAAG,GAAG,IAAI,qBAAS,CAAC,UAAU,CAAC,CAAC;QAEtC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IACxC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,24 +1,19 @@
|
|
|
1
|
-
import { Observable } from 'rxjs';
|
|
2
1
|
import { Instrument } from '../domain';
|
|
3
|
-
import { timestamp } from '../shared';
|
|
2
|
+
import { decimal, timestamp } from '../shared';
|
|
4
3
|
import { Component } from './component';
|
|
5
4
|
export declare type PositionMode = 'CROSS' | 'ISOLATED';
|
|
6
5
|
export declare class Position implements Component {
|
|
7
6
|
readonly id: string;
|
|
8
7
|
readonly instrument: Instrument;
|
|
8
|
+
readonly mode: PositionMode;
|
|
9
|
+
averageExecutionRate: decimal;
|
|
10
|
+
size: decimal;
|
|
11
|
+
leverage: number;
|
|
9
12
|
kind: string;
|
|
10
13
|
timestamp: timestamp;
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
leverage: number;
|
|
14
|
-
|
|
15
|
-
estimatedUnrealizedPnL: number;
|
|
16
|
-
get margin(): number;
|
|
17
|
-
constructor(id: string, instrument: Instrument);
|
|
18
|
-
calculatePnL(rate: number): number;
|
|
14
|
+
estimatedUnrealizedPnL?: decimal;
|
|
15
|
+
get margin(): decimal;
|
|
16
|
+
constructor(id: string, instrument: Instrument, mode: PositionMode, averageExecutionRate: decimal, size: decimal, leverage: number);
|
|
17
|
+
calculateEstimatedUnrealizedPnL(rate: decimal): decimal;
|
|
19
18
|
toString(): string;
|
|
20
19
|
}
|
|
21
|
-
export declare function positionsFlat(): (source: Observable<Position[]>) => Observable<{
|
|
22
|
-
size: number;
|
|
23
|
-
rate: number;
|
|
24
|
-
}>;
|
package/dist/domain/position.js
CHANGED
|
@@ -1,21 +1,22 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
4
|
-
const rxjs_1 = require("rxjs");
|
|
3
|
+
exports.Position = void 0;
|
|
5
4
|
const shared_1 = require("../shared");
|
|
6
5
|
class Position {
|
|
7
|
-
constructor(id, instrument) {
|
|
6
|
+
constructor(id, instrument, mode, averageExecutionRate, size, leverage) {
|
|
8
7
|
this.id = id;
|
|
9
8
|
this.instrument = instrument;
|
|
9
|
+
this.mode = mode;
|
|
10
|
+
this.averageExecutionRate = averageExecutionRate;
|
|
11
|
+
this.size = size;
|
|
12
|
+
this.leverage = leverage;
|
|
10
13
|
this.kind = 'position';
|
|
11
|
-
this.mode = 'CROSS';
|
|
12
|
-
this.estimatedUnrealizedPnL = 0;
|
|
13
14
|
}
|
|
14
15
|
get margin() {
|
|
15
|
-
return this.instrument.quote.
|
|
16
|
+
return this.instrument.quote.floor(this.size.abs().div(this.leverage));
|
|
16
17
|
}
|
|
17
|
-
|
|
18
|
-
this.estimatedUnrealizedPnL = (0, shared_1.pnl)(this.averageExecutionRate, rate, this.size);
|
|
18
|
+
calculateEstimatedUnrealizedPnL(rate) {
|
|
19
|
+
this.estimatedUnrealizedPnL = this.instrument.quote.floor((0, shared_1.pnl)(this.averageExecutionRate, rate, this.size));
|
|
19
20
|
return this.estimatedUnrealizedPnL;
|
|
20
21
|
}
|
|
21
22
|
toString() {
|
|
@@ -23,27 +24,4 @@ class Position {
|
|
|
23
24
|
}
|
|
24
25
|
}
|
|
25
26
|
exports.Position = Position;
|
|
26
|
-
function positionsFlat() {
|
|
27
|
-
return function (source) {
|
|
28
|
-
return source.pipe((0, rxjs_1.map)(it => {
|
|
29
|
-
if (it.length > 1) {
|
|
30
|
-
return {
|
|
31
|
-
size: it.reduce((aggregate, position) => aggregate + position.size, 0),
|
|
32
|
-
rate: (0, shared_1.weightedMean)(it.map(x => x.averageExecutionRate), it.map(x => x.size))
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
if (it.length == 1) {
|
|
36
|
-
return {
|
|
37
|
-
size: it[0].size,
|
|
38
|
-
rate: it[0].averageExecutionRate
|
|
39
|
-
};
|
|
40
|
-
}
|
|
41
|
-
return {
|
|
42
|
-
size: 0,
|
|
43
|
-
rate: 0
|
|
44
|
-
};
|
|
45
|
-
}), (0, rxjs_1.share)());
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
exports.positionsFlat = positionsFlat;
|
|
49
27
|
//# sourceMappingURL=position.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"position.js","sourceRoot":"","sources":["../../src/domain/position.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"position.js","sourceRoot":"","sources":["../../src/domain/position.ts"],"names":[],"mappings":";;;AACA,sCAAoD;AAKpD,MAAa,QAAQ;IASnB,YACW,EAAU,EACV,UAAsB,EACtB,IAAkB,EACpB,oBAA6B,EAC7B,IAAa,EACb,QAAgB;QALd,OAAE,GAAF,EAAE,CAAQ;QACV,eAAU,GAAV,UAAU,CAAY;QACtB,SAAI,GAAJ,IAAI,CAAc;QACpB,yBAAoB,GAApB,oBAAoB,CAAS;QAC7B,SAAI,GAAJ,IAAI,CAAS;QACb,aAAQ,GAAR,QAAQ,CAAQ;QAdzB,SAAI,GAAG,UAAU,CAAC;IAef,CAAC;IAXJ,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IACzE,CAAC;IAWD,+BAA+B,CAAC,IAAa;QAC3C,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,KAAK,CACvD,IAAA,YAAG,EAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAChD,CAAC;QAEF,OAAO,IAAI,CAAC,sBAAsB,CAAC;IACrC,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;CACF;AA7BD,4BA6BC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Observable } from 'rxjs';
|
|
2
|
+
import { decimal } from '../shared';
|
|
3
|
+
import { State } from '../store';
|
|
4
|
+
import { InstrumentSelector } from './instrument';
|
|
5
|
+
import { Position } from './position';
|
|
6
|
+
export declare function position(selector: InstrumentSelector): (source: Observable<Position>) => Observable<Readonly<Position>>;
|
|
7
|
+
export declare function positions(selector: InstrumentSelector, state: State): (source: Observable<Position>) => Observable<Position[]>;
|
|
8
|
+
export declare function flatten(): (source: Observable<Position[]>) => Observable<{
|
|
9
|
+
size: decimal;
|
|
10
|
+
rate: decimal;
|
|
11
|
+
}>;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.flatten = exports.positions = exports.position = void 0;
|
|
4
|
+
const rxjs_1 = require("rxjs");
|
|
5
|
+
const shared_1 = require("../shared");
|
|
6
|
+
function position(selector) {
|
|
7
|
+
return (source) => source.pipe((0, rxjs_1.filter)(it => it.kind == 'position' && it.instrument.id == selector.id), (0, rxjs_1.map)(it => it));
|
|
8
|
+
}
|
|
9
|
+
exports.position = position;
|
|
10
|
+
function positions(selector, state) {
|
|
11
|
+
const getter = () => Object.values(state.balance.get(selector.quote.id).position).filter(it => it.instrument.id == selector.id);
|
|
12
|
+
return (source) => source.pipe(position(selector), (0, rxjs_1.map)(() => getter()), (0, rxjs_1.startWith)(getter()));
|
|
13
|
+
}
|
|
14
|
+
exports.positions = positions;
|
|
15
|
+
function flatten() {
|
|
16
|
+
return function (source) {
|
|
17
|
+
return source.pipe((0, rxjs_1.map)(it => {
|
|
18
|
+
if (it.length > 1) {
|
|
19
|
+
return {
|
|
20
|
+
size: it.reduce((aggregate, position) => aggregate.add(position.size), shared_1.d.Zero),
|
|
21
|
+
rate: (0, shared_1.weightedMean)(it.map(x => x.averageExecutionRate), it.map(x => x.size))
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
if (it.length == 1) {
|
|
25
|
+
return {
|
|
26
|
+
size: it[0].size,
|
|
27
|
+
rate: it[0].averageExecutionRate
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
return {
|
|
31
|
+
size: shared_1.d.Zero,
|
|
32
|
+
rate: shared_1.d.Zero
|
|
33
|
+
};
|
|
34
|
+
}), (0, rxjs_1.share)());
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
exports.flatten = flatten;
|
|
38
|
+
//# sourceMappingURL=position.operator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"position.operator.js","sourceRoot":"","sources":["../../src/domain/position.operator.ts"],"names":[],"mappings":";;;AAAA,+BAAiE;AAEjE,sCAAqD;AAKrD,SAAgB,QAAQ,CAAC,QAA4B;IACnD,OAAO,CAAC,MAA4B,EAAE,EAAE,CACtC,MAAM,CAAC,IAAI,CACT,IAAA,aAAM,EAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,IAAI,UAAU,IAAI,EAAE,CAAC,UAAU,CAAC,EAAE,IAAI,QAAQ,CAAC,EAAE,CAAC,EACtE,IAAA,UAAG,EAAC,EAAE,CAAC,EAAE,CAAC,EAAwB,CAAC,CACpC,CAAC;AACN,CAAC;AAND,4BAMC;AAED,SAAgB,SAAS,CAAC,QAA4B,EAAE,KAAY;IAClE,MAAM,MAAM,GAAG,GAAG,EAAE,CAClB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CACjE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,IAAI,QAAQ,CAAC,EAAE,CACtC,CAAC;IAEJ,OAAO,CAAC,MAA4B,EAAE,EAAE,CACtC,MAAM,CAAC,IAAI,CACT,QAAQ,CAAC,QAAQ,CAAC,EAClB,IAAA,UAAG,EAAC,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,EACnB,IAAA,gBAAS,EAAC,MAAM,EAAE,CAAC,CACpB,CAAC;AACN,CAAC;AAZD,8BAYC;AAED,SAAgB,OAAO;IACrB,OAAO,UACL,MAA8B;QAE9B,OAAO,MAAM,CAAC,IAAI,CAChB,IAAA,UAAG,EAAC,EAAE,CAAC,EAAE;YACP,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjB,OAAO;oBACL,IAAI,EAAE,EAAE,CAAC,MAAM,CACb,CAAC,SAAS,EAAE,QAAQ,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,EACrD,UAAC,CAAC,IAAI,CACP;oBACD,IAAI,EAAE,IAAA,qBAAY,EAChB,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,oBAAoB,CAAC,EACnC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CACpB;iBACF,CAAC;aACH;YAED,IAAI,EAAE,CAAC,MAAM,IAAI,CAAC,EAAE;gBAClB,OAAO;oBACL,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI;oBAChB,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,oBAAoB;iBACjC,CAAC;aACH;YAED,OAAO;gBACL,IAAI,EAAE,UAAC,CAAC,IAAI;gBACZ,IAAI,EAAE,UAAC,CAAC,IAAI;aACb,CAAC;QACJ,CAAC,CAAC,EACF,IAAA,YAAK,GAAE,CACR,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAlCD,0BAkCC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const rxjs_1 = require("rxjs");
|
|
4
|
+
const shared_1 = require("../shared");
|
|
5
|
+
const store_1 = require("../store");
|
|
6
|
+
const asset_1 = require("./asset");
|
|
7
|
+
const balance_1 = require("./balance");
|
|
8
|
+
const instrument_1 = require("./instrument");
|
|
9
|
+
const position_1 = require("./position");
|
|
10
|
+
const position_operator_1 = require("./position.operator");
|
|
11
|
+
const instrument = new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def');
|
|
12
|
+
describe('position', () => {
|
|
13
|
+
test('should pipe a position', done => {
|
|
14
|
+
new rxjs_1.BehaviorSubject(new position_1.Position('1', instrument, 'CROSS', (0, shared_1.d)(10), (0, shared_1.d)(2), 3))
|
|
15
|
+
.pipe((0, position_operator_1.position)(instrument))
|
|
16
|
+
.subscribe({
|
|
17
|
+
next: it => {
|
|
18
|
+
expect(it.id).toEqual('1');
|
|
19
|
+
done();
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
test('should skip a pipe', done => {
|
|
24
|
+
new rxjs_1.BehaviorSubject(instrument).pipe((0, position_operator_1.position)(instrument)).subscribe({
|
|
25
|
+
next: () => fail(),
|
|
26
|
+
complete: done()
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
});
|
|
30
|
+
describe('positions', () => {
|
|
31
|
+
const state = new store_1.State();
|
|
32
|
+
const balance = new balance_1.Balance(instrument.quote);
|
|
33
|
+
const position1 = new position_1.Position('1', instrument, 'CROSS', (0, shared_1.d)(10), (0, shared_1.d)(2), 3);
|
|
34
|
+
const position2 = new position_1.Position('2', instrument, 'CROSS', (0, shared_1.d)(20), (0, shared_1.d)(2), 3);
|
|
35
|
+
beforeEach(() => {
|
|
36
|
+
state.balance.upsert(balance);
|
|
37
|
+
balance.position['1'] = position1;
|
|
38
|
+
balance.position['2'] = position2;
|
|
39
|
+
});
|
|
40
|
+
test('should pipe an array of positions on subscription start', done => {
|
|
41
|
+
new rxjs_1.Subject().pipe((0, position_operator_1.positions)(instrument, state)).subscribe({
|
|
42
|
+
next: it => {
|
|
43
|
+
expect(it.length).toEqual(2);
|
|
44
|
+
done();
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
//# sourceMappingURL=position.operator.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"position.operator.spec.js","sourceRoot":"","sources":["../../src/domain/position.operator.spec.ts"],"names":[],"mappings":";;AAAA,+BAAgD;AAEhD,sCAA8B;AAC9B,oCAAiC;AACjC,mCAAgC;AAChC,uCAAoC;AAEpC,6CAA0C;AAC1C,yCAAsC;AACtC,2DAA0D;AAE1D,MAAM,UAAU,GAAG,IAAI,uBAAU,CAC/B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;AAEF,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,IAAI,CAAC,wBAAwB,EAAE,IAAI,CAAC,EAAE;QACpC,IAAI,sBAAe,CAAY,IAAI,mBAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,IAAA,UAAC,EAAC,EAAE,CAAC,EAAE,IAAA,UAAC,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aACnF,IAAI,CAAC,IAAA,4BAAQ,EAAC,UAAU,CAAC,CAAC;aAC1B,SAAS,CAAC;YACT,IAAI,EAAE,EAAE,CAAC,EAAE;gBACT,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;gBAC3B,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,EAAE;QAChC,IAAI,sBAAe,CAAY,UAAU,CAAC,CAAC,IAAI,CAAC,IAAA,4BAAQ,EAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;YAC9E,IAAI,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE;YAClB,QAAQ,EAAE,IAAI,EAAE;SACjB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,KAAK,GAAG,IAAI,aAAK,EAAE,CAAC;IAC1B,MAAM,OAAO,GAAG,IAAI,iBAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAC9C,MAAM,SAAS,GAAG,IAAI,mBAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,IAAA,UAAC,EAAC,EAAE,CAAC,EAAE,IAAA,UAAC,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACzE,MAAM,SAAS,GAAG,IAAI,mBAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,IAAA,UAAC,EAAC,EAAE,CAAC,EAAE,IAAA,UAAC,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAEzE,UAAU,CAAC,GAAG,EAAE;QACd,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAE9B,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;QAClC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,yDAAyD,EAAE,IAAI,CAAC,EAAE;QACrE,IAAI,cAAO,EAAa,CAAC,IAAI,CAAC,IAAA,6BAAS,EAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;YACpE,IAAI,EAAE,EAAE,CAAC,EAAE;gBACT,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC7B,IAAI,EAAE,CAAC;YACT,CAAC;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,26 +1,31 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const shared_1 = require("../shared");
|
|
3
4
|
const asset_1 = require("./asset");
|
|
4
5
|
const instrument_1 = require("./instrument");
|
|
5
6
|
const position_1 = require("./position");
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
test('should
|
|
9
|
-
const sut = new position_1.Position('
|
|
10
|
-
sut.
|
|
11
|
-
sut.
|
|
12
|
-
sut.
|
|
13
|
-
expect(sut.
|
|
14
|
-
expect(sut.
|
|
7
|
+
describe('Position', () => {
|
|
8
|
+
const instrument = new instrument_1.Instrument(new asset_1.Asset('abc', 'xyz', 4), new asset_1.Asset('def', 'xyz', 4), 'abc-def');
|
|
9
|
+
test('should construct a position', () => {
|
|
10
|
+
const sut = new position_1.Position('1', instrument, 'CROSS', (0, shared_1.d)(10), (0, shared_1.d)(2), 3);
|
|
11
|
+
expect(sut.id).toEqual('1');
|
|
12
|
+
expect(sut.mode).toEqual('CROSS');
|
|
13
|
+
expect(sut.averageExecutionRate).toEqual((0, shared_1.d)(10));
|
|
14
|
+
expect(sut.size).toEqual((0, shared_1.d)(2));
|
|
15
|
+
expect(sut.leverage).toEqual(3);
|
|
16
|
+
expect(sut.estimatedUnrealizedPnL).toEqual(undefined);
|
|
17
|
+
expect(sut.id).toEqual('1');
|
|
15
18
|
});
|
|
16
|
-
test('should calculate
|
|
17
|
-
const sut = new position_1.Position('
|
|
18
|
-
sut.
|
|
19
|
-
sut.
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
19
|
+
test('should calculate correct margin', () => {
|
|
20
|
+
const sut = new position_1.Position('1', instrument, 'CROSS', (0, shared_1.d)(2511.81), (0, shared_1.d)(10.31), 20);
|
|
21
|
+
expect(sut.margin).toEqual((0, shared_1.d)(0.5155));
|
|
22
|
+
expect(sut.estimatedUnrealizedPnL).toEqual(undefined);
|
|
23
|
+
});
|
|
24
|
+
test('should calculate correct unrealized pnl', () => {
|
|
25
|
+
const sut = new position_1.Position('1', instrument, 'CROSS', (0, shared_1.d)(2511.81), (0, shared_1.d)(10.31), 20);
|
|
26
|
+
const pnl = sut.calculateEstimatedUnrealizedPnL((0, shared_1.d)(2576.44));
|
|
27
|
+
expect(pnl).toEqual((0, shared_1.d)(0.2652));
|
|
28
|
+
expect(sut.estimatedUnrealizedPnL).toEqual((0, shared_1.d)(0.2652));
|
|
24
29
|
});
|
|
25
30
|
});
|
|
26
31
|
//# sourceMappingURL=position.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"position.spec.js","sourceRoot":"","sources":["../../src/domain/position.spec.ts"],"names":[],"mappings":";;AAAA,mCAAgC;AAChC,6CAA0C;AAC1C,yCAAsC;AAEtC,MAAM,UAAU,GAAG,IAAI,uBAAU,CAC/B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;
|
|
1
|
+
{"version":3,"file":"position.spec.js","sourceRoot":"","sources":["../../src/domain/position.spec.ts"],"names":[],"mappings":";;AAAA,sCAA8B;AAC9B,mCAAgC;AAChC,6CAA0C;AAC1C,yCAAsC;AAEtC,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACxB,MAAM,UAAU,GAAG,IAAI,uBAAU,CAC/B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,IAAI,aAAK,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,EAC1B,SAAS,CACV,CAAC;IAEF,IAAI,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACvC,MAAM,GAAG,GAAG,IAAI,mBAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,IAAA,UAAC,EAAC,EAAE,CAAC,EAAE,IAAA,UAAC,EAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAEnE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAC5B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,EAAE,CAAC,CAAC,CAAC;QAChD,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACtD,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC3C,MAAM,GAAG,GAAG,IAAI,mBAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,IAAA,UAAC,EAAC,OAAO,CAAC,EAAE,IAAA,UAAC,EAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QAE7E,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,MAAM,CAAC,CAAC,CAAC;QACtC,MAAM,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACnD,MAAM,GAAG,GAAG,IAAI,mBAAQ,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,IAAA,UAAC,EAAC,OAAO,CAAC,EAAE,IAAA,UAAC,EAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC;QAE7E,MAAM,GAAG,GAAG,GAAG,CAAC,+BAA+B,CAAC,IAAA,UAAC,EAAC,OAAO,CAAC,CAAC,CAAC;QAE5D,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,MAAM,CAAC,CAAC,CAAC;QAC/B,MAAM,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC,OAAO,CAAC,IAAA,UAAC,EAAC,MAAM,CAAC,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/dist/domain/session.d.ts
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { Observable } from 'rxjs';
|
|
2
|
-
import {
|
|
2
|
+
import { AdapterFactory, BacktesterOptions, PaperOptions } from '../adapter';
|
|
3
3
|
import { AdapterAggregate } from '../adapter/adapter-aggregate';
|
|
4
|
-
import { AssetSelector, Balance, Candle, Instrument, InstrumentSelector, Order, Orderbook,
|
|
4
|
+
import { AssetSelector, Balance, Candle, Instrument, InstrumentSelector, Order, Orderbook, Position, Trade } from '../domain';
|
|
5
5
|
import { StorageFactory } from '../storage';
|
|
6
6
|
import { Store } from '../store';
|
|
7
7
|
export interface SessionDescriptor {
|
|
8
8
|
id?: number;
|
|
9
|
-
adapter:
|
|
9
|
+
adapter: AdapterFactory[];
|
|
10
10
|
storage?: StorageFactory;
|
|
11
11
|
simulation?: PaperOptions & BacktesterOptions;
|
|
12
12
|
}
|
|
@@ -17,23 +17,20 @@ export declare class Session {
|
|
|
17
17
|
private initialized;
|
|
18
18
|
private subscription;
|
|
19
19
|
get timestamp(): number;
|
|
20
|
-
readonly statement: Record<string, Record<string, any>>;
|
|
21
20
|
constructor(store: Store, aggregate: AdapterAggregate, descriptor?: SessionDescriptor);
|
|
22
21
|
awake(describe: (session: Session) => Observable<any>): Promise<void>;
|
|
23
22
|
dispose(): Promise<void>;
|
|
24
|
-
useStatement(section: string): Record<string, any>;
|
|
25
|
-
useOptimizer(path: string): any;
|
|
26
23
|
subscribe(instrument: Array<InstrumentSelector>): Promise<void>;
|
|
27
|
-
open(order: Order): Observable<Order
|
|
28
|
-
cancel(order: Order): Observable<Order
|
|
29
|
-
instrument(selector: InstrumentSelector): Observable<Instrument
|
|
30
|
-
instruments(): Observable<Instrument[]
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
history(selector: InstrumentSelector, timeframe: number, length: number): Observable<Candle
|
|
24
|
+
open(order: Order): Observable<Readonly<Order>>;
|
|
25
|
+
cancel(order: Order): Observable<Readonly<Order>>;
|
|
26
|
+
instrument(selector: InstrumentSelector): Observable<Readonly<Instrument>>;
|
|
27
|
+
instruments(): Observable<Readonly<Instrument[]>>;
|
|
28
|
+
balance(selector: AssetSelector): Observable<Readonly<Balance>>;
|
|
29
|
+
trade(selector: InstrumentSelector): Observable<Readonly<Trade>>;
|
|
30
|
+
orderbook(selector: InstrumentSelector): Observable<Readonly<Orderbook>>;
|
|
31
|
+
position(selector: InstrumentSelector): Observable<Readonly<Position>>;
|
|
32
|
+
positions(selector: InstrumentSelector): Observable<Readonly<Position[]>>;
|
|
33
|
+
order(selector: InstrumentSelector): Observable<Readonly<Order>>;
|
|
34
|
+
orders(selector: InstrumentSelector): Observable<Readonly<Order[]>>;
|
|
35
|
+
history(selector: InstrumentSelector, timeframe: number, length: number): Observable<Readonly<Candle>>;
|
|
39
36
|
}
|