Coverage for functions \ flipdare \ generated \ model \ internal \ dare_event_model.py: 100%
0 statements
« prev ^ index » next coverage.py v7.13.0, created at 2026-05-08 12:22 +1000
« prev ^ index » next coverage.py v7.13.0, created at 2026-05-08 12:22 +1000
1#!/usr/bin/env python
2#
3# Copyright (c) 2026 Flipdare Pty Ltd. All rights reserved.
4#
5# This file is part of Flipdare's proprietary software and contains
6# confidential and copyrighted material. Unauthorised copying,
7# modification, distribution, or use of this file is strictly
8# prohibited without prior written permission from Flipdare Pty Ltd.
9#
10# This software includes third-party components licensed under MIT,
11# BSD, and Apache 2.0 licences. See THIRD_PARTY_NOTICES for details.
12#
13# NOTE: THIS FILE IS AUTO GENERATED. DO NOT EDIT.
14#
15# Generated by codegen_models.py
16#
17# Modify 'codegen_models.py'
18# and re-run the script above to update.
19#
20# pragma: no cover
21from __future__ import annotations
22from datetime import datetime
23from google.cloud.firestore_v1.transforms import Sentinel
24from flipdare.core.firestore_field import FirestoreField
25from flipdare.util.time_util import FirestoreTime
26from typing import Any, TypedDict, cast, Unpack
27from enum import StrEnum
28from pydantic import Field, ConfigDict, TypeAdapter
29from flipdare.firestore.core.app_base_model import AppBaseModel
30from flipdare.generated.model.internal.video_model import VideoModel, VideoDict
31from flipdare.generated.model.internal.image_model import ImageModel, ImageDict
34class DareEventKeys(StrEnum):
35 UPDATED_AT = "updated_at"
36 CREATED_AT = "created_at"
37 UID = "uid"
38 MESSAGE = "message"
39 IS_ADMIN = "is_admin"
40 VIDEO = "video"
41 IMAGE = "image"
44# !! IMPORTANT !!
45# !!
46# !! this should only be used in the database to query.
47# !!
48class DareEventInternalKeys(StrEnum):
49 UPDATED_AT = "updated_at"
50 CREATED_AT = "created_at"
53class DareEventModel(AppBaseModel):
54 """Internal Dare Event Schema"""
56 model_config = ConfigDict(populate_by_name=True, arbitrary_types_allowed=True)
58 updated_at: FirestoreField = Field(
59 default_factory=cast("Any", lambda: FirestoreTime.server_timestamp())
60 )
61 created_at: FirestoreField = Field(
62 default_factory=cast("Any", lambda: FirestoreTime.server_timestamp())
63 )
64 uid: str
65 message: str
66 is_admin: bool = Field(default=False)
67 video: VideoModel | None = None
68 image: ImageModel | None = None
70 @classmethod
71 def validate_partial(cls, **data: Unpack[DareEventDict]) -> dict[str, Any]:
72 """
73 Uses Unpack to give you autocomplete and static warnings
74 if you pass an invalid key or type in your code.
76 Returns a dict with Firestore field names (aliases) for use with batch.update().
77 """
78 result: dict[str, Any] = {}
79 for k, v in data.items():
80 if k in cls.__pydantic_fields__:
81 field_info = cls.__pydantic_fields__[k]
82 validated_value = cast(
83 "Any",
84 TypeAdapter(field_info.annotation).validate_python(v),
85 )
86 # Use alias if defined, otherwise use field name
87 output_key = field_info.alias or k
88 result[output_key] = validated_value
89 return result
92DAREEVENT_FIELD_NAMES: list[str] = list(DareEventModel.model_fields.keys())
95class DareEventDict(TypedDict, total=False):
96 updated_at: Sentinel | datetime | str
97 created_at: Sentinel | datetime | str
98 uid: str
99 message: str
100 is_admin: bool | None
101 video: VideoDict | None
102 image: ImageDict | None