Limit enter_tag and exit_reason to their actual field lenght
closes #8486
This commit is contained in:
		| @@ -64,7 +64,7 @@ USERPATH_FREQAIMODELS = 'freqaimodels' | ||||
| TELEGRAM_SETTING_OPTIONS = ['on', 'off', 'silent'] | ||||
| WEBHOOK_FORMAT_OPTIONS = ['form', 'json', 'raw'] | ||||
| FULL_DATAFRAME_THRESHOLD = 100 | ||||
| CUSTOM_TAG_MAX_LENGTH = 64 | ||||
| CUSTOM_TAG_MAX_LENGTH = 100 | ||||
|  | ||||
| ENV_VAR_PREFIX = 'FREQTRADE__' | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ from typing import Any, ClassVar, Dict, List, Optional, Sequence, cast | ||||
|  | ||||
| from sqlalchemy import (Enum, Float, ForeignKey, Integer, ScalarResult, Select, String, | ||||
|                         UniqueConstraint, desc, func, select) | ||||
| from sqlalchemy.orm import Mapped, lazyload, mapped_column, relationship | ||||
| from sqlalchemy.orm import Mapped, lazyload, mapped_column, relationship, validates | ||||
|  | ||||
| from freqtrade.constants import (CUSTOM_TAG_MAX_LENGTH, DATETIME_PRINT_FORMAT, MATH_CLOSE_PREC, | ||||
|                                  NON_OPEN_EXCHANGE_STATES, BuySell, LongShort) | ||||
| @@ -1295,6 +1295,13 @@ class Trade(ModelBase, LocalTrade): | ||||
|         self.realized_profit = 0 | ||||
|         self.recalc_open_trade_value() | ||||
|  | ||||
|     @validates('enter_tag', 'exit_reason') | ||||
|     def validate_string_len(self, key, value): | ||||
|         max_len = getattr(self.__class__, key).prop.columns[0].type.length | ||||
|         if value and len(value) > max_len: | ||||
|             return value[:max_len] | ||||
|         return value | ||||
|  | ||||
|     def delete(self) -> None: | ||||
|  | ||||
|         for order in self.orders: | ||||
|   | ||||
		Reference in New Issue
	
	Block a user