#![allow(unused_imports)]
#![cfg_attr(rustfmt, rustfmt_skip)]
use crate::{Client, ClientBuilder, Credentials, Retry};
use anyhow::Error;
use serde_json::Value;
use std::time::Duration;
use crate::util::urlencode;
pub struct PurgeCache (Client);
#[allow(non_snake_case)]
impl PurgeCache {
pub fn new<CB: Into<ClientBuilder>>(client_builder: CB) -> Result<Self, Error> {
Ok(Self(client_builder
.into()
.path_prefix("api/purge-cache/v1/")
.build()?))
}
pub async fn ping(&self) -> Result<(), Error> {
let method = "GET";
let (path, query) = Self::ping_details();
let body = None;
let resp = self.0.request(method, path, query, body).await?;
resp.bytes().await?;
Ok(())
}
pub fn ping_url(&self) -> Result<String, Error> {
let (path, query) = Self::ping_details();
self.0.make_url(path, query)
}
pub fn ping_signed_url(&self, ttl: Duration) -> Result<String, Error> {
let (path, query) = Self::ping_details();
self.0.make_signed_url(path, query, ttl)
}
fn ping_details<'a>() -> (&'static str, Option<Vec<(&'static str, &'a str)>>) {
let path = "ping";
let query = None;
(path, query)
}
pub async fn purgeCache(&self, workerPoolId: &str, payload: &Value) -> Result<(), Error> {
let method = "POST";
let (path, query) = Self::purgeCache_details(workerPoolId);
let body = Some(payload);
let resp = self.0.request(method, &path, query, body).await?;
resp.bytes().await?;
Ok(())
}
fn purgeCache_details<'a>(workerPoolId: &'a str) -> (String, Option<Vec<(&'static str, &'a str)>>) {
let path = format!("purge-cache/{}", urlencode(workerPoolId));
let query = None;
(path, query)
}
pub async fn allPurgeRequests(&self, continuationToken: Option<&str>, limit: Option<&str>) -> Result<Value, Error> {
let method = "GET";
let (path, query) = Self::allPurgeRequests_details(continuationToken, limit);
let body = None;
let resp = self.0.request(method, path, query, body).await?;
Ok(resp.json().await?)
}
pub fn allPurgeRequests_url(&self, continuationToken: Option<&str>, limit: Option<&str>) -> Result<String, Error> {
let (path, query) = Self::allPurgeRequests_details(continuationToken, limit);
self.0.make_url(path, query)
}
pub fn allPurgeRequests_signed_url(&self, continuationToken: Option<&str>, limit: Option<&str>, ttl: Duration) -> Result<String, Error> {
let (path, query) = Self::allPurgeRequests_details(continuationToken, limit);
self.0.make_signed_url(path, query, ttl)
}
fn allPurgeRequests_details<'a>(continuationToken: Option<&'a str>, limit: Option<&'a str>) -> (&'static str, Option<Vec<(&'static str, &'a str)>>) {
let path = "purge-cache/list";
let mut query = None;
if let Some(q) = continuationToken {
query.get_or_insert_with(Vec::new).push(("continuationToken", q));
}
if let Some(q) = limit {
query.get_or_insert_with(Vec::new).push(("limit", q));
}
(path, query)
}
pub async fn purgeRequests(&self, workerPoolId: &str, since: Option<&str>) -> Result<Value, Error> {
let method = "GET";
let (path, query) = Self::purgeRequests_details(workerPoolId, since);
let body = None;
let resp = self.0.request(method, &path, query, body).await?;
Ok(resp.json().await?)
}
pub fn purgeRequests_url(&self, workerPoolId: &str, since: Option<&str>) -> Result<String, Error> {
let (path, query) = Self::purgeRequests_details(workerPoolId, since);
self.0.make_url(&path, query)
}
pub fn purgeRequests_signed_url(&self, workerPoolId: &str, since: Option<&str>, ttl: Duration) -> Result<String, Error> {
let (path, query) = Self::purgeRequests_details(workerPoolId, since);
self.0.make_signed_url(&path, query, ttl)
}
fn purgeRequests_details<'a>(workerPoolId: &'a str, since: Option<&'a str>) -> (String, Option<Vec<(&'static str, &'a str)>>) {
let path = format!("purge-cache/{}", urlencode(workerPoolId));
let mut query = None;
if let Some(q) = since {
query.get_or_insert_with(Vec::new).push(("since", q));
}
(path, query)
}
}