use std::rc::Rc;
use std::borrow::Borrow;
#[allow(unused_imports)]
use std::option::Option;
use hyper;
use serde_json;
use futures::Future;
use super::{Error, configuration};
use super::request as __internal_request;
pub struct WebhookControllerApiClient<C: hyper::client::Connect> {
configuration: Rc<configuration::Configuration<C>>,
}
impl<C: hyper::client::Connect> WebhookControllerApiClient<C> {
pub fn new(configuration: Rc<configuration::Configuration<C>>) -> WebhookControllerApiClient<C> {
WebhookControllerApiClient {
configuration,
}
}
}
pub trait WebhookControllerApi {
fn create_webhook(&self, inbox_id: &str, webhook_options: crate::models::CreateWebhookOptions) -> Box<dyn Future<Item = crate::models::WebhookDto, Error = Error<serde_json::Value>>>;
fn delete_webhook(&self, inbox_id: &str, webhook_id: &str) -> Box<dyn Future<Item = (), Error = Error<serde_json::Value>>>;
fn get_all_webhooks(&self, page: Option<i32>, size: Option<i32>, sort: Option<&str>) -> Box<dyn Future<Item = crate::models::PageWebhookProjection, Error = Error<serde_json::Value>>>;
fn get_webhook(&self, webhook_id: &str) -> Box<dyn Future<Item = crate::models::WebhookDto, Error = Error<serde_json::Value>>>;
fn get_webhooks(&self, inbox_id: &str) -> Box<dyn Future<Item = Vec<crate::models::WebhookDto>, Error = Error<serde_json::Value>>>;
fn send_test_data(&self, webhook_id: &str) -> Box<dyn Future<Item = crate::models::WebhookTestResult, Error = Error<serde_json::Value>>>;
}
impl<C: hyper::client::Connect>WebhookControllerApi for WebhookControllerApiClient<C> {
fn create_webhook(&self, inbox_id: &str, webhook_options: crate::models::CreateWebhookOptions) -> Box<dyn Future<Item = crate::models::WebhookDto, Error = Error<serde_json::Value>>> {
let mut req = __internal_request::Request::new(hyper::Method::Post, "/inboxes/{inboxId}/webhooks".to_string())
.with_auth(__internal_request::Auth::ApiKey(__internal_request::ApiKey{
in_header: true,
in_query: false,
param_name: "x-api-key".to_owned(),
}))
;
req = req.with_path_param("inboxId".to_string(), inbox_id.to_string());
req = req.with_body_param(webhook_options);
req.execute(self.configuration.borrow())
}
fn delete_webhook(&self, inbox_id: &str, webhook_id: &str) -> Box<dyn Future<Item = (), Error = Error<serde_json::Value>>> {
let mut req = __internal_request::Request::new(hyper::Method::Delete, "/inboxes/{inboxId}/webhooks/{webhookId}".to_string())
.with_auth(__internal_request::Auth::ApiKey(__internal_request::ApiKey{
in_header: true,
in_query: false,
param_name: "x-api-key".to_owned(),
}))
;
req = req.with_path_param("inboxId".to_string(), inbox_id.to_string());
req = req.with_path_param("webhookId".to_string(), webhook_id.to_string());
req = req.returns_nothing();
req.execute(self.configuration.borrow())
}
fn get_all_webhooks(&self, page: Option<i32>, size: Option<i32>, sort: Option<&str>) -> Box<dyn Future<Item = crate::models::PageWebhookProjection, Error = Error<serde_json::Value>>> {
let mut req = __internal_request::Request::new(hyper::Method::Get, "/webhooks/paginated".to_string())
.with_auth(__internal_request::Auth::ApiKey(__internal_request::ApiKey{
in_header: true,
in_query: false,
param_name: "x-api-key".to_owned(),
}))
;
if let Some(ref s) = page {
req = req.with_query_param("page".to_string(), s.to_string());
}
if let Some(ref s) = size {
req = req.with_query_param("size".to_string(), s.to_string());
}
if let Some(ref s) = sort {
req = req.with_query_param("sort".to_string(), s.to_string());
}
req.execute(self.configuration.borrow())
}
fn get_webhook(&self, webhook_id: &str) -> Box<dyn Future<Item = crate::models::WebhookDto, Error = Error<serde_json::Value>>> {
let mut req = __internal_request::Request::new(hyper::Method::Get, "/webhooks/{webhookId}".to_string())
.with_auth(__internal_request::Auth::ApiKey(__internal_request::ApiKey{
in_header: true,
in_query: false,
param_name: "x-api-key".to_owned(),
}))
;
req = req.with_path_param("webhookId".to_string(), webhook_id.to_string());
req.execute(self.configuration.borrow())
}
fn get_webhooks(&self, inbox_id: &str) -> Box<dyn Future<Item = Vec<crate::models::WebhookDto>, Error = Error<serde_json::Value>>> {
let mut req = __internal_request::Request::new(hyper::Method::Get, "/inboxes/{inboxId}/webhooks".to_string())
.with_auth(__internal_request::Auth::ApiKey(__internal_request::ApiKey{
in_header: true,
in_query: false,
param_name: "x-api-key".to_owned(),
}))
;
req = req.with_path_param("inboxId".to_string(), inbox_id.to_string());
req.execute(self.configuration.borrow())
}
fn send_test_data(&self, webhook_id: &str) -> Box<dyn Future<Item = crate::models::WebhookTestResult, Error = Error<serde_json::Value>>> {
let mut req = __internal_request::Request::new(hyper::Method::Post, "/webhooks/{webhookId}/test".to_string())
.with_auth(__internal_request::Auth::ApiKey(__internal_request::ApiKey{
in_header: true,
in_query: false,
param_name: "x-api-key".to_owned(),
}))
;
req = req.with_path_param("webhookId".to_string(), webhook_id.to_string());
req.execute(self.configuration.borrow())
}
}