chorus/src/api/auth/register.rs

80 lines
3.3 KiB
Rust
Raw Normal View History

2023-04-16 23:03:24 +02:00
pub mod register {
use std::{cell::RefCell, rc::Rc};
2023-04-20 00:14:11 +02:00
use reqwest::Client;
use serde_json::{from_str, json};
2023-04-20 00:14:11 +02:00
2023-04-21 18:20:57 +02:00
use crate::{
2023-05-26 12:50:16 +02:00
api::limits::LimitType,
2023-04-21 18:20:57 +02:00
errors::InstanceServerError,
2023-05-26 12:50:16 +02:00
instance::{Instance, Token, UserMeta},
limit::LimitedRequester,
2023-05-26 12:50:16 +02:00
types::{ErrorResponse, RegisterSchema},
2023-04-21 18:20:57 +02:00
};
2023-04-16 23:03:24 +02:00
impl Instance {
2023-04-21 18:20:57 +02:00
/**
Registers a new user on the Spacebar server.
# Arguments
* `register_schema` - The [`RegisterSchema`] that contains all the information that is needed to register a new user.
# Errors
* [`InstanceServerError`] - If the server does not respond.
*/
pub async fn register_account(
2023-04-21 18:20:57 +02:00
&mut self,
register_schema: &RegisterSchema,
2023-05-26 12:50:16 +02:00
) -> Result<UserMeta, InstanceServerError> {
2023-04-21 14:27:56 +02:00
let json_schema = json!(register_schema);
let mut limited_requester = LimitedRequester::new().await;
2023-04-20 00:14:11 +02:00
let client = Client::new();
2023-04-21 14:27:56 +02:00
let endpoint_url = self.urls.get_api().to_string() + "/auth/register";
let request_builder = client.post(endpoint_url).body(json_schema.to_string());
2023-04-24 20:58:45 +02:00
// We do not have a user yet, and the UserRateLimits will not be affected by a login
// request (since register is an instance wide limit), which is why we are just cloning
// the instances' limits to pass them on as user_rate_limits later.
let mut cloned_limits = self.limits.clone();
2023-04-21 18:20:57 +02:00
let response = limited_requester
2023-04-24 20:58:45 +02:00
.send_request(
request_builder,
LimitType::AuthRegister,
&mut self.limits,
&mut cloned_limits,
)
2023-04-21 18:20:57 +02:00
.await;
2023-04-25 17:33:35 +02:00
if response.is_err() {
2023-04-21 18:20:57 +02:00
return Err(InstanceServerError::NoResponse);
2023-04-22 11:32:44 +02:00
}
let response_unwrap = response.unwrap();
let status = response_unwrap.status();
let response_unwrap_text = response_unwrap.text().await.unwrap();
let token = from_str::<Token>(&response_unwrap_text).unwrap();
let token = token.token;
2023-04-22 11:32:44 +02:00
if status.is_client_error() {
let json: ErrorResponse = serde_json::from_str(&token).unwrap();
2023-04-22 22:12:56 +02:00
let error_type = json.errors.errors.iter().next().unwrap().0.to_owned();
let mut error = "".to_string();
for (_, value) in json.errors.errors.iter() {
for error_item in value._errors.iter() {
error += &(error_item.message.to_string() + " (" + &error_item.code + ")");
}
}
return Err(InstanceServerError::InvalidFormBodyError { error_type, error });
2023-04-22 11:32:44 +02:00
}
let user_object = self.get_user(token.clone(), None).await.unwrap();
2023-05-26 12:50:16 +02:00
let settings =
UserMeta::get_settings(&token, &self.urls.get_api().to_string(), &mut self.limits)
.await
.unwrap();
let user: UserMeta = UserMeta::new(
Rc::new(RefCell::new(self.clone())),
token.clone(),
2023-05-09 14:05:03 +02:00
cloned_limits,
settings,
Some(user_object),
);
Ok(user)
2023-04-20 00:14:11 +02:00
}
2023-04-16 23:03:24 +02:00
}
}