event: str
data: dict
Как присвоить event название класса?
Какого класса?
Чтобы Base(data={}).event == "Base"
name mapping что ли?
ChatGPT подсказал добавить метод к классу: def __init_subclass__(cls, **kwargs): cls.event = cls.__name__ super().__init_subclass__(**kwargs)
Нет, просто хочу в сокетах модели отправлять (FastAPI)
Получилось: class Base(BaseModel): event: str = Field("", validate_default=True) data: dict @field_validator("event") @classmethod def validate_event(cls, value: Optional[str]=None) -> str: return cls.__name__
Выглядит максимально странно. Но омжет я что-то не догоняю. Возвращать валидатором класс вместо значения - это меганеочевидно
Какой смысл в этом?
Для чего мне это? Я использую это, чтобы потом в WebSocket'ах отдавать ответ JSON'ами моделей
А ты до этого не marshmallow-ли пользовался случайно? Ищещь аналог post_dump?
Даже не знаю что такое marshmallow
сериализатор популярный в среде Flask
Пока pydantic нравится )
В общем, погугли `pydantic post_dump - post_dump` - это метод, вызываемый после дампа схемы, в нём логично добавлять информацию о классе схемы. Твой класс - это же класс схемы?
Ничего не нашёл
Ну на этом наши полномочия всё
А зачем клиенту знать имя твоего класса?
Отправляются данные в таком формате: {"event": "join", "data": {...}}
Пример моей модели: class Join(Base): @classmethod def parse(cls, ...) -> "Join": return cls( data = dict(...) )
И зачем тут имя класса?
Выше пример
А вот так отправляю юзеру: await connection.send_json( data = schemas.Join.parse(...) )
какая-то дичь. Если тебе нужно передавать тип события, передавай его в схему pydantic, зачем тебе привязывать схему к типу события?
Удобно? Твой тип в данных должен быть фиксирован и не обязан совпадать с именем класса
Уже так и подумал, и добавил значение event к каждому
Ну ты просто потратил кучу времени на поиск возможности сделать через жопу)
Обсуждают сегодня