v2_roles_UpdateRole/
v2_roles_UpdateRole.rs

1// Update a role returns "OK" response
2use 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    // there is a valid "role" in the system
16    let role_data_id = std::env::var("ROLE_DATA_ID").unwrap();
17
18    // there is a valid "permission" in the system
19    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}