gcore 0.1.0a2__py3-none-any.whl → 0.3.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 (293) hide show
  1. gcore/__init__.py +5 -0
  2. gcore/_base_client.py +22 -2
  3. gcore/_client.py +9 -0
  4. gcore/_models.py +2 -0
  5. gcore/_types.py +2 -0
  6. gcore/_utils/_proxy.py +4 -1
  7. gcore/_utils/_resources_proxy.py +24 -0
  8. gcore/_version.py +1 -1
  9. gcore/resources/__init__.py +14 -0
  10. gcore/resources/cloud/baremetal/flavors.py +2 -2
  11. gcore/resources/cloud/baremetal/images.py +2 -2
  12. gcore/resources/cloud/baremetal/servers.py +280 -52
  13. gcore/resources/cloud/billing_reservations.py +24 -0
  14. gcore/resources/cloud/file_shares/file_shares.py +16 -0
  15. gcore/resources/cloud/floating_ips.py +4 -4
  16. gcore/resources/cloud/gpu_baremetal_clusters/gpu_baremetal_clusters.py +358 -8
  17. gcore/resources/cloud/gpu_baremetal_clusters/images.py +206 -2
  18. gcore/resources/cloud/gpu_baremetal_clusters/servers.py +84 -4
  19. gcore/resources/cloud/inference/deployments/deployments.py +328 -10
  20. gcore/resources/cloud/instances/flavors.py +2 -2
  21. gcore/resources/cloud/instances/images.py +318 -2
  22. gcore/resources/cloud/instances/instances.py +534 -70
  23. gcore/resources/cloud/instances/interfaces.py +4 -4
  24. gcore/resources/cloud/load_balancers/flavors.py +2 -2
  25. gcore/resources/cloud/load_balancers/l7_policies/l7_policies.py +302 -20
  26. gcore/resources/cloud/load_balancers/l7_policies/rules.py +326 -0
  27. gcore/resources/cloud/load_balancers/listeners.py +385 -20
  28. gcore/resources/cloud/load_balancers/load_balancers.py +392 -24
  29. gcore/resources/cloud/load_balancers/pools/health_monitors.py +24 -0
  30. gcore/resources/cloud/load_balancers/pools/members.py +34 -6
  31. gcore/resources/cloud/load_balancers/pools/pools.py +388 -8
  32. gcore/resources/cloud/networks/networks.py +72 -16
  33. gcore/resources/cloud/networks/subnets.py +6 -6
  34. gcore/resources/cloud/registries/registries.py +6 -10
  35. gcore/resources/cloud/registries/users.py +4 -10
  36. gcore/resources/cloud/reserved_fixed_ips/reserved_fixed_ips.py +10 -10
  37. gcore/resources/cloud/secrets.py +56 -11
  38. gcore/resources/cloud/security_groups/security_groups.py +2 -2
  39. gcore/resources/cloud/ssh_keys.py +2 -2
  40. gcore/resources/cloud/tasks.py +203 -184
  41. gcore/resources/cloud/users/role_assignments.py +4 -4
  42. gcore/resources/cloud/volumes.py +18 -18
  43. gcore/resources/waap/__init__.py +131 -0
  44. gcore/resources/waap/advanced_rules.py +135 -0
  45. gcore/resources/waap/clients.py +135 -0
  46. gcore/resources/waap/custom_page_sets.py +805 -0
  47. gcore/resources/waap/domains/__init__.py +173 -0
  48. gcore/resources/waap/domains/advanced_rules.py +876 -0
  49. gcore/resources/waap/domains/analytics/__init__.py +33 -0
  50. gcore/resources/waap/domains/analytics/analytics.py +676 -0
  51. gcore/resources/waap/domains/analytics/requests.py +378 -0
  52. gcore/resources/waap/domains/api_discovery/__init__.py +33 -0
  53. gcore/resources/waap/domains/api_discovery/api_discovery.py +530 -0
  54. gcore/resources/waap/domains/api_discovery/scan_results.py +352 -0
  55. gcore/resources/waap/domains/api_path_groups.py +163 -0
  56. gcore/resources/waap/domains/api_paths.py +771 -0
  57. gcore/resources/waap/domains/custom_rules.py +889 -0
  58. gcore/resources/waap/domains/domains.py +914 -0
  59. gcore/resources/waap/domains/firewall_rules.py +884 -0
  60. gcore/resources/waap/domains/insight_silences.py +689 -0
  61. gcore/resources/waap/domains/insights.py +425 -0
  62. gcore/resources/waap/domains/policies.py +173 -0
  63. gcore/resources/waap/domains/settings.py +271 -0
  64. gcore/resources/waap/ip_info.py +1017 -0
  65. gcore/resources/waap/organizations.py +217 -0
  66. gcore/resources/waap/statistics.py +225 -0
  67. gcore/resources/waap/tags.py +233 -0
  68. gcore/resources/waap/waap.py +391 -0
  69. gcore/types/cloud/__init__.py +1 -0
  70. gcore/types/cloud/allowed_address_pairs.py +2 -2
  71. gcore/types/cloud/baremetal/baremetal_server.py +1 -1
  72. gcore/types/cloud/baremetal/image_list_params.py +1 -1
  73. gcore/types/cloud/baremetal/server_create_params.py +9 -9
  74. gcore/types/cloud/baremetal/server_list_params.py +8 -8
  75. gcore/types/cloud/baremetal/server_rebuild_params.py +1 -1
  76. gcore/types/cloud/baremetal_flavor.py +3 -3
  77. gcore/types/cloud/billing_reservation_list_params.py +5 -0
  78. gcore/types/cloud/container_probe_config.py +1 -1
  79. gcore/types/cloud/container_probe_config_create_param.py +2 -3
  80. gcore/types/cloud/container_scale_triggers.py +2 -2
  81. gcore/types/cloud/file_share.py +3 -0
  82. gcore/types/cloud/file_share_list_params.py +7 -1
  83. gcore/types/cloud/floating_ip_detailed.py +1 -1
  84. gcore/types/cloud/floating_ip_list_params.py +2 -2
  85. gcore/types/cloud/gpu_baremetal_cluster.py +1 -1
  86. gcore/types/cloud/gpu_baremetal_cluster_create_params.py +21 -1
  87. gcore/types/cloud/gpu_baremetal_cluster_delete_params.py +1 -1
  88. gcore/types/cloud/gpu_baremetal_cluster_rebuild_params.py +1 -1
  89. gcore/types/cloud/gpu_baremetal_cluster_server.py +1 -1
  90. gcore/types/cloud/gpu_baremetal_clusters/image_upload_params.py +1 -1
  91. gcore/types/cloud/gpu_baremetal_clusters/server_attach_interface_params.py +10 -10
  92. gcore/types/cloud/gpu_baremetal_flavor.py +3 -3
  93. gcore/types/cloud/image.py +1 -1
  94. gcore/types/cloud/inference/deployment_create_params.py +4 -4
  95. gcore/types/cloud/inference/deployment_update_params.py +206 -9
  96. gcore/types/cloud/inference/inference.py +5 -5
  97. gcore/types/cloud/instance.py +1 -1
  98. gcore/types/cloud/instance_create_params.py +8 -10
  99. gcore/types/cloud/instance_list_params.py +8 -8
  100. gcore/types/cloud/instances/flavor_list_suitable_params.py +4 -1
  101. gcore/types/cloud/instances/image_list_params.py +1 -1
  102. gcore/types/cloud/instances/instance_flavor.py +3 -3
  103. gcore/types/cloud/instances/interface_attach_params.py +10 -10
  104. gcore/types/cloud/load_balancer_create_params.py +17 -15
  105. gcore/types/cloud/load_balancer_flavor_detail.py +3 -3
  106. gcore/types/cloud/load_balancer_l7_policy.py +5 -5
  107. gcore/types/cloud/load_balancer_list_params.py +5 -5
  108. gcore/types/cloud/load_balancer_listener_detail.py +17 -17
  109. gcore/types/cloud/load_balancer_pool.py +13 -13
  110. gcore/types/cloud/load_balancer_pool_list.py +99 -4
  111. gcore/types/cloud/load_balancers/l7_policy_create_params.py +5 -5
  112. gcore/types/cloud/load_balancers/l7_policy_replace_params.py +5 -5
  113. gcore/types/cloud/load_balancers/listener_create_params.py +6 -4
  114. gcore/types/cloud/load_balancers/listener_get_params.py +3 -1
  115. gcore/types/cloud/load_balancers/listener_list_params.py +4 -2
  116. gcore/types/cloud/load_balancers/listener_update_params.py +5 -3
  117. gcore/types/cloud/load_balancers/pool_create_params.py +6 -4
  118. gcore/types/cloud/load_balancers/pool_list_params.py +5 -6
  119. gcore/types/cloud/load_balancers/pool_update_params.py +6 -4
  120. gcore/types/cloud/load_balancers/pools/health_monitor_create_params.py +2 -0
  121. gcore/types/cloud/load_balancers/pools/member_add_params.py +5 -3
  122. gcore/types/cloud/member.py +2 -2
  123. gcore/types/cloud/network.py +22 -22
  124. gcore/types/cloud/network_create_params.py +2 -0
  125. gcore/types/cloud/network_details.py +25 -24
  126. gcore/types/cloud/network_list_params.py +15 -10
  127. gcore/types/cloud/network_update_params.py +2 -0
  128. gcore/types/cloud/networks/subnet_create_params.py +1 -1
  129. gcore/types/cloud/networks/subnet_list_params.py +2 -2
  130. gcore/types/cloud/quota_get_all_response.py +18 -0
  131. gcore/types/cloud/quota_get_by_region_response.py +18 -0
  132. gcore/types/cloud/quotas/request_create_params.py +9 -0
  133. gcore/types/cloud/quotas/request_get_response.py +9 -0
  134. gcore/types/cloud/quotas/request_list_response.py +9 -0
  135. gcore/types/cloud/region.py +4 -4
  136. gcore/types/cloud/registries/user_create_multiple_params.py +3 -5
  137. gcore/types/cloud/registries/user_create_params.py +3 -5
  138. gcore/types/cloud/registry_create_params.py +3 -5
  139. gcore/types/cloud/reserved_fixed_ip_create_params.py +2 -2
  140. gcore/types/cloud/reserved_fixed_ip_list_params.py +3 -3
  141. gcore/types/cloud/secret_list_params.py +24 -0
  142. gcore/types/cloud/security_group_list_params.py +1 -1
  143. gcore/types/cloud/session_persistence.py +1 -1
  144. gcore/types/cloud/ssh_key_created.py +3 -6
  145. gcore/types/cloud/task.py +1 -4
  146. gcore/types/cloud/task_list_params.py +56 -46
  147. gcore/types/cloud/users/role_assignment_create_params.py +1 -1
  148. gcore/types/cloud/users/role_assignment_update_params.py +1 -1
  149. gcore/types/cloud/volume_create_params.py +6 -6
  150. gcore/types/cloud/volume_list_params.py +3 -3
  151. gcore/types/waap/__init__.py +108 -0
  152. gcore/types/waap/client_me_response.py +34 -0
  153. gcore/types/waap/custom_page_set_create_params.py +35 -0
  154. gcore/types/waap/custom_page_set_list_params.py +25 -0
  155. gcore/types/waap/custom_page_set_preview_params.py +34 -0
  156. gcore/types/waap/custom_page_set_update_params.py +35 -0
  157. gcore/types/waap/domain_list_params.py +30 -0
  158. gcore/types/waap/domain_list_rule_sets_response.py +10 -0
  159. gcore/types/waap/domain_update_params.py +12 -0
  160. gcore/types/waap/domains/__init__.py +47 -0
  161. gcore/types/waap/domains/advanced_rule_create_params.py +80 -0
  162. gcore/types/waap/domains/advanced_rule_list_params.py +58 -0
  163. gcore/types/waap/domains/advanced_rule_update_params.py +83 -0
  164. gcore/types/waap/domains/analytics/__init__.py +5 -0
  165. gcore/types/waap/domains/analytics/request_list_params.py +53 -0
  166. gcore/types/waap/domains/analytics_get_event_statistics_params.py +34 -0
  167. gcore/types/waap/domains/analytics_list_ddos_attacks_params.py +28 -0
  168. gcore/types/waap/domains/analytics_list_ddos_info_params.py +31 -0
  169. gcore/types/waap/domains/analytics_list_event_traffic_params.py +26 -0
  170. gcore/types/waap/domains/analytics_list_event_traffic_response.py +10 -0
  171. gcore/types/waap/domains/api_discovery/__init__.py +7 -0
  172. gcore/types/waap/domains/api_discovery/scan_result_get_response.py +29 -0
  173. gcore/types/waap/domains/api_discovery/scan_result_list_params.py +41 -0
  174. gcore/types/waap/domains/api_discovery/scan_result_list_response.py +29 -0
  175. gcore/types/waap/domains/api_discovery_get_settings_response.py +36 -0
  176. gcore/types/waap/domains/api_discovery_scan_openapi_response.py +10 -0
  177. gcore/types/waap/domains/api_discovery_update_settings_params.py +34 -0
  178. gcore/types/waap/domains/api_discovery_update_settings_response.py +36 -0
  179. gcore/types/waap/domains/api_discovery_upload_openapi_params.py +19 -0
  180. gcore/types/waap/domains/api_discovery_upload_openapi_response.py +10 -0
  181. gcore/types/waap/domains/api_path_create_params.py +31 -0
  182. gcore/types/waap/domains/api_path_create_response.py +50 -0
  183. gcore/types/waap/domains/api_path_get_response.py +50 -0
  184. gcore/types/waap/domains/api_path_group_list_response.py +12 -0
  185. gcore/types/waap/domains/api_path_list_params.py +62 -0
  186. gcore/types/waap/domains/api_path_list_response.py +50 -0
  187. gcore/types/waap/domains/api_path_update_params.py +29 -0
  188. gcore/types/waap/domains/custom_rule_create_params.py +368 -0
  189. gcore/types/waap/domains/custom_rule_delete_multiple_params.py +13 -0
  190. gcore/types/waap/domains/custom_rule_list_params.py +35 -0
  191. gcore/types/waap/domains/custom_rule_update_params.py +371 -0
  192. gcore/types/waap/domains/firewall_rule_create_params.py +75 -0
  193. gcore/types/waap/domains/firewall_rule_delete_multiple_params.py +13 -0
  194. gcore/types/waap/domains/firewall_rule_list_params.py +33 -0
  195. gcore/types/waap/domains/firewall_rule_update_params.py +78 -0
  196. gcore/types/waap/domains/insight_list_params.py +34 -0
  197. gcore/types/waap/domains/insight_replace_params.py +17 -0
  198. gcore/types/waap/domains/insight_silence_create_params.py +28 -0
  199. gcore/types/waap/domains/insight_silence_list_params.py +33 -0
  200. gcore/types/waap/domains/insight_silence_update_params.py +28 -0
  201. gcore/types/waap/domains/setting_update_params.py +48 -0
  202. gcore/types/waap/ip_info_get_attack_time_series_params.py +12 -0
  203. gcore/types/waap/ip_info_get_attack_time_series_response.py +10 -0
  204. gcore/types/waap/ip_info_get_blocked_requests_params.py +15 -0
  205. gcore/types/waap/ip_info_get_blocked_requests_response.py +10 -0
  206. gcore/types/waap/ip_info_get_counts_params.py +19 -0
  207. gcore/types/waap/ip_info_get_ddos_attack_series_params.py +12 -0
  208. gcore/types/waap/ip_info_get_params.py +12 -0
  209. gcore/types/waap/ip_info_get_top_sessions_params.py +15 -0
  210. gcore/types/waap/ip_info_get_top_sessions_response.py +10 -0
  211. gcore/types/waap/ip_info_get_top_urls_params.py +15 -0
  212. gcore/types/waap/ip_info_get_top_urls_response.py +10 -0
  213. gcore/types/waap/ip_info_get_top_user_agents_params.py +15 -0
  214. gcore/types/waap/ip_info_get_top_user_agents_response.py +10 -0
  215. gcore/types/waap/ip_info_list_attacked_countries_params.py +12 -0
  216. gcore/types/waap/ip_info_list_attacked_countries_response.py +10 -0
  217. gcore/types/waap/organization_list_params.py +22 -0
  218. gcore/types/waap/statistic_get_usage_series_params.py +25 -0
  219. gcore/types/waap/tag_list_params.py +28 -0
  220. gcore/types/waap/waap_advanced_rule.py +83 -0
  221. gcore/types/waap/waap_advanced_rule_descriptor.py +49 -0
  222. gcore/types/waap/waap_advanced_rule_descriptor_list.py +15 -0
  223. gcore/types/waap/waap_block_csrf_page_data.py +28 -0
  224. gcore/types/waap/waap_block_csrf_page_data_param.py +28 -0
  225. gcore/types/waap/waap_block_page_data.py +28 -0
  226. gcore/types/waap/waap_block_page_data_param.py +28 -0
  227. gcore/types/waap/waap_blocked_statistics.py +36 -0
  228. gcore/types/waap/waap_captcha_page_data.py +31 -0
  229. gcore/types/waap/waap_captcha_page_data_param.py +31 -0
  230. gcore/types/waap/waap_common_tag.py +16 -0
  231. gcore/types/waap/waap_cookie_disabled_page_data.py +18 -0
  232. gcore/types/waap/waap_cookie_disabled_page_data_param.py +18 -0
  233. gcore/types/waap/waap_count_statistics.py +36 -0
  234. gcore/types/waap/waap_custom_page_preview.py +10 -0
  235. gcore/types/waap/waap_custom_page_set.py +36 -0
  236. gcore/types/waap/waap_custom_rule.py +373 -0
  237. gcore/types/waap/waap_customer_rule_state.py +7 -0
  238. gcore/types/waap/waap_ddos_attack.py +16 -0
  239. gcore/types/waap/waap_ddos_info.py +17 -0
  240. gcore/types/waap/waap_detailed_domain.py +37 -0
  241. gcore/types/waap/waap_domain_api_settings.py +22 -0
  242. gcore/types/waap/waap_domain_ddos_settings.py +31 -0
  243. gcore/types/waap/waap_domain_policy.py +29 -0
  244. gcore/types/waap/waap_domain_settings_model.py +15 -0
  245. gcore/types/waap/waap_domain_status.py +7 -0
  246. gcore/types/waap/waap_event_statistics.py +15 -0
  247. gcore/types/waap/waap_firewall_rule.py +78 -0
  248. gcore/types/waap/waap_get_account_overview_response.py +34 -0
  249. gcore/types/waap/waap_handshake_page_data.py +25 -0
  250. gcore/types/waap/waap_handshake_page_data_param.py +25 -0
  251. gcore/types/waap/waap_insight.py +38 -0
  252. gcore/types/waap/waap_insight_silence.py +28 -0
  253. gcore/types/waap/waap_insight_silence_sort_by.py +9 -0
  254. gcore/types/waap/waap_insight_sort_by.py +20 -0
  255. gcore/types/waap/waap_insight_status.py +7 -0
  256. gcore/types/waap/waap_ip_country_attack.py +16 -0
  257. gcore/types/waap/waap_ip_ddos_info_model.py +23 -0
  258. gcore/types/waap/waap_ip_info.py +57 -0
  259. gcore/types/waap/waap_ip_info_counts.py +16 -0
  260. gcore/types/waap/waap_javascript_disabled_page_data.py +18 -0
  261. gcore/types/waap/waap_javascript_disabled_page_data_param.py +18 -0
  262. gcore/types/waap/waap_network_details.py +17 -0
  263. gcore/types/waap/waap_organization.py +13 -0
  264. gcore/types/waap/waap_page_type.py +9 -0
  265. gcore/types/waap/waap_paginated_custom_page_set.py +22 -0
  266. gcore/types/waap/waap_paginated_ddos_attack.py +22 -0
  267. gcore/types/waap/waap_paginated_ddos_info.py +22 -0
  268. gcore/types/waap/waap_paginated_request_summary.py +22 -0
  269. gcore/types/waap/waap_pattern_matched_tag.py +37 -0
  270. gcore/types/waap/waap_policy_action.py +7 -0
  271. gcore/types/waap/waap_policy_mode.py +10 -0
  272. gcore/types/waap/waap_request_details.py +92 -0
  273. gcore/types/waap/waap_request_organization.py +13 -0
  274. gcore/types/waap/waap_request_summary.py +59 -0
  275. gcore/types/waap/waap_resolution.py +7 -0
  276. gcore/types/waap/waap_rule_action_type.py +7 -0
  277. gcore/types/waap/waap_rule_blocked_requests.py +16 -0
  278. gcore/types/waap/waap_rule_set.py +41 -0
  279. gcore/types/waap/waap_statistic_item.py +18 -0
  280. gcore/types/waap/waap_statistics_series.py +16 -0
  281. gcore/types/waap/waap_summary_domain.py +26 -0
  282. gcore/types/waap/waap_tag.py +16 -0
  283. gcore/types/waap/waap_time_series_attack.py +23 -0
  284. gcore/types/waap/waap_top_session.py +24 -0
  285. gcore/types/waap/waap_top_url.py +13 -0
  286. gcore/types/waap/waap_top_user_agent.py +13 -0
  287. gcore/types/waap/waap_traffic_metrics.py +68 -0
  288. gcore/types/waap/waap_traffic_type.py +28 -0
  289. gcore/types/waap/waap_user_agent_details.py +40 -0
  290. {gcore-0.1.0a2.dist-info → gcore-0.3.0.dist-info}/METADATA +3 -3
  291. {gcore-0.1.0a2.dist-info → gcore-0.3.0.dist-info}/RECORD +293 -126
  292. {gcore-0.1.0a2.dist-info → gcore-0.3.0.dist-info}/WHEEL +0 -0
  293. {gcore-0.1.0a2.dist-info → gcore-0.3.0.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,30 @@
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
6
+ from typing_extensions import Literal, TypedDict
7
+
8
+ from .waap_domain_status import WaapDomainStatus
9
+
10
+ __all__ = ["DomainListParams"]
11
+
12
+
13
+ class DomainListParams(TypedDict, total=False):
14
+ ids: Iterable[int]
15
+ """Filter domains based on their IDs"""
16
+
17
+ limit: int
18
+ """Number of items to return"""
19
+
20
+ name: str
21
+ """Filter domains based on the domain name. Supports '\\**' as a wildcard character"""
22
+
23
+ offset: int
24
+ """Number of items to skip"""
25
+
26
+ ordering: Literal["id", "name", "status", "created_at", "-id", "-name", "-status", "-created_at"]
27
+ """Sort the response by given field."""
28
+
29
+ status: WaapDomainStatus
30
+ """The different statuses a domain can have"""
@@ -0,0 +1,10 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from typing import List
4
+ from typing_extensions import TypeAlias
5
+
6
+ from .waap_rule_set import WaapRuleSet
7
+
8
+ __all__ = ["DomainListRuleSetsResponse"]
9
+
10
+ DomainListRuleSetsResponse: TypeAlias = List[WaapRuleSet]
@@ -0,0 +1,12 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing_extensions import Literal, TypedDict
6
+
7
+ __all__ = ["DomainUpdateParams"]
8
+
9
+
10
+ class DomainUpdateParams(TypedDict, total=False):
11
+ status: Literal["active", "monitor"]
12
+ """Domain statuses that can be used when updating a domain"""
@@ -0,0 +1,47 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from __future__ import annotations
4
+
5
+ from .insight_list_params import InsightListParams as InsightListParams
6
+ from .api_path_list_params import APIPathListParams as APIPathListParams
7
+ from .api_path_get_response import APIPathGetResponse as APIPathGetResponse
8
+ from .setting_update_params import SettingUpdateParams as SettingUpdateParams
9
+ from .api_path_create_params import APIPathCreateParams as APIPathCreateParams
10
+ from .api_path_list_response import APIPathListResponse as APIPathListResponse
11
+ from .api_path_update_params import APIPathUpdateParams as APIPathUpdateParams
12
+ from .insight_replace_params import InsightReplaceParams as InsightReplaceParams
13
+ from .custom_rule_list_params import CustomRuleListParams as CustomRuleListParams
14
+ from .api_path_create_response import APIPathCreateResponse as APIPathCreateResponse
15
+ from .advanced_rule_list_params import AdvancedRuleListParams as AdvancedRuleListParams
16
+ from .custom_rule_create_params import CustomRuleCreateParams as CustomRuleCreateParams
17
+ from .custom_rule_update_params import CustomRuleUpdateParams as CustomRuleUpdateParams
18
+ from .firewall_rule_list_params import FirewallRuleListParams as FirewallRuleListParams
19
+ from .advanced_rule_create_params import AdvancedRuleCreateParams as AdvancedRuleCreateParams
20
+ from .advanced_rule_update_params import AdvancedRuleUpdateParams as AdvancedRuleUpdateParams
21
+ from .firewall_rule_create_params import FirewallRuleCreateParams as FirewallRuleCreateParams
22
+ from .firewall_rule_update_params import FirewallRuleUpdateParams as FirewallRuleUpdateParams
23
+ from .insight_silence_list_params import InsightSilenceListParams as InsightSilenceListParams
24
+ from .api_path_group_list_response import APIPathGroupListResponse as APIPathGroupListResponse
25
+ from .insight_silence_create_params import InsightSilenceCreateParams as InsightSilenceCreateParams
26
+ from .insight_silence_update_params import InsightSilenceUpdateParams as InsightSilenceUpdateParams
27
+ from .analytics_list_ddos_info_params import AnalyticsListDDOSInfoParams as AnalyticsListDDOSInfoParams
28
+ from .analytics_list_ddos_attacks_params import AnalyticsListDDOSAttacksParams as AnalyticsListDDOSAttacksParams
29
+ from .custom_rule_delete_multiple_params import CustomRuleDeleteMultipleParams as CustomRuleDeleteMultipleParams
30
+ from .analytics_list_event_traffic_params import AnalyticsListEventTrafficParams as AnalyticsListEventTrafficParams
31
+ from .api_discovery_get_settings_response import APIDiscoveryGetSettingsResponse as APIDiscoveryGetSettingsResponse
32
+ from .api_discovery_scan_openapi_response import APIDiscoveryScanOpenAPIResponse as APIDiscoveryScanOpenAPIResponse
33
+ from .api_discovery_upload_openapi_params import APIDiscoveryUploadOpenAPIParams as APIDiscoveryUploadOpenAPIParams
34
+ from .api_discovery_update_settings_params import APIDiscoveryUpdateSettingsParams as APIDiscoveryUpdateSettingsParams
35
+ from .firewall_rule_delete_multiple_params import FirewallRuleDeleteMultipleParams as FirewallRuleDeleteMultipleParams
36
+ from .analytics_get_event_statistics_params import (
37
+ AnalyticsGetEventStatisticsParams as AnalyticsGetEventStatisticsParams,
38
+ )
39
+ from .analytics_list_event_traffic_response import (
40
+ AnalyticsListEventTrafficResponse as AnalyticsListEventTrafficResponse,
41
+ )
42
+ from .api_discovery_upload_openapi_response import (
43
+ APIDiscoveryUploadOpenAPIResponse as APIDiscoveryUploadOpenAPIResponse,
44
+ )
45
+ from .api_discovery_update_settings_response import (
46
+ APIDiscoveryUpdateSettingsResponse as APIDiscoveryUpdateSettingsResponse,
47
+ )
@@ -0,0 +1,80 @@
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 List, Optional
6
+ from typing_extensions import Literal, Required, TypedDict
7
+
8
+ __all__ = ["AdvancedRuleCreateParams", "Action", "ActionBlock", "ActionTag"]
9
+
10
+
11
+ class AdvancedRuleCreateParams(TypedDict, total=False):
12
+ action: Required[Action]
13
+ """The action that a WAAP rule takes when triggered"""
14
+
15
+ enabled: Required[bool]
16
+ """Whether or not the rule is enabled"""
17
+
18
+ name: Required[str]
19
+ """The name assigned to the rule"""
20
+
21
+ source: Required[str]
22
+ """A CEL syntax expression that contains the rule's conditions.
23
+
24
+ Allowed objects are: request, whois, session, response, tags,
25
+ `user_defined_tags`, `user_agent`, `client_data`. More info can be found here:
26
+ https://gcore.com/docs/waap/waap-rules/advanced-rules
27
+ """
28
+
29
+ description: Optional[str]
30
+ """The description assigned to the rule"""
31
+
32
+ phase: Optional[Literal["access", "header_filter", "body_filter"]]
33
+ """The WAAP request/response phase for applying the rule.
34
+
35
+ Default is "access". The "access" phase is responsible for modifying the request
36
+ before it is sent to the origin server. The "`header_filter`" phase is
37
+ responsible for modifying the HTTP headers of a response before they are sent
38
+ back to the client. The "`body_filter`" phase is responsible for modifying the
39
+ body of a response before it is sent back to the client.
40
+ """
41
+
42
+
43
+ class ActionBlock(TypedDict, total=False):
44
+ action_duration: Optional[str]
45
+ """How long a rule's block action will apply to subsequent requests.
46
+
47
+ Can be specified in seconds or by using a numeral followed by 's', 'm', 'h', or
48
+ 'd' to represent time format (seconds, minutes, hours, or days)
49
+ """
50
+
51
+ status_code: Optional[Literal[403, 405, 418, 429]]
52
+ """Designates the HTTP status code to deliver when a request is blocked."""
53
+
54
+
55
+ class ActionTag(TypedDict, total=False):
56
+ tags: Required[List[str]]
57
+ """The list of user defined tags to tag the request with"""
58
+
59
+
60
+ class Action(TypedDict, total=False):
61
+ allow: Optional[object]
62
+ """The WAAP allowed the request"""
63
+
64
+ block: Optional[ActionBlock]
65
+ """
66
+ WAAP block action behavior could be configured with response status code and
67
+ action duration.
68
+ """
69
+
70
+ captcha: Optional[object]
71
+ """The WAAP presented the user with a captcha"""
72
+
73
+ handshake: Optional[object]
74
+ """The WAAP performed automatic browser validation"""
75
+
76
+ monitor: Optional[object]
77
+ """The WAAP monitored the request but took no action"""
78
+
79
+ tag: Optional[ActionTag]
80
+ """WAAP tag action gets a list of tags to tag the request scope with"""
@@ -0,0 +1,58 @@
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, TypedDict
7
+
8
+ from ..waap_rule_action_type import WaapRuleActionType
9
+
10
+ __all__ = ["AdvancedRuleListParams"]
11
+
12
+
13
+ class AdvancedRuleListParams(TypedDict, total=False):
14
+ action: WaapRuleActionType
15
+ """Filter to refine results by specific actions"""
16
+
17
+ description: str
18
+ """Filter rules based on their description. Supports '\\**' as a wildcard character."""
19
+
20
+ enabled: bool
21
+ """Filter rules based on their active status"""
22
+
23
+ limit: int
24
+ """Number of items to return"""
25
+
26
+ name: str
27
+ """Filter rules based on their name. Supports '\\**' as a wildcard character."""
28
+
29
+ offset: int
30
+ """Number of items to skip"""
31
+
32
+ ordering: Optional[
33
+ Literal[
34
+ "id",
35
+ "name",
36
+ "description",
37
+ "enabled",
38
+ "action",
39
+ "phase",
40
+ "-id",
41
+ "-name",
42
+ "-description",
43
+ "-enabled",
44
+ "-action",
45
+ "-phase",
46
+ ]
47
+ ]
48
+ """Determine the field to order results by"""
49
+
50
+ phase: Literal["access", "header_filter", "body_filter"]
51
+ """
52
+ Filter rules based on the WAAP request/response phase for applying the rule. The
53
+ "access" phase is responsible for modifying the request before it is sent to the
54
+ origin server. The "`header_filter`" phase is responsible for modifying the HTTP
55
+ headers of a response before they are sent back to the client. The
56
+ "`body_filter`" phase is responsible for modifying the body of a response before
57
+ it is sent back to the client.
58
+ """
@@ -0,0 +1,83 @@
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 List, Optional
6
+ from typing_extensions import Literal, Required, TypedDict
7
+
8
+ __all__ = ["AdvancedRuleUpdateParams", "Action", "ActionBlock", "ActionTag"]
9
+
10
+
11
+ class AdvancedRuleUpdateParams(TypedDict, total=False):
12
+ domain_id: Required[int]
13
+ """The domain ID"""
14
+
15
+ action: Optional[Action]
16
+ """The action that a WAAP rule takes when triggered"""
17
+
18
+ description: Optional[str]
19
+ """The description assigned to the rule"""
20
+
21
+ enabled: Optional[bool]
22
+ """Whether or not the rule is enabled"""
23
+
24
+ name: Optional[str]
25
+ """The name assigned to the rule"""
26
+
27
+ phase: Optional[Literal["access", "header_filter", "body_filter"]]
28
+ """
29
+ The WAAP request/response phase for applying the rule. The "access" phase is
30
+ responsible for modifying the request before it is sent to the origin server.
31
+ The "`header_filter`" phase is responsible for modifying the HTTP headers of a
32
+ response before they are sent back to the client. The "`body_filter`" phase is
33
+ responsible for modifying the body of a response before it is sent back to the
34
+ client.
35
+ """
36
+
37
+ source: Optional[str]
38
+ """A CEL syntax expression that contains the rule's conditions.
39
+
40
+ Allowed objects are: request, whois, session, response, tags,
41
+ `user_defined_tags`, `user_agent`, `client_data`. More info can be found here:
42
+ https://gcore.com/docs/waap/waap-rules/advanced-rules
43
+ """
44
+
45
+
46
+ class ActionBlock(TypedDict, total=False):
47
+ action_duration: Optional[str]
48
+ """How long a rule's block action will apply to subsequent requests.
49
+
50
+ Can be specified in seconds or by using a numeral followed by 's', 'm', 'h', or
51
+ 'd' to represent time format (seconds, minutes, hours, or days)
52
+ """
53
+
54
+ status_code: Optional[Literal[403, 405, 418, 429]]
55
+ """Designates the HTTP status code to deliver when a request is blocked."""
56
+
57
+
58
+ class ActionTag(TypedDict, total=False):
59
+ tags: Required[List[str]]
60
+ """The list of user defined tags to tag the request with"""
61
+
62
+
63
+ class Action(TypedDict, total=False):
64
+ allow: Optional[object]
65
+ """The WAAP allowed the request"""
66
+
67
+ block: Optional[ActionBlock]
68
+ """
69
+ WAAP block action behavior could be configured with response status code and
70
+ action duration.
71
+ """
72
+
73
+ captcha: Optional[object]
74
+ """The WAAP presented the user with a captcha"""
75
+
76
+ handshake: Optional[object]
77
+ """The WAAP performed automatic browser validation"""
78
+
79
+ monitor: Optional[object]
80
+ """The WAAP monitored the request but took no action"""
81
+
82
+ tag: Optional[ActionTag]
83
+ """WAAP tag action gets a list of tags to tag the request scope with"""
@@ -0,0 +1,5 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from __future__ import annotations
4
+
5
+ from .request_list_params import RequestListParams as RequestListParams
@@ -0,0 +1,53 @@
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 List, Union
6
+ from datetime import datetime
7
+ from typing_extensions import Literal, Required, Annotated, TypedDict
8
+
9
+ from ....._utils import PropertyInfo
10
+ from ...waap_traffic_type import WaapTrafficType
11
+
12
+ __all__ = ["RequestListParams"]
13
+
14
+
15
+ class RequestListParams(TypedDict, total=False):
16
+ start: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]]
17
+ """Filter traffic starting from a specified date in ISO 8601 format"""
18
+
19
+ actions: List[Literal["allow", "block", "captcha", "handshake"]]
20
+ """Filter the response by actions."""
21
+
22
+ countries: List[str]
23
+ """Filter the response by country codes in ISO 3166-1 alpha-2 format."""
24
+
25
+ end: Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]
26
+ """Filter traffic up to a specified end date in ISO 8601 format.
27
+
28
+ If not provided, defaults to the current date and time.
29
+ """
30
+
31
+ ip: str
32
+ """Filter the response by IP."""
33
+
34
+ limit: int
35
+ """Number of items to return"""
36
+
37
+ offset: int
38
+ """Number of items to skip"""
39
+
40
+ ordering: str
41
+ """Sort the response by given field."""
42
+
43
+ reference_id: str
44
+ """Filter the response by reference ID."""
45
+
46
+ security_rule_name: str
47
+ """Filter the response by security rule name."""
48
+
49
+ status_code: int
50
+ """Filter the response by response code."""
51
+
52
+ traffic_types: List[WaapTrafficType]
53
+ """Filter the response by traffic types."""
@@ -0,0 +1,34 @@
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 List, Union, Optional
6
+ from datetime import datetime
7
+ from typing_extensions import Literal, Required, Annotated, TypedDict
8
+
9
+ from ...._utils import PropertyInfo
10
+
11
+ __all__ = ["AnalyticsGetEventStatisticsParams"]
12
+
13
+
14
+ class AnalyticsGetEventStatisticsParams(TypedDict, total=False):
15
+ start: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]]
16
+ """Filter traffic starting from a specified date in ISO 8601 format"""
17
+
18
+ action: Optional[List[Literal["block", "captcha", "handshake", "monitor"]]]
19
+ """A list of action names to filter on."""
20
+
21
+ end: Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]
22
+ """Filter traffic up to a specified end date in ISO 8601 format.
23
+
24
+ If not provided, defaults to the current date and time.
25
+ """
26
+
27
+ ip: Optional[List[str]]
28
+ """A list of IPs to filter event statistics."""
29
+
30
+ reference_id: Optional[List[str]]
31
+ """A list of reference IDs to filter event statistics."""
32
+
33
+ result: Optional[List[Literal["passed", "blocked", "monitored", "allowed"]]]
34
+ """A list of results to filter event statistics."""
@@ -0,0 +1,28 @@
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
6
+ from datetime import datetime
7
+ from typing_extensions import Literal, Annotated, TypedDict
8
+
9
+ from ...._utils import PropertyInfo
10
+
11
+ __all__ = ["AnalyticsListDDOSAttacksParams"]
12
+
13
+
14
+ class AnalyticsListDDOSAttacksParams(TypedDict, total=False):
15
+ end_time: Annotated[Union[str, datetime, None], PropertyInfo(format="iso8601")]
16
+ """Filter attacks up to a specified end date in ISO 8601 format"""
17
+
18
+ limit: int
19
+ """Number of items to return"""
20
+
21
+ offset: int
22
+ """Number of items to skip"""
23
+
24
+ ordering: Literal["start_time", "-start_time", "end_time", "-end_time"]
25
+ """Sort the response by given field."""
26
+
27
+ start_time: Annotated[Union[str, datetime, None], PropertyInfo(format="iso8601")]
28
+ """Filter attacks starting from a specified date in ISO 8601 format"""
@@ -0,0 +1,31 @@
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
6
+ from datetime import datetime
7
+ from typing_extensions import Literal, Required, Annotated, TypedDict
8
+
9
+ from ...._utils import PropertyInfo
10
+
11
+ __all__ = ["AnalyticsListDDOSInfoParams"]
12
+
13
+
14
+ class AnalyticsListDDOSInfoParams(TypedDict, total=False):
15
+ group_by: Required[Literal["URL", "User-Agent", "IP"]]
16
+ """The identity of the requests to group by"""
17
+
18
+ start: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]]
19
+ """Filter traffic starting from a specified date in ISO 8601 format"""
20
+
21
+ end: Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]
22
+ """Filter traffic up to a specified end date in ISO 8601 format.
23
+
24
+ If not provided, defaults to the current date and time.
25
+ """
26
+
27
+ limit: int
28
+ """Number of items to return"""
29
+
30
+ offset: int
31
+ """Number of items to skip"""
@@ -0,0 +1,26 @@
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
6
+ from datetime import datetime
7
+ from typing_extensions import Required, Annotated, TypedDict
8
+
9
+ from ...._utils import PropertyInfo
10
+ from ..waap_resolution import WaapResolution
11
+
12
+ __all__ = ["AnalyticsListEventTrafficParams"]
13
+
14
+
15
+ class AnalyticsListEventTrafficParams(TypedDict, total=False):
16
+ resolution: Required[WaapResolution]
17
+ """Specifies the granularity of the result data."""
18
+
19
+ start: Required[Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]]
20
+ """Filter traffic starting from a specified date in ISO 8601 format"""
21
+
22
+ end: Annotated[Union[str, datetime], PropertyInfo(format="iso8601")]
23
+ """Filter traffic up to a specified end date in ISO 8601 format.
24
+
25
+ If not provided, defaults to the current date and time.
26
+ """
@@ -0,0 +1,10 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from typing import List
4
+ from typing_extensions import TypeAlias
5
+
6
+ from ..waap_traffic_metrics import WaapTrafficMetrics
7
+
8
+ __all__ = ["AnalyticsListEventTrafficResponse"]
9
+
10
+ AnalyticsListEventTrafficResponse: TypeAlias = List[WaapTrafficMetrics]
@@ -0,0 +1,7 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from __future__ import annotations
4
+
5
+ from .scan_result_list_params import ScanResultListParams as ScanResultListParams
6
+ from .scan_result_get_response import ScanResultGetResponse as ScanResultGetResponse
7
+ from .scan_result_list_response import ScanResultListResponse as ScanResultListResponse
@@ -0,0 +1,29 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from typing import Optional
4
+ from datetime import datetime
5
+ from typing_extensions import Literal
6
+
7
+ from ....._models import BaseModel
8
+
9
+ __all__ = ["ScanResultGetResponse"]
10
+
11
+
12
+ class ScanResultGetResponse(BaseModel):
13
+ id: str
14
+ """The scan ID"""
15
+
16
+ end_time: Optional[datetime] = None
17
+ """The date and time the scan ended"""
18
+
19
+ message: str
20
+ """The message associated with the scan"""
21
+
22
+ start_time: datetime
23
+ """The date and time the scan started"""
24
+
25
+ status: Literal["SUCCESS", "FAILURE", "IN_PROGRESS"]
26
+ """The different statuses a task result can have"""
27
+
28
+ type: Literal["TRAFFIC_SCAN", "API_DESCRIPTION_FILE_SCAN"]
29
+ """The different types of scans that can be performed"""
@@ -0,0 +1,41 @@
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, TypedDict
7
+
8
+ __all__ = ["ScanResultListParams"]
9
+
10
+
11
+ class ScanResultListParams(TypedDict, total=False):
12
+ limit: int
13
+ """Number of items to return"""
14
+
15
+ message: Optional[str]
16
+ """Filter by the message of the scan. Supports '\\**' as a wildcard character"""
17
+
18
+ offset: int
19
+ """Number of items to skip"""
20
+
21
+ ordering: Literal[
22
+ "id",
23
+ "type",
24
+ "start_time",
25
+ "end_time",
26
+ "status",
27
+ "message",
28
+ "-id",
29
+ "-type",
30
+ "-start_time",
31
+ "-end_time",
32
+ "-status",
33
+ "-message",
34
+ ]
35
+ """Sort the response by given field."""
36
+
37
+ status: Optional[Literal["SUCCESS", "FAILURE", "IN_PROGRESS"]]
38
+ """The different statuses a task result can have"""
39
+
40
+ type: Optional[Literal["TRAFFIC_SCAN", "API_DESCRIPTION_FILE_SCAN"]]
41
+ """The different types of scans that can be performed"""
@@ -0,0 +1,29 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from typing import Optional
4
+ from datetime import datetime
5
+ from typing_extensions import Literal
6
+
7
+ from ....._models import BaseModel
8
+
9
+ __all__ = ["ScanResultListResponse"]
10
+
11
+
12
+ class ScanResultListResponse(BaseModel):
13
+ id: str
14
+ """The scan ID"""
15
+
16
+ end_time: Optional[datetime] = None
17
+ """The date and time the scan ended"""
18
+
19
+ message: str
20
+ """The message associated with the scan"""
21
+
22
+ start_time: datetime
23
+ """The date and time the scan started"""
24
+
25
+ status: Literal["SUCCESS", "FAILURE", "IN_PROGRESS"]
26
+ """The different statuses a task result can have"""
27
+
28
+ type: Literal["TRAFFIC_SCAN", "API_DESCRIPTION_FILE_SCAN"]
29
+ """The different types of scans that can be performed"""
@@ -0,0 +1,36 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from typing import Optional
4
+
5
+ from pydantic import Field as FieldInfo
6
+
7
+ from ...._models import BaseModel
8
+
9
+ __all__ = ["APIDiscoveryGetSettingsResponse"]
10
+
11
+
12
+ class APIDiscoveryGetSettingsResponse(BaseModel):
13
+ description_file_location: Optional[str] = FieldInfo(alias="descriptionFileLocation", default=None)
14
+ """The URL of the API description file.
15
+
16
+ This will be periodically scanned if `descriptionFileScanEnabled` is enabled.
17
+ Supported formats are YAML and JSON, and it must adhere to OpenAPI versions 2,
18
+ 3, or 3.1.
19
+ """
20
+
21
+ description_file_scan_enabled: Optional[bool] = FieldInfo(alias="descriptionFileScanEnabled", default=None)
22
+ """Indicates if periodic scan of the description file is enabled"""
23
+
24
+ description_file_scan_interval_hours: Optional[int] = FieldInfo(
25
+ alias="descriptionFileScanIntervalHours", default=None
26
+ )
27
+ """The interval in hours for scanning the description file"""
28
+
29
+ traffic_scan_enabled: Optional[bool] = FieldInfo(alias="trafficScanEnabled", default=None)
30
+ """Indicates if traffic scan is enabled.
31
+
32
+ Traffic scan is used to discover undocumented APIs
33
+ """
34
+
35
+ traffic_scan_interval_hours: Optional[int] = FieldInfo(alias="trafficScanIntervalHours", default=None)
36
+ """The interval in hours for scanning the traffic"""