v2_roles_UpdateRole/
v2_roles_UpdateRole.rs1use datadog_api_client::datadog;
3use datadog_api_client::datadogV2::api_roles::RolesAPI;
4use datadog_api_client::datadogV2::model::PermissionsType;
5use datadog_api_client::datadogV2::model::RelationshipToPermissionData;
6use datadog_api_client::datadogV2::model::RelationshipToPermissions;
7use datadog_api_client::datadogV2::model::RoleRelationships;
8use datadog_api_client::datadogV2::model::RoleUpdateAttributes;
9use datadog_api_client::datadogV2::model::RoleUpdateData;
10use datadog_api_client::datadogV2::model::RoleUpdateRequest;
11use datadog_api_client::datadogV2::model::RolesType;
12
13#[tokio::main]
14async fn main() {
15 let role_data_id = std::env::var("ROLE_DATA_ID").unwrap();
17
18 let permission_id = std::env::var("PERMISSION_ID").unwrap();
20 let body = RoleUpdateRequest::new(
21 RoleUpdateData::new(
22 RoleUpdateAttributes::new().name("developers-updated".to_string()),
23 role_data_id.clone(),
24 RolesType::ROLES,
25 )
26 .relationships(RoleRelationships::new().permissions(
27 RelationshipToPermissions::new().data(vec![
28 RelationshipToPermissionData::new()
29 .id(permission_id.clone())
30 .type_(PermissionsType::PERMISSIONS)
31 ]),
32 )),
33 );
34 let configuration = datadog::Configuration::new();
35 let api = RolesAPI::with_config(configuration);
36 let resp = api.update_role(role_data_id.clone(), body).await;
37 if let Ok(value) = resp {
38 println!("{:#?}", value);
39 } else {
40 println!("{:#?}", resp.unwrap_err());
41 }
42}