diff options
author | 2020-12-02 14:15:26 +0200 | |
---|---|---|
committer | 2020-12-02 14:15:26 +0200 | |
commit | f04af89d8fc4e3ca45ecab83f39dd581c207d3cd (patch) | |
tree | 4e6e1d7b079aaea79b987073b36f61cc260e9b8f | |
parent | Fix form features validation and allow passing ID as id not _id (diff) |
Parse type and data in same validator and allow passing ID as id not _id
-rw-r--r-- | backend/models/question.py | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/backend/models/question.py b/backend/models/question.py index 22565fd..d6b4946 100644 --- a/backend/models/question.py +++ b/backend/models/question.py @@ -1,6 +1,6 @@ import typing as t -from pydantic import BaseModel, Field, validator +from pydantic import BaseModel, Field, root_validator, validator from backend.constants import QUESTION_TYPES, REQUIRED_QUESTION_TYPE_DATA @@ -13,6 +13,9 @@ class Question(BaseModel): type: str data: t.Dict[str, t.Any] + class Config: + allow_population_by_field_name = True + @validator("type", pre=True) def validate_question_type(cls, value: str) -> t.Optional[str]: """Checks if question type in currently allowed types list.""" @@ -25,30 +28,30 @@ class Question(BaseModel): return value - @validator("data") + @root_validator def validate_question_data( cls, value: t.Dict[str, t.Any] ) -> t.Optional[t.Dict[str, t.Any]]: """Check does required data exists for question type and remove other data.""" # When question type don't need data, don't add anything to keep DB clean. - if cls.type not in REQUIRED_QUESTION_TYPE_DATA: + if value.get("type") not in REQUIRED_QUESTION_TYPE_DATA: return {} # Required keys (and values) will be stored to here # to remove all unnecessary stuff result = {} - for key, data_type in REQUIRED_QUESTION_TYPE_DATA[cls.type].items(): - if key not in value: + for key, data_type in REQUIRED_QUESTION_TYPE_DATA[value.get("type")].items(): + if key not in value.get("data", {}): raise ValueError(f"Required question data key '{key}' not provided.") - if not isinstance(value[key], data_type): + if not isinstance(value["data"][key], data_type): raise ValueError( f"Question data key '{key}' expects {data_type.__name__}, " - f"got {type(value[key]).__name__} instead." + f"got {type(value['data'][key]).__name__} instead." ) - result[key] = value[key] + result[key] = value["data"][key] return result |