mirror of
https://github.com/mii443/vrchatapi-rust.git
synced 2025-08-22 15:45:35 +00:00
* add formatting Signed-off-by: C0D3 M4513R <28912031+C0D3-M4513R@users.noreply.github.com> * Apply Changes --------- Signed-off-by: C0D3 M4513R <28912031+C0D3-M4513R@users.noreply.github.com>
446 lines
18 KiB
Rust
446 lines
18 KiB
Rust
/*
|
|
* VRChat API Documentation
|
|
*
|
|
*
|
|
* Contact: vrchatapi.lpv0t@aries.fyi
|
|
* Generated by: https://openapi-generator.tech
|
|
*/
|
|
|
|
use super::{configuration, Error};
|
|
use crate::{apis::ResponseContent, models};
|
|
use reqwest;
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
/// struct for typed errors of method [`get_invite_message`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum GetInviteMessageError {
|
|
Status400(models::Error),
|
|
Status401(models::Error),
|
|
Status404(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// struct for typed errors of method [`get_invite_messages`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum GetInviteMessagesError {
|
|
Status400(models::Error),
|
|
Status401(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// struct for typed errors of method [`invite_myself_to`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum InviteMyselfToError {
|
|
Status401(models::Error),
|
|
Status404(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// struct for typed errors of method [`invite_user`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum InviteUserError {
|
|
Status403(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// struct for typed errors of method [`request_invite`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum RequestInviteError {
|
|
Status403(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// struct for typed errors of method [`reset_invite_message`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum ResetInviteMessageError {
|
|
Status400(models::Error),
|
|
Status401(models::Error),
|
|
Status404(models::Error),
|
|
Status429(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// struct for typed errors of method [`respond_invite`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum RespondInviteError {
|
|
Status400(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// struct for typed errors of method [`update_invite_message`]
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
#[serde(untagged)]
|
|
pub enum UpdateInviteMessageError {
|
|
Status400(models::Error),
|
|
Status401(models::Error),
|
|
Status429(models::Error),
|
|
UnknownValue(serde_json::Value),
|
|
}
|
|
|
|
/// Returns a single Invite Message. This returns the exact same information but less than `getInviteMessages`. Admin Credentials are required to view messages of other users! Message type refers to a different collection of messages, used during different types of responses. * `message` = Message during a normal invite * `response` = Message when replying to a message * `request` = Message when requesting an invite * `requestResponse` = Message when replying to a request for invite
|
|
pub async fn get_invite_message(
|
|
configuration: &configuration::Configuration,
|
|
user_id: &str,
|
|
message_type: models::InviteMessageType,
|
|
slot: i32,
|
|
) -> Result<models::InviteMessage, Error<GetInviteMessageError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/message/{userId}/{messageType}/{slot}",
|
|
local_var_configuration.base_path,
|
|
userId = crate::apis::urlencode(user_id),
|
|
messageType = message_type.to_string(),
|
|
slot = slot
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<GetInviteMessageError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|
|
|
|
/// Returns a list of all the users Invite Messages. Admin Credentials are required to view messages of other users! Message type refers to a different collection of messages, used during different types of responses. * `message` = Message during a normal invite * `response` = Message when replying to a message * `request` = Message when requesting an invite * `requestResponse` = Message when replying to a request for invite
|
|
pub async fn get_invite_messages(
|
|
configuration: &configuration::Configuration,
|
|
user_id: &str,
|
|
message_type: models::InviteMessageType,
|
|
) -> Result<Vec<models::InviteMessage>, Error<GetInviteMessagesError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/message/{userId}/{messageType}",
|
|
local_var_configuration.base_path,
|
|
userId = crate::apis::urlencode(user_id),
|
|
messageType = message_type.to_string()
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::GET, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<GetInviteMessagesError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|
|
|
|
/// Sends self an invite to an instance
|
|
pub async fn invite_myself_to(
|
|
configuration: &configuration::Configuration,
|
|
world_id: &str,
|
|
instance_id: &str,
|
|
) -> Result<models::SentNotification, Error<InviteMyselfToError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/invite/myself/to/{worldId}:{instanceId}",
|
|
local_var_configuration.base_path,
|
|
worldId = crate::apis::urlencode(world_id),
|
|
instanceId = crate::apis::urlencode(instance_id)
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<InviteMyselfToError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|
|
|
|
/// Sends an invite to a user. Returns the Notification of type `invite` that was sent.
|
|
pub async fn invite_user(
|
|
configuration: &configuration::Configuration,
|
|
user_id: &str,
|
|
invite_request: models::InviteRequest,
|
|
) -> Result<models::SentNotification, Error<InviteUserError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/invite/{userId}",
|
|
local_var_configuration.base_path,
|
|
userId = crate::apis::urlencode(user_id)
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
local_var_req_builder = local_var_req_builder.json(&invite_request);
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<InviteUserError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|
|
|
|
/// Requests an invite from a user. Returns the Notification of type `requestInvite` that was sent.
|
|
pub async fn request_invite(
|
|
configuration: &configuration::Configuration,
|
|
user_id: &str,
|
|
request_invite_request: Option<models::RequestInviteRequest>,
|
|
) -> Result<models::Notification, Error<RequestInviteError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/requestInvite/{userId}",
|
|
local_var_configuration.base_path,
|
|
userId = crate::apis::urlencode(user_id)
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
local_var_req_builder = local_var_req_builder.json(&request_invite_request);
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<RequestInviteError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|
|
|
|
/// Resets a single Invite Message back to its original message, and then returns a list of all of them. Admin Credentials are required to update messages of other users! Resetting a message respects the rate-limit, so it is not possible to reset within the 60 minutes countdown. Resetting it does however not set the rate-limit to 60 like when editing it. It is possible to edit it right after resetting it. Trying to edit a message before the cooldown timer expires results in a 429 \"Too Fast Error\". Message type refers to a different collection of messages, used during different types of responses. * `message` = Message during a normal invite * `response` = Message when replying to a message * `request` = Message when requesting an invite * `requestResponse` = Message when replying to a request for invite The DELETE endpoint does not have/require any request body.
|
|
pub async fn reset_invite_message(
|
|
configuration: &configuration::Configuration,
|
|
user_id: &str,
|
|
message_type: models::InviteMessageType,
|
|
slot: i32,
|
|
) -> Result<Vec<models::InviteMessage>, Error<ResetInviteMessageError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/message/{userId}/{messageType}/{slot}",
|
|
local_var_configuration.base_path,
|
|
userId = crate::apis::urlencode(user_id),
|
|
messageType = message_type.to_string(),
|
|
slot = slot
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::DELETE, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<ResetInviteMessageError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|
|
|
|
/// Respond to an invite request by sending a world invite to the requesting user. `:notificationId` is the ID of the requesting notification.
|
|
pub async fn respond_invite(
|
|
configuration: &configuration::Configuration,
|
|
notification_id: &str,
|
|
invite_response: models::InviteResponse,
|
|
) -> Result<models::Notification, Error<RespondInviteError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/invite/{notificationId}/response",
|
|
local_var_configuration.base_path,
|
|
notificationId = crate::apis::urlencode(notification_id)
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::POST, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
local_var_req_builder = local_var_req_builder.json(&invite_response);
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<RespondInviteError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|
|
|
|
/// Updates a single Invite Message and then returns a list of all of them. Admin Credentials are required to update messages of other users! Updating a message automatically sets the cooldown timer to 60 minutes. Trying to edit a message before the cooldown timer expires results in a 429 \"Too Fast Error\". Message type refers to a different collection of messages, used during different types of responses. * `message` = Message during a normal invite * `response` = Message when replying to a message * `request` = Message when requesting an invite * `requestResponse` = Message when replying to a request for invite
|
|
pub async fn update_invite_message(
|
|
configuration: &configuration::Configuration,
|
|
user_id: &str,
|
|
message_type: models::InviteMessageType,
|
|
slot: i32,
|
|
update_invite_message_request: Option<models::UpdateInviteMessageRequest>,
|
|
) -> Result<Vec<models::InviteMessage>, Error<UpdateInviteMessageError>> {
|
|
let local_var_configuration = configuration;
|
|
|
|
let local_var_client = &local_var_configuration.client;
|
|
|
|
let local_var_uri_str = format!(
|
|
"{}/message/{userId}/{messageType}/{slot}",
|
|
local_var_configuration.base_path,
|
|
userId = crate::apis::urlencode(user_id),
|
|
messageType = message_type.to_string(),
|
|
slot = slot
|
|
);
|
|
let mut local_var_req_builder =
|
|
local_var_client.request(reqwest::Method::PUT, local_var_uri_str.as_str());
|
|
|
|
if let Some(ref local_var_user_agent) = local_var_configuration.user_agent {
|
|
local_var_req_builder =
|
|
local_var_req_builder.header(reqwest::header::USER_AGENT, local_var_user_agent.clone());
|
|
}
|
|
local_var_req_builder = local_var_req_builder.json(&update_invite_message_request);
|
|
|
|
let local_var_req = local_var_req_builder.build()?;
|
|
let local_var_resp = local_var_client.execute(local_var_req).await?;
|
|
|
|
let local_var_status = local_var_resp.status();
|
|
let local_var_content = local_var_resp.text().await?;
|
|
|
|
if !local_var_status.is_client_error() && !local_var_status.is_server_error() {
|
|
serde_json::from_str(&local_var_content).map_err(Error::from)
|
|
} else {
|
|
let local_var_entity: Option<UpdateInviteMessageError> =
|
|
serde_json::from_str(&local_var_content).ok();
|
|
let local_var_error = ResponseContent {
|
|
status: local_var_status,
|
|
content: local_var_content,
|
|
entity: local_var_entity,
|
|
};
|
|
Err(Error::ResponseError(local_var_error))
|
|
}
|
|
}
|