permitstack 1.0.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- permitstack/__init__.py +17 -0
- permitstack/_hooks/__init__.py +4 -0
- permitstack/_hooks/sdkhooks.py +74 -0
- permitstack/_hooks/types.py +112 -0
- permitstack/_version.py +15 -0
- permitstack/basesdk.py +396 -0
- permitstack/bulk_export.py +241 -0
- permitstack/contractors.py +625 -0
- permitstack/errors/__init__.py +39 -0
- permitstack/errors/httpvalidationerror.py +28 -0
- permitstack/errors/no_response_error.py +17 -0
- permitstack/errors/permitstackdefaulterror.py +40 -0
- permitstack/errors/permitstackerror.py +30 -0
- permitstack/errors/responsevalidationerror.py +27 -0
- permitstack/health.py +171 -0
- permitstack/httpclient.py +125 -0
- permitstack/models/__init__.py +158 -0
- permitstack/models/contractorprofile.py +108 -0
- permitstack/models/contractorsearchresponse.py +24 -0
- permitstack/models/contractorsummary.py +57 -0
- permitstack/models/delete_webhookop.py +16 -0
- permitstack/models/export_permits_csvop.py +98 -0
- permitstack/models/get_contractor_permitsop.py +46 -0
- permitstack/models/get_contractorop.py +16 -0
- permitstack/models/get_permitop.py +16 -0
- permitstack/models/get_permits_by_addressop.py +46 -0
- permitstack/models/get_property_historyop.py +18 -0
- permitstack/models/permitcategory.py +27 -0
- permitstack/models/permitdetail.py +164 -0
- permitstack/models/permitsearchresponse.py +24 -0
- permitstack/models/permitstatus.py +16 -0
- permitstack/models/permitsummary.py +121 -0
- permitstack/models/propertytype.py +14 -0
- permitstack/models/search_contractorsop.py +98 -0
- permitstack/models/search_permitsop.py +247 -0
- permitstack/models/security.py +42 -0
- permitstack/models/validationerror.py +57 -0
- permitstack/models/webhookcreate.py +60 -0
- permitstack/permits.py +866 -0
- permitstack/property_history.py +207 -0
- permitstack/py.typed +1 -0
- permitstack/sdk.py +218 -0
- permitstack/sdkconfiguration.py +49 -0
- permitstack/types/__init__.py +21 -0
- permitstack/types/basemodel.py +77 -0
- permitstack/utils/__init__.py +178 -0
- permitstack/utils/annotations.py +79 -0
- permitstack/utils/datetimes.py +23 -0
- permitstack/utils/dynamic_imports.py +54 -0
- permitstack/utils/enums.py +134 -0
- permitstack/utils/eventstreaming.py +309 -0
- permitstack/utils/forms.py +234 -0
- permitstack/utils/headers.py +136 -0
- permitstack/utils/logger.py +27 -0
- permitstack/utils/metadata.py +119 -0
- permitstack/utils/queryparams.py +217 -0
- permitstack/utils/requestbodies.py +66 -0
- permitstack/utils/retries.py +271 -0
- permitstack/utils/security.py +215 -0
- permitstack/utils/serializers.py +225 -0
- permitstack/utils/unmarshal_json_response.py +38 -0
- permitstack/utils/url.py +155 -0
- permitstack/utils/values.py +137 -0
- permitstack/webhooks.py +593 -0
- permitstack-1.0.0.dist-info/METADATA +541 -0
- permitstack-1.0.0.dist-info/RECORD +68 -0
- permitstack-1.0.0.dist-info/WHEEL +5 -0
- permitstack-1.0.0.dist-info/top_level.txt +1 -0
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"""Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
|
|
2
|
+
|
|
3
|
+
from datetime import datetime
|
|
4
|
+
from enum import Enum
|
|
5
|
+
from email.message import Message
|
|
6
|
+
from functools import partial
|
|
7
|
+
import os
|
|
8
|
+
from typing import Any, Callable, Dict, List, Optional, Tuple, TypeVar, Union, cast
|
|
9
|
+
|
|
10
|
+
from httpx import Response
|
|
11
|
+
from pydantic import BaseModel
|
|
12
|
+
from pydantic.fields import FieldInfo
|
|
13
|
+
|
|
14
|
+
from ..types.basemodel import Unset
|
|
15
|
+
|
|
16
|
+
from .serializers import marshal_json
|
|
17
|
+
|
|
18
|
+
from .metadata import ParamMetadata, find_field_metadata
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
def match_content_type(content_type: str, pattern: str) -> bool:
|
|
22
|
+
if pattern in (content_type, "*", "*/*"):
|
|
23
|
+
return True
|
|
24
|
+
|
|
25
|
+
msg = Message()
|
|
26
|
+
msg["content-type"] = content_type
|
|
27
|
+
media_type = msg.get_content_type()
|
|
28
|
+
|
|
29
|
+
if media_type == pattern:
|
|
30
|
+
return True
|
|
31
|
+
|
|
32
|
+
parts = media_type.split("/")
|
|
33
|
+
if len(parts) == 2:
|
|
34
|
+
if pattern in (f"{parts[0]}/*", f"*/{parts[1]}"):
|
|
35
|
+
return True
|
|
36
|
+
|
|
37
|
+
return False
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
def match_status_codes(status_codes: List[str], status_code: int) -> bool:
|
|
41
|
+
if "default" in status_codes:
|
|
42
|
+
return True
|
|
43
|
+
|
|
44
|
+
for code in status_codes:
|
|
45
|
+
if code == str(status_code):
|
|
46
|
+
return True
|
|
47
|
+
|
|
48
|
+
if code.endswith("XX") and code.startswith(str(status_code)[:1]):
|
|
49
|
+
return True
|
|
50
|
+
return False
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
T = TypeVar("T")
|
|
54
|
+
|
|
55
|
+
def cast_partial(typ):
|
|
56
|
+
return partial(cast, typ)
|
|
57
|
+
|
|
58
|
+
def get_global_from_env(
|
|
59
|
+
value: Optional[T], env_key: str, type_cast: Callable[[str], T]
|
|
60
|
+
) -> Optional[T]:
|
|
61
|
+
if value is not None:
|
|
62
|
+
return value
|
|
63
|
+
env_value = os.getenv(env_key)
|
|
64
|
+
if env_value is not None:
|
|
65
|
+
try:
|
|
66
|
+
return type_cast(env_value)
|
|
67
|
+
except ValueError:
|
|
68
|
+
pass
|
|
69
|
+
return None
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
def match_response(
|
|
73
|
+
response: Response, code: Union[str, List[str]], content_type: str
|
|
74
|
+
) -> bool:
|
|
75
|
+
codes = code if isinstance(code, list) else [code]
|
|
76
|
+
return match_status_codes(codes, response.status_code) and match_content_type(
|
|
77
|
+
response.headers.get("content-type", "application/octet-stream"), content_type
|
|
78
|
+
)
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
def _populate_from_globals(
|
|
82
|
+
param_name: str, value: Any, param_metadata_type: type, gbls: Any
|
|
83
|
+
) -> Tuple[Any, bool]:
|
|
84
|
+
if gbls is None:
|
|
85
|
+
return value, False
|
|
86
|
+
|
|
87
|
+
if not isinstance(gbls, BaseModel):
|
|
88
|
+
raise TypeError("globals must be a pydantic model")
|
|
89
|
+
|
|
90
|
+
global_fields: Dict[str, FieldInfo] = gbls.__class__.model_fields
|
|
91
|
+
found = False
|
|
92
|
+
for name in global_fields:
|
|
93
|
+
field = global_fields[name]
|
|
94
|
+
if name is not param_name:
|
|
95
|
+
continue
|
|
96
|
+
|
|
97
|
+
found = True
|
|
98
|
+
|
|
99
|
+
if value is not None:
|
|
100
|
+
return value, True
|
|
101
|
+
|
|
102
|
+
global_value = getattr(gbls, name)
|
|
103
|
+
|
|
104
|
+
param_metadata = find_field_metadata(field, param_metadata_type)
|
|
105
|
+
if param_metadata is None:
|
|
106
|
+
return value, True
|
|
107
|
+
|
|
108
|
+
return global_value, True
|
|
109
|
+
|
|
110
|
+
return value, found
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
def _val_to_string(val) -> str:
|
|
114
|
+
if isinstance(val, bool):
|
|
115
|
+
return str(val).lower()
|
|
116
|
+
if isinstance(val, datetime):
|
|
117
|
+
return str(val.isoformat().replace("+00:00", "Z"))
|
|
118
|
+
if isinstance(val, Enum):
|
|
119
|
+
return str(val.value)
|
|
120
|
+
|
|
121
|
+
return str(val)
|
|
122
|
+
|
|
123
|
+
|
|
124
|
+
def _get_serialized_params(
|
|
125
|
+
metadata: ParamMetadata, field_name: str, obj: Any, typ: type
|
|
126
|
+
) -> Dict[str, str]:
|
|
127
|
+
params: Dict[str, str] = {}
|
|
128
|
+
|
|
129
|
+
serialization = metadata.serialization
|
|
130
|
+
if serialization == "json":
|
|
131
|
+
params[field_name] = marshal_json(obj, typ)
|
|
132
|
+
|
|
133
|
+
return params
|
|
134
|
+
|
|
135
|
+
|
|
136
|
+
def _is_set(value: Any) -> bool:
|
|
137
|
+
return value is not None and not isinstance(value, Unset)
|