#![allow(clippy::all)]
#![allow(missing_docs)]
#![allow(unused_imports)]
#![allow(unused_mut)]
use reqwest::Method;
use serde::Serialize;
use crate::error::{ApiError, Result};
use crate::http::HttpInner;
use crate::models;
#[derive(Debug, Clone)]
pub struct MissionsClient {
inner: HttpInner,
}
impl MissionsClient {
pub fn new(inner: HttpInner) -> Self {
Self { inner }
}
pub async fn create_mission(
&self,
slug: String,
body: &crate::models::CreateMissionReq,
) -> Result<serde_json::Value> {
let path = format!("/{}/-/missions", slug);
let mut url = self.inner.url(&path)?;
self.inner
.execute_with_body::<serde_json::Value, _>(Method::POST, url, body)
.await
}
pub async fn delete_mission(&self, mission: String) -> Result<serde_json::Value> {
let path = format!("/{}", mission);
let mut url = self.inner.url(&path)?;
self.inner
.execute::<serde_json::Value>(Method::DELETE, url)
.await
}
pub async fn get_group_sub_missions(
&self,
slug: String,
query: &GetGroupSubMissionsQuery,
) -> Result<Vec<crate::models::Missions4User>> {
let path = format!("/{}/-/missions", slug);
let mut url = self.inner.url(&path)?;
{
let mut pairs = url.query_pairs_mut();
if let Some(v) = query.page {
pairs.append_pair("page", &v.to_string());
}
if let Some(v) = query.page_size {
pairs.append_pair("page_size", &v.to_string());
}
if let Some(ref v) = query.filter_type {
pairs.append_pair("filter_type", v);
}
if let Some(ref v) = query.order_by {
pairs.append_pair("order_by", v);
}
if let Some(v) = query.desc {
pairs.append_pair("desc", &v.to_string());
}
if let Some(ref v) = query.descendant {
pairs.append_pair("descendant", v);
}
if let Some(ref v) = query.search {
pairs.append_pair("search", v);
}
drop(pairs);
}
self.inner
.execute::<Vec<crate::models::Missions4User>>(Method::GET, url)
.await
}
pub async fn get_mission_view_config(
&self,
mission: String,
query: &GetMissionViewConfigQuery,
) -> Result<crate::models::MissionViewConfig> {
let path = format!("/{}/-/mission/view", mission);
let mut url = self.inner.url(&path)?;
{
let mut pairs = url.query_pairs_mut();
if let Some(ref v) = query.id {
pairs.append_pair("id", v);
}
drop(pairs);
}
self.inner
.execute::<crate::models::MissionViewConfig>(Method::GET, url)
.await
}
pub async fn get_mission_view_list(
&self,
mission: String,
) -> Result<Vec<crate::models::MissionView>> {
let path = format!("/{}/-/mission/view-list", mission);
let mut url = self.inner.url(&path)?;
self.inner
.execute::<Vec<crate::models::MissionView>>(Method::GET, url)
.await
}
pub async fn post_mission_view_config(
&self,
mission: String,
body: &crate::models::MissionViewConfig,
) -> Result<serde_json::Value> {
let path = format!("/{}/-/mission/view", mission);
let mut url = self.inner.url(&path)?;
self.inner
.execute_with_body::<serde_json::Value, _>(Method::POST, url, body)
.await
}
pub async fn post_mission_view_list(
&self,
mission: String,
body: &crate::models::MissionPostViewReq,
) -> Result<serde_json::Value> {
let path = format!("/{}/-/mission/view-list", mission);
let mut url = self.inner.url(&path)?;
self.inner
.execute_with_body::<serde_json::Value, _>(Method::POST, url, body)
.await
}
pub async fn put_mission_view_list(
&self,
mission: String,
body: &crate::models::MissionView,
) -> Result<serde_json::Value> {
let path = format!("/{}/-/mission/view-list", mission);
let mut url = self.inner.url(&path)?;
self.inner
.execute_with_body::<serde_json::Value, _>(Method::PUT, url, body)
.await
}
pub async fn set_mission_visibility(
&self,
mission: String,
query: &SetMissionVisibilityQuery,
) -> Result<serde_json::Value> {
let path = format!("/{}/-/settings/set_visibility", mission);
let mut url = self.inner.url(&path)?;
{
let mut pairs = url.query_pairs_mut();
if let Some(ref v) = query.visibility {
pairs.append_pair("visibility", v);
}
drop(pairs);
}
self.inner
.execute::<serde_json::Value>(Method::POST, url)
.await
}
}
#[derive(Debug, Clone, Default, Serialize)]
pub struct GetGroupSubMissionsQuery {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub page: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub page_size: Option<i64>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub filter_type: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub order_by: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub desc: Option<bool>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub descendant: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub search: Option<String>,
}
impl GetGroupSubMissionsQuery {
pub fn new() -> Self {
Self::default()
}
pub fn page(mut self, v: impl Into<i64>) -> Self {
self.page = Some(v.into());
self
}
pub fn page_size(mut self, v: impl Into<i64>) -> Self {
self.page_size = Some(v.into());
self
}
pub fn filter_type(mut self, v: impl Into<String>) -> Self {
self.filter_type = Some(v.into());
self
}
pub fn order_by(mut self, v: impl Into<String>) -> Self {
self.order_by = Some(v.into());
self
}
pub fn desc(mut self, v: impl Into<bool>) -> Self {
self.desc = Some(v.into());
self
}
pub fn descendant(mut self, v: impl Into<String>) -> Self {
self.descendant = Some(v.into());
self
}
pub fn search(mut self, v: impl Into<String>) -> Self {
self.search = Some(v.into());
self
}
}
#[derive(Debug, Clone, Default, Serialize)]
pub struct GetMissionViewConfigQuery {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub id: Option<String>,
}
impl GetMissionViewConfigQuery {
pub fn new() -> Self {
Self::default()
}
pub fn id(mut self, v: impl Into<String>) -> Self {
self.id = Some(v.into());
self
}
}
#[derive(Debug, Clone, Default, Serialize)]
pub struct SetMissionVisibilityQuery {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub visibility: Option<String>,
}
impl SetMissionVisibilityQuery {
pub fn new() -> Self {
Self::default()
}
pub fn visibility(mut self, v: impl Into<String>) -> Self {
self.visibility = Some(v.into());
self
}
}