ory_client/models/
create_project_normalized_payload.rs

1/*
2 * Ory APIs
3 *
4 * # Introduction Documentation for all public and administrative Ory APIs. Administrative APIs can only be accessed with a valid Personal Access Token. Public APIs are mostly used in browsers.  ## SDKs This document describes the APIs available in the Ory Network. The APIs are available as SDKs for the following languages:  | Language       | Download SDK                                                     | Documentation                                                                        | | -------------- | ---------------------------------------------------------------- | ------------------------------------------------------------------------------------ | | Dart           | [pub.dev](https://pub.dev/packages/ory_client)                   | [README](https://github.com/ory/sdk/blob/master/clients/client/dart/README.md)       | | .NET           | [nuget.org](https://www.nuget.org/packages/Ory.Client/)          | [README](https://github.com/ory/sdk/blob/master/clients/client/dotnet/README.md)     | | Elixir         | [hex.pm](https://hex.pm/packages/ory_client)                     | [README](https://github.com/ory/sdk/blob/master/clients/client/elixir/README.md)     | | Go             | [github.com](https://github.com/ory/client-go)                   | [README](https://github.com/ory/sdk/blob/master/clients/client/go/README.md)         | | Java           | [maven.org](https://search.maven.org/artifact/sh.ory/ory-client) | [README](https://github.com/ory/sdk/blob/master/clients/client/java/README.md)       | | JavaScript     | [npmjs.com](https://www.npmjs.com/package/@ory/client)           | [README](https://github.com/ory/sdk/blob/master/clients/client/typescript/README.md) | | JavaScript (With fetch) | [npmjs.com](https://www.npmjs.com/package/@ory/client-fetch)           | [README](https://github.com/ory/sdk/blob/master/clients/client/typescript-fetch/README.md) |  | PHP            | [packagist.org](https://packagist.org/packages/ory/client)       | [README](https://github.com/ory/sdk/blob/master/clients/client/php/README.md)        | | Python         | [pypi.org](https://pypi.org/project/ory-client/)                 | [README](https://github.com/ory/sdk/blob/master/clients/client/python/README.md)     | | Ruby           | [rubygems.org](https://rubygems.org/gems/ory-client)             | [README](https://github.com/ory/sdk/blob/master/clients/client/ruby/README.md)       | | Rust           | [crates.io](https://crates.io/crates/ory-client)                 | [README](https://github.com/ory/sdk/blob/master/clients/client/rust/README.md)       | 
5 *
6 * The version of the OpenAPI document: v1.17.2
7 * Contact: support@ory.sh
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14/// CreateProjectNormalizedPayload : Create project (normalized) request payload
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct CreateProjectNormalizedPayload {
17    /// Holds the URL to the account experience's dark theme favicon (currently unused).
18    #[serde(rename = "account_experience_favicon_dark", skip_serializing_if = "Option::is_none")]
19    pub account_experience_favicon_dark: Option<String>,
20    /// Holds the URL to the account experience's favicon.
21    #[serde(rename = "account_experience_favicon_light", skip_serializing_if = "Option::is_none")]
22    pub account_experience_favicon_light: Option<String>,
23    /// Holds the URL to the account experience's dark theme logo (currently unused).
24    #[serde(rename = "account_experience_logo_dark", skip_serializing_if = "Option::is_none")]
25    pub account_experience_logo_dark: Option<String>,
26    /// Holds the URL to the account experience's logo.
27    #[serde(rename = "account_experience_logo_light", skip_serializing_if = "Option::is_none")]
28    pub account_experience_logo_light: Option<String>,
29    /// Holds the URL to the account experience's dark theme variables.
30    #[serde(rename = "account_experience_theme_variables_dark", skip_serializing_if = "Option::is_none")]
31    pub account_experience_theme_variables_dark: Option<String>,
32    /// Holds the URL to the account experience's light theme variables.
33    #[serde(rename = "account_experience_theme_variables_light", skip_serializing_if = "Option::is_none")]
34    pub account_experience_theme_variables_light: Option<String>,
35    /// The Project's Revision Creation Date
36    #[serde(rename = "created_at", skip_serializing_if = "Option::is_none")]
37    pub created_at: Option<String>,
38    /// Whether to disable the account experience welcome screen, which is hosted under `/ui/welcome`.
39    #[serde(rename = "disable_account_experience_welcome_screen", skip_serializing_if = "Option::is_none")]
40    pub disable_account_experience_welcome_screen: Option<bool>,
41    /// Whether the new account experience is enabled and reachable.
42    #[serde(rename = "enable_ax_v2", skip_serializing_if = "Option::is_none")]
43    pub enable_ax_v2: Option<bool>,
44    ///  prod Production stage Staging dev Development
45    #[serde(rename = "environment")]
46    pub environment: EnvironmentEnum,
47    ///  eu-central EUCentral asia-northeast AsiaNorthEast us-east USEast us-west USWest us US global Global
48    #[serde(rename = "home_region", skip_serializing_if = "Option::is_none")]
49    pub home_region: Option<HomeRegionEnum>,
50    #[serde(rename = "hydra_oauth2_allowed_top_level_claims", skip_serializing_if = "Option::is_none")]
51    pub hydra_oauth2_allowed_top_level_claims: Option<Vec<String>>,
52    /// Automatically grant authorized OAuth2 Scope in OAuth2 Client Credentials Flow.  Each OAuth2 Client is allowed to request a predefined OAuth2 Scope (for example `read write`). If this option is enabled, the full scope is automatically granted when performing the OAuth2 Client Credentials flow.  If disabled, the OAuth2 Client has to request the scope in the OAuth2 request by providing the `scope` query parameter.  Setting this option to true is common if you need compatibility with MITREid.  This governs the \"oauth2.client_credentials.default_grant_allowed_scope\" setting.
53    #[serde(rename = "hydra_oauth2_client_credentials_default_grant_allowed_scope", skip_serializing_if = "Option::is_none")]
54    pub hydra_oauth2_client_credentials_default_grant_allowed_scope: Option<bool>,
55    /// Set to true if you want to exclude claim `nbf (not before)` part of access token.  This governs the \"oauth2.exclude_not_before_claim\" setting.
56    #[serde(rename = "hydra_oauth2_exclude_not_before_claim", skip_serializing_if = "Option::is_none")]
57    pub hydra_oauth2_exclude_not_before_claim: Option<bool>,
58    /// Configures if the issued at (`iat`) claim is required in the JSON Web Token (JWT) Profile for OAuth 2.0 Client Authentication and Authorization Grants (RFC7523).  If set to `false`, the `iat` claim is required. Set this value to `true` only after careful consideration.  This governs the \"oauth2.grant.jwt.iat_optional\" setting.
59    #[serde(rename = "hydra_oauth2_grant_jwt_iat_optional", skip_serializing_if = "Option::is_none")]
60    pub hydra_oauth2_grant_jwt_iat_optional: Option<bool>,
61    /// Configures if the JSON Web Token ID (`jti`) claim is required in the JSON Web Token (JWT) Profile for OAuth 2.0 Client Authentication and Authorization Grants (RFC7523).  If set to `false`, the `jti` claim is required. Set this value to `true` only after careful consideration.  This governs the \"oauth2.grant.jwt.jti_optional\" setting.
62    #[serde(rename = "hydra_oauth2_grant_jwt_jti_optional", skip_serializing_if = "Option::is_none")]
63    pub hydra_oauth2_grant_jwt_jti_optional: Option<bool>,
64    /// Configures what the maximum age of a JWT assertion used in the JSON Web Token (JWT) Profile for OAuth 2.0 Client Authentication and Authorization Grants (RFC7523) can be.  This feature uses the `exp` claim and `iat` claim to calculate assertion age. Assertions exceeding the max age will be denied.  Useful as a safety measure and recommended to keep below 720h.  This governs the \"oauth2.grant.jwt.max_ttl\" setting.
65    #[serde(rename = "hydra_oauth2_grant_jwt_max_ttl", skip_serializing_if = "Option::is_none")]
66    pub hydra_oauth2_grant_jwt_max_ttl: Option<String>,
67    /// Configures the OAuth2 Grant Refresh Token Rotation Grace Period  If set to `null` or `\"0s\"`, the graceful refresh token rotation is disabled.  This governs the \"oauth2.grant.refresh_token_rotation_grace_period\" setting.
68    #[serde(rename = "hydra_oauth2_grant_refresh_token_rotation_grace_period", skip_serializing_if = "Option::is_none")]
69    pub hydra_oauth2_grant_refresh_token_rotation_grace_period: Option<String>,
70    /// Set to false if you don't want to mirror custom claims under 'ext'.  This governs the \"oauth2.mirror_top_level_claims\" setting.
71    #[serde(rename = "hydra_oauth2_mirror_top_level_claims", skip_serializing_if = "Option::is_none")]
72    pub hydra_oauth2_mirror_top_level_claims: Option<bool>,
73    /// Configures whether PKCE should be enforced for all OAuth2 Clients.  This governs the \"oauth2.pkce.enforced\" setting.
74    #[serde(rename = "hydra_oauth2_pkce_enforced", skip_serializing_if = "Option::is_none")]
75    pub hydra_oauth2_pkce_enforced: Option<bool>,
76    /// Configures whether PKCE should be enforced for OAuth2 Clients without a client secret (public clients).  This governs the \"oauth2.pkce.enforced_for_public_clients\" setting.
77    #[serde(rename = "hydra_oauth2_pkce_enforced_for_public_clients", skip_serializing_if = "Option::is_none")]
78    pub hydra_oauth2_pkce_enforced_for_public_clients: Option<bool>,
79    /// Sets the Refresh Token Hook Endpoint. If set this endpoint will be called during the OAuth2 Token Refresh grant update the OAuth2 Access Token claims.  This governs the \"oauth2.refresh_token_hook\" setting.
80    #[serde(rename = "hydra_oauth2_refresh_token_hook", skip_serializing_if = "Option::is_none")]
81    pub hydra_oauth2_refresh_token_hook: Option<String>,
82    /// Sets the token hook endpoint for all grant types. If set it will be called while providing token to customize claims.  This governs the \"oauth2.token_hook.url\" setting.
83    #[serde(rename = "hydra_oauth2_token_hook", skip_serializing_if = "Option::is_none")]
84    pub hydra_oauth2_token_hook: Option<String>,
85    #[serde(rename = "hydra_oidc_dynamic_client_registration_default_scope", skip_serializing_if = "Option::is_none")]
86    pub hydra_oidc_dynamic_client_registration_default_scope: Option<Vec<String>>,
87    /// Configures OpenID Connect Dynamic Client Registration.  This governs the \"oidc.dynamic_client_registration.enabled\" setting.
88    #[serde(rename = "hydra_oidc_dynamic_client_registration_enabled", skip_serializing_if = "Option::is_none")]
89    pub hydra_oidc_dynamic_client_registration_enabled: Option<bool>,
90    /// Configures OpenID Connect Discovery and overwrites the pairwise algorithm  This governs the \"oidc.subject_identifiers.pairwise_salt\" setting.
91    #[serde(rename = "hydra_oidc_subject_identifiers_pairwise_salt", skip_serializing_if = "Option::is_none")]
92    pub hydra_oidc_subject_identifiers_pairwise_salt: Option<String>,
93    #[serde(rename = "hydra_oidc_subject_identifiers_supported_types", skip_serializing_if = "Option::is_none")]
94    pub hydra_oidc_subject_identifiers_supported_types: Option<Vec<String>>,
95    #[serde(rename = "hydra_secrets_cookie", skip_serializing_if = "Option::is_none")]
96    pub hydra_secrets_cookie: Option<Vec<String>>,
97    #[serde(rename = "hydra_secrets_system", skip_serializing_if = "Option::is_none")]
98    pub hydra_secrets_system: Option<Vec<String>>,
99    /// Configures the Ory Hydra Cookie Same Site Legacy Workaround  This governs the \"serve.cookies.same_site_legacy_workaround\" setting.
100    #[serde(rename = "hydra_serve_cookies_same_site_legacy_workaround", skip_serializing_if = "Option::is_none")]
101    pub hydra_serve_cookies_same_site_legacy_workaround: Option<bool>,
102    /// Configures the Ory Hydra Cookie Same Site Mode  This governs the \"serve.cookies.same_site_mode\" setting.
103    #[serde(rename = "hydra_serve_cookies_same_site_mode", skip_serializing_if = "Option::is_none")]
104    pub hydra_serve_cookies_same_site_mode: Option<String>,
105    /// Defines access token type  This governs the \"strategies.access_token\" setting. opaque Oauth2AccessTokenStrategyOpaque jwt Oauth2AccessTokenStrategyJwt
106    #[serde(rename = "hydra_strategies_access_token", skip_serializing_if = "Option::is_none")]
107    pub hydra_strategies_access_token: Option<HydraStrategiesAccessTokenEnum>,
108    /// Define the claim to use as the scope in the access token.  This governs the \"strategies.jwt.scope_claim\" setting:  list: The scope claim is an array of strings named `scope`: `{ \"scope\": [\"read\", \"write\"] }` string: The scope claim is a space delimited list of strings named `scp`: `{ \"scp\": \"read write\" }` both: The scope claim is both a space delimited list and an array of strings named `scope` and `scp`: `{ \"scope\": [\"read\", \"write\"], \"scp\": \"read write\" }` list OAuth2JWTScopeClaimList string OAuth2JWTScopeClaimString both OAuth2JWTScopeClaimBoth
109    #[serde(rename = "hydra_strategies_jwt_scope_claim", skip_serializing_if = "Option::is_none")]
110    pub hydra_strategies_jwt_scope_claim: Option<HydraStrategiesJwtScopeClaimEnum>,
111    /// Defines how scopes are matched. For more details have a look at https://github.com/ory/fosite#scopes  This governs the \"strategies.scope\" setting. exact Oauth2ScopeStrategyExact wildcard Oauth2ScopeStrategyWildcard
112    #[serde(rename = "hydra_strategies_scope", skip_serializing_if = "Option::is_none")]
113    pub hydra_strategies_scope: Option<HydraStrategiesScopeEnum>,
114    /// This governs the \"ttl.access_token\" setting.
115    #[serde(rename = "hydra_ttl_access_token", skip_serializing_if = "Option::is_none")]
116    pub hydra_ttl_access_token: Option<String>,
117    /// Configures how long refresh tokens are valid.  Set to -1 for refresh tokens to never expire. This is not recommended!  This governs the \"ttl.auth_code\" setting.
118    #[serde(rename = "hydra_ttl_auth_code", skip_serializing_if = "Option::is_none")]
119    pub hydra_ttl_auth_code: Option<String>,
120    /// This governs the \"ttl.id_token\" setting.
121    #[serde(rename = "hydra_ttl_id_token", skip_serializing_if = "Option::is_none")]
122    pub hydra_ttl_id_token: Option<String>,
123    /// Configures how long a user login and consent flow may take.  This governs the \"ttl.login_consent_request\" setting.
124    #[serde(rename = "hydra_ttl_login_consent_request", skip_serializing_if = "Option::is_none")]
125    pub hydra_ttl_login_consent_request: Option<String>,
126    /// Configures how long refresh tokens are valid.  Set to -1 for refresh tokens to never expire. This is not recommended!  This governs the \"ttl.refresh_token\" setting.
127    #[serde(rename = "hydra_ttl_refresh_token", skip_serializing_if = "Option::is_none")]
128    pub hydra_ttl_refresh_token: Option<String>,
129    /// Sets the OAuth2 Consent Endpoint URL of the OAuth2 User Login & Consent flow.  Defaults to the Ory Account Experience if left empty.  This governs the \"urls.consent\" setting.
130    #[serde(rename = "hydra_urls_consent", skip_serializing_if = "Option::is_none")]
131    pub hydra_urls_consent: Option<String>,
132    /// Sets the OAuth2 Error URL of the OAuth2 User Login & Consent flow.  Defaults to the Ory Account Experience if left empty.  This governs the \"urls.error\" setting.
133    #[serde(rename = "hydra_urls_error", skip_serializing_if = "Option::is_none")]
134    pub hydra_urls_error: Option<String>,
135    /// Sets the OAuth2 Login Endpoint URL of the OAuth2 User Login & Consent flow.  Defaults to the Ory Account Experience if left empty.  This governs the \"urls.login\" setting.
136    #[serde(rename = "hydra_urls_login", skip_serializing_if = "Option::is_none")]
137    pub hydra_urls_login: Option<String>,
138    /// Sets the logout endpoint.  Defaults to the Ory Account Experience if left empty.  This governs the \"urls.logout\" setting.
139    #[serde(rename = "hydra_urls_logout", skip_serializing_if = "Option::is_none")]
140    pub hydra_urls_logout: Option<String>,
141    /// When an OAuth2-related user agent requests to log out, they will be redirected to this url afterwards per default.  Defaults to the Ory Account Experience in development and your application in production mode when a custom domain is connected.  This governs the \"urls.post_logout_redirect\" setting.
142    #[serde(rename = "hydra_urls_post_logout_redirect", skip_serializing_if = "Option::is_none")]
143    pub hydra_urls_post_logout_redirect: Option<String>,
144    /// Sets the OAuth2 Registration Endpoint URL of the OAuth2 User Login & Consent flow.  Defaults to the Ory Account Experience if left empty.  This governs the \"urls.registration\" setting.
145    #[serde(rename = "hydra_urls_registration", skip_serializing_if = "Option::is_none")]
146    pub hydra_urls_registration: Option<String>,
147    /// This value will be used as the issuer in access and ID tokens. It must be specified and using HTTPS protocol, unless the development mode is enabled.  On the Ory Network it will be very rare that you want to modify this value. If left empty, it will default to the correct value for the Ory Network.  This governs the \"urls.self.issuer\" setting.
148    #[serde(rename = "hydra_urls_self_issuer", skip_serializing_if = "Option::is_none")]
149    pub hydra_urls_self_issuer: Option<String>,
150    #[serde(rename = "hydra_webfinger_jwks_broadcast_keys", skip_serializing_if = "Option::is_none")]
151    pub hydra_webfinger_jwks_broadcast_keys: Option<Vec<String>>,
152    /// Configures OpenID Connect Discovery and overwrites the OAuth2 Authorization URL.  This governs the \"webfinger.oidc.discovery.auth_url\" setting.
153    #[serde(rename = "hydra_webfinger_oidc_discovery_auth_url", skip_serializing_if = "Option::is_none")]
154    pub hydra_webfinger_oidc_discovery_auth_url: Option<String>,
155    /// Configures OpenID Connect Discovery and overwrites the OpenID Connect Dynamic Client Registration Endpoint.  This governs the \"webfinger.oidc.discovery.client_registration_url\" setting.
156    #[serde(rename = "hydra_webfinger_oidc_discovery_client_registration_url", skip_serializing_if = "Option::is_none")]
157    pub hydra_webfinger_oidc_discovery_client_registration_url: Option<String>,
158    /// Configures OpenID Connect Discovery and overwrites the JWKS URL.  This governs the \"webfinger.oidc.discovery.jwks_url\" setting.
159    #[serde(rename = "hydra_webfinger_oidc_discovery_jwks_url", skip_serializing_if = "Option::is_none")]
160    pub hydra_webfinger_oidc_discovery_jwks_url: Option<String>,
161    #[serde(rename = "hydra_webfinger_oidc_discovery_supported_claims", skip_serializing_if = "Option::is_none")]
162    pub hydra_webfinger_oidc_discovery_supported_claims: Option<Vec<String>>,
163    #[serde(rename = "hydra_webfinger_oidc_discovery_supported_scope", skip_serializing_if = "Option::is_none")]
164    pub hydra_webfinger_oidc_discovery_supported_scope: Option<Vec<String>>,
165    /// Configures OpenID Connect Discovery and overwrites the OAuth2 Token URL.  This governs the \"webfinger.oidc.discovery.token_url\" setting.
166    #[serde(rename = "hydra_webfinger_oidc_discovery_token_url", skip_serializing_if = "Option::is_none")]
167    pub hydra_webfinger_oidc_discovery_token_url: Option<String>,
168    /// Configures OpenID Connect Discovery and overwrites userinfo endpoint to be advertised at the OpenID Connect Discovery endpoint /.well-known/openid-configuration. Defaults to Ory Hydra's userinfo endpoint at /userinfo. Set this value if you want to handle this endpoint yourself.  This governs the \"webfinger.oidc.discovery.userinfo_url\" setting.
169    #[serde(rename = "hydra_webfinger_oidc_discovery_userinfo_url", skip_serializing_if = "Option::is_none")]
170    pub hydra_webfinger_oidc_discovery_userinfo_url: Option<String>,
171    /// The revision ID.
172    #[serde(rename = "id", skip_serializing_if = "Option::is_none")]
173    pub id: Option<String>,
174    /// The Revisions' Keto Namespace Configuration  The string is a URL pointing to an OPL file with the configuration.
175    #[serde(rename = "keto_namespace_configuration", skip_serializing_if = "Option::is_none")]
176    pub keto_namespace_configuration: Option<String>,
177    #[serde(rename = "keto_namespaces", skip_serializing_if = "Option::is_none")]
178    pub keto_namespaces: Option<Vec<models::KetoNamespace>>,
179    /// Configures the Ory Kratos Cookie SameSite Attribute  This governs the \"cookies.same_site\" setting.
180    #[serde(rename = "kratos_cookies_same_site", skip_serializing_if = "Option::is_none")]
181    pub kratos_cookies_same_site: Option<String>,
182    #[serde(rename = "kratos_courier_channels", skip_serializing_if = "Option::is_none")]
183    pub kratos_courier_channels: Option<Vec<models::NormalizedProjectRevisionCourierChannel>>,
184    /// The delivery strategy to use when sending emails  `smtp`: Use SMTP server `http`: Use the built in HTTP client to send the email to some remote service
185    #[serde(rename = "kratos_courier_delivery_strategy", skip_serializing_if = "Option::is_none")]
186    pub kratos_courier_delivery_strategy: Option<String>,
187    /// The location of the API key to use in the HTTP email sending service's authentication  `header`: Send the key value pair as a header `cookie`: Send the key value pair as a cookie This governs the \"courier.http.auth.config.in\" setting
188    #[serde(rename = "kratos_courier_http_request_config_auth_api_key_in", skip_serializing_if = "Option::is_none")]
189    pub kratos_courier_http_request_config_auth_api_key_in: Option<String>,
190    /// The name of the API key to use in the HTTP email sending service's authentication  This governs the \"courier.http.auth.config.name\" setting
191    #[serde(rename = "kratos_courier_http_request_config_auth_api_key_name", skip_serializing_if = "Option::is_none")]
192    pub kratos_courier_http_request_config_auth_api_key_name: Option<String>,
193    /// The value of the API key to use in the HTTP email sending service's authentication  This governs the \"courier.http.auth.config.value\" setting
194    #[serde(rename = "kratos_courier_http_request_config_auth_api_key_value", skip_serializing_if = "Option::is_none")]
195    pub kratos_courier_http_request_config_auth_api_key_value: Option<String>,
196    /// The password to use for basic auth in the HTTP email sending service's authentication  This governs the \"courier.http.auth.config.password\" setting
197    #[serde(rename = "kratos_courier_http_request_config_auth_basic_auth_password", skip_serializing_if = "Option::is_none")]
198    pub kratos_courier_http_request_config_auth_basic_auth_password: Option<String>,
199    /// The user to use for basic auth in the HTTP email sending service's authentication  This governs the \"courier.http.auth.config.user\" setting
200    #[serde(rename = "kratos_courier_http_request_config_auth_basic_auth_user", skip_serializing_if = "Option::is_none")]
201    pub kratos_courier_http_request_config_auth_basic_auth_user: Option<String>,
202    /// The authentication type to use while contacting the remote HTTP email sending service  `basic_auth`: Use Basic Authentication `api_key`: Use API Key Authentication in a header or cookie
203    #[serde(rename = "kratos_courier_http_request_config_auth_type", skip_serializing_if = "Option::is_none")]
204    pub kratos_courier_http_request_config_auth_type: Option<String>,
205    /// The Jsonnet template to generate the body to send to the remote HTTP email sending service  Should be valid Jsonnet and base64 encoded  This governs the \"courier.http.body\" setting
206    #[serde(rename = "kratos_courier_http_request_config_body", skip_serializing_if = "Option::is_none")]
207    pub kratos_courier_http_request_config_body: Option<String>,
208    /// NullJSONRawMessage represents a json.RawMessage that works well with JSON, SQL, and Swagger and is NULLable-
209    #[serde(rename = "kratos_courier_http_request_config_headers", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
210    pub kratos_courier_http_request_config_headers: Option<Option<serde_json::Value>>,
211    /// The http METHOD to use when calling the remote HTTP email sending service
212    #[serde(rename = "kratos_courier_http_request_config_method", skip_serializing_if = "Option::is_none")]
213    pub kratos_courier_http_request_config_method: Option<String>,
214    /// The URL of the remote HTTP email sending service  This governs the \"courier.http.url\" setting
215    #[serde(rename = "kratos_courier_http_request_config_url", skip_serializing_if = "Option::is_none")]
216    pub kratos_courier_http_request_config_url: Option<String>,
217    /// Configures the Ory Kratos SMTP Connection URI  This governs the \"courier.smtp.connection_uri\" setting.
218    #[serde(rename = "kratos_courier_smtp_connection_uri", skip_serializing_if = "Option::is_none")]
219    pub kratos_courier_smtp_connection_uri: Option<String>,
220    /// Configures the Ory Kratos SMTP From Address  This governs the \"courier.smtp.from_address\" setting.
221    #[serde(rename = "kratos_courier_smtp_from_address", skip_serializing_if = "Option::is_none")]
222    pub kratos_courier_smtp_from_address: Option<String>,
223    /// Configures the Ory Kratos SMTP From Name  This governs the \"courier.smtp.from_name\" setting.
224    #[serde(rename = "kratos_courier_smtp_from_name", skip_serializing_if = "Option::is_none")]
225    pub kratos_courier_smtp_from_name: Option<String>,
226    /// NullJSONRawMessage represents a json.RawMessage that works well with JSON, SQL, and Swagger and is NULLable-
227    #[serde(rename = "kratos_courier_smtp_headers", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
228    pub kratos_courier_smtp_headers: Option<Option<serde_json::Value>>,
229    /// Configures the local_name to use in SMTP connections  This governs the \"courier.smtp.local_name\" setting.
230    #[serde(rename = "kratos_courier_smtp_local_name", skip_serializing_if = "Option::is_none")]
231    pub kratos_courier_smtp_local_name: Option<String>,
232    /// Configures the Ory Kratos Valid Login via Code Email Body HTML Template  This governs the \"courier.smtp.templates.login_code.valid.email.body.html\" setting.
233    #[serde(rename = "kratos_courier_templates_login_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
234    pub kratos_courier_templates_login_code_valid_email_body_html: Option<String>,
235    /// Configures the Ory Kratos Valid Login via Code Email Body Plaintext Template  This governs the \"courier.smtp.templates.login_code.valid.email.body.plaintext\" setting.
236    #[serde(rename = "kratos_courier_templates_login_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
237    pub kratos_courier_templates_login_code_valid_email_body_plaintext: Option<String>,
238    /// Configures the Ory Kratos Valid Login via Code Email Subject Template  This governs the \"courier.smtp.templates.login_code.valid.email.subject\" setting.
239    #[serde(rename = "kratos_courier_templates_login_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
240    pub kratos_courier_templates_login_code_valid_email_subject: Option<String>,
241    /// Configures the Ory Kratos Valid Login via Code SMS plain text body  This governs the \"courier.smtp.templates.login_code.valid.sms.plaintext\" setting.
242    #[serde(rename = "kratos_courier_templates_login_code_valid_sms_body_plaintext", skip_serializing_if = "Option::is_none")]
243    pub kratos_courier_templates_login_code_valid_sms_body_plaintext: Option<String>,
244    /// Configures the Ory Kratos Invalid Recovery via Code Email Body HTML Template  This governs the \"courier.smtp.templates.recovery_code.invalid.email.body.html\" setting.
245    #[serde(rename = "kratos_courier_templates_recovery_code_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
246    pub kratos_courier_templates_recovery_code_invalid_email_body_html: Option<String>,
247    /// Configures the Ory Kratos Invalid Recovery via Code Email Body Plaintext Template  This governs the \"courier.smtp.templates.recovery_code.invalid.email.body.plaintext\" setting.
248    #[serde(rename = "kratos_courier_templates_recovery_code_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
249    pub kratos_courier_templates_recovery_code_invalid_email_body_plaintext: Option<String>,
250    /// Configures the Ory Kratos Invalid Recovery via Code Email Subject Template  This governs the \"courier.smtp.templates.recovery_code.invalid.email.body.html\" setting.
251    #[serde(rename = "kratos_courier_templates_recovery_code_invalid_email_subject", skip_serializing_if = "Option::is_none")]
252    pub kratos_courier_templates_recovery_code_invalid_email_subject: Option<String>,
253    /// Configures the Ory Kratos Valid Recovery via Code Email Body HTML Template  This governs the \"courier.smtp.templates.recovery_code.valid.email.body.html\" setting.
254    #[serde(rename = "kratos_courier_templates_recovery_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
255    pub kratos_courier_templates_recovery_code_valid_email_body_html: Option<String>,
256    /// Configures the Ory Kratos Valid Recovery via Code Email Body Plaintext Template  This governs the \"courier.smtp.templates.recovery_code.valid.email.body.plaintext\" setting.
257    #[serde(rename = "kratos_courier_templates_recovery_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
258    pub kratos_courier_templates_recovery_code_valid_email_body_plaintext: Option<String>,
259    /// Configures the Ory Kratos Valid Recovery via Code Email Subject Template  This governs the \"courier.smtp.templates.recovery_code.valid.email.subject\" setting.
260    #[serde(rename = "kratos_courier_templates_recovery_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
261    pub kratos_courier_templates_recovery_code_valid_email_subject: Option<String>,
262    /// Configures the Ory Kratos Invalid Recovery Email Body HTML Template  This governs the \"courier.smtp.templates.recovery.invalid.email.body.html\" setting.
263    #[serde(rename = "kratos_courier_templates_recovery_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
264    pub kratos_courier_templates_recovery_invalid_email_body_html: Option<String>,
265    /// Configures the Ory Kratos Invalid Recovery Email Body Plaintext Template  This governs the \"courier.smtp.templates.recovery.invalid.email.body.plaintext\" setting.
266    #[serde(rename = "kratos_courier_templates_recovery_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
267    pub kratos_courier_templates_recovery_invalid_email_body_plaintext: Option<String>,
268    /// Configures the Ory Kratos Invalid Recovery Email Subject Template  This governs the \"courier.smtp.templates.recovery.invalid.email.body.html\" setting.
269    #[serde(rename = "kratos_courier_templates_recovery_invalid_email_subject", skip_serializing_if = "Option::is_none")]
270    pub kratos_courier_templates_recovery_invalid_email_subject: Option<String>,
271    /// Configures the Ory Kratos Valid Recovery Email Body HTML Template  This governs the \"courier.smtp.templates.recovery.valid.email.body.html\" setting.
272    #[serde(rename = "kratos_courier_templates_recovery_valid_email_body_html", skip_serializing_if = "Option::is_none")]
273    pub kratos_courier_templates_recovery_valid_email_body_html: Option<String>,
274    /// Configures the Ory Kratos Valid Recovery Email Body Plaintext Template  This governs the \"courier.smtp.templates.recovery.valid.email.body.plaintext\" setting.
275    #[serde(rename = "kratos_courier_templates_recovery_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
276    pub kratos_courier_templates_recovery_valid_email_body_plaintext: Option<String>,
277    /// Configures the Ory Kratos Valid Recovery Email Subject Template  This governs the \"courier.smtp.templates.recovery.valid.email.subject\" setting.
278    #[serde(rename = "kratos_courier_templates_recovery_valid_email_subject", skip_serializing_if = "Option::is_none")]
279    pub kratos_courier_templates_recovery_valid_email_subject: Option<String>,
280    /// Configures the Ory Kratos Valid Registration via Code Email Body HTML Template  This governs the \"courier.smtp.templates.registration_code.valid.email.body.html\" setting.
281    #[serde(rename = "kratos_courier_templates_registration_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
282    pub kratos_courier_templates_registration_code_valid_email_body_html: Option<String>,
283    /// Configures the Ory Kratos Valid Registration via Code Email Body Plaintext Template  This governs the \"courier.smtp.templates.registration_code.valid.email.body.plaintext\" setting.
284    #[serde(rename = "kratos_courier_templates_registration_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
285    pub kratos_courier_templates_registration_code_valid_email_body_plaintext: Option<String>,
286    /// Configures the Ory Kratos Valid Registration via Code Email Subject Template  This governs the \"courier.smtp.templates.registration_code.valid.email.subject\" setting.
287    #[serde(rename = "kratos_courier_templates_registration_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
288    pub kratos_courier_templates_registration_code_valid_email_subject: Option<String>,
289    /// Configures the Ory Kratos Valid Registration via Code Email Subject Template  This governs the \"courier.smtp.templates.registration_code.valid.sms.body.plaintext\" setting.
290    #[serde(rename = "kratos_courier_templates_registration_code_valid_sms_body_plaintext", skip_serializing_if = "Option::is_none")]
291    pub kratos_courier_templates_registration_code_valid_sms_body_plaintext: Option<String>,
292    /// Configures the Ory Kratos Invalid Verification via Code Email Body HTML Template  This governs the \"courier.smtp.templates.verification_code.invalid.email.body.html\" setting.
293    #[serde(rename = "kratos_courier_templates_verification_code_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
294    pub kratos_courier_templates_verification_code_invalid_email_body_html: Option<String>,
295    /// Configures the Ory Kratos Invalid Verification via Code Email Body Plaintext Template  This governs the \"courier.smtp.templates.verification_code.invalid.email.body.plaintext\" setting.
296    #[serde(rename = "kratos_courier_templates_verification_code_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
297    pub kratos_courier_templates_verification_code_invalid_email_body_plaintext: Option<String>,
298    /// Configures the Ory Kratos Invalid Verification via Code Email Subject Template  This governs the \"courier.smtp.templates.verification_code.invalid.email.subject\" setting.
299    #[serde(rename = "kratos_courier_templates_verification_code_invalid_email_subject", skip_serializing_if = "Option::is_none")]
300    pub kratos_courier_templates_verification_code_invalid_email_subject: Option<String>,
301    /// Configures the Ory Kratos Valid Verification via Code Email Body HTML Template  This governs the \"courier.smtp.templates.verification_code.valid.email.body.html\" setting.
302    #[serde(rename = "kratos_courier_templates_verification_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
303    pub kratos_courier_templates_verification_code_valid_email_body_html: Option<String>,
304    /// Configures the Ory Kratos Valid Verification via Code Email Body Plaintext Template  This governs the \"courier.smtp.templates.verification_code.valid.email.body.plaintext\" setting.
305    #[serde(rename = "kratos_courier_templates_verification_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
306    pub kratos_courier_templates_verification_code_valid_email_body_plaintext: Option<String>,
307    /// Configures the Ory Kratos Valid Verification via Code Email Subject Template  This governs the \"courier.smtp.templates.verification_code.valid.email.subject\" setting.
308    #[serde(rename = "kratos_courier_templates_verification_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
309    pub kratos_courier_templates_verification_code_valid_email_subject: Option<String>,
310    /// Configures the Ory Kratos Valid Verification via Code SMS Body Plaintext  This governs the \"courier.smtp.templates.verification_code.valid.sms.body.plaintext\" setting.
311    #[serde(rename = "kratos_courier_templates_verification_code_valid_sms_body_plaintext", skip_serializing_if = "Option::is_none")]
312    pub kratos_courier_templates_verification_code_valid_sms_body_plaintext: Option<String>,
313    /// Configures the Ory Kratos Invalid Verification Email Body HTML Template  This governs the \"courier.smtp.templates.verification.invalid.email.body.html\" setting.
314    #[serde(rename = "kratos_courier_templates_verification_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
315    pub kratos_courier_templates_verification_invalid_email_body_html: Option<String>,
316    /// Configures the Ory Kratos Invalid Verification Email Body Plaintext Template  This governs the \"courier.smtp.templates.verification.invalid.email.body.plaintext\" setting.
317    #[serde(rename = "kratos_courier_templates_verification_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
318    pub kratos_courier_templates_verification_invalid_email_body_plaintext: Option<String>,
319    /// Configures the Ory Kratos Invalid Verification Email Subject Template  This governs the \"courier.smtp.templates.verification.invalid.email.subject\" setting.
320    #[serde(rename = "kratos_courier_templates_verification_invalid_email_subject", skip_serializing_if = "Option::is_none")]
321    pub kratos_courier_templates_verification_invalid_email_subject: Option<String>,
322    /// Configures the Ory Kratos Valid Verification Email Body HTML Template  This governs the \"courier.smtp.templates.verification.valid.email.body.html\" setting.
323    #[serde(rename = "kratos_courier_templates_verification_valid_email_body_html", skip_serializing_if = "Option::is_none")]
324    pub kratos_courier_templates_verification_valid_email_body_html: Option<String>,
325    /// Configures the Ory Kratos Valid Verification Email Body Plaintext Template  This governs the \"courier.smtp.templates.verification.valid.email.body.plaintext\" setting.
326    #[serde(rename = "kratos_courier_templates_verification_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
327    pub kratos_courier_templates_verification_valid_email_body_plaintext: Option<String>,
328    /// Configures the Ory Kratos Valid Verification Email Subject Template  This governs the \"courier.smtp.templates.verification.valid.email.subject\" setting.
329    #[serde(rename = "kratos_courier_templates_verification_valid_email_subject", skip_serializing_if = "Option::is_none")]
330    pub kratos_courier_templates_verification_valid_email_subject: Option<String>,
331    /// Configures the Ory Kratos Session caching feature flag  This governs the \"feature_flags.cacheable_sessions\" setting.
332    #[serde(rename = "kratos_feature_flags_cacheable_sessions", skip_serializing_if = "Option::is_none")]
333    pub kratos_feature_flags_cacheable_sessions: Option<bool>,
334    /// Configures the Ory Kratos Session caching max-age feature flag  This governs the \"feature_flags.cacheable_sessions_max_age\" setting.
335    #[serde(rename = "kratos_feature_flags_cacheable_sessions_max_age", skip_serializing_if = "Option::is_none")]
336    pub kratos_feature_flags_cacheable_sessions_max_age: Option<String>,
337    /// Configures the Ory Kratos Faster Session Extend setting  If enabled allows faster session extension by skipping the session lookup and returning 201 instead of 200. Disabling this feature will be deprecated in the future.  This governs the \"feature_flags.faster_session_extend\" setting.
338    #[serde(rename = "kratos_feature_flags_faster_session_extend", skip_serializing_if = "Option::is_none")]
339    pub kratos_feature_flags_faster_session_extend: Option<bool>,
340    /// Configures the Ory Kratos Session use_continue_with_transitions flag  This governs the \"feature_flags.use_continue_with_transitions\" setting.
341    #[serde(rename = "kratos_feature_flags_use_continue_with_transitions", skip_serializing_if = "Option::is_none")]
342    pub kratos_feature_flags_use_continue_with_transitions: Option<bool>,
343    #[serde(rename = "kratos_identity_schemas", skip_serializing_if = "Option::is_none")]
344    pub kratos_identity_schemas: Option<Vec<models::NormalizedProjectRevisionIdentitySchema>>,
345    /// NullJSONRawMessage represents a json.RawMessage that works well with JSON, SQL, and Swagger and is NULLable-
346    #[serde(rename = "kratos_oauth2_provider_headers", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
347    pub kratos_oauth2_provider_headers: Option<Option<serde_json::Value>>,
348    /// Kratos OAuth2 Provider Override Return To  Enabling this allows Kratos to set the return_to parameter automatically to the OAuth2 request URL on the login flow, allowing complex flows such as recovery to continue to the initial OAuth2 flow.
349    #[serde(rename = "kratos_oauth2_provider_override_return_to", skip_serializing_if = "Option::is_none")]
350    pub kratos_oauth2_provider_override_return_to: Option<bool>,
351    /// The Revisions' OAuth2 Provider Integration URL  This governs the \"oauth2_provider.url\" setting.
352    #[serde(rename = "kratos_oauth2_provider_url", skip_serializing_if = "Option::is_none")]
353    pub kratos_oauth2_provider_url: Option<String>,
354    /// Configures the default read consistency level for identity APIs  This governs the `preview.default_read_consistency_level` setting.  The read consistency level determines the consistency guarantee for reads:  strong (slow): The read is guaranteed to return the most recent data committed at the start of the read. eventual (very fast): The result will return data that is about 4.8 seconds old.  Setting the default consistency level to `eventual` may cause regressions in the future as we add consistency controls to more APIs. Currently, the following APIs will be affected by this setting:  `GET /admin/identities`  Defaults to \"strong\" for new and existing projects. This feature is in preview. Use with caution.
355    #[serde(rename = "kratos_preview_default_read_consistency_level", skip_serializing_if = "Option::is_none")]
356    pub kratos_preview_default_read_consistency_level: Option<String>,
357    #[serde(rename = "kratos_secrets_cipher", skip_serializing_if = "Option::is_none")]
358    pub kratos_secrets_cipher: Option<Vec<String>>,
359    #[serde(rename = "kratos_secrets_cookie", skip_serializing_if = "Option::is_none")]
360    pub kratos_secrets_cookie: Option<Vec<String>>,
361    #[serde(rename = "kratos_secrets_default", skip_serializing_if = "Option::is_none")]
362    pub kratos_secrets_default: Option<Vec<String>>,
363    #[serde(rename = "kratos_selfservice_allowed_return_urls", skip_serializing_if = "Option::is_none")]
364    pub kratos_selfservice_allowed_return_urls: Option<Vec<String>>,
365    /// Configures the Ory Kratos Default Return URL  This governs the \"selfservice.allowed_return_urls\" setting.
366    #[serde(rename = "kratos_selfservice_default_browser_return_url", skip_serializing_if = "Option::is_none")]
367    pub kratos_selfservice_default_browser_return_url: Option<String>,
368    /// Configures the Ory Kratos Error UI URL  This governs the \"selfservice.flows.error.ui_url\" setting.
369    #[serde(rename = "kratos_selfservice_flows_error_ui_url", skip_serializing_if = "Option::is_none")]
370    pub kratos_selfservice_flows_error_ui_url: Option<String>,
371    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.code.after.password.default_browser_return_url\" setting.
372    #[serde(rename = "kratos_selfservice_flows_login_after_code_default_browser_return_url", skip_serializing_if = "Option::is_none")]
373    pub kratos_selfservice_flows_login_after_code_default_browser_return_url: Option<String>,
374    /// Configures the Ory Kratos Login Default Return URL  This governs the \"selfservice.flows.login.after.default_browser_return_url\" setting.
375    #[serde(rename = "kratos_selfservice_flows_login_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
376    pub kratos_selfservice_flows_login_after_default_browser_return_url: Option<String>,
377    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.lookup_secret.after.password.default_browser_return_url\" setting.
378    #[serde(rename = "kratos_selfservice_flows_login_after_lookup_secret_default_browser_return_url", skip_serializing_if = "Option::is_none")]
379    pub kratos_selfservice_flows_login_after_lookup_secret_default_browser_return_url: Option<String>,
380    /// Configures the Ory Kratos Login After OIDC Default Return URL  This governs the \"selfservice.flows.login.after.oidc.default_browser_return_url\" setting.
381    #[serde(rename = "kratos_selfservice_flows_login_after_oidc_default_browser_return_url", skip_serializing_if = "Option::is_none")]
382    pub kratos_selfservice_flows_login_after_oidc_default_browser_return_url: Option<String>,
383    /// Configures the Ory Kratos Login After Passkey Default Return URL  This governs the \"selfservice.flows.login.after.passkey.default_browser_return_url\" setting.
384    #[serde(rename = "kratos_selfservice_flows_login_after_passkey_default_browser_return_url", skip_serializing_if = "Option::is_none")]
385    pub kratos_selfservice_flows_login_after_passkey_default_browser_return_url: Option<String>,
386    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.login.after.password.default_browser_return_url\" setting.
387    #[serde(rename = "kratos_selfservice_flows_login_after_password_default_browser_return_url", skip_serializing_if = "Option::is_none")]
388    pub kratos_selfservice_flows_login_after_password_default_browser_return_url: Option<String>,
389    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.totp.after.password.default_browser_return_url\" setting.
390    #[serde(rename = "kratos_selfservice_flows_login_after_totp_default_browser_return_url", skip_serializing_if = "Option::is_none")]
391    pub kratos_selfservice_flows_login_after_totp_default_browser_return_url: Option<String>,
392    /// Configures the Ory Kratos Login After WebAuthn Default Return URL  This governs the \"selfservice.flows.login.after.webauthn.default_browser_return_url\" setting.
393    #[serde(rename = "kratos_selfservice_flows_login_after_webauthn_default_browser_return_url", skip_serializing_if = "Option::is_none")]
394    pub kratos_selfservice_flows_login_after_webauthn_default_browser_return_url: Option<String>,
395    /// Configures the Ory Kratos Login Lifespan  This governs the \"selfservice.flows.login.lifespan\" setting.
396    #[serde(rename = "kratos_selfservice_flows_login_lifespan", skip_serializing_if = "Option::is_none")]
397    pub kratos_selfservice_flows_login_lifespan: Option<String>,
398    /// Configures the Ory Kratos Login UI URL  This governs the \"selfservice.flows.login.ui_url\" setting.
399    #[serde(rename = "kratos_selfservice_flows_login_ui_url", skip_serializing_if = "Option::is_none")]
400    pub kratos_selfservice_flows_login_ui_url: Option<String>,
401    /// Configures the Ory Kratos Logout Default Return URL  This governs the \"selfservice.flows.logout.after.default_browser_return_url\" setting.
402    #[serde(rename = "kratos_selfservice_flows_logout_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
403    pub kratos_selfservice_flows_logout_after_default_browser_return_url: Option<String>,
404    /// Configures the Ory Kratos Recovery Default Return URL  This governs the \"selfservice.flows.recovery.after.default_browser_return_url\" setting.
405    #[serde(rename = "kratos_selfservice_flows_recovery_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
406    pub kratos_selfservice_flows_recovery_after_default_browser_return_url: Option<String>,
407    /// Configures the Ory Kratos Recovery Enabled Setting  This governs the \"selfservice.flows.recovery.enabled\" setting.
408    #[serde(rename = "kratos_selfservice_flows_recovery_enabled", skip_serializing_if = "Option::is_none")]
409    pub kratos_selfservice_flows_recovery_enabled: Option<bool>,
410    /// Configures the Ory Kratos Recovery Lifespan  This governs the \"selfservice.flows.recovery.lifespan\" setting.
411    #[serde(rename = "kratos_selfservice_flows_recovery_lifespan", skip_serializing_if = "Option::is_none")]
412    pub kratos_selfservice_flows_recovery_lifespan: Option<String>,
413    /// Configures whether to notify unknown recipients of a Ory Kratos recovery flow  This governs the \"selfservice.flows.recovery.notify_unknown_recipients\" setting.
414    #[serde(rename = "kratos_selfservice_flows_recovery_notify_unknown_recipients", skip_serializing_if = "Option::is_none")]
415    pub kratos_selfservice_flows_recovery_notify_unknown_recipients: Option<bool>,
416    /// Configures the Ory Kratos Recovery UI URL  This governs the \"selfservice.flows.recovery.ui_url\" setting.
417    #[serde(rename = "kratos_selfservice_flows_recovery_ui_url", skip_serializing_if = "Option::is_none")]
418    pub kratos_selfservice_flows_recovery_ui_url: Option<String>,
419    /// Configures the Ory Kratos Recovery strategy to use (\"link\" or \"code\")  This governs the \"selfservice.flows.recovery.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
420    #[serde(rename = "kratos_selfservice_flows_recovery_use", skip_serializing_if = "Option::is_none")]
421    pub kratos_selfservice_flows_recovery_use: Option<KratosSelfserviceFlowsRecoveryUseEnum>,
422    /// Configures the Ory Kratos Registration After Code Default Return URL  This governs the \"selfservice.flows.registration.after.code.default_browser_return_url\" setting.
423    #[serde(rename = "kratos_selfservice_flows_registration_after_code_default_browser_return_url", skip_serializing_if = "Option::is_none")]
424    pub kratos_selfservice_flows_registration_after_code_default_browser_return_url: Option<String>,
425    /// Configures the Ory Kratos Registration Default Return URL  This governs the \"selfservice.flows.registration.after.default_browser_return_url\" setting.
426    #[serde(rename = "kratos_selfservice_flows_registration_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
427    pub kratos_selfservice_flows_registration_after_default_browser_return_url: Option<String>,
428    /// Configures the Ory Kratos Registration After OIDC Default Return URL  This governs the \"selfservice.flows.registration.after.oidc.default_browser_return_url\" setting.
429    #[serde(rename = "kratos_selfservice_flows_registration_after_oidc_default_browser_return_url", skip_serializing_if = "Option::is_none")]
430    pub kratos_selfservice_flows_registration_after_oidc_default_browser_return_url: Option<String>,
431    /// Configures the Ory Kratos Registration After Passkey Default Return URL  This governs the \"selfservice.flows.registration.after.password.default_browser_return_url\" setting.
432    #[serde(rename = "kratos_selfservice_flows_registration_after_passkey_default_browser_return_url", skip_serializing_if = "Option::is_none")]
433    pub kratos_selfservice_flows_registration_after_passkey_default_browser_return_url: Option<String>,
434    /// Configures the Ory Kratos Registration After Password Default Return URL  This governs the \"selfservice.flows.registration.after.password.default_browser_return_url\" setting.
435    #[serde(rename = "kratos_selfservice_flows_registration_after_password_default_browser_return_url", skip_serializing_if = "Option::is_none")]
436    pub kratos_selfservice_flows_registration_after_password_default_browser_return_url: Option<String>,
437    /// Configures the Ory Kratos Registration After Webauthn Default Return URL  This governs the \"selfservice.flows.registration.after.webauthn.default_browser_return_url\" setting.
438    #[serde(rename = "kratos_selfservice_flows_registration_after_webauthn_default_browser_return_url", skip_serializing_if = "Option::is_none")]
439    pub kratos_selfservice_flows_registration_after_webauthn_default_browser_return_url: Option<String>,
440    /// Disable two-step registration  Two-step registration is a significantly improved sign up flow and recommended when using more than one sign up methods. To revert to one-step registration, set this to `true`.  This governs the \"selfservice.flows.registration.enable_legacy_one_step\" setting.
441    #[serde(rename = "kratos_selfservice_flows_registration_enable_legacy_one_step", skip_serializing_if = "Option::is_none")]
442    pub kratos_selfservice_flows_registration_enable_legacy_one_step: Option<bool>,
443    /// Configures the Whether Ory Kratos Registration is Enabled  This governs the \"selfservice.flows.registration.enabled\" setting.0
444    #[serde(rename = "kratos_selfservice_flows_registration_enabled", skip_serializing_if = "Option::is_none")]
445    pub kratos_selfservice_flows_registration_enabled: Option<bool>,
446    /// Configures the Ory Kratos Registration Lifespan  This governs the \"selfservice.flows.registration.lifespan\" setting.
447    #[serde(rename = "kratos_selfservice_flows_registration_lifespan", skip_serializing_if = "Option::is_none")]
448    pub kratos_selfservice_flows_registration_lifespan: Option<String>,
449    /// Configures the Ory Kratos Registration Login Hints  Shows helpful information when a user tries to sign up with a duplicate account.  This governs the \"selfservice.flows.registration.login_hints\" setting.
450    #[serde(rename = "kratos_selfservice_flows_registration_login_hints", skip_serializing_if = "Option::is_none")]
451    pub kratos_selfservice_flows_registration_login_hints: Option<bool>,
452    /// Configures the Ory Kratos Registration UI URL  This governs the \"selfservice.flows.registration.ui_url\" setting.
453    #[serde(rename = "kratos_selfservice_flows_registration_ui_url", skip_serializing_if = "Option::is_none")]
454    pub kratos_selfservice_flows_registration_ui_url: Option<String>,
455    /// Configures the Ory Kratos Settings Default Return URL  This governs the \"selfservice.flows.settings.after.default_browser_return_url\" setting.
456    #[serde(rename = "kratos_selfservice_flows_settings_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
457    pub kratos_selfservice_flows_settings_after_default_browser_return_url: Option<String>,
458    /// Configures the Ory Kratos Settings Default Return URL After Updating Lookup Secrets  This governs the \"selfservice.flows.settings.after.lookup_secret.default_browser_return_url\" setting.
459    #[serde(rename = "kratos_selfservice_flows_settings_after_lookup_secret_default_browser_return_url", skip_serializing_if = "Option::is_none")]
460    pub kratos_selfservice_flows_settings_after_lookup_secret_default_browser_return_url: Option<String>,
461    /// Configures the Ory Kratos Settings Default Return URL After Updating Social Sign In  This governs the \"selfservice.flows.settings.after.oidc.default_browser_return_url\" setting.
462    #[serde(rename = "kratos_selfservice_flows_settings_after_oidc_default_browser_return_url", skip_serializing_if = "Option::is_none")]
463    pub kratos_selfservice_flows_settings_after_oidc_default_browser_return_url: Option<String>,
464    /// Configures the Ory Kratos Settings Default Return URL After Updating Passkey  This governs the \"selfservice.flows.settings.after.passkey.default_browser_return_url\" setting.
465    #[serde(rename = "kratos_selfservice_flows_settings_after_passkey_default_browser_return_url", skip_serializing_if = "Option::is_none")]
466    pub kratos_selfservice_flows_settings_after_passkey_default_browser_return_url: Option<String>,
467    /// Configures the Ory Kratos Settings Default Return URL After Updating Passwords  This governs the \"selfservice.flows.settings.after.password.default_browser_return_url\" setting.
468    #[serde(rename = "kratos_selfservice_flows_settings_after_password_default_browser_return_url", skip_serializing_if = "Option::is_none")]
469    pub kratos_selfservice_flows_settings_after_password_default_browser_return_url: Option<String>,
470    /// Configures the Ory Kratos Settings Default Return URL After Updating Profiles  This governs the \"selfservice.flows.settings.after.profile.default_browser_return_url\" setting.
471    #[serde(rename = "kratos_selfservice_flows_settings_after_profile_default_browser_return_url", skip_serializing_if = "Option::is_none")]
472    pub kratos_selfservice_flows_settings_after_profile_default_browser_return_url: Option<String>,
473    /// Configures the Ory Kratos Settings Default Return URL After Updating TOTP  This governs the \"selfservice.flows.settings.after.totp.default_browser_return_url\" setting.
474    #[serde(rename = "kratos_selfservice_flows_settings_after_totp_default_browser_return_url", skip_serializing_if = "Option::is_none")]
475    pub kratos_selfservice_flows_settings_after_totp_default_browser_return_url: Option<String>,
476    /// Configures the Ory Kratos Settings Default Return URL After Updating WebAuthn  This governs the \"selfservice.flows.settings.after.webauthn.default_browser_return_url\" setting.
477    #[serde(rename = "kratos_selfservice_flows_settings_after_webauthn_default_browser_return_url", skip_serializing_if = "Option::is_none")]
478    pub kratos_selfservice_flows_settings_after_webauthn_default_browser_return_url: Option<String>,
479    /// Configures the Ory Kratos Settings Lifespan  This governs the \"selfservice.flows.settings.lifespan\" setting.
480    #[serde(rename = "kratos_selfservice_flows_settings_lifespan", skip_serializing_if = "Option::is_none")]
481    pub kratos_selfservice_flows_settings_lifespan: Option<String>,
482    /// Configures the Ory Kratos Settings Privileged Session Max Age  This governs the \"selfservice.flows.settings.privileged_session_max_age\" setting.
483    #[serde(rename = "kratos_selfservice_flows_settings_privileged_session_max_age", skip_serializing_if = "Option::is_none")]
484    pub kratos_selfservice_flows_settings_privileged_session_max_age: Option<String>,
485    /// Configures the Ory Kratos Settings Required AAL  This governs the \"selfservice.flows.settings.required_aal\" setting.
486    #[serde(rename = "kratos_selfservice_flows_settings_required_aal", skip_serializing_if = "Option::is_none")]
487    pub kratos_selfservice_flows_settings_required_aal: Option<String>,
488    /// Configures the Ory Kratos Settings UI URL  This governs the \"selfservice.flows.settings.ui_url\" setting.
489    #[serde(rename = "kratos_selfservice_flows_settings_ui_url", skip_serializing_if = "Option::is_none")]
490    pub kratos_selfservice_flows_settings_ui_url: Option<String>,
491    /// Configures the Ory Kratos Verification Default Return URL  This governs the \"selfservice.flows.verification.after.default_browser_return_url\" setting.
492    #[serde(rename = "kratos_selfservice_flows_verification_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
493    pub kratos_selfservice_flows_verification_after_default_browser_return_url: Option<String>,
494    /// Configures the Ory Kratos Verification Enabled Setting  This governs the \"selfservice.flows.verification.enabled\" setting.
495    #[serde(rename = "kratos_selfservice_flows_verification_enabled", skip_serializing_if = "Option::is_none")]
496    pub kratos_selfservice_flows_verification_enabled: Option<bool>,
497    /// Configures the Ory Kratos Verification Lifespan  This governs the \"selfservice.flows.verification.lifespan\" setting.
498    #[serde(rename = "kratos_selfservice_flows_verification_lifespan", skip_serializing_if = "Option::is_none")]
499    pub kratos_selfservice_flows_verification_lifespan: Option<String>,
500    /// Configures whether to notify unknown recipients of a Ory Kratos verification flow  This governs the \"selfservice.flows.verification.notify_unknown_recipients\" setting.
501    #[serde(rename = "kratos_selfservice_flows_verification_notify_unknown_recipients", skip_serializing_if = "Option::is_none")]
502    pub kratos_selfservice_flows_verification_notify_unknown_recipients: Option<bool>,
503    /// Configures the Ory Kratos Verification UI URL  This governs the \"selfservice.flows.verification.ui_url\" setting.
504    #[serde(rename = "kratos_selfservice_flows_verification_ui_url", skip_serializing_if = "Option::is_none")]
505    pub kratos_selfservice_flows_verification_ui_url: Option<String>,
506    /// Configures the Ory Kratos Strategy to use for Verification  This governs the \"selfservice.flows.verification.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
507    #[serde(rename = "kratos_selfservice_flows_verification_use", skip_serializing_if = "Option::is_none")]
508    pub kratos_selfservice_flows_verification_use: Option<KratosSelfserviceFlowsVerificationUseEnum>,
509    /// Configures the Turnstile site key for CAPTCHA protection  The site key is public and will be shared with the client.  Reach out to your account manager to enable this feature.
510    #[serde(rename = "kratos_selfservice_methods_captcha_config_cf_turnstile_sitekey", skip_serializing_if = "Option::is_none")]
511    pub kratos_selfservice_methods_captcha_config_cf_turnstile_sitekey: Option<String>,
512    /// Configures the Ory Kratos Self-Service Methods' Captcha Enabled Setting  Reach out to your account manager to enable this feature.
513    #[serde(rename = "kratos_selfservice_methods_captcha_enabled", skip_serializing_if = "Option::is_none")]
514    pub kratos_selfservice_methods_captcha_enabled: Option<bool>,
515    /// Configures the Ory Kratos Code Method's lifespan  This governs the \"selfservice.methods.code.config.lifespan\" setting.
516    #[serde(rename = "kratos_selfservice_methods_code_config_lifespan", skip_serializing_if = "Option::is_none")]
517    pub kratos_selfservice_methods_code_config_lifespan: Option<String>,
518    /// Enables a fallback method required in certain legacy use cases.  This governs the \"selfservice.methods.code.config.missing_credential_fallback_enabled\" setting.
519    #[serde(rename = "kratos_selfservice_methods_code_config_missing_credential_fallback_enabled", skip_serializing_if = "Option::is_none")]
520    pub kratos_selfservice_methods_code_config_missing_credential_fallback_enabled: Option<bool>,
521    /// Configures whether Ory Kratos Code Method is enabled  This governs the \"selfservice.methods.code.enabled\" setting.
522    #[serde(rename = "kratos_selfservice_methods_code_enabled", skip_serializing_if = "Option::is_none")]
523    pub kratos_selfservice_methods_code_enabled: Option<bool>,
524    /// Configures whether the code method can be used to fulfil MFA flows  This governs the \"selfservice.methods.code.mfa_enabled\" setting.
525    #[serde(rename = "kratos_selfservice_methods_code_mfa_enabled", skip_serializing_if = "Option::is_none")]
526    pub kratos_selfservice_methods_code_mfa_enabled: Option<bool>,
527    /// Configures whether Ory Kratos Passwordless should use the Code Method  This governs the \"selfservice.methods.code.passwordless_enabled\" setting.
528    #[serde(rename = "kratos_selfservice_methods_code_passwordless_enabled", skip_serializing_if = "Option::is_none")]
529    pub kratos_selfservice_methods_code_passwordless_enabled: Option<bool>,
530    /// This setting allows the code method to always login a user with code if they have registered with another authentication method such as password or social sign in.  This governs the \"selfservice.methods.code.passwordless_login_fallback_enabled\" setting.
531    #[serde(rename = "kratos_selfservice_methods_code_passwordless_login_fallback_enabled", skip_serializing_if = "Option::is_none")]
532    pub kratos_selfservice_methods_code_passwordless_login_fallback_enabled: Option<bool>,
533    /// Configures the Base URL which Recovery, Verification, and Login Links Point to  It is recommended to leave this value empty. It will be appropriately configured to the best matching domain (e.g. when using custom domains) automatically.  This governs the \"selfservice.methods.link.config.base_url\" setting.
534    #[serde(rename = "kratos_selfservice_methods_link_config_base_url", skip_serializing_if = "Option::is_none")]
535    pub kratos_selfservice_methods_link_config_base_url: Option<String>,
536    /// Configures the Ory Kratos Link Method's lifespan  This governs the \"selfservice.methods.link.config.lifespan\" setting.
537    #[serde(rename = "kratos_selfservice_methods_link_config_lifespan", skip_serializing_if = "Option::is_none")]
538    pub kratos_selfservice_methods_link_config_lifespan: Option<String>,
539    /// Configures whether Ory Kratos Link Method is enabled  This governs the \"selfservice.methods.link.enabled\" setting.
540    #[serde(rename = "kratos_selfservice_methods_link_enabled", skip_serializing_if = "Option::is_none")]
541    pub kratos_selfservice_methods_link_enabled: Option<bool>,
542    /// Configures whether Ory Kratos TOTP Lookup Secret is enabled  This governs the \"selfservice.methods.lookup_secret.enabled\" setting.
543    #[serde(rename = "kratos_selfservice_methods_lookup_secret_enabled", skip_serializing_if = "Option::is_none")]
544    pub kratos_selfservice_methods_lookup_secret_enabled: Option<bool>,
545    /// Configures the Ory Kratos Third Party / OpenID Connect base redirect URI  This governs the \"selfservice.methods.oidc.config.base_redirect_uri\" setting.
546    #[serde(rename = "kratos_selfservice_methods_oidc_config_base_redirect_uri", skip_serializing_if = "Option::is_none")]
547    pub kratos_selfservice_methods_oidc_config_base_redirect_uri: Option<String>,
548    #[serde(rename = "kratos_selfservice_methods_oidc_config_providers", skip_serializing_if = "Option::is_none")]
549    pub kratos_selfservice_methods_oidc_config_providers: Option<Vec<models::NormalizedProjectRevisionThirdPartyProvider>>,
550    /// Configures whether Ory Kratos Third Party / OpenID Connect Login is enabled  This governs the \"selfservice.methods.oidc.enabled\" setting.
551    #[serde(rename = "kratos_selfservice_methods_oidc_enabled", skip_serializing_if = "Option::is_none")]
552    pub kratos_selfservice_methods_oidc_enabled: Option<bool>,
553    /// Configures the Ory Kratos Passkey RP Display Name  This governs the \"selfservice.methods.passkey.config.rp.display_name\" setting.
554    #[serde(rename = "kratos_selfservice_methods_passkey_config_rp_display_name", skip_serializing_if = "Option::is_none")]
555    pub kratos_selfservice_methods_passkey_config_rp_display_name: Option<String>,
556    /// Configures the Ory Kratos Passkey RP ID  This governs the \"selfservice.methods.passkey.config.rp.id\" setting.
557    #[serde(rename = "kratos_selfservice_methods_passkey_config_rp_id", skip_serializing_if = "Option::is_none")]
558    pub kratos_selfservice_methods_passkey_config_rp_id: Option<String>,
559    #[serde(rename = "kratos_selfservice_methods_passkey_config_rp_origins", skip_serializing_if = "Option::is_none")]
560    pub kratos_selfservice_methods_passkey_config_rp_origins: Option<Vec<String>>,
561    /// Configures whether Ory Kratos Passkey authentication is enabled  This governs the \"selfservice.methods.passkey.enabled\" setting.
562    #[serde(rename = "kratos_selfservice_methods_passkey_enabled", skip_serializing_if = "Option::is_none")]
563    pub kratos_selfservice_methods_passkey_enabled: Option<bool>,
564    /// Configures whether Ory Kratos Password HIBP Checks is enabled  This governs the \"selfservice.methods.password.config.haveibeenpwned_enabled\" setting.
565    #[serde(rename = "kratos_selfservice_methods_password_config_haveibeenpwned_enabled", skip_serializing_if = "Option::is_none")]
566    pub kratos_selfservice_methods_password_config_haveibeenpwned_enabled: Option<bool>,
567    /// Configures whether Ory Kratos Password should disable the similarity policy.  This governs the \"selfservice.methods.password.config.identifier_similarity_check_enabled\" setting.
568    #[serde(rename = "kratos_selfservice_methods_password_config_identifier_similarity_check_enabled", skip_serializing_if = "Option::is_none")]
569    pub kratos_selfservice_methods_password_config_identifier_similarity_check_enabled: Option<bool>,
570    /// Configures whether Ory Kratos Password Should ignore HIBPWND Network Errors  This governs the \"selfservice.methods.password.config.ignore_network_errors\" setting.
571    #[serde(rename = "kratos_selfservice_methods_password_config_ignore_network_errors", skip_serializing_if = "Option::is_none")]
572    pub kratos_selfservice_methods_password_config_ignore_network_errors: Option<bool>,
573    /// Configures Ory Kratos Password Max Breaches Detection  This governs the \"selfservice.methods.password.config.max_breaches\" setting.
574    #[serde(rename = "kratos_selfservice_methods_password_config_max_breaches", skip_serializing_if = "Option::is_none")]
575    pub kratos_selfservice_methods_password_config_max_breaches: Option<i64>,
576    /// Configures the minimum length of passwords.  This governs the \"selfservice.methods.password.config.min_password_length\" setting.
577    #[serde(rename = "kratos_selfservice_methods_password_config_min_password_length", skip_serializing_if = "Option::is_none")]
578    pub kratos_selfservice_methods_password_config_min_password_length: Option<i64>,
579    /// Configures whether Ory Kratos Password Method is enabled  This governs the \"selfservice.methods.password.enabled\" setting.
580    #[serde(rename = "kratos_selfservice_methods_password_enabled", skip_serializing_if = "Option::is_none")]
581    pub kratos_selfservice_methods_password_enabled: Option<bool>,
582    /// Configures whether Ory Kratos Profile Method is enabled  This governs the \"selfservice.methods.profile.enabled\" setting.
583    #[serde(rename = "kratos_selfservice_methods_profile_enabled", skip_serializing_if = "Option::is_none")]
584    pub kratos_selfservice_methods_profile_enabled: Option<bool>,
585    #[serde(rename = "kratos_selfservice_methods_saml_config_providers", skip_serializing_if = "Option::is_none")]
586    pub kratos_selfservice_methods_saml_config_providers: Option<Vec<models::NormalizedProjectRevisionSamlProvider>>,
587    /// Configures whether Ory Kratos SAML Login is enabled  This governs the \"selfservice.methods.saml.enabled\" setting.
588    #[serde(rename = "kratos_selfservice_methods_saml_enabled", skip_serializing_if = "Option::is_none")]
589    pub kratos_selfservice_methods_saml_enabled: Option<bool>,
590    /// Configures Ory Kratos TOTP Issuer  This governs the \"selfservice.methods.totp.config.issuer\" setting.
591    #[serde(rename = "kratos_selfservice_methods_totp_config_issuer", skip_serializing_if = "Option::is_none")]
592    pub kratos_selfservice_methods_totp_config_issuer: Option<String>,
593    /// Configures whether Ory Kratos TOTP Method is enabled  This governs the \"selfservice.methods.totp.enabled\" setting.
594    #[serde(rename = "kratos_selfservice_methods_totp_enabled", skip_serializing_if = "Option::is_none")]
595    pub kratos_selfservice_methods_totp_enabled: Option<bool>,
596    /// Configures whether Ory Kratos Webauthn is used for passwordless flows  This governs the \"selfservice.methods.webauthn.config.passwordless\" setting.
597    #[serde(rename = "kratos_selfservice_methods_webauthn_config_passwordless", skip_serializing_if = "Option::is_none")]
598    pub kratos_selfservice_methods_webauthn_config_passwordless: Option<bool>,
599    /// Configures the Ory Kratos Webauthn RP Display Name  This governs the \"selfservice.methods.webauthn.config.rp.display_name\" setting.
600    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_display_name", skip_serializing_if = "Option::is_none")]
601    pub kratos_selfservice_methods_webauthn_config_rp_display_name: Option<String>,
602    /// Configures the Ory Kratos Webauthn RP Icon  This governs the \"selfservice.methods.webauthn.config.rp.icon\" setting. Deprecated: This value will be ignored due to security considerations.
603    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_icon", skip_serializing_if = "Option::is_none")]
604    pub kratos_selfservice_methods_webauthn_config_rp_icon: Option<String>,
605    /// Configures the Ory Kratos Webauthn RP ID  This governs the \"selfservice.methods.webauthn.config.rp.id\" setting.
606    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_id", skip_serializing_if = "Option::is_none")]
607    pub kratos_selfservice_methods_webauthn_config_rp_id: Option<String>,
608    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_origins", skip_serializing_if = "Option::is_none")]
609    pub kratos_selfservice_methods_webauthn_config_rp_origins: Option<Vec<String>>,
610    /// Configures whether Ory Kratos Webauthn is enabled  This governs the \"selfservice.methods.webauthn.enabled\" setting.
611    #[serde(rename = "kratos_selfservice_methods_webauthn_enabled", skip_serializing_if = "Option::is_none")]
612    pub kratos_selfservice_methods_webauthn_enabled: Option<bool>,
613    /// Configures the Ory Kratos Session Cookie Persistent Attribute  This governs the \"session.cookie.persistent\" setting.
614    #[serde(rename = "kratos_session_cookie_persistent", skip_serializing_if = "Option::is_none")]
615    pub kratos_session_cookie_persistent: Option<bool>,
616    /// Configures the Ory Kratos Session Cookie SameSite Attribute  This governs the \"session.cookie.same_site\" setting.
617    #[serde(rename = "kratos_session_cookie_same_site", skip_serializing_if = "Option::is_none")]
618    pub kratos_session_cookie_same_site: Option<String>,
619    /// Configures the Ory Kratos Session Lifespan  This governs the \"session.lifespan\" setting.
620    #[serde(rename = "kratos_session_lifespan", skip_serializing_if = "Option::is_none")]
621    pub kratos_session_lifespan: Option<String>,
622    /// Configures the Ory Kratos Session Whoami AAL requirement  This governs the \"session.whoami.required_aal\" setting.
623    #[serde(rename = "kratos_session_whoami_required_aal", skip_serializing_if = "Option::is_none")]
624    pub kratos_session_whoami_required_aal: Option<String>,
625    #[serde(rename = "kratos_session_whoami_tokenizer_templates", skip_serializing_if = "Option::is_none")]
626    pub kratos_session_whoami_tokenizer_templates: Option<Vec<models::NormalizedProjectRevisionTokenizerTemplate>>,
627    /// The project's name.
628    #[serde(rename = "name")]
629    pub name: String,
630    /// The Revision's Project ID
631    #[serde(rename = "project_id", skip_serializing_if = "Option::is_none")]
632    pub project_id: Option<String>,
633    #[serde(rename = "project_revision_hooks", skip_serializing_if = "Option::is_none")]
634    pub project_revision_hooks: Option<Vec<models::NormalizedProjectRevisionHook>>,
635    #[serde(rename = "serve_admin_cors_allowed_origins", skip_serializing_if = "Option::is_none")]
636    pub serve_admin_cors_allowed_origins: Option<Vec<String>>,
637    /// Enable CORS headers on all admin APIs  This governs the \"serve.admin.cors.enabled\" setting.
638    #[serde(rename = "serve_admin_cors_enabled", skip_serializing_if = "Option::is_none")]
639    pub serve_admin_cors_enabled: Option<bool>,
640    #[serde(rename = "serve_public_cors_allowed_origins", skip_serializing_if = "Option::is_none")]
641    pub serve_public_cors_allowed_origins: Option<Vec<String>>,
642    /// Enable CORS headers on all public APIs  This governs the \"serve.public.cors.enabled\" setting.
643    #[serde(rename = "serve_public_cors_enabled", skip_serializing_if = "Option::is_none")]
644    pub serve_public_cors_enabled: Option<bool>,
645    /// Whether the project should employ strict security measures. Setting this to true is recommended for going into production.
646    #[serde(rename = "strict_security", skip_serializing_if = "Option::is_none")]
647    pub strict_security: Option<bool>,
648    /// Last Time Project's Revision was Updated
649    #[serde(rename = "updated_at", skip_serializing_if = "Option::is_none")]
650    pub updated_at: Option<String>,
651    #[serde(rename = "workspace_id", skip_serializing_if = "Option::is_none")]
652    pub workspace_id: Option<String>,
653}
654
655impl CreateProjectNormalizedPayload {
656    /// Create project (normalized) request payload
657    pub fn new(environment: EnvironmentEnum, name: String) -> CreateProjectNormalizedPayload {
658        CreateProjectNormalizedPayload {
659            account_experience_favicon_dark: None,
660            account_experience_favicon_light: None,
661            account_experience_logo_dark: None,
662            account_experience_logo_light: None,
663            account_experience_theme_variables_dark: None,
664            account_experience_theme_variables_light: None,
665            created_at: None,
666            disable_account_experience_welcome_screen: None,
667            enable_ax_v2: None,
668            environment,
669            home_region: None,
670            hydra_oauth2_allowed_top_level_claims: None,
671            hydra_oauth2_client_credentials_default_grant_allowed_scope: None,
672            hydra_oauth2_exclude_not_before_claim: None,
673            hydra_oauth2_grant_jwt_iat_optional: None,
674            hydra_oauth2_grant_jwt_jti_optional: None,
675            hydra_oauth2_grant_jwt_max_ttl: None,
676            hydra_oauth2_grant_refresh_token_rotation_grace_period: None,
677            hydra_oauth2_mirror_top_level_claims: None,
678            hydra_oauth2_pkce_enforced: None,
679            hydra_oauth2_pkce_enforced_for_public_clients: None,
680            hydra_oauth2_refresh_token_hook: None,
681            hydra_oauth2_token_hook: None,
682            hydra_oidc_dynamic_client_registration_default_scope: None,
683            hydra_oidc_dynamic_client_registration_enabled: None,
684            hydra_oidc_subject_identifiers_pairwise_salt: None,
685            hydra_oidc_subject_identifiers_supported_types: None,
686            hydra_secrets_cookie: None,
687            hydra_secrets_system: None,
688            hydra_serve_cookies_same_site_legacy_workaround: None,
689            hydra_serve_cookies_same_site_mode: None,
690            hydra_strategies_access_token: None,
691            hydra_strategies_jwt_scope_claim: None,
692            hydra_strategies_scope: None,
693            hydra_ttl_access_token: None,
694            hydra_ttl_auth_code: None,
695            hydra_ttl_id_token: None,
696            hydra_ttl_login_consent_request: None,
697            hydra_ttl_refresh_token: None,
698            hydra_urls_consent: None,
699            hydra_urls_error: None,
700            hydra_urls_login: None,
701            hydra_urls_logout: None,
702            hydra_urls_post_logout_redirect: None,
703            hydra_urls_registration: None,
704            hydra_urls_self_issuer: None,
705            hydra_webfinger_jwks_broadcast_keys: None,
706            hydra_webfinger_oidc_discovery_auth_url: None,
707            hydra_webfinger_oidc_discovery_client_registration_url: None,
708            hydra_webfinger_oidc_discovery_jwks_url: None,
709            hydra_webfinger_oidc_discovery_supported_claims: None,
710            hydra_webfinger_oidc_discovery_supported_scope: None,
711            hydra_webfinger_oidc_discovery_token_url: None,
712            hydra_webfinger_oidc_discovery_userinfo_url: None,
713            id: None,
714            keto_namespace_configuration: None,
715            keto_namespaces: None,
716            kratos_cookies_same_site: None,
717            kratos_courier_channels: None,
718            kratos_courier_delivery_strategy: None,
719            kratos_courier_http_request_config_auth_api_key_in: None,
720            kratos_courier_http_request_config_auth_api_key_name: None,
721            kratos_courier_http_request_config_auth_api_key_value: None,
722            kratos_courier_http_request_config_auth_basic_auth_password: None,
723            kratos_courier_http_request_config_auth_basic_auth_user: None,
724            kratos_courier_http_request_config_auth_type: None,
725            kratos_courier_http_request_config_body: None,
726            kratos_courier_http_request_config_headers: None,
727            kratos_courier_http_request_config_method: None,
728            kratos_courier_http_request_config_url: None,
729            kratos_courier_smtp_connection_uri: None,
730            kratos_courier_smtp_from_address: None,
731            kratos_courier_smtp_from_name: None,
732            kratos_courier_smtp_headers: None,
733            kratos_courier_smtp_local_name: None,
734            kratos_courier_templates_login_code_valid_email_body_html: None,
735            kratos_courier_templates_login_code_valid_email_body_plaintext: None,
736            kratos_courier_templates_login_code_valid_email_subject: None,
737            kratos_courier_templates_login_code_valid_sms_body_plaintext: None,
738            kratos_courier_templates_recovery_code_invalid_email_body_html: None,
739            kratos_courier_templates_recovery_code_invalid_email_body_plaintext: None,
740            kratos_courier_templates_recovery_code_invalid_email_subject: None,
741            kratos_courier_templates_recovery_code_valid_email_body_html: None,
742            kratos_courier_templates_recovery_code_valid_email_body_plaintext: None,
743            kratos_courier_templates_recovery_code_valid_email_subject: None,
744            kratos_courier_templates_recovery_invalid_email_body_html: None,
745            kratos_courier_templates_recovery_invalid_email_body_plaintext: None,
746            kratos_courier_templates_recovery_invalid_email_subject: None,
747            kratos_courier_templates_recovery_valid_email_body_html: None,
748            kratos_courier_templates_recovery_valid_email_body_plaintext: None,
749            kratos_courier_templates_recovery_valid_email_subject: None,
750            kratos_courier_templates_registration_code_valid_email_body_html: None,
751            kratos_courier_templates_registration_code_valid_email_body_plaintext: None,
752            kratos_courier_templates_registration_code_valid_email_subject: None,
753            kratos_courier_templates_registration_code_valid_sms_body_plaintext: None,
754            kratos_courier_templates_verification_code_invalid_email_body_html: None,
755            kratos_courier_templates_verification_code_invalid_email_body_plaintext: None,
756            kratos_courier_templates_verification_code_invalid_email_subject: None,
757            kratos_courier_templates_verification_code_valid_email_body_html: None,
758            kratos_courier_templates_verification_code_valid_email_body_plaintext: None,
759            kratos_courier_templates_verification_code_valid_email_subject: None,
760            kratos_courier_templates_verification_code_valid_sms_body_plaintext: None,
761            kratos_courier_templates_verification_invalid_email_body_html: None,
762            kratos_courier_templates_verification_invalid_email_body_plaintext: None,
763            kratos_courier_templates_verification_invalid_email_subject: None,
764            kratos_courier_templates_verification_valid_email_body_html: None,
765            kratos_courier_templates_verification_valid_email_body_plaintext: None,
766            kratos_courier_templates_verification_valid_email_subject: None,
767            kratos_feature_flags_cacheable_sessions: None,
768            kratos_feature_flags_cacheable_sessions_max_age: None,
769            kratos_feature_flags_faster_session_extend: None,
770            kratos_feature_flags_use_continue_with_transitions: None,
771            kratos_identity_schemas: None,
772            kratos_oauth2_provider_headers: None,
773            kratos_oauth2_provider_override_return_to: None,
774            kratos_oauth2_provider_url: None,
775            kratos_preview_default_read_consistency_level: None,
776            kratos_secrets_cipher: None,
777            kratos_secrets_cookie: None,
778            kratos_secrets_default: None,
779            kratos_selfservice_allowed_return_urls: None,
780            kratos_selfservice_default_browser_return_url: None,
781            kratos_selfservice_flows_error_ui_url: None,
782            kratos_selfservice_flows_login_after_code_default_browser_return_url: None,
783            kratos_selfservice_flows_login_after_default_browser_return_url: None,
784            kratos_selfservice_flows_login_after_lookup_secret_default_browser_return_url: None,
785            kratos_selfservice_flows_login_after_oidc_default_browser_return_url: None,
786            kratos_selfservice_flows_login_after_passkey_default_browser_return_url: None,
787            kratos_selfservice_flows_login_after_password_default_browser_return_url: None,
788            kratos_selfservice_flows_login_after_totp_default_browser_return_url: None,
789            kratos_selfservice_flows_login_after_webauthn_default_browser_return_url: None,
790            kratos_selfservice_flows_login_lifespan: None,
791            kratos_selfservice_flows_login_ui_url: None,
792            kratos_selfservice_flows_logout_after_default_browser_return_url: None,
793            kratos_selfservice_flows_recovery_after_default_browser_return_url: None,
794            kratos_selfservice_flows_recovery_enabled: None,
795            kratos_selfservice_flows_recovery_lifespan: None,
796            kratos_selfservice_flows_recovery_notify_unknown_recipients: None,
797            kratos_selfservice_flows_recovery_ui_url: None,
798            kratos_selfservice_flows_recovery_use: None,
799            kratos_selfservice_flows_registration_after_code_default_browser_return_url: None,
800            kratos_selfservice_flows_registration_after_default_browser_return_url: None,
801            kratos_selfservice_flows_registration_after_oidc_default_browser_return_url: None,
802            kratos_selfservice_flows_registration_after_passkey_default_browser_return_url: None,
803            kratos_selfservice_flows_registration_after_password_default_browser_return_url: None,
804            kratos_selfservice_flows_registration_after_webauthn_default_browser_return_url: None,
805            kratos_selfservice_flows_registration_enable_legacy_one_step: None,
806            kratos_selfservice_flows_registration_enabled: None,
807            kratos_selfservice_flows_registration_lifespan: None,
808            kratos_selfservice_flows_registration_login_hints: None,
809            kratos_selfservice_flows_registration_ui_url: None,
810            kratos_selfservice_flows_settings_after_default_browser_return_url: None,
811            kratos_selfservice_flows_settings_after_lookup_secret_default_browser_return_url: None,
812            kratos_selfservice_flows_settings_after_oidc_default_browser_return_url: None,
813            kratos_selfservice_flows_settings_after_passkey_default_browser_return_url: None,
814            kratos_selfservice_flows_settings_after_password_default_browser_return_url: None,
815            kratos_selfservice_flows_settings_after_profile_default_browser_return_url: None,
816            kratos_selfservice_flows_settings_after_totp_default_browser_return_url: None,
817            kratos_selfservice_flows_settings_after_webauthn_default_browser_return_url: None,
818            kratos_selfservice_flows_settings_lifespan: None,
819            kratos_selfservice_flows_settings_privileged_session_max_age: None,
820            kratos_selfservice_flows_settings_required_aal: None,
821            kratos_selfservice_flows_settings_ui_url: None,
822            kratos_selfservice_flows_verification_after_default_browser_return_url: None,
823            kratos_selfservice_flows_verification_enabled: None,
824            kratos_selfservice_flows_verification_lifespan: None,
825            kratos_selfservice_flows_verification_notify_unknown_recipients: None,
826            kratos_selfservice_flows_verification_ui_url: None,
827            kratos_selfservice_flows_verification_use: None,
828            kratos_selfservice_methods_captcha_config_cf_turnstile_sitekey: None,
829            kratos_selfservice_methods_captcha_enabled: None,
830            kratos_selfservice_methods_code_config_lifespan: None,
831            kratos_selfservice_methods_code_config_missing_credential_fallback_enabled: None,
832            kratos_selfservice_methods_code_enabled: None,
833            kratos_selfservice_methods_code_mfa_enabled: None,
834            kratos_selfservice_methods_code_passwordless_enabled: None,
835            kratos_selfservice_methods_code_passwordless_login_fallback_enabled: None,
836            kratos_selfservice_methods_link_config_base_url: None,
837            kratos_selfservice_methods_link_config_lifespan: None,
838            kratos_selfservice_methods_link_enabled: None,
839            kratos_selfservice_methods_lookup_secret_enabled: None,
840            kratos_selfservice_methods_oidc_config_base_redirect_uri: None,
841            kratos_selfservice_methods_oidc_config_providers: None,
842            kratos_selfservice_methods_oidc_enabled: None,
843            kratos_selfservice_methods_passkey_config_rp_display_name: None,
844            kratos_selfservice_methods_passkey_config_rp_id: None,
845            kratos_selfservice_methods_passkey_config_rp_origins: None,
846            kratos_selfservice_methods_passkey_enabled: None,
847            kratos_selfservice_methods_password_config_haveibeenpwned_enabled: None,
848            kratos_selfservice_methods_password_config_identifier_similarity_check_enabled: None,
849            kratos_selfservice_methods_password_config_ignore_network_errors: None,
850            kratos_selfservice_methods_password_config_max_breaches: None,
851            kratos_selfservice_methods_password_config_min_password_length: None,
852            kratos_selfservice_methods_password_enabled: None,
853            kratos_selfservice_methods_profile_enabled: None,
854            kratos_selfservice_methods_saml_config_providers: None,
855            kratos_selfservice_methods_saml_enabled: None,
856            kratos_selfservice_methods_totp_config_issuer: None,
857            kratos_selfservice_methods_totp_enabled: None,
858            kratos_selfservice_methods_webauthn_config_passwordless: None,
859            kratos_selfservice_methods_webauthn_config_rp_display_name: None,
860            kratos_selfservice_methods_webauthn_config_rp_icon: None,
861            kratos_selfservice_methods_webauthn_config_rp_id: None,
862            kratos_selfservice_methods_webauthn_config_rp_origins: None,
863            kratos_selfservice_methods_webauthn_enabled: None,
864            kratos_session_cookie_persistent: None,
865            kratos_session_cookie_same_site: None,
866            kratos_session_lifespan: None,
867            kratos_session_whoami_required_aal: None,
868            kratos_session_whoami_tokenizer_templates: None,
869            name,
870            project_id: None,
871            project_revision_hooks: None,
872            serve_admin_cors_allowed_origins: None,
873            serve_admin_cors_enabled: None,
874            serve_public_cors_allowed_origins: None,
875            serve_public_cors_enabled: None,
876            strict_security: None,
877            updated_at: None,
878            workspace_id: None,
879        }
880    }
881}
882///  prod Production stage Staging dev Development
883#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
884pub enum EnvironmentEnum {
885    #[serde(rename = "prod")]
886    Prod,
887    #[serde(rename = "stage")]
888    Stage,
889    #[serde(rename = "dev")]
890    Dev,
891}
892
893impl Default for EnvironmentEnum {
894    fn default() -> EnvironmentEnum {
895        Self::Prod
896    }
897}
898///  eu-central EUCentral asia-northeast AsiaNorthEast us-east USEast us-west USWest us US global Global
899#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
900pub enum HomeRegionEnum {
901    #[serde(rename = "eu-central")]
902    EuCentral,
903    #[serde(rename = "asia-northeast")]
904    AsiaNortheast,
905    #[serde(rename = "us-east")]
906    UsEast,
907    #[serde(rename = "us-west")]
908    UsWest,
909    #[serde(rename = "us")]
910    Us,
911    #[serde(rename = "global")]
912    Global,
913}
914
915impl Default for HomeRegionEnum {
916    fn default() -> HomeRegionEnum {
917        Self::EuCentral
918    }
919}
920/// Defines access token type  This governs the \"strategies.access_token\" setting. opaque Oauth2AccessTokenStrategyOpaque jwt Oauth2AccessTokenStrategyJwt
921#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
922pub enum HydraStrategiesAccessTokenEnum {
923    #[serde(rename = "opaque")]
924    Opaque,
925    #[serde(rename = "jwt")]
926    Jwt,
927}
928
929impl Default for HydraStrategiesAccessTokenEnum {
930    fn default() -> HydraStrategiesAccessTokenEnum {
931        Self::Opaque
932    }
933}
934/// Define the claim to use as the scope in the access token.  This governs the \"strategies.jwt.scope_claim\" setting:  list: The scope claim is an array of strings named `scope`: `{ \"scope\": [\"read\", \"write\"] }` string: The scope claim is a space delimited list of strings named `scp`: `{ \"scp\": \"read write\" }` both: The scope claim is both a space delimited list and an array of strings named `scope` and `scp`: `{ \"scope\": [\"read\", \"write\"], \"scp\": \"read write\" }` list OAuth2JWTScopeClaimList string OAuth2JWTScopeClaimString both OAuth2JWTScopeClaimBoth
935#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
936pub enum HydraStrategiesJwtScopeClaimEnum {
937    #[serde(rename = "list")]
938    List,
939    #[serde(rename = "string")]
940    String,
941    #[serde(rename = "both")]
942    Both,
943}
944
945impl Default for HydraStrategiesJwtScopeClaimEnum {
946    fn default() -> HydraStrategiesJwtScopeClaimEnum {
947        Self::List
948    }
949}
950/// Defines how scopes are matched. For more details have a look at https://github.com/ory/fosite#scopes  This governs the \"strategies.scope\" setting. exact Oauth2ScopeStrategyExact wildcard Oauth2ScopeStrategyWildcard
951#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
952pub enum HydraStrategiesScopeEnum {
953    #[serde(rename = "exact")]
954    Exact,
955    #[serde(rename = "wildcard")]
956    Wildcard,
957}
958
959impl Default for HydraStrategiesScopeEnum {
960    fn default() -> HydraStrategiesScopeEnum {
961        Self::Exact
962    }
963}
964/// Configures the Ory Kratos Recovery strategy to use (\"link\" or \"code\")  This governs the \"selfservice.flows.recovery.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
965#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
966pub enum KratosSelfserviceFlowsRecoveryUseEnum {
967    #[serde(rename = "link")]
968    Link,
969    #[serde(rename = "code")]
970    Code,
971}
972
973impl Default for KratosSelfserviceFlowsRecoveryUseEnum {
974    fn default() -> KratosSelfserviceFlowsRecoveryUseEnum {
975        Self::Link
976    }
977}
978/// Configures the Ory Kratos Strategy to use for Verification  This governs the \"selfservice.flows.verification.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
979#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
980pub enum KratosSelfserviceFlowsVerificationUseEnum {
981    #[serde(rename = "link")]
982    Link,
983    #[serde(rename = "code")]
984    Code,
985}
986
987impl Default for KratosSelfserviceFlowsVerificationUseEnum {
988    fn default() -> KratosSelfserviceFlowsVerificationUseEnum {
989        Self::Link
990    }
991}
992