2023-04-16 23:03:24 +02:00
|
|
|
pub mod register {
|
2023-04-21 15:04:58 +02:00
|
|
|
use custom_error::custom_error;
|
2023-04-20 00:14:11 +02:00
|
|
|
use reqwest::Client;
|
2023-04-21 14:27:56 +02:00
|
|
|
use serde_json::json;
|
2023-04-20 00:14:11 +02:00
|
|
|
|
2023-04-21 18:20:57 +02:00
|
|
|
use crate::{
|
|
|
|
api::{limits::LimitType, schemas::schemas::RegisterSchema},
|
|
|
|
errors::InstanceServerError,
|
|
|
|
instance::{Instance, Token},
|
|
|
|
};
|
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(
|
|
|
|
&mut self,
|
|
|
|
register_schema: &RegisterSchema,
|
|
|
|
) -> Result<Token, InstanceServerError> {
|
2023-04-21 14:27:56 +02:00
|
|
|
let json_schema = json!(register_schema);
|
2023-04-21 18:20:57 +02:00
|
|
|
let limited_requester = &mut self.requester;
|
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-21 18:20:57 +02:00
|
|
|
let response = limited_requester
|
|
|
|
.send_request(request_builder, LimitType::AuthRegister)
|
|
|
|
.await;
|
|
|
|
if response.is_none() {
|
|
|
|
return Err(InstanceServerError::NoResponse);
|
|
|
|
}
|
|
|
|
let token = match response.unwrap().text().await {
|
|
|
|
Ok(token) => token,
|
|
|
|
Err(_) => return Err(InstanceServerError::NoResponse),
|
|
|
|
};
|
|
|
|
return Ok(Token { token });
|
2023-04-20 00:14:11 +02:00
|
|
|
}
|
2023-04-16 23:03:24 +02:00
|
|
|
}
|
|
|
|
}
|