freqtrade_origin/freqtrade/rpc/api_server/api_schemas.py

602 lines
14 KiB
Python
Raw Permalink Normal View History

2020-12-27 08:02:35 +00:00
from datetime import date, datetime
from typing import Any
2020-12-27 08:02:35 +00:00
from pydantic import AwareDatetime, BaseModel, RootModel, SerializeAsAny
2023-11-12 18:32:17 +00:00
from freqtrade.constants import IntOrInf
2023-06-04 11:25:39 +00:00
from freqtrade.enums import MarginMode, OrderTypeValues, SignalDirection, TradingMode
2024-09-04 04:44:48 +00:00
from freqtrade.ft_types import ValidExchangesType
2020-12-27 08:02:35 +00:00
2023-06-03 04:57:25 +00:00
class ExchangeModePayloadMixin(BaseModel):
trading_mode: TradingMode | None = None
margin_mode: MarginMode | None = None
exchange: str | None = None
2023-06-03 04:57:25 +00:00
class Ping(BaseModel):
status: str
2020-12-25 12:11:01 +00:00
2020-12-25 14:50:19 +00:00
class AccessToken(BaseModel):
access_token: str
class AccessAndRefreshToken(AccessToken):
refresh_token: str
2020-12-25 12:11:01 +00:00
class Version(BaseModel):
version: str
2020-12-25 19:07:12 +00:00
class StatusMsg(BaseModel):
status: str
2023-05-31 05:00:20 +00:00
class BgJobStarted(StatusMsg):
job_id: str
class BackgroundTaskStatus(BaseModel):
2023-05-31 05:08:27 +00:00
job_id: str
job_category: str
2023-05-31 05:00:20 +00:00
status: str
running: bool
progress: float | None = None
error: str | None = None
2023-05-31 05:00:20 +00:00
class BackgroundTaskResult(BaseModel):
error: str | None = None
2023-05-31 05:00:20 +00:00
status: str
2020-12-26 16:33:27 +00:00
class ResultMsg(BaseModel):
result: str
class Balance(BaseModel):
currency: str
free: float
balance: float
used: float
bot_owned: float | None = None
est_stake: float
est_stake_bot: float | None = None
stake: str
# Starting with 2.x
side: str
is_position: bool
position: float
2023-04-22 12:57:13 +00:00
is_bot_managed: bool
class Balances(BaseModel):
currencies: list[Balance]
total: float
2023-04-22 14:13:27 +00:00
total_bot: float
symbol: str
value: float
2023-04-22 14:13:27 +00:00
value_bot: float
stake: str
note: str
starting_capital: float
starting_capital_ratio: float
starting_capital_pct: float
starting_capital_fiat: float
starting_capital_fiat_ratio: float
starting_capital_fiat_pct: float
2020-12-26 14:54:22 +00:00
class Count(BaseModel):
current: int
max: int
total_stake: float
2020-12-26 15:43:15 +00:00
2023-11-11 16:16:31 +00:00
class __BaseStatsModel(BaseModel):
2023-11-11 13:43:24 +00:00
profit_ratio: float
profit_pct: float
profit_abs: float
count: int
2023-11-11 16:16:31 +00:00
class Entry(__BaseStatsModel):
enter_tag: str
class Exit(__BaseStatsModel):
2023-11-11 13:43:24 +00:00
exit_reason: str
2023-11-11 16:16:31 +00:00
class MixTag(__BaseStatsModel):
2023-11-11 13:43:24 +00:00
mix_tag: str
2023-11-11 16:16:31 +00:00
class PerformanceEntry(__BaseStatsModel):
2020-12-26 15:43:15 +00:00
pair: str
profit: float
class Profit(BaseModel):
profit_closed_coin: float
profit_closed_percent_mean: float
profit_closed_ratio_mean: float
profit_closed_percent_sum: float
profit_closed_ratio_sum: float
profit_closed_percent: float
profit_closed_ratio: float
2020-12-26 15:43:15 +00:00
profit_closed_fiat: float
profit_all_coin: float
profit_all_percent_mean: float
profit_all_ratio_mean: float
profit_all_percent_sum: float
profit_all_ratio_sum: float
profit_all_percent: float
profit_all_ratio: float
2020-12-26 15:43:15 +00:00
profit_all_fiat: float
trade_count: int
closed_trade_count: int
first_trade_date: str
first_trade_humanized: str
2020-12-26 15:43:15 +00:00
first_trade_timestamp: int
latest_trade_date: str
latest_trade_humanized: str
2020-12-26 15:43:15 +00:00
latest_trade_timestamp: int
avg_duration: str
best_pair: str
best_rate: float
best_pair_profit_ratio: float
2020-12-26 15:43:15 +00:00
winning_trades: int
losing_trades: int
profit_factor: float
2023-07-15 15:27:58 +00:00
winrate: float
expectancy: float
2023-07-17 13:16:22 +00:00
expectancy_ratio: float
max_drawdown: float
max_drawdown_abs: float
max_drawdown_start: str
max_drawdown_start_timestamp: int
max_drawdown_end: str
max_drawdown_end_timestamp: int
trading_volume: float | None = None
2023-04-08 14:40:22 +00:00
bot_start_timestamp: int
bot_start_date: str
2020-12-26 15:43:15 +00:00
class SellReason(BaseModel):
wins: int
losses: int
draws: int
class Stats(BaseModel):
exit_reasons: dict[str, SellReason]
durations: dict[str, float | None]
2023-09-02 15:06:23 +00:00
class DailyWeeklyMonthlyRecord(BaseModel):
2020-12-26 16:33:27 +00:00
date: date
abs_profit: float
2022-06-11 09:28:45 +00:00
rel_profit: float
starting_balance: float
2020-12-26 16:33:27 +00:00
fiat_value: float
trade_count: int
2023-09-02 15:06:23 +00:00
class DailyWeeklyMonthly(BaseModel):
data: list[DailyWeeklyMonthlyRecord]
2020-12-26 16:33:27 +00:00
fiat_display_currency: str
stake_currency: str
2021-11-06 15:12:25 +00:00
class UnfilledTimeout(BaseModel):
entry: int | None = None
exit: int | None = None
unit: str | None = None
exit_timeout_count: int | None = None
2021-11-06 15:12:25 +00:00
class OrderTypes(BaseModel):
entry: OrderTypeValues
exit: OrderTypeValues
emergency_exit: OrderTypeValues | None = None
force_exit: OrderTypeValues | None = None
force_entry: OrderTypeValues | None = None
2021-11-24 19:11:04 +00:00
stoploss: OrderTypeValues
2021-11-06 15:12:25 +00:00
stoploss_on_exchange: bool
stoploss_on_exchange_interval: int | None = None
2021-11-06 15:12:25 +00:00
2021-01-02 14:48:33 +00:00
class ShowConfig(BaseModel):
2021-11-06 15:12:25 +00:00
version: str
strategy_version: str | None = None
2021-11-23 06:06:53 +00:00
api_version: float
2021-02-20 18:17:10 +00:00
dry_run: bool
trading_mode: str
short_allowed: bool
2021-01-02 14:48:33 +00:00
stake_currency: str
stake_amount: str
available_capital: float | None = None
stake_currency_decimals: int
max_open_trades: IntOrInf
minimal_roi: dict[str, Any]
stoploss: float | None = None
stoploss_on_exchange: bool
trailing_stop: bool | None = None
trailing_stop_positive: float | None = None
trailing_stop_positive_offset: float | None = None
trailing_only_offset_is_reached: bool | None = None
unfilledtimeout: UnfilledTimeout | None = None # Empty in webserver mode
order_types: OrderTypes | None = None
use_custom_stoploss: bool | None = None
timeframe: str | None = None
2021-01-02 14:48:33 +00:00
timeframe_ms: int
timeframe_min: int
exchange: str
strategy: str | None = None
2022-04-08 11:39:41 +00:00
force_entry_enable: bool
exit_pricing: dict[str, Any]
entry_pricing: dict[str, Any]
bot_name: str
2021-01-02 14:48:33 +00:00
state: str
runmode: str
2022-01-21 00:35:22 +00:00
position_adjustment_enable: bool
max_entry_position_adjustment: int
2021-01-02 14:48:33 +00:00
2022-02-26 15:10:54 +00:00
class OrderSchema(BaseModel):
pair: str
order_id: str
status: str
remaining: float | None = None
2022-02-26 15:10:54 +00:00
amount: float
safe_price: float
cost: float
filled: float | None = None
2022-02-26 15:10:54 +00:00
ft_order_side: str
order_type: str
is_open: bool
order_timestamp: int | None = None
order_filled_timestamp: int | None = None
ft_fee_base: float | None = None
ft_order_tag: str | None = None
2022-02-26 15:10:54 +00:00
2021-01-01 18:36:03 +00:00
class TradeSchema(BaseModel):
2021-01-01 18:38:28 +00:00
trade_id: int
2021-01-01 18:36:03 +00:00
pair: str
2022-04-09 14:42:18 +00:00
base_currency: str
quote_currency: str
2021-01-01 18:36:03 +00:00
is_open: bool
is_short: bool
2021-01-01 18:36:03 +00:00
exchange: str
amount: float
amount_requested: float
stake_amount: float
max_stake_amount: float | None = None
2021-01-01 18:36:03 +00:00
strategy: str
enter_tag: str | None = None
2021-01-01 18:38:28 +00:00
timeframe: int
fee_open: float | None = None
fee_open_cost: float | None = None
fee_open_currency: str | None = None
fee_close: float | None = None
fee_close_cost: float | None = None
fee_close_currency: str | None = None
2023-02-28 17:09:52 +00:00
2021-01-01 18:36:03 +00:00
open_date: str
open_timestamp: int
open_fill_date: str | None
open_fill_timestamp: int | None
2021-01-01 18:36:03 +00:00
open_rate: float
open_rate_requested: float | None = None
2021-01-01 18:36:03 +00:00
open_trade_value: float
2023-02-28 17:09:52 +00:00
close_date: str | None = None
close_timestamp: int | None = None
close_rate: float | None = None
close_rate_requested: float | None = None
2023-02-28 17:09:52 +00:00
close_profit: float | None = None
close_profit_pct: float | None = None
close_profit_abs: float | None = None
2023-02-28 17:09:52 +00:00
profit_ratio: float | None = None
profit_pct: float | None = None
profit_abs: float | None = None
profit_fiat: float | None = None
2023-02-28 17:09:52 +00:00
2023-02-27 19:31:02 +00:00
realized_profit: float
realized_profit_ratio: float | None = None
exit_reason: str | None = None
exit_order_status: str | None = None
stop_loss_abs: float | None = None
stop_loss_ratio: float | None = None
stop_loss_pct: float | None = None
stoploss_last_update: str | None = None
stoploss_last_update_timestamp: int | None = None
initial_stop_loss_abs: float | None = None
initial_stop_loss_ratio: float | None = None
initial_stop_loss_pct: float | None = None
min_rate: float | None = None
max_rate: float | None = None
has_open_orders: bool
orders: list[OrderSchema]
2021-01-01 18:36:03 +00:00
leverage: float | None = None
interest_rate: float | None = None
liquidation_price: float | None = None
funding_fees: float | None = None
trading_mode: TradingMode | None = None
amount_precision: float | None = None
price_precision: float | None = None
precision_mode: int | None = None
2023-03-25 10:55:47 +00:00
2021-01-01 18:36:03 +00:00
2021-01-01 18:38:28 +00:00
class OpenTradeSchema(TradeSchema):
stoploss_current_dist: float | None = None
stoploss_current_dist_pct: float | None = None
stoploss_current_dist_ratio: float | None = None
stoploss_entry_dist: float | None = None
stoploss_entry_dist_ratio: float | None = None
2021-01-01 18:38:28 +00:00
current_rate: float
2023-02-28 19:31:02 +00:00
total_profit_abs: float
total_profit_fiat: float | None = None
total_profit_ratio: float | None = None
2023-02-28 19:31:02 +00:00
2021-01-01 18:38:28 +00:00
2021-01-01 18:36:03 +00:00
class TradeResponse(BaseModel):
trades: list[TradeSchema]
2021-01-01 18:36:03 +00:00
trades_count: int
2022-06-18 15:44:15 +00:00
offset: int
total_trades: int
2021-01-01 18:36:03 +00:00
ForceEnterResponse = RootModel[TradeSchema | StatusMsg]
2021-01-02 14:11:40 +00:00
2020-12-26 16:33:27 +00:00
class LockModel(BaseModel):
2021-03-01 18:50:39 +00:00
id: int
2020-12-26 16:33:27 +00:00
active: bool
lock_end_time: str
lock_end_timestamp: int
lock_time: str
lock_timestamp: int
pair: str
2022-04-24 09:51:33 +00:00
side: str
reason: str | None = None
2020-12-26 16:33:27 +00:00
class Locks(BaseModel):
lock_count: int
locks: list[LockModel]
2020-12-26 16:33:27 +00:00
class LocksPayload(BaseModel):
pair: str
2024-05-12 14:51:11 +00:00
side: str = "*" # Default to both sides
until: AwareDatetime
reason: str | None = None
2021-03-01 18:50:39 +00:00
class DeleteLockRequest(BaseModel):
pair: str | None = None
lockid: int | None = None
2021-03-01 18:50:39 +00:00
2020-12-26 16:33:27 +00:00
class Logs(BaseModel):
log_count: int
logs: list[list]
2020-12-26 16:33:27 +00:00
2022-01-26 06:10:38 +00:00
class ForceEnterPayload(BaseModel):
pair: str
2022-01-26 06:10:38 +00:00
side: SignalDirection = SignalDirection.LONG
price: float | None = None
ordertype: OrderTypeValues | None = None
stakeamount: float | None = None
entry_tag: str | None = None
leverage: float | None = None
2022-04-06 01:35:43 +00:00
class ForceExitPayload(BaseModel):
tradeid: str | int
ordertype: OrderTypeValues | None = None
amount: float | None = None
2020-12-26 16:33:27 +00:00
class BlacklistPayload(BaseModel):
blacklist: list[str]
2020-12-26 16:33:27 +00:00
class BlacklistResponse(BaseModel):
blacklist: list[str]
blacklist_expanded: list[str]
errors: dict
2020-12-26 16:33:27 +00:00
length: int
method: list[str]
2020-12-26 16:33:27 +00:00
class WhitelistResponse(BaseModel):
whitelist: list[str]
2020-12-26 16:33:27 +00:00
length: int
method: list[str]
2020-12-26 16:33:27 +00:00
2023-05-31 05:00:20 +00:00
class WhitelistEvaluateResponse(BackgroundTaskResult):
result: WhitelistResponse | None = None
2020-12-26 16:33:27 +00:00
class DeleteTrade(BaseModel):
cancel_order_count: int
result: str
result_msg: str
trade_id: int
2020-12-26 19:05:27 +00:00
2021-01-02 14:11:40 +00:00
class PlotConfig_(BaseModel):
main_plot: dict[str, Any]
subplots: dict[str, Any]
2020-12-26 19:05:27 +00:00
PlotConfig = RootModel[PlotConfig_ | dict]
2021-01-02 14:11:40 +00:00
2020-12-26 19:05:27 +00:00
class StrategyListResponse(BaseModel):
strategies: list[str]
2020-12-26 19:05:27 +00:00
class ExchangeListResponse(BaseModel):
exchanges: list[ValidExchangesType]
2024-10-22 04:36:21 +00:00
class HyperoptLoss(BaseModel):
name: str
description: str
class HyperoptLossListResponse(BaseModel):
loss_functions: list[HyperoptLoss]
2023-04-19 16:35:52 +00:00
class PairListResponse(BaseModel):
2023-04-20 16:15:31 +00:00
name: str
description: str
2023-04-20 16:15:31 +00:00
is_pairlist_generator: bool
params: dict[str, Any]
2023-04-20 16:15:31 +00:00
class PairListsResponse(BaseModel):
pairlists: list[PairListResponse]
2023-04-19 16:35:52 +00:00
2023-06-03 04:57:25 +00:00
class PairListsPayload(ExchangeModePayloadMixin, BaseModel):
pairlists: list[dict[str, Any]]
blacklist: list[str]
stake_currency: str
2022-12-20 06:21:52 +00:00
class FreqAIModelListResponse(BaseModel):
freqaimodels: list[str]
2022-12-20 06:21:52 +00:00
2020-12-26 19:05:27 +00:00
class StrategyResponse(BaseModel):
strategy: str
code: str
timeframe: str | None
2020-12-26 19:05:27 +00:00
class AvailablePairs(BaseModel):
length: int
pairs: list[str]
pair_interval: list[list[str]]
2020-12-27 08:02:35 +00:00
2024-04-28 09:33:45 +00:00
class PairCandlesRequest(BaseModel):
pair: str
timeframe: str
limit: int | None = None
columns: list[str] | None = None
2024-04-28 09:44:21 +00:00
class PairHistoryRequest(PairCandlesRequest):
timerange: str
strategy: str
freqaimodel: str | None = None
2024-04-28 09:44:21 +00:00
2020-12-27 08:02:35 +00:00
class PairHistory(BaseModel):
strategy: str
pair: str
timeframe: str
timeframe_ms: int
columns: list[str]
all_columns: list[str] = []
data: SerializeAsAny[list[Any]]
2020-12-27 08:02:35 +00:00
length: int
buy_signals: int
sell_signals: int
enter_long_signals: int
exit_long_signals: int
enter_short_signals: int
exit_short_signals: int
2020-12-27 08:02:35 +00:00
last_analyzed: datetime
last_analyzed_ts: int
data_start_ts: int
data_start: str
data_stop: str
data_stop_ts: int
2021-01-02 14:13:32 +00:00
2022-12-20 18:44:01 +00:00
class BacktestFreqAIInputs(BaseModel):
identifier: str
2021-01-02 14:13:32 +00:00
class BacktestRequest(BaseModel):
strategy: str
timeframe: str | None = None
timeframe_detail: str | None = None
timerange: str | None = None
max_open_trades: IntOrInf | None = None
stake_amount: str | float | None = None
enable_protections: bool
dry_run_wallet: float | None = None
backtest_cache: str | None = None
freqaimodel: str | None = None
freqai: BacktestFreqAIInputs | None = None
2021-01-02 14:13:32 +00:00
class BacktestResponse(BaseModel):
status: str
running: bool
status_msg: str
2021-03-11 18:16:18 +00:00
step: str
progress: float
trade_count: float | None = None
2021-01-02 14:13:32 +00:00
# TODO: Properly type backtestresult...
backtest_result: dict[str, Any] | None = None
2021-10-06 17:36:28 +00:00
2023-07-31 18:26:21 +00:00
# TODO: This is a copy of BacktestHistoryEntryType
class BacktestHistoryEntry(BaseModel):
filename: str
strategy: str
run_id: str
backtest_start_time: int
notes: str | None = ""
backtest_start_ts: int | None = None
backtest_end_ts: int | None = None
timeframe: str | None = None
timeframe_detail: str | None = None
2023-07-31 19:16:25 +00:00
class BacktestMetadataUpdate(BaseModel):
strategy: str
2024-05-12 14:51:11 +00:00
notes: str = ""
class BacktestMarketChange(BaseModel):
columns: list[str]
length: int
data: list[list[Any]]
class SysInfo(BaseModel):
cpu_pct: list[float]
ram_pct: float
class Health(BaseModel):
last_process: datetime | None = None
last_process_ts: int | None = None
bot_start: datetime | None = None
bot_start_ts: int | None = None
bot_startup: datetime | None = None
bot_startup_ts: int | None = None