use crate::resources::_base::{put_opt, vars};
use crate::types::{FilterConfig, ListResult, Subscription, TransformConfig};
use crate::HivehookError;
use serde::{Deserialize, Serialize};
use serde_json::Value;
const FRAGMENT: &str = "id name sourceId destinationId filterConfig { eventTypes regex bodyMatch { path value operator } rules { path operator value rules { path operator value } } } transformConfig { envelope headers } enabled createdAt";
#[non_exhaustive]
#[derive(Debug, Default, Clone)]
pub struct ListSubscriptionsOptions {
pub source_id: Option<String>,
pub destination_id: Option<String>,
pub enabled: Option<bool>,
pub search: Option<String>,
pub limit: Option<i32>,
pub offset: Option<i32>,
pub after: Option<String>,
pub first: Option<i32>,
}
#[non_exhaustive]
#[derive(Debug, Default, Clone, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct CreateSubscriptionInput {
pub name: String,
pub source_id: String,
pub destination_id: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub filter_config: Option<FilterConfig>,
#[serde(skip_serializing_if = "Option::is_none")]
pub transform_config: Option<TransformConfig>,
pub enabled: bool,
}
#[non_exhaustive]
#[derive(Debug, Default, Clone, Serialize)]
#[serde(rename_all = "camelCase")]
pub struct UpdateSubscriptionInput {
#[serde(skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub enabled: Option<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
pub filter_config: Option<FilterConfig>,
#[serde(skip_serializing_if = "Option::is_none")]
pub transform_config: Option<TransformConfig>,
}
#[derive(Deserialize)]
struct ListData {
subscriptions: ListResult<Subscription>,
}
#[derive(Deserialize)]
struct GetData {
subscription: Option<Subscription>,
}
#[derive(Deserialize)]
struct CreateData {
#[serde(rename = "createSubscription")]
create_subscription: Subscription,
}
#[derive(Deserialize)]
struct UpdateData {
#[serde(rename = "updateSubscription")]
update_subscription: Subscription,
}
#[derive(Deserialize)]
struct DeleteData {
#[serde(rename = "deleteSubscription")]
delete_subscription: bool,
}
#[cfg(feature = "blocking")]
pub struct SubscriptionService<'a> {
pub(crate) transport: &'a crate::transport::BlockingGraphQLTransport,
}
#[cfg(feature = "blocking")]
impl<'a> SubscriptionService<'a> {
pub fn list(
&self,
options: ListSubscriptionsOptions,
) -> Result<ListResult<Subscription>, HivehookError> {
let query = format!(
r#"query($sourceId: UUID, $destinationId: UUID, $enabled: Boolean, $search: String, $limit: Int, $offset: Int, $after: String, $first: Int) {{
subscriptions(sourceId: $sourceId, destinationId: $destinationId, enabled: $enabled, search: $search, limit: $limit, offset: $offset, after: $after, first: $first) {{
nodes {{ {FRAGMENT} }}
pageInfo {{ total limit offset endCursor hasNextPage }}
}}
}}"#
);
let mut v = vars();
put_opt(&mut v, "sourceId", options.source_id);
put_opt(&mut v, "destinationId", options.destination_id);
put_opt(&mut v, "enabled", options.enabled);
put_opt(&mut v, "search", options.search);
put_opt(&mut v, "limit", options.limit);
put_opt(&mut v, "offset", options.offset);
put_opt(&mut v, "after", options.after);
put_opt(&mut v, "first", options.first);
let data: ListData = self.transport.execute(&query, Some(v))?;
Ok(data.subscriptions)
}
pub fn get(&self, id: &str) -> Result<Option<Subscription>, HivehookError> {
let query = format!("query($id: UUID!) {{ subscription(id: $id) {{ {FRAGMENT} }} }}");
let mut v = vars();
v.insert("id".into(), Value::String(id.into()));
let data: GetData = self.transport.execute(&query, Some(v))?;
Ok(data.subscription)
}
pub fn create(
&self,
input: CreateSubscriptionInput,
) -> Result<Subscription, HivehookError> {
let query = format!("mutation($input: CreateSubscriptionInput!) {{ createSubscription(input: $input) {{ {FRAGMENT} }} }}");
let mut v = vars();
v.insert("input".into(), serde_json::to_value(input)?);
let data: CreateData = self.transport.execute(&query, Some(v))?;
Ok(data.create_subscription)
}
pub fn update(
&self,
id: &str,
input: UpdateSubscriptionInput,
) -> Result<Subscription, HivehookError> {
let query = format!("mutation($id: UUID!, $input: UpdateSubscriptionInput!) {{ updateSubscription(id: $id, input: $input) {{ {FRAGMENT} }} }}");
let mut v = vars();
v.insert("id".into(), Value::String(id.into()));
v.insert("input".into(), serde_json::to_value(input)?);
let data: UpdateData = self.transport.execute(&query, Some(v))?;
Ok(data.update_subscription)
}
pub fn delete(&self, id: &str) -> Result<bool, HivehookError> {
let mut v = vars();
v.insert("id".into(), Value::String(id.into()));
let data: DeleteData = self
.transport
.execute("mutation($id: UUID!) { deleteSubscription(id: $id) }", Some(v))?;
Ok(data.delete_subscription)
}
}
#[cfg(feature = "async")]
#[cfg_attr(docsrs, doc(cfg(feature = "async")))]
pub struct AsyncSubscriptionService<'a> {
pub(crate) transport: &'a crate::transport::AsyncGraphQLTransport,
}
#[cfg(feature = "async")]
impl<'a> AsyncSubscriptionService<'a> {
pub async fn list(
&self,
options: ListSubscriptionsOptions,
) -> Result<ListResult<Subscription>, HivehookError> {
let query = format!(
r#"query($sourceId: UUID, $destinationId: UUID, $enabled: Boolean, $search: String, $limit: Int, $offset: Int, $after: String, $first: Int) {{
subscriptions(sourceId: $sourceId, destinationId: $destinationId, enabled: $enabled, search: $search, limit: $limit, offset: $offset, after: $after, first: $first) {{
nodes {{ {FRAGMENT} }}
pageInfo {{ total limit offset endCursor hasNextPage }}
}}
}}"#
);
let mut v = vars();
put_opt(&mut v, "sourceId", options.source_id);
put_opt(&mut v, "destinationId", options.destination_id);
put_opt(&mut v, "enabled", options.enabled);
put_opt(&mut v, "search", options.search);
put_opt(&mut v, "limit", options.limit);
put_opt(&mut v, "offset", options.offset);
put_opt(&mut v, "after", options.after);
put_opt(&mut v, "first", options.first);
let data: ListData = self.transport.execute(&query, Some(v)).await?;
Ok(data.subscriptions)
}
pub async fn get(&self, id: &str) -> Result<Option<Subscription>, HivehookError> {
let query = format!("query($id: UUID!) {{ subscription(id: $id) {{ {FRAGMENT} }} }}");
let mut v = vars();
v.insert("id".into(), Value::String(id.into()));
let data: GetData = self.transport.execute(&query, Some(v)).await?;
Ok(data.subscription)
}
pub async fn create(
&self,
input: CreateSubscriptionInput,
) -> Result<Subscription, HivehookError> {
let query = format!("mutation($input: CreateSubscriptionInput!) {{ createSubscription(input: $input) {{ {FRAGMENT} }} }}");
let mut v = vars();
v.insert("input".into(), serde_json::to_value(input)?);
let data: CreateData = self.transport.execute(&query, Some(v)).await?;
Ok(data.create_subscription)
}
pub async fn update(
&self,
id: &str,
input: UpdateSubscriptionInput,
) -> Result<Subscription, HivehookError> {
let query = format!("mutation($id: UUID!, $input: UpdateSubscriptionInput!) {{ updateSubscription(id: $id, input: $input) {{ {FRAGMENT} }} }}");
let mut v = vars();
v.insert("id".into(), Value::String(id.into()));
v.insert("input".into(), serde_json::to_value(input)?);
let data: UpdateData = self.transport.execute(&query, Some(v)).await?;
Ok(data.update_subscription)
}
pub async fn delete(&self, id: &str) -> Result<bool, HivehookError> {
let mut v = vars();
v.insert("id".into(), Value::String(id.into()));
let data: DeleteData = self
.transport
.execute("mutation($id: UUID!) { deleteSubscription(id: $id) }", Some(v))
.await?;
Ok(data.delete_subscription)
}
}