ory_client/models/
normalized_project_revision.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.22.4
7 * Contact: support@ory.sh
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct NormalizedProjectRevision {
16    /// Holds the default locale for the account experience.
17    #[serde(rename = "account_experience_default_locale", skip_serializing_if = "Option::is_none")]
18    pub account_experience_default_locale: Option<String>,
19    /// Holds the URL to the account experience's dark theme favicon (currently unused).
20    #[serde(rename = "account_experience_favicon_dark", skip_serializing_if = "Option::is_none")]
21    pub account_experience_favicon_dark: Option<String>,
22    /// Holds the URL to the account experience's favicon.
23    #[serde(rename = "account_experience_favicon_light", skip_serializing_if = "Option::is_none")]
24    pub account_experience_favicon_light: Option<String>,
25    /// Holds the URL to the account experience's language behavior.  Can be one of: `respect_accept_language`: Respect the `Accept-Language` header. `force_default`: Force the default language.
26    #[serde(rename = "account_experience_locale_behavior", skip_serializing_if = "Option::is_none")]
27    pub account_experience_locale_behavior: Option<String>,
28    /// Holds the URL to the account experience's dark theme logo (currently unused).
29    #[serde(rename = "account_experience_logo_dark", skip_serializing_if = "Option::is_none")]
30    pub account_experience_logo_dark: Option<String>,
31    /// Holds the URL to the account experience's logo.
32    #[serde(rename = "account_experience_logo_light", skip_serializing_if = "Option::is_none")]
33    pub account_experience_logo_light: Option<String>,
34    /// Holds the URL to the account experience's dark theme variables.
35    #[serde(rename = "account_experience_theme_variables_dark", skip_serializing_if = "Option::is_none")]
36    pub account_experience_theme_variables_dark: Option<String>,
37    /// Holds the URL to the account experience's light theme variables.
38    #[serde(rename = "account_experience_theme_variables_light", skip_serializing_if = "Option::is_none")]
39    pub account_experience_theme_variables_light: Option<String>,
40    /// The Project's Revision Creation Date
41    #[serde(rename = "created_at", skip_serializing_if = "Option::is_none")]
42    pub created_at: Option<String>,
43    /// Whether to disable the account experience welcome screen, which is hosted under `/ui/welcome`.
44    #[serde(rename = "disable_account_experience_welcome_screen", skip_serializing_if = "Option::is_none")]
45    pub disable_account_experience_welcome_screen: Option<bool>,
46    /// Whether the new account experience is enabled and reachable.
47    #[serde(rename = "enable_ax_v2", skip_serializing_if = "Option::is_none")]
48    pub enable_ax_v2: Option<bool>,
49    #[serde(rename = "hydra_oauth2_allowed_top_level_claims", skip_serializing_if = "Option::is_none")]
50    pub hydra_oauth2_allowed_top_level_claims: Option<Vec<String>>,
51    /// 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.
52    #[serde(rename = "hydra_oauth2_client_credentials_default_grant_allowed_scope", skip_serializing_if = "Option::is_none")]
53    pub hydra_oauth2_client_credentials_default_grant_allowed_scope: Option<bool>,
54    /// 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.
55    #[serde(rename = "hydra_oauth2_exclude_not_before_claim", skip_serializing_if = "Option::is_none")]
56    pub hydra_oauth2_exclude_not_before_claim: Option<bool>,
57    /// 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.
58    #[serde(rename = "hydra_oauth2_grant_jwt_iat_optional", skip_serializing_if = "Option::is_none")]
59    pub hydra_oauth2_grant_jwt_iat_optional: Option<bool>,
60    /// 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.
61    #[serde(rename = "hydra_oauth2_grant_jwt_jti_optional", skip_serializing_if = "Option::is_none")]
62    pub hydra_oauth2_grant_jwt_jti_optional: Option<bool>,
63    /// 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.
64    #[serde(rename = "hydra_oauth2_grant_jwt_max_ttl", skip_serializing_if = "Option::is_none")]
65    pub hydra_oauth2_grant_jwt_max_ttl: Option<String>,
66    /// 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.
67    #[serde(rename = "hydra_oauth2_grant_refresh_token_rotation_grace_period", skip_serializing_if = "Option::is_none")]
68    pub hydra_oauth2_grant_refresh_token_rotation_grace_period: Option<String>,
69    /// Set to false if you don't want to mirror custom claims under 'ext'.  This governs the \"oauth2.mirror_top_level_claims\" setting.
70    #[serde(rename = "hydra_oauth2_mirror_top_level_claims", skip_serializing_if = "Option::is_none")]
71    pub hydra_oauth2_mirror_top_level_claims: Option<bool>,
72    /// Configures whether PKCE should be enforced for all OAuth2 Clients.  This governs the \"oauth2.pkce.enforced\" setting.
73    #[serde(rename = "hydra_oauth2_pkce_enforced", skip_serializing_if = "Option::is_none")]
74    pub hydra_oauth2_pkce_enforced: Option<bool>,
75    /// 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.
76    #[serde(rename = "hydra_oauth2_pkce_enforced_for_public_clients", skip_serializing_if = "Option::is_none")]
77    pub hydra_oauth2_pkce_enforced_for_public_clients: Option<bool>,
78    /// 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.
79    #[serde(rename = "hydra_oauth2_refresh_token_hook", skip_serializing_if = "Option::is_none")]
80    pub hydra_oauth2_refresh_token_hook: Option<String>,
81    /// 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.
82    #[serde(rename = "hydra_oauth2_token_hook", skip_serializing_if = "Option::is_none")]
83    pub hydra_oauth2_token_hook: Option<String>,
84    #[serde(rename = "hydra_oidc_dynamic_client_registration_default_scope", skip_serializing_if = "Option::is_none")]
85    pub hydra_oidc_dynamic_client_registration_default_scope: Option<Vec<String>>,
86    /// Configures OpenID Connect Dynamic Client Registration.  This governs the \"oidc.dynamic_client_registration.enabled\" setting.
87    #[serde(rename = "hydra_oidc_dynamic_client_registration_enabled", skip_serializing_if = "Option::is_none")]
88    pub hydra_oidc_dynamic_client_registration_enabled: Option<bool>,
89    /// Configures OpenID Connect Discovery and overwrites the pairwise algorithm  This governs the \"oidc.subject_identifiers.pairwise_salt\" setting.
90    #[serde(rename = "hydra_oidc_subject_identifiers_pairwise_salt", skip_serializing_if = "Option::is_none")]
91    pub hydra_oidc_subject_identifiers_pairwise_salt: Option<String>,
92    #[serde(rename = "hydra_oidc_subject_identifiers_supported_types", skip_serializing_if = "Option::is_none")]
93    pub hydra_oidc_subject_identifiers_supported_types: Option<Vec<String>>,
94    #[serde(rename = "hydra_secrets_cookie", skip_serializing_if = "Option::is_none")]
95    pub hydra_secrets_cookie: Option<Vec<String>>,
96    #[serde(rename = "hydra_secrets_pagination", skip_serializing_if = "Option::is_none")]
97    pub hydra_secrets_pagination: Option<Vec<String>>,
98    #[serde(rename = "hydra_secrets_system", skip_serializing_if = "Option::is_none")]
99    pub hydra_secrets_system: Option<Vec<String>>,
100    /// Configures the Ory Hydra Cookie Same Site Legacy Workaround  This governs the \"serve.cookies.same_site_legacy_workaround\" setting.
101    #[serde(rename = "hydra_serve_cookies_same_site_legacy_workaround", skip_serializing_if = "Option::is_none")]
102    pub hydra_serve_cookies_same_site_legacy_workaround: Option<bool>,
103    /// Configures the Ory Hydra Cookie Same Site Mode  This governs the \"serve.cookies.same_site_mode\" setting.
104    #[serde(rename = "hydra_serve_cookies_same_site_mode", skip_serializing_if = "Option::is_none")]
105    pub hydra_serve_cookies_same_site_mode: Option<String>,
106    /// Defines access token type  This governs the \"strategies.access_token\" setting. opaque Oauth2AccessTokenStrategyOpaque jwt Oauth2AccessTokenStrategyJwt
107    #[serde(rename = "hydra_strategies_access_token", skip_serializing_if = "Option::is_none")]
108    pub hydra_strategies_access_token: Option<HydraStrategiesAccessTokenEnum>,
109    /// 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
110    #[serde(rename = "hydra_strategies_jwt_scope_claim", skip_serializing_if = "Option::is_none")]
111    pub hydra_strategies_jwt_scope_claim: Option<HydraStrategiesJwtScopeClaimEnum>,
112    /// 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
113    #[serde(rename = "hydra_strategies_scope", skip_serializing_if = "Option::is_none")]
114    pub hydra_strategies_scope: Option<HydraStrategiesScopeEnum>,
115    /// This governs the \"ttl.access_token\" setting.
116    #[serde(rename = "hydra_ttl_access_token", skip_serializing_if = "Option::is_none")]
117    pub hydra_ttl_access_token: Option<String>,
118    /// 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.
119    #[serde(rename = "hydra_ttl_auth_code", skip_serializing_if = "Option::is_none")]
120    pub hydra_ttl_auth_code: Option<String>,
121    /// This governs the \"ttl.id_token\" setting.
122    #[serde(rename = "hydra_ttl_id_token", skip_serializing_if = "Option::is_none")]
123    pub hydra_ttl_id_token: Option<String>,
124    /// Configures how long a user login and consent flow may take.  This governs the \"ttl.login_consent_request\" setting.
125    #[serde(rename = "hydra_ttl_login_consent_request", skip_serializing_if = "Option::is_none")]
126    pub hydra_ttl_login_consent_request: Option<String>,
127    /// 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.
128    #[serde(rename = "hydra_ttl_refresh_token", skip_serializing_if = "Option::is_none")]
129    pub hydra_ttl_refresh_token: Option<String>,
130    /// 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.
131    #[serde(rename = "hydra_urls_consent", skip_serializing_if = "Option::is_none")]
132    pub hydra_urls_consent: Option<String>,
133    /// 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.
134    #[serde(rename = "hydra_urls_error", skip_serializing_if = "Option::is_none")]
135    pub hydra_urls_error: Option<String>,
136    /// 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.
137    #[serde(rename = "hydra_urls_login", skip_serializing_if = "Option::is_none")]
138    pub hydra_urls_login: Option<String>,
139    /// Sets the logout endpoint.  Defaults to the Ory Account Experience if left empty.  This governs the \"urls.logout\" setting.
140    #[serde(rename = "hydra_urls_logout", skip_serializing_if = "Option::is_none")]
141    pub hydra_urls_logout: Option<String>,
142    /// 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.
143    #[serde(rename = "hydra_urls_post_logout_redirect", skip_serializing_if = "Option::is_none")]
144    pub hydra_urls_post_logout_redirect: Option<String>,
145    /// 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.
146    #[serde(rename = "hydra_urls_registration", skip_serializing_if = "Option::is_none")]
147    pub hydra_urls_registration: Option<String>,
148    /// 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.
149    #[serde(rename = "hydra_urls_self_issuer", skip_serializing_if = "Option::is_none")]
150    pub hydra_urls_self_issuer: Option<String>,
151    #[serde(rename = "hydra_webfinger_jwks_broadcast_keys", skip_serializing_if = "Option::is_none")]
152    pub hydra_webfinger_jwks_broadcast_keys: Option<Vec<String>>,
153    /// Configures OpenID Connect Discovery and overwrites the OAuth2 Authorization URL.  This governs the \"webfinger.oidc.discovery.auth_url\" setting.
154    #[serde(rename = "hydra_webfinger_oidc_discovery_auth_url", skip_serializing_if = "Option::is_none")]
155    pub hydra_webfinger_oidc_discovery_auth_url: Option<String>,
156    /// Configures OpenID Connect Discovery and overwrites the OpenID Connect Dynamic Client Registration Endpoint.  This governs the \"webfinger.oidc.discovery.client_registration_url\" setting.
157    #[serde(rename = "hydra_webfinger_oidc_discovery_client_registration_url", skip_serializing_if = "Option::is_none")]
158    pub hydra_webfinger_oidc_discovery_client_registration_url: Option<String>,
159    /// Configures OpenID Connect Discovery and overwrites the JWKS URL.  This governs the \"webfinger.oidc.discovery.jwks_url\" setting.
160    #[serde(rename = "hydra_webfinger_oidc_discovery_jwks_url", skip_serializing_if = "Option::is_none")]
161    pub hydra_webfinger_oidc_discovery_jwks_url: Option<String>,
162    #[serde(rename = "hydra_webfinger_oidc_discovery_supported_claims", skip_serializing_if = "Option::is_none")]
163    pub hydra_webfinger_oidc_discovery_supported_claims: Option<Vec<String>>,
164    #[serde(rename = "hydra_webfinger_oidc_discovery_supported_scope", skip_serializing_if = "Option::is_none")]
165    pub hydra_webfinger_oidc_discovery_supported_scope: Option<Vec<String>>,
166    /// Configures OpenID Connect Discovery and overwrites the OAuth2 Token URL.  This governs the \"webfinger.oidc.discovery.token_url\" setting.
167    #[serde(rename = "hydra_webfinger_oidc_discovery_token_url", skip_serializing_if = "Option::is_none")]
168    pub hydra_webfinger_oidc_discovery_token_url: Option<String>,
169    /// 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.
170    #[serde(rename = "hydra_webfinger_oidc_discovery_userinfo_url", skip_serializing_if = "Option::is_none")]
171    pub hydra_webfinger_oidc_discovery_userinfo_url: Option<String>,
172    /// The revision ID.
173    #[serde(rename = "id", skip_serializing_if = "Option::is_none")]
174    pub id: Option<String>,
175    /// The Revisions' Keto Namespace Configuration  The string is a URL pointing to an OPL file with the configuration.
176    #[serde(rename = "keto_namespace_configuration", skip_serializing_if = "Option::is_none")]
177    pub keto_namespace_configuration: Option<String>,
178    #[serde(rename = "keto_namespaces", skip_serializing_if = "Option::is_none")]
179    pub keto_namespaces: Option<Vec<models::KetoNamespace>>,
180    #[serde(rename = "keto_secrets_pagination", skip_serializing_if = "Option::is_none")]
181    pub keto_secrets_pagination: Option<Vec<String>>,
182    /// Configures the Ory Kratos Cookie SameSite Attribute  This governs the \"cookies.same_site\" setting.
183    #[serde(rename = "kratos_cookies_same_site", skip_serializing_if = "Option::is_none")]
184    pub kratos_cookies_same_site: Option<String>,
185    #[serde(rename = "kratos_courier_channels", skip_serializing_if = "Option::is_none")]
186    pub kratos_courier_channels: Option<Vec<models::NormalizedProjectRevisionCourierChannel>>,
187    /// 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
188    #[serde(rename = "kratos_courier_delivery_strategy", skip_serializing_if = "Option::is_none")]
189    pub kratos_courier_delivery_strategy: Option<String>,
190    /// 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
191    #[serde(rename = "kratos_courier_http_request_config_auth_api_key_in", skip_serializing_if = "Option::is_none")]
192    pub kratos_courier_http_request_config_auth_api_key_in: Option<String>,
193    /// 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
194    #[serde(rename = "kratos_courier_http_request_config_auth_api_key_name", skip_serializing_if = "Option::is_none")]
195    pub kratos_courier_http_request_config_auth_api_key_name: Option<String>,
196    /// 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
197    #[serde(rename = "kratos_courier_http_request_config_auth_api_key_value", skip_serializing_if = "Option::is_none")]
198    pub kratos_courier_http_request_config_auth_api_key_value: Option<String>,
199    /// The password to use for basic auth in the HTTP email sending service's authentication  This governs the \"courier.http.auth.config.password\" setting
200    #[serde(rename = "kratos_courier_http_request_config_auth_basic_auth_password", skip_serializing_if = "Option::is_none")]
201    pub kratos_courier_http_request_config_auth_basic_auth_password: Option<String>,
202    /// The user to use for basic auth in the HTTP email sending service's authentication  This governs the \"courier.http.auth.config.user\" setting
203    #[serde(rename = "kratos_courier_http_request_config_auth_basic_auth_user", skip_serializing_if = "Option::is_none")]
204    pub kratos_courier_http_request_config_auth_basic_auth_user: Option<String>,
205    /// 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
206    #[serde(rename = "kratos_courier_http_request_config_auth_type", skip_serializing_if = "Option::is_none")]
207    pub kratos_courier_http_request_config_auth_type: Option<String>,
208    /// 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
209    #[serde(rename = "kratos_courier_http_request_config_body", skip_serializing_if = "Option::is_none")]
210    pub kratos_courier_http_request_config_body: Option<String>,
211    /// NullJSONRawMessage represents a json.RawMessage that works well with JSON, SQL, and Swagger and is NULLable-
212    #[serde(rename = "kratos_courier_http_request_config_headers", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
213    pub kratos_courier_http_request_config_headers: Option<Option<serde_json::Value>>,
214    /// The http METHOD to use when calling the remote HTTP email sending service
215    #[serde(rename = "kratos_courier_http_request_config_method", skip_serializing_if = "Option::is_none")]
216    pub kratos_courier_http_request_config_method: Option<String>,
217    /// The URL of the remote HTTP email sending service  This governs the \"courier.http.url\" setting
218    #[serde(rename = "kratos_courier_http_request_config_url", skip_serializing_if = "Option::is_none")]
219    pub kratos_courier_http_request_config_url: Option<String>,
220    /// Configures the Ory Kratos SMTP Connection URI  This governs the \"courier.smtp.connection_uri\" setting.
221    #[serde(rename = "kratos_courier_smtp_connection_uri", skip_serializing_if = "Option::is_none")]
222    pub kratos_courier_smtp_connection_uri: Option<String>,
223    /// Configures the Ory Kratos SMTP From Address  This governs the \"courier.smtp.from_address\" setting.
224    #[serde(rename = "kratos_courier_smtp_from_address", skip_serializing_if = "Option::is_none")]
225    pub kratos_courier_smtp_from_address: Option<String>,
226    /// Configures the Ory Kratos SMTP From Name  This governs the \"courier.smtp.from_name\" setting.
227    #[serde(rename = "kratos_courier_smtp_from_name", skip_serializing_if = "Option::is_none")]
228    pub kratos_courier_smtp_from_name: Option<String>,
229    /// NullJSONRawMessage represents a json.RawMessage that works well with JSON, SQL, and Swagger and is NULLable-
230    #[serde(rename = "kratos_courier_smtp_headers", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
231    pub kratos_courier_smtp_headers: Option<Option<serde_json::Value>>,
232    /// Configures the local_name to use in SMTP connections  This governs the \"courier.smtp.local_name\" setting.
233    #[serde(rename = "kratos_courier_smtp_local_name", skip_serializing_if = "Option::is_none")]
234    pub kratos_courier_smtp_local_name: Option<String>,
235    /// 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.
236    #[serde(rename = "kratos_courier_templates_login_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
237    pub kratos_courier_templates_login_code_valid_email_body_html: Option<String>,
238    /// 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.
239    #[serde(rename = "kratos_courier_templates_login_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
240    pub kratos_courier_templates_login_code_valid_email_body_plaintext: Option<String>,
241    /// Configures the Ory Kratos Valid Login via Code Email Subject Template  This governs the \"courier.smtp.templates.login_code.valid.email.subject\" setting.
242    #[serde(rename = "kratos_courier_templates_login_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
243    pub kratos_courier_templates_login_code_valid_email_subject: Option<String>,
244    /// Configures the Ory Kratos Valid Login via Code SMS plain text body  This governs the \"courier.smtp.templates.login_code.valid.sms.plaintext\" setting.
245    #[serde(rename = "kratos_courier_templates_login_code_valid_sms_body_plaintext", skip_serializing_if = "Option::is_none")]
246    pub kratos_courier_templates_login_code_valid_sms_body_plaintext: Option<String>,
247    /// 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.
248    #[serde(rename = "kratos_courier_templates_recovery_code_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
249    pub kratos_courier_templates_recovery_code_invalid_email_body_html: Option<String>,
250    /// 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.
251    #[serde(rename = "kratos_courier_templates_recovery_code_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
252    pub kratos_courier_templates_recovery_code_invalid_email_body_plaintext: Option<String>,
253    /// Configures the Ory Kratos Invalid Recovery via Code Email Subject Template  This governs the \"courier.smtp.templates.recovery_code.invalid.email.body.html\" setting.
254    #[serde(rename = "kratos_courier_templates_recovery_code_invalid_email_subject", skip_serializing_if = "Option::is_none")]
255    pub kratos_courier_templates_recovery_code_invalid_email_subject: Option<String>,
256    /// 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.
257    #[serde(rename = "kratos_courier_templates_recovery_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
258    pub kratos_courier_templates_recovery_code_valid_email_body_html: Option<String>,
259    /// 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.
260    #[serde(rename = "kratos_courier_templates_recovery_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
261    pub kratos_courier_templates_recovery_code_valid_email_body_plaintext: Option<String>,
262    /// Configures the Ory Kratos Valid Recovery via Code Email Subject Template  This governs the \"courier.smtp.templates.recovery_code.valid.email.subject\" setting.
263    #[serde(rename = "kratos_courier_templates_recovery_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
264    pub kratos_courier_templates_recovery_code_valid_email_subject: Option<String>,
265    /// Configures the Ory Kratos Invalid Recovery Email Body HTML Template  This governs the \"courier.smtp.templates.recovery.invalid.email.body.html\" setting.
266    #[serde(rename = "kratos_courier_templates_recovery_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
267    pub kratos_courier_templates_recovery_invalid_email_body_html: Option<String>,
268    /// Configures the Ory Kratos Invalid Recovery Email Body Plaintext Template  This governs the \"courier.smtp.templates.recovery.invalid.email.body.plaintext\" setting.
269    #[serde(rename = "kratos_courier_templates_recovery_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
270    pub kratos_courier_templates_recovery_invalid_email_body_plaintext: Option<String>,
271    /// Configures the Ory Kratos Invalid Recovery Email Subject Template  This governs the \"courier.smtp.templates.recovery.invalid.email.body.html\" setting.
272    #[serde(rename = "kratos_courier_templates_recovery_invalid_email_subject", skip_serializing_if = "Option::is_none")]
273    pub kratos_courier_templates_recovery_invalid_email_subject: Option<String>,
274    /// Configures the Ory Kratos Valid Recovery Email Body HTML Template  This governs the \"courier.smtp.templates.recovery.valid.email.body.html\" setting.
275    #[serde(rename = "kratos_courier_templates_recovery_valid_email_body_html", skip_serializing_if = "Option::is_none")]
276    pub kratos_courier_templates_recovery_valid_email_body_html: Option<String>,
277    /// Configures the Ory Kratos Valid Recovery Email Body Plaintext Template  This governs the \"courier.smtp.templates.recovery.valid.email.body.plaintext\" setting.
278    #[serde(rename = "kratos_courier_templates_recovery_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
279    pub kratos_courier_templates_recovery_valid_email_body_plaintext: Option<String>,
280    /// Configures the Ory Kratos Valid Recovery Email Subject Template  This governs the \"courier.smtp.templates.recovery.valid.email.subject\" setting.
281    #[serde(rename = "kratos_courier_templates_recovery_valid_email_subject", skip_serializing_if = "Option::is_none")]
282    pub kratos_courier_templates_recovery_valid_email_subject: Option<String>,
283    /// 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.
284    #[serde(rename = "kratos_courier_templates_registration_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
285    pub kratos_courier_templates_registration_code_valid_email_body_html: Option<String>,
286    /// 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.
287    #[serde(rename = "kratos_courier_templates_registration_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
288    pub kratos_courier_templates_registration_code_valid_email_body_plaintext: Option<String>,
289    /// Configures the Ory Kratos Valid Registration via Code Email Subject Template  This governs the \"courier.smtp.templates.registration_code.valid.email.subject\" setting.
290    #[serde(rename = "kratos_courier_templates_registration_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
291    pub kratos_courier_templates_registration_code_valid_email_subject: Option<String>,
292    /// Configures the Ory Kratos Valid Registration via Code Email Subject Template  This governs the \"courier.smtp.templates.registration_code.valid.sms.body.plaintext\" setting.
293    #[serde(rename = "kratos_courier_templates_registration_code_valid_sms_body_plaintext", skip_serializing_if = "Option::is_none")]
294    pub kratos_courier_templates_registration_code_valid_sms_body_plaintext: Option<String>,
295    /// 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.
296    #[serde(rename = "kratos_courier_templates_verification_code_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
297    pub kratos_courier_templates_verification_code_invalid_email_body_html: Option<String>,
298    /// 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.
299    #[serde(rename = "kratos_courier_templates_verification_code_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
300    pub kratos_courier_templates_verification_code_invalid_email_body_plaintext: Option<String>,
301    /// Configures the Ory Kratos Invalid Verification via Code Email Subject Template  This governs the \"courier.smtp.templates.verification_code.invalid.email.subject\" setting.
302    #[serde(rename = "kratos_courier_templates_verification_code_invalid_email_subject", skip_serializing_if = "Option::is_none")]
303    pub kratos_courier_templates_verification_code_invalid_email_subject: Option<String>,
304    /// 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.
305    #[serde(rename = "kratos_courier_templates_verification_code_valid_email_body_html", skip_serializing_if = "Option::is_none")]
306    pub kratos_courier_templates_verification_code_valid_email_body_html: Option<String>,
307    /// 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.
308    #[serde(rename = "kratos_courier_templates_verification_code_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
309    pub kratos_courier_templates_verification_code_valid_email_body_plaintext: Option<String>,
310    /// Configures the Ory Kratos Valid Verification via Code Email Subject Template  This governs the \"courier.smtp.templates.verification_code.valid.email.subject\" setting.
311    #[serde(rename = "kratos_courier_templates_verification_code_valid_email_subject", skip_serializing_if = "Option::is_none")]
312    pub kratos_courier_templates_verification_code_valid_email_subject: Option<String>,
313    /// Configures the Ory Kratos Valid Verification via Code SMS Body Plaintext  This governs the \"courier.smtp.templates.verification_code.valid.sms.body.plaintext\" setting.
314    #[serde(rename = "kratos_courier_templates_verification_code_valid_sms_body_plaintext", skip_serializing_if = "Option::is_none")]
315    pub kratos_courier_templates_verification_code_valid_sms_body_plaintext: Option<String>,
316    /// Configures the Ory Kratos Invalid Verification Email Body HTML Template  This governs the \"courier.smtp.templates.verification.invalid.email.body.html\" setting.
317    #[serde(rename = "kratos_courier_templates_verification_invalid_email_body_html", skip_serializing_if = "Option::is_none")]
318    pub kratos_courier_templates_verification_invalid_email_body_html: Option<String>,
319    /// Configures the Ory Kratos Invalid Verification Email Body Plaintext Template  This governs the \"courier.smtp.templates.verification.invalid.email.body.plaintext\" setting.
320    #[serde(rename = "kratos_courier_templates_verification_invalid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
321    pub kratos_courier_templates_verification_invalid_email_body_plaintext: Option<String>,
322    /// Configures the Ory Kratos Invalid Verification Email Subject Template  This governs the \"courier.smtp.templates.verification.invalid.email.subject\" setting.
323    #[serde(rename = "kratos_courier_templates_verification_invalid_email_subject", skip_serializing_if = "Option::is_none")]
324    pub kratos_courier_templates_verification_invalid_email_subject: Option<String>,
325    /// Configures the Ory Kratos Valid Verification Email Body HTML Template  This governs the \"courier.smtp.templates.verification.valid.email.body.html\" setting.
326    #[serde(rename = "kratos_courier_templates_verification_valid_email_body_html", skip_serializing_if = "Option::is_none")]
327    pub kratos_courier_templates_verification_valid_email_body_html: Option<String>,
328    /// Configures the Ory Kratos Valid Verification Email Body Plaintext Template  This governs the \"courier.smtp.templates.verification.valid.email.body.plaintext\" setting.
329    #[serde(rename = "kratos_courier_templates_verification_valid_email_body_plaintext", skip_serializing_if = "Option::is_none")]
330    pub kratos_courier_templates_verification_valid_email_body_plaintext: Option<String>,
331    /// Configures the Ory Kratos Valid Verification Email Subject Template  This governs the \"courier.smtp.templates.verification.valid.email.subject\" setting.
332    #[serde(rename = "kratos_courier_templates_verification_valid_email_subject", skip_serializing_if = "Option::is_none")]
333    pub kratos_courier_templates_verification_valid_email_subject: Option<String>,
334    /// Configures the Ory Kratos Session caching feature flag  This governs the \"feature_flags.cacheable_sessions\" setting.
335    #[serde(rename = "kratos_feature_flags_cacheable_sessions", skip_serializing_if = "Option::is_none")]
336    pub kratos_feature_flags_cacheable_sessions: Option<bool>,
337    /// Configures the Ory Kratos Session caching max-age feature flag  This governs the \"feature_flags.cacheable_sessions_max_age\" setting.
338    #[serde(rename = "kratos_feature_flags_cacheable_sessions_max_age", skip_serializing_if = "Option::is_none")]
339    pub kratos_feature_flags_cacheable_sessions_max_age: Option<String>,
340    /// This governs the \"feature_flags.choose_recovery_address\" setting.
341    #[serde(rename = "kratos_feature_flags_choose_recovery_address", skip_serializing_if = "Option::is_none")]
342    pub kratos_feature_flags_choose_recovery_address: Option<bool>,
343    /// 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.
344    #[serde(rename = "kratos_feature_flags_faster_session_extend", skip_serializing_if = "Option::is_none")]
345    pub kratos_feature_flags_faster_session_extend: Option<bool>,
346    /// Always include show_verification_ui in continue_with  If true, restores the legacy behavior of always including `show_verification_ui` in the registration flow's `continue_with` when verification is enabled. If set to false, `show_verification_ui` is only set in `continue_with` if the `show_verification_ui` hook is used. This flag will be removed in the future.  This governs the \"feature_flags.legacy_continue_with_verification_ui\" setting.
347    #[serde(rename = "kratos_feature_flags_legacy_continue_with_verification_ui", skip_serializing_if = "Option::is_none")]
348    pub kratos_feature_flags_legacy_continue_with_verification_ui: Option<bool>,
349    /// Controls whether the UI nodes in an OIDC registration flow have group \"oidc\" in case required fields are not returned by the OIDC provider.  If set to true, the UI nodes will have group \"oidc\" and the flow will be considered successful if the user completes the flow. This is the legacy behavior.  This governs the \"feature_flags.legacy_oidc_registration_node_group\" setting.
350    #[serde(rename = "kratos_feature_flags_legacy_oidc_registration_node_group", skip_serializing_if = "Option::is_none")]
351    pub kratos_feature_flags_legacy_oidc_registration_node_group: Option<bool>,
352    /// Return a form error if the login identifier is not verified  If true, the login flow will return a form error if the login identifier is not verified, which restores legacy behavior. If this value is false, the `continue_with` array will contain a `show_verification_ui` hook instead.  This flag is deprecated and will be removed in the future.  This governs the \"feature_flags.legacy_require_verified_login_error\" setting.
353    #[serde(rename = "kratos_feature_flags_legacy_require_verified_login_error", skip_serializing_if = "Option::is_none")]
354    pub kratos_feature_flags_legacy_require_verified_login_error: Option<bool>,
355    /// Configures the group for the password method in the registration flow.  If true, it sets the password method group value to \"password\" if it is the only method available. This is the legacy behavior. If false is, it sets the password method group value to \"default\".
356    #[serde(rename = "kratos_feature_flags_password_profile_registration_node_group", skip_serializing_if = "Option::is_none")]
357    pub kratos_feature_flags_password_profile_registration_node_group: Option<bool>,
358    /// Configures the Ory Kratos Session use_continue_with_transitions flag  This governs the \"feature_flags.use_continue_with_transitions\" setting.
359    #[serde(rename = "kratos_feature_flags_use_continue_with_transitions", skip_serializing_if = "Option::is_none")]
360    pub kratos_feature_flags_use_continue_with_transitions: Option<bool>,
361    #[serde(rename = "kratos_identity_schemas", skip_serializing_if = "Option::is_none")]
362    pub kratos_identity_schemas: Option<Vec<models::NormalizedProjectRevisionIdentitySchema>>,
363    /// NullJSONRawMessage represents a json.RawMessage that works well with JSON, SQL, and Swagger and is NULLable-
364    #[serde(rename = "kratos_oauth2_provider_headers", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
365    pub kratos_oauth2_provider_headers: Option<Option<serde_json::Value>>,
366    /// 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.
367    #[serde(rename = "kratos_oauth2_provider_override_return_to", skip_serializing_if = "Option::is_none")]
368    pub kratos_oauth2_provider_override_return_to: Option<bool>,
369    /// The Revisions' OAuth2 Provider Integration URL  This governs the \"oauth2_provider.url\" setting.
370    #[serde(rename = "kratos_oauth2_provider_url", skip_serializing_if = "Option::is_none")]
371    pub kratos_oauth2_provider_url: Option<String>,
372    /// 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.
373    #[serde(rename = "kratos_preview_default_read_consistency_level", skip_serializing_if = "Option::is_none")]
374    pub kratos_preview_default_read_consistency_level: Option<String>,
375    #[serde(rename = "kratos_secrets_cipher", skip_serializing_if = "Option::is_none")]
376    pub kratos_secrets_cipher: Option<Vec<String>>,
377    #[serde(rename = "kratos_secrets_cookie", skip_serializing_if = "Option::is_none")]
378    pub kratos_secrets_cookie: Option<Vec<String>>,
379    #[serde(rename = "kratos_secrets_default", skip_serializing_if = "Option::is_none")]
380    pub kratos_secrets_default: Option<Vec<String>>,
381    #[serde(rename = "kratos_secrets_pagination", skip_serializing_if = "Option::is_none")]
382    pub kratos_secrets_pagination: Option<Vec<String>>,
383    /// Configures if account enumeration should be mitigated when using identifier first login.
384    #[serde(rename = "kratos_security_account_enumeration_mitigate", skip_serializing_if = "Option::is_none")]
385    pub kratos_security_account_enumeration_mitigate: Option<bool>,
386    #[serde(rename = "kratos_selfservice_allowed_return_urls", skip_serializing_if = "Option::is_none")]
387    pub kratos_selfservice_allowed_return_urls: Option<Vec<String>>,
388    /// Configures the Ory Kratos Default Return URL  This governs the \"selfservice.allowed_return_urls\" setting.
389    #[serde(rename = "kratos_selfservice_default_browser_return_url", skip_serializing_if = "Option::is_none")]
390    pub kratos_selfservice_default_browser_return_url: Option<String>,
391    /// Configures the Ory Kratos Error UI URL  This governs the \"selfservice.flows.error.ui_url\" setting.
392    #[serde(rename = "kratos_selfservice_flows_error_ui_url", skip_serializing_if = "Option::is_none")]
393    pub kratos_selfservice_flows_error_ui_url: Option<String>,
394    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.code.after.password.default_browser_return_url\" setting.
395    #[serde(rename = "kratos_selfservice_flows_login_after_code_default_browser_return_url", skip_serializing_if = "Option::is_none")]
396    pub kratos_selfservice_flows_login_after_code_default_browser_return_url: Option<String>,
397    /// Configures the Ory Kratos Login Default Return URL  This governs the \"selfservice.flows.login.after.default_browser_return_url\" setting.
398    #[serde(rename = "kratos_selfservice_flows_login_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
399    pub kratos_selfservice_flows_login_after_default_browser_return_url: Option<String>,
400    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.lookup_secret.after.password.default_browser_return_url\" setting.
401    #[serde(rename = "kratos_selfservice_flows_login_after_lookup_secret_default_browser_return_url", skip_serializing_if = "Option::is_none")]
402    pub kratos_selfservice_flows_login_after_lookup_secret_default_browser_return_url: Option<String>,
403    /// Configures the Ory Kratos Login After OIDC Default Return URL  This governs the \"selfservice.flows.login.after.oidc.default_browser_return_url\" setting.
404    #[serde(rename = "kratos_selfservice_flows_login_after_oidc_default_browser_return_url", skip_serializing_if = "Option::is_none")]
405    pub kratos_selfservice_flows_login_after_oidc_default_browser_return_url: Option<String>,
406    /// Configures the Ory Kratos Login After Passkey Default Return URL  This governs the \"selfservice.flows.login.after.passkey.default_browser_return_url\" setting.
407    #[serde(rename = "kratos_selfservice_flows_login_after_passkey_default_browser_return_url", skip_serializing_if = "Option::is_none")]
408    pub kratos_selfservice_flows_login_after_passkey_default_browser_return_url: Option<String>,
409    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.login.after.password.default_browser_return_url\" setting.
410    #[serde(rename = "kratos_selfservice_flows_login_after_password_default_browser_return_url", skip_serializing_if = "Option::is_none")]
411    pub kratos_selfservice_flows_login_after_password_default_browser_return_url: Option<String>,
412    /// Configures the Ory Kratos Login After Password Default Return URL  This governs the \"selfservice.flows.totp.after.password.default_browser_return_url\" setting.
413    #[serde(rename = "kratos_selfservice_flows_login_after_totp_default_browser_return_url", skip_serializing_if = "Option::is_none")]
414    pub kratos_selfservice_flows_login_after_totp_default_browser_return_url: Option<String>,
415    /// Configures the Ory Kratos Login After WebAuthn Default Return URL  This governs the \"selfservice.flows.login.after.webauthn.default_browser_return_url\" setting.
416    #[serde(rename = "kratos_selfservice_flows_login_after_webauthn_default_browser_return_url", skip_serializing_if = "Option::is_none")]
417    pub kratos_selfservice_flows_login_after_webauthn_default_browser_return_url: Option<String>,
418    /// Configures the Ory Kratos Login Lifespan  This governs the \"selfservice.flows.login.lifespan\" setting.
419    #[serde(rename = "kratos_selfservice_flows_login_lifespan", skip_serializing_if = "Option::is_none")]
420    pub kratos_selfservice_flows_login_lifespan: Option<String>,
421    /// Configures the Ory Kratos Login UI URL  This governs the \"selfservice.flows.login.ui_url\" setting.
422    #[serde(rename = "kratos_selfservice_flows_login_ui_url", skip_serializing_if = "Option::is_none")]
423    pub kratos_selfservice_flows_login_ui_url: Option<String>,
424    /// Configures the Ory Kratos Logout Default Return URL  This governs the \"selfservice.flows.logout.after.default_browser_return_url\" setting.
425    #[serde(rename = "kratos_selfservice_flows_logout_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
426    pub kratos_selfservice_flows_logout_after_default_browser_return_url: Option<String>,
427    /// Configures the Ory Kratos Recovery Default Return URL  This governs the \"selfservice.flows.recovery.after.default_browser_return_url\" setting.
428    #[serde(rename = "kratos_selfservice_flows_recovery_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
429    pub kratos_selfservice_flows_recovery_after_default_browser_return_url: Option<String>,
430    /// Configures the Ory Kratos Recovery Enabled Setting  This governs the \"selfservice.flows.recovery.enabled\" setting.
431    #[serde(rename = "kratos_selfservice_flows_recovery_enabled", skip_serializing_if = "Option::is_none")]
432    pub kratos_selfservice_flows_recovery_enabled: Option<bool>,
433    /// Configures the Ory Kratos Recovery Lifespan  This governs the \"selfservice.flows.recovery.lifespan\" setting.
434    #[serde(rename = "kratos_selfservice_flows_recovery_lifespan", skip_serializing_if = "Option::is_none")]
435    pub kratos_selfservice_flows_recovery_lifespan: Option<String>,
436    /// Configures whether to notify unknown recipients of a Ory Kratos recovery flow  This governs the \"selfservice.flows.recovery.notify_unknown_recipients\" setting.
437    #[serde(rename = "kratos_selfservice_flows_recovery_notify_unknown_recipients", skip_serializing_if = "Option::is_none")]
438    pub kratos_selfservice_flows_recovery_notify_unknown_recipients: Option<bool>,
439    /// Configures the Ory Kratos Recovery UI URL  This governs the \"selfservice.flows.recovery.ui_url\" setting.
440    #[serde(rename = "kratos_selfservice_flows_recovery_ui_url", skip_serializing_if = "Option::is_none")]
441    pub kratos_selfservice_flows_recovery_ui_url: Option<String>,
442    /// Configures the Ory Kratos Recovery strategy to use (\"link\" or \"code\")  This governs the \"selfservice.flows.recovery.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
443    #[serde(rename = "kratos_selfservice_flows_recovery_use", skip_serializing_if = "Option::is_none")]
444    pub kratos_selfservice_flows_recovery_use: Option<KratosSelfserviceFlowsRecoveryUseEnum>,
445    /// Configures the Ory Kratos Registration After Code Default Return URL  This governs the \"selfservice.flows.registration.after.code.default_browser_return_url\" setting.
446    #[serde(rename = "kratos_selfservice_flows_registration_after_code_default_browser_return_url", skip_serializing_if = "Option::is_none")]
447    pub kratos_selfservice_flows_registration_after_code_default_browser_return_url: Option<String>,
448    /// Configures the Ory Kratos Registration Default Return URL  This governs the \"selfservice.flows.registration.after.default_browser_return_url\" setting.
449    #[serde(rename = "kratos_selfservice_flows_registration_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
450    pub kratos_selfservice_flows_registration_after_default_browser_return_url: Option<String>,
451    /// Configures the Ory Kratos Registration After OIDC Default Return URL  This governs the \"selfservice.flows.registration.after.oidc.default_browser_return_url\" setting.
452    #[serde(rename = "kratos_selfservice_flows_registration_after_oidc_default_browser_return_url", skip_serializing_if = "Option::is_none")]
453    pub kratos_selfservice_flows_registration_after_oidc_default_browser_return_url: Option<String>,
454    /// Configures the Ory Kratos Registration After Passkey Default Return URL  This governs the \"selfservice.flows.registration.after.password.default_browser_return_url\" setting.
455    #[serde(rename = "kratos_selfservice_flows_registration_after_passkey_default_browser_return_url", skip_serializing_if = "Option::is_none")]
456    pub kratos_selfservice_flows_registration_after_passkey_default_browser_return_url: Option<String>,
457    /// Configures the Ory Kratos Registration After Password Default Return URL  This governs the \"selfservice.flows.registration.after.password.default_browser_return_url\" setting.
458    #[serde(rename = "kratos_selfservice_flows_registration_after_password_default_browser_return_url", skip_serializing_if = "Option::is_none")]
459    pub kratos_selfservice_flows_registration_after_password_default_browser_return_url: Option<String>,
460    /// Configures the Ory Kratos Registration After Webauthn Default Return URL  This governs the \"selfservice.flows.registration.after.webauthn.default_browser_return_url\" setting.
461    #[serde(rename = "kratos_selfservice_flows_registration_after_webauthn_default_browser_return_url", skip_serializing_if = "Option::is_none")]
462    pub kratos_selfservice_flows_registration_after_webauthn_default_browser_return_url: Option<String>,
463    /// 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.
464    #[serde(rename = "kratos_selfservice_flows_registration_enable_legacy_one_step", skip_serializing_if = "Option::is_none")]
465    pub kratos_selfservice_flows_registration_enable_legacy_one_step: Option<bool>,
466    /// Configures the Whether Ory Kratos Registration is Enabled  This governs the \"selfservice.flows.registration.enabled\" setting.0
467    #[serde(rename = "kratos_selfservice_flows_registration_enabled", skip_serializing_if = "Option::is_none")]
468    pub kratos_selfservice_flows_registration_enabled: Option<bool>,
469    /// Configures the Ory Kratos Registration Lifespan  This governs the \"selfservice.flows.registration.lifespan\" setting.
470    #[serde(rename = "kratos_selfservice_flows_registration_lifespan", skip_serializing_if = "Option::is_none")]
471    pub kratos_selfservice_flows_registration_lifespan: Option<String>,
472    /// 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.
473    #[serde(rename = "kratos_selfservice_flows_registration_login_hints", skip_serializing_if = "Option::is_none")]
474    pub kratos_selfservice_flows_registration_login_hints: Option<bool>,
475    /// Configures the Ory Kratos Registration UI URL  This governs the \"selfservice.flows.registration.ui_url\" setting.
476    #[serde(rename = "kratos_selfservice_flows_registration_ui_url", skip_serializing_if = "Option::is_none")]
477    pub kratos_selfservice_flows_registration_ui_url: Option<String>,
478    /// Configures the Ory Kratos Settings Default Return URL  This governs the \"selfservice.flows.settings.after.default_browser_return_url\" setting.
479    #[serde(rename = "kratos_selfservice_flows_settings_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
480    pub kratos_selfservice_flows_settings_after_default_browser_return_url: Option<String>,
481    /// 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.
482    #[serde(rename = "kratos_selfservice_flows_settings_after_lookup_secret_default_browser_return_url", skip_serializing_if = "Option::is_none")]
483    pub kratos_selfservice_flows_settings_after_lookup_secret_default_browser_return_url: Option<String>,
484    /// 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.
485    #[serde(rename = "kratos_selfservice_flows_settings_after_oidc_default_browser_return_url", skip_serializing_if = "Option::is_none")]
486    pub kratos_selfservice_flows_settings_after_oidc_default_browser_return_url: Option<String>,
487    /// Configures the Ory Kratos Settings Default Return URL After Updating Passkey  This governs the \"selfservice.flows.settings.after.passkey.default_browser_return_url\" setting.
488    #[serde(rename = "kratos_selfservice_flows_settings_after_passkey_default_browser_return_url", skip_serializing_if = "Option::is_none")]
489    pub kratos_selfservice_flows_settings_after_passkey_default_browser_return_url: Option<String>,
490    /// Configures the Ory Kratos Settings Default Return URL After Updating Passwords  This governs the \"selfservice.flows.settings.after.password.default_browser_return_url\" setting.
491    #[serde(rename = "kratos_selfservice_flows_settings_after_password_default_browser_return_url", skip_serializing_if = "Option::is_none")]
492    pub kratos_selfservice_flows_settings_after_password_default_browser_return_url: Option<String>,
493    /// Configures the Ory Kratos Settings Default Return URL After Updating Profiles  This governs the \"selfservice.flows.settings.after.profile.default_browser_return_url\" setting.
494    #[serde(rename = "kratos_selfservice_flows_settings_after_profile_default_browser_return_url", skip_serializing_if = "Option::is_none")]
495    pub kratos_selfservice_flows_settings_after_profile_default_browser_return_url: Option<String>,
496    /// Configures the Ory Kratos Settings Default Return URL After Updating TOTP  This governs the \"selfservice.flows.settings.after.totp.default_browser_return_url\" setting.
497    #[serde(rename = "kratos_selfservice_flows_settings_after_totp_default_browser_return_url", skip_serializing_if = "Option::is_none")]
498    pub kratos_selfservice_flows_settings_after_totp_default_browser_return_url: Option<String>,
499    /// Configures the Ory Kratos Settings Default Return URL After Updating WebAuthn  This governs the \"selfservice.flows.settings.after.webauthn.default_browser_return_url\" setting.
500    #[serde(rename = "kratos_selfservice_flows_settings_after_webauthn_default_browser_return_url", skip_serializing_if = "Option::is_none")]
501    pub kratos_selfservice_flows_settings_after_webauthn_default_browser_return_url: Option<String>,
502    /// Configures the Ory Kratos Settings Lifespan  This governs the \"selfservice.flows.settings.lifespan\" setting.
503    #[serde(rename = "kratos_selfservice_flows_settings_lifespan", skip_serializing_if = "Option::is_none")]
504    pub kratos_selfservice_flows_settings_lifespan: Option<String>,
505    /// Configures the Ory Kratos Settings Privileged Session Max Age  This governs the \"selfservice.flows.settings.privileged_session_max_age\" setting.
506    #[serde(rename = "kratos_selfservice_flows_settings_privileged_session_max_age", skip_serializing_if = "Option::is_none")]
507    pub kratos_selfservice_flows_settings_privileged_session_max_age: Option<String>,
508    /// Configures the Ory Kratos Settings Required AAL  This governs the \"selfservice.flows.settings.required_aal\" setting.
509    #[serde(rename = "kratos_selfservice_flows_settings_required_aal", skip_serializing_if = "Option::is_none")]
510    pub kratos_selfservice_flows_settings_required_aal: Option<String>,
511    /// Configures the Ory Kratos Settings UI URL  This governs the \"selfservice.flows.settings.ui_url\" setting.
512    #[serde(rename = "kratos_selfservice_flows_settings_ui_url", skip_serializing_if = "Option::is_none")]
513    pub kratos_selfservice_flows_settings_ui_url: Option<String>,
514    /// Configures the Ory Kratos Verification Default Return URL  This governs the \"selfservice.flows.verification.after.default_browser_return_url\" setting.
515    #[serde(rename = "kratos_selfservice_flows_verification_after_default_browser_return_url", skip_serializing_if = "Option::is_none")]
516    pub kratos_selfservice_flows_verification_after_default_browser_return_url: Option<String>,
517    /// Configures the Ory Kratos Verification Enabled Setting  This governs the \"selfservice.flows.verification.enabled\" setting.
518    #[serde(rename = "kratos_selfservice_flows_verification_enabled", skip_serializing_if = "Option::is_none")]
519    pub kratos_selfservice_flows_verification_enabled: Option<bool>,
520    /// Configures the Ory Kratos Verification Lifespan  This governs the \"selfservice.flows.verification.lifespan\" setting.
521    #[serde(rename = "kratos_selfservice_flows_verification_lifespan", skip_serializing_if = "Option::is_none")]
522    pub kratos_selfservice_flows_verification_lifespan: Option<String>,
523    /// Configures whether to notify unknown recipients of a Ory Kratos verification flow  This governs the \"selfservice.flows.verification.notify_unknown_recipients\" setting.
524    #[serde(rename = "kratos_selfservice_flows_verification_notify_unknown_recipients", skip_serializing_if = "Option::is_none")]
525    pub kratos_selfservice_flows_verification_notify_unknown_recipients: Option<bool>,
526    /// Configures the Ory Kratos Verification UI URL  This governs the \"selfservice.flows.verification.ui_url\" setting.
527    #[serde(rename = "kratos_selfservice_flows_verification_ui_url", skip_serializing_if = "Option::is_none")]
528    pub kratos_selfservice_flows_verification_ui_url: Option<String>,
529    /// Configures the Ory Kratos Strategy to use for Verification  This governs the \"selfservice.flows.verification.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
530    #[serde(rename = "kratos_selfservice_flows_verification_use", skip_serializing_if = "Option::is_none")]
531    pub kratos_selfservice_flows_verification_use: Option<KratosSelfserviceFlowsVerificationUseEnum>,
532    #[serde(rename = "kratos_selfservice_methods_captcha_config_allowed_domains", skip_serializing_if = "Option::is_none")]
533    pub kratos_selfservice_methods_captcha_config_allowed_domains: Option<Vec<String>>,
534    /// Configures the Cloudflare Turnstile site secret for CAPTCHA protection  The site secret is private and will be never be shared with the client. This key is write only and the value will not be returned in response to a read request.  Reach out to your account manager to enable this feature.
535    #[serde(rename = "kratos_selfservice_methods_captcha_config_cf_turnstile_secret", skip_serializing_if = "Option::is_none")]
536    pub kratos_selfservice_methods_captcha_config_cf_turnstile_secret: Option<String>,
537    /// Configures the Cloudflare 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.
538    #[serde(rename = "kratos_selfservice_methods_captcha_config_cf_turnstile_sitekey", skip_serializing_if = "Option::is_none")]
539    pub kratos_selfservice_methods_captcha_config_cf_turnstile_sitekey: Option<String>,
540    /// Configures the Ory Kratos Self-Service Methods' Captcha Enabled Setting  Reach out to your account manager to enable this feature.
541    #[serde(rename = "kratos_selfservice_methods_captcha_config_legacy_inject_node", skip_serializing_if = "Option::is_none")]
542    pub kratos_selfservice_methods_captcha_config_legacy_inject_node: Option<bool>,
543    /// Configures the Ory Kratos Self-Service Methods' Captcha Enabled Setting  Reach out to your account manager to enable this feature.
544    #[serde(rename = "kratos_selfservice_methods_captcha_enabled", skip_serializing_if = "Option::is_none")]
545    pub kratos_selfservice_methods_captcha_enabled: Option<bool>,
546    /// Configures the Ory Kratos Code Method's lifespan  This governs the \"selfservice.methods.code.config.lifespan\" setting.
547    #[serde(rename = "kratos_selfservice_methods_code_config_lifespan", skip_serializing_if = "Option::is_none")]
548    pub kratos_selfservice_methods_code_config_lifespan: Option<String>,
549    #[serde(rename = "kratos_selfservice_methods_code_config_max_submissions", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
550    pub kratos_selfservice_methods_code_config_max_submissions: Option<Option<i32>>,
551    /// Enables a fallback method required in certain legacy use cases.  This governs the \"selfservice.methods.code.config.missing_credential_fallback_enabled\" setting.
552    #[serde(rename = "kratos_selfservice_methods_code_config_missing_credential_fallback_enabled", skip_serializing_if = "Option::is_none")]
553    pub kratos_selfservice_methods_code_config_missing_credential_fallback_enabled: Option<bool>,
554    /// Configures whether Ory Kratos Code Method is enabled  This governs the \"selfservice.methods.code.enabled\" setting.
555    #[serde(rename = "kratos_selfservice_methods_code_enabled", skip_serializing_if = "Option::is_none")]
556    pub kratos_selfservice_methods_code_enabled: Option<bool>,
557    /// Configures whether the code method can be used to fulfil MFA flows  This governs the \"selfservice.methods.code.mfa_enabled\" setting.
558    #[serde(rename = "kratos_selfservice_methods_code_mfa_enabled", skip_serializing_if = "Option::is_none")]
559    pub kratos_selfservice_methods_code_mfa_enabled: Option<bool>,
560    /// Configures whether Ory Kratos Passwordless should use the Code Method  This governs the \"selfservice.methods.code.passwordless_enabled\" setting.
561    #[serde(rename = "kratos_selfservice_methods_code_passwordless_enabled", skip_serializing_if = "Option::is_none")]
562    pub kratos_selfservice_methods_code_passwordless_enabled: Option<bool>,
563    /// 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.
564    #[serde(rename = "kratos_selfservice_methods_code_passwordless_login_fallback_enabled", skip_serializing_if = "Option::is_none")]
565    pub kratos_selfservice_methods_code_passwordless_login_fallback_enabled: Option<bool>,
566    /// 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.
567    #[serde(rename = "kratos_selfservice_methods_link_config_base_url", skip_serializing_if = "Option::is_none")]
568    pub kratos_selfservice_methods_link_config_base_url: Option<String>,
569    /// Configures the Ory Kratos Link Method's lifespan  This governs the \"selfservice.methods.link.config.lifespan\" setting.
570    #[serde(rename = "kratos_selfservice_methods_link_config_lifespan", skip_serializing_if = "Option::is_none")]
571    pub kratos_selfservice_methods_link_config_lifespan: Option<String>,
572    /// Configures whether Ory Kratos Link Method is enabled  This governs the \"selfservice.methods.link.enabled\" setting.
573    #[serde(rename = "kratos_selfservice_methods_link_enabled", skip_serializing_if = "Option::is_none")]
574    pub kratos_selfservice_methods_link_enabled: Option<bool>,
575    /// Configures whether Ory Kratos TOTP Lookup Secret is enabled  This governs the \"selfservice.methods.lookup_secret.enabled\" setting.
576    #[serde(rename = "kratos_selfservice_methods_lookup_secret_enabled", skip_serializing_if = "Option::is_none")]
577    pub kratos_selfservice_methods_lookup_secret_enabled: Option<bool>,
578    /// Configures the Ory Kratos Third Party / OpenID Connect base redirect URI  This governs the \"selfservice.methods.oidc.config.base_redirect_uri\" setting.
579    #[serde(rename = "kratos_selfservice_methods_oidc_config_base_redirect_uri", skip_serializing_if = "Option::is_none")]
580    pub kratos_selfservice_methods_oidc_config_base_redirect_uri: Option<String>,
581    #[serde(rename = "kratos_selfservice_methods_oidc_config_providers", skip_serializing_if = "Option::is_none")]
582    pub kratos_selfservice_methods_oidc_config_providers: Option<Vec<models::NormalizedProjectRevisionThirdPartyProvider>>,
583    /// Configures whether Ory Kratos allows auto-linking of OIDC credentials without a subject  This governs the \"selfservice.methods.oidc.enable_auto_link_policy\" setting.
584    #[serde(rename = "kratos_selfservice_methods_oidc_enable_auto_link_policy", skip_serializing_if = "Option::is_none")]
585    pub kratos_selfservice_methods_oidc_enable_auto_link_policy: Option<bool>,
586    /// Configures whether Ory Kratos Third Party / OpenID Connect Login is enabled  This governs the \"selfservice.methods.oidc.enabled\" setting.
587    #[serde(rename = "kratos_selfservice_methods_oidc_enabled", skip_serializing_if = "Option::is_none")]
588    pub kratos_selfservice_methods_oidc_enabled: Option<bool>,
589    /// Configures the Ory Kratos Passkey RP Display Name  This governs the \"selfservice.methods.passkey.config.rp.display_name\" setting.
590    #[serde(rename = "kratos_selfservice_methods_passkey_config_rp_display_name", skip_serializing_if = "Option::is_none")]
591    pub kratos_selfservice_methods_passkey_config_rp_display_name: Option<String>,
592    /// Configures the Ory Kratos Passkey RP ID  This governs the \"selfservice.methods.passkey.config.rp.id\" setting.
593    #[serde(rename = "kratos_selfservice_methods_passkey_config_rp_id", skip_serializing_if = "Option::is_none")]
594    pub kratos_selfservice_methods_passkey_config_rp_id: Option<String>,
595    #[serde(rename = "kratos_selfservice_methods_passkey_config_rp_origins", skip_serializing_if = "Option::is_none")]
596    pub kratos_selfservice_methods_passkey_config_rp_origins: Option<Vec<String>>,
597    /// Configures whether Ory Kratos Passkey authentication is enabled  This governs the \"selfservice.methods.passkey.enabled\" setting.
598    #[serde(rename = "kratos_selfservice_methods_passkey_enabled", skip_serializing_if = "Option::is_none")]
599    pub kratos_selfservice_methods_passkey_enabled: Option<bool>,
600    /// Configures whether Ory Kratos Password HIBP Checks is enabled  This governs the \"selfservice.methods.password.config.haveibeenpwned_enabled\" setting.
601    #[serde(rename = "kratos_selfservice_methods_password_config_haveibeenpwned_enabled", skip_serializing_if = "Option::is_none")]
602    pub kratos_selfservice_methods_password_config_haveibeenpwned_enabled: Option<bool>,
603    /// Configures whether Ory Kratos Password should disable the similarity policy.  This governs the \"selfservice.methods.password.config.identifier_similarity_check_enabled\" setting.
604    #[serde(rename = "kratos_selfservice_methods_password_config_identifier_similarity_check_enabled", skip_serializing_if = "Option::is_none")]
605    pub kratos_selfservice_methods_password_config_identifier_similarity_check_enabled: Option<bool>,
606    /// Configures whether Ory Kratos Password Should ignore HIBPWND Network Errors  This governs the \"selfservice.methods.password.config.ignore_network_errors\" setting.
607    #[serde(rename = "kratos_selfservice_methods_password_config_ignore_network_errors", skip_serializing_if = "Option::is_none")]
608    pub kratos_selfservice_methods_password_config_ignore_network_errors: Option<bool>,
609    /// Configures Ory Kratos Password Max Breaches Detection  This governs the \"selfservice.methods.password.config.max_breaches\" setting.
610    #[serde(rename = "kratos_selfservice_methods_password_config_max_breaches", skip_serializing_if = "Option::is_none")]
611    pub kratos_selfservice_methods_password_config_max_breaches: Option<i64>,
612    /// Configures the minimum length of passwords.  This governs the \"selfservice.methods.password.config.min_password_length\" setting.
613    #[serde(rename = "kratos_selfservice_methods_password_config_min_password_length", skip_serializing_if = "Option::is_none")]
614    pub kratos_selfservice_methods_password_config_min_password_length: Option<i64>,
615    /// Configures whether Ory Kratos Password Method is enabled  This governs the \"selfservice.methods.password.enabled\" setting.
616    #[serde(rename = "kratos_selfservice_methods_password_enabled", skip_serializing_if = "Option::is_none")]
617    pub kratos_selfservice_methods_password_enabled: Option<bool>,
618    /// Configures whether Ory Kratos Profile Method is enabled  This governs the \"selfservice.methods.profile.enabled\" setting.
619    #[serde(rename = "kratos_selfservice_methods_profile_enabled", skip_serializing_if = "Option::is_none")]
620    pub kratos_selfservice_methods_profile_enabled: Option<bool>,
621    #[serde(rename = "kratos_selfservice_methods_saml_config_providers", skip_serializing_if = "Option::is_none")]
622    pub kratos_selfservice_methods_saml_config_providers: Option<Vec<models::NormalizedProjectRevisionSamlProvider>>,
623    /// Configures whether Ory Kratos SAML Login is enabled  This governs the \"selfservice.methods.saml.enabled\" setting.
624    #[serde(rename = "kratos_selfservice_methods_saml_enabled", skip_serializing_if = "Option::is_none")]
625    pub kratos_selfservice_methods_saml_enabled: Option<bool>,
626    /// Configures Ory Kratos TOTP Issuer  This governs the \"selfservice.methods.totp.config.issuer\" setting.
627    #[serde(rename = "kratos_selfservice_methods_totp_config_issuer", skip_serializing_if = "Option::is_none")]
628    pub kratos_selfservice_methods_totp_config_issuer: Option<String>,
629    /// Configures whether Ory Kratos TOTP Method is enabled  This governs the \"selfservice.methods.totp.enabled\" setting.
630    #[serde(rename = "kratos_selfservice_methods_totp_enabled", skip_serializing_if = "Option::is_none")]
631    pub kratos_selfservice_methods_totp_enabled: Option<bool>,
632    /// Configures whether Ory Kratos Webauthn is used for passwordless flows  This governs the \"selfservice.methods.webauthn.config.passwordless\" setting.
633    #[serde(rename = "kratos_selfservice_methods_webauthn_config_passwordless", skip_serializing_if = "Option::is_none")]
634    pub kratos_selfservice_methods_webauthn_config_passwordless: Option<bool>,
635    /// Configures the Ory Kratos Webauthn RP Display Name  This governs the \"selfservice.methods.webauthn.config.rp.display_name\" setting.
636    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_display_name", skip_serializing_if = "Option::is_none")]
637    pub kratos_selfservice_methods_webauthn_config_rp_display_name: Option<String>,
638    /// 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.
639    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_icon", skip_serializing_if = "Option::is_none")]
640    pub kratos_selfservice_methods_webauthn_config_rp_icon: Option<String>,
641    /// Configures the Ory Kratos Webauthn RP ID  This governs the \"selfservice.methods.webauthn.config.rp.id\" setting.
642    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_id", skip_serializing_if = "Option::is_none")]
643    pub kratos_selfservice_methods_webauthn_config_rp_id: Option<String>,
644    #[serde(rename = "kratos_selfservice_methods_webauthn_config_rp_origins", skip_serializing_if = "Option::is_none")]
645    pub kratos_selfservice_methods_webauthn_config_rp_origins: Option<Vec<String>>,
646    /// Configures whether Ory Kratos Webauthn is enabled  This governs the \"selfservice.methods.webauthn.enabled\" setting.
647    #[serde(rename = "kratos_selfservice_methods_webauthn_enabled", skip_serializing_if = "Option::is_none")]
648    pub kratos_selfservice_methods_webauthn_enabled: Option<bool>,
649    /// Configures the Ory Kratos Session Cookie Persistent Attribute  This governs the \"session.cookie.persistent\" setting.
650    #[serde(rename = "kratos_session_cookie_persistent", skip_serializing_if = "Option::is_none")]
651    pub kratos_session_cookie_persistent: Option<bool>,
652    /// Configures the Ory Kratos Session Cookie SameSite Attribute  This governs the \"session.cookie.same_site\" setting.
653    #[serde(rename = "kratos_session_cookie_same_site", skip_serializing_if = "Option::is_none")]
654    pub kratos_session_cookie_same_site: Option<String>,
655    /// Configures the Ory Kratos Session Lifespan  This governs the \"session.lifespan\" setting.
656    #[serde(rename = "kratos_session_lifespan", skip_serializing_if = "Option::is_none")]
657    pub kratos_session_lifespan: Option<String>,
658    /// Configures the Ory Kratos Session Whoami AAL requirement  This governs the \"session.whoami.required_aal\" setting.
659    #[serde(rename = "kratos_session_whoami_required_aal", skip_serializing_if = "Option::is_none")]
660    pub kratos_session_whoami_required_aal: Option<String>,
661    #[serde(rename = "kratos_session_whoami_tokenizer_templates", skip_serializing_if = "Option::is_none")]
662    pub kratos_session_whoami_tokenizer_templates: Option<Vec<models::NormalizedProjectRevisionTokenizerTemplate>>,
663    /// The project's name.
664    #[serde(rename = "name")]
665    pub name: String,
666    #[serde(rename = "organizations", skip_serializing_if = "Option::is_none")]
667    pub organizations: Option<Vec<models::Organization>>,
668    /// The Revision's Project ID
669    #[serde(rename = "project_id", skip_serializing_if = "Option::is_none")]
670    pub project_id: Option<String>,
671    #[serde(rename = "project_revision_hooks", skip_serializing_if = "Option::is_none")]
672    pub project_revision_hooks: Option<Vec<models::NormalizedProjectRevisionHook>>,
673    #[serde(rename = "scim_clients", skip_serializing_if = "Option::is_none")]
674    pub scim_clients: Option<Vec<models::NormalizedProjectRevisionScimClient>>,
675    #[serde(rename = "serve_admin_cors_allowed_origins", skip_serializing_if = "Option::is_none")]
676    pub serve_admin_cors_allowed_origins: Option<Vec<String>>,
677    /// Enable CORS headers on all admin APIs  This governs the \"serve.admin.cors.enabled\" setting.
678    #[serde(rename = "serve_admin_cors_enabled", skip_serializing_if = "Option::is_none")]
679    pub serve_admin_cors_enabled: Option<bool>,
680    #[serde(rename = "serve_public_cors_allowed_origins", skip_serializing_if = "Option::is_none")]
681    pub serve_public_cors_allowed_origins: Option<Vec<String>>,
682    /// Enable CORS headers on all public APIs  This governs the \"serve.public.cors.enabled\" setting.
683    #[serde(rename = "serve_public_cors_enabled", skip_serializing_if = "Option::is_none")]
684    pub serve_public_cors_enabled: Option<bool>,
685    /// Whether the project should employ strict security measures. Setting this to true is recommended for going into production.
686    #[serde(rename = "strict_security", skip_serializing_if = "Option::is_none")]
687    pub strict_security: Option<bool>,
688    /// Last Time Project's Revision was Updated
689    #[serde(rename = "updated_at", skip_serializing_if = "Option::is_none")]
690    pub updated_at: Option<String>,
691}
692
693impl NormalizedProjectRevision {
694    pub fn new(name: String) -> NormalizedProjectRevision {
695        NormalizedProjectRevision {
696            account_experience_default_locale: None,
697            account_experience_favicon_dark: None,
698            account_experience_favicon_light: None,
699            account_experience_locale_behavior: None,
700            account_experience_logo_dark: None,
701            account_experience_logo_light: None,
702            account_experience_theme_variables_dark: None,
703            account_experience_theme_variables_light: None,
704            created_at: None,
705            disable_account_experience_welcome_screen: None,
706            enable_ax_v2: None,
707            hydra_oauth2_allowed_top_level_claims: None,
708            hydra_oauth2_client_credentials_default_grant_allowed_scope: None,
709            hydra_oauth2_exclude_not_before_claim: None,
710            hydra_oauth2_grant_jwt_iat_optional: None,
711            hydra_oauth2_grant_jwt_jti_optional: None,
712            hydra_oauth2_grant_jwt_max_ttl: None,
713            hydra_oauth2_grant_refresh_token_rotation_grace_period: None,
714            hydra_oauth2_mirror_top_level_claims: None,
715            hydra_oauth2_pkce_enforced: None,
716            hydra_oauth2_pkce_enforced_for_public_clients: None,
717            hydra_oauth2_refresh_token_hook: None,
718            hydra_oauth2_token_hook: None,
719            hydra_oidc_dynamic_client_registration_default_scope: None,
720            hydra_oidc_dynamic_client_registration_enabled: None,
721            hydra_oidc_subject_identifiers_pairwise_salt: None,
722            hydra_oidc_subject_identifiers_supported_types: None,
723            hydra_secrets_cookie: None,
724            hydra_secrets_pagination: None,
725            hydra_secrets_system: None,
726            hydra_serve_cookies_same_site_legacy_workaround: None,
727            hydra_serve_cookies_same_site_mode: None,
728            hydra_strategies_access_token: None,
729            hydra_strategies_jwt_scope_claim: None,
730            hydra_strategies_scope: None,
731            hydra_ttl_access_token: None,
732            hydra_ttl_auth_code: None,
733            hydra_ttl_id_token: None,
734            hydra_ttl_login_consent_request: None,
735            hydra_ttl_refresh_token: None,
736            hydra_urls_consent: None,
737            hydra_urls_error: None,
738            hydra_urls_login: None,
739            hydra_urls_logout: None,
740            hydra_urls_post_logout_redirect: None,
741            hydra_urls_registration: None,
742            hydra_urls_self_issuer: None,
743            hydra_webfinger_jwks_broadcast_keys: None,
744            hydra_webfinger_oidc_discovery_auth_url: None,
745            hydra_webfinger_oidc_discovery_client_registration_url: None,
746            hydra_webfinger_oidc_discovery_jwks_url: None,
747            hydra_webfinger_oidc_discovery_supported_claims: None,
748            hydra_webfinger_oidc_discovery_supported_scope: None,
749            hydra_webfinger_oidc_discovery_token_url: None,
750            hydra_webfinger_oidc_discovery_userinfo_url: None,
751            id: None,
752            keto_namespace_configuration: None,
753            keto_namespaces: None,
754            keto_secrets_pagination: None,
755            kratos_cookies_same_site: None,
756            kratos_courier_channels: None,
757            kratos_courier_delivery_strategy: None,
758            kratos_courier_http_request_config_auth_api_key_in: None,
759            kratos_courier_http_request_config_auth_api_key_name: None,
760            kratos_courier_http_request_config_auth_api_key_value: None,
761            kratos_courier_http_request_config_auth_basic_auth_password: None,
762            kratos_courier_http_request_config_auth_basic_auth_user: None,
763            kratos_courier_http_request_config_auth_type: None,
764            kratos_courier_http_request_config_body: None,
765            kratos_courier_http_request_config_headers: None,
766            kratos_courier_http_request_config_method: None,
767            kratos_courier_http_request_config_url: None,
768            kratos_courier_smtp_connection_uri: None,
769            kratos_courier_smtp_from_address: None,
770            kratos_courier_smtp_from_name: None,
771            kratos_courier_smtp_headers: None,
772            kratos_courier_smtp_local_name: None,
773            kratos_courier_templates_login_code_valid_email_body_html: None,
774            kratos_courier_templates_login_code_valid_email_body_plaintext: None,
775            kratos_courier_templates_login_code_valid_email_subject: None,
776            kratos_courier_templates_login_code_valid_sms_body_plaintext: None,
777            kratos_courier_templates_recovery_code_invalid_email_body_html: None,
778            kratos_courier_templates_recovery_code_invalid_email_body_plaintext: None,
779            kratos_courier_templates_recovery_code_invalid_email_subject: None,
780            kratos_courier_templates_recovery_code_valid_email_body_html: None,
781            kratos_courier_templates_recovery_code_valid_email_body_plaintext: None,
782            kratos_courier_templates_recovery_code_valid_email_subject: None,
783            kratos_courier_templates_recovery_invalid_email_body_html: None,
784            kratos_courier_templates_recovery_invalid_email_body_plaintext: None,
785            kratos_courier_templates_recovery_invalid_email_subject: None,
786            kratos_courier_templates_recovery_valid_email_body_html: None,
787            kratos_courier_templates_recovery_valid_email_body_plaintext: None,
788            kratos_courier_templates_recovery_valid_email_subject: None,
789            kratos_courier_templates_registration_code_valid_email_body_html: None,
790            kratos_courier_templates_registration_code_valid_email_body_plaintext: None,
791            kratos_courier_templates_registration_code_valid_email_subject: None,
792            kratos_courier_templates_registration_code_valid_sms_body_plaintext: None,
793            kratos_courier_templates_verification_code_invalid_email_body_html: None,
794            kratos_courier_templates_verification_code_invalid_email_body_plaintext: None,
795            kratos_courier_templates_verification_code_invalid_email_subject: None,
796            kratos_courier_templates_verification_code_valid_email_body_html: None,
797            kratos_courier_templates_verification_code_valid_email_body_plaintext: None,
798            kratos_courier_templates_verification_code_valid_email_subject: None,
799            kratos_courier_templates_verification_code_valid_sms_body_plaintext: None,
800            kratos_courier_templates_verification_invalid_email_body_html: None,
801            kratos_courier_templates_verification_invalid_email_body_plaintext: None,
802            kratos_courier_templates_verification_invalid_email_subject: None,
803            kratos_courier_templates_verification_valid_email_body_html: None,
804            kratos_courier_templates_verification_valid_email_body_plaintext: None,
805            kratos_courier_templates_verification_valid_email_subject: None,
806            kratos_feature_flags_cacheable_sessions: None,
807            kratos_feature_flags_cacheable_sessions_max_age: None,
808            kratos_feature_flags_choose_recovery_address: None,
809            kratos_feature_flags_faster_session_extend: None,
810            kratos_feature_flags_legacy_continue_with_verification_ui: None,
811            kratos_feature_flags_legacy_oidc_registration_node_group: None,
812            kratos_feature_flags_legacy_require_verified_login_error: None,
813            kratos_feature_flags_password_profile_registration_node_group: None,
814            kratos_feature_flags_use_continue_with_transitions: None,
815            kratos_identity_schemas: None,
816            kratos_oauth2_provider_headers: None,
817            kratos_oauth2_provider_override_return_to: None,
818            kratos_oauth2_provider_url: None,
819            kratos_preview_default_read_consistency_level: None,
820            kratos_secrets_cipher: None,
821            kratos_secrets_cookie: None,
822            kratos_secrets_default: None,
823            kratos_secrets_pagination: None,
824            kratos_security_account_enumeration_mitigate: None,
825            kratos_selfservice_allowed_return_urls: None,
826            kratos_selfservice_default_browser_return_url: None,
827            kratos_selfservice_flows_error_ui_url: None,
828            kratos_selfservice_flows_login_after_code_default_browser_return_url: None,
829            kratos_selfservice_flows_login_after_default_browser_return_url: None,
830            kratos_selfservice_flows_login_after_lookup_secret_default_browser_return_url: None,
831            kratos_selfservice_flows_login_after_oidc_default_browser_return_url: None,
832            kratos_selfservice_flows_login_after_passkey_default_browser_return_url: None,
833            kratos_selfservice_flows_login_after_password_default_browser_return_url: None,
834            kratos_selfservice_flows_login_after_totp_default_browser_return_url: None,
835            kratos_selfservice_flows_login_after_webauthn_default_browser_return_url: None,
836            kratos_selfservice_flows_login_lifespan: None,
837            kratos_selfservice_flows_login_ui_url: None,
838            kratos_selfservice_flows_logout_after_default_browser_return_url: None,
839            kratos_selfservice_flows_recovery_after_default_browser_return_url: None,
840            kratos_selfservice_flows_recovery_enabled: None,
841            kratos_selfservice_flows_recovery_lifespan: None,
842            kratos_selfservice_flows_recovery_notify_unknown_recipients: None,
843            kratos_selfservice_flows_recovery_ui_url: None,
844            kratos_selfservice_flows_recovery_use: None,
845            kratos_selfservice_flows_registration_after_code_default_browser_return_url: None,
846            kratos_selfservice_flows_registration_after_default_browser_return_url: None,
847            kratos_selfservice_flows_registration_after_oidc_default_browser_return_url: None,
848            kratos_selfservice_flows_registration_after_passkey_default_browser_return_url: None,
849            kratos_selfservice_flows_registration_after_password_default_browser_return_url: None,
850            kratos_selfservice_flows_registration_after_webauthn_default_browser_return_url: None,
851            kratos_selfservice_flows_registration_enable_legacy_one_step: None,
852            kratos_selfservice_flows_registration_enabled: None,
853            kratos_selfservice_flows_registration_lifespan: None,
854            kratos_selfservice_flows_registration_login_hints: None,
855            kratos_selfservice_flows_registration_ui_url: None,
856            kratos_selfservice_flows_settings_after_default_browser_return_url: None,
857            kratos_selfservice_flows_settings_after_lookup_secret_default_browser_return_url: None,
858            kratos_selfservice_flows_settings_after_oidc_default_browser_return_url: None,
859            kratos_selfservice_flows_settings_after_passkey_default_browser_return_url: None,
860            kratos_selfservice_flows_settings_after_password_default_browser_return_url: None,
861            kratos_selfservice_flows_settings_after_profile_default_browser_return_url: None,
862            kratos_selfservice_flows_settings_after_totp_default_browser_return_url: None,
863            kratos_selfservice_flows_settings_after_webauthn_default_browser_return_url: None,
864            kratos_selfservice_flows_settings_lifespan: None,
865            kratos_selfservice_flows_settings_privileged_session_max_age: None,
866            kratos_selfservice_flows_settings_required_aal: None,
867            kratos_selfservice_flows_settings_ui_url: None,
868            kratos_selfservice_flows_verification_after_default_browser_return_url: None,
869            kratos_selfservice_flows_verification_enabled: None,
870            kratos_selfservice_flows_verification_lifespan: None,
871            kratos_selfservice_flows_verification_notify_unknown_recipients: None,
872            kratos_selfservice_flows_verification_ui_url: None,
873            kratos_selfservice_flows_verification_use: None,
874            kratos_selfservice_methods_captcha_config_allowed_domains: None,
875            kratos_selfservice_methods_captcha_config_cf_turnstile_secret: None,
876            kratos_selfservice_methods_captcha_config_cf_turnstile_sitekey: None,
877            kratos_selfservice_methods_captcha_config_legacy_inject_node: None,
878            kratos_selfservice_methods_captcha_enabled: None,
879            kratos_selfservice_methods_code_config_lifespan: None,
880            kratos_selfservice_methods_code_config_max_submissions: None,
881            kratos_selfservice_methods_code_config_missing_credential_fallback_enabled: None,
882            kratos_selfservice_methods_code_enabled: None,
883            kratos_selfservice_methods_code_mfa_enabled: None,
884            kratos_selfservice_methods_code_passwordless_enabled: None,
885            kratos_selfservice_methods_code_passwordless_login_fallback_enabled: None,
886            kratos_selfservice_methods_link_config_base_url: None,
887            kratos_selfservice_methods_link_config_lifespan: None,
888            kratos_selfservice_methods_link_enabled: None,
889            kratos_selfservice_methods_lookup_secret_enabled: None,
890            kratos_selfservice_methods_oidc_config_base_redirect_uri: None,
891            kratos_selfservice_methods_oidc_config_providers: None,
892            kratos_selfservice_methods_oidc_enable_auto_link_policy: None,
893            kratos_selfservice_methods_oidc_enabled: None,
894            kratos_selfservice_methods_passkey_config_rp_display_name: None,
895            kratos_selfservice_methods_passkey_config_rp_id: None,
896            kratos_selfservice_methods_passkey_config_rp_origins: None,
897            kratos_selfservice_methods_passkey_enabled: None,
898            kratos_selfservice_methods_password_config_haveibeenpwned_enabled: None,
899            kratos_selfservice_methods_password_config_identifier_similarity_check_enabled: None,
900            kratos_selfservice_methods_password_config_ignore_network_errors: None,
901            kratos_selfservice_methods_password_config_max_breaches: None,
902            kratos_selfservice_methods_password_config_min_password_length: None,
903            kratos_selfservice_methods_password_enabled: None,
904            kratos_selfservice_methods_profile_enabled: None,
905            kratos_selfservice_methods_saml_config_providers: None,
906            kratos_selfservice_methods_saml_enabled: None,
907            kratos_selfservice_methods_totp_config_issuer: None,
908            kratos_selfservice_methods_totp_enabled: None,
909            kratos_selfservice_methods_webauthn_config_passwordless: None,
910            kratos_selfservice_methods_webauthn_config_rp_display_name: None,
911            kratos_selfservice_methods_webauthn_config_rp_icon: None,
912            kratos_selfservice_methods_webauthn_config_rp_id: None,
913            kratos_selfservice_methods_webauthn_config_rp_origins: None,
914            kratos_selfservice_methods_webauthn_enabled: None,
915            kratos_session_cookie_persistent: None,
916            kratos_session_cookie_same_site: None,
917            kratos_session_lifespan: None,
918            kratos_session_whoami_required_aal: None,
919            kratos_session_whoami_tokenizer_templates: None,
920            name,
921            organizations: None,
922            project_id: None,
923            project_revision_hooks: None,
924            scim_clients: None,
925            serve_admin_cors_allowed_origins: None,
926            serve_admin_cors_enabled: None,
927            serve_public_cors_allowed_origins: None,
928            serve_public_cors_enabled: None,
929            strict_security: None,
930            updated_at: None,
931        }
932    }
933}
934/// Defines access token type  This governs the \"strategies.access_token\" setting. opaque Oauth2AccessTokenStrategyOpaque jwt Oauth2AccessTokenStrategyJwt
935#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
936pub enum HydraStrategiesAccessTokenEnum {
937    #[serde(rename = "opaque")]
938    Opaque,
939    #[serde(rename = "jwt")]
940    Jwt,
941}
942
943impl Default for HydraStrategiesAccessTokenEnum {
944    fn default() -> HydraStrategiesAccessTokenEnum {
945        Self::Opaque
946    }
947}
948/// 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
949#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
950pub enum HydraStrategiesJwtScopeClaimEnum {
951    #[serde(rename = "list")]
952    List,
953    #[serde(rename = "string")]
954    String,
955    #[serde(rename = "both")]
956    Both,
957}
958
959impl Default for HydraStrategiesJwtScopeClaimEnum {
960    fn default() -> HydraStrategiesJwtScopeClaimEnum {
961        Self::List
962    }
963}
964/// 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
965#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
966pub enum HydraStrategiesScopeEnum {
967    #[serde(rename = "exact")]
968    Exact,
969    #[serde(rename = "wildcard")]
970    Wildcard,
971}
972
973impl Default for HydraStrategiesScopeEnum {
974    fn default() -> HydraStrategiesScopeEnum {
975        Self::Exact
976    }
977}
978/// Configures the Ory Kratos Recovery strategy to use (\"link\" or \"code\")  This governs the \"selfservice.flows.recovery.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
979#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
980pub enum KratosSelfserviceFlowsRecoveryUseEnum {
981    #[serde(rename = "link")]
982    Link,
983    #[serde(rename = "code")]
984    Code,
985}
986
987impl Default for KratosSelfserviceFlowsRecoveryUseEnum {
988    fn default() -> KratosSelfserviceFlowsRecoveryUseEnum {
989        Self::Link
990    }
991}
992/// Configures the Ory Kratos Strategy to use for Verification  This governs the \"selfservice.flows.verification.use\" setting. link SelfServiceMessageVerificationStrategyLink code SelfServiceMessageVerificationStrategyCode
993#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
994pub enum KratosSelfserviceFlowsVerificationUseEnum {
995    #[serde(rename = "link")]
996    Link,
997    #[serde(rename = "code")]
998    Code,
999}
1000
1001impl Default for KratosSelfserviceFlowsVerificationUseEnum {
1002    fn default() -> KratosSelfserviceFlowsVerificationUseEnum {
1003        Self::Link
1004    }
1005}
1006