-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathadmin_contract_fields.py
More file actions
112 lines (90 loc) · 3.79 KB
/
admin_contract_fields.py
File metadata and controls
112 lines (90 loc) · 3.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
# coding: utf-8
"""
Infrahub-API
No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
The version of the OpenAPI document: 1.0
Generated by OpenAPI Generator (https://openapi-generator.tech)
Do not edit the class manually.
""" # noqa: E501
from __future__ import annotations
import pprint
import re # noqa: F401
import json
from datetime import datetime
from pydantic import BaseModel, ConfigDict, StrictFloat, StrictInt, StrictStr
from typing import Any, ClassVar, Dict, List, Optional, Union
from typing import Optional, Set
from typing_extensions import Self
class AdminContractFields(BaseModel):
"""
AdminContractFields
""" # noqa: E501
id: Optional[StrictInt] = None
org_name: Optional[StrictStr] = None
description: Optional[StrictStr] = None
start_date: Optional[datetime] = None
end_date: Optional[datetime] = None
expiration_policy: Optional[StrictInt] = None
status: Optional[StrictStr] = None
gpu_name: Optional[StrictStr] = None
percent: Optional[Union[StrictFloat, StrictInt]] = None
amount: Optional[Union[StrictFloat, StrictInt]] = None
discount_type: Optional[StrictStr] = None
resource_count: Optional[StrictInt] = None
created_at: Optional[datetime] = None
__properties: ClassVar[List[str]] = ["id", "org_name", "description", "start_date", "end_date", "expiration_policy", "status", "gpu_name", "percent", "amount", "discount_type", "resource_count", "created_at"]
model_config = ConfigDict(
populate_by_name=True,
validate_assignment=True,
protected_namespaces=(),
)
def to_str(self) -> str:
"""Returns the string representation of the model using alias"""
return pprint.pformat(self.model_dump(by_alias=True))
def to_json(self) -> str:
"""Returns the JSON representation of the model using alias"""
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
return json.dumps(self.to_dict())
@classmethod
def from_json(cls, json_str: str) -> Optional[Self]:
"""Create an instance of AdminContractFields from a JSON string"""
return cls.from_dict(json.loads(json_str))
def to_dict(self) -> Dict[str, Any]:
"""Return the dictionary representation of the model using alias.
This has the following differences from calling pydantic's
`self.model_dump(by_alias=True)`:
* `None` is only added to the output dict for nullable fields that
were set at model initialization. Other fields with value `None`
are ignored.
"""
excluded_fields: Set[str] = set([
])
_dict = self.model_dump(
by_alias=True,
exclude=excluded_fields,
exclude_none=True,
)
return _dict
@classmethod
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
"""Create an instance of AdminContractFields from a dict"""
if obj is None:
return None
if not isinstance(obj, dict):
return cls.model_validate(obj)
_obj = cls.model_validate({
"id": obj.get("id"),
"org_name": obj.get("org_name"),
"description": obj.get("description"),
"start_date": obj.get("start_date"),
"end_date": obj.get("end_date"),
"expiration_policy": obj.get("expiration_policy"),
"status": obj.get("status"),
"gpu_name": obj.get("gpu_name"),
"percent": obj.get("percent"),
"amount": obj.get("amount"),
"discount_type": obj.get("discount_type"),
"resource_count": obj.get("resource_count"),
"created_at": obj.get("created_at")
})
return _obj