cloud-api/src/organisation/schemas.py

120 lines
2.9 KiB
Python
Raw Normal View History

2026-04-06 12:41:49 +01:00
"""
Pydantic models for organisation module
2026-05-28 14:23:36 +01:00
Models follow the nomenclature of:
- Sub-models: "<Resource><Opt:>Schema"
- Mixins: "<Attribute>Mixin"
- Models: "<Module><Method><Resource><Opt:Resource><Direction>" ie "OrgPostOrgRequest"
2026-04-06 12:41:49 +01:00
"""
from typing import Optional
2026-04-06 12:41:49 +01:00
2026-06-02 13:34:05 +01:00
from pydantic import EmailStr, ConfigDict, Field
2026-04-06 12:41:49 +01:00
from src.schemas import CustomBaseModel
from src.contact.schemas import ContactModel
from src.user.schemas import UserIDMixin
2026-04-06 12:41:49 +01:00
from src.organisation.constants import Status, ContactType
2026-04-06 12:41:49 +01:00
2026-06-03 09:38:54 +01:00
class OrgIDMixin(CustomBaseModel):
organisation_id: int = Field(gt=0)
2026-05-28 13:28:14 +01:00
class Questionnaire(CustomBaseModel):
2026-05-29 09:44:24 +01:00
question_one: Optional[str] = None
question_two: Optional[str] = None
question_three: Optional[str] = None
2026-06-03 09:38:54 +01:00
class OrgSchema(CustomBaseModel):
id: int
name: str
class OrgPostOrgRequest(CustomBaseModel):
2026-04-06 12:41:49 +01:00
name: str
2026-05-28 13:28:14 +01:00
intake_questionnaire: Optional[Questionnaire] = None
2026-04-06 12:41:49 +01:00
2026-05-29 09:44:24 +01:00
class OrgPostOrgResponse(CustomBaseModel):
name: str
status: Status
class OrgPatchQuestionnaireRequest(OrgIDMixin):
2026-05-28 13:28:14 +01:00
intake_questionnaire: Questionnaire
2026-04-06 12:41:49 +01:00
partial: bool
2026-05-29 09:44:24 +01:00
class OrgPatchQuestionnaireResponse(CustomBaseModel):
name: str
intake_questionnaire: Questionnaire
status: Status
class OrgPatchStatusRequest(OrgIDMixin):
2026-04-06 12:41:49 +01:00
status: Status
2026-05-29 09:44:24 +01:00
class OrgPatchStatusResponse(CustomBaseModel):
name: str
status: Status
class OrgPatchContactRequest(OrgIDMixin):
contact_type: ContactType
email: Optional[EmailStr] = None
first_name: Optional[str] = None
last_name: Optional[str] = None
phonenumber: Optional[str] = None
vat_number: Optional[str] = None
post_office_box_number: Optional[str] = None
street_address: Optional[str] = None
street_address_line_2: Optional[str] = None
locality: Optional[str] = None
address_region: Optional[str] = None
country_code: Optional[str] = None
postal_code: Optional[str] = None
2026-04-06 12:41:49 +01:00
class OrgPostUserRequest(OrgIDMixin, UserIDMixin):
pass
2026-04-06 12:41:49 +01:00
2026-05-29 09:44:24 +01:00
class OrgPostUserResponse(CustomBaseModel):
users: list[str]
class OrgDeleteUserRequest(OrgIDMixin, UserIDMixin):
pass
class OrgPatchRootRequest(OrgIDMixin, UserIDMixin):
pass
2026-04-06 12:41:49 +01:00
2026-05-29 09:44:24 +01:00
class OrgPatchRootResponse(CustomBaseModel):
name: str
root_user_email: str
class OrgGetUserResponse(CustomBaseModel):
users: list[str]
2026-06-03 09:38:54 +01:00
organisation: OrgSchema
class OrgGetGroupResponse(CustomBaseModel):
groups: list[str]
class OrgGetContactResponse(CustomBaseModel):
model_config = ConfigDict(from_attributes=True, extra="ignore")
contact: ContactModel
organisation: OrgSchema
class OrgPatchContactResponse(CustomBaseModel):
model_config = ConfigDict(from_attributes=True, extra="ignore")
contact: ContactModel
organisation: OrgSchema
class OrgGetOrgResponse(CustomBaseModel):
2026-06-08 14:16:45 +01:00
id: int
2026-04-06 12:41:49 +01:00
name: str
status: Status
root_user: Optional[str] = None
owner_contact: Optional[str] = None
billing_contact: Optional[str] = None
security_contact: Optional[str] = None
intake_questionnaire: Optional[Questionnaire] = None
class OrgDeleteOrgRequest(OrgIDMixin):
pass