redfish_codegen/models/certificate/v1_7_0/
certificate.rs

1// Generated by redfish-codegen. Do not modify.
2
3use crate::models;
4
5/// The Certificate schema describes a certificate that proves the identify of a component, account, or service.
6#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
7#[derive(derivative::Derivative)]
8#[derivative(Default)]
9pub struct Certificate {
10    #[serde(rename = "@odata.context")]
11    #[serde(skip_deserializing)]
12    #[serde(default, skip_serializing_if = "Option::is_none")]
13    pub odata_context: Option<models::odata_v4::Context>,
14    #[serde(rename = "@odata.etag")]
15    #[serde(skip_deserializing)]
16    #[serde(default, skip_serializing_if = "Option::is_none")]
17    pub odata_etag: Option<models::odata_v4::Etag>,
18    #[serde(rename = "@odata.id")]
19    #[serde(skip_deserializing)]
20    pub odata_id: models::odata_v4::Id,
21    #[serde(rename = "@odata.type")]
22    #[serde(skip_deserializing)]
23    #[derivative(Default(value = "models::odata_v4::Type(\"#Certificate.v1_7_0.Certificate\".to_string())"))]
24    pub odata_type: models::odata_v4::Type,
25    #[serde(rename = "Actions")]
26    #[serde(default, skip_serializing_if = "Option::is_none")]
27    pub actions: Option<models::certificate::v1_7_0::Actions>,
28    /// The string for the certificate.
29    #[serde(rename = "CertificateString")]
30    #[serde(default, skip_serializing_if = "Option::is_none")]
31    pub certificate_string: Option<String>,
32    #[serde(rename = "CertificateType")]
33    #[serde(default, skip_serializing_if = "Option::is_none")]
34    pub certificate_type: Option<models::certificate::CertificateType>,
35    /// The types or purposes for this certificate.
36    #[serde(rename = "CertificateUsageTypes")]
37    #[serde(default, skip_serializing_if = "Option::is_none")]
38    pub certificate_usage_types: Option<Vec<models::certificate::v1_7_0::CertificateUsageType>>,
39    #[serde(rename = "Description")]
40    #[serde(default, skip_serializing_if = "Option::is_none")]
41    pub description: Option<models::resource::Description>,
42    /// The fingerprint of the certificate.
43    #[serde(rename = "Fingerprint")]
44    #[serde(default, skip_serializing_if = "Option::is_none")]
45    pub fingerprint: Option<String>,
46    /// The hash algorithm for the fingerprint of the certificate.
47    #[serde(rename = "FingerprintHashAlgorithm")]
48    #[serde(default, skip_serializing_if = "Option::is_none")]
49    pub fingerprint_hash_algorithm: Option<String>,
50    #[serde(rename = "Id")]
51    #[serde(skip_deserializing)]
52    pub id: models::resource::Id,
53    #[serde(rename = "Issuer")]
54    #[serde(default, skip_serializing_if = "Option::is_none")]
55    pub issuer: Option<models::certificate::v1_7_0::Identifier>,
56    /// The key usage extension, which defines the purpose of the public keys in this certificate.
57    #[serde(rename = "KeyUsage")]
58    #[serde(default, skip_serializing_if = "Option::is_none")]
59    pub key_usage: Option<Vec<models::certificate::KeyUsage>>,
60    #[serde(rename = "Links")]
61    #[serde(default, skip_serializing_if = "Option::is_none")]
62    pub links: Option<models::certificate::v1_7_0::Links>,
63    #[serde(rename = "Name")]
64    #[serde(skip_deserializing)]
65    pub name: models::resource::Name,
66    #[serde(rename = "Oem")]
67    #[serde(default, skip_serializing_if = "Option::is_none")]
68    pub oem: Option<models::resource::Oem>,
69    #[serde(rename = "SPDM")]
70    #[serde(default, skip_serializing_if = "Option::is_none")]
71    pub spdm: Option<models::certificate::v1_7_0::SPDM>,
72    /// The serial number of the certificate.
73    #[serde(rename = "SerialNumber")]
74    #[serde(default, skip_serializing_if = "Option::is_none")]
75    pub serial_number: Option<String>,
76    /// The algorithm used for creating the signature of the certificate.
77    #[serde(rename = "SignatureAlgorithm")]
78    #[serde(default, skip_serializing_if = "Option::is_none")]
79    pub signature_algorithm: Option<String>,
80    #[serde(rename = "Subject")]
81    #[serde(default, skip_serializing_if = "Option::is_none")]
82    pub subject: Option<models::certificate::v1_7_0::Identifier>,
83    /// The UEFI signature owner for this certificate.
84    #[serde(rename = "UefiSignatureOwner")]
85    #[serde(default, skip_serializing_if = "Option::is_none")]
86    pub uefi_signature_owner: Option<String>,
87    /// The date when the certificate is no longer valid.
88    #[serde(rename = "ValidNotAfter")]
89    #[serde(default, skip_serializing_if = "Option::is_none")]
90    pub valid_not_after: Option<String>,
91    /// The date when the certificate becomes valid.
92    #[serde(rename = "ValidNotBefore")]
93    #[serde(default, skip_serializing_if = "Option::is_none")]
94    pub valid_not_before: Option<String>,
95}
96
97impl crate::Metadata<'static> for Certificate {
98    const JSON_SCHEMA: &'static str = "Certificate.v1_7_0.json";
99}