diff --git a/oas/gen_pydantic.sh b/oas/gen_pydantic.sh new file mode 100755 index 00000000..c90d8692 --- /dev/null +++ b/oas/gen_pydantic.sh @@ -0,0 +1,7 @@ +#!/bin/bash + +python oas_to_pydantic.py 2.0/sources.yaml pydantic/sources.py +python oas_to_pydantic.py 2.0/complaints.yaml pydantic/complaints.py +python oas_to_pydantic.py 2.0/officers.yaml pydantic/officers.py +python oas_to_pydantic.py 2.0/agencies.yaml pydantic/agencies.py +python oas_to_pydantic.py 2.0/litigation.yaml pydantic/litigation.py \ No newline at end of file diff --git a/oas/pydantic/agencies.py b/oas/pydantic/agencies.py index ddaaf207..b13867ff 100644 --- a/oas/pydantic/agencies.py +++ b/oas/pydantic/agencies.py @@ -3,7 +3,6 @@ class BaseAgency(BaseModel): - uid: Optional[str] = Field(None, description="Unique identifier for the agency") name: Optional[str] = Field(None, description="Name of the agency") hq_address: Optional[str] = Field(None, description="Address of the agency") hq_city: Optional[str] = Field(None, description="City of the agency") @@ -16,7 +15,6 @@ class BaseAgency(BaseModel): class CreateAgency(BaseAgency, BaseModel): - uid: Optional[str] = Field(None, description="Unique identifier for the agency") name: Optional[str] = Field(None, description="Name of the agency") hq_address: Optional[str] = Field(None, description="Address of the agency") hq_city: Optional[str] = Field(None, description="City of the agency") @@ -29,7 +27,6 @@ class CreateAgency(BaseAgency, BaseModel): class UpdateAgency(BaseAgency, BaseModel): - uid: Optional[str] = Field(None, description="Unique identifier for the agency") name: Optional[str] = Field(None, description="Name of the agency") hq_address: Optional[str] = Field(None, description="Address of the agency") hq_city: Optional[str] = Field(None, description="City of the agency") @@ -46,7 +43,6 @@ class AgencyList(PaginatedResponse, BaseModel): class Agency(BaseAgency, BaseModel): - uid: Optional[str] = Field(None, description="Unique identifier for the agency") name: Optional[str] = Field(None, description="Name of the agency") hq_address: Optional[str] = Field(None, description="Address of the agency") hq_city: Optional[str] = Field(None, description="City of the agency") @@ -56,6 +52,7 @@ class Agency(BaseAgency, BaseModel): phone: Optional[str] = Field(None, description="Phone number of the agency") email: Optional[str] = Field(None, description="Email of the agency") website_url: Optional[str] = Field(None, description="Website of the agency") + uid: Optional[str] = Field(None, description="Unique identifier for the agency") officers_url: Optional[str] = Field(None, description="URL to get a list of officers for this agency") units_url: Optional[str] = Field(None, description="URL to get a list of units for this agency") diff --git a/oas/pydantic/complaints.py b/oas/pydantic/complaints.py index af44d2bd..8f96120a 100644 --- a/oas/pydantic/complaints.py +++ b/oas/pydantic/complaints.py @@ -4,10 +4,11 @@ class BaseComplaint(BaseModel): """Base complaint object""" + record_id: Optional[str] = Field(None, description="The ID that was given to this complaint by the orginal source of the data.") source_details: Optional[SourceDetails] = None category: Optional[str] = Field(None, description="The category of the complaint.") incident_date: Optional[str] = Field(None, description="The date and time the incident occurred.") - recieved_date: Optional[str] = Field(None, description="The date and time the complaint was received by the reporting partner.") + recieved_date: Optional[str] = Field(None, description="The date and time the complaint was received by the reporting source.") closed_date: Optional[str] = Field(None, description="The date and time the complaint was closed.") location: Optional[Dict[str, Any]] = None reason_for_contact: Optional[str] = Field(None, description="The reason for the contact.") @@ -17,17 +18,18 @@ class BaseComplaint(BaseModel): class CreateComplaint(BaseComplaint, BaseModel): + record_id: Optional[str] = Field(None, description="The ID that was given to this complaint by the orginal source of the data.") source_details: Optional[SourceDetails] = None category: Optional[str] = Field(None, description="The category of the complaint.") incident_date: Optional[str] = Field(None, description="The date and time the incident occurred.") - recieved_date: Optional[str] = Field(None, description="The date and time the complaint was received by the reporting partner.") + recieved_date: Optional[str] = Field(None, description="The date and time the complaint was received by the reporting source.") closed_date: Optional[str] = Field(None, description="The date and time the complaint was closed.") location: Optional[Dict[str, Any]] = None reason_for_contact: Optional[str] = Field(None, description="The reason for the contact.") outcome_of_contact: Optional[str] = Field(None, description="The outcome of the contact.") civilian_witnesses: Optional[List[Civilian]] = Field(None, description="The civilian witnesses associated with the complaint.") attachements: Optional[List[Attachemnts]] = Field(None, description="Documents and multimeida associated with the complaint.") - source_uid: Optional[str] = Field(None, description="The UID of the partner that reported the complaint.") + source_uid: Optional[str] = Field(None, description="The UID of the source that reported the complaint.") civilian_review_board_uid: Optional[str] = Field(None, description="The UID of the civilian review board that reviewed the complaint.") police_witnesses: Optional[List[str]] = Field(None, description="The UID of any police witnesses associated with the complaint.") allegations: Optional[List[CreateAllegation]] = Field(None, description="The allegations associated with the complaint.") @@ -36,10 +38,11 @@ class CreateComplaint(BaseComplaint, BaseModel): class UpdateComplaint(BaseComplaint, BaseModel): + record_id: Optional[str] = Field(None, description="The ID that was given to this complaint by the orginal source of the data.") source_details: Optional[SourceDetails] = None category: Optional[str] = Field(None, description="The category of the complaint.") incident_date: Optional[str] = Field(None, description="The date and time the incident occurred.") - recieved_date: Optional[str] = Field(None, description="The date and time the complaint was received by the reporting partner.") + recieved_date: Optional[str] = Field(None, description="The date and time the complaint was received by the reporting source.") closed_date: Optional[str] = Field(None, description="The date and time the complaint was closed.") location: Optional[Dict[str, Any]] = None reason_for_contact: Optional[str] = Field(None, description="The reason for the contact.") @@ -54,10 +57,11 @@ class UpdateComplaint(BaseComplaint, BaseModel): class Complaint(BaseComplaint, BaseModel): + record_id: Optional[str] = Field(None, description="The ID that was given to this complaint by the orginal source of the data.") source_details: Optional[SourceDetails] = None category: str = Field(..., description="The category of the complaint.") incident_date: str = Field(..., description="The date and time the incident occurred.") - recieved_date: str = Field(..., description="The date and time the complaint was received by the reporting partner.") + recieved_date: str = Field(..., description="The date and time the complaint was received by the reporting source.") closed_date: Optional[str] = Field(None, description="The date and time the complaint was closed.") location: Dict[str, Any] = ... reason_for_contact: Optional[str] = Field(None, description="The reason for the contact.") @@ -67,7 +71,7 @@ class Complaint(BaseComplaint, BaseModel): uid: str = Field(..., description="Unique identifier for the complaint.") created_at: str = Field(..., description="Date and time the complaint was created.") updated_at: str = Field(..., description="Date and time the complaint was last updated.") - source: Optional[Partner] = Field(None, description="The partner that reported the complaint.") + source: Optional[Source] = Field(None, description="The source that reported the complaint.") civilian_review_board: Optional[ReviewBoard] = Field(None, description="The civilian review board that reviewed the complaint.") police_witnesses: List[Officer] = Field(..., description="The police witnesses associated with the complaint.") allegations: List[Allegation] = Field(..., description="The allegations associated with the complaint.") @@ -80,8 +84,11 @@ class ComplaintList(PaginatedResponse, BaseModel): class BaseAllegation(BaseModel): + record_id: Optional[str] = Field(None, description="The ID that was given to this allegation by the orginal source of the data.") complaintant: Optional[Civilian] = Field(None, description="Demographic information of the individual who filed the complaint.") allegation: Optional[str] = Field(None, description="The allegation made by the complaintant.") + type: Optional[str] = Field(None, description="The type of allegation.") + sub_type: Optional[str] = Field(None, description="The sub type of the allegation.") recomended_finding: Optional[str] = Field(None, description="The finding recomended by the review board.") recomended_outcome: Optional[str] = Field(None, description="The outcome recomended by the review board.") finding: Optional[str] = Field(None, description="The legal finding.") @@ -89,8 +96,11 @@ class BaseAllegation(BaseModel): class CreateAllegation(BaseAllegation, BaseModel): + record_id: Optional[str] = Field(None, description="The ID that was given to this allegation by the orginal source of the data.") complaintant: Optional[Civilian] = Field(None, description="Demographic information of the individual who filed the complaint.") allegation: Optional[str] = Field(None, description="The allegation made by the complaintant.") + type: Optional[str] = Field(None, description="The type of allegation.") + sub_type: Optional[str] = Field(None, description="The sub type of the allegation.") recomended_finding: Optional[str] = Field(None, description="The finding recomended by the review board.") recomended_outcome: Optional[str] = Field(None, description="The outcome recomended by the review board.") finding: Optional[str] = Field(None, description="The legal finding.") @@ -99,8 +109,11 @@ class CreateAllegation(BaseAllegation, BaseModel): class Allegation(BaseAllegation, BaseModel): + record_id: Optional[str] = Field(None, description="The ID that was given to this allegation by the orginal source of the data.") complaintant: Optional[Civilian] = Field(None, description="Demographic information of the individual who filed the complaint.") allegation: Optional[str] = Field(None, description="The allegation made by the complaintant.") + type: Optional[str] = Field(None, description="The type of allegation.") + sub_type: Optional[str] = Field(None, description="The sub type of the allegation.") recomended_finding: Optional[str] = Field(None, description="The finding recomended by the review board.") recomended_outcome: Optional[str] = Field(None, description="The outcome recomended by the review board.") finding: Optional[str] = Field(None, description="The legal finding.") diff --git a/oas/pydantic/officers.py b/oas/pydantic/officers.py index 94f68904..1780acc7 100644 --- a/oas/pydantic/officers.py +++ b/oas/pydantic/officers.py @@ -6,8 +6,8 @@ class BaseEmployment(BaseModel): officer_uid: Optional[str] = Field(None, description="The UID of the officer.") agency_uid: Optional[str] = Field(None, description="The UID of the agency the officer is employed by.") unit_uid: Optional[str] = Field(None, description="The UID of the unit the officer is assigned to.") - earliest_employment: Optional[str] = Field(None, description="The earliest date of employment") - latest_employment: Optional[str] = Field(None, description="The latest date of employment") + earliest_employment: Optional[str] = Field(None, description="The earliest known date of employment") + latest_employment: Optional[str] = Field(None, description="The latest known date of employment") badge_number: Optional[str] = Field(None, description="The badge number of the officer") highest_rank: Optional[str] = Field(None, description="The highest rank the officer has held during this employment.") commander: Optional[bool] = Field(None, description="Indicates that the officer commanded the unit during this employment.") @@ -17,8 +17,8 @@ class AddEmployment(BaseEmployment, BaseModel): officer_uid: Optional[str] = Field(None, description="The UID of the officer.") agency_uid: Optional[str] = Field(None, description="The UID of the agency the officer is employed by.") unit_uid: Optional[str] = Field(None, description="The UID of the unit the officer is assigned to.") - earliest_employment: Optional[str] = Field(None, description="The earliest date of employment") - latest_employment: Optional[str] = Field(None, description="The latest date of employment") + earliest_employment: Optional[str] = Field(None, description="The earliest known date of employment") + latest_employment: Optional[str] = Field(None, description="The latest known date of employment") badge_number: Optional[str] = Field(None, description="The badge number of the officer") highest_rank: Optional[str] = Field(None, description="The highest rank the officer has held during this employment.") commander: Optional[bool] = Field(None, description="Indicates that the officer commanded the unit during this employment.") @@ -37,8 +37,8 @@ class Employment(BaseEmployment, BaseModel): officer_uid: Optional[str] = Field(None, description="The UID of the officer.") agency_uid: Optional[str] = Field(None, description="The UID of the agency the officer is employed by.") unit_uid: Optional[str] = Field(None, description="The UID of the unit the officer is assigned to.") - earliest_employment: Optional[str] = Field(None, description="The earliest date of employment") - latest_employment: Optional[str] = Field(None, description="The latest date of employment") + earliest_employment: Optional[str] = Field(None, description="The earliest known date of employment") + latest_employment: Optional[str] = Field(None, description="The latest known date of employment") badge_number: Optional[str] = Field(None, description="The badge number of the officer") highest_rank: Optional[str] = Field(None, description="The highest rank the officer has held during this employment.") commander: Optional[bool] = Field(None, description="Indicates that the officer commanded the unit during this employment.") @@ -59,6 +59,7 @@ class BaseOfficer(BaseModel): first_name: Optional[str] = Field(None, description="First name of the officer") middle_name: Optional[str] = Field(None, description="Middle name of the officer") last_name: Optional[str] = Field(None, description="Last name of the officer") + suffix: Optional[str] = Field(None, description="Suffix of the officer's name") ethnicity: Optional[str] = Field(None, description="The ethnicity of the officer") gender: Optional[str] = Field(None, description="The gender of the officer") date_of_birth: Optional[str] = Field(None, description="The date of birth of the officer") @@ -69,6 +70,7 @@ class CreateOfficer(BaseOfficer, BaseModel): first_name: Optional[str] = Field(None, description="First name of the officer") middle_name: Optional[str] = Field(None, description="Middle name of the officer") last_name: Optional[str] = Field(None, description="Last name of the officer") + suffix: Optional[str] = Field(None, description="Suffix of the officer's name") ethnicity: Optional[str] = Field(None, description="The ethnicity of the officer") gender: Optional[str] = Field(None, description="The gender of the officer") date_of_birth: Optional[str] = Field(None, description="The date of birth of the officer") @@ -79,6 +81,7 @@ class UpdateOfficer(BaseOfficer, BaseModel): first_name: Optional[str] = Field(None, description="First name of the officer") middle_name: Optional[str] = Field(None, description="Middle name of the officer") last_name: Optional[str] = Field(None, description="Last name of the officer") + suffix: Optional[str] = Field(None, description="Suffix of the officer's name") ethnicity: Optional[str] = Field(None, description="The ethnicity of the officer") gender: Optional[str] = Field(None, description="The gender of the officer") date_of_birth: Optional[str] = Field(None, description="The date of birth of the officer") @@ -89,6 +92,7 @@ class Officer(BaseOfficer, BaseModel): first_name: Optional[str] = Field(None, description="First name of the officer") middle_name: Optional[str] = Field(None, description="Middle name of the officer") last_name: Optional[str] = Field(None, description="Last name of the officer") + suffix: Optional[str] = Field(None, description="Suffix of the officer's name") ethnicity: Optional[str] = Field(None, description="The ethnicity of the officer") gender: Optional[str] = Field(None, description="The gender of the officer") date_of_birth: Optional[str] = Field(None, description="The date of birth of the officer") diff --git a/oas/pydantic/sources.py b/oas/pydantic/sources.py new file mode 100644 index 00000000..22cc96c8 --- /dev/null +++ b/oas/pydantic/sources.py @@ -0,0 +1,62 @@ +from pydantic import BaseModel, Field +from typing import List, Optional, Dict, Any, Union + + +class BasePartner(BaseModel): + name: Optional[str] = Field(None, description="Name of the source organization.") + url: Optional[str] = Field(None, description="Website URL of the source.") + contact_email: Optional[str] = Field(None, description="Contact email for the source organization.") + + +class CreatePartner(BasePartner, BaseModel): + name: Optional[str] = Field(None, description="Name of the source organization.") + url: Optional[str] = Field(None, description="Website URL of the source.") + contact_email: Optional[str] = Field(None, description="Contact email for the source organization.") + + +class UpdatePartner(BasePartner, BaseModel): + name: Optional[str] = Field(None, description="Name of the source organization.") + url: Optional[str] = Field(None, description="Website URL of the source.") + contact_email: Optional[str] = Field(None, description="Contact email for the source organization.") + + +class Source(BasePartner, BaseModel): + name: Optional[str] = Field(None, description="Name of the source organization.") + url: Optional[str] = Field(None, description="Website URL of the source.") + contact_email: Optional[str] = Field(None, description="Contact email for the source organization.") + uid: Optional[str] = Field(None, description="Unique identifier for the source.") + members: Optional[str] = Field(None, description="Url to get all members of the source.") + reported_complaints: Optional[str] = Field(None, description="Url to get all complaints reported by the source.") + + +class PartnerList(PaginatedResponse, BaseModel): + results: Optional[List[Source]] = None + + +class MemberBase(BaseModel): + source_uid: Optional[str] = Field(None, description="Unique identifier for the source.") + user_uid: Optional[str] = Field(None, description="Unique identifier for the user.") + role: Optional[str] = Field(None, description="Role of the user.") + is_active: Optional[bool] = Field(None, description="Whether the user is active.") + + +class Member(MemberBase, BaseModel): + source_uid: Optional[str] = Field(None, description="Unique identifier for the source.") + user_uid: Optional[str] = Field(None, description="Unique identifier for the user.") + role: Optional[str] = Field(None, description="Role of the user.") + is_active: Optional[bool] = Field(None, description="Whether the user is active.") + uid: Optional[str] = Field(None, description="Unique identifier for the user.") + date_joined: Optional[str] = Field(None, description="Date the user joined the source organizaation.") + + +class AddMember(MemberBase, BaseModel): + source_uid: Optional[str] = Field(None, description="Unique identifier for the source.") + user_uid: Optional[str] = Field(None, description="Unique identifier for the user.") + role: Optional[str] = Field(None, description="Role of the user.") + is_active: Optional[bool] = Field(None, description="Whether the user is active.") + + +class MemberList(PaginatedResponse, BaseModel): + results: Optional[List[Member]] = None + +