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.
Files changed (68) hide show
  1. permitstack/__init__.py +17 -0
  2. permitstack/_hooks/__init__.py +4 -0
  3. permitstack/_hooks/sdkhooks.py +74 -0
  4. permitstack/_hooks/types.py +112 -0
  5. permitstack/_version.py +15 -0
  6. permitstack/basesdk.py +396 -0
  7. permitstack/bulk_export.py +241 -0
  8. permitstack/contractors.py +625 -0
  9. permitstack/errors/__init__.py +39 -0
  10. permitstack/errors/httpvalidationerror.py +28 -0
  11. permitstack/errors/no_response_error.py +17 -0
  12. permitstack/errors/permitstackdefaulterror.py +40 -0
  13. permitstack/errors/permitstackerror.py +30 -0
  14. permitstack/errors/responsevalidationerror.py +27 -0
  15. permitstack/health.py +171 -0
  16. permitstack/httpclient.py +125 -0
  17. permitstack/models/__init__.py +158 -0
  18. permitstack/models/contractorprofile.py +108 -0
  19. permitstack/models/contractorsearchresponse.py +24 -0
  20. permitstack/models/contractorsummary.py +57 -0
  21. permitstack/models/delete_webhookop.py +16 -0
  22. permitstack/models/export_permits_csvop.py +98 -0
  23. permitstack/models/get_contractor_permitsop.py +46 -0
  24. permitstack/models/get_contractorop.py +16 -0
  25. permitstack/models/get_permitop.py +16 -0
  26. permitstack/models/get_permits_by_addressop.py +46 -0
  27. permitstack/models/get_property_historyop.py +18 -0
  28. permitstack/models/permitcategory.py +27 -0
  29. permitstack/models/permitdetail.py +164 -0
  30. permitstack/models/permitsearchresponse.py +24 -0
  31. permitstack/models/permitstatus.py +16 -0
  32. permitstack/models/permitsummary.py +121 -0
  33. permitstack/models/propertytype.py +14 -0
  34. permitstack/models/search_contractorsop.py +98 -0
  35. permitstack/models/search_permitsop.py +247 -0
  36. permitstack/models/security.py +42 -0
  37. permitstack/models/validationerror.py +57 -0
  38. permitstack/models/webhookcreate.py +60 -0
  39. permitstack/permits.py +866 -0
  40. permitstack/property_history.py +207 -0
  41. permitstack/py.typed +1 -0
  42. permitstack/sdk.py +218 -0
  43. permitstack/sdkconfiguration.py +49 -0
  44. permitstack/types/__init__.py +21 -0
  45. permitstack/types/basemodel.py +77 -0
  46. permitstack/utils/__init__.py +178 -0
  47. permitstack/utils/annotations.py +79 -0
  48. permitstack/utils/datetimes.py +23 -0
  49. permitstack/utils/dynamic_imports.py +54 -0
  50. permitstack/utils/enums.py +134 -0
  51. permitstack/utils/eventstreaming.py +309 -0
  52. permitstack/utils/forms.py +234 -0
  53. permitstack/utils/headers.py +136 -0
  54. permitstack/utils/logger.py +27 -0
  55. permitstack/utils/metadata.py +119 -0
  56. permitstack/utils/queryparams.py +217 -0
  57. permitstack/utils/requestbodies.py +66 -0
  58. permitstack/utils/retries.py +271 -0
  59. permitstack/utils/security.py +215 -0
  60. permitstack/utils/serializers.py +225 -0
  61. permitstack/utils/unmarshal_json_response.py +38 -0
  62. permitstack/utils/url.py +155 -0
  63. permitstack/utils/values.py +137 -0
  64. permitstack/webhooks.py +593 -0
  65. permitstack-1.0.0.dist-info/METADATA +541 -0
  66. permitstack-1.0.0.dist-info/RECORD +68 -0
  67. permitstack-1.0.0.dist-info/WHEEL +5 -0
  68. 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)