gcloud_storage/http/bucket_access_controls/
insert.rs

1use reqwest_middleware::{ClientWithMiddleware as Client, RequestBuilder};
2
3use crate::http::bucket_access_controls::BucketACLRole;
4use crate::http::Escape;
5
6#[derive(Clone, PartialEq, Eq, serde::Deserialize, serde::Serialize, Debug)]
7#[serde(rename_all = "camelCase")]
8pub struct BucketAccessControlCreationConfig {
9    /// The entity holding the permission. Can be user-emailAddress, group-groupId, group-emailAddress, allUsers, or allAuthenticatedUsers.
10    pub entity: String,
11    pub role: BucketACLRole,
12}
13
14#[derive(Clone, PartialEq, Eq, serde::Deserialize, serde::Serialize, Debug)]
15#[serde(rename_all = "camelCase")]
16pub struct InsertBucketAccessControlRequest {
17    /// Name of a bucket.
18    pub bucket: String,
19    pub acl: BucketAccessControlCreationConfig,
20}
21
22pub fn build(base_url: &str, client: &Client, req: &InsertBucketAccessControlRequest) -> RequestBuilder {
23    let url = format!("{}/b/{}/acl", base_url, req.bucket.escape());
24    client.post(url).json(&req.acl)
25}