1use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct DynamicSecretCreateGcp {
17 #[serde(rename = "access-type", skip_serializing_if = "Option::is_none")]
18 pub access_type: Option<String>,
19 #[serde(rename = "custom-username-template", skip_serializing_if = "Option::is_none")]
21 pub custom_username_template: Option<String>,
22 #[serde(rename = "delete_protection", skip_serializing_if = "Option::is_none")]
24 pub delete_protection: Option<String>,
25 #[serde(rename = "description", skip_serializing_if = "Option::is_none")]
27 pub description: Option<String>,
28 #[serde(rename = "fixed-user-claim-keyname", skip_serializing_if = "Option::is_none")]
30 pub fixed_user_claim_keyname: Option<String>,
31 #[serde(rename = "gcp-cred-type", skip_serializing_if = "Option::is_none")]
32 pub gcp_cred_type: Option<String>,
33 #[serde(rename = "gcp-key", skip_serializing_if = "Option::is_none")]
35 pub gcp_key: Option<String>,
36 #[serde(rename = "gcp-key-algo", skip_serializing_if = "Option::is_none")]
38 pub gcp_key_algo: Option<String>,
39 #[serde(rename = "gcp-project-id", skip_serializing_if = "Option::is_none")]
41 pub gcp_project_id: Option<String>,
42 #[serde(rename = "gcp-sa-email", skip_serializing_if = "Option::is_none")]
44 pub gcp_sa_email: Option<String>,
45 #[serde(rename = "gcp-token-scopes", skip_serializing_if = "Option::is_none")]
47 pub gcp_token_scopes: Option<String>,
48 #[serde(rename = "item-custom-fields", skip_serializing_if = "Option::is_none")]
50 pub item_custom_fields: Option<std::collections::HashMap<String, String>>,
51 #[serde(rename = "json", skip_serializing_if = "Option::is_none")]
53 pub json: Option<bool>,
54 #[serde(rename = "name")]
56 pub name: String,
57 #[serde(rename = "producer-encryption-key-name", skip_serializing_if = "Option::is_none")]
59 pub producer_encryption_key_name: Option<String>,
60 #[serde(rename = "role-binding", skip_serializing_if = "Option::is_none")]
62 pub role_binding: Option<String>,
63 #[serde(rename = "role-names", skip_serializing_if = "Option::is_none")]
65 pub role_names: Option<String>,
66 #[serde(rename = "secure-access-delay", skip_serializing_if = "Option::is_none")]
68 pub secure_access_delay: Option<i64>,
69 #[serde(rename = "secure-access-enable", skip_serializing_if = "Option::is_none")]
71 pub secure_access_enable: Option<String>,
72 #[serde(rename = "secure-access-url", skip_serializing_if = "Option::is_none")]
74 pub secure_access_url: Option<String>,
75 #[serde(rename = "secure-access-web-browsing", skip_serializing_if = "Option::is_none")]
77 pub secure_access_web_browsing: Option<bool>,
78 #[serde(rename = "secure-access-web-proxy", skip_serializing_if = "Option::is_none")]
80 pub secure_access_web_proxy: Option<bool>,
81 #[serde(rename = "service-account-type", skip_serializing_if = "Option::is_none")]
83 pub service_account_type: Option<String>,
84 #[serde(rename = "tags", skip_serializing_if = "Option::is_none")]
86 pub tags: Option<Vec<String>>,
87 #[serde(rename = "target-name", skip_serializing_if = "Option::is_none")]
89 pub target_name: Option<String>,
90 #[serde(rename = "token", skip_serializing_if = "Option::is_none")]
92 pub token: Option<String>,
93 #[serde(rename = "uid-token", skip_serializing_if = "Option::is_none")]
95 pub uid_token: Option<String>,
96 #[serde(rename = "user-ttl", skip_serializing_if = "Option::is_none")]
98 pub user_ttl: Option<String>,
99}
100
101impl DynamicSecretCreateGcp {
102 pub fn new(name: String) -> DynamicSecretCreateGcp {
104 DynamicSecretCreateGcp {
105 access_type: None,
106 custom_username_template: None,
107 delete_protection: None,
108 description: None,
109 fixed_user_claim_keyname: None,
110 gcp_cred_type: None,
111 gcp_key: None,
112 gcp_key_algo: None,
113 gcp_project_id: None,
114 gcp_sa_email: None,
115 gcp_token_scopes: None,
116 item_custom_fields: None,
117 json: None,
118 name,
119 producer_encryption_key_name: None,
120 role_binding: None,
121 role_names: None,
122 secure_access_delay: None,
123 secure_access_enable: None,
124 secure_access_url: None,
125 secure_access_web_browsing: None,
126 secure_access_web_proxy: None,
127 service_account_type: None,
128 tags: None,
129 target_name: None,
130 token: None,
131 uid_token: None,
132 user_ttl: None,
133 }
134 }
135}
136