gcloud_storage/http/bucket_access_controls/
patch.rs

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