gcore 0.16.0__py3-none-any.whl → 0.23.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.
Potentially problematic release.
This version of gcore might be problematic. Click here for more details.
- gcore/_client.py +16 -0
- gcore/_models.py +37 -15
- gcore/_streaming.py +12 -12
- gcore/_utils/_sync.py +3 -31
- gcore/_utils/_utils.py +1 -1
- gcore/_version.py +1 -1
- gcore/resources/cdn/audit_log.py +4 -4
- gcore/resources/cdn/cdn.py +120 -21
- gcore/resources/cdn/ip_ranges.py +97 -5
- gcore/resources/cdn/{logs/logs.py → logs.py} +9 -9
- gcore/resources/cdn/resources/resources.py +20 -20
- gcore/resources/cdn/statistics.py +56 -58
- gcore/resources/cloud/__init__.py +40 -12
- gcore/resources/cloud/audit_logs.py +20 -0
- gcore/resources/cloud/baremetal/servers.py +48 -14
- gcore/resources/cloud/billing_reservations.py +2 -2
- gcore/resources/cloud/cloud.py +100 -18
- gcore/resources/cloud/databases/__init__.py +33 -0
- gcore/resources/cloud/databases/databases.py +102 -0
- gcore/resources/cloud/databases/postgres/__init__.py +61 -0
- gcore/resources/cloud/databases/postgres/clusters/__init__.py +33 -0
- gcore/resources/cloud/databases/postgres/clusters/clusters.py +716 -0
- gcore/resources/cloud/databases/postgres/clusters/user_credentials.py +281 -0
- gcore/resources/cloud/databases/postgres/configurations.py +169 -0
- gcore/resources/cloud/databases/postgres/custom_configurations.py +197 -0
- gcore/resources/cloud/databases/postgres/postgres.py +166 -0
- gcore/resources/cloud/file_shares/file_shares.py +154 -49
- gcore/resources/cloud/floating_ips.py +42 -10
- gcore/resources/cloud/gpu_baremetal_clusters/gpu_baremetal_clusters.py +70 -10
- gcore/resources/cloud/gpu_baremetal_clusters/images.py +40 -6
- gcore/resources/cloud/gpu_baremetal_clusters/servers.py +16 -0
- gcore/resources/cloud/gpu_virtual_clusters/__init__.py +89 -0
- gcore/resources/cloud/gpu_virtual_clusters/flavors.py +211 -0
- gcore/resources/cloud/gpu_virtual_clusters/gpu_virtual_clusters.py +1551 -0
- gcore/resources/cloud/gpu_virtual_clusters/images.py +582 -0
- gcore/resources/cloud/gpu_virtual_clusters/interfaces.py +187 -0
- gcore/resources/cloud/gpu_virtual_clusters/servers.py +506 -0
- gcore/resources/cloud/gpu_virtual_clusters/volumes.py +187 -0
- gcore/resources/cloud/inference/deployments/deployments.py +52 -4
- gcore/resources/cloud/instances/images.py +72 -18
- gcore/resources/cloud/instances/instances.py +110 -18
- gcore/resources/cloud/instances/interfaces.py +12 -0
- gcore/resources/cloud/k8s/__init__.py +12 -12
- gcore/resources/cloud/k8s/clusters/clusters.py +25 -25
- gcore/resources/cloud/k8s/clusters/pools/pools.py +14 -14
- gcore/resources/cloud/k8s/k8s.py +24 -24
- gcore/resources/cloud/load_balancers/l7_policies/l7_policies.py +1420 -218
- gcore/resources/cloud/load_balancers/l7_policies/rules.py +134 -22
- gcore/resources/cloud/load_balancers/listeners.py +77 -6
- gcore/resources/cloud/load_balancers/load_balancers.py +92 -14
- gcore/resources/cloud/load_balancers/pools/pools.py +52 -4
- gcore/resources/cloud/networks/networks.py +30 -10
- gcore/resources/cloud/networks/subnets.py +26 -10
- gcore/resources/cloud/placement_groups.py +8 -0
- gcore/resources/cloud/projects.py +99 -119
- gcore/resources/cloud/quotas/requests.py +0 -8
- gcore/resources/cloud/reserved_fixed_ips/reserved_fixed_ips.py +18 -0
- gcore/resources/cloud/secrets.py +16 -0
- gcore/resources/cloud/security_groups/security_groups.py +38 -12
- gcore/resources/cloud/ssh_keys.py +10 -0
- gcore/resources/cloud/tasks.py +22 -7
- gcore/resources/cloud/volumes.py +65 -23
- gcore/resources/dns/zones/rrsets.py +10 -10
- gcore/resources/dns/zones/zones.py +2 -2
- gcore/resources/security/bgp_announces.py +0 -4
- gcore/resources/security/profiles.py +31 -7
- gcore/resources/storage/credentials.py +0 -28
- gcore/resources/storage/storage.py +2 -2
- gcore/types/cdn/__init__.py +5 -0
- gcore/types/cdn/alibaba_regions.py +22 -0
- gcore/types/cdn/audit_log_list_params.py +2 -2
- gcore/types/cdn/aws_regions.py +22 -0
- gcore/types/cdn/cdn_list_purge_statuses_response.py +10 -0
- gcore/types/cdn/cdn_resource.py +17 -12
- gcore/types/cdn/ip_range_list_ips_params.py +19 -0
- gcore/types/cdn/ip_range_list_params.py +19 -0
- gcore/types/cdn/resource_create_params.py +17 -12
- gcore/types/cdn/resource_purge_params.py +4 -4
- gcore/types/cdn/resource_replace_params.py +17 -12
- gcore/types/cdn/resource_update_params.py +17 -12
- gcore/types/cdn/resource_usage_stats.py +16 -15
- gcore/types/cdn/resources/cdn_resource_rule.py +15 -10
- gcore/types/cdn/resources/rule_create_params.py +15 -10
- gcore/types/cdn/resources/rule_replace_params.py +15 -10
- gcore/types/cdn/resources/rule_update_params.py +15 -10
- gcore/types/cdn/rule_template.py +15 -10
- gcore/types/cdn/rule_template_create_params.py +15 -10
- gcore/types/cdn/rule_template_replace_params.py +15 -10
- gcore/types/cdn/rule_template_update_params.py +15 -10
- gcore/types/cdn/statistic_get_logs_usage_aggregated_params.py +4 -1
- gcore/types/cdn/statistic_get_logs_usage_series_params.py +5 -12
- gcore/types/cdn/statistic_get_resource_usage_aggregated_params.py +10 -21
- gcore/types/cdn/statistic_get_resource_usage_series_params.py +6 -1
- gcore/types/cdn/statistic_get_shield_usage_aggregated_params.py +5 -2
- gcore/types/cdn/statistic_get_shield_usage_series_params.py +3 -0
- gcore/types/cloud/__init__.py +9 -3
- gcore/types/cloud/audit_log_entry.py +9 -3
- gcore/types/cloud/audit_log_list_params.py +12 -0
- gcore/types/cloud/baremetal/server_create_params.py +7 -7
- gcore/types/cloud/baremetal_flavor.py +0 -6
- gcore/types/cloud/billing_reservation_list_params.py +1 -1
- gcore/types/cloud/blackhole_port.py +4 -1
- gcore/types/cloud/databases/postgres/__init__.py +12 -0
- gcore/types/cloud/databases/postgres/cluster_create_params.py +108 -0
- gcore/types/cloud/databases/postgres/cluster_list_params.py +19 -0
- gcore/types/cloud/databases/postgres/cluster_update_params.py +102 -0
- gcore/types/cloud/databases/postgres/clusters/__init__.py +5 -0
- gcore/types/cloud/databases/postgres/clusters/postgres_user_credentials.py +13 -0
- gcore/types/cloud/databases/postgres/custom_configuration_validate_params.py +19 -0
- gcore/types/cloud/databases/postgres/pg_conf_validation.py +15 -0
- gcore/types/cloud/databases/postgres/postgres_cluster.py +118 -0
- gcore/types/cloud/databases/postgres/postgres_cluster_short.py +22 -0
- gcore/types/cloud/databases/postgres/postgres_configuration.py +31 -0
- gcore/types/cloud/file_share_create_params.py +8 -8
- gcore/types/cloud/file_share_update_params.py +7 -2
- gcore/types/cloud/floating_ip.py +5 -1
- gcore/types/cloud/floating_ip_create_params.py +4 -4
- gcore/types/cloud/floating_ip_detailed.py +5 -1
- gcore/types/cloud/floating_ip_list_params.py +8 -0
- gcore/types/cloud/floating_ip_update_params.py +7 -2
- gcore/types/cloud/gpu_baremetal_cluster.py +18 -3
- gcore/types/cloud/gpu_baremetal_cluster_action_params.py +7 -2
- gcore/types/cloud/gpu_baremetal_cluster_create_params.py +16 -4
- gcore/types/cloud/gpu_baremetal_clusters/gpu_baremetal_cluster_server.py +5 -2
- gcore/types/cloud/gpu_baremetal_clusters/image_upload_params.py +4 -4
- gcore/types/cloud/gpu_image.py +9 -0
- gcore/types/cloud/gpu_virtual_cluster.py +189 -0
- gcore/types/cloud/gpu_virtual_cluster_action_params.py +127 -0
- gcore/types/cloud/gpu_virtual_cluster_create_params.py +213 -0
- gcore/types/cloud/gpu_virtual_cluster_delete_params.py +41 -0
- gcore/types/cloud/gpu_virtual_cluster_list_params.py +21 -0
- gcore/types/cloud/gpu_virtual_cluster_update_params.py +18 -0
- gcore/types/cloud/gpu_virtual_clusters/__init__.py +16 -0
- gcore/types/cloud/gpu_virtual_clusters/flavor_list_params.py +21 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_cluster_server.py +77 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_cluster_server_list.py +16 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_cluster_volume.py +64 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_cluster_volume_list.py +16 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_flavor.py +155 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_flavor_list.py +16 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_interface.py +190 -0
- gcore/types/cloud/gpu_virtual_clusters/gpu_virtual_interface_list.py +16 -0
- gcore/types/cloud/gpu_virtual_clusters/image_upload_params.py +56 -0
- gcore/types/cloud/gpu_virtual_clusters/server_delete_params.py +44 -0
- gcore/types/cloud/gpu_virtual_clusters/server_list_params.py +75 -0
- gcore/types/cloud/image.py +9 -0
- gcore/types/cloud/inference/deployment_create_params.py +1 -1
- gcore/types/cloud/inference/deployment_update_params.py +1 -1
- gcore/types/cloud/inference/inference_deployment.py +1 -1
- gcore/types/cloud/instance_create_params.py +27 -27
- gcore/types/cloud/instance_update_params.py +7 -2
- gcore/types/cloud/instances/image_create_from_volume_params.py +4 -4
- gcore/types/cloud/instances/image_update_params.py +4 -4
- gcore/types/cloud/instances/image_upload_params.py +4 -4
- gcore/types/cloud/k8s/__init__.py +4 -4
- gcore/types/cloud/k8s/cluster_update_params.py +5 -5
- gcore/types/cloud/k8s/clusters/__init__.py +2 -2
- gcore/types/cloud/k8s/clusters/k8s_cluster_pool.py +2 -2
- gcore/types/cloud/k8s/clusters/k8s_cluster_pool_list.py +4 -4
- gcore/types/cloud/k8s/k8s_cluster.py +4 -4
- gcore/types/cloud/k8s/k8s_cluster_certificate.py +2 -2
- gcore/types/cloud/k8s/k8s_cluster_kubeconfig.py +14 -2
- gcore/types/cloud/k8s/k8s_cluster_list.py +4 -4
- gcore/types/cloud/k8s_cluster_version.py +2 -2
- gcore/types/cloud/k8s_cluster_version_list.py +4 -4
- gcore/types/cloud/load_balancer_create_params.py +14 -8
- gcore/types/cloud/load_balancer_flavor_detail.py +2 -2
- gcore/types/cloud/load_balancer_l7_policy.py +29 -16
- gcore/types/cloud/load_balancer_l7_policy_list.py +3 -3
- gcore/types/cloud/load_balancer_l7_rule.py +14 -23
- gcore/types/cloud/load_balancer_l7_rule_list.py +3 -3
- gcore/types/cloud/load_balancer_listener_detail.py +2 -2
- gcore/types/cloud/load_balancer_update_params.py +7 -2
- gcore/types/cloud/load_balancers/__init__.py +1 -0
- gcore/types/cloud/load_balancers/l7_policies/rule_create_params.py +5 -10
- gcore/types/cloud/load_balancers/l7_policies/rule_replace_params.py +7 -11
- gcore/types/cloud/load_balancers/l7_policy_create_params.py +102 -18
- gcore/types/cloud/load_balancers/l7_policy_replace_params.py +94 -16
- gcore/types/cloud/load_balancers/listener_create_params.py +4 -1
- gcore/types/cloud/load_balancers/listener_delete_params.py +18 -0
- gcore/types/cloud/load_balancers/listener_update_params.py +4 -1
- gcore/types/cloud/load_balancers/pool_create_params.py +1 -1
- gcore/types/cloud/network_create_params.py +4 -4
- gcore/types/cloud/network_update_params.py +7 -2
- gcore/types/cloud/networks/subnet_create_params.py +4 -4
- gcore/types/cloud/networks/subnet_update_params.py +7 -2
- gcore/types/cloud/project_create_params.py +0 -6
- gcore/types/cloud/{project_replace_params.py → project_update_params.py} +2 -2
- gcore/types/cloud/quotas/request_create_params.py +0 -3
- gcore/types/cloud/region.py +3 -3
- gcore/types/cloud/security_group.py +8 -1
- gcore/types/cloud/security_group_create_params.py +7 -5
- gcore/types/cloud/security_group_list_params.py +6 -4
- gcore/types/cloud/security_group_update_params.py +7 -2
- gcore/types/cloud/ssh_key_list_params.py +7 -0
- gcore/types/cloud/tag.py +2 -2
- gcore/types/cloud/task_id_list.py +3 -3
- gcore/types/cloud/volume_create_params.py +12 -12
- gcore/types/cloud/volume_update_params.py +7 -2
- gcore/types/dns/zone_list_params.py +1 -1
- gcore/types/iam/api_token_create.py +70 -1
- gcore/types/security/bgp_announce_list_params.py +0 -2
- gcore/types/security/client_profile.py +1 -0
- gcore/types/security/profile_create_params.py +4 -2
- gcore/types/security/profile_recreate_params.py +4 -2
- gcore/types/security/profile_replace_params.py +4 -2
- gcore/types/storage/credential_recreate_params.py +0 -17
- gcore/types/storage/storage.py +1 -1
- gcore/types/storage/storage_create_params.py +1 -1
- gcore/types/streaming/stream.py +3 -2
- gcore/types/streaming/video.py +1 -1
- gcore/types/waap/domains/custom_rule_create_params.py +1 -1
- gcore/types/waap/domains/custom_rule_update_params.py +1 -1
- gcore/types/waap/domains/waap_custom_rule.py +1 -1
- {gcore-0.16.0.dist-info → gcore-0.23.0.dist-info}/METADATA +14 -14
- {gcore-0.16.0.dist-info → gcore-0.23.0.dist-info}/RECORD +219 -168
- gcore/resources/cdn/logs/__init__.py +0 -19
- /gcore/types/{cdn/logs → cloud/databases}/__init__.py +0 -0
- {gcore-0.16.0.dist-info → gcore-0.23.0.dist-info}/WHEEL +0 -0
- {gcore-0.16.0.dist-info → gcore-0.23.0.dist-info}/licenses/LICENSE +0 -0
|
@@ -0,0 +1,716 @@
|
|
|
1
|
+
# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
|
|
2
|
+
|
|
3
|
+
from __future__ import annotations
|
|
4
|
+
|
|
5
|
+
from typing import Iterable, Optional
|
|
6
|
+
|
|
7
|
+
import httpx
|
|
8
|
+
|
|
9
|
+
from ......_types import Body, Omit, Query, Headers, NotGiven, omit, not_given
|
|
10
|
+
from ......_utils import maybe_transform, async_maybe_transform
|
|
11
|
+
from ......_compat import cached_property
|
|
12
|
+
from ......_resource import SyncAPIResource, AsyncAPIResource
|
|
13
|
+
from ......_response import (
|
|
14
|
+
to_raw_response_wrapper,
|
|
15
|
+
to_streamed_response_wrapper,
|
|
16
|
+
async_to_raw_response_wrapper,
|
|
17
|
+
async_to_streamed_response_wrapper,
|
|
18
|
+
)
|
|
19
|
+
from ......pagination import SyncOffsetPage, AsyncOffsetPage
|
|
20
|
+
from .user_credentials import (
|
|
21
|
+
UserCredentialsResource,
|
|
22
|
+
AsyncUserCredentialsResource,
|
|
23
|
+
UserCredentialsResourceWithRawResponse,
|
|
24
|
+
AsyncUserCredentialsResourceWithRawResponse,
|
|
25
|
+
UserCredentialsResourceWithStreamingResponse,
|
|
26
|
+
AsyncUserCredentialsResourceWithStreamingResponse,
|
|
27
|
+
)
|
|
28
|
+
from ......_base_client import AsyncPaginator, make_request_options
|
|
29
|
+
from ......types.cloud.task_id_list import TaskIDList
|
|
30
|
+
from ......types.cloud.databases.postgres import cluster_list_params, cluster_create_params, cluster_update_params
|
|
31
|
+
from ......types.cloud.databases.postgres.postgres_cluster import PostgresCluster
|
|
32
|
+
from ......types.cloud.databases.postgres.postgres_cluster_short import PostgresClusterShort
|
|
33
|
+
|
|
34
|
+
__all__ = ["ClustersResource", "AsyncClustersResource"]
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
class ClustersResource(SyncAPIResource):
|
|
38
|
+
@cached_property
|
|
39
|
+
def user_credentials(self) -> UserCredentialsResource:
|
|
40
|
+
return UserCredentialsResource(self._client)
|
|
41
|
+
|
|
42
|
+
@cached_property
|
|
43
|
+
def with_raw_response(self) -> ClustersResourceWithRawResponse:
|
|
44
|
+
"""
|
|
45
|
+
This property can be used as a prefix for any HTTP method call to return
|
|
46
|
+
the raw response object instead of the parsed content.
|
|
47
|
+
|
|
48
|
+
For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
|
|
49
|
+
"""
|
|
50
|
+
return ClustersResourceWithRawResponse(self)
|
|
51
|
+
|
|
52
|
+
@cached_property
|
|
53
|
+
def with_streaming_response(self) -> ClustersResourceWithStreamingResponse:
|
|
54
|
+
"""
|
|
55
|
+
An alternative to `.with_raw_response` that doesn't eagerly read the response body.
|
|
56
|
+
|
|
57
|
+
For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
|
|
58
|
+
"""
|
|
59
|
+
return ClustersResourceWithStreamingResponse(self)
|
|
60
|
+
|
|
61
|
+
def create(
|
|
62
|
+
self,
|
|
63
|
+
*,
|
|
64
|
+
project_id: int | None = None,
|
|
65
|
+
region_id: int | None = None,
|
|
66
|
+
cluster_name: str,
|
|
67
|
+
flavor: cluster_create_params.Flavor,
|
|
68
|
+
high_availability: Optional[cluster_create_params.HighAvailability],
|
|
69
|
+
network: cluster_create_params.Network,
|
|
70
|
+
pg_server_configuration: cluster_create_params.PgServerConfiguration,
|
|
71
|
+
storage: cluster_create_params.Storage,
|
|
72
|
+
databases: Iterable[cluster_create_params.Database] | Omit = omit,
|
|
73
|
+
users: Iterable[cluster_create_params.User] | Omit = omit,
|
|
74
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
75
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
76
|
+
extra_headers: Headers | None = None,
|
|
77
|
+
extra_query: Query | None = None,
|
|
78
|
+
extra_body: Body | None = None,
|
|
79
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
80
|
+
) -> TaskIDList:
|
|
81
|
+
"""
|
|
82
|
+
Create a new PostgreSQL cluster with the specified configuration.
|
|
83
|
+
|
|
84
|
+
Args:
|
|
85
|
+
cluster_name: PostgreSQL cluster name
|
|
86
|
+
|
|
87
|
+
flavor: Instance RAM and CPU
|
|
88
|
+
|
|
89
|
+
high_availability: High Availability settings
|
|
90
|
+
|
|
91
|
+
pg_server_configuration: PosgtreSQL cluster configuration
|
|
92
|
+
|
|
93
|
+
storage: Cluster's storage configuration
|
|
94
|
+
|
|
95
|
+
extra_headers: Send extra headers
|
|
96
|
+
|
|
97
|
+
extra_query: Add additional query parameters to the request
|
|
98
|
+
|
|
99
|
+
extra_body: Add additional JSON properties to the request
|
|
100
|
+
|
|
101
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
102
|
+
"""
|
|
103
|
+
if project_id is None:
|
|
104
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
105
|
+
if region_id is None:
|
|
106
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
107
|
+
return self._post(
|
|
108
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}",
|
|
109
|
+
body=maybe_transform(
|
|
110
|
+
{
|
|
111
|
+
"cluster_name": cluster_name,
|
|
112
|
+
"flavor": flavor,
|
|
113
|
+
"high_availability": high_availability,
|
|
114
|
+
"network": network,
|
|
115
|
+
"pg_server_configuration": pg_server_configuration,
|
|
116
|
+
"storage": storage,
|
|
117
|
+
"databases": databases,
|
|
118
|
+
"users": users,
|
|
119
|
+
},
|
|
120
|
+
cluster_create_params.ClusterCreateParams,
|
|
121
|
+
),
|
|
122
|
+
options=make_request_options(
|
|
123
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
124
|
+
),
|
|
125
|
+
cast_to=TaskIDList,
|
|
126
|
+
)
|
|
127
|
+
|
|
128
|
+
def update(
|
|
129
|
+
self,
|
|
130
|
+
cluster_name: str,
|
|
131
|
+
*,
|
|
132
|
+
project_id: int | None = None,
|
|
133
|
+
region_id: int | None = None,
|
|
134
|
+
databases: Iterable[cluster_update_params.Database] | Omit = omit,
|
|
135
|
+
flavor: Optional[cluster_update_params.Flavor] | Omit = omit,
|
|
136
|
+
high_availability: Optional[cluster_update_params.HighAvailability] | Omit = omit,
|
|
137
|
+
network: Optional[cluster_update_params.Network] | Omit = omit,
|
|
138
|
+
pg_server_configuration: Optional[cluster_update_params.PgServerConfiguration] | Omit = omit,
|
|
139
|
+
storage: Optional[cluster_update_params.Storage] | Omit = omit,
|
|
140
|
+
users: Iterable[cluster_update_params.User] | Omit = omit,
|
|
141
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
142
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
143
|
+
extra_headers: Headers | None = None,
|
|
144
|
+
extra_query: Query | None = None,
|
|
145
|
+
extra_body: Body | None = None,
|
|
146
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
147
|
+
) -> TaskIDList:
|
|
148
|
+
"""
|
|
149
|
+
Update the configuration of an existing PostgreSQL cluster.
|
|
150
|
+
|
|
151
|
+
Args:
|
|
152
|
+
flavor: New instance RAM and CPU
|
|
153
|
+
|
|
154
|
+
high_availability: New High Availability settings
|
|
155
|
+
|
|
156
|
+
pg_server_configuration: New PosgtreSQL cluster configuration
|
|
157
|
+
|
|
158
|
+
storage: New storage configuration
|
|
159
|
+
|
|
160
|
+
extra_headers: Send extra headers
|
|
161
|
+
|
|
162
|
+
extra_query: Add additional query parameters to the request
|
|
163
|
+
|
|
164
|
+
extra_body: Add additional JSON properties to the request
|
|
165
|
+
|
|
166
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
167
|
+
"""
|
|
168
|
+
if project_id is None:
|
|
169
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
170
|
+
if region_id is None:
|
|
171
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
172
|
+
if not cluster_name:
|
|
173
|
+
raise ValueError(f"Expected a non-empty value for `cluster_name` but received {cluster_name!r}")
|
|
174
|
+
return self._patch(
|
|
175
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}/{cluster_name}",
|
|
176
|
+
body=maybe_transform(
|
|
177
|
+
{
|
|
178
|
+
"databases": databases,
|
|
179
|
+
"flavor": flavor,
|
|
180
|
+
"high_availability": high_availability,
|
|
181
|
+
"network": network,
|
|
182
|
+
"pg_server_configuration": pg_server_configuration,
|
|
183
|
+
"storage": storage,
|
|
184
|
+
"users": users,
|
|
185
|
+
},
|
|
186
|
+
cluster_update_params.ClusterUpdateParams,
|
|
187
|
+
),
|
|
188
|
+
options=make_request_options(
|
|
189
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
190
|
+
),
|
|
191
|
+
cast_to=TaskIDList,
|
|
192
|
+
)
|
|
193
|
+
|
|
194
|
+
def list(
|
|
195
|
+
self,
|
|
196
|
+
*,
|
|
197
|
+
project_id: int | None = None,
|
|
198
|
+
region_id: int | None = None,
|
|
199
|
+
limit: int | Omit = omit,
|
|
200
|
+
offset: int | Omit = omit,
|
|
201
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
202
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
203
|
+
extra_headers: Headers | None = None,
|
|
204
|
+
extra_query: Query | None = None,
|
|
205
|
+
extra_body: Body | None = None,
|
|
206
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
207
|
+
) -> SyncOffsetPage[PostgresClusterShort]:
|
|
208
|
+
"""List all PostgreSQL clusters in the specified project and region.
|
|
209
|
+
|
|
210
|
+
Results can be
|
|
211
|
+
filtered by search query and paginated.
|
|
212
|
+
|
|
213
|
+
Args:
|
|
214
|
+
limit: Maximum number of clusters to return
|
|
215
|
+
|
|
216
|
+
offset: Number of clusters to skip
|
|
217
|
+
|
|
218
|
+
extra_headers: Send extra headers
|
|
219
|
+
|
|
220
|
+
extra_query: Add additional query parameters to the request
|
|
221
|
+
|
|
222
|
+
extra_body: Add additional JSON properties to the request
|
|
223
|
+
|
|
224
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
225
|
+
"""
|
|
226
|
+
if project_id is None:
|
|
227
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
228
|
+
if region_id is None:
|
|
229
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
230
|
+
return self._get_api_list(
|
|
231
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}",
|
|
232
|
+
page=SyncOffsetPage[PostgresClusterShort],
|
|
233
|
+
options=make_request_options(
|
|
234
|
+
extra_headers=extra_headers,
|
|
235
|
+
extra_query=extra_query,
|
|
236
|
+
extra_body=extra_body,
|
|
237
|
+
timeout=timeout,
|
|
238
|
+
query=maybe_transform(
|
|
239
|
+
{
|
|
240
|
+
"limit": limit,
|
|
241
|
+
"offset": offset,
|
|
242
|
+
},
|
|
243
|
+
cluster_list_params.ClusterListParams,
|
|
244
|
+
),
|
|
245
|
+
),
|
|
246
|
+
model=PostgresClusterShort,
|
|
247
|
+
)
|
|
248
|
+
|
|
249
|
+
def delete(
|
|
250
|
+
self,
|
|
251
|
+
cluster_name: str,
|
|
252
|
+
*,
|
|
253
|
+
project_id: int | None = None,
|
|
254
|
+
region_id: int | None = None,
|
|
255
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
256
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
257
|
+
extra_headers: Headers | None = None,
|
|
258
|
+
extra_query: Query | None = None,
|
|
259
|
+
extra_body: Body | None = None,
|
|
260
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
261
|
+
) -> TaskIDList:
|
|
262
|
+
"""
|
|
263
|
+
Delete a PostgreSQL cluster and all its associated resources.
|
|
264
|
+
|
|
265
|
+
Args:
|
|
266
|
+
extra_headers: Send extra headers
|
|
267
|
+
|
|
268
|
+
extra_query: Add additional query parameters to the request
|
|
269
|
+
|
|
270
|
+
extra_body: Add additional JSON properties to the request
|
|
271
|
+
|
|
272
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
273
|
+
"""
|
|
274
|
+
if project_id is None:
|
|
275
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
276
|
+
if region_id is None:
|
|
277
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
278
|
+
if not cluster_name:
|
|
279
|
+
raise ValueError(f"Expected a non-empty value for `cluster_name` but received {cluster_name!r}")
|
|
280
|
+
return self._delete(
|
|
281
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}/{cluster_name}",
|
|
282
|
+
options=make_request_options(
|
|
283
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
284
|
+
),
|
|
285
|
+
cast_to=TaskIDList,
|
|
286
|
+
)
|
|
287
|
+
|
|
288
|
+
def get(
|
|
289
|
+
self,
|
|
290
|
+
cluster_name: str,
|
|
291
|
+
*,
|
|
292
|
+
project_id: int | None = None,
|
|
293
|
+
region_id: int | None = None,
|
|
294
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
295
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
296
|
+
extra_headers: Headers | None = None,
|
|
297
|
+
extra_query: Query | None = None,
|
|
298
|
+
extra_body: Body | None = None,
|
|
299
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
300
|
+
) -> PostgresCluster:
|
|
301
|
+
"""
|
|
302
|
+
Get detailed information about a specific PostgreSQL cluster.
|
|
303
|
+
|
|
304
|
+
Args:
|
|
305
|
+
extra_headers: Send extra headers
|
|
306
|
+
|
|
307
|
+
extra_query: Add additional query parameters to the request
|
|
308
|
+
|
|
309
|
+
extra_body: Add additional JSON properties to the request
|
|
310
|
+
|
|
311
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
312
|
+
"""
|
|
313
|
+
if project_id is None:
|
|
314
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
315
|
+
if region_id is None:
|
|
316
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
317
|
+
if not cluster_name:
|
|
318
|
+
raise ValueError(f"Expected a non-empty value for `cluster_name` but received {cluster_name!r}")
|
|
319
|
+
return self._get(
|
|
320
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}/{cluster_name}",
|
|
321
|
+
options=make_request_options(
|
|
322
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
323
|
+
),
|
|
324
|
+
cast_to=PostgresCluster,
|
|
325
|
+
)
|
|
326
|
+
|
|
327
|
+
|
|
328
|
+
class AsyncClustersResource(AsyncAPIResource):
|
|
329
|
+
@cached_property
|
|
330
|
+
def user_credentials(self) -> AsyncUserCredentialsResource:
|
|
331
|
+
return AsyncUserCredentialsResource(self._client)
|
|
332
|
+
|
|
333
|
+
@cached_property
|
|
334
|
+
def with_raw_response(self) -> AsyncClustersResourceWithRawResponse:
|
|
335
|
+
"""
|
|
336
|
+
This property can be used as a prefix for any HTTP method call to return
|
|
337
|
+
the raw response object instead of the parsed content.
|
|
338
|
+
|
|
339
|
+
For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
|
|
340
|
+
"""
|
|
341
|
+
return AsyncClustersResourceWithRawResponse(self)
|
|
342
|
+
|
|
343
|
+
@cached_property
|
|
344
|
+
def with_streaming_response(self) -> AsyncClustersResourceWithStreamingResponse:
|
|
345
|
+
"""
|
|
346
|
+
An alternative to `.with_raw_response` that doesn't eagerly read the response body.
|
|
347
|
+
|
|
348
|
+
For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
|
|
349
|
+
"""
|
|
350
|
+
return AsyncClustersResourceWithStreamingResponse(self)
|
|
351
|
+
|
|
352
|
+
async def create(
|
|
353
|
+
self,
|
|
354
|
+
*,
|
|
355
|
+
project_id: int | None = None,
|
|
356
|
+
region_id: int | None = None,
|
|
357
|
+
cluster_name: str,
|
|
358
|
+
flavor: cluster_create_params.Flavor,
|
|
359
|
+
high_availability: Optional[cluster_create_params.HighAvailability],
|
|
360
|
+
network: cluster_create_params.Network,
|
|
361
|
+
pg_server_configuration: cluster_create_params.PgServerConfiguration,
|
|
362
|
+
storage: cluster_create_params.Storage,
|
|
363
|
+
databases: Iterable[cluster_create_params.Database] | Omit = omit,
|
|
364
|
+
users: Iterable[cluster_create_params.User] | Omit = omit,
|
|
365
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
366
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
367
|
+
extra_headers: Headers | None = None,
|
|
368
|
+
extra_query: Query | None = None,
|
|
369
|
+
extra_body: Body | None = None,
|
|
370
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
371
|
+
) -> TaskIDList:
|
|
372
|
+
"""
|
|
373
|
+
Create a new PostgreSQL cluster with the specified configuration.
|
|
374
|
+
|
|
375
|
+
Args:
|
|
376
|
+
cluster_name: PostgreSQL cluster name
|
|
377
|
+
|
|
378
|
+
flavor: Instance RAM and CPU
|
|
379
|
+
|
|
380
|
+
high_availability: High Availability settings
|
|
381
|
+
|
|
382
|
+
pg_server_configuration: PosgtreSQL cluster configuration
|
|
383
|
+
|
|
384
|
+
storage: Cluster's storage configuration
|
|
385
|
+
|
|
386
|
+
extra_headers: Send extra headers
|
|
387
|
+
|
|
388
|
+
extra_query: Add additional query parameters to the request
|
|
389
|
+
|
|
390
|
+
extra_body: Add additional JSON properties to the request
|
|
391
|
+
|
|
392
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
393
|
+
"""
|
|
394
|
+
if project_id is None:
|
|
395
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
396
|
+
if region_id is None:
|
|
397
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
398
|
+
return await self._post(
|
|
399
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}",
|
|
400
|
+
body=await async_maybe_transform(
|
|
401
|
+
{
|
|
402
|
+
"cluster_name": cluster_name,
|
|
403
|
+
"flavor": flavor,
|
|
404
|
+
"high_availability": high_availability,
|
|
405
|
+
"network": network,
|
|
406
|
+
"pg_server_configuration": pg_server_configuration,
|
|
407
|
+
"storage": storage,
|
|
408
|
+
"databases": databases,
|
|
409
|
+
"users": users,
|
|
410
|
+
},
|
|
411
|
+
cluster_create_params.ClusterCreateParams,
|
|
412
|
+
),
|
|
413
|
+
options=make_request_options(
|
|
414
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
415
|
+
),
|
|
416
|
+
cast_to=TaskIDList,
|
|
417
|
+
)
|
|
418
|
+
|
|
419
|
+
async def update(
|
|
420
|
+
self,
|
|
421
|
+
cluster_name: str,
|
|
422
|
+
*,
|
|
423
|
+
project_id: int | None = None,
|
|
424
|
+
region_id: int | None = None,
|
|
425
|
+
databases: Iterable[cluster_update_params.Database] | Omit = omit,
|
|
426
|
+
flavor: Optional[cluster_update_params.Flavor] | Omit = omit,
|
|
427
|
+
high_availability: Optional[cluster_update_params.HighAvailability] | Omit = omit,
|
|
428
|
+
network: Optional[cluster_update_params.Network] | Omit = omit,
|
|
429
|
+
pg_server_configuration: Optional[cluster_update_params.PgServerConfiguration] | Omit = omit,
|
|
430
|
+
storage: Optional[cluster_update_params.Storage] | Omit = omit,
|
|
431
|
+
users: Iterable[cluster_update_params.User] | Omit = omit,
|
|
432
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
433
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
434
|
+
extra_headers: Headers | None = None,
|
|
435
|
+
extra_query: Query | None = None,
|
|
436
|
+
extra_body: Body | None = None,
|
|
437
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
438
|
+
) -> TaskIDList:
|
|
439
|
+
"""
|
|
440
|
+
Update the configuration of an existing PostgreSQL cluster.
|
|
441
|
+
|
|
442
|
+
Args:
|
|
443
|
+
flavor: New instance RAM and CPU
|
|
444
|
+
|
|
445
|
+
high_availability: New High Availability settings
|
|
446
|
+
|
|
447
|
+
pg_server_configuration: New PosgtreSQL cluster configuration
|
|
448
|
+
|
|
449
|
+
storage: New storage configuration
|
|
450
|
+
|
|
451
|
+
extra_headers: Send extra headers
|
|
452
|
+
|
|
453
|
+
extra_query: Add additional query parameters to the request
|
|
454
|
+
|
|
455
|
+
extra_body: Add additional JSON properties to the request
|
|
456
|
+
|
|
457
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
458
|
+
"""
|
|
459
|
+
if project_id is None:
|
|
460
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
461
|
+
if region_id is None:
|
|
462
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
463
|
+
if not cluster_name:
|
|
464
|
+
raise ValueError(f"Expected a non-empty value for `cluster_name` but received {cluster_name!r}")
|
|
465
|
+
return await self._patch(
|
|
466
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}/{cluster_name}",
|
|
467
|
+
body=await async_maybe_transform(
|
|
468
|
+
{
|
|
469
|
+
"databases": databases,
|
|
470
|
+
"flavor": flavor,
|
|
471
|
+
"high_availability": high_availability,
|
|
472
|
+
"network": network,
|
|
473
|
+
"pg_server_configuration": pg_server_configuration,
|
|
474
|
+
"storage": storage,
|
|
475
|
+
"users": users,
|
|
476
|
+
},
|
|
477
|
+
cluster_update_params.ClusterUpdateParams,
|
|
478
|
+
),
|
|
479
|
+
options=make_request_options(
|
|
480
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
481
|
+
),
|
|
482
|
+
cast_to=TaskIDList,
|
|
483
|
+
)
|
|
484
|
+
|
|
485
|
+
def list(
|
|
486
|
+
self,
|
|
487
|
+
*,
|
|
488
|
+
project_id: int | None = None,
|
|
489
|
+
region_id: int | None = None,
|
|
490
|
+
limit: int | Omit = omit,
|
|
491
|
+
offset: int | Omit = omit,
|
|
492
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
493
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
494
|
+
extra_headers: Headers | None = None,
|
|
495
|
+
extra_query: Query | None = None,
|
|
496
|
+
extra_body: Body | None = None,
|
|
497
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
498
|
+
) -> AsyncPaginator[PostgresClusterShort, AsyncOffsetPage[PostgresClusterShort]]:
|
|
499
|
+
"""List all PostgreSQL clusters in the specified project and region.
|
|
500
|
+
|
|
501
|
+
Results can be
|
|
502
|
+
filtered by search query and paginated.
|
|
503
|
+
|
|
504
|
+
Args:
|
|
505
|
+
limit: Maximum number of clusters to return
|
|
506
|
+
|
|
507
|
+
offset: Number of clusters to skip
|
|
508
|
+
|
|
509
|
+
extra_headers: Send extra headers
|
|
510
|
+
|
|
511
|
+
extra_query: Add additional query parameters to the request
|
|
512
|
+
|
|
513
|
+
extra_body: Add additional JSON properties to the request
|
|
514
|
+
|
|
515
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
516
|
+
"""
|
|
517
|
+
if project_id is None:
|
|
518
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
519
|
+
if region_id is None:
|
|
520
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
521
|
+
return self._get_api_list(
|
|
522
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}",
|
|
523
|
+
page=AsyncOffsetPage[PostgresClusterShort],
|
|
524
|
+
options=make_request_options(
|
|
525
|
+
extra_headers=extra_headers,
|
|
526
|
+
extra_query=extra_query,
|
|
527
|
+
extra_body=extra_body,
|
|
528
|
+
timeout=timeout,
|
|
529
|
+
query=maybe_transform(
|
|
530
|
+
{
|
|
531
|
+
"limit": limit,
|
|
532
|
+
"offset": offset,
|
|
533
|
+
},
|
|
534
|
+
cluster_list_params.ClusterListParams,
|
|
535
|
+
),
|
|
536
|
+
),
|
|
537
|
+
model=PostgresClusterShort,
|
|
538
|
+
)
|
|
539
|
+
|
|
540
|
+
async def delete(
|
|
541
|
+
self,
|
|
542
|
+
cluster_name: str,
|
|
543
|
+
*,
|
|
544
|
+
project_id: int | None = None,
|
|
545
|
+
region_id: int | None = None,
|
|
546
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
547
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
548
|
+
extra_headers: Headers | None = None,
|
|
549
|
+
extra_query: Query | None = None,
|
|
550
|
+
extra_body: Body | None = None,
|
|
551
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
552
|
+
) -> TaskIDList:
|
|
553
|
+
"""
|
|
554
|
+
Delete a PostgreSQL cluster and all its associated resources.
|
|
555
|
+
|
|
556
|
+
Args:
|
|
557
|
+
extra_headers: Send extra headers
|
|
558
|
+
|
|
559
|
+
extra_query: Add additional query parameters to the request
|
|
560
|
+
|
|
561
|
+
extra_body: Add additional JSON properties to the request
|
|
562
|
+
|
|
563
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
564
|
+
"""
|
|
565
|
+
if project_id is None:
|
|
566
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
567
|
+
if region_id is None:
|
|
568
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
569
|
+
if not cluster_name:
|
|
570
|
+
raise ValueError(f"Expected a non-empty value for `cluster_name` but received {cluster_name!r}")
|
|
571
|
+
return await self._delete(
|
|
572
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}/{cluster_name}",
|
|
573
|
+
options=make_request_options(
|
|
574
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
575
|
+
),
|
|
576
|
+
cast_to=TaskIDList,
|
|
577
|
+
)
|
|
578
|
+
|
|
579
|
+
async def get(
|
|
580
|
+
self,
|
|
581
|
+
cluster_name: str,
|
|
582
|
+
*,
|
|
583
|
+
project_id: int | None = None,
|
|
584
|
+
region_id: int | None = None,
|
|
585
|
+
# Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
|
|
586
|
+
# The extra values given here take precedence over values defined on the client or passed to this method.
|
|
587
|
+
extra_headers: Headers | None = None,
|
|
588
|
+
extra_query: Query | None = None,
|
|
589
|
+
extra_body: Body | None = None,
|
|
590
|
+
timeout: float | httpx.Timeout | None | NotGiven = not_given,
|
|
591
|
+
) -> PostgresCluster:
|
|
592
|
+
"""
|
|
593
|
+
Get detailed information about a specific PostgreSQL cluster.
|
|
594
|
+
|
|
595
|
+
Args:
|
|
596
|
+
extra_headers: Send extra headers
|
|
597
|
+
|
|
598
|
+
extra_query: Add additional query parameters to the request
|
|
599
|
+
|
|
600
|
+
extra_body: Add additional JSON properties to the request
|
|
601
|
+
|
|
602
|
+
timeout: Override the client-level default timeout for this request, in seconds
|
|
603
|
+
"""
|
|
604
|
+
if project_id is None:
|
|
605
|
+
project_id = self._client._get_cloud_project_id_path_param()
|
|
606
|
+
if region_id is None:
|
|
607
|
+
region_id = self._client._get_cloud_region_id_path_param()
|
|
608
|
+
if not cluster_name:
|
|
609
|
+
raise ValueError(f"Expected a non-empty value for `cluster_name` but received {cluster_name!r}")
|
|
610
|
+
return await self._get(
|
|
611
|
+
f"/cloud/v1/dbaas/postgres/clusters/{project_id}/{region_id}/{cluster_name}",
|
|
612
|
+
options=make_request_options(
|
|
613
|
+
extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
|
|
614
|
+
),
|
|
615
|
+
cast_to=PostgresCluster,
|
|
616
|
+
)
|
|
617
|
+
|
|
618
|
+
|
|
619
|
+
class ClustersResourceWithRawResponse:
|
|
620
|
+
def __init__(self, clusters: ClustersResource) -> None:
|
|
621
|
+
self._clusters = clusters
|
|
622
|
+
|
|
623
|
+
self.create = to_raw_response_wrapper(
|
|
624
|
+
clusters.create,
|
|
625
|
+
)
|
|
626
|
+
self.update = to_raw_response_wrapper(
|
|
627
|
+
clusters.update,
|
|
628
|
+
)
|
|
629
|
+
self.list = to_raw_response_wrapper(
|
|
630
|
+
clusters.list,
|
|
631
|
+
)
|
|
632
|
+
self.delete = to_raw_response_wrapper(
|
|
633
|
+
clusters.delete,
|
|
634
|
+
)
|
|
635
|
+
self.get = to_raw_response_wrapper(
|
|
636
|
+
clusters.get,
|
|
637
|
+
)
|
|
638
|
+
|
|
639
|
+
@cached_property
|
|
640
|
+
def user_credentials(self) -> UserCredentialsResourceWithRawResponse:
|
|
641
|
+
return UserCredentialsResourceWithRawResponse(self._clusters.user_credentials)
|
|
642
|
+
|
|
643
|
+
|
|
644
|
+
class AsyncClustersResourceWithRawResponse:
|
|
645
|
+
def __init__(self, clusters: AsyncClustersResource) -> None:
|
|
646
|
+
self._clusters = clusters
|
|
647
|
+
|
|
648
|
+
self.create = async_to_raw_response_wrapper(
|
|
649
|
+
clusters.create,
|
|
650
|
+
)
|
|
651
|
+
self.update = async_to_raw_response_wrapper(
|
|
652
|
+
clusters.update,
|
|
653
|
+
)
|
|
654
|
+
self.list = async_to_raw_response_wrapper(
|
|
655
|
+
clusters.list,
|
|
656
|
+
)
|
|
657
|
+
self.delete = async_to_raw_response_wrapper(
|
|
658
|
+
clusters.delete,
|
|
659
|
+
)
|
|
660
|
+
self.get = async_to_raw_response_wrapper(
|
|
661
|
+
clusters.get,
|
|
662
|
+
)
|
|
663
|
+
|
|
664
|
+
@cached_property
|
|
665
|
+
def user_credentials(self) -> AsyncUserCredentialsResourceWithRawResponse:
|
|
666
|
+
return AsyncUserCredentialsResourceWithRawResponse(self._clusters.user_credentials)
|
|
667
|
+
|
|
668
|
+
|
|
669
|
+
class ClustersResourceWithStreamingResponse:
|
|
670
|
+
def __init__(self, clusters: ClustersResource) -> None:
|
|
671
|
+
self._clusters = clusters
|
|
672
|
+
|
|
673
|
+
self.create = to_streamed_response_wrapper(
|
|
674
|
+
clusters.create,
|
|
675
|
+
)
|
|
676
|
+
self.update = to_streamed_response_wrapper(
|
|
677
|
+
clusters.update,
|
|
678
|
+
)
|
|
679
|
+
self.list = to_streamed_response_wrapper(
|
|
680
|
+
clusters.list,
|
|
681
|
+
)
|
|
682
|
+
self.delete = to_streamed_response_wrapper(
|
|
683
|
+
clusters.delete,
|
|
684
|
+
)
|
|
685
|
+
self.get = to_streamed_response_wrapper(
|
|
686
|
+
clusters.get,
|
|
687
|
+
)
|
|
688
|
+
|
|
689
|
+
@cached_property
|
|
690
|
+
def user_credentials(self) -> UserCredentialsResourceWithStreamingResponse:
|
|
691
|
+
return UserCredentialsResourceWithStreamingResponse(self._clusters.user_credentials)
|
|
692
|
+
|
|
693
|
+
|
|
694
|
+
class AsyncClustersResourceWithStreamingResponse:
|
|
695
|
+
def __init__(self, clusters: AsyncClustersResource) -> None:
|
|
696
|
+
self._clusters = clusters
|
|
697
|
+
|
|
698
|
+
self.create = async_to_streamed_response_wrapper(
|
|
699
|
+
clusters.create,
|
|
700
|
+
)
|
|
701
|
+
self.update = async_to_streamed_response_wrapper(
|
|
702
|
+
clusters.update,
|
|
703
|
+
)
|
|
704
|
+
self.list = async_to_streamed_response_wrapper(
|
|
705
|
+
clusters.list,
|
|
706
|
+
)
|
|
707
|
+
self.delete = async_to_streamed_response_wrapper(
|
|
708
|
+
clusters.delete,
|
|
709
|
+
)
|
|
710
|
+
self.get = async_to_streamed_response_wrapper(
|
|
711
|
+
clusters.get,
|
|
712
|
+
)
|
|
713
|
+
|
|
714
|
+
@cached_property
|
|
715
|
+
def user_credentials(self) -> AsyncUserCredentialsResourceWithStreamingResponse:
|
|
716
|
+
return AsyncUserCredentialsResourceWithStreamingResponse(self._clusters.user_credentials)
|