OctoBot-Trading 2.4.167__tar.gz → 2.4.168__tar.gz
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.
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/CHANGELOG.md +4 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168/OctoBot_Trading.egg-info}/PKG-INFO +2 -2
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/OctoBot_Trading.egg-info/SOURCES.txt +1 -0
- {OctoBot-Trading-2.4.167/OctoBot_Trading.egg-info → OctoBot-Trading-2.4.168}/PKG-INFO +2 -2
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/README.md +1 -1
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/__init__.py +1 -1
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/__init__.py +2 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/orders.py +6 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/util/exchange_util.py +7 -1
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/__init__.py +4 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/__init__.py +4 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/order_util.py +37 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/portfolio_util.py +54 -20
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/sub_portfolio_data.py +32 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/types/spot_portfolio.py +2 -8
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/util/test_exchange_util.py +42 -1
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/test_portfolio_util.py +211 -60
- OctoBot-Trading-2.4.168/tests/personal_data/portfolios/test_sub_portfolio_data.py +123 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/LICENSE +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/MANIFEST.in +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/OctoBot_Trading.egg-info/dependency_links.txt +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/OctoBot_Trading.egg-info/not-zip-safe +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/OctoBot_Trading.egg-info/requires.txt +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/OctoBot_Trading.egg-info/top_level.txt +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/channels.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/contracts.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/modes.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/positions.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/profitability.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/storage.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/symbol_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/trader.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/api/trades.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/constants.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/enums.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/errors.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_channel.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/contracts/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/contracts/contract_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/contracts/future_contract.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/contracts/margin_contract.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/exchange_symbol_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/exchange_symbols_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/funding/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/funding/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/funding/channel/funding.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/funding/channel/funding_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/funding/channel/funding_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/funding/funding_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/kline/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/kline/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/kline/channel/kline.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/kline/channel/kline_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/kline/channel/kline_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/kline/kline_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/candles_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/candles_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/channel/ohlcv.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/channel/ohlcv_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/channel/ohlcv_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ohlcv/preloaded_candles_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/order_book/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/order_book/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/order_book/channel/order_book.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/order_book/channel/order_book_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/order_book/channel/order_book_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/order_book/order_book_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/prices/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/prices/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/prices/channel/price.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/prices/channel/prices_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/prices/channel/prices_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/prices/price_events_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/prices/prices_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/recent_trades/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/recent_trades/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/recent_trades/channel/recent_trade.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/recent_trades/channel/recent_trade_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/recent_trades/channel/recent_trade_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/recent_trades/recent_trades_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ticker/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ticker/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ticker/channel/ticker.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ticker/channel/ticker_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ticker/channel/ticker_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchange_data/ticker/ticker_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/abstract_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/abstract_websocket_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/adapters/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/adapters/abstract_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/config/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/config/backtesting_exchange_config.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/config/exchange_config_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/config/proxy_config.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/ccxt_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/ccxt_client_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/ccxt_clients_cache.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/ccxt_connector.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/ccxt_websocket_connector.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/constants.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/ccxt/enums.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/simulator/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/simulator/ccxt_client_simulation.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/simulator/exchange_simulator_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/connectors/simulator/exchange_simulator_connector.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/exchange_builder.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/exchange_channels.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/exchange_details.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/exchange_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/exchange_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/exchange_websocket_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/exchanges.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/implementations/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/implementations/default_rest_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/implementations/default_websocket_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/implementations/exchange_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/traders/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/traders/trader.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/traders/trader_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/types/rest_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/types/websocket_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/util/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/util/exchange_market_status_fixer.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/util/symbol_details.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/util/websockets_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/abstract_trading_mode.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/channel/abstract_mode_consumer.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/channel/abstract_mode_producer.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/channel/mode.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/mode_activity.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/mode_config.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/modes_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/modes_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/account_balance.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/amount.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/configuration.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/price.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/run_persistence.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/trading_signals.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/basic_keywords/user_inputs.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/context_management.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/dsl/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/dsl/quantity.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/script_keywords/dsl/values.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/scripted_trading_mode/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/modes/scripted_trading_mode/abstract_scripted_trading_mode.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/octobot_channel_consumer.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/exchange_personal_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/channel/orders.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/channel/orders_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/channel/orders_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/decimal_order_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/groups/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/groups/balanced_take_profit_and_stop_order_group.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/groups/group_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/groups/one_cancels_the_other_order_group.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/groups/trailing_on_filled_tp_balanced_order_group.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/order_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/order_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/order_group.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/orders_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/orders_storage_operations.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/cancel_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/close_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/fill_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/open_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/order_state_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/pending_creation_chained_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/states/pending_creation_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/trailing_profiles/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/trailing_profiles/filled_take_profit_trailing_profile.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/trailing_profiles/trailing_price_step.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/trailing_profiles/trailing_profile.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/trailing_profiles/trailing_profile_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/trailing_profiles/trailing_profile_types.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/buy_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/sell_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/stop_loss_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/stop_loss_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/take_profit_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/limit/take_profit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/market/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/market/buy_market_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/market/market_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/market/sell_market_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/trailing/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/trailing/trailing_stop_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/trailing/trailing_stop_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/unknown_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/types/unsupported_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/assets/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/assets/future_asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/assets/margin_asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/assets/spot_asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/channel/balance.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/channel/balance_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/channel/balance_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/history/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/history/historical_asset_value.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/history/historical_asset_value_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/history/historical_portfolio_value_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/portfolio_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/portfolio_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/portfolio_profitability.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/portfolio_value_holder.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/sub_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/types/future_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/types/margin_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/portfolios/value_converter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/channel/positions.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/channel/positions_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/channel/positions_updater_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/position_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/position_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/position_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/positions_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/states/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/states/active_position_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/states/idle_position_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/states/liquidate_position_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/states/position_state_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/types/inverse_position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/positions/types/linear_position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/channel/trades.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/channel/trades_updater.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/trade.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/trade_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/trade_pnl.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/trades_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/trades/trades_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/transaction.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/transaction_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/transactions_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/types/blockchain_transaction.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/types/fee_transaction.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/types/realised_pnl_transaction.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/transactions/types/transfer_transaction.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/channel/remote_trading_signal.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/channel/remote_trading_signal_channel_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/channel/signal_producer.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/signal_creation.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/trading_signal_bundle_builder.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/signals/util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/abstract_storage.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/candles_storage.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/orders_storage.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/portfolio_storage.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/storage_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/trades_storage.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/transactions_storage.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/storage/util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/supervisors/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/supervisors/abstract_portfolio_supervisor.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/supervisors/abstract_supervisor.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/config_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/initializable.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/initialization_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/simulator_updater_utils.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/test_tools/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/test_tools/exchange_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/test_tools/exchanges_test_tools.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/test_tools/spot_rest_exchange_test_tools.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/util/test_tools/websocket_test_tools.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/requirements.txt +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/setup.cfg +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/setup.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_channels.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_modes.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_orders.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_profitability.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_symbol_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_trader.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/api/test_trades.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/cli/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/contracts/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/contracts/test_future_contract.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/contracts/test_margin_contract.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/funding/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/funding/test_funding_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/kline/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/kline/test_kline_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/ohlcv/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/ohlcv/test_candles_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/ohlcv/test_candles_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/order_book/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/order_book/test_order_book_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/prices/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/prices/test_price_events_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/prices/test_prices_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/recent_trades/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/recent_trades/test_recent_trades_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/test_exchange_symbols_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/ticker/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchange_data/ticker/test_ticker_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/connectors/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/connectors/ccxt/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/connectors/ccxt/mock_exchanges_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/connectors/ccxt/test_ccxt_connector.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/implementations/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/implementations/test_default_rest_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/implementations/test_default_websocket_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_abstract_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_abstract_websocket_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_exchange_builder.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_exchange_config_data.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_exchange_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_exchange_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_exchange_simulator.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/test_exchanges.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/traders/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/traders/test_trader.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/types/test_websocket_exchange.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/util/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/util/test_exchange_market_status_fixer.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/basic_keywords/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/basic_keywords/test_account_balance.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/basic_keywords/test_amount.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/basic_keywords/test_position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/basic_keywords/test_price.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/dsl/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/script_keywords/dsl/test_quantity.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/test_abstract_mode_consumer.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/test_abstract_trading_mode.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/modes/test_modes_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/groups/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/groups/test_balanced_take_profit_and_stop_order_group.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/groups/test_group_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/groups/test_one_cancels_the_other_order_group.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/groups/test_trailing_on_filled_tp_balanced_order_group.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_cancel_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_close_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_fill_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_open_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_order_state_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_pending_creation_chained_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/states/test_pending_creation_order_state.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_decimal_order_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_double_filled_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_order_adapter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_order_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_order_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_orders_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/test_orders_storage_operations.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/trailing_profiles/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/trailing_profiles/test_filled_take_profit_trailing_profile.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/trailing_profiles/test_trailing_profile_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/test_buy_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/test_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/test_sell_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/test_stop_loss_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/test_stop_loss_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/test_take_profit_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/limit/test_take_profit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/market/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/market/test_buy_market_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/market/test_sell_market_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/test_unknown_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/trailing/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/trailing/test_trailing_stop_limit_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/orders/types/trailing/test_trailing_stop_order.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/assets/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/assets/test_future_asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/assets/test_margin_asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/assets/test_spot_asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/history/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/history/test_historical_asset_value_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/history/test_historical_portfolio_value_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/test_asset.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/test_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/test_portfolio_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/test_portfolio_profitability.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/test_portfolio_value_holder.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/test_value_converter.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/types/test_future_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/types/test_margin_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/portfolios/types/test_spot_portfolio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/channel/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/states/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/test_position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/test_position_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/test_positions_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/types/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/types/test_inverse_position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/positions/types/test_linear_position.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/trades/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/trades/test_trade_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/trades/test_trade_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/trades/test_trade_pnl.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/trades/test_trade_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/transactions/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/transactions/test_transaction_factory.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/personal_data/transactions/test_transactions_manager.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/signals/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/signals/test_trading_signal_bundle_builder.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/signals/test_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/test_utils/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/test_utils/order_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/test_utils/random_numbers.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/util/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/util/test_config_util.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/__init__.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/real_exchange_tester.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/real_futures_exchange_tester.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_ascendex.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_binance.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_binance_futures.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bingx.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bitfinex.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bitget.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bithumb.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bitmart.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bitmex.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bitso.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bitstamp.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bybit.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_bybit_futures.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_coinbase.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_coinex.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_cryptocom.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_gateio.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_hitbtc.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_hollaex.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_htx.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_kraken.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_kucoin.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_kucoin_futures.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_mexc.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_ndax.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_okcoin.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_okx.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_okx_futures.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_phemex.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_poloniex.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_upbit.py +0 -0
- {OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests_additional/real_exchanges/test_wavesexchange.py +0 -0
@@ -4,6 +4,10 @@ All notable changes to this project will be documented in this file.
|
|
4
4
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
5
5
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
6
6
|
|
7
|
+
## [2.4.168] - 2025-04-01
|
8
|
+
### Updated
|
9
|
+
[Subportfolio] handle locked funds from open orders
|
10
|
+
|
7
11
|
## [2.4.167] - 2025-03-31
|
8
12
|
### Updated
|
9
13
|
[Orders] fixed maker/taker fees of chained orders
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: OctoBot-Trading
|
3
|
-
Version: 2.4.
|
3
|
+
Version: 2.4.168
|
4
4
|
Summary: OctoBot project trading package
|
5
5
|
Home-page: https://github.com/Drakkar-Software/OctoBot-Trading
|
6
6
|
Author: Drakkar-Software
|
@@ -16,7 +16,7 @@ Classifier: Operating System :: POSIX
|
|
16
16
|
Requires-Python: >=3.8
|
17
17
|
License-File: LICENSE
|
18
18
|
|
19
|
-
# OctoBot-Trading [2.4.
|
19
|
+
# OctoBot-Trading [2.4.168](https://github.com/Drakkar-Software/OctoBot-Trading/blob/master/CHANGELOG.md)
|
20
20
|
[](https://app.codacy.com/gh/Drakkar-Software/OctoBot-Trading?utm_source=github.com&utm_medium=referral&utm_content=Drakkar-Software/OctoBot-Trading&utm_campaign=Badge_Grade_Dashboard)
|
21
21
|
[](https://pypi.python.org/pypi/OctoBot-Trading/)
|
22
22
|
[](https://coveralls.io/github/Drakkar-Software/OctoBot-Trading?branch=master)
|
@@ -415,6 +415,7 @@ tests/personal_data/portfolios/test_portfolio_manager.py
|
|
415
415
|
tests/personal_data/portfolios/test_portfolio_profitability.py
|
416
416
|
tests/personal_data/portfolios/test_portfolio_util.py
|
417
417
|
tests/personal_data/portfolios/test_portfolio_value_holder.py
|
418
|
+
tests/personal_data/portfolios/test_sub_portfolio_data.py
|
418
419
|
tests/personal_data/portfolios/test_value_converter.py
|
419
420
|
tests/personal_data/portfolios/assets/__init__.py
|
420
421
|
tests/personal_data/portfolios/assets/test_future_asset.py
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: OctoBot-Trading
|
3
|
-
Version: 2.4.
|
3
|
+
Version: 2.4.168
|
4
4
|
Summary: OctoBot project trading package
|
5
5
|
Home-page: https://github.com/Drakkar-Software/OctoBot-Trading
|
6
6
|
Author: Drakkar-Software
|
@@ -16,7 +16,7 @@ Classifier: Operating System :: POSIX
|
|
16
16
|
Requires-Python: >=3.8
|
17
17
|
License-File: LICENSE
|
18
18
|
|
19
|
-
# OctoBot-Trading [2.4.
|
19
|
+
# OctoBot-Trading [2.4.168](https://github.com/Drakkar-Software/OctoBot-Trading/blob/master/CHANGELOG.md)
|
20
20
|
[](https://app.codacy.com/gh/Drakkar-Software/OctoBot-Trading?utm_source=github.com&utm_medium=referral&utm_content=Drakkar-Software/OctoBot-Trading&utm_campaign=Badge_Grade_Dashboard)
|
21
21
|
[](https://pypi.python.org/pypi/OctoBot-Trading/)
|
22
22
|
[](https://coveralls.io/github/Drakkar-Software/OctoBot-Trading?branch=master)
|
@@ -1,4 +1,4 @@
|
|
1
|
-
# OctoBot-Trading [2.4.
|
1
|
+
# OctoBot-Trading [2.4.168](https://github.com/Drakkar-Software/OctoBot-Trading/blob/master/CHANGELOG.md)
|
2
2
|
[](https://app.codacy.com/gh/Drakkar-Software/OctoBot-Trading?utm_source=github.com&utm_medium=referral&utm_content=Drakkar-Software/OctoBot-Trading&utm_campaign=Badge_Grade_Dashboard)
|
3
3
|
[](https://pypi.python.org/pypi/OctoBot-Trading/)
|
4
4
|
[](https://coveralls.io/github/Drakkar-Software/OctoBot-Trading?branch=master)
|
@@ -196,6 +196,7 @@ from octobot_trading.api.orders import (
|
|
196
196
|
get_order_profitability,
|
197
197
|
get_minimal_order_cost,
|
198
198
|
get_order_trailing_profile_dict,
|
199
|
+
get_orders_locked_amounts_by_asset,
|
199
200
|
create_order,
|
200
201
|
cancel_all_open_orders,
|
201
202
|
cancel_all_open_orders_with_currency,
|
@@ -385,6 +386,7 @@ __all__ = [
|
|
385
386
|
"get_order_profitability",
|
386
387
|
"get_minimal_order_cost",
|
387
388
|
"get_order_trailing_profile_dict",
|
389
|
+
"get_orders_locked_amounts_by_asset",
|
388
390
|
"create_order",
|
389
391
|
"cancel_all_open_orders",
|
390
392
|
"cancel_all_open_orders_with_currency",
|
@@ -13,6 +13,8 @@
|
|
13
13
|
#
|
14
14
|
# You should have received a copy of the GNU Lesser General Public
|
15
15
|
# License along with this library.
|
16
|
+
import decimal
|
17
|
+
|
16
18
|
import octobot_commons.logging as logging
|
17
19
|
|
18
20
|
import octobot_trading.personal_data as personal_data
|
@@ -100,3 +102,7 @@ def get_minimal_order_cost(exchange_manager, symbol, default_price=None) -> floa
|
|
100
102
|
|
101
103
|
def get_order_trailing_profile_dict(order: personal_data.Order) -> dict:
|
102
104
|
return storage.get_order_trailing_profile_dict(order)
|
105
|
+
|
106
|
+
|
107
|
+
def get_orders_locked_amounts_by_asset(open_orders: list[personal_data.Order]) -> dict[str, decimal.Decimal]:
|
108
|
+
return personal_data.get_orders_locked_amounts_by_asset(open_orders)
|
{OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/exchanges/util/exchange_util.py
RENAMED
@@ -399,7 +399,7 @@ def update_raw_order_from_raw_trade(order_to_update, raw_trade):
|
|
399
399
|
enums.ExchangeConstantsOrderColumns.PRICE.value)
|
400
400
|
order_to_update[enums.ExchangeConstantsOrderColumns.TIMESTAMP.value] = order_to_update.get(
|
401
401
|
enums.ExchangeConstantsOrderColumns.TIMESTAMP.value,
|
402
|
-
raw_trade
|
402
|
+
raw_trade.get(enums.ExchangeConstantsOrderColumns.TIMESTAMP.value))
|
403
403
|
order_to_update[enums.ExchangeConstantsOrderColumns.STATUS.value] = enums.OrderStatus.FILLED.value
|
404
404
|
order_to_update[enums.ExchangeConstantsOrderColumns.FILLED.value] = raw_trade.get(
|
405
405
|
enums.ExchangeConstantsOrderColumns.AMOUNT.value)
|
@@ -409,6 +409,12 @@ def update_raw_order_from_raw_trade(order_to_update, raw_trade):
|
|
409
409
|
order_to_update[
|
410
410
|
enums.ExchangeConstantsOrderColumns.FEE.value
|
411
411
|
] = raw_trade.get(enums.ExchangeConstantsOrderColumns.FEE.value)
|
412
|
+
order_to_update[
|
413
|
+
enums.ExchangeConstantsOrderColumns.TAG.value
|
414
|
+
] = raw_trade.get(enums.ExchangeConstantsOrderColumns.TAG.value)
|
415
|
+
order_to_update[
|
416
|
+
enums.ExchangeConstantsOrderColumns.REDUCE_ONLY.value
|
417
|
+
] = raw_trade.get(enums.ExchangeConstantsOrderColumns.REDUCE_ONLY.value, False)
|
412
418
|
return order_to_update
|
413
419
|
|
414
420
|
|
{OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/__init__.py
RENAMED
@@ -34,6 +34,8 @@ from octobot_trading.personal_data.orders import (
|
|
34
34
|
total_fees_from_order_dict,
|
35
35
|
get_locked_funds,
|
36
36
|
get_fees_for_currency,
|
37
|
+
get_order_locked_amount,
|
38
|
+
get_orders_locked_amounts_by_asset,
|
37
39
|
parse_raw_fees,
|
38
40
|
parse_order_status,
|
39
41
|
parse_is_cancelled,
|
@@ -270,6 +272,8 @@ __all__ = [
|
|
270
272
|
"total_fees_from_order_dict",
|
271
273
|
"get_locked_funds",
|
272
274
|
"get_fees_for_currency",
|
275
|
+
"get_order_locked_amount",
|
276
|
+
"get_orders_locked_amounts_by_asset",
|
273
277
|
"parse_raw_fees",
|
274
278
|
"parse_order_status",
|
275
279
|
"parse_is_cancelled",
|
{OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/octobot_trading/personal_data/orders/__init__.py
RENAMED
@@ -94,6 +94,8 @@ from octobot_trading.personal_data.orders.order_util import (
|
|
94
94
|
get_locked_funds,
|
95
95
|
total_fees_from_order_dict,
|
96
96
|
get_fees_for_currency,
|
97
|
+
get_order_locked_amount,
|
98
|
+
get_orders_locked_amounts_by_asset,
|
97
99
|
parse_raw_fees,
|
98
100
|
parse_order_status,
|
99
101
|
parse_is_cancelled,
|
@@ -170,6 +172,8 @@ __all__ = [
|
|
170
172
|
"get_locked_funds",
|
171
173
|
"total_fees_from_order_dict",
|
172
174
|
"get_fees_for_currency",
|
175
|
+
"get_order_locked_amount",
|
176
|
+
"get_orders_locked_amounts_by_asset",
|
173
177
|
"parse_raw_fees",
|
174
178
|
"parse_order_status",
|
175
179
|
"parse_is_cancelled",
|
@@ -29,6 +29,7 @@ import octobot_trading.errors as errors
|
|
29
29
|
import octobot_trading.personal_data.orders.decimal_order_adapter as decimal_order_adapter
|
30
30
|
import octobot_trading.exchanges.util.exchange_market_status_fixer as exchange_market_status_fixer
|
31
31
|
import octobot_trading.personal_data.orders.states.fill_order_state as fill_order_state
|
32
|
+
import octobot_trading.personal_data.orders.order as order_import
|
32
33
|
from octobot_trading.enums import ExchangeConstantsMarketStatusColumns as Ecmsc
|
33
34
|
|
34
35
|
|
@@ -376,6 +377,42 @@ def get_fees_for_currency(fee, currency):
|
|
376
377
|
return constants.ZERO
|
377
378
|
|
378
379
|
|
380
|
+
def get_order_locked_amount(order: order_import.Order) -> decimal.Decimal:
|
381
|
+
# take fees into account when in locked asset
|
382
|
+
# ( a BTC/USDT order with USDT fees need to lock USDT fees to be able to pay them)
|
383
|
+
forecasted_fees = order.get_computed_fee(use_origin_quantity_and_price=not order.is_filled())
|
384
|
+
base, quote = symbol_util.parse_symbol(order.symbol).base_and_quote()
|
385
|
+
# when buy order
|
386
|
+
if order.side == enums.TradeOrderSide.BUY:
|
387
|
+
return order.origin_quantity * order.origin_price + get_fees_for_currency(forecasted_fees, quote)
|
388
|
+
# when sell order
|
389
|
+
return order.origin_quantity + get_fees_for_currency(forecasted_fees, base)
|
390
|
+
|
391
|
+
|
392
|
+
def get_orders_locked_amounts_by_asset(open_orders: list[order_import.Order]) -> dict[str, decimal.Decimal]:
|
393
|
+
if not open_orders:
|
394
|
+
return {}
|
395
|
+
locked_funds_by_asset = {}
|
396
|
+
for order in open_orders:
|
397
|
+
base, quote = symbol_util.parse_symbol(order.symbol).base_and_quote()
|
398
|
+
# use get_order_locked_amount just like trader simulator to ensure locked funds integrity
|
399
|
+
if order.side == enums.TradeOrderSide.BUY:
|
400
|
+
# buy orders only lock fees in quote
|
401
|
+
locked_quote = get_order_locked_amount(order)
|
402
|
+
if quote not in locked_funds_by_asset:
|
403
|
+
locked_funds_by_asset[quote] = locked_quote
|
404
|
+
else:
|
405
|
+
locked_funds_by_asset[quote] += locked_quote
|
406
|
+
else:
|
407
|
+
# sell orders only lock fees in base
|
408
|
+
locked_base = get_order_locked_amount(order)
|
409
|
+
if base not in locked_funds_by_asset:
|
410
|
+
locked_funds_by_asset[base] = locked_base
|
411
|
+
else:
|
412
|
+
locked_funds_by_asset[base] += locked_base
|
413
|
+
return locked_funds_by_asset
|
414
|
+
|
415
|
+
|
379
416
|
def parse_raw_fees(raw_fees):
|
380
417
|
fees = raw_fees
|
381
418
|
if fees:
|
@@ -281,11 +281,12 @@ def _resolve_sub_portfolio(
|
|
281
281
|
resolved_content = {}
|
282
282
|
funds_deltas = {}
|
283
283
|
missing_funds = {}
|
284
|
-
forecasted_sub_portfolio_content = sub_portfolio.get_content_after_deltas()
|
285
284
|
missing_amount_by_asset = {}
|
285
|
+
forecasted_sub_portfolio_content = sub_portfolio.get_content_after_deltas()
|
286
286
|
for asset_name, holdings in forecasted_sub_portfolio_content.items():
|
287
287
|
missing_amount_in_asset = _resolve_sub_portfolio_asset(
|
288
|
-
asset_name, holdings, remaining_master_portfolio, resolved_content,
|
288
|
+
asset_name, holdings, remaining_master_portfolio, resolved_content,
|
289
|
+
sub_portfolio.locked_funds_by_asset.get(asset_name, constants.ZERO), forbidden_filling_assets
|
289
290
|
)
|
290
291
|
if missing_amount_in_asset > constants.ZERO:
|
291
292
|
missing_amount_by_asset[asset_name] = missing_amount_in_asset
|
@@ -309,47 +310,80 @@ def _resolve_sub_portfolio(
|
|
309
310
|
|
310
311
|
|
311
312
|
def _resolve_sub_portfolio_asset(
|
312
|
-
asset_name
|
313
|
+
asset_name: str,
|
314
|
+
holdings: dict[str, decimal.Decimal],
|
315
|
+
remaining_master_portfolio: sub_portfolio_data.SubPortfolioData,
|
316
|
+
resolved_content: dict[str, dict[str, decimal.Decimal]],
|
317
|
+
locked_funds: decimal.Decimal,
|
318
|
+
forbidden_filling_assets: list[str]
|
313
319
|
) -> decimal.Decimal:
|
314
|
-
|
320
|
+
required_total_amount = holdings[commons_constants.PORTFOLIO_TOTAL]
|
321
|
+
required_available_amount = holdings[commons_constants.PORTFOLIO_TOTAL] - locked_funds
|
315
322
|
missing_amount_in_asset = constants.ZERO
|
316
323
|
if asset_name in remaining_master_portfolio.content and asset_name not in forbidden_filling_assets:
|
317
324
|
remaining_master_holding = remaining_master_portfolio.content[asset_name]
|
318
|
-
#
|
325
|
+
# available = total - locked_funds
|
326
|
+
remaining_total = remaining_master_holding[commons_constants.PORTFOLIO_TOTAL]
|
319
327
|
remaining_available = remaining_master_holding[commons_constants.PORTFOLIO_AVAILABLE]
|
320
|
-
|
321
|
-
|
328
|
+
allowed_missing_ratio_multiplier = constants.ONE - constants.SUB_PORTFOLIO_ALLOWED_MISSING_RATIO
|
329
|
+
if remaining_total < locked_funds * allowed_missing_ratio_multiplier:
|
330
|
+
# should never happen, log it in case it does
|
331
|
+
commons_logging.get_logger(__name__).error(
|
332
|
+
f"Unexpected missing locked {asset_name} funds in total portfolio {remaining_total=} {locked_funds=}"
|
333
|
+
)
|
334
|
+
# As orders are still open, their funds must be locked. Therefore, only consider available funds
|
335
|
+
if remaining_available >= required_available_amount * allowed_missing_ratio_multiplier:
|
336
|
+
if remaining_total < required_total_amount * allowed_missing_ratio_multiplier:
|
337
|
+
# should never happen, log it in case it does
|
338
|
+
commons_logging.get_logger(__name__).error(
|
339
|
+
f"Unexpected missing total {asset_name} value in portfolio: ensure order funds really locked"
|
340
|
+
)
|
341
|
+
sub_portfolio_total_amount = min(remaining_total, required_total_amount)
|
342
|
+
# Do not use remaining_available or remaining_available here to avoid side effects due to locked fees
|
343
|
+
# on some exchanges and not on others. Only compute from total holdings.
|
344
|
+
# ex: coinbase locks 101 USDC to buy for 100 USDC + 1 USDC fee,
|
345
|
+
# binance will just lock 100 and given less of the bought asset
|
346
|
+
sub_portfolio_available_amount = sub_portfolio_total_amount - locked_funds
|
322
347
|
# assets are available in master portfolio: reduce it from master
|
323
348
|
if asset_name in resolved_content:
|
324
|
-
resolved_content[asset_name][commons_constants.PORTFOLIO_TOTAL] +=
|
325
|
-
resolved_content[asset_name][commons_constants.PORTFOLIO_AVAILABLE] +=
|
349
|
+
resolved_content[asset_name][commons_constants.PORTFOLIO_TOTAL] += sub_portfolio_total_amount
|
350
|
+
resolved_content[asset_name][commons_constants.PORTFOLIO_AVAILABLE] += sub_portfolio_available_amount
|
326
351
|
else:
|
327
352
|
resolved_content[asset_name] = {
|
328
|
-
commons_constants.PORTFOLIO_TOTAL:
|
329
|
-
commons_constants.PORTFOLIO_AVAILABLE:
|
353
|
+
commons_constants.PORTFOLIO_TOTAL: sub_portfolio_total_amount,
|
354
|
+
commons_constants.PORTFOLIO_AVAILABLE: sub_portfolio_available_amount,
|
330
355
|
}
|
331
|
-
remaining_master_portfolio.content[asset_name][commons_constants.PORTFOLIO_TOTAL] -=
|
332
|
-
|
356
|
+
remaining_master_portfolio.content[asset_name][commons_constants.PORTFOLIO_TOTAL] -= sub_portfolio_total_amount
|
357
|
+
# don't make remaining available negative
|
358
|
+
removed_portfolio_available_amount = min(remaining_available, sub_portfolio_available_amount)
|
359
|
+
remaining_master_portfolio.content[asset_name][commons_constants.PORTFOLIO_AVAILABLE] -= removed_portfolio_available_amount
|
333
360
|
else:
|
334
|
-
#
|
361
|
+
# As orders are still open, their funds must be locked. Therefore, only consider available funds
|
362
|
+
# Not enough assets in master portfolio
|
363
|
+
usable_total = min(remaining_total, remaining_available + locked_funds)
|
335
364
|
if asset_name in resolved_content:
|
336
|
-
resolved_content[asset_name][commons_constants.PORTFOLIO_TOTAL] +=
|
365
|
+
resolved_content[asset_name][commons_constants.PORTFOLIO_TOTAL] += usable_total
|
337
366
|
resolved_content[asset_name][commons_constants.PORTFOLIO_AVAILABLE] += remaining_available
|
338
367
|
else:
|
339
368
|
resolved_content[asset_name] = {
|
340
|
-
commons_constants.PORTFOLIO_TOTAL:
|
369
|
+
commons_constants.PORTFOLIO_TOTAL: usable_total,
|
341
370
|
commons_constants.PORTFOLIO_AVAILABLE: remaining_available,
|
342
371
|
}
|
343
|
-
missing_amount_in_asset = abs(remaining_available -
|
344
|
-
remaining_master_portfolio.content[asset_name][commons_constants.PORTFOLIO_TOTAL] -=
|
372
|
+
missing_amount_in_asset = abs(remaining_available - required_available_amount)
|
373
|
+
remaining_master_portfolio.content[asset_name][commons_constants.PORTFOLIO_TOTAL] -= usable_total
|
345
374
|
remaining_master_portfolio.content[asset_name][commons_constants.PORTFOLIO_AVAILABLE] -= remaining_available
|
346
375
|
else:
|
376
|
+
if locked_funds > constants.ZERO:
|
377
|
+
# should never happen, log it in case it does
|
378
|
+
commons_logging.get_logger(__name__).error(
|
379
|
+
f"Unexpected missing {asset_name} value in portfolio but {locked_funds=}"
|
380
|
+
)
|
347
381
|
resolved_content[asset_name] = {
|
348
382
|
commons_constants.PORTFOLIO_TOTAL: constants.ZERO,
|
349
383
|
commons_constants.PORTFOLIO_AVAILABLE: constants.ZERO,
|
350
384
|
}
|
351
385
|
# asset not in master portfolio (anymore):
|
352
|
-
missing_amount_in_asset =
|
386
|
+
missing_amount_in_asset = required_available_amount
|
353
387
|
return missing_amount_in_asset
|
354
388
|
|
355
389
|
|
@@ -473,7 +507,7 @@ def get_portfolio_filled_orders_deltas(
|
|
473
507
|
ignored_deltas[asset_name] = holdings_delta
|
474
508
|
elif abs(min_allowed_equivalent_total_holding) > abs(order_asset_delta):
|
475
509
|
# too much in portfolio delta: only take what is linked to the orders deltas
|
476
|
-
#
|
510
|
+
# => updates both total and available
|
477
511
|
orders_linked_deltas[asset_name] = {
|
478
512
|
key: order_asset_delta
|
479
513
|
for key in holdings_delta
|
@@ -18,8 +18,10 @@ import dataclasses
|
|
18
18
|
import decimal
|
19
19
|
import typing
|
20
20
|
|
21
|
+
import octobot_commons.logging as commons_logging
|
21
22
|
import octobot_commons.constants as commons_constants
|
22
23
|
import octobot_trading.personal_data as personal_data
|
24
|
+
import octobot_trading.constants as constants
|
23
25
|
|
24
26
|
|
25
27
|
@dataclasses.dataclass
|
@@ -31,10 +33,17 @@ class SubPortfolioData:
|
|
31
33
|
unit: typing.Optional[str]
|
32
34
|
# deltas to be applied on top of the current content of the sub-portfolio from get_content_after_deltas()
|
33
35
|
funds_deltas: dict[str, dict[str, decimal.Decimal]] = dataclasses.field(default_factory=dict)
|
36
|
+
# funds that are missing from this portfolio. Populated after portfolio has been resolved
|
34
37
|
missing_funds: dict[str, decimal.Decimal] = dataclasses.field(default_factory=dict)
|
35
38
|
|
39
|
+
# funds that are locked (maybe in orders) from this portfolio
|
40
|
+
locked_funds_by_asset: dict[str, decimal.Decimal] = dataclasses.field(default_factory=dict)
|
41
|
+
|
36
42
|
|
37
43
|
def get_content_after_deltas(self) -> dict[str, dict[str, decimal.Decimal]]:
|
44
|
+
"""
|
45
|
+
Computes the updated portfolio from delta available and total
|
46
|
+
"""
|
38
47
|
updated_content = copy.deepcopy(self.content)
|
39
48
|
for asset, delta_values in self.funds_deltas.items():
|
40
49
|
if asset in updated_content:
|
@@ -51,6 +60,29 @@ class SubPortfolioData:
|
|
51
60
|
}
|
52
61
|
return updated_content
|
53
62
|
|
63
|
+
def get_content_from_total_deltas_and_locked_funds(self) -> dict[str, dict[str, decimal.Decimal]]:
|
64
|
+
"""
|
65
|
+
Only uses PORTFOLIO_TOTAL deltas and computes available values from locked_funds_by_asset
|
66
|
+
"""
|
67
|
+
updated_content = copy.deepcopy(self.content)
|
68
|
+
for asset, delta_values in self.funds_deltas.items():
|
69
|
+
if asset in updated_content:
|
70
|
+
updated_content[asset][commons_constants.PORTFOLIO_TOTAL] += (
|
71
|
+
delta_values[commons_constants.PORTFOLIO_TOTAL]
|
72
|
+
)
|
73
|
+
else:
|
74
|
+
updated_content[asset] = {
|
75
|
+
commons_constants.PORTFOLIO_TOTAL: delta_values[commons_constants.PORTFOLIO_TOTAL]
|
76
|
+
}
|
77
|
+
for asset, values in updated_content.items():
|
78
|
+
locked_funds = self.locked_funds_by_asset.get(asset, constants.ZERO)
|
79
|
+
if locked_funds > values[commons_constants.PORTFOLIO_TOTAL]:
|
80
|
+
commons_logging.get_logger(__name__).error(
|
81
|
+
f"Unexpected: negative {asset} available value after applying {locked_funds} locked funds to {values}"
|
82
|
+
)
|
83
|
+
values[commons_constants.PORTFOLIO_AVAILABLE] = values[commons_constants.PORTFOLIO_TOTAL] - locked_funds
|
84
|
+
return updated_content
|
85
|
+
|
54
86
|
def is_similar_to(self, other) -> bool:
|
55
87
|
return (
|
56
88
|
other
|
@@ -71,22 +71,16 @@ class SpotPortfolio(portfolio_class.Portfolio):
|
|
71
71
|
"""
|
72
72
|
multiplier = constants.ONE if is_new_order else -constants.ONE
|
73
73
|
|
74
|
-
# take fees into account when in locked asset
|
75
|
-
# ( a BTC/USDT order with USDT fees need to lock USDT fees to be able to pay them)
|
76
|
-
forecasted_fees = order.get_computed_fee(use_origin_quantity_and_price=not order.is_filled())
|
77
|
-
base_fees = order_util.get_fees_for_currency(forecasted_fees, order.currency)
|
78
|
-
quote_fees = order_util.get_fees_for_currency(forecasted_fees, order.market)
|
79
|
-
|
80
74
|
# when buy order
|
81
75
|
if order.side == enums.TradeOrderSide.BUY:
|
82
|
-
new_quantity = - (order
|
76
|
+
new_quantity = - order_util.get_order_locked_amount(order) * multiplier
|
83
77
|
self._update_portfolio_data(order.market,
|
84
78
|
available_value=new_quantity,
|
85
79
|
total_value=constants.ZERO)
|
86
80
|
|
87
81
|
# when sell order
|
88
82
|
else:
|
89
|
-
new_quantity = - (order
|
83
|
+
new_quantity = - order_util.get_order_locked_amount(order) * multiplier
|
90
84
|
self._update_portfolio_data(order.currency,
|
91
85
|
available_value=new_quantity,
|
92
86
|
total_value=constants.ZERO)
|
{OctoBot-Trading-2.4.167 → OctoBot-Trading-2.4.168}/tests/exchanges/util/test_exchange_util.py
RENAMED
@@ -19,7 +19,7 @@ import mock
|
|
19
19
|
import trading_backend.exchanges
|
20
20
|
import octobot_commons.constants as commons_constants
|
21
21
|
import octobot_commons.configuration as commons_configuration
|
22
|
-
import octobot_trading.
|
22
|
+
import octobot_trading.enums as enums
|
23
23
|
import octobot_trading.exchanges as exchanges
|
24
24
|
import octobot_trading.exchanges.util.exchange_util as exchange_util
|
25
25
|
|
@@ -251,3 +251,44 @@ def test_is_error_on_this_type():
|
|
251
251
|
assert exchange_util.is_error_on_this_type(Exception("api key doesn't exist"), errors) is True
|
252
252
|
assert exchange_util.is_error_on_this_type(Exception("api"), errors) is False
|
253
253
|
assert exchange_util.is_error_on_this_type(Exception("api"), errors) is False
|
254
|
+
|
255
|
+
|
256
|
+
def test_update_raw_order_from_raw_trade():
|
257
|
+
required_keys = [
|
258
|
+
enums.ExchangeConstantsOrderColumns.INFO,
|
259
|
+
enums.ExchangeConstantsOrderColumns.EXCHANGE_ID,
|
260
|
+
enums.ExchangeConstantsOrderColumns.SYMBOL,
|
261
|
+
enums.ExchangeConstantsOrderColumns.TYPE,
|
262
|
+
enums.ExchangeConstantsOrderColumns.AMOUNT,
|
263
|
+
enums.ExchangeConstantsOrderColumns.DATETIME,
|
264
|
+
enums.ExchangeConstantsOrderColumns.SIDE,
|
265
|
+
enums.ExchangeConstantsOrderColumns.TAKER_OR_MAKER,
|
266
|
+
enums.ExchangeConstantsOrderColumns.PRICE,
|
267
|
+
enums.ExchangeConstantsOrderColumns.TIMESTAMP,
|
268
|
+
enums.ExchangeConstantsOrderColumns.STATUS,
|
269
|
+
enums.ExchangeConstantsOrderColumns.FILLED,
|
270
|
+
enums.ExchangeConstantsOrderColumns.COST,
|
271
|
+
enums.ExchangeConstantsOrderColumns.REMAINING,
|
272
|
+
enums.ExchangeConstantsOrderColumns.FEE,
|
273
|
+
enums.ExchangeConstantsOrderColumns.TAG,
|
274
|
+
enums.ExchangeConstantsOrderColumns.REDUCE_ONLY,
|
275
|
+
]
|
276
|
+
default_value = exchange_util.update_raw_order_from_raw_trade({}, {})
|
277
|
+
assert all(key.value in default_value for key in required_keys)
|
278
|
+
with_trade_values = exchange_util.update_raw_order_from_raw_trade(
|
279
|
+
{}, {**{k.value: k.name for k in required_keys}, **{
|
280
|
+
enums.ExchangeConstantsOrderColumns.ORDER.value: "EXCHANGE_ID",
|
281
|
+
enums.ExchangeConstantsOrderColumns.AMOUNT.value: "AMOUNT",
|
282
|
+
}}
|
283
|
+
)
|
284
|
+
for key in required_keys:
|
285
|
+
if key == enums.ExchangeConstantsOrderColumns.STATUS:
|
286
|
+
assert with_trade_values[key.value] == enums.OrderStatus.FILLED.value
|
287
|
+
elif key == enums.ExchangeConstantsOrderColumns.REMAINING:
|
288
|
+
assert with_trade_values[key.value] == 0
|
289
|
+
elif key == enums.ExchangeConstantsOrderColumns.FILLED:
|
290
|
+
assert with_trade_values[key.value] == "AMOUNT"
|
291
|
+
elif key == enums.ExchangeConstantsOrderColumns.EXCHANGE_ID:
|
292
|
+
assert with_trade_values[key.value] == "EXCHANGE_ID"
|
293
|
+
else:
|
294
|
+
assert with_trade_values[key.value] == key.name
|