#[non_exhaustive]pub struct Workload {Show 16 fields
pub name: String,
pub display_name: String,
pub resources: Vec<ResourceInfo>,
pub compliance_regime: ComplianceRegime,
pub create_time: Option<Timestamp>,
pub billing_account: String,
pub etag: String,
pub labels: HashMap<String, String>,
pub provisioned_resources_parent: String,
pub kms_settings: Option<KMSSettings>,
pub resource_settings: Vec<ResourceSettings>,
pub kaj_enrollment_state: KajEnrollmentState,
pub enable_sovereign_controls: bool,
pub saa_enrollment_response: Option<SaaEnrollmentResponse>,
pub compliant_but_disallowed_services: Vec<String>,
pub partner: Partner,
/* private fields */
}Expand description
A Workload object for managing highly regulated workloads of cloud customers.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.name: StringOptional. The resource name of the workload. Format: organizations/{organization}/locations/{location}/workloads/{workload}
Read-only.
display_name: StringRequired. The user-assigned display name of the Workload. When present it must be between 4 to 30 characters. Allowed characters are: lowercase and uppercase letters, numbers, hyphen, and spaces.
Example: My Workload
resources: Vec<ResourceInfo>Output only. The resources associated with this workload. These resources will be created when creating the workload. If any of the projects already exist, the workload creation will fail. Always read only.
compliance_regime: ComplianceRegimeRequired. Immutable. Compliance Regime associated with this workload.
create_time: Option<Timestamp>Output only. Immutable. The Workload creation timestamp.
billing_account: StringOptional. The billing account used for the resources which are
direct children of workload. This billing account is initially associated
with the resources created as part of Workload creation.
After the initial creation of these resources, the customer can change
the assigned billing account.
The resource name has the form
billingAccounts/{billing_account_id}. For example,
billingAccounts/012345-567890-ABCDEF.
etag: StringOptional. ETag of the workload, it is calculated on the basis of the Workload contents. It will be used in Update & Delete operations.
labels: HashMap<String, String>Optional. Labels applied to the workload.
provisioned_resources_parent: StringInput only. The parent resource for the resources managed by this Assured Workload. May be either empty or a folder resource which is a child of the Workload parent. If not specified all resources are created under the parent organization. Format: folders/{folder_id}
kms_settings: Option<KMSSettings>Input only. Settings used to create a CMEK crypto key. When set, a project with a KMS CMEK key is provisioned. This field is deprecated as of Feb 28, 2022. In order to create a Keyring, callers should specify, ENCRYPTION_KEYS_PROJECT or KEYRING in ResourceSettings.resource_type field.
resource_settings: Vec<ResourceSettings>Input only. Resource properties that are used to customize workload resources. These properties (such as custom project id) will be used to create workload resources if possible. This field is optional.
kaj_enrollment_state: KajEnrollmentStateOutput only. Represents the KAJ enrollment state of the given workload.
enable_sovereign_controls: boolOptional. Indicates the sovereignty status of the given workload. Currently meant to be used by Europe/Canada customers.
saa_enrollment_response: Option<SaaEnrollmentResponse>Output only. Represents the SAA enrollment response of the given workload. SAA enrollment response is queried during GetWorkload call. In failure cases, user friendly error message is shown in SAA details page.
compliant_but_disallowed_services: Vec<String>Output only. Urls for services which are compliant for this Assured Workload, but which are currently disallowed by the ResourceUsageRestriction org policy. Invoke RestrictAllowedResources endpoint to allow your project developers to use these services in their environment.“
partner: PartnerOptional. Compliance Regime associated with this workload.
Implementations§
Source§impl Workload
impl Workload
pub fn new() -> Self
Sourcepub fn set_display_name<T: Into<String>>(self, v: T) -> Self
pub fn set_display_name<T: Into<String>>(self, v: T) -> Self
Sourcepub fn set_resources<T, V>(self, v: T) -> Self
pub fn set_resources<T, V>(self, v: T) -> Self
Sourcepub fn set_compliance_regime<T: Into<ComplianceRegime>>(self, v: T) -> Self
pub fn set_compliance_regime<T: Into<ComplianceRegime>>(self, v: T) -> Self
Sets the value of compliance_regime.
§Example
use google_cloud_assuredworkloads_v1::model::workload::ComplianceRegime;
let x0 = Workload::new().set_compliance_regime(ComplianceRegime::Il4);
let x1 = Workload::new().set_compliance_regime(ComplianceRegime::Cjis);
let x2 = Workload::new().set_compliance_regime(ComplianceRegime::FedrampHigh);Sourcepub fn set_create_time<T>(self, v: T) -> Self
pub fn set_create_time<T>(self, v: T) -> Self
Sets the value of create_time.
§Example
use wkt::Timestamp;
let x = Workload::new().set_create_time(Timestamp::default()/* use setters */);Sourcepub fn set_or_clear_create_time<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_create_time<T>(self, v: Option<T>) -> Self
Sets or clears the value of create_time.
§Example
use wkt::Timestamp;
let x = Workload::new().set_or_clear_create_time(Some(Timestamp::default()/* use setters */));
let x = Workload::new().set_or_clear_create_time(None::<Timestamp>);Sourcepub fn set_billing_account<T: Into<String>>(self, v: T) -> Self
pub fn set_billing_account<T: Into<String>>(self, v: T) -> Self
Sets the value of billing_account.
§Example
let x = Workload::new().set_billing_account("example");Sourcepub fn set_labels<T, K, V>(self, v: T) -> Self
pub fn set_labels<T, K, V>(self, v: T) -> Self
Sourcepub fn set_provisioned_resources_parent<T: Into<String>>(self, v: T) -> Self
pub fn set_provisioned_resources_parent<T: Into<String>>(self, v: T) -> Self
Sets the value of provisioned_resources_parent.
§Example
let x = Workload::new().set_provisioned_resources_parent("example");Sourcepub fn set_kms_settings<T>(self, v: T) -> Selfwhere
T: Into<KMSSettings>,
👎Deprecated
pub fn set_kms_settings<T>(self, v: T) -> Selfwhere
T: Into<KMSSettings>,
Sets the value of kms_settings.
§Example
use google_cloud_assuredworkloads_v1::model::workload::KMSSettings;
let x = Workload::new().set_kms_settings(KMSSettings::default()/* use setters */);Sourcepub fn set_or_clear_kms_settings<T>(self, v: Option<T>) -> Selfwhere
T: Into<KMSSettings>,
👎Deprecated
pub fn set_or_clear_kms_settings<T>(self, v: Option<T>) -> Selfwhere
T: Into<KMSSettings>,
Sets or clears the value of kms_settings.
§Example
use google_cloud_assuredworkloads_v1::model::workload::KMSSettings;
let x = Workload::new().set_or_clear_kms_settings(Some(KMSSettings::default()/* use setters */));
let x = Workload::new().set_or_clear_kms_settings(None::<KMSSettings>);Sourcepub fn set_resource_settings<T, V>(self, v: T) -> Self
pub fn set_resource_settings<T, V>(self, v: T) -> Self
Sets the value of resource_settings.
§Example
use google_cloud_assuredworkloads_v1::model::workload::ResourceSettings;
let x = Workload::new()
.set_resource_settings([
ResourceSettings::default()/* use setters */,
ResourceSettings::default()/* use (different) setters */,
]);Sourcepub fn set_kaj_enrollment_state<T: Into<KajEnrollmentState>>(self, v: T) -> Self
pub fn set_kaj_enrollment_state<T: Into<KajEnrollmentState>>(self, v: T) -> Self
Sets the value of kaj_enrollment_state.
§Example
use google_cloud_assuredworkloads_v1::model::workload::KajEnrollmentState;
let x0 = Workload::new().set_kaj_enrollment_state(KajEnrollmentState::Pending);
let x1 = Workload::new().set_kaj_enrollment_state(KajEnrollmentState::Complete);Sourcepub fn set_enable_sovereign_controls<T: Into<bool>>(self, v: T) -> Self
pub fn set_enable_sovereign_controls<T: Into<bool>>(self, v: T) -> Self
Sets the value of enable_sovereign_controls.
§Example
let x = Workload::new().set_enable_sovereign_controls(true);Sourcepub fn set_saa_enrollment_response<T>(self, v: T) -> Selfwhere
T: Into<SaaEnrollmentResponse>,
pub fn set_saa_enrollment_response<T>(self, v: T) -> Selfwhere
T: Into<SaaEnrollmentResponse>,
Sets the value of saa_enrollment_response.
§Example
use google_cloud_assuredworkloads_v1::model::workload::SaaEnrollmentResponse;
let x = Workload::new().set_saa_enrollment_response(SaaEnrollmentResponse::default()/* use setters */);Sourcepub fn set_or_clear_saa_enrollment_response<T>(self, v: Option<T>) -> Selfwhere
T: Into<SaaEnrollmentResponse>,
pub fn set_or_clear_saa_enrollment_response<T>(self, v: Option<T>) -> Selfwhere
T: Into<SaaEnrollmentResponse>,
Sets or clears the value of saa_enrollment_response.
§Example
use google_cloud_assuredworkloads_v1::model::workload::SaaEnrollmentResponse;
let x = Workload::new().set_or_clear_saa_enrollment_response(Some(SaaEnrollmentResponse::default()/* use setters */));
let x = Workload::new().set_or_clear_saa_enrollment_response(None::<SaaEnrollmentResponse>);Sourcepub fn set_compliant_but_disallowed_services<T, V>(self, v: T) -> Self
pub fn set_compliant_but_disallowed_services<T, V>(self, v: T) -> Self
Sets the value of compliant_but_disallowed_services.
§Example
let x = Workload::new().set_compliant_but_disallowed_services(["a", "b", "c"]);