gcloud_storage/http/bucket_access_controls/
insert.rs1use 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 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 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}