#![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 StarringClient {
inner: HttpInner,
}
impl StarringClient {
pub fn new(inner: HttpInner) -> Self {
Self { inner }
}
pub async fn get_user_all_stared_repos(
&self,
query: &GetUserAllStaredReposQuery,
) -> Result<Vec<crate::models::Repos4User>> {
let path = "/user/stared-repos".to_string();
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.search {
pairs.append_pair("search", v);
}
if let Some(ref v) = query.flags {
pairs.append_pair("flags", v);
}
if let Some(ref v) = query.flags_match {
pairs.append_pair("flags_match", v);
}
if let Some(ref v) = query.status {
pairs.append_pair("status", v);
}
if let Some(v) = query.desc {
pairs.append_pair("desc", &v.to_string());
}
if let Some(ref v) = query.order_by {
pairs.append_pair("order_by", v);
}
drop(pairs);
}
self.inner
.execute::<Vec<crate::models::Repos4User>>(Method::GET, url)
.await
}
pub async fn get_user_stared_repos(
&self,
username: String,
query: &GetUserStaredReposQuery,
) -> Result<Vec<crate::models::Repos4User>> {
let path = format!("/users/{}/stared-repos", username);
let mut url = self.inner.url(&path)?;
{
let mut pairs = url.query_pairs_mut();
if let Some(ref v) = query.search {
pairs.append_pair("search", v);
}
if let Some(ref v) = query.flags {
pairs.append_pair("flags", v);
}
if let Some(ref v) = query.flags_match {
pairs.append_pair("flags_match", v);
}
if let Some(ref v) = query.status {
pairs.append_pair("status", v);
}
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(v) = query.desc {
pairs.append_pair("desc", &v.to_string());
}
if let Some(ref v) = query.order_by {
pairs.append_pair("order_by", v);
}
drop(pairs);
}
self.inner
.execute::<Vec<crate::models::Repos4User>>(Method::GET, url)
.await
}
pub async fn list_star_users(
&self,
slug: String,
query: &ListStarUsersQuery,
) -> Result<crate::models::RepoStarUsers> {
let path = format!("/{}/-/stars", slug);
let mut url = self.inner.url(&path)?;
{
let mut pairs = url.query_pairs_mut();
if let Some(ref v) = query.filter_type {
pairs.append_pair("filter_type", v);
}
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());
}
drop(pairs);
}
self.inner
.execute::<crate::models::RepoStarUsers>(Method::GET, url)
.await
}
}
#[derive(Debug, Clone, Default, Serialize)]
pub struct GetUserAllStaredReposQuery {
#[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 search: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub flags: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub flags_match: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub status: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub desc: Option<bool>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub order_by: Option<String>,
}
impl GetUserAllStaredReposQuery {
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 search(mut self, v: impl Into<String>) -> Self {
self.search = Some(v.into());
self
}
pub fn flags(mut self, v: impl Into<String>) -> Self {
self.flags = Some(v.into());
self
}
pub fn flags_match(mut self, v: impl Into<String>) -> Self {
self.flags_match = Some(v.into());
self
}
pub fn status(mut self, v: impl Into<String>) -> Self {
self.status = Some(v.into());
self
}
pub fn desc(mut self, v: impl Into<bool>) -> Self {
self.desc = Some(v.into());
self
}
pub fn order_by(mut self, v: impl Into<String>) -> Self {
self.order_by = Some(v.into());
self
}
}
#[derive(Debug, Clone, Default, Serialize)]
pub struct GetUserStaredReposQuery {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub search: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub flags: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub flags_match: Option<String>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub status: Option<String>,
#[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 desc: Option<bool>,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub order_by: Option<String>,
}
impl GetUserStaredReposQuery {
pub fn new() -> Self {
Self::default()
}
pub fn search(mut self, v: impl Into<String>) -> Self {
self.search = Some(v.into());
self
}
pub fn flags(mut self, v: impl Into<String>) -> Self {
self.flags = Some(v.into());
self
}
pub fn flags_match(mut self, v: impl Into<String>) -> Self {
self.flags_match = Some(v.into());
self
}
pub fn status(mut self, v: impl Into<String>) -> Self {
self.status = Some(v.into());
self
}
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 desc(mut self, v: impl Into<bool>) -> Self {
self.desc = Some(v.into());
self
}
pub fn order_by(mut self, v: impl Into<String>) -> Self {
self.order_by = Some(v.into());
self
}
}
#[derive(Debug, Clone, Default, Serialize)]
pub struct ListStarUsersQuery {
#[serde(default, skip_serializing_if = "Option::is_none")]
pub filter_type: Option<String>,
#[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>,
}
impl ListStarUsersQuery {
pub fn new() -> Self {
Self::default()
}
pub fn filter_type(mut self, v: impl Into<String>) -> Self {
self.filter_type = Some(v.into());
self
}
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
}
}