gcore 0.8.0__py3-none-any.whl → 0.10.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.

Files changed (164) hide show
  1. gcore/_base_client.py +4 -1
  2. gcore/_client.py +9 -0
  3. gcore/_files.py +4 -4
  4. gcore/_version.py +1 -1
  5. gcore/resources/__init__.py +14 -0
  6. gcore/resources/cloud/cost_reports.py +24 -0
  7. gcore/resources/cloud/load_balancers/pools/health_monitors.py +8 -4
  8. gcore/resources/cloud/load_balancers/pools/members.py +2 -2
  9. gcore/resources/cloud/quotas/requests.py +7 -15
  10. gcore/resources/fastedge/binaries.py +81 -1
  11. gcore/resources/security/__init__.py +75 -0
  12. gcore/resources/security/bgp_announces.py +308 -0
  13. gcore/resources/security/events.py +234 -0
  14. gcore/resources/security/profile_templates.py +143 -0
  15. gcore/resources/security/profiles.py +661 -0
  16. gcore/resources/security/security.py +198 -0
  17. gcore/resources/waap/__init__.py +14 -0
  18. gcore/resources/waap/custom_page_sets.py +40 -34
  19. gcore/resources/waap/domains/__init__.py +14 -28
  20. gcore/resources/waap/domains/advanced_rules.py +5 -8
  21. gcore/resources/waap/domains/{api_discovery/api_discovery.py → api_discovery.py} +292 -59
  22. gcore/resources/waap/domains/api_path_groups.py +5 -5
  23. gcore/resources/waap/domains/api_paths.py +15 -17
  24. gcore/resources/waap/domains/custom_rules.py +5 -8
  25. gcore/resources/waap/domains/domains.py +120 -64
  26. gcore/resources/waap/domains/firewall_rules.py +3 -5
  27. gcore/resources/waap/domains/insight_silences.py +28 -5
  28. gcore/resources/waap/domains/insights.py +36 -10
  29. gcore/resources/waap/domains/{analytics/analytics.py → statistics.py} +514 -213
  30. gcore/resources/waap/insights.py +233 -0
  31. gcore/resources/waap/ip_info/__init__.py +33 -0
  32. gcore/resources/waap/{ip_info.py → ip_info/ip_info.py} +149 -235
  33. gcore/resources/waap/ip_info/metrics.py +203 -0
  34. gcore/resources/waap/waap.py +40 -8
  35. gcore/types/cloud/cost_report_get_aggregated_monthly_params.py +3 -0
  36. gcore/types/cloud/cost_report_get_aggregated_params.py +3 -0
  37. gcore/types/cloud/cost_report_get_detailed_params.py +3 -0
  38. gcore/types/cloud/gpu_baremetal_flavor.py +16 -0
  39. gcore/types/cloud/health_monitor.py +6 -0
  40. gcore/types/cloud/load_balancer_create_params.py +8 -3
  41. gcore/types/cloud/load_balancers/pool_create_params.py +8 -3
  42. gcore/types/cloud/load_balancers/pool_update_params.py +8 -3
  43. gcore/types/cloud/load_balancers/pools/health_monitor_create_params.py +7 -2
  44. gcore/types/cloud/load_balancers/pools/member_add_params.py +1 -1
  45. gcore/types/cloud/quotas/request_list_params.py +2 -2
  46. gcore/types/cloud/region.py +6 -6
  47. gcore/types/fastedge/__init__.py +1 -0
  48. gcore/types/fastedge/binary_create_params.py +11 -0
  49. gcore/types/security/__init__.py +18 -0
  50. gcore/types/security/bgp_announce_list_params.py +18 -0
  51. gcore/types/security/bgp_announce_list_response.py +10 -0
  52. gcore/types/security/bgp_announce_toggle_params.py +16 -0
  53. gcore/types/security/client_announce.py +15 -0
  54. gcore/types/security/client_profile.py +56 -0
  55. gcore/types/security/client_profile_template.py +43 -0
  56. gcore/types/security/client_view.py +29 -0
  57. gcore/types/security/event_list_params.py +38 -0
  58. gcore/types/security/profile_create_params.py +24 -0
  59. gcore/types/security/profile_list_params.py +17 -0
  60. gcore/types/security/profile_list_response.py +10 -0
  61. gcore/types/security/profile_recreate_params.py +24 -0
  62. gcore/types/security/profile_replace_params.py +24 -0
  63. gcore/types/security/profile_template_list_response.py +10 -0
  64. gcore/types/waap/__init__.py +6 -54
  65. gcore/types/waap/custom_page_set_create_params.py +121 -14
  66. gcore/types/waap/custom_page_set_preview_params.py +11 -4
  67. gcore/types/waap/custom_page_set_update_params.py +122 -15
  68. gcore/types/waap/domain_list_params.py +1 -3
  69. gcore/types/waap/domains/__init__.py +28 -18
  70. gcore/types/waap/domains/advanced_rule_list_params.py +1 -3
  71. gcore/types/waap/domains/{api_discovery/scan_result_list_params.py → api_discovery_list_scan_results_params.py} +2 -2
  72. gcore/types/waap/domains/{api_path_group_list_response.py → api_path_group_list.py} +2 -2
  73. gcore/types/waap/domains/custom_rule_list_params.py +1 -3
  74. gcore/types/waap/domains/insight_list_params.py +16 -6
  75. gcore/types/waap/domains/insight_replace_params.py +2 -4
  76. gcore/types/waap/domains/insight_silence_list_params.py +13 -4
  77. gcore/types/waap/domains/{analytics_list_ddos_attacks_params.py → statistic_get_ddos_attacks_params.py} +2 -2
  78. gcore/types/waap/domains/{analytics_list_ddos_info_params.py → statistic_get_ddos_info_params.py} +2 -2
  79. gcore/types/waap/domains/{analytics_get_event_statistics_params.py → statistic_get_events_aggregated_params.py} +2 -2
  80. gcore/types/waap/domains/{analytics/request_list_params.py → statistic_get_requests_series_params.py} +27 -5
  81. gcore/types/waap/domains/{analytics_list_event_traffic_params.py → statistic_get_traffic_series_params.py} +4 -5
  82. gcore/types/waap/domains/statistic_get_traffic_series_response.py +10 -0
  83. gcore/types/waap/{waap_advanced_rule.py → domains/waap_advanced_rule.py} +1 -1
  84. gcore/types/waap/domains/{api_discovery_get_settings_response.py → waap_api_discovery_settings.py} +2 -2
  85. gcore/types/waap/domains/{api_path_get_response.py → waap_api_path.py} +2 -2
  86. gcore/types/waap/domains/{api_discovery/scan_result_get_response.py → waap_api_scan_result.py} +3 -3
  87. gcore/types/waap/{waap_blocked_statistics.py → domains/waap_blocked_statistics.py} +1 -1
  88. gcore/types/waap/{waap_count_statistics.py → domains/waap_count_statistics.py} +1 -1
  89. gcore/types/waap/{waap_custom_rule.py → domains/waap_custom_rule.py} +1 -1
  90. gcore/types/waap/{waap_ddos_attack.py → domains/waap_ddos_attack.py} +1 -1
  91. gcore/types/waap/{waap_ddos_info.py → domains/waap_ddos_info.py} +1 -1
  92. gcore/types/waap/{waap_event_statistics.py → domains/waap_event_statistics.py} +1 -1
  93. gcore/types/waap/{waap_firewall_rule.py → domains/waap_firewall_rule.py} +1 -1
  94. gcore/types/waap/{waap_insight.py → domains/waap_insight.py} +3 -3
  95. gcore/types/waap/{waap_insight_silence.py → domains/waap_insight_silence.py} +1 -1
  96. gcore/types/waap/domains/waap_request_details.py +185 -0
  97. gcore/types/waap/{waap_request_summary.py → domains/waap_request_summary.py} +1 -1
  98. gcore/types/waap/domains/{api_discovery_scan_openapi_response.py → waap_task_id.py} +2 -2
  99. gcore/types/waap/{waap_traffic_metrics.py → domains/waap_traffic_metrics.py} +1 -1
  100. gcore/types/waap/insight_list_types_params.py +28 -0
  101. gcore/types/waap/ip_info/__init__.py +6 -0
  102. gcore/types/waap/{ip_info_get_counts_params.py → ip_info/metric_list_params.py} +2 -2
  103. gcore/types/waap/{waap_ip_info_counts.py → ip_info/waap_ip_info_counts.py} +1 -1
  104. gcore/types/waap/{ip_info_get_params.py → ip_info_get_ip_info_params.py} +2 -2
  105. gcore/types/waap/{waap_ip_info.py → ip_info_get_ip_info_response.py} +2 -2
  106. gcore/types/waap/ip_info_get_top_urls_response.py +12 -3
  107. gcore/types/waap/{ip_info_get_top_sessions_params.py → ip_info_get_top_user_sessions_params.py} +2 -2
  108. gcore/types/waap/{ip_info_get_top_sessions_response.py → ip_info_get_top_user_sessions_response.py} +2 -2
  109. gcore/types/waap/waap_custom_page_set.py +113 -13
  110. gcore/types/waap/waap_detailed_domain.py +2 -2
  111. gcore/types/waap/waap_insight_type.py +33 -0
  112. gcore/types/waap/waap_rule_set.py +26 -3
  113. gcore/types/waap/waap_summary_domain.py +2 -2
  114. {gcore-0.8.0.dist-info → gcore-0.10.0.dist-info}/METADATA +1 -1
  115. {gcore-0.8.0.dist-info → gcore-0.10.0.dist-info}/RECORD +117 -134
  116. gcore/resources/waap/domains/analytics/__init__.py +0 -33
  117. gcore/resources/waap/domains/analytics/requests.py +0 -378
  118. gcore/resources/waap/domains/api_discovery/__init__.py +0 -33
  119. gcore/resources/waap/domains/api_discovery/scan_results.py +0 -352
  120. gcore/resources/waap/domains/policies.py +0 -173
  121. gcore/types/waap/domains/analytics/__init__.py +0 -5
  122. gcore/types/waap/domains/analytics_list_event_traffic_response.py +0 -10
  123. gcore/types/waap/domains/api_discovery/__init__.py +0 -7
  124. gcore/types/waap/domains/api_discovery/scan_result_list_response.py +0 -29
  125. gcore/types/waap/domains/api_discovery_update_settings_response.py +0 -36
  126. gcore/types/waap/domains/api_discovery_upload_openapi_response.py +0 -10
  127. gcore/types/waap/domains/api_path_create_response.py +0 -50
  128. gcore/types/waap/domains/api_path_list_response.py +0 -50
  129. gcore/types/waap/waap_block_csrf_page_data.py +0 -28
  130. gcore/types/waap/waap_block_csrf_page_data_param.py +0 -28
  131. gcore/types/waap/waap_block_page_data.py +0 -28
  132. gcore/types/waap/waap_block_page_data_param.py +0 -28
  133. gcore/types/waap/waap_captcha_page_data.py +0 -31
  134. gcore/types/waap/waap_captcha_page_data_param.py +0 -31
  135. gcore/types/waap/waap_common_tag.py +0 -16
  136. gcore/types/waap/waap_cookie_disabled_page_data.py +0 -18
  137. gcore/types/waap/waap_cookie_disabled_page_data_param.py +0 -18
  138. gcore/types/waap/waap_customer_rule_state.py +0 -7
  139. gcore/types/waap/waap_domain_policy.py +0 -29
  140. gcore/types/waap/waap_domain_status.py +0 -7
  141. gcore/types/waap/waap_handshake_page_data.py +0 -25
  142. gcore/types/waap/waap_handshake_page_data_param.py +0 -25
  143. gcore/types/waap/waap_insight_silence_sort_by.py +0 -9
  144. gcore/types/waap/waap_insight_sort_by.py +0 -20
  145. gcore/types/waap/waap_insight_status.py +0 -7
  146. gcore/types/waap/waap_javascript_disabled_page_data.py +0 -18
  147. gcore/types/waap/waap_javascript_disabled_page_data_param.py +0 -18
  148. gcore/types/waap/waap_network_details.py +0 -17
  149. gcore/types/waap/waap_page_type.py +0 -9
  150. gcore/types/waap/waap_paginated_custom_page_set.py +0 -22
  151. gcore/types/waap/waap_paginated_ddos_attack.py +0 -22
  152. gcore/types/waap/waap_paginated_ddos_info.py +0 -22
  153. gcore/types/waap/waap_paginated_request_summary.py +0 -22
  154. gcore/types/waap/waap_pattern_matched_tag.py +0 -37
  155. gcore/types/waap/waap_policy_action.py +0 -7
  156. gcore/types/waap/waap_request_details.py +0 -92
  157. gcore/types/waap/waap_request_organization.py +0 -13
  158. gcore/types/waap/waap_resolution.py +0 -7
  159. gcore/types/waap/waap_rule_action_type.py +0 -7
  160. gcore/types/waap/waap_top_url.py +0 -13
  161. gcore/types/waap/waap_traffic_type.py +0 -28
  162. gcore/types/waap/waap_user_agent_details.py +0 -40
  163. {gcore-0.8.0.dist-info → gcore-0.10.0.dist-info}/WHEEL +0 -0
  164. {gcore-0.8.0.dist-info → gcore-0.10.0.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,308 @@
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 Optional
6
+ from typing_extensions import Literal
7
+
8
+ import httpx
9
+
10
+ from ..._types import NOT_GIVEN, Body, Query, Headers, NotGiven
11
+ from ..._utils import maybe_transform, async_maybe_transform
12
+ from ..._compat import cached_property
13
+ from ..._resource import SyncAPIResource, AsyncAPIResource
14
+ from ..._response import (
15
+ to_raw_response_wrapper,
16
+ to_streamed_response_wrapper,
17
+ async_to_raw_response_wrapper,
18
+ async_to_streamed_response_wrapper,
19
+ )
20
+ from ..._base_client import make_request_options
21
+ from ...types.security import bgp_announce_list_params, bgp_announce_toggle_params
22
+ from ...types.security.bgp_announce_list_response import BgpAnnounceListResponse
23
+
24
+ __all__ = ["BgpAnnouncesResource", "AsyncBgpAnnouncesResource"]
25
+
26
+
27
+ class BgpAnnouncesResource(SyncAPIResource):
28
+ @cached_property
29
+ def with_raw_response(self) -> BgpAnnouncesResourceWithRawResponse:
30
+ """
31
+ This property can be used as a prefix for any HTTP method call to return
32
+ the raw response object instead of the parsed content.
33
+
34
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
35
+ """
36
+ return BgpAnnouncesResourceWithRawResponse(self)
37
+
38
+ @cached_property
39
+ def with_streaming_response(self) -> BgpAnnouncesResourceWithStreamingResponse:
40
+ """
41
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
42
+
43
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
44
+ """
45
+ return BgpAnnouncesResourceWithStreamingResponse(self)
46
+
47
+ def list(
48
+ self,
49
+ *,
50
+ announced: Optional[bool] | NotGiven = NOT_GIVEN,
51
+ client_id: Optional[int] | NotGiven = NOT_GIVEN,
52
+ origin: Optional[Literal["STATIC", "DYNAMIC"]] | NotGiven = NOT_GIVEN,
53
+ site: Optional[str] | NotGiven = NOT_GIVEN,
54
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
55
+ # The extra values given here take precedence over values defined on the client or passed to this method.
56
+ extra_headers: Headers | None = None,
57
+ extra_query: Query | None = None,
58
+ extra_body: Body | None = None,
59
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
60
+ ) -> BgpAnnounceListResponse:
61
+ """Get BGP announces filtered by parameters.
62
+
63
+ Shows announces in active profiles,
64
+ meaning that to get a non-empty response, the client must have at least one
65
+ active profile.
66
+
67
+ Args:
68
+ extra_headers: Send extra headers
69
+
70
+ extra_query: Add additional query parameters to the request
71
+
72
+ extra_body: Add additional JSON properties to the request
73
+
74
+ timeout: Override the client-level default timeout for this request, in seconds
75
+ """
76
+ return self._get(
77
+ "/security/sifter/v2/protected_addresses/announces",
78
+ options=make_request_options(
79
+ extra_headers=extra_headers,
80
+ extra_query=extra_query,
81
+ extra_body=extra_body,
82
+ timeout=timeout,
83
+ query=maybe_transform(
84
+ {
85
+ "announced": announced,
86
+ "client_id": client_id,
87
+ "origin": origin,
88
+ "site": site,
89
+ },
90
+ bgp_announce_list_params.BgpAnnounceListParams,
91
+ ),
92
+ ),
93
+ cast_to=BgpAnnounceListResponse,
94
+ )
95
+
96
+ def toggle(
97
+ self,
98
+ *,
99
+ announce: str,
100
+ enabled: bool,
101
+ client_id: Optional[int] | NotGiven = NOT_GIVEN,
102
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
103
+ # The extra values given here take precedence over values defined on the client or passed to this method.
104
+ extra_headers: Headers | None = None,
105
+ extra_query: Query | None = None,
106
+ extra_body: Body | None = None,
107
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
108
+ ) -> object:
109
+ """Change BGP announces (it can be enabled or disabled, but not created or
110
+ updated).
111
+
112
+ Can be applied to already existing announces in active profiles,
113
+ meaning that the client must have at least one active profile.
114
+
115
+ Args:
116
+ extra_headers: Send extra headers
117
+
118
+ extra_query: Add additional query parameters to the request
119
+
120
+ extra_body: Add additional JSON properties to the request
121
+
122
+ timeout: Override the client-level default timeout for this request, in seconds
123
+ """
124
+ return self._post(
125
+ "/security/sifter/v2/protected_addresses/announces",
126
+ body=maybe_transform(
127
+ {
128
+ "announce": announce,
129
+ "enabled": enabled,
130
+ },
131
+ bgp_announce_toggle_params.BgpAnnounceToggleParams,
132
+ ),
133
+ options=make_request_options(
134
+ extra_headers=extra_headers,
135
+ extra_query=extra_query,
136
+ extra_body=extra_body,
137
+ timeout=timeout,
138
+ query=maybe_transform({"client_id": client_id}, bgp_announce_toggle_params.BgpAnnounceToggleParams),
139
+ ),
140
+ cast_to=object,
141
+ )
142
+
143
+
144
+ class AsyncBgpAnnouncesResource(AsyncAPIResource):
145
+ @cached_property
146
+ def with_raw_response(self) -> AsyncBgpAnnouncesResourceWithRawResponse:
147
+ """
148
+ This property can be used as a prefix for any HTTP method call to return
149
+ the raw response object instead of the parsed content.
150
+
151
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
152
+ """
153
+ return AsyncBgpAnnouncesResourceWithRawResponse(self)
154
+
155
+ @cached_property
156
+ def with_streaming_response(self) -> AsyncBgpAnnouncesResourceWithStreamingResponse:
157
+ """
158
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
159
+
160
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
161
+ """
162
+ return AsyncBgpAnnouncesResourceWithStreamingResponse(self)
163
+
164
+ async def list(
165
+ self,
166
+ *,
167
+ announced: Optional[bool] | NotGiven = NOT_GIVEN,
168
+ client_id: Optional[int] | NotGiven = NOT_GIVEN,
169
+ origin: Optional[Literal["STATIC", "DYNAMIC"]] | NotGiven = NOT_GIVEN,
170
+ site: Optional[str] | NotGiven = NOT_GIVEN,
171
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
172
+ # The extra values given here take precedence over values defined on the client or passed to this method.
173
+ extra_headers: Headers | None = None,
174
+ extra_query: Query | None = None,
175
+ extra_body: Body | None = None,
176
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
177
+ ) -> BgpAnnounceListResponse:
178
+ """Get BGP announces filtered by parameters.
179
+
180
+ Shows announces in active profiles,
181
+ meaning that to get a non-empty response, the client must have at least one
182
+ active profile.
183
+
184
+ Args:
185
+ extra_headers: Send extra headers
186
+
187
+ extra_query: Add additional query parameters to the request
188
+
189
+ extra_body: Add additional JSON properties to the request
190
+
191
+ timeout: Override the client-level default timeout for this request, in seconds
192
+ """
193
+ return await self._get(
194
+ "/security/sifter/v2/protected_addresses/announces",
195
+ options=make_request_options(
196
+ extra_headers=extra_headers,
197
+ extra_query=extra_query,
198
+ extra_body=extra_body,
199
+ timeout=timeout,
200
+ query=await async_maybe_transform(
201
+ {
202
+ "announced": announced,
203
+ "client_id": client_id,
204
+ "origin": origin,
205
+ "site": site,
206
+ },
207
+ bgp_announce_list_params.BgpAnnounceListParams,
208
+ ),
209
+ ),
210
+ cast_to=BgpAnnounceListResponse,
211
+ )
212
+
213
+ async def toggle(
214
+ self,
215
+ *,
216
+ announce: str,
217
+ enabled: bool,
218
+ client_id: Optional[int] | NotGiven = NOT_GIVEN,
219
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
220
+ # The extra values given here take precedence over values defined on the client or passed to this method.
221
+ extra_headers: Headers | None = None,
222
+ extra_query: Query | None = None,
223
+ extra_body: Body | None = None,
224
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
225
+ ) -> object:
226
+ """Change BGP announces (it can be enabled or disabled, but not created or
227
+ updated).
228
+
229
+ Can be applied to already existing announces in active profiles,
230
+ meaning that the client must have at least one active profile.
231
+
232
+ Args:
233
+ extra_headers: Send extra headers
234
+
235
+ extra_query: Add additional query parameters to the request
236
+
237
+ extra_body: Add additional JSON properties to the request
238
+
239
+ timeout: Override the client-level default timeout for this request, in seconds
240
+ """
241
+ return await self._post(
242
+ "/security/sifter/v2/protected_addresses/announces",
243
+ body=await async_maybe_transform(
244
+ {
245
+ "announce": announce,
246
+ "enabled": enabled,
247
+ },
248
+ bgp_announce_toggle_params.BgpAnnounceToggleParams,
249
+ ),
250
+ options=make_request_options(
251
+ extra_headers=extra_headers,
252
+ extra_query=extra_query,
253
+ extra_body=extra_body,
254
+ timeout=timeout,
255
+ query=await async_maybe_transform(
256
+ {"client_id": client_id}, bgp_announce_toggle_params.BgpAnnounceToggleParams
257
+ ),
258
+ ),
259
+ cast_to=object,
260
+ )
261
+
262
+
263
+ class BgpAnnouncesResourceWithRawResponse:
264
+ def __init__(self, bgp_announces: BgpAnnouncesResource) -> None:
265
+ self._bgp_announces = bgp_announces
266
+
267
+ self.list = to_raw_response_wrapper(
268
+ bgp_announces.list,
269
+ )
270
+ self.toggle = to_raw_response_wrapper(
271
+ bgp_announces.toggle,
272
+ )
273
+
274
+
275
+ class AsyncBgpAnnouncesResourceWithRawResponse:
276
+ def __init__(self, bgp_announces: AsyncBgpAnnouncesResource) -> None:
277
+ self._bgp_announces = bgp_announces
278
+
279
+ self.list = async_to_raw_response_wrapper(
280
+ bgp_announces.list,
281
+ )
282
+ self.toggle = async_to_raw_response_wrapper(
283
+ bgp_announces.toggle,
284
+ )
285
+
286
+
287
+ class BgpAnnouncesResourceWithStreamingResponse:
288
+ def __init__(self, bgp_announces: BgpAnnouncesResource) -> None:
289
+ self._bgp_announces = bgp_announces
290
+
291
+ self.list = to_streamed_response_wrapper(
292
+ bgp_announces.list,
293
+ )
294
+ self.toggle = to_streamed_response_wrapper(
295
+ bgp_announces.toggle,
296
+ )
297
+
298
+
299
+ class AsyncBgpAnnouncesResourceWithStreamingResponse:
300
+ def __init__(self, bgp_announces: AsyncBgpAnnouncesResource) -> None:
301
+ self._bgp_announces = bgp_announces
302
+
303
+ self.list = async_to_streamed_response_wrapper(
304
+ bgp_announces.list,
305
+ )
306
+ self.toggle = async_to_streamed_response_wrapper(
307
+ bgp_announces.toggle,
308
+ )
@@ -0,0 +1,234 @@
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 Union, Optional
6
+ from datetime import datetime
7
+ from typing_extensions import Literal
8
+
9
+ import httpx
10
+
11
+ from ..._types import NOT_GIVEN, Body, Query, Headers, NotGiven
12
+ from ..._utils import maybe_transform
13
+ from ..._compat import cached_property
14
+ from ..._resource import SyncAPIResource, AsyncAPIResource
15
+ from ..._response import (
16
+ to_raw_response_wrapper,
17
+ to_streamed_response_wrapper,
18
+ async_to_raw_response_wrapper,
19
+ async_to_streamed_response_wrapper,
20
+ )
21
+ from ...pagination import SyncOffsetPage, AsyncOffsetPage
22
+ from ..._base_client import AsyncPaginator, make_request_options
23
+ from ...types.security import event_list_params
24
+ from ...types.security.client_view import ClientView
25
+
26
+ __all__ = ["EventsResource", "AsyncEventsResource"]
27
+
28
+
29
+ class EventsResource(SyncAPIResource):
30
+ @cached_property
31
+ def with_raw_response(self) -> EventsResourceWithRawResponse:
32
+ """
33
+ This property can be used as a prefix for any HTTP method call to return
34
+ the raw response object instead of the parsed content.
35
+
36
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
37
+ """
38
+ return EventsResourceWithRawResponse(self)
39
+
40
+ @cached_property
41
+ def with_streaming_response(self) -> EventsResourceWithStreamingResponse:
42
+ """
43
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
44
+
45
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
46
+ """
47
+ return EventsResourceWithStreamingResponse(self)
48
+
49
+ def list(
50
+ self,
51
+ *,
52
+ alert_type: Optional[Literal["ddos_alert", "rtbh_alert"]] | NotGiven = NOT_GIVEN,
53
+ date_from: Union[Union[str, datetime], str] | NotGiven = NOT_GIVEN,
54
+ date_to: Union[Union[str, datetime], str] | NotGiven = NOT_GIVEN,
55
+ limit: int | NotGiven = NOT_GIVEN,
56
+ offset: int | NotGiven = NOT_GIVEN,
57
+ ordering: Literal[
58
+ "attack_start_time",
59
+ "-attack_start_time",
60
+ "attack_power_bps",
61
+ "-attack_power_bps",
62
+ "attack_power_pps",
63
+ "-attack_power_pps",
64
+ "number_of_ip_involved_in_attack",
65
+ "-number_of_ip_involved_in_attack",
66
+ "alert_type",
67
+ "-alert_type",
68
+ ]
69
+ | NotGiven = NOT_GIVEN,
70
+ targeted_ip_addresses: Optional[str] | NotGiven = NOT_GIVEN,
71
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
72
+ # The extra values given here take precedence over values defined on the client or passed to this method.
73
+ extra_headers: Headers | None = None,
74
+ extra_query: Query | None = None,
75
+ extra_body: Body | None = None,
76
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
77
+ ) -> SyncOffsetPage[ClientView]:
78
+ """
79
+ Event Logs Clients View
80
+
81
+ Args:
82
+ extra_headers: Send extra headers
83
+
84
+ extra_query: Add additional query parameters to the request
85
+
86
+ extra_body: Add additional JSON properties to the request
87
+
88
+ timeout: Override the client-level default timeout for this request, in seconds
89
+ """
90
+ return self._get_api_list(
91
+ "/security/notifier/v1/event_logs",
92
+ page=SyncOffsetPage[ClientView],
93
+ options=make_request_options(
94
+ extra_headers=extra_headers,
95
+ extra_query=extra_query,
96
+ extra_body=extra_body,
97
+ timeout=timeout,
98
+ query=maybe_transform(
99
+ {
100
+ "alert_type": alert_type,
101
+ "date_from": date_from,
102
+ "date_to": date_to,
103
+ "limit": limit,
104
+ "offset": offset,
105
+ "ordering": ordering,
106
+ "targeted_ip_addresses": targeted_ip_addresses,
107
+ },
108
+ event_list_params.EventListParams,
109
+ ),
110
+ ),
111
+ model=ClientView,
112
+ )
113
+
114
+
115
+ class AsyncEventsResource(AsyncAPIResource):
116
+ @cached_property
117
+ def with_raw_response(self) -> AsyncEventsResourceWithRawResponse:
118
+ """
119
+ This property can be used as a prefix for any HTTP method call to return
120
+ the raw response object instead of the parsed content.
121
+
122
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
123
+ """
124
+ return AsyncEventsResourceWithRawResponse(self)
125
+
126
+ @cached_property
127
+ def with_streaming_response(self) -> AsyncEventsResourceWithStreamingResponse:
128
+ """
129
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
130
+
131
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
132
+ """
133
+ return AsyncEventsResourceWithStreamingResponse(self)
134
+
135
+ def list(
136
+ self,
137
+ *,
138
+ alert_type: Optional[Literal["ddos_alert", "rtbh_alert"]] | NotGiven = NOT_GIVEN,
139
+ date_from: Union[Union[str, datetime], str] | NotGiven = NOT_GIVEN,
140
+ date_to: Union[Union[str, datetime], str] | NotGiven = NOT_GIVEN,
141
+ limit: int | NotGiven = NOT_GIVEN,
142
+ offset: int | NotGiven = NOT_GIVEN,
143
+ ordering: Literal[
144
+ "attack_start_time",
145
+ "-attack_start_time",
146
+ "attack_power_bps",
147
+ "-attack_power_bps",
148
+ "attack_power_pps",
149
+ "-attack_power_pps",
150
+ "number_of_ip_involved_in_attack",
151
+ "-number_of_ip_involved_in_attack",
152
+ "alert_type",
153
+ "-alert_type",
154
+ ]
155
+ | NotGiven = NOT_GIVEN,
156
+ targeted_ip_addresses: Optional[str] | NotGiven = NOT_GIVEN,
157
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
158
+ # The extra values given here take precedence over values defined on the client or passed to this method.
159
+ extra_headers: Headers | None = None,
160
+ extra_query: Query | None = None,
161
+ extra_body: Body | None = None,
162
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
163
+ ) -> AsyncPaginator[ClientView, AsyncOffsetPage[ClientView]]:
164
+ """
165
+ Event Logs Clients View
166
+
167
+ Args:
168
+ extra_headers: Send extra headers
169
+
170
+ extra_query: Add additional query parameters to the request
171
+
172
+ extra_body: Add additional JSON properties to the request
173
+
174
+ timeout: Override the client-level default timeout for this request, in seconds
175
+ """
176
+ return self._get_api_list(
177
+ "/security/notifier/v1/event_logs",
178
+ page=AsyncOffsetPage[ClientView],
179
+ options=make_request_options(
180
+ extra_headers=extra_headers,
181
+ extra_query=extra_query,
182
+ extra_body=extra_body,
183
+ timeout=timeout,
184
+ query=maybe_transform(
185
+ {
186
+ "alert_type": alert_type,
187
+ "date_from": date_from,
188
+ "date_to": date_to,
189
+ "limit": limit,
190
+ "offset": offset,
191
+ "ordering": ordering,
192
+ "targeted_ip_addresses": targeted_ip_addresses,
193
+ },
194
+ event_list_params.EventListParams,
195
+ ),
196
+ ),
197
+ model=ClientView,
198
+ )
199
+
200
+
201
+ class EventsResourceWithRawResponse:
202
+ def __init__(self, events: EventsResource) -> None:
203
+ self._events = events
204
+
205
+ self.list = to_raw_response_wrapper(
206
+ events.list,
207
+ )
208
+
209
+
210
+ class AsyncEventsResourceWithRawResponse:
211
+ def __init__(self, events: AsyncEventsResource) -> None:
212
+ self._events = events
213
+
214
+ self.list = async_to_raw_response_wrapper(
215
+ events.list,
216
+ )
217
+
218
+
219
+ class EventsResourceWithStreamingResponse:
220
+ def __init__(self, events: EventsResource) -> None:
221
+ self._events = events
222
+
223
+ self.list = to_streamed_response_wrapper(
224
+ events.list,
225
+ )
226
+
227
+
228
+ class AsyncEventsResourceWithStreamingResponse:
229
+ def __init__(self, events: AsyncEventsResource) -> None:
230
+ self._events = events
231
+
232
+ self.list = async_to_streamed_response_wrapper(
233
+ events.list,
234
+ )
@@ -0,0 +1,143 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from __future__ import annotations
4
+
5
+ import httpx
6
+
7
+ from ..._types import NOT_GIVEN, Body, Query, Headers, NotGiven
8
+ from ..._compat import cached_property
9
+ from ..._resource import SyncAPIResource, AsyncAPIResource
10
+ from ..._response import (
11
+ to_raw_response_wrapper,
12
+ to_streamed_response_wrapper,
13
+ async_to_raw_response_wrapper,
14
+ async_to_streamed_response_wrapper,
15
+ )
16
+ from ..._base_client import make_request_options
17
+ from ...types.security.profile_template_list_response import ProfileTemplateListResponse
18
+
19
+ __all__ = ["ProfileTemplatesResource", "AsyncProfileTemplatesResource"]
20
+
21
+
22
+ class ProfileTemplatesResource(SyncAPIResource):
23
+ @cached_property
24
+ def with_raw_response(self) -> ProfileTemplatesResourceWithRawResponse:
25
+ """
26
+ This property can be used as a prefix for any HTTP method call to return
27
+ the raw response object instead of the parsed content.
28
+
29
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
30
+ """
31
+ return ProfileTemplatesResourceWithRawResponse(self)
32
+
33
+ @cached_property
34
+ def with_streaming_response(self) -> ProfileTemplatesResourceWithStreamingResponse:
35
+ """
36
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
37
+
38
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
39
+ """
40
+ return ProfileTemplatesResourceWithStreamingResponse(self)
41
+
42
+ def list(
43
+ self,
44
+ *,
45
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
46
+ # The extra values given here take precedence over values defined on the client or passed to this method.
47
+ extra_headers: Headers | None = None,
48
+ extra_query: Query | None = None,
49
+ extra_body: Body | None = None,
50
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
51
+ ) -> ProfileTemplateListResponse:
52
+ """Get list of profile templates.
53
+
54
+ Profile template is used as a template to create
55
+ profile. Client receives only common and created for him profile templates.
56
+ """
57
+ return self._get(
58
+ "/security/iaas/profile-templates",
59
+ options=make_request_options(
60
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
61
+ ),
62
+ cast_to=ProfileTemplateListResponse,
63
+ )
64
+
65
+
66
+ class AsyncProfileTemplatesResource(AsyncAPIResource):
67
+ @cached_property
68
+ def with_raw_response(self) -> AsyncProfileTemplatesResourceWithRawResponse:
69
+ """
70
+ This property can be used as a prefix for any HTTP method call to return
71
+ the raw response object instead of the parsed content.
72
+
73
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
74
+ """
75
+ return AsyncProfileTemplatesResourceWithRawResponse(self)
76
+
77
+ @cached_property
78
+ def with_streaming_response(self) -> AsyncProfileTemplatesResourceWithStreamingResponse:
79
+ """
80
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
81
+
82
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
83
+ """
84
+ return AsyncProfileTemplatesResourceWithStreamingResponse(self)
85
+
86
+ async def list(
87
+ self,
88
+ *,
89
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
90
+ # The extra values given here take precedence over values defined on the client or passed to this method.
91
+ extra_headers: Headers | None = None,
92
+ extra_query: Query | None = None,
93
+ extra_body: Body | None = None,
94
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
95
+ ) -> ProfileTemplateListResponse:
96
+ """Get list of profile templates.
97
+
98
+ Profile template is used as a template to create
99
+ profile. Client receives only common and created for him profile templates.
100
+ """
101
+ return await self._get(
102
+ "/security/iaas/profile-templates",
103
+ options=make_request_options(
104
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
105
+ ),
106
+ cast_to=ProfileTemplateListResponse,
107
+ )
108
+
109
+
110
+ class ProfileTemplatesResourceWithRawResponse:
111
+ def __init__(self, profile_templates: ProfileTemplatesResource) -> None:
112
+ self._profile_templates = profile_templates
113
+
114
+ self.list = to_raw_response_wrapper(
115
+ profile_templates.list,
116
+ )
117
+
118
+
119
+ class AsyncProfileTemplatesResourceWithRawResponse:
120
+ def __init__(self, profile_templates: AsyncProfileTemplatesResource) -> None:
121
+ self._profile_templates = profile_templates
122
+
123
+ self.list = async_to_raw_response_wrapper(
124
+ profile_templates.list,
125
+ )
126
+
127
+
128
+ class ProfileTemplatesResourceWithStreamingResponse:
129
+ def __init__(self, profile_templates: ProfileTemplatesResource) -> None:
130
+ self._profile_templates = profile_templates
131
+
132
+ self.list = to_streamed_response_wrapper(
133
+ profile_templates.list,
134
+ )
135
+
136
+
137
+ class AsyncProfileTemplatesResourceWithStreamingResponse:
138
+ def __init__(self, profile_templates: AsyncProfileTemplatesResource) -> None:
139
+ self._profile_templates = profile_templates
140
+
141
+ self.list = async_to_streamed_response_wrapper(
142
+ profile_templates.list,
143
+ )