payi 0.1.0a7__tar.gz → 0.1.0a8__tar.gz
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.
Potentially problematic release.
This version of payi might be problematic. Click here for more details.
- payi-0.1.0a8/.release-please-manifest.json +3 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/CHANGELOG.md +9 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/PKG-INFO +1 -1
- {payi-0.1.0a7 → payi-0.1.0a8}/api.md +9 -1
- {payi-0.1.0a7 → payi-0.1.0a8}/pyproject.toml +1 -1
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_version.py +1 -1
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/__init__.py +3 -0
- payi-0.1.0a8/src/payi/types/budget_response.py +49 -0
- payi-0.1.0a8/src/payi/types/cost_data.py +16 -0
- payi-0.1.0a8/src/payi/types/cost_details.py +13 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/paged_budget_list.py +5 -52
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/proxy_result.py +5 -16
- payi-0.1.0a8/src/payi/types/requests_data.py +21 -0
- payi-0.1.0a7/.release-please-manifest.json +0 -3
- payi-0.1.0a7/src/payi/types/budget_response.py +0 -98
- {payi-0.1.0a7 → payi-0.1.0a8}/.gitignore +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/CONTRIBUTING.md +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/LICENSE +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/README.md +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/SECURITY.md +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/bin/check-release-environment +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/bin/publish-pypi +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/examples/.keep +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/mypy.ini +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/noxfile.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/release-please-config.json +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/requirements-dev.lock +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/requirements.lock +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_base_client.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_client.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_compat.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_constants.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_exceptions.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_files.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_models.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_qs.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_resource.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_streaming.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_types.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_logs.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_proxy.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_reflection.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_streams.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_sync.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_transform.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_typing.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/_utils/_utils.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/lib/.keep +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/lib/helpers.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/py.typed +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/resources/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/resources/budgets/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/resources/budgets/budgets.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/resources/budgets/tags.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/resources/ingest.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budget_create_params.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budget_history_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budget_list_params.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budget_update_params.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/budget_tags.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_create_params.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_create_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_delete_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_list_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_remove_params.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_remove_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_update_params.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/budgets/tag_update_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/default_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/src/payi/types/ingest_units_params.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/api_resources/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/api_resources/budgets/__init__.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/api_resources/budgets/test_tags.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/api_resources/test_budgets.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/api_resources/test_ingest.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/conftest.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/sample_file.txt +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_client.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_deepcopy.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_extract_files.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_files.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_models.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_qs.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_required_args.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_response.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_streaming.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_transform.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_utils/test_proxy.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/test_utils/test_typing.py +0 -0
- {payi-0.1.0a7 → payi-0.1.0a8}/tests/utils.py +0 -0
|
@@ -1,5 +1,14 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## 0.1.0-alpha.8 (2024-07-02)
|
|
4
|
+
|
|
5
|
+
Full Changelog: [v0.1.0-alpha.7...v0.1.0-alpha.8](https://github.com/Pay-i/pay-i-python/compare/v0.1.0-alpha.7...v0.1.0-alpha.8)
|
|
6
|
+
|
|
7
|
+
### Features
|
|
8
|
+
|
|
9
|
+
* **api:** update via SDK Studio ([#28](https://github.com/Pay-i/pay-i-python/issues/28)) ([972e5e3](https://github.com/Pay-i/pay-i-python/commit/972e5e3b8c84df6d3b47ba2dba4137151d9e414c))
|
|
10
|
+
* **api:** update via SDK Studio ([#30](https://github.com/Pay-i/pay-i-python/issues/30)) ([3334f89](https://github.com/Pay-i/pay-i-python/commit/3334f89029ba31d70aa759d367be32888a77b603))
|
|
11
|
+
|
|
3
12
|
## 0.1.0-alpha.7 (2024-07-02)
|
|
4
13
|
|
|
5
14
|
Full Changelog: [v0.1.0-alpha.6...v0.1.0-alpha.7](https://github.com/Pay-i/pay-i-python/compare/v0.1.0-alpha.6...v0.1.0-alpha.7)
|
|
@@ -3,7 +3,15 @@
|
|
|
3
3
|
Types:
|
|
4
4
|
|
|
5
5
|
```python
|
|
6
|
-
from payi.types import
|
|
6
|
+
from payi.types import (
|
|
7
|
+
BudgetHistoryResponse,
|
|
8
|
+
BudgetResponse,
|
|
9
|
+
CostData,
|
|
10
|
+
CostDetails,
|
|
11
|
+
DefaultResponse,
|
|
12
|
+
PagedBudgetList,
|
|
13
|
+
RequestsData,
|
|
14
|
+
)
|
|
7
15
|
```
|
|
8
16
|
|
|
9
17
|
Methods:
|
|
@@ -2,7 +2,10 @@
|
|
|
2
2
|
|
|
3
3
|
from __future__ import annotations
|
|
4
4
|
|
|
5
|
+
from .cost_data import CostData as CostData
|
|
6
|
+
from .cost_details import CostDetails as CostDetails
|
|
5
7
|
from .proxy_result import ProxyResult as ProxyResult
|
|
8
|
+
from .requests_data import RequestsData as RequestsData
|
|
6
9
|
from .budget_response import BudgetResponse as BudgetResponse
|
|
7
10
|
from .default_response import DefaultResponse as DefaultResponse
|
|
8
11
|
from .paged_budget_list import PagedBudgetList as PagedBudgetList
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
from typing import List, Optional
|
|
4
|
+
from datetime import datetime
|
|
5
|
+
from typing_extensions import Literal
|
|
6
|
+
|
|
7
|
+
from .._models import BaseModel
|
|
8
|
+
from .cost_data import CostData
|
|
9
|
+
from .requests_data import RequestsData
|
|
10
|
+
|
|
11
|
+
__all__ = ["BudgetResponse", "Budget", "BudgetTotals"]
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class BudgetTotals(BaseModel):
|
|
15
|
+
cost: Optional[CostData] = None
|
|
16
|
+
|
|
17
|
+
requests: Optional[RequestsData] = None
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
class Budget(BaseModel):
|
|
21
|
+
base_cost_estimate: Literal["Max"]
|
|
22
|
+
|
|
23
|
+
budget_creation_timestamp: datetime
|
|
24
|
+
|
|
25
|
+
budget_id: str
|
|
26
|
+
|
|
27
|
+
budget_name: str
|
|
28
|
+
|
|
29
|
+
budget_response_type: Literal["Block", "Allow"]
|
|
30
|
+
|
|
31
|
+
budget_type: Literal["Conservative", "Liberal"]
|
|
32
|
+
|
|
33
|
+
budget_update_timestamp: datetime
|
|
34
|
+
|
|
35
|
+
currency: str
|
|
36
|
+
|
|
37
|
+
max: float
|
|
38
|
+
|
|
39
|
+
totals: BudgetTotals
|
|
40
|
+
|
|
41
|
+
budget_tags: Optional[List[str]] = None
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
class BudgetResponse(BaseModel):
|
|
45
|
+
budget: Budget
|
|
46
|
+
|
|
47
|
+
request_id: str
|
|
48
|
+
|
|
49
|
+
message: Optional[str] = None
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
from .._models import BaseModel
|
|
6
|
+
from .cost_details import CostDetails
|
|
7
|
+
|
|
8
|
+
__all__ = ["CostData"]
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
class CostData(BaseModel):
|
|
12
|
+
input: CostDetails
|
|
13
|
+
|
|
14
|
+
output: CostDetails
|
|
15
|
+
|
|
16
|
+
total: CostDetails
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
from typing import Optional
|
|
4
|
+
|
|
5
|
+
from .._models import BaseModel
|
|
6
|
+
|
|
7
|
+
__all__ = ["CostDetails"]
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
class CostDetails(BaseModel):
|
|
11
|
+
base: float
|
|
12
|
+
|
|
13
|
+
overrun_base: Optional[float] = None
|
|
@@ -7,63 +7,16 @@ from typing_extensions import Literal
|
|
|
7
7
|
from pydantic import Field as FieldInfo
|
|
8
8
|
|
|
9
9
|
from .._models import BaseModel
|
|
10
|
+
from .cost_data import CostData
|
|
11
|
+
from .requests_data import RequestsData
|
|
10
12
|
|
|
11
|
-
__all__ = [
|
|
12
|
-
"PagedBudgetList",
|
|
13
|
-
"Item",
|
|
14
|
-
"ItemTotals",
|
|
15
|
-
"ItemTotalsCost",
|
|
16
|
-
"ItemTotalsCostInputCost",
|
|
17
|
-
"ItemTotalsCostOutputCost",
|
|
18
|
-
"ItemTotalsCostTotalCost",
|
|
19
|
-
"ItemTotalsRequests",
|
|
20
|
-
]
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
class ItemTotalsCostInputCost(BaseModel):
|
|
24
|
-
base: Optional[float] = None
|
|
25
|
-
|
|
26
|
-
overrun_base: Optional[float] = None
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
class ItemTotalsCostOutputCost(BaseModel):
|
|
30
|
-
base: Optional[float] = None
|
|
31
|
-
|
|
32
|
-
overrun_base: Optional[float] = None
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
class ItemTotalsCostTotalCost(BaseModel):
|
|
36
|
-
base: Optional[float] = None
|
|
37
|
-
|
|
38
|
-
overrun_base: Optional[float] = None
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
class ItemTotalsCost(BaseModel):
|
|
42
|
-
input_cost: Optional[ItemTotalsCostInputCost] = FieldInfo(alias="inputCost", default=None)
|
|
43
|
-
|
|
44
|
-
output_cost: Optional[ItemTotalsCostOutputCost] = FieldInfo(alias="outputCost", default=None)
|
|
45
|
-
|
|
46
|
-
total_cost: Optional[ItemTotalsCostTotalCost] = FieldInfo(alias="totalCost", default=None)
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
class ItemTotalsRequests(BaseModel):
|
|
50
|
-
blocked: Optional[int] = None
|
|
51
|
-
|
|
52
|
-
error: Optional[int] = None
|
|
53
|
-
|
|
54
|
-
exceeded: Optional[int] = None
|
|
55
|
-
|
|
56
|
-
failed: Optional[int] = None
|
|
57
|
-
|
|
58
|
-
successful: Optional[int] = None
|
|
59
|
-
|
|
60
|
-
total: Optional[int] = None
|
|
13
|
+
__all__ = ["PagedBudgetList", "Item", "ItemTotals"]
|
|
61
14
|
|
|
62
15
|
|
|
63
16
|
class ItemTotals(BaseModel):
|
|
64
|
-
cost: Optional[
|
|
17
|
+
cost: Optional[CostData] = None
|
|
65
18
|
|
|
66
|
-
requests: Optional[
|
|
19
|
+
requests: Optional[RequestsData] = None
|
|
67
20
|
|
|
68
21
|
|
|
69
22
|
class Item(BaseModel):
|
|
@@ -3,34 +3,23 @@
|
|
|
3
3
|
from typing import Dict, List, Optional
|
|
4
4
|
|
|
5
5
|
from .._models import BaseModel
|
|
6
|
+
from .cost_details import CostDetails
|
|
6
7
|
|
|
7
|
-
__all__ = ["ProxyResult", "Budgets", "Cost"
|
|
8
|
+
__all__ = ["ProxyResult", "Budgets", "Cost"]
|
|
8
9
|
|
|
9
10
|
|
|
10
11
|
class Budgets(BaseModel):
|
|
11
12
|
state: Optional[str] = None
|
|
12
13
|
|
|
13
14
|
|
|
14
|
-
class CostInput(BaseModel):
|
|
15
|
-
base: Optional[float] = None
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
class CostOutput(BaseModel):
|
|
19
|
-
base: Optional[float] = None
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
class CostTotal(BaseModel):
|
|
23
|
-
base: Optional[float] = None
|
|
24
|
-
|
|
25
|
-
|
|
26
15
|
class Cost(BaseModel):
|
|
27
16
|
currency: Optional[str] = None
|
|
28
17
|
|
|
29
|
-
input: Optional[
|
|
18
|
+
input: Optional[CostDetails] = None
|
|
30
19
|
|
|
31
|
-
output: Optional[
|
|
20
|
+
output: Optional[CostDetails] = None
|
|
32
21
|
|
|
33
|
-
total: Optional[
|
|
22
|
+
total: Optional[CostDetails] = None
|
|
34
23
|
|
|
35
24
|
|
|
36
25
|
class ProxyResult(BaseModel):
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
from typing import Optional
|
|
4
|
+
|
|
5
|
+
from .._models import BaseModel
|
|
6
|
+
|
|
7
|
+
__all__ = ["RequestsData"]
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
class RequestsData(BaseModel):
|
|
11
|
+
blocked: Optional[int] = None
|
|
12
|
+
|
|
13
|
+
error: Optional[int] = None
|
|
14
|
+
|
|
15
|
+
exceeded: Optional[int] = None
|
|
16
|
+
|
|
17
|
+
failed: Optional[int] = None
|
|
18
|
+
|
|
19
|
+
successful: Optional[int] = None
|
|
20
|
+
|
|
21
|
+
total: Optional[int] = None
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
-
|
|
3
|
-
from typing import List, Optional
|
|
4
|
-
from datetime import datetime
|
|
5
|
-
from typing_extensions import Literal
|
|
6
|
-
|
|
7
|
-
from pydantic import Field as FieldInfo
|
|
8
|
-
|
|
9
|
-
from .._models import BaseModel
|
|
10
|
-
|
|
11
|
-
__all__ = [
|
|
12
|
-
"BudgetResponse",
|
|
13
|
-
"Budget",
|
|
14
|
-
"BudgetTotals",
|
|
15
|
-
"BudgetTotalsCost",
|
|
16
|
-
"BudgetTotalsCostInputCost",
|
|
17
|
-
"BudgetTotalsCostOutputCost",
|
|
18
|
-
"BudgetTotalsCostTotalCost",
|
|
19
|
-
"BudgetTotalsRequests",
|
|
20
|
-
]
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
class BudgetTotalsCostInputCost(BaseModel):
|
|
24
|
-
base: Optional[float] = None
|
|
25
|
-
|
|
26
|
-
overrun_base: Optional[float] = None
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
class BudgetTotalsCostOutputCost(BaseModel):
|
|
30
|
-
base: Optional[float] = None
|
|
31
|
-
|
|
32
|
-
overrun_base: Optional[float] = None
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
class BudgetTotalsCostTotalCost(BaseModel):
|
|
36
|
-
base: Optional[float] = None
|
|
37
|
-
|
|
38
|
-
overrun_base: Optional[float] = None
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
class BudgetTotalsCost(BaseModel):
|
|
42
|
-
input_cost: Optional[BudgetTotalsCostInputCost] = FieldInfo(alias="inputCost", default=None)
|
|
43
|
-
|
|
44
|
-
output_cost: Optional[BudgetTotalsCostOutputCost] = FieldInfo(alias="outputCost", default=None)
|
|
45
|
-
|
|
46
|
-
total_cost: Optional[BudgetTotalsCostTotalCost] = FieldInfo(alias="totalCost", default=None)
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
class BudgetTotalsRequests(BaseModel):
|
|
50
|
-
blocked: Optional[int] = None
|
|
51
|
-
|
|
52
|
-
error: Optional[int] = None
|
|
53
|
-
|
|
54
|
-
exceeded: Optional[int] = None
|
|
55
|
-
|
|
56
|
-
failed: Optional[int] = None
|
|
57
|
-
|
|
58
|
-
successful: Optional[int] = None
|
|
59
|
-
|
|
60
|
-
total: Optional[int] = None
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
class BudgetTotals(BaseModel):
|
|
64
|
-
cost: Optional[BudgetTotalsCost] = None
|
|
65
|
-
|
|
66
|
-
requests: Optional[BudgetTotalsRequests] = None
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
class Budget(BaseModel):
|
|
70
|
-
base_cost_estimate: Literal["Max"]
|
|
71
|
-
|
|
72
|
-
budget_creation_timestamp: datetime
|
|
73
|
-
|
|
74
|
-
budget_id: str
|
|
75
|
-
|
|
76
|
-
budget_name: str
|
|
77
|
-
|
|
78
|
-
budget_response_type: Literal["Block", "Allow"]
|
|
79
|
-
|
|
80
|
-
budget_type: Literal["Conservative", "Liberal"]
|
|
81
|
-
|
|
82
|
-
budget_update_timestamp: datetime
|
|
83
|
-
|
|
84
|
-
currency: str
|
|
85
|
-
|
|
86
|
-
max: float
|
|
87
|
-
|
|
88
|
-
totals: BudgetTotals
|
|
89
|
-
|
|
90
|
-
budget_tags: Optional[List[str]] = None
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
class BudgetResponse(BaseModel):
|
|
94
|
-
budget: Budget
|
|
95
|
-
|
|
96
|
-
request_id: str
|
|
97
|
-
|
|
98
|
-
message: Optional[str] = None
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|