ory-client 1.22.41

OpenAPI API client for Ory Network, Ory's web-scale API for identity and access control.
Documentation
/*
 * Ory APIs
 *
 * # 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)       | 
 *
 * The version of the OpenAPI document: v1.22.41
 * Contact: support@ory.sh
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

/// RevocationReason : RevocationReason provides structured revocation reasons inspired by RFC 5280. Used in both admin and self-revocation flows.   - REVOCATION_REASON_UNSPECIFIED: Default zero value. Use a specific reason; UNSPECIFIED is rejected by admin and self-revocation endpoints.  - REVOCATION_REASON_KEY_COMPROMISE: The key was leaked or believed to be in the hands of an unauthorized party.  - REVOCATION_REASON_AFFILIATION_CHANGED: The owning actor's relationship with the issuer changed (e.g., role change, departure).  - REVOCATION_REASON_SUPERSEDED: A new key has replaced this one as part of a rotation.  - REVOCATION_REASON_PRIVILEGE_WITHDRAWN: Admin-only. The actor's privilege to use this key was withdrawn by an operator. Self-revocation requests using this reason are rejected with InvalidArgument. Pair with `description` on RevokeAPIKeyRequest to record the operator-supplied justification.
/// RevocationReason provides structured revocation reasons inspired by RFC 5280. Used in both admin and self-revocation flows.   - REVOCATION_REASON_UNSPECIFIED: Default zero value. Use a specific reason; UNSPECIFIED is rejected by admin and self-revocation endpoints.  - REVOCATION_REASON_KEY_COMPROMISE: The key was leaked or believed to be in the hands of an unauthorized party.  - REVOCATION_REASON_AFFILIATION_CHANGED: The owning actor's relationship with the issuer changed (e.g., role change, departure).  - REVOCATION_REASON_SUPERSEDED: A new key has replaced this one as part of a rotation.  - REVOCATION_REASON_PRIVILEGE_WITHDRAWN: Admin-only. The actor's privilege to use this key was withdrawn by an operator. Self-revocation requests using this reason are rejected with InvalidArgument. Pair with `description` on RevokeAPIKeyRequest to record the operator-supplied justification.
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum RevocationReason {
    #[serde(rename = "REVOCATION_REASON_UNSPECIFIED")]
    RevocationReasonUnspecified,
    #[serde(rename = "REVOCATION_REASON_KEY_COMPROMISE")]
    RevocationReasonKeyCompromise,
    #[serde(rename = "REVOCATION_REASON_AFFILIATION_CHANGED")]
    RevocationReasonAffiliationChanged,
    #[serde(rename = "REVOCATION_REASON_SUPERSEDED")]
    RevocationReasonSuperseded,
    #[serde(rename = "REVOCATION_REASON_PRIVILEGE_WITHDRAWN")]
    RevocationReasonPrivilegeWithdrawn,

}

impl std::fmt::Display for RevocationReason {
    fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
        match self {
            Self::RevocationReasonUnspecified => write!(f, "REVOCATION_REASON_UNSPECIFIED"),
            Self::RevocationReasonKeyCompromise => write!(f, "REVOCATION_REASON_KEY_COMPROMISE"),
            Self::RevocationReasonAffiliationChanged => write!(f, "REVOCATION_REASON_AFFILIATION_CHANGED"),
            Self::RevocationReasonSuperseded => write!(f, "REVOCATION_REASON_SUPERSEDED"),
            Self::RevocationReasonPrivilegeWithdrawn => write!(f, "REVOCATION_REASON_PRIVILEGE_WITHDRAWN"),
        }
    }
}

impl Default for RevocationReason {
    fn default() -> RevocationReason {
        Self::RevocationReasonUnspecified
    }
}