From a1638393599a05aa5be92ef7f1e4170e4fdd7911 Mon Sep 17 00:00:00 2001 From: "stainless-app[bot]" <142633134+stainless-app[bot]@users.noreply.github.com> Date: Thu, 11 Apr 2024 23:48:02 +0000 Subject: [PATCH] feat(api): update via SDK Studio (#298) --- .stats.yml | 2 +- api.md | 54 +- src/cloudflare/resources/rulesets/rules.py | 128 +-- .../dispatch/namespaces/scripts/__init__.py | 28 + .../dispatch/namespaces/scripts/scripts.py | 64 ++ .../dispatch/namespaces/scripts/secrets.py | 327 ++++++ .../dispatch/namespaces/scripts/tags.py | 420 ++++++++ src/cloudflare/types/__init__.py | 2 - src/cloudflare/types/hostname.py | 48 - src/cloudflare/types/hostname_param.py | 23 - src/cloudflare/types/ruleset_create_params.py | 879 +--------------- .../types/ruleset_create_response.py | 977 +----------------- src/cloudflare/types/ruleset_get_response.py | 977 +----------------- src/cloudflare/types/ruleset_update_params.py | 879 +--------------- .../types/ruleset_update_response.py | 977 +----------------- src/cloudflare/types/rulesets/__init__.py | 24 + .../types/rulesets/challenge_rule.py | 45 + .../types/rulesets/challenge_rule_param.py | 35 + .../types/rulesets/compress_response_rule.py | 55 + .../rulesets/compress_response_rule_param.py | 46 + .../types/rulesets/js_challenge_rule.py | 45 + .../types/rulesets/js_challenge_rule_param.py | 35 + .../types/rulesets/managed_challenge_rule.py | 45 + .../rulesets/managed_challenge_rule_param.py | 35 + .../types/rulesets/phase_get_response.py | 971 +---------------- .../types/rulesets/phase_update_params.py | 873 +--------------- .../types/rulesets/phase_update_response.py | 971 +---------------- .../rulesets/phases/version_get_response.py | 971 +---------------- .../types/rulesets/redirect_rule.py | 95 ++ .../types/rulesets/redirect_rule_param.py | 86 ++ src/cloudflare/types/rulesets/rewrite_rule.py | 93 ++ .../types/rulesets/rewrite_rule_param.py | 84 ++ .../types/rulesets/rewrite_uri_part.py | 20 + .../types/rulesets/rewrite_uri_part_param.py | 21 + src/cloudflare/types/rulesets/route_rule.py | 69 ++ .../types/rulesets/route_rule_param.py | 59 ++ .../types/rulesets/rule_create_params.py | 335 +++--- .../types/rulesets/rule_create_response.py | 971 +---------------- .../types/rulesets/rule_delete_response.py | 971 +---------------- .../types/rulesets/rule_edit_params.py | 335 +++--- .../types/rulesets/rule_edit_response.py | 971 +---------------- src/cloudflare/types/rulesets/score_rule.py | 53 + .../types/rulesets/score_rule_param.py | 43 + .../types/rulesets/serve_error_rule.py | 56 + .../types/rulesets/serve_error_rule_param.py | 46 + .../types/rulesets/set_cache_settings_rule.py | 322 ++++++ .../rulesets/set_cache_settings_rule_param.py | 319 ++++++ .../types/rulesets/set_config_rule.py | 103 ++ .../types/rulesets/set_config_rule_param.py | 93 ++ .../types/rulesets/version_get_response.py | 971 +---------------- .../rulesets/versions/by_tag_get_response.py | 971 +---------------- .../types/warp_connector_create_response.py | 39 +- .../types/warp_connector_delete_response.py | 39 +- .../types/warp_connector_edit_response.py | 39 +- .../types/warp_connector_get_response.py | 39 +- .../types/warp_connector_list_response.py | 39 +- .../dispatch/namespaces/scripts/__init__.py | 6 + .../scripts/secret_list_response.py | 16 + .../scripts/secret_update_params.py | 24 + .../scripts/secret_update_response.py | 16 + .../namespaces/scripts/tag_list_response.py | 6 + .../namespaces/scripts/tag_update_params.py | 19 + .../namespaces/scripts/tag_update_response.py | 7 + src/cloudflare/types/zero_trust/connection.py | 25 +- src/cloudflare/types/zero_trust/tunnel.py | 38 +- .../zero_trust/tunnel_create_response.py | 19 +- .../zero_trust/tunnel_delete_response.py | 19 +- .../types/zero_trust/tunnel_edit_response.py | 38 +- .../types/zero_trust/tunnel_get_response.py | 19 +- .../types/zero_trust/tunnel_list_response.py | 38 +- .../types/zero_trust/tunnel_param.py | 32 +- .../types/zero_trust/tunnels/client.py | 36 +- .../namespaces/scripts/test_secrets.py | 310 ++++++ .../dispatch/namespaces/scripts/test_tags.py | 450 ++++++++ 74 files changed, 4757 insertions(+), 13579 deletions(-) create mode 100644 src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/secrets.py create mode 100644 src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/tags.py delete mode 100644 src/cloudflare/types/hostname.py delete mode 100644 src/cloudflare/types/hostname_param.py create mode 100644 src/cloudflare/types/rulesets/challenge_rule.py create mode 100644 src/cloudflare/types/rulesets/challenge_rule_param.py create mode 100644 src/cloudflare/types/rulesets/compress_response_rule.py create mode 100644 src/cloudflare/types/rulesets/compress_response_rule_param.py create mode 100644 src/cloudflare/types/rulesets/js_challenge_rule.py create mode 100644 src/cloudflare/types/rulesets/js_challenge_rule_param.py create mode 100644 src/cloudflare/types/rulesets/managed_challenge_rule.py create mode 100644 src/cloudflare/types/rulesets/managed_challenge_rule_param.py create mode 100644 src/cloudflare/types/rulesets/redirect_rule.py create mode 100644 src/cloudflare/types/rulesets/redirect_rule_param.py create mode 100644 src/cloudflare/types/rulesets/rewrite_rule.py create mode 100644 src/cloudflare/types/rulesets/rewrite_rule_param.py create mode 100644 src/cloudflare/types/rulesets/rewrite_uri_part.py create mode 100644 src/cloudflare/types/rulesets/rewrite_uri_part_param.py create mode 100644 src/cloudflare/types/rulesets/route_rule.py create mode 100644 src/cloudflare/types/rulesets/route_rule_param.py create mode 100644 src/cloudflare/types/rulesets/score_rule.py create mode 100644 src/cloudflare/types/rulesets/score_rule_param.py create mode 100644 src/cloudflare/types/rulesets/serve_error_rule.py create mode 100644 src/cloudflare/types/rulesets/serve_error_rule_param.py create mode 100644 src/cloudflare/types/rulesets/set_cache_settings_rule.py create mode 100644 src/cloudflare/types/rulesets/set_cache_settings_rule_param.py create mode 100644 src/cloudflare/types/rulesets/set_config_rule.py create mode 100644 src/cloudflare/types/rulesets/set_config_rule_param.py create mode 100644 src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_list_response.py create mode 100644 src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_params.py create mode 100644 src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_response.py create mode 100644 src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_list_response.py create mode 100644 src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_params.py create mode 100644 src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_response.py create mode 100644 tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_secrets.py create mode 100644 tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_tags.py diff --git a/.stats.yml b/.stats.yml index 0818ecbb822..d0e375fdcb3 100644 --- a/.stats.yml +++ b/.stats.yml @@ -1 +1 @@ -configured_endpoints: 1251 +configured_endpoints: 1256 diff --git a/api.md b/api.md index 54eaf9c3a94..229e19728c8 100644 --- a/api.md +++ b/api.md @@ -2014,7 +2014,7 @@ Methods: Types: ```python -from cloudflare.types import Hostname, KeylessCertificate, Tunnel, KeylessCertificateDeleteResponse +from cloudflare.types import KeylessCertificate, Tunnel, KeylessCertificateDeleteResponse ``` Methods: @@ -2204,11 +2204,7 @@ Methods: Types: ```python -from cloudflare.types.origin_tls_client_auth import ( - AuthenticatedOriginPull, - ID, - HostnameUpdateResponse, -) +from cloudflare.types.origin_tls_client_auth import AuthenticatedOriginPull, HostnameUpdateResponse ``` Methods: @@ -3043,10 +3039,22 @@ Types: ```python from cloudflare.types.rulesets import ( BlockRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, + JsChallengeRule, LogRule, Logging, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RewriteURIPart, + RouteRule, RulesetRule, + ScoreRule, + ServeErrorRule, + SetCacheSettingsRule, + SetConfigRule, SkipRule, RuleCreateResponse, RuleDeleteResponse, @@ -4684,6 +4692,40 @@ Methods: - client.workers_for_platforms.dispatch.namespaces.scripts.bindings.get(script_name, \*, account_id, dispatch_namespace) -> BindingGetResponse +##### Secrets + +Types: + +```python +from cloudflare.types.workers_for_platforms.dispatch.namespaces.scripts import ( + SecretUpdateResponse, + SecretListResponse, +) +``` + +Methods: + +- client.workers_for_platforms.dispatch.namespaces.scripts.secrets.update(script_name, \*, account_id, dispatch_namespace, \*\*params) -> SecretUpdateResponse +- client.workers_for_platforms.dispatch.namespaces.scripts.secrets.list(script_name, \*, account_id, dispatch_namespace) -> SyncSinglePage[SecretListResponse] + +##### Tags + +Types: + +```python +from cloudflare.types.workers_for_platforms.dispatch.namespaces.scripts import ( + TagUpdateResponse, + TagListResponse, + TagDeleteResponse, +) +``` + +Methods: + +- client.workers_for_platforms.dispatch.namespaces.scripts.tags.update(script_name, \*, account_id, dispatch_namespace, \*\*params) -> TagUpdateResponse +- client.workers_for_platforms.dispatch.namespaces.scripts.tags.list(script_name, \*, account_id, dispatch_namespace) -> SyncSinglePage[TagListResponse] +- client.workers_for_platforms.dispatch.namespaces.scripts.tags.delete(tag, \*, account_id, dispatch_namespace, script_name) -> object + # ZeroTrust ## Devices diff --git a/src/cloudflare/resources/rulesets/rules.py b/src/cloudflare/resources/rulesets/rules.py index 7f07952a531..393df75653b 100644 --- a/src/cloudflare/resources/rulesets/rules.py +++ b/src/cloudflare/resources/rulesets/rules.py @@ -175,7 +175,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["compress_response"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsCompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.CompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -475,7 +475,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["redirect"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsRedirectRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.RedirectRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -535,7 +535,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["rewrite"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsRewriteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.RewriteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -595,7 +595,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["route"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsRouteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.RouteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -655,7 +655,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["score"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsScoreRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.ScoreRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -715,7 +715,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["serve_error"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.ServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -775,7 +775,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_config"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsSetConfigRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.SetConfigRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -895,7 +895,7 @@ def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_cache_settings"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsSetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -971,16 +971,16 @@ def create( | NotGiven = NOT_GIVEN, action_parameters: rule_create_params.BlockRuleActionParameters | object - | rule_create_params.RulesetsCompressResponseRuleActionParameters + | rule_create_params.CompressResponseRuleActionParameters | rule_create_params.ExecuteRuleActionParameters - | rule_create_params.RulesetsRedirectRuleActionParameters - | rule_create_params.RulesetsRewriteRuleActionParameters - | rule_create_params.RulesetsRouteRuleActionParameters - | rule_create_params.RulesetsScoreRuleActionParameters - | rule_create_params.RulesetsServeErrorRuleActionParameters - | rule_create_params.RulesetsSetConfigRuleActionParameters + | rule_create_params.RedirectRuleActionParameters + | rule_create_params.RewriteRuleActionParameters + | rule_create_params.RouteRuleActionParameters + | rule_create_params.ScoreRuleActionParameters + | rule_create_params.ServeErrorRuleActionParameters + | rule_create_params.SetConfigRuleActionParameters | rule_create_params.SkipRuleActionParameters - | rule_create_params.RulesetsSetCacheSettingsRuleActionParameters + | rule_create_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, @@ -1233,7 +1233,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["compress_response"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsCompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.CompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -1538,7 +1538,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["redirect"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsRedirectRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.RedirectRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -1599,7 +1599,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["rewrite"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsRewriteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.RewriteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -1660,7 +1660,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["route"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsRouteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.RouteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -1721,7 +1721,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["score"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsScoreRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.ScoreRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -1782,7 +1782,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["serve_error"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.ServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -1843,7 +1843,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_config"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsSetConfigRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.SetConfigRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -1965,7 +1965,7 @@ def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_cache_settings"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsSetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2059,16 +2059,16 @@ def edit( | NotGiven = NOT_GIVEN, action_parameters: rule_edit_params.BlockRuleActionParameters | object - | rule_edit_params.RulesetsCompressResponseRuleActionParameters + | rule_edit_params.CompressResponseRuleActionParameters | rule_edit_params.ExecuteRuleActionParameters - | rule_edit_params.RulesetsRedirectRuleActionParameters - | rule_edit_params.RulesetsRewriteRuleActionParameters - | rule_edit_params.RulesetsRouteRuleActionParameters - | rule_edit_params.RulesetsScoreRuleActionParameters - | rule_edit_params.RulesetsServeErrorRuleActionParameters - | rule_edit_params.RulesetsSetConfigRuleActionParameters + | rule_edit_params.RedirectRuleActionParameters + | rule_edit_params.RewriteRuleActionParameters + | rule_edit_params.RouteRuleActionParameters + | rule_edit_params.ScoreRuleActionParameters + | rule_edit_params.ServeErrorRuleActionParameters + | rule_edit_params.SetConfigRuleActionParameters | rule_edit_params.SkipRuleActionParameters - | rule_edit_params.RulesetsSetCacheSettingsRuleActionParameters + | rule_edit_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, @@ -2265,7 +2265,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["compress_response"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsCompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.CompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2565,7 +2565,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["redirect"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsRedirectRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.RedirectRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2625,7 +2625,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["rewrite"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsRewriteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.RewriteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2685,7 +2685,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["route"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsRouteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.RouteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2745,7 +2745,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["score"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsScoreRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.ScoreRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2805,7 +2805,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["serve_error"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.ServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2865,7 +2865,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_config"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsSetConfigRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.SetConfigRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -2985,7 +2985,7 @@ async def create( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_cache_settings"] | NotGiven = NOT_GIVEN, - action_parameters: rule_create_params.RulesetsSetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_create_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -3061,16 +3061,16 @@ async def create( | NotGiven = NOT_GIVEN, action_parameters: rule_create_params.BlockRuleActionParameters | object - | rule_create_params.RulesetsCompressResponseRuleActionParameters + | rule_create_params.CompressResponseRuleActionParameters | rule_create_params.ExecuteRuleActionParameters - | rule_create_params.RulesetsRedirectRuleActionParameters - | rule_create_params.RulesetsRewriteRuleActionParameters - | rule_create_params.RulesetsRouteRuleActionParameters - | rule_create_params.RulesetsScoreRuleActionParameters - | rule_create_params.RulesetsServeErrorRuleActionParameters - | rule_create_params.RulesetsSetConfigRuleActionParameters + | rule_create_params.RedirectRuleActionParameters + | rule_create_params.RewriteRuleActionParameters + | rule_create_params.RouteRuleActionParameters + | rule_create_params.ScoreRuleActionParameters + | rule_create_params.ServeErrorRuleActionParameters + | rule_create_params.SetConfigRuleActionParameters | rule_create_params.SkipRuleActionParameters - | rule_create_params.RulesetsSetCacheSettingsRuleActionParameters + | rule_create_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, @@ -3323,7 +3323,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["compress_response"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsCompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.CompressResponseRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -3628,7 +3628,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["redirect"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsRedirectRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.RedirectRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -3689,7 +3689,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["rewrite"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsRewriteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.RewriteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -3750,7 +3750,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["route"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsRouteRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.RouteRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -3811,7 +3811,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["score"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsScoreRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.ScoreRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -3872,7 +3872,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["serve_error"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.ServeErrorRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -3933,7 +3933,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_config"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsSetConfigRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.SetConfigRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -4055,7 +4055,7 @@ async def edit( zone_id: str | NotGiven = NOT_GIVEN, id: str | NotGiven = NOT_GIVEN, action: Literal["set_cache_settings"] | NotGiven = NOT_GIVEN, - action_parameters: rule_edit_params.RulesetsSetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, + action_parameters: rule_edit_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, expression: str | NotGiven = NOT_GIVEN, @@ -4149,16 +4149,16 @@ async def edit( | NotGiven = NOT_GIVEN, action_parameters: rule_edit_params.BlockRuleActionParameters | object - | rule_edit_params.RulesetsCompressResponseRuleActionParameters + | rule_edit_params.CompressResponseRuleActionParameters | rule_edit_params.ExecuteRuleActionParameters - | rule_edit_params.RulesetsRedirectRuleActionParameters - | rule_edit_params.RulesetsRewriteRuleActionParameters - | rule_edit_params.RulesetsRouteRuleActionParameters - | rule_edit_params.RulesetsScoreRuleActionParameters - | rule_edit_params.RulesetsServeErrorRuleActionParameters - | rule_edit_params.RulesetsSetConfigRuleActionParameters + | rule_edit_params.RedirectRuleActionParameters + | rule_edit_params.RewriteRuleActionParameters + | rule_edit_params.RouteRuleActionParameters + | rule_edit_params.ScoreRuleActionParameters + | rule_edit_params.ServeErrorRuleActionParameters + | rule_edit_params.SetConfigRuleActionParameters | rule_edit_params.SkipRuleActionParameters - | rule_edit_params.RulesetsSetCacheSettingsRuleActionParameters + | rule_edit_params.SetCacheSettingsRuleActionParameters | NotGiven = NOT_GIVEN, description: str | NotGiven = NOT_GIVEN, enabled: bool | NotGiven = NOT_GIVEN, diff --git a/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/__init__.py b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/__init__.py index 0b995bdf832..07bbce064b2 100644 --- a/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/__init__.py +++ b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/__init__.py @@ -1,5 +1,13 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. +from .tags import ( + Tags, + AsyncTags, + TagsWithRawResponse, + AsyncTagsWithRawResponse, + TagsWithStreamingResponse, + AsyncTagsWithStreamingResponse, +) from .content import ( Content, AsyncContent, @@ -16,6 +24,14 @@ ScriptsWithStreamingResponse, AsyncScriptsWithStreamingResponse, ) +from .secrets import ( + Secrets, + AsyncSecrets, + SecretsWithRawResponse, + AsyncSecretsWithRawResponse, + SecretsWithStreamingResponse, + AsyncSecretsWithStreamingResponse, +) from .bindings import ( Bindings, AsyncBindings, @@ -52,6 +68,18 @@ "AsyncBindingsWithRawResponse", "BindingsWithStreamingResponse", "AsyncBindingsWithStreamingResponse", + "Secrets", + "AsyncSecrets", + "SecretsWithRawResponse", + "AsyncSecretsWithRawResponse", + "SecretsWithStreamingResponse", + "AsyncSecretsWithStreamingResponse", + "Tags", + "AsyncTags", + "TagsWithRawResponse", + "AsyncTagsWithRawResponse", + "TagsWithStreamingResponse", + "AsyncTagsWithStreamingResponse", "Scripts", "AsyncScripts", "ScriptsWithRawResponse", diff --git a/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/scripts.py b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/scripts.py index 3a82e2d2a85..4e7f2ed5fd7 100644 --- a/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/scripts.py +++ b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/scripts.py @@ -6,6 +6,14 @@ import httpx +from .tags import ( + Tags, + AsyncTags, + TagsWithRawResponse, + AsyncTagsWithRawResponse, + TagsWithStreamingResponse, + AsyncTagsWithStreamingResponse, +) from .content import ( Content, AsyncContent, @@ -14,6 +22,14 @@ ContentWithStreamingResponse, AsyncContentWithStreamingResponse, ) +from .secrets import ( + Secrets, + AsyncSecrets, + SecretsWithRawResponse, + AsyncSecretsWithRawResponse, + SecretsWithStreamingResponse, + AsyncSecretsWithStreamingResponse, +) from .bindings import ( Bindings, AsyncBindings, @@ -67,6 +83,14 @@ def settings(self) -> Settings: def bindings(self) -> Bindings: return Bindings(self._client) + @cached_property + def secrets(self) -> Secrets: + return Secrets(self._client) + + @cached_property + def tags(self) -> Tags: + return Tags(self._client) + @cached_property def with_raw_response(self) -> ScriptsWithRawResponse: return ScriptsWithRawResponse(self) @@ -328,6 +352,14 @@ def settings(self) -> AsyncSettings: def bindings(self) -> AsyncBindings: return AsyncBindings(self._client) + @cached_property + def secrets(self) -> AsyncSecrets: + return AsyncSecrets(self._client) + + @cached_property + def tags(self) -> AsyncTags: + return AsyncTags(self._client) + @cached_property def with_raw_response(self) -> AsyncScriptsWithRawResponse: return AsyncScriptsWithRawResponse(self) @@ -602,6 +634,14 @@ def settings(self) -> SettingsWithRawResponse: def bindings(self) -> BindingsWithRawResponse: return BindingsWithRawResponse(self._scripts.bindings) + @cached_property + def secrets(self) -> SecretsWithRawResponse: + return SecretsWithRawResponse(self._scripts.secrets) + + @cached_property + def tags(self) -> TagsWithRawResponse: + return TagsWithRawResponse(self._scripts.tags) + class AsyncScriptsWithRawResponse: def __init__(self, scripts: AsyncScripts) -> None: @@ -629,6 +669,14 @@ def settings(self) -> AsyncSettingsWithRawResponse: def bindings(self) -> AsyncBindingsWithRawResponse: return AsyncBindingsWithRawResponse(self._scripts.bindings) + @cached_property + def secrets(self) -> AsyncSecretsWithRawResponse: + return AsyncSecretsWithRawResponse(self._scripts.secrets) + + @cached_property + def tags(self) -> AsyncTagsWithRawResponse: + return AsyncTagsWithRawResponse(self._scripts.tags) + class ScriptsWithStreamingResponse: def __init__(self, scripts: Scripts) -> None: @@ -656,6 +704,14 @@ def settings(self) -> SettingsWithStreamingResponse: def bindings(self) -> BindingsWithStreamingResponse: return BindingsWithStreamingResponse(self._scripts.bindings) + @cached_property + def secrets(self) -> SecretsWithStreamingResponse: + return SecretsWithStreamingResponse(self._scripts.secrets) + + @cached_property + def tags(self) -> TagsWithStreamingResponse: + return TagsWithStreamingResponse(self._scripts.tags) + class AsyncScriptsWithStreamingResponse: def __init__(self, scripts: AsyncScripts) -> None: @@ -682,3 +738,11 @@ def settings(self) -> AsyncSettingsWithStreamingResponse: @cached_property def bindings(self) -> AsyncBindingsWithStreamingResponse: return AsyncBindingsWithStreamingResponse(self._scripts.bindings) + + @cached_property + def secrets(self) -> AsyncSecretsWithStreamingResponse: + return AsyncSecretsWithStreamingResponse(self._scripts.secrets) + + @cached_property + def tags(self) -> AsyncTagsWithStreamingResponse: + return AsyncTagsWithStreamingResponse(self._scripts.tags) diff --git a/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/secrets.py b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/secrets.py new file mode 100644 index 00000000000..9aac5862840 --- /dev/null +++ b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/secrets.py @@ -0,0 +1,327 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import Type, cast +from typing_extensions import Literal + +import httpx + +from ......_types import NOT_GIVEN, Body, Query, Headers, NotGiven +from ......_utils import ( + maybe_transform, + async_maybe_transform, +) +from ......_compat import cached_property +from ......_resource import SyncAPIResource, AsyncAPIResource +from ......_response import ( + to_raw_response_wrapper, + to_streamed_response_wrapper, + async_to_raw_response_wrapper, + async_to_streamed_response_wrapper, +) +from ......_wrappers import ResultWrapper +from ......pagination import SyncSinglePage, AsyncSinglePage +from ......_base_client import ( + AsyncPaginator, + make_request_options, +) +from ......types.workers_for_platforms.dispatch.namespaces.scripts import ( + SecretListResponse, + SecretUpdateResponse, + secret_update_params, +) + +__all__ = ["Secrets", "AsyncSecrets"] + + +class Secrets(SyncAPIResource): + @cached_property + def with_raw_response(self) -> SecretsWithRawResponse: + return SecretsWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> SecretsWithStreamingResponse: + return SecretsWithStreamingResponse(self) + + def update( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + name: str | NotGiven = NOT_GIVEN, + text: str | NotGiven = NOT_GIVEN, + type: Literal["secret_text"] | NotGiven = NOT_GIVEN, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> SecretUpdateResponse: + """ + Put secrets to a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + name: The name of this secret, this is what will be to access it inside the Worker. + + text: The value of the secret. + + type: The type of secret to put. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return self._put( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/secrets", + body=maybe_transform( + { + "name": name, + "text": text, + "type": type, + }, + secret_update_params.SecretUpdateParams, + ), + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper._unwrapper, + ), + cast_to=cast(Type[SecretUpdateResponse], ResultWrapper[SecretUpdateResponse]), + ) + + def list( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> SyncSinglePage[SecretListResponse]: + """ + Fetch secrets from a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return self._get_api_list( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/secrets", + page=SyncSinglePage[SecretListResponse], + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + model=SecretListResponse, + ) + + +class AsyncSecrets(AsyncAPIResource): + @cached_property + def with_raw_response(self) -> AsyncSecretsWithRawResponse: + return AsyncSecretsWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> AsyncSecretsWithStreamingResponse: + return AsyncSecretsWithStreamingResponse(self) + + async def update( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + name: str | NotGiven = NOT_GIVEN, + text: str | NotGiven = NOT_GIVEN, + type: Literal["secret_text"] | NotGiven = NOT_GIVEN, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> SecretUpdateResponse: + """ + Put secrets to a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + name: The name of this secret, this is what will be to access it inside the Worker. + + text: The value of the secret. + + type: The type of secret to put. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return await self._put( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/secrets", + body=await async_maybe_transform( + { + "name": name, + "text": text, + "type": type, + }, + secret_update_params.SecretUpdateParams, + ), + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper._unwrapper, + ), + cast_to=cast(Type[SecretUpdateResponse], ResultWrapper[SecretUpdateResponse]), + ) + + def list( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> AsyncPaginator[SecretListResponse, AsyncSinglePage[SecretListResponse]]: + """ + Fetch secrets from a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return self._get_api_list( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/secrets", + page=AsyncSinglePage[SecretListResponse], + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + model=SecretListResponse, + ) + + +class SecretsWithRawResponse: + def __init__(self, secrets: Secrets) -> None: + self._secrets = secrets + + self.update = to_raw_response_wrapper( + secrets.update, + ) + self.list = to_raw_response_wrapper( + secrets.list, + ) + + +class AsyncSecretsWithRawResponse: + def __init__(self, secrets: AsyncSecrets) -> None: + self._secrets = secrets + + self.update = async_to_raw_response_wrapper( + secrets.update, + ) + self.list = async_to_raw_response_wrapper( + secrets.list, + ) + + +class SecretsWithStreamingResponse: + def __init__(self, secrets: Secrets) -> None: + self._secrets = secrets + + self.update = to_streamed_response_wrapper( + secrets.update, + ) + self.list = to_streamed_response_wrapper( + secrets.list, + ) + + +class AsyncSecretsWithStreamingResponse: + def __init__(self, secrets: AsyncSecrets) -> None: + self._secrets = secrets + + self.update = async_to_streamed_response_wrapper( + secrets.update, + ) + self.list = async_to_streamed_response_wrapper( + secrets.list, + ) diff --git a/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/tags.py b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/tags.py new file mode 100644 index 00000000000..188a42b443a --- /dev/null +++ b/src/cloudflare/resources/workers_for_platforms/dispatch/namespaces/scripts/tags.py @@ -0,0 +1,420 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import List, Type, cast + +import httpx + +from ......_types import NOT_GIVEN, Body, Query, Headers, NotGiven +from ......_utils import ( + maybe_transform, + async_maybe_transform, +) +from ......_compat import cached_property +from ......_resource import SyncAPIResource, AsyncAPIResource +from ......_response import ( + to_raw_response_wrapper, + to_streamed_response_wrapper, + async_to_raw_response_wrapper, + async_to_streamed_response_wrapper, +) +from ......_wrappers import ResultWrapper +from ......pagination import SyncSinglePage, AsyncSinglePage +from ......_base_client import ( + AsyncPaginator, + make_request_options, +) +from ......types.workers_for_platforms.dispatch.namespaces.scripts import ( + TagListResponse, + TagUpdateResponse, + tag_update_params, +) + +__all__ = ["Tags", "AsyncTags"] + + +class Tags(SyncAPIResource): + @cached_property + def with_raw_response(self) -> TagsWithRawResponse: + return TagsWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> TagsWithStreamingResponse: + return TagsWithStreamingResponse(self) + + def update( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + body: List[str], + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> TagUpdateResponse: + """ + Put script tags for a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + body: Tags to help you manage your Workers + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return self._put( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/tags", + body=maybe_transform(body, tag_update_params.TagUpdateParams), + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper._unwrapper, + ), + cast_to=cast(Type[TagUpdateResponse], ResultWrapper[TagUpdateResponse]), + ) + + def list( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> SyncSinglePage[TagListResponse]: + """ + Fetch tags from a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return self._get_api_list( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/tags", + page=SyncSinglePage[TagListResponse], + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + model=str, + ) + + def delete( + self, + tag: str, + *, + account_id: str, + dispatch_namespace: str, + script_name: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> object: + """ + Delete script tag for a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + tag: Tag to help you manage your Worker + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + if not tag: + raise ValueError(f"Expected a non-empty value for `tag` but received {tag!r}") + return self._delete( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/tags/{tag}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper._unwrapper, + ), + cast_to=cast(Type[object], ResultWrapper[object]), + ) + + +class AsyncTags(AsyncAPIResource): + @cached_property + def with_raw_response(self) -> AsyncTagsWithRawResponse: + return AsyncTagsWithRawResponse(self) + + @cached_property + def with_streaming_response(self) -> AsyncTagsWithStreamingResponse: + return AsyncTagsWithStreamingResponse(self) + + async def update( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + body: List[str], + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> TagUpdateResponse: + """ + Put script tags for a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + body: Tags to help you manage your Workers + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return await self._put( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/tags", + body=await async_maybe_transform(body, tag_update_params.TagUpdateParams), + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper._unwrapper, + ), + cast_to=cast(Type[TagUpdateResponse], ResultWrapper[TagUpdateResponse]), + ) + + def list( + self, + script_name: str, + *, + account_id: str, + dispatch_namespace: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> AsyncPaginator[TagListResponse, AsyncSinglePage[TagListResponse]]: + """ + Fetch tags from a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + return self._get_api_list( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/tags", + page=AsyncSinglePage[TagListResponse], + options=make_request_options( + extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout + ), + model=str, + ) + + async def delete( + self, + tag: str, + *, + account_id: str, + dispatch_namespace: str, + script_name: str, + # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs. + # The extra values given here take precedence over values defined on the client or passed to this method. + extra_headers: Headers | None = None, + extra_query: Query | None = None, + extra_body: Body | None = None, + timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN, + ) -> object: + """ + Delete script tag for a script uploaded to a Workers for Platforms namespace. + + Args: + account_id: Identifier + + dispatch_namespace: Name of the Workers for Platforms dispatch namespace. + + script_name: Name of the script, used in URLs and route configuration. + + tag: Tag to help you manage your Worker + + extra_headers: Send extra headers + + extra_query: Add additional query parameters to the request + + extra_body: Add additional JSON properties to the request + + timeout: Override the client-level default timeout for this request, in seconds + """ + if not account_id: + raise ValueError(f"Expected a non-empty value for `account_id` but received {account_id!r}") + if not dispatch_namespace: + raise ValueError(f"Expected a non-empty value for `dispatch_namespace` but received {dispatch_namespace!r}") + if not script_name: + raise ValueError(f"Expected a non-empty value for `script_name` but received {script_name!r}") + if not tag: + raise ValueError(f"Expected a non-empty value for `tag` but received {tag!r}") + return await self._delete( + f"/accounts/{account_id}/workers/dispatch/namespaces/{dispatch_namespace}/scripts/{script_name}/tags/{tag}", + options=make_request_options( + extra_headers=extra_headers, + extra_query=extra_query, + extra_body=extra_body, + timeout=timeout, + post_parser=ResultWrapper._unwrapper, + ), + cast_to=cast(Type[object], ResultWrapper[object]), + ) + + +class TagsWithRawResponse: + def __init__(self, tags: Tags) -> None: + self._tags = tags + + self.update = to_raw_response_wrapper( + tags.update, + ) + self.list = to_raw_response_wrapper( + tags.list, + ) + self.delete = to_raw_response_wrapper( + tags.delete, + ) + + +class AsyncTagsWithRawResponse: + def __init__(self, tags: AsyncTags) -> None: + self._tags = tags + + self.update = async_to_raw_response_wrapper( + tags.update, + ) + self.list = async_to_raw_response_wrapper( + tags.list, + ) + self.delete = async_to_raw_response_wrapper( + tags.delete, + ) + + +class TagsWithStreamingResponse: + def __init__(self, tags: Tags) -> None: + self._tags = tags + + self.update = to_streamed_response_wrapper( + tags.update, + ) + self.list = to_streamed_response_wrapper( + tags.list, + ) + self.delete = to_streamed_response_wrapper( + tags.delete, + ) + + +class AsyncTagsWithStreamingResponse: + def __init__(self, tags: AsyncTags) -> None: + self._tags = tags + + self.update = async_to_streamed_response_wrapper( + tags.update, + ) + self.list = async_to_streamed_response_wrapper( + tags.list, + ) + self.delete = async_to_streamed_response_wrapper( + tags.delete, + ) diff --git a/src/cloudflare/types/__init__.py b/src/cloudflare/types/__init__.py index 4b06fc7e734..827978ab0d0 100644 --- a/src/cloudflare/types/__init__.py +++ b/src/cloudflare/types/__init__.py @@ -37,7 +37,6 @@ from .setting import Setting as Setting from .snippet import Snippet as Snippet from .edge_ips import EdgeIPs as EdgeIPs -from .hostname import Hostname as Hostname from .settings import Settings as Settings from .calls_app import CallsApp as CallsApp from .dns_param import DNSParam as DNSParam @@ -76,7 +75,6 @@ from .request_model import RequestModel as RequestModel from .edge_ips_param import EdgeIPsParam as EdgeIPsParam from .filter_options import FilterOptions as FilterOptions -from .hostname_param import HostnameParam as HostnameParam from .ip_list_params import IPListParams as IPListParams from .labeled_region import LabeledRegion as LabeledRegion from .migration_step import MigrationStep as MigrationStep diff --git a/src/cloudflare/types/hostname.py b/src/cloudflare/types/hostname.py deleted file mode 100644 index a4e440379c1..00000000000 --- a/src/cloudflare/types/hostname.py +++ /dev/null @@ -1,48 +0,0 @@ -# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. - -from typing import List, Optional -from datetime import datetime -from typing_extensions import Literal - -from .tunnel import Tunnel -from .._models import BaseModel - -__all__ = ["Hostname"] - - -class Hostname(BaseModel): - id: str - """Keyless certificate identifier tag.""" - - created_on: datetime - """When the Keyless SSL was created.""" - - enabled: bool - """Whether or not the Keyless SSL is on or off.""" - - host: str - """The keyless SSL name.""" - - modified_on: datetime - """When the Keyless SSL was last modified.""" - - name: str - """The keyless SSL name.""" - - permissions: List[object] - """ - Available permissions for the Keyless SSL for the current user requesting the - item. - """ - - port: float - """ - The keyless SSL port used to communicate between Cloudflare and the client's - Keyless SSL server. - """ - - status: Literal["active", "deleted"] - """Status of the Keyless SSL.""" - - tunnel: Optional[Tunnel] = None - """Configuration for using Keyless SSL through a Cloudflare Tunnel""" diff --git a/src/cloudflare/types/hostname_param.py b/src/cloudflare/types/hostname_param.py deleted file mode 100644 index 338408aac8b..00000000000 --- a/src/cloudflare/types/hostname_param.py +++ /dev/null @@ -1,23 +0,0 @@ -# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. - -from __future__ import annotations - -from typing_extensions import Required, TypedDict - -from .tunnel_param import TunnelParam - -__all__ = ["HostnameParam"] - - -class HostnameParam(TypedDict, total=False): - host: Required[str] - """The keyless SSL name.""" - - port: Required[float] - """ - The keyless SSL port used to communicate between Cloudflare and the client's - Keyless SSL server. - """ - - tunnel: TunnelParam - """Configuration for using Keyless SSL through a Cloudflare Tunnel""" diff --git a/src/cloudflare/types/ruleset_create_params.py b/src/cloudflare/types/ruleset_create_params.py index 230242c5aa6..ed5e84c494e 100644 --- a/src/cloudflare/types/ruleset_create_params.py +++ b/src/cloudflare/types/ruleset_create_params.py @@ -2,69 +2,28 @@ from __future__ import annotations -from typing import Dict, List, Union, Iterable +from typing import Union, Iterable from typing_extensions import Literal, Required, TypedDict -from .rulesets import LoggingParam, LogRuleParam, SkipRuleParam, BlockRuleParam, ExecuteRuleParam +from .rulesets import ( + LogRuleParam, + SkipRuleParam, + BlockRuleParam, + RouteRuleParam, + ScoreRuleParam, + ExecuteRuleParam, + RewriteRuleParam, + RedirectRuleParam, + ChallengeRuleParam, + SetConfigRuleParam, + ServeErrorRuleParam, + JsChallengeRuleParam, + CompressResponseRuleParam, + ManagedChallengeRuleParam, + SetCacheSettingsRuleParam, +) -__all__ = [ - "RulesetCreateParams", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] +__all__ = ["RulesetCreateParams", "Rule"] class RulesetCreateParams(TypedDict, total=False): @@ -116,798 +75,20 @@ class RulesetCreateParams(TypedDict, total=False): """An informative description of the ruleset.""" -class RuleRulesetsChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(TypedDict, total=False): - name: Literal["none", "auto", "default", "gzip", "brotli"] - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(TypedDict, total=False): - algorithms: Iterable[RuleRulesetsCompressResponseRuleActionParametersAlgorithm] - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["compress_response"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsCompressResponseRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["js_challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["managed_challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(TypedDict, total=False): - key: str - """Expression that evaluates to the list lookup key.""" - - name: str - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): - value: str - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): - expression: str - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(TypedDict, total=False): - preserve_query_string: bool - """Keep the query string of the original request.""" - - status_code: Literal[301, 302, 303, 307, 308] - """The status code to be used for the redirect.""" - - target_url: RuleRulesetsRedirectRuleActionParametersFromValueTargetURL - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(TypedDict, total=False): - from_list: RuleRulesetsRedirectRuleActionParametersFromList - """Serve a redirect based on a bulk list lookup.""" - - from_value: RuleRulesetsRedirectRuleActionParametersFromValue - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["redirect"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRedirectRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(TypedDict, total=False): - operation: Required[Literal["remove"]] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(TypedDict, total=False): - operation: Required[Literal["set"]] - - value: Required[str] - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(TypedDict, total=False): - expression: Required[str] - """Expression for the header value.""" - - operation: Required[Literal["set"]] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(TypedDict, total=False): - path: RuleRulesetsRewriteRuleActionParametersURIPath - """Path portion rewrite.""" - - query: RuleRulesetsRewriteRuleActionParametersURIQuery - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(TypedDict, total=False): - headers: Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders] - """Map of request headers to modify.""" - - uri: RuleRulesetsRewriteRuleActionParametersURI - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["rewrite"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRewriteRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(TypedDict, total=False): - host: str - """Override the resolved hostname.""" - - port: float - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(TypedDict, total=False): - value: Required[str] - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(TypedDict, total=False): - host_header: str - """Rewrite the HTTP Host header.""" - - origin: RuleRulesetsRouteRuleActionParametersOrigin - """Override the IP/TCP destination.""" - - sni: RuleRulesetsRouteRuleActionParametersSni - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["route"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRouteRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(TypedDict, total=False): - increment: int - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["score"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsScoreRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(TypedDict, total=False): - content: str - """Error response content.""" - - content_type: Literal["application/json", "text/xml", "text/plain", "text/html"] - """Content-type header to set with the response.""" - - status_code: float - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["serve_error"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsServeErrorRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(TypedDict, total=False): - css: bool - """Minify CSS files.""" - - html: bool - """Minify HTML files.""" - - js: bool - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(TypedDict, total=False): - automatic_https_rewrites: bool - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: RuleRulesetsSetConfigRuleActionParametersAutominify - """Select which file extensions to minify automatically.""" - - bic: bool - """Turn on or off Browser Integrity Check.""" - - disable_apps: bool - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: bool - """Turn off Zaraz.""" - - email_obfuscation: bool - """Turn on or off Email Obfuscation.""" - - hotlink_protection: bool - """Turn on or off the Hotlink Protection.""" - - mirage: bool - """Turn on or off Mirage.""" - - opportunistic_encryption: bool - """Turn on or off Opportunistic Encryption.""" - - polish: Literal["off", "lossless", "lossy"] - """Configure the Polish level.""" - - rocket_loader: bool - """Turn on or off Rocket Loader""" - - security_level: Literal["off", "essentially_off", "low", "medium", "high", "under_attack"] - """Configure the Security Level.""" - - server_side_excludes: bool - """Turn on or off Server Side Excludes.""" - - ssl: Literal["off", "flexible", "full", "strict", "origin_pull"] - """Configure the SSL level.""" - - sxg: bool - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["set_config"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsSetConfigRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=False): - mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] - """Determines which browser ttl mode to use.""" - - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): - check_presence: List[str] - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: List[str] - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): - check_presence: List[str] - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: bool - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: List[str] - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): - resolved: bool - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): - all: bool - """Exclude all query string parameters from use in building the cache key.""" - - list: List[str] - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): - all: bool - """Use all query string parameters in the cache key.""" - - list: List[str] - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): - exclude: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): - device_type: bool - """Use the user agent's device type in the cache key.""" - - geo: bool - """Use the user agents's country in the cache key.""" - - lang: bool - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(TypedDict, total=False): - cookie: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie - """The cookies to include in building the cache key.""" - - header: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader - """The header names and values to include in building the cache key.""" - - host: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=False): - cache_by_device_type: bool - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: bool - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: bool - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total=False): - eligible: Required[bool] - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: Required[int] - """The minimum file size eligible for store in cache reserve.""" - - -_RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( - "_RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", - { - "from": int, - }, - total=False, -) - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( - _RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False -): - to: Required[int] - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): - value: Required[int] - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - """The range of status codes used to apply the selected mode.""" - - status_code_value: int - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(TypedDict, total=False): - default: Required[int] - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] - """edge ttl options""" - - status_code_ttl: Required[Iterable[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL]] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(TypedDict, total=False): - disable_stale_while_updating: Required[bool] - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): - additional_cacheable_ports: Iterable[int] - """List of additional ports that caching can be enabled on.""" - - browser_ttl: RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: bool - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: bool - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: bool - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: int - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: bool - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: RuleRulesetsSetCacheSettingsRuleActionParametersServeStale - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["set_cache_settings"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsSetCacheSettingsRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - Rule = Union[ BlockRuleParam, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRuleParam, + CompressResponseRuleParam, ExecuteRuleParam, - RuleRulesetsJsChallengeRule, + JsChallengeRuleParam, LogRuleParam, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRuleParam, + RedirectRuleParam, + RewriteRuleParam, + RouteRuleParam, + ScoreRuleParam, + ServeErrorRuleParam, + SetConfigRuleParam, SkipRuleParam, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRuleParam, ] diff --git a/src/cloudflare/types/ruleset_create_response.py b/src/cloudflare/types/ruleset_create_response.py index 983d53a5821..84bacfd8f1e 100644 --- a/src/cloudflare/types/ruleset_create_response.py +++ b/src/cloudflare/types/ruleset_create_response.py @@ -1,961 +1,46 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - from .._models import BaseModel -from .rulesets import Logging, LogRule, SkipRule, BlockRule, ExecuteRule - -__all__ = [ - "RulesetCreateResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rulesets import ( + LogRule, + SkipRule, + BlockRule, + RouteRule, + ScoreRule, + ExecuteRule, + RewriteRule, + RedirectRule, + ChallengeRule, + SetConfigRule, + ServeErrorRule, + JsChallengeRule, + CompressResponseRule, + ManagedChallengeRule, + SetCacheSettingsRule, +) + +__all__ = ["RulesetCreateResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/ruleset_get_response.py b/src/cloudflare/types/ruleset_get_response.py index 7171964af75..01e252fd950 100644 --- a/src/cloudflare/types/ruleset_get_response.py +++ b/src/cloudflare/types/ruleset_get_response.py @@ -1,961 +1,46 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - from .._models import BaseModel -from .rulesets import Logging, LogRule, SkipRule, BlockRule, ExecuteRule - -__all__ = [ - "RulesetGetResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rulesets import ( + LogRule, + SkipRule, + BlockRule, + RouteRule, + ScoreRule, + ExecuteRule, + RewriteRule, + RedirectRule, + ChallengeRule, + SetConfigRule, + ServeErrorRule, + JsChallengeRule, + CompressResponseRule, + ManagedChallengeRule, + SetCacheSettingsRule, +) + +__all__ = ["RulesetGetResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/ruleset_update_params.py b/src/cloudflare/types/ruleset_update_params.py index 4de369133c1..d0d49b584e1 100644 --- a/src/cloudflare/types/ruleset_update_params.py +++ b/src/cloudflare/types/ruleset_update_params.py @@ -2,69 +2,28 @@ from __future__ import annotations -from typing import Dict, List, Union, Iterable +from typing import Union, Iterable from typing_extensions import Literal, Required, TypedDict -from .rulesets import LoggingParam, LogRuleParam, SkipRuleParam, BlockRuleParam, ExecuteRuleParam +from .rulesets import ( + LogRuleParam, + SkipRuleParam, + BlockRuleParam, + RouteRuleParam, + ScoreRuleParam, + ExecuteRuleParam, + RewriteRuleParam, + RedirectRuleParam, + ChallengeRuleParam, + SetConfigRuleParam, + ServeErrorRuleParam, + JsChallengeRuleParam, + CompressResponseRuleParam, + ManagedChallengeRuleParam, + SetCacheSettingsRuleParam, +) -__all__ = [ - "RulesetUpdateParams", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] +__all__ = ["RulesetUpdateParams", "Rule"] class RulesetUpdateParams(TypedDict, total=False): @@ -114,798 +73,20 @@ class RulesetUpdateParams(TypedDict, total=False): """The phase of the ruleset.""" -class RuleRulesetsChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(TypedDict, total=False): - name: Literal["none", "auto", "default", "gzip", "brotli"] - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(TypedDict, total=False): - algorithms: Iterable[RuleRulesetsCompressResponseRuleActionParametersAlgorithm] - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["compress_response"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsCompressResponseRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["js_challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["managed_challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(TypedDict, total=False): - key: str - """Expression that evaluates to the list lookup key.""" - - name: str - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): - value: str - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): - expression: str - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(TypedDict, total=False): - preserve_query_string: bool - """Keep the query string of the original request.""" - - status_code: Literal[301, 302, 303, 307, 308] - """The status code to be used for the redirect.""" - - target_url: RuleRulesetsRedirectRuleActionParametersFromValueTargetURL - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(TypedDict, total=False): - from_list: RuleRulesetsRedirectRuleActionParametersFromList - """Serve a redirect based on a bulk list lookup.""" - - from_value: RuleRulesetsRedirectRuleActionParametersFromValue - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["redirect"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRedirectRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(TypedDict, total=False): - operation: Required[Literal["remove"]] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(TypedDict, total=False): - operation: Required[Literal["set"]] - - value: Required[str] - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(TypedDict, total=False): - expression: Required[str] - """Expression for the header value.""" - - operation: Required[Literal["set"]] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(TypedDict, total=False): - path: RuleRulesetsRewriteRuleActionParametersURIPath - """Path portion rewrite.""" - - query: RuleRulesetsRewriteRuleActionParametersURIQuery - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(TypedDict, total=False): - headers: Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders] - """Map of request headers to modify.""" - - uri: RuleRulesetsRewriteRuleActionParametersURI - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["rewrite"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRewriteRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(TypedDict, total=False): - host: str - """Override the resolved hostname.""" - - port: float - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(TypedDict, total=False): - value: Required[str] - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(TypedDict, total=False): - host_header: str - """Rewrite the HTTP Host header.""" - - origin: RuleRulesetsRouteRuleActionParametersOrigin - """Override the IP/TCP destination.""" - - sni: RuleRulesetsRouteRuleActionParametersSni - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["route"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRouteRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(TypedDict, total=False): - increment: int - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["score"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsScoreRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(TypedDict, total=False): - content: str - """Error response content.""" - - content_type: Literal["application/json", "text/xml", "text/plain", "text/html"] - """Content-type header to set with the response.""" - - status_code: float - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["serve_error"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsServeErrorRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(TypedDict, total=False): - css: bool - """Minify CSS files.""" - - html: bool - """Minify HTML files.""" - - js: bool - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(TypedDict, total=False): - automatic_https_rewrites: bool - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: RuleRulesetsSetConfigRuleActionParametersAutominify - """Select which file extensions to minify automatically.""" - - bic: bool - """Turn on or off Browser Integrity Check.""" - - disable_apps: bool - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: bool - """Turn off Zaraz.""" - - email_obfuscation: bool - """Turn on or off Email Obfuscation.""" - - hotlink_protection: bool - """Turn on or off the Hotlink Protection.""" - - mirage: bool - """Turn on or off Mirage.""" - - opportunistic_encryption: bool - """Turn on or off Opportunistic Encryption.""" - - polish: Literal["off", "lossless", "lossy"] - """Configure the Polish level.""" - - rocket_loader: bool - """Turn on or off Rocket Loader""" - - security_level: Literal["off", "essentially_off", "low", "medium", "high", "under_attack"] - """Configure the Security Level.""" - - server_side_excludes: bool - """Turn on or off Server Side Excludes.""" - - ssl: Literal["off", "flexible", "full", "strict", "origin_pull"] - """Configure the SSL level.""" - - sxg: bool - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["set_config"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsSetConfigRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=False): - mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] - """Determines which browser ttl mode to use.""" - - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): - check_presence: List[str] - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: List[str] - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): - check_presence: List[str] - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: bool - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: List[str] - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): - resolved: bool - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): - all: bool - """Exclude all query string parameters from use in building the cache key.""" - - list: List[str] - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): - all: bool - """Use all query string parameters in the cache key.""" - - list: List[str] - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): - exclude: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): - device_type: bool - """Use the user agent's device type in the cache key.""" - - geo: bool - """Use the user agents's country in the cache key.""" - - lang: bool - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(TypedDict, total=False): - cookie: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie - """The cookies to include in building the cache key.""" - - header: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader - """The header names and values to include in building the cache key.""" - - host: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=False): - cache_by_device_type: bool - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: bool - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: bool - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total=False): - eligible: Required[bool] - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: Required[int] - """The minimum file size eligible for store in cache reserve.""" - - -_RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( - "_RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", - { - "from": int, - }, - total=False, -) - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( - _RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False -): - to: Required[int] - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): - value: Required[int] - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - """The range of status codes used to apply the selected mode.""" - - status_code_value: int - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(TypedDict, total=False): - default: Required[int] - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] - """edge ttl options""" - - status_code_ttl: Required[Iterable[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL]] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(TypedDict, total=False): - disable_stale_while_updating: Required[bool] - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): - additional_cacheable_ports: Iterable[int] - """List of additional ports that caching can be enabled on.""" - - browser_ttl: RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: bool - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: bool - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: bool - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: int - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: bool - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: RuleRulesetsSetCacheSettingsRuleActionParametersServeStale - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["set_cache_settings"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsSetCacheSettingsRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - Rule = Union[ BlockRuleParam, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRuleParam, + CompressResponseRuleParam, ExecuteRuleParam, - RuleRulesetsJsChallengeRule, + JsChallengeRuleParam, LogRuleParam, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRuleParam, + RedirectRuleParam, + RewriteRuleParam, + RouteRuleParam, + ScoreRuleParam, + ServeErrorRuleParam, + SetConfigRuleParam, SkipRuleParam, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRuleParam, ] diff --git a/src/cloudflare/types/ruleset_update_response.py b/src/cloudflare/types/ruleset_update_response.py index 8ef688d6149..4fe157273a1 100644 --- a/src/cloudflare/types/ruleset_update_response.py +++ b/src/cloudflare/types/ruleset_update_response.py @@ -1,961 +1,46 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - from .._models import BaseModel -from .rulesets import Logging, LogRule, SkipRule, BlockRule, ExecuteRule - -__all__ = [ - "RulesetUpdateResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rulesets import ( + LogRule, + SkipRule, + BlockRule, + RouteRule, + ScoreRule, + ExecuteRule, + RewriteRule, + RedirectRule, + ChallengeRule, + SetConfigRule, + ServeErrorRule, + JsChallengeRule, + CompressResponseRule, + ManagedChallengeRule, + SetCacheSettingsRule, +) + +__all__ = ["RulesetUpdateResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/__init__.py b/src/cloudflare/types/rulesets/__init__.py index 2a3e688b0f5..c84a6a31cd8 100644 --- a/src/cloudflare/types/rulesets/__init__.py +++ b/src/cloudflare/types/rulesets/__init__.py @@ -6,18 +6,42 @@ from .log_rule import LogRule as LogRule from .skip_rule import SkipRule as SkipRule from .block_rule import BlockRule as BlockRule +from .route_rule import RouteRule as RouteRule +from .score_rule import ScoreRule as ScoreRule from .execute_rule import ExecuteRule as ExecuteRule +from .rewrite_rule import RewriteRule as RewriteRule from .logging_param import LoggingParam as LoggingParam +from .redirect_rule import RedirectRule as RedirectRule +from .challenge_rule import ChallengeRule as ChallengeRule from .log_rule_param import LogRuleParam as LogRuleParam +from .set_config_rule import SetConfigRule as SetConfigRule from .skip_rule_param import SkipRuleParam as SkipRuleParam from .block_rule_param import BlockRuleParam as BlockRuleParam +from .rewrite_uri_part import RewriteURIPart as RewriteURIPart +from .route_rule_param import RouteRuleParam as RouteRuleParam from .rule_edit_params import RuleEditParams as RuleEditParams +from .score_rule_param import ScoreRuleParam as ScoreRuleParam +from .serve_error_rule import ServeErrorRule as ServeErrorRule +from .js_challenge_rule import JsChallengeRule as JsChallengeRule from .execute_rule_param import ExecuteRuleParam as ExecuteRuleParam from .phase_get_response import PhaseGetResponse as PhaseGetResponse +from .rewrite_rule_param import RewriteRuleParam as RewriteRuleParam from .rule_create_params import RuleCreateParams as RuleCreateParams from .rule_edit_response import RuleEditResponse as RuleEditResponse from .phase_update_params import PhaseUpdateParams as PhaseUpdateParams +from .redirect_rule_param import RedirectRuleParam as RedirectRuleParam +from .challenge_rule_param import ChallengeRuleParam as ChallengeRuleParam from .rule_create_response import RuleCreateResponse as RuleCreateResponse from .rule_delete_response import RuleDeleteResponse as RuleDeleteResponse from .version_get_response import VersionGetResponse as VersionGetResponse from .phase_update_response import PhaseUpdateResponse as PhaseUpdateResponse +from .set_config_rule_param import SetConfigRuleParam as SetConfigRuleParam +from .compress_response_rule import CompressResponseRule as CompressResponseRule +from .managed_challenge_rule import ManagedChallengeRule as ManagedChallengeRule +from .rewrite_uri_part_param import RewriteURIPartParam as RewriteURIPartParam +from .serve_error_rule_param import ServeErrorRuleParam as ServeErrorRuleParam +from .js_challenge_rule_param import JsChallengeRuleParam as JsChallengeRuleParam +from .set_cache_settings_rule import SetCacheSettingsRule as SetCacheSettingsRule +from .compress_response_rule_param import CompressResponseRuleParam as CompressResponseRuleParam +from .managed_challenge_rule_param import ManagedChallengeRuleParam as ManagedChallengeRuleParam +from .set_cache_settings_rule_param import SetCacheSettingsRuleParam as SetCacheSettingsRuleParam diff --git a/src/cloudflare/types/rulesets/challenge_rule.py b/src/cloudflare/types/rulesets/challenge_rule.py new file mode 100644 index 00000000000..5443d8298e5 --- /dev/null +++ b/src/cloudflare/types/rulesets/challenge_rule.py @@ -0,0 +1,45 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["ChallengeRule"] + + +class ChallengeRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["challenge"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[object] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/challenge_rule_param.py b/src/cloudflare/types/rulesets/challenge_rule_param.py new file mode 100644 index 00000000000..d430a95a678 --- /dev/null +++ b/src/cloudflare/types/rulesets/challenge_rule_param.py @@ -0,0 +1,35 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["ChallengeRuleParam"] + + +class ChallengeRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["challenge"] + """The action to perform when the rule matches.""" + + action_parameters: object + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/compress_response_rule.py b/src/cloudflare/types/rulesets/compress_response_rule.py new file mode 100644 index 00000000000..cfadff08d90 --- /dev/null +++ b/src/cloudflare/types/rulesets/compress_response_rule.py @@ -0,0 +1,55 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["CompressResponseRule", "ActionParameters", "ActionParametersAlgorithm"] + + +class ActionParametersAlgorithm(BaseModel): + name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None + """Name of compression algorithm to enable.""" + + +class ActionParameters(BaseModel): + algorithms: Optional[List[ActionParametersAlgorithm]] = None + """Custom order for compression algorithms.""" + + +class CompressResponseRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["compress_response"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/compress_response_rule_param.py b/src/cloudflare/types/rulesets/compress_response_rule_param.py new file mode 100644 index 00000000000..79c4ef44957 --- /dev/null +++ b/src/cloudflare/types/rulesets/compress_response_rule_param.py @@ -0,0 +1,46 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import Iterable +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["CompressResponseRuleParam", "ActionParameters", "ActionParametersAlgorithm"] + + +class ActionParametersAlgorithm(TypedDict, total=False): + name: Literal["none", "auto", "default", "gzip", "brotli"] + """Name of compression algorithm to enable.""" + + +class ActionParameters(TypedDict, total=False): + algorithms: Iterable[ActionParametersAlgorithm] + """Custom order for compression algorithms.""" + + +class CompressResponseRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["compress_response"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/js_challenge_rule.py b/src/cloudflare/types/rulesets/js_challenge_rule.py new file mode 100644 index 00000000000..c24e8833f87 --- /dev/null +++ b/src/cloudflare/types/rulesets/js_challenge_rule.py @@ -0,0 +1,45 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["JsChallengeRule"] + + +class JsChallengeRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["js_challenge"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[object] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/js_challenge_rule_param.py b/src/cloudflare/types/rulesets/js_challenge_rule_param.py new file mode 100644 index 00000000000..3dc666ae047 --- /dev/null +++ b/src/cloudflare/types/rulesets/js_challenge_rule_param.py @@ -0,0 +1,35 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["JsChallengeRuleParam"] + + +class JsChallengeRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["js_challenge"] + """The action to perform when the rule matches.""" + + action_parameters: object + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/managed_challenge_rule.py b/src/cloudflare/types/rulesets/managed_challenge_rule.py new file mode 100644 index 00000000000..6c2772bd14d --- /dev/null +++ b/src/cloudflare/types/rulesets/managed_challenge_rule.py @@ -0,0 +1,45 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["ManagedChallengeRule"] + + +class ManagedChallengeRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["managed_challenge"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[object] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/managed_challenge_rule_param.py b/src/cloudflare/types/rulesets/managed_challenge_rule_param.py new file mode 100644 index 00000000000..63ccee1f4a2 --- /dev/null +++ b/src/cloudflare/types/rulesets/managed_challenge_rule_param.py @@ -0,0 +1,35 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["ManagedChallengeRuleParam"] + + +class ManagedChallengeRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["managed_challenge"] + """The action to perform when the rule matches.""" + + action_parameters: object + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/phase_get_response.py b/src/cloudflare/types/rulesets/phase_get_response.py index 7a4562b8e16..b0f1c8dc5c0 100644 --- a/src/cloudflare/types/rulesets/phase_get_response.py +++ b/src/cloudflare/types/rulesets/phase_get_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from .logging import Logging from .log_rule import LogRule from ..._models import BaseModel from .skip_rule import SkipRule from .block_rule import BlockRule +from .route_rule import RouteRule +from .score_rule import ScoreRule from .execute_rule import ExecuteRule - -__all__ = [ - "PhaseGetResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rewrite_rule import RewriteRule +from .redirect_rule import RedirectRule +from .challenge_rule import ChallengeRule +from .set_config_rule import SetConfigRule +from .serve_error_rule import ServeErrorRule +from .js_challenge_rule import JsChallengeRule +from .compress_response_rule import CompressResponseRule +from .managed_challenge_rule import ManagedChallengeRule +from .set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["PhaseGetResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/phase_update_params.py b/src/cloudflare/types/rulesets/phase_update_params.py index 134d35989ff..35f0f070769 100644 --- a/src/cloudflare/types/rulesets/phase_update_params.py +++ b/src/cloudflare/types/rulesets/phase_update_params.py @@ -2,73 +2,26 @@ from __future__ import annotations -from typing import Dict, List, Union, Iterable +from typing import Union, Iterable from typing_extensions import Literal, Required, TypedDict -from .logging_param import LoggingParam from .log_rule_param import LogRuleParam from .skip_rule_param import SkipRuleParam from .block_rule_param import BlockRuleParam +from .route_rule_param import RouteRuleParam +from .score_rule_param import ScoreRuleParam from .execute_rule_param import ExecuteRuleParam +from .rewrite_rule_param import RewriteRuleParam +from .redirect_rule_param import RedirectRuleParam +from .challenge_rule_param import ChallengeRuleParam +from .set_config_rule_param import SetConfigRuleParam +from .serve_error_rule_param import ServeErrorRuleParam +from .js_challenge_rule_param import JsChallengeRuleParam +from .compress_response_rule_param import CompressResponseRuleParam +from .managed_challenge_rule_param import ManagedChallengeRuleParam +from .set_cache_settings_rule_param import SetCacheSettingsRuleParam -__all__ = [ - "PhaseUpdateParams", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] +__all__ = ["PhaseUpdateParams", "Rule"] class PhaseUpdateParams(TypedDict, total=False): @@ -118,798 +71,20 @@ class PhaseUpdateParams(TypedDict, total=False): """The phase of the ruleset.""" -class RuleRulesetsChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(TypedDict, total=False): - name: Literal["none", "auto", "default", "gzip", "brotli"] - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(TypedDict, total=False): - algorithms: Iterable[RuleRulesetsCompressResponseRuleActionParametersAlgorithm] - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["compress_response"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsCompressResponseRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["js_challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["managed_challenge"] - """The action to perform when the rule matches.""" - - action_parameters: object - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(TypedDict, total=False): - key: str - """Expression that evaluates to the list lookup key.""" - - name: str - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): - value: str - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): - expression: str - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(TypedDict, total=False): - preserve_query_string: bool - """Keep the query string of the original request.""" - - status_code: Literal[301, 302, 303, 307, 308] - """The status code to be used for the redirect.""" - - target_url: RuleRulesetsRedirectRuleActionParametersFromValueTargetURL - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(TypedDict, total=False): - from_list: RuleRulesetsRedirectRuleActionParametersFromList - """Serve a redirect based on a bulk list lookup.""" - - from_value: RuleRulesetsRedirectRuleActionParametersFromValue - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["redirect"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRedirectRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(TypedDict, total=False): - operation: Required[Literal["remove"]] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(TypedDict, total=False): - operation: Required[Literal["set"]] - - value: Required[str] - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(TypedDict, total=False): - expression: Required[str] - """Expression for the header value.""" - - operation: Required[Literal["set"]] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(TypedDict, total=False): - path: RuleRulesetsRewriteRuleActionParametersURIPath - """Path portion rewrite.""" - - query: RuleRulesetsRewriteRuleActionParametersURIQuery - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(TypedDict, total=False): - headers: Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders] - """Map of request headers to modify.""" - - uri: RuleRulesetsRewriteRuleActionParametersURI - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["rewrite"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRewriteRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(TypedDict, total=False): - host: str - """Override the resolved hostname.""" - - port: float - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(TypedDict, total=False): - value: Required[str] - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(TypedDict, total=False): - host_header: str - """Rewrite the HTTP Host header.""" - - origin: RuleRulesetsRouteRuleActionParametersOrigin - """Override the IP/TCP destination.""" - - sni: RuleRulesetsRouteRuleActionParametersSni - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["route"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsRouteRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(TypedDict, total=False): - increment: int - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["score"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsScoreRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(TypedDict, total=False): - content: str - """Error response content.""" - - content_type: Literal["application/json", "text/xml", "text/plain", "text/html"] - """Content-type header to set with the response.""" - - status_code: float - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["serve_error"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsServeErrorRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(TypedDict, total=False): - css: bool - """Minify CSS files.""" - - html: bool - """Minify HTML files.""" - - js: bool - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(TypedDict, total=False): - automatic_https_rewrites: bool - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: RuleRulesetsSetConfigRuleActionParametersAutominify - """Select which file extensions to minify automatically.""" - - bic: bool - """Turn on or off Browser Integrity Check.""" - - disable_apps: bool - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: bool - """Turn off Zaraz.""" - - email_obfuscation: bool - """Turn on or off Email Obfuscation.""" - - hotlink_protection: bool - """Turn on or off the Hotlink Protection.""" - - mirage: bool - """Turn on or off Mirage.""" - - opportunistic_encryption: bool - """Turn on or off Opportunistic Encryption.""" - - polish: Literal["off", "lossless", "lossy"] - """Configure the Polish level.""" - - rocket_loader: bool - """Turn on or off Rocket Loader""" - - security_level: Literal["off", "essentially_off", "low", "medium", "high", "under_attack"] - """Configure the Security Level.""" - - server_side_excludes: bool - """Turn on or off Server Side Excludes.""" - - ssl: Literal["off", "flexible", "full", "strict", "origin_pull"] - """Configure the SSL level.""" - - sxg: bool - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["set_config"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsSetConfigRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=False): - mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] - """Determines which browser ttl mode to use.""" - - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): - check_presence: List[str] - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: List[str] - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): - check_presence: List[str] - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: bool - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: List[str] - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): - resolved: bool - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): - all: bool - """Exclude all query string parameters from use in building the cache key.""" - - list: List[str] - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): - all: bool - """Use all query string parameters in the cache key.""" - - list: List[str] - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): - exclude: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): - device_type: bool - """Use the user agent's device type in the cache key.""" - - geo: bool - """Use the user agents's country in the cache key.""" - - lang: bool - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(TypedDict, total=False): - cookie: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie - """The cookies to include in building the cache key.""" - - header: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader - """The header names and values to include in building the cache key.""" - - host: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=False): - cache_by_device_type: bool - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: bool - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: bool - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total=False): - eligible: Required[bool] - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: Required[int] - """The minimum file size eligible for store in cache reserve.""" - - -_RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( - "_RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", - { - "from": int, - }, - total=False, -) - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( - _RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False -): - to: Required[int] - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): - value: Required[int] - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - """The range of status codes used to apply the selected mode.""" - - status_code_value: int - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(TypedDict, total=False): - default: Required[int] - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] - """edge ttl options""" - - status_code_ttl: Required[Iterable[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL]] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(TypedDict, total=False): - disable_stale_while_updating: Required[bool] - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): - additional_cacheable_ports: Iterable[int] - """List of additional ports that caching can be enabled on.""" - - browser_ttl: RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: bool - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: bool - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: bool - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: int - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: bool - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: RuleRulesetsSetCacheSettingsRuleActionParametersServeStale - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(TypedDict, total=False): - id: str - """The unique ID of the rule.""" - - action: Literal["set_cache_settings"] - """The action to perform when the rule matches.""" - - action_parameters: RuleRulesetsSetCacheSettingsRuleActionParameters - """The parameters configuring the rule's action.""" - - description: str - """An informative description of the rule.""" - - enabled: bool - """Whether the rule should be executed.""" - - expression: str - """The expression defining which traffic will match the rule.""" - - logging: LoggingParam - """An object configuring the rule's logging behavior.""" - - ref: str - """The reference of the rule (the rule ID by default).""" - - Rule = Union[ BlockRuleParam, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRuleParam, + CompressResponseRuleParam, ExecuteRuleParam, - RuleRulesetsJsChallengeRule, + JsChallengeRuleParam, LogRuleParam, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRuleParam, + RedirectRuleParam, + RewriteRuleParam, + RouteRuleParam, + ScoreRuleParam, + ServeErrorRuleParam, + SetConfigRuleParam, SkipRuleParam, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRuleParam, ] diff --git a/src/cloudflare/types/rulesets/phase_update_response.py b/src/cloudflare/types/rulesets/phase_update_response.py index 5295d28b058..890bbbbb100 100644 --- a/src/cloudflare/types/rulesets/phase_update_response.py +++ b/src/cloudflare/types/rulesets/phase_update_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from .logging import Logging from .log_rule import LogRule from ..._models import BaseModel from .skip_rule import SkipRule from .block_rule import BlockRule +from .route_rule import RouteRule +from .score_rule import ScoreRule from .execute_rule import ExecuteRule - -__all__ = [ - "PhaseUpdateResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rewrite_rule import RewriteRule +from .redirect_rule import RedirectRule +from .challenge_rule import ChallengeRule +from .set_config_rule import SetConfigRule +from .serve_error_rule import ServeErrorRule +from .js_challenge_rule import JsChallengeRule +from .compress_response_rule import CompressResponseRule +from .managed_challenge_rule import ManagedChallengeRule +from .set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["PhaseUpdateResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/phases/version_get_response.py b/src/cloudflare/types/rulesets/phases/version_get_response.py index 4bb716b1bb9..86bce386821 100644 --- a/src/cloudflare/types/rulesets/phases/version_get_response.py +++ b/src/cloudflare/types/rulesets/phases/version_get_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from ..logging import Logging from ..log_rule import LogRule from ...._models import BaseModel from ..skip_rule import SkipRule from ..block_rule import BlockRule +from ..route_rule import RouteRule +from ..score_rule import ScoreRule from ..execute_rule import ExecuteRule - -__all__ = [ - "VersionGetResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from ..rewrite_rule import RewriteRule +from ..redirect_rule import RedirectRule +from ..challenge_rule import ChallengeRule +from ..set_config_rule import SetConfigRule +from ..serve_error_rule import ServeErrorRule +from ..js_challenge_rule import JsChallengeRule +from ..compress_response_rule import CompressResponseRule +from ..managed_challenge_rule import ManagedChallengeRule +from ..set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["VersionGetResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/redirect_rule.py b/src/cloudflare/types/rulesets/redirect_rule.py new file mode 100644 index 00000000000..9c8d6246760 --- /dev/null +++ b/src/cloudflare/types/rulesets/redirect_rule.py @@ -0,0 +1,95 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Union, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = [ + "RedirectRule", + "ActionParameters", + "ActionParametersFromList", + "ActionParametersFromValue", + "ActionParametersFromValueTargetURL", + "ActionParametersFromValueTargetURLStaticURLRedirect", + "ActionParametersFromValueTargetURLDynamicURLRedirect", +] + + +class ActionParametersFromList(BaseModel): + key: Optional[str] = None + """Expression that evaluates to the list lookup key.""" + + name: Optional[str] = None + """The name of the list to match against.""" + + +class ActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): + value: Optional[str] = None + """The URL to redirect the request to.""" + + +class ActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): + expression: Optional[str] = None + """An expression to evaluate to get the URL to redirect the request to.""" + + +ActionParametersFromValueTargetURL = Union[ + ActionParametersFromValueTargetURLStaticURLRedirect, ActionParametersFromValueTargetURLDynamicURLRedirect +] + + +class ActionParametersFromValue(BaseModel): + preserve_query_string: Optional[bool] = None + """Keep the query string of the original request.""" + + status_code: Optional[Literal[301, 302, 303, 307, 308]] = None + """The status code to be used for the redirect.""" + + target_url: Optional[ActionParametersFromValueTargetURL] = None + """The URL to redirect the request to.""" + + +class ActionParameters(BaseModel): + from_list: Optional[ActionParametersFromList] = None + """Serve a redirect based on a bulk list lookup.""" + + from_value: Optional[ActionParametersFromValue] = None + """Serve a redirect based on the request properties.""" + + +class RedirectRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["redirect"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/redirect_rule_param.py b/src/cloudflare/types/rulesets/redirect_rule_param.py new file mode 100644 index 00000000000..ef67a8411f7 --- /dev/null +++ b/src/cloudflare/types/rulesets/redirect_rule_param.py @@ -0,0 +1,86 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import Union +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = [ + "RedirectRuleParam", + "ActionParameters", + "ActionParametersFromList", + "ActionParametersFromValue", + "ActionParametersFromValueTargetURL", + "ActionParametersFromValueTargetURLStaticURLRedirect", + "ActionParametersFromValueTargetURLDynamicURLRedirect", +] + + +class ActionParametersFromList(TypedDict, total=False): + key: str + """Expression that evaluates to the list lookup key.""" + + name: str + """The name of the list to match against.""" + + +class ActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): + value: str + """The URL to redirect the request to.""" + + +class ActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): + expression: str + """An expression to evaluate to get the URL to redirect the request to.""" + + +ActionParametersFromValueTargetURL = Union[ + ActionParametersFromValueTargetURLStaticURLRedirect, ActionParametersFromValueTargetURLDynamicURLRedirect +] + + +class ActionParametersFromValue(TypedDict, total=False): + preserve_query_string: bool + """Keep the query string of the original request.""" + + status_code: Literal[301, 302, 303, 307, 308] + """The status code to be used for the redirect.""" + + target_url: ActionParametersFromValueTargetURL + """The URL to redirect the request to.""" + + +class ActionParameters(TypedDict, total=False): + from_list: ActionParametersFromList + """Serve a redirect based on a bulk list lookup.""" + + from_value: ActionParametersFromValue + """Serve a redirect based on the request properties.""" + + +class RedirectRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["redirect"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/rewrite_rule.py b/src/cloudflare/types/rulesets/rewrite_rule.py new file mode 100644 index 00000000000..aa76c3d0894 --- /dev/null +++ b/src/cloudflare/types/rulesets/rewrite_rule.py @@ -0,0 +1,93 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Dict, List, Union, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel +from .rewrite_uri_part import RewriteURIPart + +__all__ = [ + "RewriteRule", + "ActionParameters", + "ActionParametersHeaders", + "ActionParametersHeadersRemoveHeader", + "ActionParametersHeadersStaticHeader", + "ActionParametersHeadersDynamicHeader", + "ActionParametersURI", +] + + +class ActionParametersHeadersRemoveHeader(BaseModel): + operation: Literal["remove"] + + +class ActionParametersHeadersStaticHeader(BaseModel): + operation: Literal["set"] + + value: str + """Static value for the header.""" + + +class ActionParametersHeadersDynamicHeader(BaseModel): + expression: str + """Expression for the header value.""" + + operation: Literal["set"] + + +ActionParametersHeaders = Union[ + ActionParametersHeadersRemoveHeader, ActionParametersHeadersStaticHeader, ActionParametersHeadersDynamicHeader +] + + +class ActionParametersURI(BaseModel): + path: Optional[RewriteURIPart] = None + """Path portion rewrite.""" + + query: Optional[RewriteURIPart] = None + """Query portion rewrite.""" + + +class ActionParameters(BaseModel): + headers: Optional[Dict[str, ActionParametersHeaders]] = None + """Map of request headers to modify.""" + + uri: Optional[ActionParametersURI] = None + """URI to rewrite the request to.""" + + +class RewriteRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["rewrite"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/rewrite_rule_param.py b/src/cloudflare/types/rulesets/rewrite_rule_param.py new file mode 100644 index 00000000000..0b0e5617f65 --- /dev/null +++ b/src/cloudflare/types/rulesets/rewrite_rule_param.py @@ -0,0 +1,84 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import Dict, Union +from typing_extensions import Literal, Required, TypedDict + +from .logging_param import LoggingParam +from .rewrite_uri_part_param import RewriteURIPartParam + +__all__ = [ + "RewriteRuleParam", + "ActionParameters", + "ActionParametersHeaders", + "ActionParametersHeadersRemoveHeader", + "ActionParametersHeadersStaticHeader", + "ActionParametersHeadersDynamicHeader", + "ActionParametersURI", +] + + +class ActionParametersHeadersRemoveHeader(TypedDict, total=False): + operation: Required[Literal["remove"]] + + +class ActionParametersHeadersStaticHeader(TypedDict, total=False): + operation: Required[Literal["set"]] + + value: Required[str] + """Static value for the header.""" + + +class ActionParametersHeadersDynamicHeader(TypedDict, total=False): + expression: Required[str] + """Expression for the header value.""" + + operation: Required[Literal["set"]] + + +ActionParametersHeaders = Union[ + ActionParametersHeadersRemoveHeader, ActionParametersHeadersStaticHeader, ActionParametersHeadersDynamicHeader +] + + +class ActionParametersURI(TypedDict, total=False): + path: RewriteURIPartParam + """Path portion rewrite.""" + + query: RewriteURIPartParam + """Query portion rewrite.""" + + +class ActionParameters(TypedDict, total=False): + headers: Dict[str, ActionParametersHeaders] + """Map of request headers to modify.""" + + uri: ActionParametersURI + """URI to rewrite the request to.""" + + +class RewriteRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["rewrite"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/rewrite_uri_part.py b/src/cloudflare/types/rulesets/rewrite_uri_part.py new file mode 100644 index 00000000000..b8620330c13 --- /dev/null +++ b/src/cloudflare/types/rulesets/rewrite_uri_part.py @@ -0,0 +1,20 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Union + +from ..._models import BaseModel + +__all__ = ["RewriteURIPart", "StaticValue", "DynamicValue"] + + +class StaticValue(BaseModel): + value: str + """Predefined replacement value.""" + + +class DynamicValue(BaseModel): + expression: str + """Expression to evaluate for the replacement value.""" + + +RewriteURIPart = Union[StaticValue, DynamicValue] diff --git a/src/cloudflare/types/rulesets/rewrite_uri_part_param.py b/src/cloudflare/types/rulesets/rewrite_uri_part_param.py new file mode 100644 index 00000000000..32d4397ceee --- /dev/null +++ b/src/cloudflare/types/rulesets/rewrite_uri_part_param.py @@ -0,0 +1,21 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import Union +from typing_extensions import Required, TypedDict + +__all__ = ["RewriteURIPartParam", "StaticValue", "DynamicValue"] + + +class StaticValue(TypedDict, total=False): + value: Required[str] + """Predefined replacement value.""" + + +class DynamicValue(TypedDict, total=False): + expression: Required[str] + """Expression to evaluate for the replacement value.""" + + +RewriteURIPartParam = Union[StaticValue, DynamicValue] diff --git a/src/cloudflare/types/rulesets/route_rule.py b/src/cloudflare/types/rulesets/route_rule.py new file mode 100644 index 00000000000..79ac7512ba0 --- /dev/null +++ b/src/cloudflare/types/rulesets/route_rule.py @@ -0,0 +1,69 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["RouteRule", "ActionParameters", "ActionParametersOrigin", "ActionParametersSni"] + + +class ActionParametersOrigin(BaseModel): + host: Optional[str] = None + """Override the resolved hostname.""" + + port: Optional[float] = None + """Override the destination port.""" + + +class ActionParametersSni(BaseModel): + value: str + """The SNI override.""" + + +class ActionParameters(BaseModel): + host_header: Optional[str] = None + """Rewrite the HTTP Host header.""" + + origin: Optional[ActionParametersOrigin] = None + """Override the IP/TCP destination.""" + + sni: Optional[ActionParametersSni] = None + """Override the Server Name Indication (SNI).""" + + +class RouteRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["route"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/route_rule_param.py b/src/cloudflare/types/rulesets/route_rule_param.py new file mode 100644 index 00000000000..06ba330a332 --- /dev/null +++ b/src/cloudflare/types/rulesets/route_rule_param.py @@ -0,0 +1,59 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, Required, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["RouteRuleParam", "ActionParameters", "ActionParametersOrigin", "ActionParametersSni"] + + +class ActionParametersOrigin(TypedDict, total=False): + host: str + """Override the resolved hostname.""" + + port: float + """Override the destination port.""" + + +class ActionParametersSni(TypedDict, total=False): + value: Required[str] + """The SNI override.""" + + +class ActionParameters(TypedDict, total=False): + host_header: str + """Rewrite the HTTP Host header.""" + + origin: ActionParametersOrigin + """Override the IP/TCP destination.""" + + sni: ActionParametersSni + """Override the Server Name Indication (SNI).""" + + +class RouteRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["route"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/rule_create_params.py b/src/cloudflare/types/rulesets/rule_create_params.py index f6098adb173..02cb342935a 100644 --- a/src/cloudflare/types/rulesets/rule_create_params.py +++ b/src/cloudflare/types/rulesets/rule_create_params.py @@ -6,75 +6,70 @@ from typing_extensions import Literal, Required, TypedDict from .logging_param import LoggingParam +from .rewrite_uri_part_param import RewriteURIPartParam __all__ = [ "RuleCreateParams", "BlockRule", "BlockRuleActionParameters", "BlockRuleActionParametersResponse", - "RulesetsChallengeRule", - "RulesetsCompressResponseRule", - "RulesetsCompressResponseRuleActionParameters", - "RulesetsCompressResponseRuleActionParametersAlgorithm", + "ChallengeRule", + "CompressResponseRule", + "CompressResponseRuleActionParameters", + "CompressResponseRuleActionParametersAlgorithm", "ExecuteRule", "ExecuteRuleActionParameters", "ExecuteRuleActionParametersMatchedData", "ExecuteRuleActionParametersOverrides", "ExecuteRuleActionParametersOverridesCategory", "ExecuteRuleActionParametersOverridesRule", - "RulesetsJsChallengeRule", + "JsChallengeRule", "LogRule", - "RulesetsManagedChallengeRule", - "RulesetsRedirectRule", - "RulesetsRedirectRuleActionParameters", - "RulesetsRedirectRuleActionParametersFromList", - "RulesetsRedirectRuleActionParametersFromValue", - "RulesetsRedirectRuleActionParametersFromValueTargetURL", - "RulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RulesetsRewriteRule", - "RulesetsRewriteRuleActionParameters", - "RulesetsRewriteRuleActionParametersHeaders", - "RulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RulesetsRewriteRuleActionParametersURI", - "RulesetsRewriteRuleActionParametersURIPath", - "RulesetsRewriteRuleActionParametersURIPathStaticValue", - "RulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RulesetsRewriteRuleActionParametersURIQuery", - "RulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RulesetsRouteRule", - "RulesetsRouteRuleActionParameters", - "RulesetsRouteRuleActionParametersOrigin", - "RulesetsRouteRuleActionParametersSni", - "RulesetsScoreRule", - "RulesetsScoreRuleActionParameters", - "RulesetsServeErrorRule", - "RulesetsServeErrorRuleActionParameters", - "RulesetsSetConfigRule", - "RulesetsSetConfigRuleActionParameters", - "RulesetsSetConfigRuleActionParametersAutominify", + "ManagedChallengeRule", + "RedirectRule", + "RedirectRuleActionParameters", + "RedirectRuleActionParametersFromList", + "RedirectRuleActionParametersFromValue", + "RedirectRuleActionParametersFromValueTargetURL", + "RedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", + "RedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", + "RewriteRule", + "RewriteRuleActionParameters", + "RewriteRuleActionParametersHeaders", + "RewriteRuleActionParametersHeadersRemoveHeader", + "RewriteRuleActionParametersHeadersStaticHeader", + "RewriteRuleActionParametersHeadersDynamicHeader", + "RewriteRuleActionParametersURI", + "RouteRule", + "RouteRuleActionParameters", + "RouteRuleActionParametersOrigin", + "RouteRuleActionParametersSni", + "ScoreRule", + "ScoreRuleActionParameters", + "ServeErrorRule", + "ServeErrorRuleActionParameters", + "SetConfigRule", + "SetConfigRuleActionParameters", + "SetConfigRuleActionParametersAutominify", "SkipRule", "SkipRuleActionParameters", - "RulesetsSetCacheSettingsRule", - "RulesetsSetCacheSettingsRuleActionParameters", - "RulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RulesetsSetCacheSettingsRuleActionParametersServeStale", + "SetCacheSettingsRule", + "SetCacheSettingsRuleActionParameters", + "SetCacheSettingsRuleActionParametersBrowserTTL", + "SetCacheSettingsRuleActionParametersCacheKey", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKey", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", + "SetCacheSettingsRuleActionParametersCacheReserve", + "SetCacheSettingsRuleActionParametersEdgeTTL", + "SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", + "SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", + "SetCacheSettingsRuleActionParametersServeStale", ] @@ -126,7 +121,7 @@ class BlockRuleActionParameters(TypedDict, total=False): """The response to show when the block is applied.""" -class RulesetsChallengeRule(TypedDict, total=False): +class ChallengeRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -158,7 +153,7 @@ class RulesetsChallengeRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsCompressResponseRule(TypedDict, total=False): +class CompressResponseRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -171,7 +166,7 @@ class RulesetsCompressResponseRule(TypedDict, total=False): action: Literal["compress_response"] """The action to perform when the rule matches.""" - action_parameters: RulesetsCompressResponseRuleActionParameters + action_parameters: CompressResponseRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -190,13 +185,13 @@ class RulesetsCompressResponseRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsCompressResponseRuleActionParametersAlgorithm(TypedDict, total=False): +class CompressResponseRuleActionParametersAlgorithm(TypedDict, total=False): name: Literal["none", "auto", "default", "gzip", "brotli"] """Name of compression algorithm to enable.""" -class RulesetsCompressResponseRuleActionParameters(TypedDict, total=False): - algorithms: Iterable[RulesetsCompressResponseRuleActionParametersAlgorithm] +class CompressResponseRuleActionParameters(TypedDict, total=False): + algorithms: Iterable[CompressResponseRuleActionParametersAlgorithm] """Custom order for compression algorithms.""" @@ -309,7 +304,7 @@ class ExecuteRuleActionParameters(TypedDict, total=False): """A set of overrides to apply to the target ruleset.""" -class RulesetsJsChallengeRule(TypedDict, total=False): +class JsChallengeRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -373,7 +368,7 @@ class LogRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsManagedChallengeRule(TypedDict, total=False): +class ManagedChallengeRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -405,7 +400,7 @@ class RulesetsManagedChallengeRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRedirectRule(TypedDict, total=False): +class RedirectRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -418,7 +413,7 @@ class RulesetsRedirectRule(TypedDict, total=False): action: Literal["redirect"] """The action to perform when the rule matches.""" - action_parameters: RulesetsRedirectRuleActionParameters + action_parameters: RedirectRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -437,7 +432,7 @@ class RulesetsRedirectRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRedirectRuleActionParametersFromList(TypedDict, total=False): +class RedirectRuleActionParametersFromList(TypedDict, total=False): key: str """Expression that evaluates to the list lookup key.""" @@ -445,42 +440,42 @@ class RulesetsRedirectRuleActionParametersFromList(TypedDict, total=False): """The name of the list to match against.""" -class RulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): +class RedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): value: str """The URL to redirect the request to.""" -class RulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): +class RedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): expression: str """An expression to evaluate to get the URL to redirect the request to.""" -RulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, +RedirectRuleActionParametersFromValueTargetURL = Union[ + RedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, + RedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, ] -class RulesetsRedirectRuleActionParametersFromValue(TypedDict, total=False): +class RedirectRuleActionParametersFromValue(TypedDict, total=False): preserve_query_string: bool """Keep the query string of the original request.""" status_code: Literal[301, 302, 303, 307, 308] """The status code to be used for the redirect.""" - target_url: RulesetsRedirectRuleActionParametersFromValueTargetURL + target_url: RedirectRuleActionParametersFromValueTargetURL """The URL to redirect the request to.""" -class RulesetsRedirectRuleActionParameters(TypedDict, total=False): - from_list: RulesetsRedirectRuleActionParametersFromList +class RedirectRuleActionParameters(TypedDict, total=False): + from_list: RedirectRuleActionParametersFromList """Serve a redirect based on a bulk list lookup.""" - from_value: RulesetsRedirectRuleActionParametersFromValue + from_value: RedirectRuleActionParametersFromValue """Serve a redirect based on the request properties.""" -class RulesetsRewriteRule(TypedDict, total=False): +class RewriteRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -493,7 +488,7 @@ class RulesetsRewriteRule(TypedDict, total=False): action: Literal["rewrite"] """The action to perform when the rule matches.""" - action_parameters: RulesetsRewriteRuleActionParameters + action_parameters: RewriteRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -512,78 +507,48 @@ class RulesetsRewriteRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRewriteRuleActionParametersHeadersRemoveHeader(TypedDict, total=False): +class RewriteRuleActionParametersHeadersRemoveHeader(TypedDict, total=False): operation: Required[Literal["remove"]] -class RulesetsRewriteRuleActionParametersHeadersStaticHeader(TypedDict, total=False): +class RewriteRuleActionParametersHeadersStaticHeader(TypedDict, total=False): operation: Required[Literal["set"]] value: Required[str] """Static value for the header.""" -class RulesetsRewriteRuleActionParametersHeadersDynamicHeader(TypedDict, total=False): +class RewriteRuleActionParametersHeadersDynamicHeader(TypedDict, total=False): expression: Required[str] """Expression for the header value.""" operation: Required[Literal["set"]] -RulesetsRewriteRuleActionParametersHeaders = Union[ - RulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RulesetsRewriteRuleActionParametersHeadersStaticHeader, - RulesetsRewriteRuleActionParametersHeadersDynamicHeader, +RewriteRuleActionParametersHeaders = Union[ + RewriteRuleActionParametersHeadersRemoveHeader, + RewriteRuleActionParametersHeadersStaticHeader, + RewriteRuleActionParametersHeadersDynamicHeader, ] -class RulesetsRewriteRuleActionParametersURIPathStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RulesetsRewriteRuleActionParametersURIPathDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RulesetsRewriteRuleActionParametersURIPath = Union[ - RulesetsRewriteRuleActionParametersURIPathStaticValue, RulesetsRewriteRuleActionParametersURIPathDynamicValue -] - - -class RulesetsRewriteRuleActionParametersURIQueryStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RulesetsRewriteRuleActionParametersURIQueryDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RulesetsRewriteRuleActionParametersURIQuery = Union[ - RulesetsRewriteRuleActionParametersURIQueryStaticValue, RulesetsRewriteRuleActionParametersURIQueryDynamicValue -] - - -class RulesetsRewriteRuleActionParametersURI(TypedDict, total=False): - path: RulesetsRewriteRuleActionParametersURIPath +class RewriteRuleActionParametersURI(TypedDict, total=False): + path: RewriteURIPartParam """Path portion rewrite.""" - query: RulesetsRewriteRuleActionParametersURIQuery + query: RewriteURIPartParam """Query portion rewrite.""" -class RulesetsRewriteRuleActionParameters(TypedDict, total=False): - headers: Dict[str, RulesetsRewriteRuleActionParametersHeaders] +class RewriteRuleActionParameters(TypedDict, total=False): + headers: Dict[str, RewriteRuleActionParametersHeaders] """Map of request headers to modify.""" - uri: RulesetsRewriteRuleActionParametersURI + uri: RewriteRuleActionParametersURI """URI to rewrite the request to.""" -class RulesetsRouteRule(TypedDict, total=False): +class RouteRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -596,7 +561,7 @@ class RulesetsRouteRule(TypedDict, total=False): action: Literal["route"] """The action to perform when the rule matches.""" - action_parameters: RulesetsRouteRuleActionParameters + action_parameters: RouteRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -615,7 +580,7 @@ class RulesetsRouteRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRouteRuleActionParametersOrigin(TypedDict, total=False): +class RouteRuleActionParametersOrigin(TypedDict, total=False): host: str """Override the resolved hostname.""" @@ -623,23 +588,23 @@ class RulesetsRouteRuleActionParametersOrigin(TypedDict, total=False): """Override the destination port.""" -class RulesetsRouteRuleActionParametersSni(TypedDict, total=False): +class RouteRuleActionParametersSni(TypedDict, total=False): value: Required[str] """The SNI override.""" -class RulesetsRouteRuleActionParameters(TypedDict, total=False): +class RouteRuleActionParameters(TypedDict, total=False): host_header: str """Rewrite the HTTP Host header.""" - origin: RulesetsRouteRuleActionParametersOrigin + origin: RouteRuleActionParametersOrigin """Override the IP/TCP destination.""" - sni: RulesetsRouteRuleActionParametersSni + sni: RouteRuleActionParametersSni """Override the Server Name Indication (SNI).""" -class RulesetsScoreRule(TypedDict, total=False): +class ScoreRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -652,7 +617,7 @@ class RulesetsScoreRule(TypedDict, total=False): action: Literal["score"] """The action to perform when the rule matches.""" - action_parameters: RulesetsScoreRuleActionParameters + action_parameters: ScoreRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -671,7 +636,7 @@ class RulesetsScoreRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsScoreRuleActionParameters(TypedDict, total=False): +class ScoreRuleActionParameters(TypedDict, total=False): increment: int """ Increment contains the delta to change the score and can be either positive or @@ -679,7 +644,7 @@ class RulesetsScoreRuleActionParameters(TypedDict, total=False): """ -class RulesetsServeErrorRule(TypedDict, total=False): +class ServeErrorRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -692,7 +657,7 @@ class RulesetsServeErrorRule(TypedDict, total=False): action: Literal["serve_error"] """The action to perform when the rule matches.""" - action_parameters: RulesetsServeErrorRuleActionParameters + action_parameters: ServeErrorRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -711,7 +676,7 @@ class RulesetsServeErrorRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsServeErrorRuleActionParameters(TypedDict, total=False): +class ServeErrorRuleActionParameters(TypedDict, total=False): content: str """Error response content.""" @@ -722,7 +687,7 @@ class RulesetsServeErrorRuleActionParameters(TypedDict, total=False): """The status code to use for the error.""" -class RulesetsSetConfigRule(TypedDict, total=False): +class SetConfigRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -735,7 +700,7 @@ class RulesetsSetConfigRule(TypedDict, total=False): action: Literal["set_config"] """The action to perform when the rule matches.""" - action_parameters: RulesetsSetConfigRuleActionParameters + action_parameters: SetConfigRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -754,7 +719,7 @@ class RulesetsSetConfigRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsSetConfigRuleActionParametersAutominify(TypedDict, total=False): +class SetConfigRuleActionParametersAutominify(TypedDict, total=False): css: bool """Minify CSS files.""" @@ -765,11 +730,11 @@ class RulesetsSetConfigRuleActionParametersAutominify(TypedDict, total=False): """Minify JS files.""" -class RulesetsSetConfigRuleActionParameters(TypedDict, total=False): +class SetConfigRuleActionParameters(TypedDict, total=False): automatic_https_rewrites: bool """Turn on or off Automatic HTTPS Rewrites.""" - autominify: RulesetsSetConfigRuleActionParametersAutominify + autominify: SetConfigRuleActionParametersAutominify """Select which file extensions to minify automatically.""" bic: bool @@ -899,7 +864,7 @@ class SkipRuleActionParameters(TypedDict, total=False): """ -class RulesetsSetCacheSettingsRule(TypedDict, total=False): +class SetCacheSettingsRule(TypedDict, total=False): account_id: str """The Account ID to use for this endpoint. Mutually exclusive with the Zone ID.""" @@ -912,7 +877,7 @@ class RulesetsSetCacheSettingsRule(TypedDict, total=False): action: Literal["set_cache_settings"] """The action to perform when the rule matches.""" - action_parameters: RulesetsSetCacheSettingsRuleActionParameters + action_parameters: SetCacheSettingsRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -931,7 +896,7 @@ class RulesetsSetCacheSettingsRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsSetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=False): mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] """Determines which browser ttl mode to use.""" @@ -939,7 +904,7 @@ class RulesetsSetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=Fa """The TTL (in seconds) if you choose override_origin mode.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): check_presence: List[str] """Checks for the presence of these cookie names. @@ -950,7 +915,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedD """Include these cookies' names and their values.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): check_presence: List[str] """Checks for the presence of these header names. @@ -967,7 +932,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedD """Include these headers' names and their values.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): resolved: bool """Use the resolved host in the cache key. @@ -976,7 +941,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDic """ -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): all: bool """Exclude all query string parameters from use in building the cache key.""" @@ -988,7 +953,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringEx """ -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): all: bool """Use all query string parameters in the cache key.""" @@ -996,21 +961,21 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringIn """A list of query string parameters used to build the cache key.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): - exclude: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): + exclude: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude """ build the cache key using all query string parameters EXCECPT these excluded parameters """ - include: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude + include: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude """ build the cache key using a list of query string parameters that ARE in the request. """ -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): device_type: bool """Use the user agent's device type in the cache key.""" @@ -1021,27 +986,27 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDic """Use the user agent's language in the cache key.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(TypedDict, total=False): - cookie: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie +class SetCacheSettingsRuleActionParametersCacheKeyCustomKey(TypedDict, total=False): + cookie: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie """The cookies to include in building the cache key.""" - header: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader + header: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader """The header names and values to include in building the cache key.""" - host: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost + host: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost """Whether to use the original host or the resolved host in the cache key.""" - query_string: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString + query_string: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString """ Use the presence or absence of parameters in the query string to build the cache key. """ - user: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser + user: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser """Characteristics of the request user agent used in building the cache key.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=False): cache_by_device_type: bool """Separate cached content based on the visitor’s device type""" @@ -1051,7 +1016,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=Fals cached """ - custom_key: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey + custom_key: SetCacheSettingsRuleActionParametersCacheKeyCustomKey """ Customize which components of the request are included or excluded from the cache key. @@ -1064,7 +1029,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=Fals """ -class RulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total=False): eligible: Required[bool] """Determines whether cache reserve is enabled. @@ -1076,8 +1041,8 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total= """The minimum file size eligible for store in cache reserve.""" -_RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( - "_RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", +_SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( + "_SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", { "from": int, }, @@ -1085,14 +1050,14 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total= ) -class RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( - _RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False +class SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( + _SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False ): to: Required[int] """response status code upper bound""" -class RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): value: Required[int] """Time to cache a response (in seconds). @@ -1101,25 +1066,25 @@ class RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict value of "no-store". """ - status_code_range: RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange + status_code_range: SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange """The range of status codes used to apply the selected mode.""" status_code_value: int """Set the ttl for responses with this specific status code""" -class RulesetsSetCacheSettingsRuleActionParametersEdgeTTL(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersEdgeTTL(TypedDict, total=False): default: Required[int] """The TTL (in seconds) if you choose override_origin mode.""" mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] """edge ttl options""" - status_code_ttl: Required[Iterable[RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL]] + status_code_ttl: Required[Iterable[SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL]] """List of single status codes, or status code ranges to apply the selected mode""" -class RulesetsSetCacheSettingsRuleActionParametersServeStale(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersServeStale(TypedDict, total=False): disable_stale_while_updating: Required[bool] """Defines whether Cloudflare should serve stale content while updating. @@ -1128,11 +1093,11 @@ class RulesetsSetCacheSettingsRuleActionParametersServeStale(TypedDict, total=Fa """ -class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): +class SetCacheSettingsRuleActionParameters(TypedDict, total=False): additional_cacheable_ports: Iterable[int] """List of additional ports that caching can be enabled on.""" - browser_ttl: RulesetsSetCacheSettingsRuleActionParametersBrowserTTL + browser_ttl: SetCacheSettingsRuleActionParametersBrowserTTL """Specify how long client browsers should cache the response. Cloudflare cache purge will not purge content cached on client browsers, so high @@ -1146,19 +1111,19 @@ class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): caching configurations. """ - cache_key: RulesetsSetCacheSettingsRuleActionParametersCacheKey + cache_key: SetCacheSettingsRuleActionParametersCacheKey """ Define which components of the request are included or excluded from the cache key Cloudflare uses to store the response in cache. """ - cache_reserve: RulesetsSetCacheSettingsRuleActionParametersCacheReserve + cache_reserve: SetCacheSettingsRuleActionParametersCacheReserve """ Mark whether the request's response from origin is eligible for Cache Reserve (requires a Cache Reserve add-on plan). """ - edge_ttl: RulesetsSetCacheSettingsRuleActionParametersEdgeTTL + edge_ttl: SetCacheSettingsRuleActionParametersEdgeTTL """ TTL (Time to Live) specifies the maximum time to cache a resource in the Cloudflare edge network. @@ -1188,7 +1153,7 @@ class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. """ - serve_stale: RulesetsSetCacheSettingsRuleActionParametersServeStale + serve_stale: SetCacheSettingsRuleActionParametersServeStale """ Define if Cloudflare should serve stale content while getting the latest content from the origin. If on, Cloudflare will not serve stale content while getting @@ -1198,18 +1163,18 @@ class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): RuleCreateParams = Union[ BlockRule, - RulesetsChallengeRule, - RulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RulesetsManagedChallengeRule, - RulesetsRedirectRule, - RulesetsRewriteRule, - RulesetsRouteRule, - RulesetsScoreRule, - RulesetsServeErrorRule, - RulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/rule_create_response.py b/src/cloudflare/types/rulesets/rule_create_response.py index 76b96406f5d..8f06a060fef 100644 --- a/src/cloudflare/types/rulesets/rule_create_response.py +++ b/src/cloudflare/types/rulesets/rule_create_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from .logging import Logging from .log_rule import LogRule from ..._models import BaseModel from .skip_rule import SkipRule from .block_rule import BlockRule +from .route_rule import RouteRule +from .score_rule import ScoreRule from .execute_rule import ExecuteRule - -__all__ = [ - "RuleCreateResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rewrite_rule import RewriteRule +from .redirect_rule import RedirectRule +from .challenge_rule import ChallengeRule +from .set_config_rule import SetConfigRule +from .serve_error_rule import ServeErrorRule +from .js_challenge_rule import JsChallengeRule +from .compress_response_rule import CompressResponseRule +from .managed_challenge_rule import ManagedChallengeRule +from .set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["RuleCreateResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/rule_delete_response.py b/src/cloudflare/types/rulesets/rule_delete_response.py index c475e49a89a..919358ff3fa 100644 --- a/src/cloudflare/types/rulesets/rule_delete_response.py +++ b/src/cloudflare/types/rulesets/rule_delete_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from .logging import Logging from .log_rule import LogRule from ..._models import BaseModel from .skip_rule import SkipRule from .block_rule import BlockRule +from .route_rule import RouteRule +from .score_rule import ScoreRule from .execute_rule import ExecuteRule - -__all__ = [ - "RuleDeleteResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rewrite_rule import RewriteRule +from .redirect_rule import RedirectRule +from .challenge_rule import ChallengeRule +from .set_config_rule import SetConfigRule +from .serve_error_rule import ServeErrorRule +from .js_challenge_rule import JsChallengeRule +from .compress_response_rule import CompressResponseRule +from .managed_challenge_rule import ManagedChallengeRule +from .set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["RuleDeleteResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/rule_edit_params.py b/src/cloudflare/types/rulesets/rule_edit_params.py index 00117df9400..297e2a99aaf 100644 --- a/src/cloudflare/types/rulesets/rule_edit_params.py +++ b/src/cloudflare/types/rulesets/rule_edit_params.py @@ -6,75 +6,70 @@ from typing_extensions import Literal, Required, TypedDict from .logging_param import LoggingParam +from .rewrite_uri_part_param import RewriteURIPartParam __all__ = [ "RuleEditParams", "BlockRule", "BlockRuleActionParameters", "BlockRuleActionParametersResponse", - "RulesetsChallengeRule", - "RulesetsCompressResponseRule", - "RulesetsCompressResponseRuleActionParameters", - "RulesetsCompressResponseRuleActionParametersAlgorithm", + "ChallengeRule", + "CompressResponseRule", + "CompressResponseRuleActionParameters", + "CompressResponseRuleActionParametersAlgorithm", "ExecuteRule", "ExecuteRuleActionParameters", "ExecuteRuleActionParametersMatchedData", "ExecuteRuleActionParametersOverrides", "ExecuteRuleActionParametersOverridesCategory", "ExecuteRuleActionParametersOverridesRule", - "RulesetsJsChallengeRule", + "JsChallengeRule", "LogRule", - "RulesetsManagedChallengeRule", - "RulesetsRedirectRule", - "RulesetsRedirectRuleActionParameters", - "RulesetsRedirectRuleActionParametersFromList", - "RulesetsRedirectRuleActionParametersFromValue", - "RulesetsRedirectRuleActionParametersFromValueTargetURL", - "RulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RulesetsRewriteRule", - "RulesetsRewriteRuleActionParameters", - "RulesetsRewriteRuleActionParametersHeaders", - "RulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RulesetsRewriteRuleActionParametersURI", - "RulesetsRewriteRuleActionParametersURIPath", - "RulesetsRewriteRuleActionParametersURIPathStaticValue", - "RulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RulesetsRewriteRuleActionParametersURIQuery", - "RulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RulesetsRouteRule", - "RulesetsRouteRuleActionParameters", - "RulesetsRouteRuleActionParametersOrigin", - "RulesetsRouteRuleActionParametersSni", - "RulesetsScoreRule", - "RulesetsScoreRuleActionParameters", - "RulesetsServeErrorRule", - "RulesetsServeErrorRuleActionParameters", - "RulesetsSetConfigRule", - "RulesetsSetConfigRuleActionParameters", - "RulesetsSetConfigRuleActionParametersAutominify", + "ManagedChallengeRule", + "RedirectRule", + "RedirectRuleActionParameters", + "RedirectRuleActionParametersFromList", + "RedirectRuleActionParametersFromValue", + "RedirectRuleActionParametersFromValueTargetURL", + "RedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", + "RedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", + "RewriteRule", + "RewriteRuleActionParameters", + "RewriteRuleActionParametersHeaders", + "RewriteRuleActionParametersHeadersRemoveHeader", + "RewriteRuleActionParametersHeadersStaticHeader", + "RewriteRuleActionParametersHeadersDynamicHeader", + "RewriteRuleActionParametersURI", + "RouteRule", + "RouteRuleActionParameters", + "RouteRuleActionParametersOrigin", + "RouteRuleActionParametersSni", + "ScoreRule", + "ScoreRuleActionParameters", + "ServeErrorRule", + "ServeErrorRuleActionParameters", + "SetConfigRule", + "SetConfigRuleActionParameters", + "SetConfigRuleActionParametersAutominify", "SkipRule", "SkipRuleActionParameters", - "RulesetsSetCacheSettingsRule", - "RulesetsSetCacheSettingsRuleActionParameters", - "RulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RulesetsSetCacheSettingsRuleActionParametersServeStale", + "SetCacheSettingsRule", + "SetCacheSettingsRuleActionParameters", + "SetCacheSettingsRuleActionParametersBrowserTTL", + "SetCacheSettingsRuleActionParametersCacheKey", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKey", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", + "SetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", + "SetCacheSettingsRuleActionParametersCacheReserve", + "SetCacheSettingsRuleActionParametersEdgeTTL", + "SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", + "SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", + "SetCacheSettingsRuleActionParametersServeStale", ] @@ -129,7 +124,7 @@ class BlockRuleActionParameters(TypedDict, total=False): """The response to show when the block is applied.""" -class RulesetsChallengeRule(TypedDict, total=False): +class ChallengeRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -164,7 +159,7 @@ class RulesetsChallengeRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsCompressResponseRule(TypedDict, total=False): +class CompressResponseRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -180,7 +175,7 @@ class RulesetsCompressResponseRule(TypedDict, total=False): action: Literal["compress_response"] """The action to perform when the rule matches.""" - action_parameters: RulesetsCompressResponseRuleActionParameters + action_parameters: CompressResponseRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -199,13 +194,13 @@ class RulesetsCompressResponseRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsCompressResponseRuleActionParametersAlgorithm(TypedDict, total=False): +class CompressResponseRuleActionParametersAlgorithm(TypedDict, total=False): name: Literal["none", "auto", "default", "gzip", "brotli"] """Name of compression algorithm to enable.""" -class RulesetsCompressResponseRuleActionParameters(TypedDict, total=False): - algorithms: Iterable[RulesetsCompressResponseRuleActionParametersAlgorithm] +class CompressResponseRuleActionParameters(TypedDict, total=False): + algorithms: Iterable[CompressResponseRuleActionParametersAlgorithm] """Custom order for compression algorithms.""" @@ -321,7 +316,7 @@ class ExecuteRuleActionParameters(TypedDict, total=False): """A set of overrides to apply to the target ruleset.""" -class RulesetsJsChallengeRule(TypedDict, total=False): +class JsChallengeRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -391,7 +386,7 @@ class LogRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsManagedChallengeRule(TypedDict, total=False): +class ManagedChallengeRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -426,7 +421,7 @@ class RulesetsManagedChallengeRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRedirectRule(TypedDict, total=False): +class RedirectRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -442,7 +437,7 @@ class RulesetsRedirectRule(TypedDict, total=False): action: Literal["redirect"] """The action to perform when the rule matches.""" - action_parameters: RulesetsRedirectRuleActionParameters + action_parameters: RedirectRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -461,7 +456,7 @@ class RulesetsRedirectRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRedirectRuleActionParametersFromList(TypedDict, total=False): +class RedirectRuleActionParametersFromList(TypedDict, total=False): key: str """Expression that evaluates to the list lookup key.""" @@ -469,42 +464,42 @@ class RulesetsRedirectRuleActionParametersFromList(TypedDict, total=False): """The name of the list to match against.""" -class RulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): +class RedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(TypedDict, total=False): value: str """The URL to redirect the request to.""" -class RulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): +class RedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(TypedDict, total=False): expression: str """An expression to evaluate to get the URL to redirect the request to.""" -RulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, +RedirectRuleActionParametersFromValueTargetURL = Union[ + RedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, + RedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, ] -class RulesetsRedirectRuleActionParametersFromValue(TypedDict, total=False): +class RedirectRuleActionParametersFromValue(TypedDict, total=False): preserve_query_string: bool """Keep the query string of the original request.""" status_code: Literal[301, 302, 303, 307, 308] """The status code to be used for the redirect.""" - target_url: RulesetsRedirectRuleActionParametersFromValueTargetURL + target_url: RedirectRuleActionParametersFromValueTargetURL """The URL to redirect the request to.""" -class RulesetsRedirectRuleActionParameters(TypedDict, total=False): - from_list: RulesetsRedirectRuleActionParametersFromList +class RedirectRuleActionParameters(TypedDict, total=False): + from_list: RedirectRuleActionParametersFromList """Serve a redirect based on a bulk list lookup.""" - from_value: RulesetsRedirectRuleActionParametersFromValue + from_value: RedirectRuleActionParametersFromValue """Serve a redirect based on the request properties.""" -class RulesetsRewriteRule(TypedDict, total=False): +class RewriteRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -520,7 +515,7 @@ class RulesetsRewriteRule(TypedDict, total=False): action: Literal["rewrite"] """The action to perform when the rule matches.""" - action_parameters: RulesetsRewriteRuleActionParameters + action_parameters: RewriteRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -539,78 +534,48 @@ class RulesetsRewriteRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRewriteRuleActionParametersHeadersRemoveHeader(TypedDict, total=False): +class RewriteRuleActionParametersHeadersRemoveHeader(TypedDict, total=False): operation: Required[Literal["remove"]] -class RulesetsRewriteRuleActionParametersHeadersStaticHeader(TypedDict, total=False): +class RewriteRuleActionParametersHeadersStaticHeader(TypedDict, total=False): operation: Required[Literal["set"]] value: Required[str] """Static value for the header.""" -class RulesetsRewriteRuleActionParametersHeadersDynamicHeader(TypedDict, total=False): +class RewriteRuleActionParametersHeadersDynamicHeader(TypedDict, total=False): expression: Required[str] """Expression for the header value.""" operation: Required[Literal["set"]] -RulesetsRewriteRuleActionParametersHeaders = Union[ - RulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RulesetsRewriteRuleActionParametersHeadersStaticHeader, - RulesetsRewriteRuleActionParametersHeadersDynamicHeader, +RewriteRuleActionParametersHeaders = Union[ + RewriteRuleActionParametersHeadersRemoveHeader, + RewriteRuleActionParametersHeadersStaticHeader, + RewriteRuleActionParametersHeadersDynamicHeader, ] -class RulesetsRewriteRuleActionParametersURIPathStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RulesetsRewriteRuleActionParametersURIPathDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RulesetsRewriteRuleActionParametersURIPath = Union[ - RulesetsRewriteRuleActionParametersURIPathStaticValue, RulesetsRewriteRuleActionParametersURIPathDynamicValue -] - - -class RulesetsRewriteRuleActionParametersURIQueryStaticValue(TypedDict, total=False): - value: Required[str] - """Predefined replacement value.""" - - -class RulesetsRewriteRuleActionParametersURIQueryDynamicValue(TypedDict, total=False): - expression: Required[str] - """Expression to evaluate for the replacement value.""" - - -RulesetsRewriteRuleActionParametersURIQuery = Union[ - RulesetsRewriteRuleActionParametersURIQueryStaticValue, RulesetsRewriteRuleActionParametersURIQueryDynamicValue -] - - -class RulesetsRewriteRuleActionParametersURI(TypedDict, total=False): - path: RulesetsRewriteRuleActionParametersURIPath +class RewriteRuleActionParametersURI(TypedDict, total=False): + path: RewriteURIPartParam """Path portion rewrite.""" - query: RulesetsRewriteRuleActionParametersURIQuery + query: RewriteURIPartParam """Query portion rewrite.""" -class RulesetsRewriteRuleActionParameters(TypedDict, total=False): - headers: Dict[str, RulesetsRewriteRuleActionParametersHeaders] +class RewriteRuleActionParameters(TypedDict, total=False): + headers: Dict[str, RewriteRuleActionParametersHeaders] """Map of request headers to modify.""" - uri: RulesetsRewriteRuleActionParametersURI + uri: RewriteRuleActionParametersURI """URI to rewrite the request to.""" -class RulesetsRouteRule(TypedDict, total=False): +class RouteRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -626,7 +591,7 @@ class RulesetsRouteRule(TypedDict, total=False): action: Literal["route"] """The action to perform when the rule matches.""" - action_parameters: RulesetsRouteRuleActionParameters + action_parameters: RouteRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -645,7 +610,7 @@ class RulesetsRouteRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsRouteRuleActionParametersOrigin(TypedDict, total=False): +class RouteRuleActionParametersOrigin(TypedDict, total=False): host: str """Override the resolved hostname.""" @@ -653,23 +618,23 @@ class RulesetsRouteRuleActionParametersOrigin(TypedDict, total=False): """Override the destination port.""" -class RulesetsRouteRuleActionParametersSni(TypedDict, total=False): +class RouteRuleActionParametersSni(TypedDict, total=False): value: Required[str] """The SNI override.""" -class RulesetsRouteRuleActionParameters(TypedDict, total=False): +class RouteRuleActionParameters(TypedDict, total=False): host_header: str """Rewrite the HTTP Host header.""" - origin: RulesetsRouteRuleActionParametersOrigin + origin: RouteRuleActionParametersOrigin """Override the IP/TCP destination.""" - sni: RulesetsRouteRuleActionParametersSni + sni: RouteRuleActionParametersSni """Override the Server Name Indication (SNI).""" -class RulesetsScoreRule(TypedDict, total=False): +class ScoreRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -685,7 +650,7 @@ class RulesetsScoreRule(TypedDict, total=False): action: Literal["score"] """The action to perform when the rule matches.""" - action_parameters: RulesetsScoreRuleActionParameters + action_parameters: ScoreRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -704,7 +669,7 @@ class RulesetsScoreRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsScoreRuleActionParameters(TypedDict, total=False): +class ScoreRuleActionParameters(TypedDict, total=False): increment: int """ Increment contains the delta to change the score and can be either positive or @@ -712,7 +677,7 @@ class RulesetsScoreRuleActionParameters(TypedDict, total=False): """ -class RulesetsServeErrorRule(TypedDict, total=False): +class ServeErrorRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -728,7 +693,7 @@ class RulesetsServeErrorRule(TypedDict, total=False): action: Literal["serve_error"] """The action to perform when the rule matches.""" - action_parameters: RulesetsServeErrorRuleActionParameters + action_parameters: ServeErrorRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -747,7 +712,7 @@ class RulesetsServeErrorRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsServeErrorRuleActionParameters(TypedDict, total=False): +class ServeErrorRuleActionParameters(TypedDict, total=False): content: str """Error response content.""" @@ -758,7 +723,7 @@ class RulesetsServeErrorRuleActionParameters(TypedDict, total=False): """The status code to use for the error.""" -class RulesetsSetConfigRule(TypedDict, total=False): +class SetConfigRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -774,7 +739,7 @@ class RulesetsSetConfigRule(TypedDict, total=False): action: Literal["set_config"] """The action to perform when the rule matches.""" - action_parameters: RulesetsSetConfigRuleActionParameters + action_parameters: SetConfigRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -793,7 +758,7 @@ class RulesetsSetConfigRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsSetConfigRuleActionParametersAutominify(TypedDict, total=False): +class SetConfigRuleActionParametersAutominify(TypedDict, total=False): css: bool """Minify CSS files.""" @@ -804,11 +769,11 @@ class RulesetsSetConfigRuleActionParametersAutominify(TypedDict, total=False): """Minify JS files.""" -class RulesetsSetConfigRuleActionParameters(TypedDict, total=False): +class SetConfigRuleActionParameters(TypedDict, total=False): automatic_https_rewrites: bool """Turn on or off Automatic HTTPS Rewrites.""" - autominify: RulesetsSetConfigRuleActionParametersAutominify + autominify: SetConfigRuleActionParametersAutominify """Select which file extensions to minify automatically.""" bic: bool @@ -941,7 +906,7 @@ class SkipRuleActionParameters(TypedDict, total=False): """ -class RulesetsSetCacheSettingsRule(TypedDict, total=False): +class SetCacheSettingsRule(TypedDict, total=False): ruleset_id: Required[str] """The unique ID of the ruleset.""" @@ -957,7 +922,7 @@ class RulesetsSetCacheSettingsRule(TypedDict, total=False): action: Literal["set_cache_settings"] """The action to perform when the rule matches.""" - action_parameters: RulesetsSetCacheSettingsRuleActionParameters + action_parameters: SetCacheSettingsRuleActionParameters """The parameters configuring the rule's action.""" description: str @@ -976,7 +941,7 @@ class RulesetsSetCacheSettingsRule(TypedDict, total=False): """The reference of the rule (the rule ID by default).""" -class RulesetsSetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=False): mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] """Determines which browser ttl mode to use.""" @@ -984,7 +949,7 @@ class RulesetsSetCacheSettingsRuleActionParametersBrowserTTL(TypedDict, total=Fa """The TTL (in seconds) if you choose override_origin mode.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): check_presence: List[str] """Checks for the presence of these cookie names. @@ -995,7 +960,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(TypedD """Include these cookies' names and their values.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): check_presence: List[str] """Checks for the presence of these header names. @@ -1012,7 +977,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(TypedD """Include these headers' names and their values.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): resolved: bool """Use the resolved host in the cache key. @@ -1021,7 +986,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(TypedDic """ -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): all: bool """Exclude all query string parameters from use in building the cache key.""" @@ -1033,7 +998,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringEx """ -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): all: bool """Use all query string parameters in the cache key.""" @@ -1041,21 +1006,21 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringIn """A list of query string parameters used to build the cache key.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): - exclude: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): + exclude: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude """ build the cache key using all query string parameters EXCECPT these excluded parameters """ - include: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude + include: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude """ build the cache key using a list of query string parameters that ARE in the request. """ -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): device_type: bool """Use the user agent's device type in the cache key.""" @@ -1066,27 +1031,27 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(TypedDic """Use the user agent's language in the cache key.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(TypedDict, total=False): - cookie: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie +class SetCacheSettingsRuleActionParametersCacheKeyCustomKey(TypedDict, total=False): + cookie: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie """The cookies to include in building the cache key.""" - header: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader + header: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader """The header names and values to include in building the cache key.""" - host: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost + host: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost """Whether to use the original host or the resolved host in the cache key.""" - query_string: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString + query_string: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString """ Use the presence or absence of parameters in the query string to build the cache key. """ - user: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser + user: SetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser """Characteristics of the request user agent used in building the cache key.""" -class RulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=False): cache_by_device_type: bool """Separate cached content based on the visitor’s device type""" @@ -1096,7 +1061,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=Fals cached """ - custom_key: RulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey + custom_key: SetCacheSettingsRuleActionParametersCacheKeyCustomKey """ Customize which components of the request are included or excluded from the cache key. @@ -1109,7 +1074,7 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheKey(TypedDict, total=Fals """ -class RulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total=False): eligible: Required[bool] """Determines whether cache reserve is enabled. @@ -1121,8 +1086,8 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total= """The minimum file size eligible for store in cache reserve.""" -_RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( - "_RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", +_SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( + "_SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", { "from": int, }, @@ -1130,14 +1095,14 @@ class RulesetsSetCacheSettingsRuleActionParametersCacheReserve(TypedDict, total= ) -class RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( - _RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False +class SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( + _SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False ): to: Required[int] """response status code upper bound""" -class RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): value: Required[int] """Time to cache a response (in seconds). @@ -1146,25 +1111,25 @@ class RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(TypedDict value of "no-store". """ - status_code_range: RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange + status_code_range: SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange """The range of status codes used to apply the selected mode.""" status_code_value: int """Set the ttl for responses with this specific status code""" -class RulesetsSetCacheSettingsRuleActionParametersEdgeTTL(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersEdgeTTL(TypedDict, total=False): default: Required[int] """The TTL (in seconds) if you choose override_origin mode.""" mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] """edge ttl options""" - status_code_ttl: Required[Iterable[RulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL]] + status_code_ttl: Required[Iterable[SetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL]] """List of single status codes, or status code ranges to apply the selected mode""" -class RulesetsSetCacheSettingsRuleActionParametersServeStale(TypedDict, total=False): +class SetCacheSettingsRuleActionParametersServeStale(TypedDict, total=False): disable_stale_while_updating: Required[bool] """Defines whether Cloudflare should serve stale content while updating. @@ -1173,11 +1138,11 @@ class RulesetsSetCacheSettingsRuleActionParametersServeStale(TypedDict, total=Fa """ -class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): +class SetCacheSettingsRuleActionParameters(TypedDict, total=False): additional_cacheable_ports: Iterable[int] """List of additional ports that caching can be enabled on.""" - browser_ttl: RulesetsSetCacheSettingsRuleActionParametersBrowserTTL + browser_ttl: SetCacheSettingsRuleActionParametersBrowserTTL """Specify how long client browsers should cache the response. Cloudflare cache purge will not purge content cached on client browsers, so high @@ -1191,19 +1156,19 @@ class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): caching configurations. """ - cache_key: RulesetsSetCacheSettingsRuleActionParametersCacheKey + cache_key: SetCacheSettingsRuleActionParametersCacheKey """ Define which components of the request are included or excluded from the cache key Cloudflare uses to store the response in cache. """ - cache_reserve: RulesetsSetCacheSettingsRuleActionParametersCacheReserve + cache_reserve: SetCacheSettingsRuleActionParametersCacheReserve """ Mark whether the request's response from origin is eligible for Cache Reserve (requires a Cache Reserve add-on plan). """ - edge_ttl: RulesetsSetCacheSettingsRuleActionParametersEdgeTTL + edge_ttl: SetCacheSettingsRuleActionParametersEdgeTTL """ TTL (Time to Live) specifies the maximum time to cache a resource in the Cloudflare edge network. @@ -1233,7 +1198,7 @@ class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. """ - serve_stale: RulesetsSetCacheSettingsRuleActionParametersServeStale + serve_stale: SetCacheSettingsRuleActionParametersServeStale """ Define if Cloudflare should serve stale content while getting the latest content from the origin. If on, Cloudflare will not serve stale content while getting @@ -1243,18 +1208,18 @@ class RulesetsSetCacheSettingsRuleActionParameters(TypedDict, total=False): RuleEditParams = Union[ BlockRule, - RulesetsChallengeRule, - RulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RulesetsManagedChallengeRule, - RulesetsRedirectRule, - RulesetsRewriteRule, - RulesetsRouteRule, - RulesetsScoreRule, - RulesetsServeErrorRule, - RulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/rule_edit_response.py b/src/cloudflare/types/rulesets/rule_edit_response.py index 75a7e050b54..dd6f8f95ad9 100644 --- a/src/cloudflare/types/rulesets/rule_edit_response.py +++ b/src/cloudflare/types/rulesets/rule_edit_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from .logging import Logging from .log_rule import LogRule from ..._models import BaseModel from .skip_rule import SkipRule from .block_rule import BlockRule +from .route_rule import RouteRule +from .score_rule import ScoreRule from .execute_rule import ExecuteRule - -__all__ = [ - "RuleEditResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rewrite_rule import RewriteRule +from .redirect_rule import RedirectRule +from .challenge_rule import ChallengeRule +from .set_config_rule import SetConfigRule +from .serve_error_rule import ServeErrorRule +from .js_challenge_rule import JsChallengeRule +from .compress_response_rule import CompressResponseRule +from .managed_challenge_rule import ManagedChallengeRule +from .set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["RuleEditResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/score_rule.py b/src/cloudflare/types/rulesets/score_rule.py new file mode 100644 index 00000000000..508adc8d594 --- /dev/null +++ b/src/cloudflare/types/rulesets/score_rule.py @@ -0,0 +1,53 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["ScoreRule", "ActionParameters"] + + +class ActionParameters(BaseModel): + increment: Optional[int] = None + """ + Increment contains the delta to change the score and can be either positive or + negative. + """ + + +class ScoreRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["score"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/score_rule_param.py b/src/cloudflare/types/rulesets/score_rule_param.py new file mode 100644 index 00000000000..9a1db280e51 --- /dev/null +++ b/src/cloudflare/types/rulesets/score_rule_param.py @@ -0,0 +1,43 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["ScoreRuleParam", "ActionParameters"] + + +class ActionParameters(TypedDict, total=False): + increment: int + """ + Increment contains the delta to change the score and can be either positive or + negative. + """ + + +class ScoreRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["score"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/serve_error_rule.py b/src/cloudflare/types/rulesets/serve_error_rule.py new file mode 100644 index 00000000000..2713e5ec61d --- /dev/null +++ b/src/cloudflare/types/rulesets/serve_error_rule.py @@ -0,0 +1,56 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["ServeErrorRule", "ActionParameters"] + + +class ActionParameters(BaseModel): + content: Optional[str] = None + """Error response content.""" + + content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None + """Content-type header to set with the response.""" + + status_code: Optional[float] = None + """The status code to use for the error.""" + + +class ServeErrorRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["serve_error"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/serve_error_rule_param.py b/src/cloudflare/types/rulesets/serve_error_rule_param.py new file mode 100644 index 00000000000..d9d51bdbc08 --- /dev/null +++ b/src/cloudflare/types/rulesets/serve_error_rule_param.py @@ -0,0 +1,46 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["ServeErrorRuleParam", "ActionParameters"] + + +class ActionParameters(TypedDict, total=False): + content: str + """Error response content.""" + + content_type: Literal["application/json", "text/xml", "text/plain", "text/html"] + """Content-type header to set with the response.""" + + status_code: float + """The status code to use for the error.""" + + +class ServeErrorRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["serve_error"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/set_cache_settings_rule.py b/src/cloudflare/types/rulesets/set_cache_settings_rule.py new file mode 100644 index 00000000000..caac51356cf --- /dev/null +++ b/src/cloudflare/types/rulesets/set_cache_settings_rule.py @@ -0,0 +1,322 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from pydantic import Field as FieldInfo + +from .logging import Logging +from ..._models import BaseModel + +__all__ = [ + "SetCacheSettingsRule", + "ActionParameters", + "ActionParametersBrowserTTL", + "ActionParametersCacheKey", + "ActionParametersCacheKeyCustomKey", + "ActionParametersCacheKeyCustomKeyCookie", + "ActionParametersCacheKeyCustomKeyHeader", + "ActionParametersCacheKeyCustomKeyHost", + "ActionParametersCacheKeyCustomKeyQueryString", + "ActionParametersCacheKeyCustomKeyQueryStringExclude", + "ActionParametersCacheKeyCustomKeyQueryStringInclude", + "ActionParametersCacheKeyCustomKeyUser", + "ActionParametersCacheReserve", + "ActionParametersEdgeTTL", + "ActionParametersEdgeTTLStatusCodeTTL", + "ActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", + "ActionParametersServeStale", +] + + +class ActionParametersBrowserTTL(BaseModel): + mode: Literal["respect_origin", "bypass_by_default", "override_origin"] + """Determines which browser ttl mode to use.""" + + default: Optional[int] = None + """The TTL (in seconds) if you choose override_origin mode.""" + + +class ActionParametersCacheKeyCustomKeyCookie(BaseModel): + check_presence: Optional[List[str]] = None + """Checks for the presence of these cookie names. + + The presence of these cookies is used in building the cache key. + """ + + include: Optional[List[str]] = None + """Include these cookies' names and their values.""" + + +class ActionParametersCacheKeyCustomKeyHeader(BaseModel): + check_presence: Optional[List[str]] = None + """Checks for the presence of these header names. + + The presence of these headers is used in building the cache key. + """ + + exclude_origin: Optional[bool] = None + """Whether or not to include the origin header. + + A value of true will exclude the origin header in the cache key. + """ + + include: Optional[List[str]] = None + """Include these headers' names and their values.""" + + +class ActionParametersCacheKeyCustomKeyHost(BaseModel): + resolved: Optional[bool] = None + """Use the resolved host in the cache key. + + A value of true will use the resolved host, while a value or false will use the + original host. + """ + + +class ActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): + all: Optional[bool] = None + """Exclude all query string parameters from use in building the cache key.""" + + rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) + """A list of query string parameters NOT used to build the cache key. + + All parameters present in the request but missing in this list will be used to + build the cache key. + """ + + +class ActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): + all: Optional[bool] = None + """Use all query string parameters in the cache key.""" + + rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) + """A list of query string parameters used to build the cache key.""" + + +class ActionParametersCacheKeyCustomKeyQueryString(BaseModel): + exclude: Optional[ActionParametersCacheKeyCustomKeyQueryStringExclude] = None + """ + build the cache key using all query string parameters EXCECPT these excluded + parameters + """ + + include: Optional[ActionParametersCacheKeyCustomKeyQueryStringInclude] = None + """ + build the cache key using a list of query string parameters that ARE in the + request. + """ + + +class ActionParametersCacheKeyCustomKeyUser(BaseModel): + device_type: Optional[bool] = None + """Use the user agent's device type in the cache key.""" + + geo: Optional[bool] = None + """Use the user agents's country in the cache key.""" + + lang: Optional[bool] = None + """Use the user agent's language in the cache key.""" + + +class ActionParametersCacheKeyCustomKey(BaseModel): + cookie: Optional[ActionParametersCacheKeyCustomKeyCookie] = None + """The cookies to include in building the cache key.""" + + header: Optional[ActionParametersCacheKeyCustomKeyHeader] = None + """The header names and values to include in building the cache key.""" + + host: Optional[ActionParametersCacheKeyCustomKeyHost] = None + """Whether to use the original host or the resolved host in the cache key.""" + + query_string: Optional[ActionParametersCacheKeyCustomKeyQueryString] = None + """ + Use the presence or absence of parameters in the query string to build the cache + key. + """ + + user: Optional[ActionParametersCacheKeyCustomKeyUser] = None + """Characteristics of the request user agent used in building the cache key.""" + + +class ActionParametersCacheKey(BaseModel): + cache_by_device_type: Optional[bool] = None + """Separate cached content based on the visitor’s device type""" + + cache_deception_armor: Optional[bool] = None + """ + Protect from web cache deception attacks while allowing static assets to be + cached + """ + + custom_key: Optional[ActionParametersCacheKeyCustomKey] = None + """ + Customize which components of the request are included or excluded from the + cache key. + """ + + ignore_query_strings_order: Optional[bool] = None + """ + Treat requests with the same query parameters the same, regardless of the order + those query parameters are in. A value of true ignores the query strings' order. + """ + + +class ActionParametersCacheReserve(BaseModel): + eligible: bool + """Determines whether cache reserve is enabled. + + If this is true and a request meets eligibility criteria, Cloudflare will write + the resource to cache reserve. + """ + + min_file_size: int + """The minimum file size eligible for store in cache reserve.""" + + +class ActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): + from_: int = FieldInfo(alias="from") + """response status code lower bound""" + + to: int + """response status code upper bound""" + + +class ActionParametersEdgeTTLStatusCodeTTL(BaseModel): + value: int + """Time to cache a response (in seconds). + + A value of 0 is equivalent to setting the Cache-Control header with the value + "no-cache". A value of -1 is equivalent to setting Cache-Control header with the + value of "no-store". + """ + + status_code_range: Optional[ActionParametersEdgeTTLStatusCodeTTLStatusCodeRange] = None + """The range of status codes used to apply the selected mode.""" + + status_code_value: Optional[int] = None + """Set the ttl for responses with this specific status code""" + + +class ActionParametersEdgeTTL(BaseModel): + default: int + """The TTL (in seconds) if you choose override_origin mode.""" + + mode: Literal["respect_origin", "bypass_by_default", "override_origin"] + """edge ttl options""" + + status_code_ttl: List[ActionParametersEdgeTTLStatusCodeTTL] + """List of single status codes, or status code ranges to apply the selected mode""" + + +class ActionParametersServeStale(BaseModel): + disable_stale_while_updating: bool + """Defines whether Cloudflare should serve stale content while updating. + + If true, Cloudflare will not serve stale content while getting the latest + content from the origin. + """ + + +class ActionParameters(BaseModel): + additional_cacheable_ports: Optional[List[int]] = None + """List of additional ports that caching can be enabled on.""" + + browser_ttl: Optional[ActionParametersBrowserTTL] = None + """Specify how long client browsers should cache the response. + + Cloudflare cache purge will not purge content cached on client browsers, so high + browser TTLs may lead to stale content. + """ + + cache: Optional[bool] = None + """Mark whether the request’s response from origin is eligible for caching. + + Caching itself will still depend on the cache-control header and your other + caching configurations. + """ + + cache_key: Optional[ActionParametersCacheKey] = None + """ + Define which components of the request are included or excluded from the cache + key Cloudflare uses to store the response in cache. + """ + + cache_reserve: Optional[ActionParametersCacheReserve] = None + """ + Mark whether the request's response from origin is eligible for Cache Reserve + (requires a Cache Reserve add-on plan). + """ + + edge_ttl: Optional[ActionParametersEdgeTTL] = None + """ + TTL (Time to Live) specifies the maximum time to cache a resource in the + Cloudflare edge network. + """ + + origin_cache_control: Optional[bool] = None + """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" + + origin_error_page_passthru: Optional[bool] = None + """Generate Cloudflare error pages from issues sent from the origin server. + + When on, error pages will trigger for issues from the origin + """ + + read_timeout: Optional[int] = None + """ + Define a timeout value between two successive read operations to your origin + server. Historically, the timeout value between two read options from Cloudflare + to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 + errors because of timeouts from an origin server, try increasing this timeout + value. + """ + + respect_strong_etags: Optional[bool] = None + """ + Specify whether or not Cloudflare should respect strong ETag (entity tag) + headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. + """ + + serve_stale: Optional[ActionParametersServeStale] = None + """ + Define if Cloudflare should serve stale content while getting the latest content + from the origin. If on, Cloudflare will not serve stale content while getting + the latest content from the origin. + """ + + +class SetCacheSettingsRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["set_cache_settings"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/set_cache_settings_rule_param.py b/src/cloudflare/types/rulesets/set_cache_settings_rule_param.py new file mode 100644 index 00000000000..cc507f4b01f --- /dev/null +++ b/src/cloudflare/types/rulesets/set_cache_settings_rule_param.py @@ -0,0 +1,319 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import List, Iterable +from typing_extensions import Literal, Required, TypedDict + +from .logging_param import LoggingParam + +__all__ = [ + "SetCacheSettingsRuleParam", + "ActionParameters", + "ActionParametersBrowserTTL", + "ActionParametersCacheKey", + "ActionParametersCacheKeyCustomKey", + "ActionParametersCacheKeyCustomKeyCookie", + "ActionParametersCacheKeyCustomKeyHeader", + "ActionParametersCacheKeyCustomKeyHost", + "ActionParametersCacheKeyCustomKeyQueryString", + "ActionParametersCacheKeyCustomKeyQueryStringExclude", + "ActionParametersCacheKeyCustomKeyQueryStringInclude", + "ActionParametersCacheKeyCustomKeyUser", + "ActionParametersCacheReserve", + "ActionParametersEdgeTTL", + "ActionParametersEdgeTTLStatusCodeTTL", + "ActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", + "ActionParametersServeStale", +] + + +class ActionParametersBrowserTTL(TypedDict, total=False): + mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] + """Determines which browser ttl mode to use.""" + + default: int + """The TTL (in seconds) if you choose override_origin mode.""" + + +class ActionParametersCacheKeyCustomKeyCookie(TypedDict, total=False): + check_presence: List[str] + """Checks for the presence of these cookie names. + + The presence of these cookies is used in building the cache key. + """ + + include: List[str] + """Include these cookies' names and their values.""" + + +class ActionParametersCacheKeyCustomKeyHeader(TypedDict, total=False): + check_presence: List[str] + """Checks for the presence of these header names. + + The presence of these headers is used in building the cache key. + """ + + exclude_origin: bool + """Whether or not to include the origin header. + + A value of true will exclude the origin header in the cache key. + """ + + include: List[str] + """Include these headers' names and their values.""" + + +class ActionParametersCacheKeyCustomKeyHost(TypedDict, total=False): + resolved: bool + """Use the resolved host in the cache key. + + A value of true will use the resolved host, while a value or false will use the + original host. + """ + + +class ActionParametersCacheKeyCustomKeyQueryStringExclude(TypedDict, total=False): + all: bool + """Exclude all query string parameters from use in building the cache key.""" + + list: List[str] + """A list of query string parameters NOT used to build the cache key. + + All parameters present in the request but missing in this list will be used to + build the cache key. + """ + + +class ActionParametersCacheKeyCustomKeyQueryStringInclude(TypedDict, total=False): + all: bool + """Use all query string parameters in the cache key.""" + + list: List[str] + """A list of query string parameters used to build the cache key.""" + + +class ActionParametersCacheKeyCustomKeyQueryString(TypedDict, total=False): + exclude: ActionParametersCacheKeyCustomKeyQueryStringExclude + """ + build the cache key using all query string parameters EXCECPT these excluded + parameters + """ + + include: ActionParametersCacheKeyCustomKeyQueryStringInclude + """ + build the cache key using a list of query string parameters that ARE in the + request. + """ + + +class ActionParametersCacheKeyCustomKeyUser(TypedDict, total=False): + device_type: bool + """Use the user agent's device type in the cache key.""" + + geo: bool + """Use the user agents's country in the cache key.""" + + lang: bool + """Use the user agent's language in the cache key.""" + + +class ActionParametersCacheKeyCustomKey(TypedDict, total=False): + cookie: ActionParametersCacheKeyCustomKeyCookie + """The cookies to include in building the cache key.""" + + header: ActionParametersCacheKeyCustomKeyHeader + """The header names and values to include in building the cache key.""" + + host: ActionParametersCacheKeyCustomKeyHost + """Whether to use the original host or the resolved host in the cache key.""" + + query_string: ActionParametersCacheKeyCustomKeyQueryString + """ + Use the presence or absence of parameters in the query string to build the cache + key. + """ + + user: ActionParametersCacheKeyCustomKeyUser + """Characteristics of the request user agent used in building the cache key.""" + + +class ActionParametersCacheKey(TypedDict, total=False): + cache_by_device_type: bool + """Separate cached content based on the visitor’s device type""" + + cache_deception_armor: bool + """ + Protect from web cache deception attacks while allowing static assets to be + cached + """ + + custom_key: ActionParametersCacheKeyCustomKey + """ + Customize which components of the request are included or excluded from the + cache key. + """ + + ignore_query_strings_order: bool + """ + Treat requests with the same query parameters the same, regardless of the order + those query parameters are in. A value of true ignores the query strings' order. + """ + + +class ActionParametersCacheReserve(TypedDict, total=False): + eligible: Required[bool] + """Determines whether cache reserve is enabled. + + If this is true and a request meets eligibility criteria, Cloudflare will write + the resource to cache reserve. + """ + + min_file_size: Required[int] + """The minimum file size eligible for store in cache reserve.""" + + +_ActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords = TypedDict( + "_ActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords", + { + "from": int, + }, + total=False, +) + + +class ActionParametersEdgeTTLStatusCodeTTLStatusCodeRange( + _ActionParametersEdgeTTLStatusCodeTTLStatusCodeRangeReservedKeywords, total=False +): + to: Required[int] + """response status code upper bound""" + + +class ActionParametersEdgeTTLStatusCodeTTL(TypedDict, total=False): + value: Required[int] + """Time to cache a response (in seconds). + + A value of 0 is equivalent to setting the Cache-Control header with the value + "no-cache". A value of -1 is equivalent to setting Cache-Control header with the + value of "no-store". + """ + + status_code_range: ActionParametersEdgeTTLStatusCodeTTLStatusCodeRange + """The range of status codes used to apply the selected mode.""" + + status_code_value: int + """Set the ttl for responses with this specific status code""" + + +class ActionParametersEdgeTTL(TypedDict, total=False): + default: Required[int] + """The TTL (in seconds) if you choose override_origin mode.""" + + mode: Required[Literal["respect_origin", "bypass_by_default", "override_origin"]] + """edge ttl options""" + + status_code_ttl: Required[Iterable[ActionParametersEdgeTTLStatusCodeTTL]] + """List of single status codes, or status code ranges to apply the selected mode""" + + +class ActionParametersServeStale(TypedDict, total=False): + disable_stale_while_updating: Required[bool] + """Defines whether Cloudflare should serve stale content while updating. + + If true, Cloudflare will not serve stale content while getting the latest + content from the origin. + """ + + +class ActionParameters(TypedDict, total=False): + additional_cacheable_ports: Iterable[int] + """List of additional ports that caching can be enabled on.""" + + browser_ttl: ActionParametersBrowserTTL + """Specify how long client browsers should cache the response. + + Cloudflare cache purge will not purge content cached on client browsers, so high + browser TTLs may lead to stale content. + """ + + cache: bool + """Mark whether the request’s response from origin is eligible for caching. + + Caching itself will still depend on the cache-control header and your other + caching configurations. + """ + + cache_key: ActionParametersCacheKey + """ + Define which components of the request are included or excluded from the cache + key Cloudflare uses to store the response in cache. + """ + + cache_reserve: ActionParametersCacheReserve + """ + Mark whether the request's response from origin is eligible for Cache Reserve + (requires a Cache Reserve add-on plan). + """ + + edge_ttl: ActionParametersEdgeTTL + """ + TTL (Time to Live) specifies the maximum time to cache a resource in the + Cloudflare edge network. + """ + + origin_cache_control: bool + """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" + + origin_error_page_passthru: bool + """Generate Cloudflare error pages from issues sent from the origin server. + + When on, error pages will trigger for issues from the origin + """ + + read_timeout: int + """ + Define a timeout value between two successive read operations to your origin + server. Historically, the timeout value between two read options from Cloudflare + to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 + errors because of timeouts from an origin server, try increasing this timeout + value. + """ + + respect_strong_etags: bool + """ + Specify whether or not Cloudflare should respect strong ETag (entity tag) + headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. + """ + + serve_stale: ActionParametersServeStale + """ + Define if Cloudflare should serve stale content while getting the latest content + from the origin. If on, Cloudflare will not serve stale content while getting + the latest content from the origin. + """ + + +class SetCacheSettingsRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["set_cache_settings"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/set_config_rule.py b/src/cloudflare/types/rulesets/set_config_rule.py new file mode 100644 index 00000000000..8d135f95608 --- /dev/null +++ b/src/cloudflare/types/rulesets/set_config_rule.py @@ -0,0 +1,103 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List, Optional +from datetime import datetime +from typing_extensions import Literal + +from .logging import Logging +from ..._models import BaseModel + +__all__ = ["SetConfigRule", "ActionParameters", "ActionParametersAutominify"] + + +class ActionParametersAutominify(BaseModel): + css: Optional[bool] = None + """Minify CSS files.""" + + html: Optional[bool] = None + """Minify HTML files.""" + + js: Optional[bool] = None + """Minify JS files.""" + + +class ActionParameters(BaseModel): + automatic_https_rewrites: Optional[bool] = None + """Turn on or off Automatic HTTPS Rewrites.""" + + autominify: Optional[ActionParametersAutominify] = None + """Select which file extensions to minify automatically.""" + + bic: Optional[bool] = None + """Turn on or off Browser Integrity Check.""" + + disable_apps: Optional[bool] = None + """Turn off all active Cloudflare Apps.""" + + disable_zaraz: Optional[bool] = None + """Turn off Zaraz.""" + + email_obfuscation: Optional[bool] = None + """Turn on or off Email Obfuscation.""" + + hotlink_protection: Optional[bool] = None + """Turn on or off the Hotlink Protection.""" + + mirage: Optional[bool] = None + """Turn on or off Mirage.""" + + opportunistic_encryption: Optional[bool] = None + """Turn on or off Opportunistic Encryption.""" + + polish: Optional[Literal["off", "lossless", "lossy"]] = None + """Configure the Polish level.""" + + rocket_loader: Optional[bool] = None + """Turn on or off Rocket Loader""" + + security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None + """Configure the Security Level.""" + + server_side_excludes: Optional[bool] = None + """Turn on or off Server Side Excludes.""" + + ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None + """Configure the SSL level.""" + + sxg: Optional[bool] = None + """Turn on or off Signed Exchanges (SXG).""" + + +class SetConfigRule(BaseModel): + last_updated: datetime + """The timestamp of when the rule was last modified.""" + + version: str + """The version of the rule.""" + + id: Optional[str] = None + """The unique ID of the rule.""" + + action: Optional[Literal["set_config"]] = None + """The action to perform when the rule matches.""" + + action_parameters: Optional[ActionParameters] = None + """The parameters configuring the rule's action.""" + + categories: Optional[List[str]] = None + """The categories of the rule.""" + + description: Optional[str] = None + """An informative description of the rule.""" + + enabled: Optional[bool] = None + """Whether the rule should be executed.""" + + expression: Optional[str] = None + """The expression defining which traffic will match the rule.""" + + logging: Optional[Logging] = None + """An object configuring the rule's logging behavior.""" + + ref: Optional[str] = None + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/set_config_rule_param.py b/src/cloudflare/types/rulesets/set_config_rule_param.py new file mode 100644 index 00000000000..e90a1670126 --- /dev/null +++ b/src/cloudflare/types/rulesets/set_config_rule_param.py @@ -0,0 +1,93 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, TypedDict + +from .logging_param import LoggingParam + +__all__ = ["SetConfigRuleParam", "ActionParameters", "ActionParametersAutominify"] + + +class ActionParametersAutominify(TypedDict, total=False): + css: bool + """Minify CSS files.""" + + html: bool + """Minify HTML files.""" + + js: bool + """Minify JS files.""" + + +class ActionParameters(TypedDict, total=False): + automatic_https_rewrites: bool + """Turn on or off Automatic HTTPS Rewrites.""" + + autominify: ActionParametersAutominify + """Select which file extensions to minify automatically.""" + + bic: bool + """Turn on or off Browser Integrity Check.""" + + disable_apps: bool + """Turn off all active Cloudflare Apps.""" + + disable_zaraz: bool + """Turn off Zaraz.""" + + email_obfuscation: bool + """Turn on or off Email Obfuscation.""" + + hotlink_protection: bool + """Turn on or off the Hotlink Protection.""" + + mirage: bool + """Turn on or off Mirage.""" + + opportunistic_encryption: bool + """Turn on or off Opportunistic Encryption.""" + + polish: Literal["off", "lossless", "lossy"] + """Configure the Polish level.""" + + rocket_loader: bool + """Turn on or off Rocket Loader""" + + security_level: Literal["off", "essentially_off", "low", "medium", "high", "under_attack"] + """Configure the Security Level.""" + + server_side_excludes: bool + """Turn on or off Server Side Excludes.""" + + ssl: Literal["off", "flexible", "full", "strict", "origin_pull"] + """Configure the SSL level.""" + + sxg: bool + """Turn on or off Signed Exchanges (SXG).""" + + +class SetConfigRuleParam(TypedDict, total=False): + id: str + """The unique ID of the rule.""" + + action: Literal["set_config"] + """The action to perform when the rule matches.""" + + action_parameters: ActionParameters + """The parameters configuring the rule's action.""" + + description: str + """An informative description of the rule.""" + + enabled: bool + """Whether the rule should be executed.""" + + expression: str + """The expression defining which traffic will match the rule.""" + + logging: LoggingParam + """An object configuring the rule's logging behavior.""" + + ref: str + """The reference of the rule (the rule ID by default).""" diff --git a/src/cloudflare/types/rulesets/version_get_response.py b/src/cloudflare/types/rulesets/version_get_response.py index 4098d8c4fcf..a3e03c89cb8 100644 --- a/src/cloudflare/types/rulesets/version_get_response.py +++ b/src/cloudflare/types/rulesets/version_get_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from .logging import Logging from .log_rule import LogRule from ..._models import BaseModel from .skip_rule import SkipRule from .block_rule import BlockRule +from .route_rule import RouteRule +from .score_rule import ScoreRule from .execute_rule import ExecuteRule - -__all__ = [ - "VersionGetResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from .rewrite_rule import RewriteRule +from .redirect_rule import RedirectRule +from .challenge_rule import ChallengeRule +from .set_config_rule import SetConfigRule +from .serve_error_rule import ServeErrorRule +from .js_challenge_rule import JsChallengeRule +from .compress_response_rule import CompressResponseRule +from .managed_challenge_rule import ManagedChallengeRule +from .set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["VersionGetResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/rulesets/versions/by_tag_get_response.py b/src/cloudflare/types/rulesets/versions/by_tag_get_response.py index 3b4be3afa64..dcb0495e66e 100644 --- a/src/cloudflare/types/rulesets/versions/by_tag_get_response.py +++ b/src/cloudflare/types/rulesets/versions/by_tag_get_response.py @@ -1,965 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Dict, List, Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal -from pydantic import Field as FieldInfo - -from ..logging import Logging from ..log_rule import LogRule from ...._models import BaseModel from ..skip_rule import SkipRule from ..block_rule import BlockRule +from ..route_rule import RouteRule +from ..score_rule import ScoreRule from ..execute_rule import ExecuteRule - -__all__ = [ - "ByTagGetResponse", - "Rule", - "RuleRulesetsChallengeRule", - "RuleRulesetsCompressResponseRule", - "RuleRulesetsCompressResponseRuleActionParameters", - "RuleRulesetsCompressResponseRuleActionParametersAlgorithm", - "RuleRulesetsJsChallengeRule", - "RuleRulesetsManagedChallengeRule", - "RuleRulesetsRedirectRule", - "RuleRulesetsRedirectRuleActionParameters", - "RuleRulesetsRedirectRuleActionParametersFromList", - "RuleRulesetsRedirectRuleActionParametersFromValue", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURL", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect", - "RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect", - "RuleRulesetsRewriteRule", - "RuleRulesetsRewriteRuleActionParameters", - "RuleRulesetsRewriteRuleActionParametersHeaders", - "RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader", - "RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader", - "RuleRulesetsRewriteRuleActionParametersURI", - "RuleRulesetsRewriteRuleActionParametersURIPath", - "RuleRulesetsRewriteRuleActionParametersURIPathStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue", - "RuleRulesetsRewriteRuleActionParametersURIQuery", - "RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue", - "RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue", - "RuleRulesetsRouteRule", - "RuleRulesetsRouteRuleActionParameters", - "RuleRulesetsRouteRuleActionParametersOrigin", - "RuleRulesetsRouteRuleActionParametersSni", - "RuleRulesetsScoreRule", - "RuleRulesetsScoreRuleActionParameters", - "RuleRulesetsServeErrorRule", - "RuleRulesetsServeErrorRuleActionParameters", - "RuleRulesetsSetConfigRule", - "RuleRulesetsSetConfigRuleActionParameters", - "RuleRulesetsSetConfigRuleActionParametersAutominify", - "RuleRulesetsSetCacheSettingsRule", - "RuleRulesetsSetCacheSettingsRuleActionParameters", - "RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser", - "RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL", - "RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange", - "RuleRulesetsSetCacheSettingsRuleActionParametersServeStale", -] - - -class RuleRulesetsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsCompressResponseRuleActionParametersAlgorithm(BaseModel): - name: Optional[Literal["none", "auto", "default", "gzip", "brotli"]] = None - """Name of compression algorithm to enable.""" - - -class RuleRulesetsCompressResponseRuleActionParameters(BaseModel): - algorithms: Optional[List[RuleRulesetsCompressResponseRuleActionParametersAlgorithm]] = None - """Custom order for compression algorithms.""" - - -class RuleRulesetsCompressResponseRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["compress_response"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsCompressResponseRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsJsChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["js_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsManagedChallengeRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["managed_challenge"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[object] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRedirectRuleActionParametersFromList(BaseModel): - key: Optional[str] = None - """Expression that evaluates to the list lookup key.""" - - name: Optional[str] = None - """The name of the list to match against.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect(BaseModel): - value: Optional[str] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect(BaseModel): - expression: Optional[str] = None - """An expression to evaluate to get the URL to redirect the request to.""" - - -RuleRulesetsRedirectRuleActionParametersFromValueTargetURL = Union[ - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLStaticURLRedirect, - RuleRulesetsRedirectRuleActionParametersFromValueTargetURLDynamicURLRedirect, -] - - -class RuleRulesetsRedirectRuleActionParametersFromValue(BaseModel): - preserve_query_string: Optional[bool] = None - """Keep the query string of the original request.""" - - status_code: Optional[Literal[301, 302, 303, 307, 308]] = None - """The status code to be used for the redirect.""" - - target_url: Optional[RuleRulesetsRedirectRuleActionParametersFromValueTargetURL] = None - """The URL to redirect the request to.""" - - -class RuleRulesetsRedirectRuleActionParameters(BaseModel): - from_list: Optional[RuleRulesetsRedirectRuleActionParametersFromList] = None - """Serve a redirect based on a bulk list lookup.""" - - from_value: Optional[RuleRulesetsRedirectRuleActionParametersFromValue] = None - """Serve a redirect based on the request properties.""" - - -class RuleRulesetsRedirectRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["redirect"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRedirectRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader(BaseModel): - operation: Literal["remove"] - - -class RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader(BaseModel): - operation: Literal["set"] - - value: str - """Static value for the header.""" - - -class RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader(BaseModel): - expression: str - """Expression for the header value.""" - - operation: Literal["set"] - - -RuleRulesetsRewriteRuleActionParametersHeaders = Union[ - RuleRulesetsRewriteRuleActionParametersHeadersRemoveHeader, - RuleRulesetsRewriteRuleActionParametersHeadersStaticHeader, - RuleRulesetsRewriteRuleActionParametersHeadersDynamicHeader, -] - - -class RuleRulesetsRewriteRuleActionParametersURIPathStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIPath = Union[ - RuleRulesetsRewriteRuleActionParametersURIPathStaticValue, - RuleRulesetsRewriteRuleActionParametersURIPathDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue(BaseModel): - value: str - """Predefined replacement value.""" - - -class RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue(BaseModel): - expression: str - """Expression to evaluate for the replacement value.""" - - -RuleRulesetsRewriteRuleActionParametersURIQuery = Union[ - RuleRulesetsRewriteRuleActionParametersURIQueryStaticValue, - RuleRulesetsRewriteRuleActionParametersURIQueryDynamicValue, -] - - -class RuleRulesetsRewriteRuleActionParametersURI(BaseModel): - path: Optional[RuleRulesetsRewriteRuleActionParametersURIPath] = None - """Path portion rewrite.""" - - query: Optional[RuleRulesetsRewriteRuleActionParametersURIQuery] = None - """Query portion rewrite.""" - - -class RuleRulesetsRewriteRuleActionParameters(BaseModel): - headers: Optional[Dict[str, RuleRulesetsRewriteRuleActionParametersHeaders]] = None - """Map of request headers to modify.""" - - uri: Optional[RuleRulesetsRewriteRuleActionParametersURI] = None - """URI to rewrite the request to.""" - - -class RuleRulesetsRewriteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["rewrite"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRewriteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsRouteRuleActionParametersOrigin(BaseModel): - host: Optional[str] = None - """Override the resolved hostname.""" - - port: Optional[float] = None - """Override the destination port.""" - - -class RuleRulesetsRouteRuleActionParametersSni(BaseModel): - value: str - """The SNI override.""" - - -class RuleRulesetsRouteRuleActionParameters(BaseModel): - host_header: Optional[str] = None - """Rewrite the HTTP Host header.""" - - origin: Optional[RuleRulesetsRouteRuleActionParametersOrigin] = None - """Override the IP/TCP destination.""" - - sni: Optional[RuleRulesetsRouteRuleActionParametersSni] = None - """Override the Server Name Indication (SNI).""" - - -class RuleRulesetsRouteRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["route"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsRouteRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsScoreRuleActionParameters(BaseModel): - increment: Optional[int] = None - """ - Increment contains the delta to change the score and can be either positive or - negative. - """ - - -class RuleRulesetsScoreRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["score"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsScoreRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsServeErrorRuleActionParameters(BaseModel): - content: Optional[str] = None - """Error response content.""" - - content_type: Optional[Literal["application/json", "text/xml", "text/plain", "text/html"]] = None - """Content-type header to set with the response.""" - - status_code: Optional[float] = None - """The status code to use for the error.""" - - -class RuleRulesetsServeErrorRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["serve_error"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsServeErrorRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetConfigRuleActionParametersAutominify(BaseModel): - css: Optional[bool] = None - """Minify CSS files.""" - - html: Optional[bool] = None - """Minify HTML files.""" - - js: Optional[bool] = None - """Minify JS files.""" - - -class RuleRulesetsSetConfigRuleActionParameters(BaseModel): - automatic_https_rewrites: Optional[bool] = None - """Turn on or off Automatic HTTPS Rewrites.""" - - autominify: Optional[RuleRulesetsSetConfigRuleActionParametersAutominify] = None - """Select which file extensions to minify automatically.""" - - bic: Optional[bool] = None - """Turn on or off Browser Integrity Check.""" - - disable_apps: Optional[bool] = None - """Turn off all active Cloudflare Apps.""" - - disable_zaraz: Optional[bool] = None - """Turn off Zaraz.""" - - email_obfuscation: Optional[bool] = None - """Turn on or off Email Obfuscation.""" - - hotlink_protection: Optional[bool] = None - """Turn on or off the Hotlink Protection.""" - - mirage: Optional[bool] = None - """Turn on or off Mirage.""" - - opportunistic_encryption: Optional[bool] = None - """Turn on or off Opportunistic Encryption.""" - - polish: Optional[Literal["off", "lossless", "lossy"]] = None - """Configure the Polish level.""" - - rocket_loader: Optional[bool] = None - """Turn on or off Rocket Loader""" - - security_level: Optional[Literal["off", "essentially_off", "low", "medium", "high", "under_attack"]] = None - """Configure the Security Level.""" - - server_side_excludes: Optional[bool] = None - """Turn on or off Server Side Excludes.""" - - ssl: Optional[Literal["off", "flexible", "full", "strict", "origin_pull"]] = None - """Configure the SSL level.""" - - sxg: Optional[bool] = None - """Turn on or off Signed Exchanges (SXG).""" - - -class RuleRulesetsSetConfigRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_config"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetConfigRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL(BaseModel): - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """Determines which browser ttl mode to use.""" - - default: Optional[int] = None - """The TTL (in seconds) if you choose override_origin mode.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these cookie names. - - The presence of these cookies is used in building the cache key. - """ - - include: Optional[List[str]] = None - """Include these cookies' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader(BaseModel): - check_presence: Optional[List[str]] = None - """Checks for the presence of these header names. - - The presence of these headers is used in building the cache key. - """ - - exclude_origin: Optional[bool] = None - """Whether or not to include the origin header. - - A value of true will exclude the origin header in the cache key. - """ - - include: Optional[List[str]] = None - """Include these headers' names and their values.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost(BaseModel): - resolved: Optional[bool] = None - """Use the resolved host in the cache key. - - A value of true will use the resolved host, while a value or false will use the - original host. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude(BaseModel): - all: Optional[bool] = None - """Exclude all query string parameters from use in building the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters NOT used to build the cache key. - - All parameters present in the request but missing in this list will be used to - build the cache key. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude(BaseModel): - all: Optional[bool] = None - """Use all query string parameters in the cache key.""" - - rule_list: Optional[List[str]] = FieldInfo(alias="list", default=None) - """A list of query string parameters used to build the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString(BaseModel): - exclude: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringExclude] = None - """ - build the cache key using all query string parameters EXCECPT these excluded - parameters - """ - - include: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryStringInclude] = None - """ - build the cache key using a list of query string parameters that ARE in the - request. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser(BaseModel): - device_type: Optional[bool] = None - """Use the user agent's device type in the cache key.""" - - geo: Optional[bool] = None - """Use the user agents's country in the cache key.""" - - lang: Optional[bool] = None - """Use the user agent's language in the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey(BaseModel): - cookie: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyCookie] = None - """The cookies to include in building the cache key.""" - - header: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHeader] = None - """The header names and values to include in building the cache key.""" - - host: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyHost] = None - """Whether to use the original host or the resolved host in the cache key.""" - - query_string: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyQueryString] = None - """ - Use the presence or absence of parameters in the query string to build the cache - key. - """ - - user: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKeyUser] = None - """Characteristics of the request user agent used in building the cache key.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey(BaseModel): - cache_by_device_type: Optional[bool] = None - """Separate cached content based on the visitor’s device type""" - - cache_deception_armor: Optional[bool] = None - """ - Protect from web cache deception attacks while allowing static assets to be - cached - """ - - custom_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKeyCustomKey] = None - """ - Customize which components of the request are included or excluded from the - cache key. - """ - - ignore_query_strings_order: Optional[bool] = None - """ - Treat requests with the same query parameters the same, regardless of the order - those query parameters are in. A value of true ignores the query strings' order. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve(BaseModel): - eligible: bool - """Determines whether cache reserve is enabled. - - If this is true and a request meets eligibility criteria, Cloudflare will write - the resource to cache reserve. - """ - - min_file_size: int - """The minimum file size eligible for store in cache reserve.""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange(BaseModel): - from_: int = FieldInfo(alias="from") - """response status code lower bound""" - - to: int - """response status code upper bound""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL(BaseModel): - value: int - """Time to cache a response (in seconds). - - A value of 0 is equivalent to setting the Cache-Control header with the value - "no-cache". A value of -1 is equivalent to setting Cache-Control header with the - value of "no-store". - """ - - status_code_range: Optional[ - RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTLStatusCodeRange - ] = None - """The range of status codes used to apply the selected mode.""" - - status_code_value: Optional[int] = None - """Set the ttl for responses with this specific status code""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL(BaseModel): - default: int - """The TTL (in seconds) if you choose override_origin mode.""" - - mode: Literal["respect_origin", "bypass_by_default", "override_origin"] - """edge ttl options""" - - status_code_ttl: List[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTLStatusCodeTTL] - """List of single status codes, or status code ranges to apply the selected mode""" - - -class RuleRulesetsSetCacheSettingsRuleActionParametersServeStale(BaseModel): - disable_stale_while_updating: bool - """Defines whether Cloudflare should serve stale content while updating. - - If true, Cloudflare will not serve stale content while getting the latest - content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRuleActionParameters(BaseModel): - additional_cacheable_ports: Optional[List[int]] = None - """List of additional ports that caching can be enabled on.""" - - browser_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersBrowserTTL] = None - """Specify how long client browsers should cache the response. - - Cloudflare cache purge will not purge content cached on client browsers, so high - browser TTLs may lead to stale content. - """ - - cache: Optional[bool] = None - """Mark whether the request’s response from origin is eligible for caching. - - Caching itself will still depend on the cache-control header and your other - caching configurations. - """ - - cache_key: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheKey] = None - """ - Define which components of the request are included or excluded from the cache - key Cloudflare uses to store the response in cache. - """ - - cache_reserve: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersCacheReserve] = None - """ - Mark whether the request's response from origin is eligible for Cache Reserve - (requires a Cache Reserve add-on plan). - """ - - edge_ttl: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersEdgeTTL] = None - """ - TTL (Time to Live) specifies the maximum time to cache a resource in the - Cloudflare edge network. - """ - - origin_cache_control: Optional[bool] = None - """When enabled, Cloudflare will aim to strictly adhere to RFC 7234.""" - - origin_error_page_passthru: Optional[bool] = None - """Generate Cloudflare error pages from issues sent from the origin server. - - When on, error pages will trigger for issues from the origin - """ - - read_timeout: Optional[int] = None - """ - Define a timeout value between two successive read operations to your origin - server. Historically, the timeout value between two read options from Cloudflare - to an origin server is 100 seconds. If you are attempting to reduce HTTP 524 - errors because of timeouts from an origin server, try increasing this timeout - value. - """ - - respect_strong_etags: Optional[bool] = None - """ - Specify whether or not Cloudflare should respect strong ETag (entity tag) - headers. When off, Cloudflare converts strong ETag headers to weak ETag headers. - """ - - serve_stale: Optional[RuleRulesetsSetCacheSettingsRuleActionParametersServeStale] = None - """ - Define if Cloudflare should serve stale content while getting the latest content - from the origin. If on, Cloudflare will not serve stale content while getting - the latest content from the origin. - """ - - -class RuleRulesetsSetCacheSettingsRule(BaseModel): - last_updated: datetime - """The timestamp of when the rule was last modified.""" - - version: str - """The version of the rule.""" - - id: Optional[str] = None - """The unique ID of the rule.""" - - action: Optional[Literal["set_cache_settings"]] = None - """The action to perform when the rule matches.""" - - action_parameters: Optional[RuleRulesetsSetCacheSettingsRuleActionParameters] = None - """The parameters configuring the rule's action.""" - - categories: Optional[List[str]] = None - """The categories of the rule.""" - - description: Optional[str] = None - """An informative description of the rule.""" - - enabled: Optional[bool] = None - """Whether the rule should be executed.""" - - expression: Optional[str] = None - """The expression defining which traffic will match the rule.""" - - logging: Optional[Logging] = None - """An object configuring the rule's logging behavior.""" - - ref: Optional[str] = None - """The reference of the rule (the rule ID by default).""" - +from ..rewrite_rule import RewriteRule +from ..redirect_rule import RedirectRule +from ..challenge_rule import ChallengeRule +from ..set_config_rule import SetConfigRule +from ..serve_error_rule import ServeErrorRule +from ..js_challenge_rule import JsChallengeRule +from ..compress_response_rule import CompressResponseRule +from ..managed_challenge_rule import ManagedChallengeRule +from ..set_cache_settings_rule import SetCacheSettingsRule + +__all__ = ["ByTagGetResponse", "Rule"] Rule = Union[ BlockRule, - RuleRulesetsChallengeRule, - RuleRulesetsCompressResponseRule, + ChallengeRule, + CompressResponseRule, ExecuteRule, - RuleRulesetsJsChallengeRule, + JsChallengeRule, LogRule, - RuleRulesetsManagedChallengeRule, - RuleRulesetsRedirectRule, - RuleRulesetsRewriteRule, - RuleRulesetsRouteRule, - RuleRulesetsScoreRule, - RuleRulesetsServeErrorRule, - RuleRulesetsSetConfigRule, + ManagedChallengeRule, + RedirectRule, + RewriteRule, + RouteRule, + ScoreRule, + ServeErrorRule, + SetConfigRule, SkipRule, - RuleRulesetsSetCacheSettingsRule, + SetCacheSettingsRule, ] diff --git a/src/cloudflare/types/warp_connector_create_response.py b/src/cloudflare/types/warp_connector_create_response.py index 6af0fd7e768..dd87278a2aa 100644 --- a/src/cloudflare/types/warp_connector_create_response.py +++ b/src/cloudflare/types/warp_connector_create_response.py @@ -1,13 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal from .._models import BaseModel -from .zero_trust import Tunnel, Connection +from .zero_trust import Tunnel -__all__ = ["WARPConnectorCreateResponse", "TunnelWARPConnectorTunnel"] +__all__ = ["WARPConnectorCreateResponse", "TunnelWARPConnectorTunnel", "TunnelWARPConnectorTunnelConnection"] + + +class TunnelWARPConnectorTunnelConnection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class TunnelWARPConnectorTunnel(BaseModel): @@ -17,7 +48,7 @@ class TunnelWARPConnectorTunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[TunnelWARPConnectorTunnelConnection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/warp_connector_delete_response.py b/src/cloudflare/types/warp_connector_delete_response.py index fa3ab386da8..e9343999295 100644 --- a/src/cloudflare/types/warp_connector_delete_response.py +++ b/src/cloudflare/types/warp_connector_delete_response.py @@ -1,13 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal from .._models import BaseModel -from .zero_trust import Tunnel, Connection +from .zero_trust import Tunnel -__all__ = ["WARPConnectorDeleteResponse", "TunnelWARPConnectorTunnel"] +__all__ = ["WARPConnectorDeleteResponse", "TunnelWARPConnectorTunnel", "TunnelWARPConnectorTunnelConnection"] + + +class TunnelWARPConnectorTunnelConnection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class TunnelWARPConnectorTunnel(BaseModel): @@ -17,7 +48,7 @@ class TunnelWARPConnectorTunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[TunnelWARPConnectorTunnelConnection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/warp_connector_edit_response.py b/src/cloudflare/types/warp_connector_edit_response.py index cd29bec5094..69103522d3b 100644 --- a/src/cloudflare/types/warp_connector_edit_response.py +++ b/src/cloudflare/types/warp_connector_edit_response.py @@ -1,13 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal from .._models import BaseModel -from .zero_trust import Tunnel, Connection +from .zero_trust import Tunnel -__all__ = ["WARPConnectorEditResponse", "TunnelWARPConnectorTunnel"] +__all__ = ["WARPConnectorEditResponse", "TunnelWARPConnectorTunnel", "TunnelWARPConnectorTunnelConnection"] + + +class TunnelWARPConnectorTunnelConnection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class TunnelWARPConnectorTunnel(BaseModel): @@ -17,7 +48,7 @@ class TunnelWARPConnectorTunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[TunnelWARPConnectorTunnelConnection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/warp_connector_get_response.py b/src/cloudflare/types/warp_connector_get_response.py index a8da274c312..4b211bb43e5 100644 --- a/src/cloudflare/types/warp_connector_get_response.py +++ b/src/cloudflare/types/warp_connector_get_response.py @@ -1,13 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal from .._models import BaseModel -from .zero_trust import Tunnel, Connection +from .zero_trust import Tunnel -__all__ = ["WARPConnectorGetResponse", "TunnelWARPConnectorTunnel"] +__all__ = ["WARPConnectorGetResponse", "TunnelWARPConnectorTunnel", "TunnelWARPConnectorTunnelConnection"] + + +class TunnelWARPConnectorTunnelConnection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class TunnelWARPConnectorTunnel(BaseModel): @@ -17,7 +48,7 @@ class TunnelWARPConnectorTunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[TunnelWARPConnectorTunnelConnection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/warp_connector_list_response.py b/src/cloudflare/types/warp_connector_list_response.py index 54cd870205e..2c5e33542ca 100644 --- a/src/cloudflare/types/warp_connector_list_response.py +++ b/src/cloudflare/types/warp_connector_list_response.py @@ -1,13 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal from .._models import BaseModel -from .zero_trust import Tunnel, Connection +from .zero_trust import Tunnel -__all__ = ["WARPConnectorListResponse", "TunnelWARPConnectorTunnel"] +__all__ = ["WARPConnectorListResponse", "TunnelWARPConnectorTunnel", "TunnelWARPConnectorTunnelConnection"] + + +class TunnelWARPConnectorTunnelConnection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class TunnelWARPConnectorTunnel(BaseModel): @@ -17,7 +48,7 @@ class TunnelWARPConnectorTunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[TunnelWARPConnectorTunnelConnection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/__init__.py b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/__init__.py index f02cfa2e631..0aa7d524060 100644 --- a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/__init__.py +++ b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/__init__.py @@ -2,8 +2,14 @@ from __future__ import annotations +from .tag_list_response import TagListResponse as TagListResponse +from .tag_update_params import TagUpdateParams as TagUpdateParams from .setting_edit_params import SettingEditParams as SettingEditParams +from .tag_update_response import TagUpdateResponse as TagUpdateResponse from .binding_get_response import BindingGetResponse as BindingGetResponse +from .secret_list_response import SecretListResponse as SecretListResponse +from .secret_update_params import SecretUpdateParams as SecretUpdateParams from .setting_get_response import SettingGetResponse as SettingGetResponse from .content_update_params import ContentUpdateParams as ContentUpdateParams from .setting_edit_response import SettingEditResponse as SettingEditResponse +from .secret_update_response import SecretUpdateResponse as SecretUpdateResponse diff --git a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_list_response.py b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_list_response.py new file mode 100644 index 00000000000..86ea1859cb1 --- /dev/null +++ b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_list_response.py @@ -0,0 +1,16 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Optional +from typing_extensions import Literal + +from ......_models import BaseModel + +__all__ = ["SecretListResponse"] + + +class SecretListResponse(BaseModel): + name: Optional[str] = None + """The name of this secret, this is what will be to access it inside the Worker.""" + + type: Optional[Literal["secret_text"]] = None + """The type of secret to put.""" diff --git a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_params.py b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_params.py new file mode 100644 index 00000000000..572b6f5e008 --- /dev/null +++ b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_params.py @@ -0,0 +1,24 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing_extensions import Literal, Required, TypedDict + +__all__ = ["SecretUpdateParams"] + + +class SecretUpdateParams(TypedDict, total=False): + account_id: Required[str] + """Identifier""" + + dispatch_namespace: Required[str] + """Name of the Workers for Platforms dispatch namespace.""" + + name: str + """The name of this secret, this is what will be to access it inside the Worker.""" + + text: str + """The value of the secret.""" + + type: Literal["secret_text"] + """The type of secret to put.""" diff --git a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_response.py b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_response.py new file mode 100644 index 00000000000..df496e500d8 --- /dev/null +++ b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/secret_update_response.py @@ -0,0 +1,16 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import Optional +from typing_extensions import Literal + +from ......_models import BaseModel + +__all__ = ["SecretUpdateResponse"] + + +class SecretUpdateResponse(BaseModel): + name: Optional[str] = None + """The name of this secret, this is what will be to access it inside the Worker.""" + + type: Optional[Literal["secret_text"]] = None + """The type of secret to put.""" diff --git a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_list_response.py b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_list_response.py new file mode 100644 index 00000000000..f26fb51fb7e --- /dev/null +++ b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_list_response.py @@ -0,0 +1,6 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + + +__all__ = ["TagListResponse"] + +TagListResponse = str diff --git a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_params.py b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_params.py new file mode 100644 index 00000000000..e423cd8440d --- /dev/null +++ b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_params.py @@ -0,0 +1,19 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +from typing import List +from typing_extensions import Required, TypedDict + +__all__ = ["TagUpdateParams"] + + +class TagUpdateParams(TypedDict, total=False): + account_id: Required[str] + """Identifier""" + + dispatch_namespace: Required[str] + """Name of the Workers for Platforms dispatch namespace.""" + + body: Required[List[str]] + """Tags to help you manage your Workers""" diff --git a/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_response.py b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_response.py new file mode 100644 index 00000000000..52678a8e0b8 --- /dev/null +++ b/src/cloudflare/types/workers_for_platforms/dispatch/namespaces/scripts/tag_update_response.py @@ -0,0 +1,7 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from typing import List + +__all__ = ["TagUpdateResponse"] + +TagUpdateResponse = List[str] diff --git a/src/cloudflare/types/zero_trust/connection.py b/src/cloudflare/types/zero_trust/connection.py index 6be1acae57e..9d1f58e7fe1 100644 --- a/src/cloudflare/types/zero_trust/connection.py +++ b/src/cloudflare/types/zero_trust/connection.py @@ -1,23 +1,13 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import List, Optional -from datetime import datetime +from typing import Optional from ..._models import BaseModel -__all__ = ["Connection", "ConnectionItem"] +__all__ = ["Connection"] -class ConnectionItem(BaseModel): - id: Optional[str] = None - """UUID of the Cloudflare Tunnel connection.""" - - client_id: Optional[object] = None - """UUID of the cloudflared instance.""" - - client_version: Optional[str] = None - """The cloudflared version used to establish this connection.""" - +class Connection(BaseModel): colo_name: Optional[str] = None """The Cloudflare data center used for this connection.""" @@ -29,14 +19,5 @@ class ConnectionItem(BaseModel): tracked. If `false`, the connection is actively serving traffic. """ - opened_at: Optional[datetime] = None - """Timestamp of when the connection was established.""" - - origin_ip: Optional[str] = None - """The public IP address of the host running cloudflared.""" - uuid: Optional[str] = None """UUID of the Cloudflare Tunnel connection.""" - - -Connection = List[ConnectionItem] diff --git a/src/cloudflare/types/zero_trust/tunnel.py b/src/cloudflare/types/zero_trust/tunnel.py index 349d5e1d3c6..a7c3ca49648 100644 --- a/src/cloudflare/types/zero_trust/tunnel.py +++ b/src/cloudflare/types/zero_trust/tunnel.py @@ -1,13 +1,43 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Optional +from typing import List, Optional from datetime import datetime from typing_extensions import Literal from ..._models import BaseModel -from .connection import Connection -__all__ = ["Tunnel"] +__all__ = ["Tunnel", "Connection"] + + +class Connection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class Tunnel(BaseModel): @@ -17,7 +47,7 @@ class Tunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[Connection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/zero_trust/tunnel_create_response.py b/src/cloudflare/types/zero_trust/tunnel_create_response.py index c3534bf5635..73f35896d9f 100644 --- a/src/cloudflare/types/zero_trust/tunnel_create_response.py +++ b/src/cloudflare/types/zero_trust/tunnel_create_response.py @@ -4,24 +4,9 @@ from datetime import datetime from ..._models import BaseModel +from .connection import Connection -__all__ = ["TunnelCreateResponse", "Connection"] - - -class Connection(BaseModel): - colo_name: Optional[str] = None - """The Cloudflare data center used for this connection.""" - - is_pending_reconnect: Optional[bool] = None - """ - Cloudflare continues to track connections for several minutes after they - disconnect. This is an optimization to improve latency and reliability of - reconnecting. If `true`, the connection has disconnected but is still being - tracked. If `false`, the connection is actively serving traffic. - """ - - uuid: Optional[str] = None - """UUID of the Cloudflare Tunnel connection.""" +__all__ = ["TunnelCreateResponse"] class TunnelCreateResponse(BaseModel): diff --git a/src/cloudflare/types/zero_trust/tunnel_delete_response.py b/src/cloudflare/types/zero_trust/tunnel_delete_response.py index cb4d1611d6e..0a3106becf0 100644 --- a/src/cloudflare/types/zero_trust/tunnel_delete_response.py +++ b/src/cloudflare/types/zero_trust/tunnel_delete_response.py @@ -4,24 +4,9 @@ from datetime import datetime from ..._models import BaseModel +from .connection import Connection -__all__ = ["TunnelDeleteResponse", "Connection"] - - -class Connection(BaseModel): - colo_name: Optional[str] = None - """The Cloudflare data center used for this connection.""" - - is_pending_reconnect: Optional[bool] = None - """ - Cloudflare continues to track connections for several minutes after they - disconnect. This is an optimization to improve latency and reliability of - reconnecting. If `true`, the connection has disconnected but is still being - tracked. If `false`, the connection is actively serving traffic. - """ - - uuid: Optional[str] = None - """UUID of the Cloudflare Tunnel connection.""" +__all__ = ["TunnelDeleteResponse"] class TunnelDeleteResponse(BaseModel): diff --git a/src/cloudflare/types/zero_trust/tunnel_edit_response.py b/src/cloudflare/types/zero_trust/tunnel_edit_response.py index 4caa7a0e6cf..5e1b6878971 100644 --- a/src/cloudflare/types/zero_trust/tunnel_edit_response.py +++ b/src/cloudflare/types/zero_trust/tunnel_edit_response.py @@ -1,14 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal from .tunnel import Tunnel from ..._models import BaseModel -from .connection import Connection -__all__ = ["TunnelEditResponse", "TunnelWARPConnectorTunnel"] +__all__ = ["TunnelEditResponse", "TunnelWARPConnectorTunnel", "TunnelWARPConnectorTunnelConnection"] + + +class TunnelWARPConnectorTunnelConnection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class TunnelWARPConnectorTunnel(BaseModel): @@ -18,7 +48,7 @@ class TunnelWARPConnectorTunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[TunnelWARPConnectorTunnelConnection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/zero_trust/tunnel_get_response.py b/src/cloudflare/types/zero_trust/tunnel_get_response.py index f7abe1db802..8803a86547c 100644 --- a/src/cloudflare/types/zero_trust/tunnel_get_response.py +++ b/src/cloudflare/types/zero_trust/tunnel_get_response.py @@ -4,24 +4,9 @@ from datetime import datetime from ..._models import BaseModel +from .connection import Connection -__all__ = ["TunnelGetResponse", "Connection"] - - -class Connection(BaseModel): - colo_name: Optional[str] = None - """The Cloudflare data center used for this connection.""" - - is_pending_reconnect: Optional[bool] = None - """ - Cloudflare continues to track connections for several minutes after they - disconnect. This is an optimization to improve latency and reliability of - reconnecting. If `true`, the connection has disconnected but is still being - tracked. If `false`, the connection is actively serving traffic. - """ - - uuid: Optional[str] = None - """UUID of the Cloudflare Tunnel connection.""" +__all__ = ["TunnelGetResponse"] class TunnelGetResponse(BaseModel): diff --git a/src/cloudflare/types/zero_trust/tunnel_list_response.py b/src/cloudflare/types/zero_trust/tunnel_list_response.py index d1bc02ff669..97a4689566f 100644 --- a/src/cloudflare/types/zero_trust/tunnel_list_response.py +++ b/src/cloudflare/types/zero_trust/tunnel_list_response.py @@ -1,14 +1,44 @@ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. -from typing import Union, Optional +from typing import List, Union, Optional from datetime import datetime from typing_extensions import Literal from .tunnel import Tunnel from ..._models import BaseModel -from .connection import Connection -__all__ = ["TunnelListResponse", "TunnelWARPConnectorTunnel"] +__all__ = ["TunnelListResponse", "TunnelWARPConnectorTunnel", "TunnelWARPConnectorTunnelConnection"] + + +class TunnelWARPConnectorTunnelConnection(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class TunnelWARPConnectorTunnel(BaseModel): @@ -18,7 +48,7 @@ class TunnelWARPConnectorTunnel(BaseModel): account_tag: Optional[str] = None """Cloudflare account ID""" - connections: Optional[Connection] = None + connections: Optional[List[TunnelWARPConnectorTunnelConnection]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Optional[datetime] = None diff --git a/src/cloudflare/types/zero_trust/tunnel_param.py b/src/cloudflare/types/zero_trust/tunnel_param.py index 6af384596d6..fe4c9a77071 100644 --- a/src/cloudflare/types/zero_trust/tunnel_param.py +++ b/src/cloudflare/types/zero_trust/tunnel_param.py @@ -2,21 +2,45 @@ from __future__ import annotations -from typing import Union +from typing import Union, Iterable from datetime import datetime from typing_extensions import Literal, Annotated, TypedDict from ..._utils import PropertyInfo -from .connection import Connection -__all__ = ["TunnelParam"] +__all__ = ["TunnelParam", "Connection"] + + +class Connection(TypedDict, total=False): + client_id: object + """UUID of the cloudflared instance.""" + + client_version: str + """The cloudflared version used to establish this connection.""" + + colo_name: str + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: bool + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Annotated[Union[str, datetime], PropertyInfo(format="iso8601")] + """Timestamp of when the connection was established.""" + + origin_ip: str + """The public IP address of the host running cloudflared.""" class TunnelParam(TypedDict, total=False): account_tag: str """Cloudflare account ID""" - connections: Connection + connections: Iterable[Connection] """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" conns_active_at: Annotated[Union[str, datetime, None], PropertyInfo(format="iso8601")] diff --git a/src/cloudflare/types/zero_trust/tunnels/client.py b/src/cloudflare/types/zero_trust/tunnels/client.py index fce0f7da0a0..1c18c5ff6f2 100644 --- a/src/cloudflare/types/zero_trust/tunnels/client.py +++ b/src/cloudflare/types/zero_trust/tunnels/client.py @@ -4,9 +4,39 @@ from datetime import datetime from ...._models import BaseModel -from ..connection import Connection -__all__ = ["Client"] +__all__ = ["Client", "Conn"] + + +class Conn(BaseModel): + id: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" + + client_id: Optional[object] = None + """UUID of the cloudflared instance.""" + + client_version: Optional[str] = None + """The cloudflared version used to establish this connection.""" + + colo_name: Optional[str] = None + """The Cloudflare data center used for this connection.""" + + is_pending_reconnect: Optional[bool] = None + """ + Cloudflare continues to track connections for several minutes after they + disconnect. This is an optimization to improve latency and reliability of + reconnecting. If `true`, the connection has disconnected but is still being + tracked. If `false`, the connection is actively serving traffic. + """ + + opened_at: Optional[datetime] = None + """Timestamp of when the connection was established.""" + + origin_ip: Optional[str] = None + """The public IP address of the host running cloudflared.""" + + uuid: Optional[str] = None + """UUID of the Cloudflare Tunnel connection.""" class Client(BaseModel): @@ -22,7 +52,7 @@ class Client(BaseModel): Used internally to sync cloudflared with the Zero Trust dashboard. """ - conns: Optional[Connection] = None + conns: Optional[List[Conn]] = None """The Cloudflare Tunnel connections between your origin and Cloudflare's edge.""" features: Optional[List[str]] = None diff --git a/tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_secrets.py b/tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_secrets.py new file mode 100644 index 00000000000..77350d5c905 --- /dev/null +++ b/tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_secrets.py @@ -0,0 +1,310 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +import os +from typing import Any, cast + +import pytest + +from cloudflare import Cloudflare, AsyncCloudflare +from tests.utils import assert_matches_type +from cloudflare.pagination import SyncSinglePage, AsyncSinglePage +from cloudflare.types.workers_for_platforms.dispatch.namespaces.scripts import ( + SecretListResponse, + SecretUpdateResponse, +) + +base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010") + + +class TestSecrets: + parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"]) + + @pytest.mark.skip() + @parametrize + def test_method_update(self, client: Cloudflare) -> None: + secret = client.workers_for_platforms.dispatch.namespaces.scripts.secrets.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_method_update_with_all_params(self, client: Cloudflare) -> None: + secret = client.workers_for_platforms.dispatch.namespaces.scripts.secrets.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + name="MY_SECRET", + text="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9", + type="secret_text", + ) + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_raw_response_update(self, client: Cloudflare) -> None: + response = client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + secret = response.parse() + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_streaming_response_update(self, client: Cloudflare) -> None: + with client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_streaming_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + secret = response.parse() + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + def test_path_params_update(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + @pytest.mark.skip() + @parametrize + def test_method_list(self, client: Cloudflare) -> None: + secret = client.workers_for_platforms.dispatch.namespaces.scripts.secrets.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + assert_matches_type(SyncSinglePage[SecretListResponse], secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_raw_response_list(self, client: Cloudflare) -> None: + response = client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + secret = response.parse() + assert_matches_type(SyncSinglePage[SecretListResponse], secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_streaming_response_list(self, client: Cloudflare) -> None: + with client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_streaming_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + secret = response.parse() + assert_matches_type(SyncSinglePage[SecretListResponse], secret, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + def test_path_params_list(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + +class TestAsyncSecrets: + parametrize = pytest.mark.parametrize("async_client", [False, True], indirect=True, ids=["loose", "strict"]) + + @pytest.mark.skip() + @parametrize + async def test_method_update(self, async_client: AsyncCloudflare) -> None: + secret = await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_method_update_with_all_params(self, async_client: AsyncCloudflare) -> None: + secret = await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + name="MY_SECRET", + text="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9", + type="secret_text", + ) + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_raw_response_update(self, async_client: AsyncCloudflare) -> None: + response = ( + await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + secret = await response.parse() + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_streaming_response_update(self, async_client: AsyncCloudflare) -> None: + async with async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_streaming_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + secret = await response.parse() + assert_matches_type(SecretUpdateResponse, secret, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + async def test_path_params_update(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.update( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + @pytest.mark.skip() + @parametrize + async def test_method_list(self, async_client: AsyncCloudflare) -> None: + secret = await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + assert_matches_type(AsyncSinglePage[SecretListResponse], secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_raw_response_list(self, async_client: AsyncCloudflare) -> None: + response = await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + secret = await response.parse() + assert_matches_type(AsyncSinglePage[SecretListResponse], secret, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_streaming_response_list(self, async_client: AsyncCloudflare) -> None: + async with async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_streaming_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + secret = await response.parse() + assert_matches_type(AsyncSinglePage[SecretListResponse], secret, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + async def test_path_params_list(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.secrets.with_raw_response.list( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) diff --git a/tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_tags.py b/tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_tags.py new file mode 100644 index 00000000000..3e7dd4d20e4 --- /dev/null +++ b/tests/api_resources/workers_for_platforms/dispatch/namespaces/scripts/test_tags.py @@ -0,0 +1,450 @@ +# File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. + +from __future__ import annotations + +import os +from typing import Any, cast + +import pytest + +from cloudflare import Cloudflare, AsyncCloudflare +from tests.utils import assert_matches_type +from cloudflare.pagination import SyncSinglePage, AsyncSinglePage +from cloudflare.types.workers_for_platforms.dispatch.namespaces.scripts import ( + TagListResponse, + TagUpdateResponse, +) + +base_url = os.environ.get("TEST_API_BASE_URL", "http://127.0.0.1:4010") + + +class TestTags: + parametrize = pytest.mark.parametrize("client", [False, True], indirect=True, ids=["loose", "strict"]) + + @pytest.mark.skip() + @parametrize + def test_method_update(self, client: Cloudflare) -> None: + tag = client.workers_for_platforms.dispatch.namespaces.scripts.tags.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + assert_matches_type(TagUpdateResponse, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_raw_response_update(self, client: Cloudflare) -> None: + response = client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + tag = response.parse() + assert_matches_type(TagUpdateResponse, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_streaming_response_update(self, client: Cloudflare) -> None: + with client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_streaming_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + tag = response.parse() + assert_matches_type(TagUpdateResponse, tag, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + def test_path_params_update(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + body=["my-tag", "my-tag", "my-tag"], + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + + @pytest.mark.skip() + @parametrize + def test_method_list(self, client: Cloudflare) -> None: + tag = client.workers_for_platforms.dispatch.namespaces.scripts.tags.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + assert_matches_type(SyncSinglePage[TagListResponse], tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_raw_response_list(self, client: Cloudflare) -> None: + response = client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + tag = response.parse() + assert_matches_type(SyncSinglePage[TagListResponse], tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_streaming_response_list(self, client: Cloudflare) -> None: + with client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_streaming_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + tag = response.parse() + assert_matches_type(SyncSinglePage[TagListResponse], tag, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + def test_path_params_list(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + @pytest.mark.skip() + @parametrize + def test_method_delete(self, client: Cloudflare) -> None: + tag = client.workers_for_platforms.dispatch.namespaces.scripts.tags.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) + assert_matches_type(object, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_raw_response_delete(self, client: Cloudflare) -> None: + response = client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + tag = response.parse() + assert_matches_type(object, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + def test_streaming_response_delete(self, client: Cloudflare) -> None: + with client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_streaming_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + tag = response.parse() + assert_matches_type(object, tag, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + def test_path_params_delete(self, client: Cloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + script_name="this-is_my_script-01", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `tag` but received ''"): + client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) + + +class TestAsyncTags: + parametrize = pytest.mark.parametrize("async_client", [False, True], indirect=True, ids=["loose", "strict"]) + + @pytest.mark.skip() + @parametrize + async def test_method_update(self, async_client: AsyncCloudflare) -> None: + tag = await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + assert_matches_type(TagUpdateResponse, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_raw_response_update(self, async_client: AsyncCloudflare) -> None: + response = await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + tag = await response.parse() + assert_matches_type(TagUpdateResponse, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_streaming_response_update(self, async_client: AsyncCloudflare) -> None: + async with async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_streaming_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + tag = await response.parse() + assert_matches_type(TagUpdateResponse, tag, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + async def test_path_params_update(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + body=["my-tag", "my-tag", "my-tag"], + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.update( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + body=["my-tag", "my-tag", "my-tag"], + ) + + @pytest.mark.skip() + @parametrize + async def test_method_list(self, async_client: AsyncCloudflare) -> None: + tag = await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + assert_matches_type(AsyncSinglePage[TagListResponse], tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_raw_response_list(self, async_client: AsyncCloudflare) -> None: + response = await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + tag = await response.parse() + assert_matches_type(AsyncSinglePage[TagListResponse], tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_streaming_response_list(self, async_client: AsyncCloudflare) -> None: + async with async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_streaming_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + tag = await response.parse() + assert_matches_type(AsyncSinglePage[TagListResponse], tag, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + async def test_path_params_list(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "this-is_my_script-01", + account_id="", + dispatch_namespace="my-dispatch-namespace", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "this-is_my_script-01", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.list( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + ) + + @pytest.mark.skip() + @parametrize + async def test_method_delete(self, async_client: AsyncCloudflare) -> None: + tag = await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) + assert_matches_type(object, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_raw_response_delete(self, async_client: AsyncCloudflare) -> None: + response = await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) + + assert response.is_closed is True + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + tag = await response.parse() + assert_matches_type(object, tag, path=["response"]) + + @pytest.mark.skip() + @parametrize + async def test_streaming_response_delete(self, async_client: AsyncCloudflare) -> None: + async with async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_streaming_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) as response: + assert not response.is_closed + assert response.http_request.headers.get("X-Stainless-Lang") == "python" + + tag = await response.parse() + assert_matches_type(object, tag, path=["response"]) + + assert cast(Any, response.is_closed) is True + + @pytest.mark.skip() + @parametrize + async def test_path_params_delete(self, async_client: AsyncCloudflare) -> None: + with pytest.raises(ValueError, match=r"Expected a non-empty value for `account_id` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `dispatch_namespace` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="", + script_name="this-is_my_script-01", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `script_name` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "my-tag", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="", + ) + + with pytest.raises(ValueError, match=r"Expected a non-empty value for `tag` but received ''"): + await async_client.workers_for_platforms.dispatch.namespaces.scripts.tags.with_raw_response.delete( + "", + account_id="023e105f4ecef8ad9ca31a8372d0c353", + dispatch_namespace="my-dispatch-namespace", + script_name="this-is_my_script-01", + )