refactor: ♻️ error, send and receive signals
This commit is contained in:
parent
85fb4fb2af
commit
f781afe995
3 changed files with 89 additions and 58 deletions
|
@ -37,7 +37,7 @@ pub async fn offer(username: String) {
|
||||||
log!("{}", rtc_session_offer);
|
log!("{}", rtc_session_offer);
|
||||||
let data = rtc_session_offer;
|
let data = rtc_session_offer;
|
||||||
|
|
||||||
send_offer(&username, &data).await;
|
send_offer(&username, &data).await.unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn answer() {}
|
pub async fn answer() {}
|
||||||
|
|
|
@ -1,43 +1,38 @@
|
||||||
use std::{str::FromStr, sync::LazyLock};
|
use std::sync::LazyLock;
|
||||||
|
|
||||||
use leptos::logging::log;
|
use leptos::logging::log;
|
||||||
use protocol::{Signal, SignalType};
|
use protocol::{Signal, SignalType};
|
||||||
use reqwest::{
|
use reqwest::{Response, header::HeaderMap};
|
||||||
Response,
|
|
||||||
header::{HeaderMap, HeaderName},
|
|
||||||
};
|
|
||||||
use serde_json::{Value, json};
|
use serde_json::{Value, json};
|
||||||
|
|
||||||
const SIGNALLING_ADDRESS: &str = "http://127.0.0.1:4546";
|
const SIGNALLING_ADDRESS: &str = "http://127.0.0.1:4546";
|
||||||
static REQUEST_CLIENT: LazyLock<reqwest::Client> = LazyLock::new(|| reqwest::Client::new());
|
static REQUEST_CLIENT: LazyLock<reqwest::Client> = LazyLock::new(|| reqwest::Client::new());
|
||||||
|
|
||||||
|
async fn create_headers(headers: Vec<(&'static str, String)>) -> HeaderMap {
|
||||||
|
let mut header_map = HeaderMap::new();
|
||||||
|
for (key, val) in headers {
|
||||||
|
header_map.insert(key, val.parse().unwrap());
|
||||||
|
}
|
||||||
|
header_map
|
||||||
|
}
|
||||||
|
|
||||||
async fn post_json(username: &String, json: &Value) -> Result<Response, reqwest::Error> {
|
async fn post_json(username: &String, json: &Value) -> Result<Response, reqwest::Error> {
|
||||||
let mut headers = HeaderMap::new();
|
let headers = create_headers(vec![]).await;
|
||||||
headers
|
|
||||||
.try_insert(
|
|
||||||
HeaderName::from_str("username").unwrap(),
|
|
||||||
username.parse().unwrap(),
|
|
||||||
)
|
|
||||||
.unwrap();
|
|
||||||
REQUEST_CLIENT
|
REQUEST_CLIENT
|
||||||
.post(SIGNALLING_ADDRESS)
|
.post(SIGNALLING_ADDRESS)
|
||||||
.headers(headers)
|
.headers(headers)
|
||||||
|
.bearer_auth(username)
|
||||||
.json(json)
|
.json(json)
|
||||||
.send()
|
.send()
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn get_json(username: &String) -> Result<Response, reqwest::Error> {
|
async fn get_json(username: &String, signal_type: SignalType) -> Result<Response, reqwest::Error> {
|
||||||
let mut headers = HeaderMap::new();
|
let headers = create_headers(vec![("EXPECTED_SIGNAL", signal_type.to_string())]).await;
|
||||||
headers
|
|
||||||
.try_insert(
|
|
||||||
HeaderName::from_str("username").unwrap(),
|
|
||||||
username.parse().unwrap(),
|
|
||||||
)
|
|
||||||
.unwrap();
|
|
||||||
REQUEST_CLIENT
|
REQUEST_CLIENT
|
||||||
.get(SIGNALLING_ADDRESS)
|
.get(SIGNALLING_ADDRESS)
|
||||||
.headers(headers)
|
.headers(headers)
|
||||||
|
.bearer_auth(username)
|
||||||
.send()
|
.send()
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
|
@ -45,7 +40,7 @@ async fn get_json(username: &String) -> Result<Response, reqwest::Error> {
|
||||||
pub async fn start_signalling(username: String) {
|
pub async fn start_signalling(username: String) {
|
||||||
log!("Start Signalling");
|
log!("Start Signalling");
|
||||||
log!("{}\n{}", username, SIGNALLING_ADDRESS);
|
log!("{}\n{}", username, SIGNALLING_ADDRESS);
|
||||||
let auth_signal = Signal::new(&username, &SignalType::Auth, &"".to_owned());
|
let auth_signal = Signal::new(&SignalType::Auth, &"".to_owned());
|
||||||
let json = json!(auth_signal);
|
let json = json!(auth_signal);
|
||||||
match post_json(&username, &json).await {
|
match post_json(&username, &json).await {
|
||||||
Ok(signal_response) => log!("{:#?}", signal_response),
|
Ok(signal_response) => log!("{:#?}", signal_response),
|
||||||
|
@ -55,42 +50,42 @@ pub async fn start_signalling(username: String) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn send_offer(username: &String, data: &String) {
|
pub async fn send_offer(username: &String, data: &String) -> Result<(), reqwest::Error> {
|
||||||
let rtc_session_offer_signal = Signal::new(username, &SignalType::Offer, data);
|
let rtc_session_offer_signal = Signal::new(&SignalType::Offer, data);
|
||||||
let rtc_session_offer_signal = json!(rtc_session_offer_signal);
|
let rtc_session_offer_signal = json!(rtc_session_offer_signal);
|
||||||
match post_json(username, &rtc_session_offer_signal).await {
|
post_json(username, &rtc_session_offer_signal)
|
||||||
Ok(signal_response) => log!("{:#?}", signal_response),
|
.await
|
||||||
Err(err_val) => {
|
.map(|_| Ok(()))?
|
||||||
log!("Error: Signal Post | {}", err_val);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn receive_offer(username: &String) -> Result<Signal, Box<dyn std::error::Error>> {
|
||||||
|
let result = get_json(username, SignalType::Offer)
|
||||||
|
.await
|
||||||
|
.map(async |response| response.json::<Signal>().await)?
|
||||||
|
.await?;
|
||||||
|
if result.get_signal_type() == SignalType::Offer {
|
||||||
|
Ok(result)
|
||||||
|
} else {
|
||||||
|
Err(protocol::Error::SignalType(result.get_signal_type()))?
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn receive_offer(username: &String) {
|
pub async fn send_answer(username: &String, data: &String) -> Result<(), reqwest::Error> {
|
||||||
match get_json(username).await {
|
let rtc_session_answer_signal = Signal::new(&SignalType::Answer, data);
|
||||||
Ok(signal_response) => log!("{:#?}", signal_response),
|
|
||||||
Err(err_val) => {
|
|
||||||
log!("Error: Signal Post | {}", err_val);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn send_answer(username: &String, data: &String) {
|
|
||||||
let rtc_session_answer_signal = Signal::new(username, &SignalType::Answer, data);
|
|
||||||
let rtc_session_answer_signal = json!(rtc_session_answer_signal);
|
let rtc_session_answer_signal = json!(rtc_session_answer_signal);
|
||||||
match post_json(username, &rtc_session_answer_signal).await {
|
post_json(username, &rtc_session_answer_signal)
|
||||||
Ok(signal_response) => log!("{:#?}", signal_response),
|
.await
|
||||||
Err(err_val) => {
|
.map(|_| Ok(()))?
|
||||||
log!("Error: Signal Post | {}", err_val);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn receive_answer(username: &String) {
|
pub async fn receive_answer(username: &String) -> Result<Signal, Box<dyn std::error::Error>> {
|
||||||
match get_json(username).await {
|
let result = get_json(username, SignalType::Answer)
|
||||||
Ok(signal_response) => log!("{:#?}", signal_response),
|
.await
|
||||||
Err(err_val) => {
|
.map(async |response| response.json::<Signal>().await)?
|
||||||
log!("Error: Signal Post | {}", err_val);
|
.await?;
|
||||||
}
|
if result.get_signal_type() == SignalType::Answer {
|
||||||
|
Ok(result)
|
||||||
|
} else {
|
||||||
|
Err(protocol::Error::SignalType(result.get_signal_type()))?
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,30 @@
|
||||||
|
use std::fmt::Display;
|
||||||
|
|
||||||
use chrono::{DateTime, Utc};
|
use chrono::{DateTime, Utc};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
#[derive(Debug, Clone, Copy, Serialize, Deserialize)]
|
#[derive(Debug, Clone, Copy, Serialize, Deserialize)]
|
||||||
|
pub enum Error {
|
||||||
|
SignalType(SignalType),
|
||||||
|
}
|
||||||
|
|
||||||
|
impl std::error::Error for Error {
|
||||||
|
fn cause(&self) -> Option<&dyn std::error::Error> {
|
||||||
|
self.source()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Display for Error {
|
||||||
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
match self {
|
||||||
|
Error::SignalType(signal_type) => {
|
||||||
|
write!(f, "Not Expected Signal Type: {}", signal_type)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, Serialize, Deserialize)]
|
||||||
pub enum SignalType {
|
pub enum SignalType {
|
||||||
Auth,
|
Auth,
|
||||||
Offer,
|
Offer,
|
||||||
|
@ -10,25 +33,38 @@ pub enum SignalType {
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
||||||
pub struct Signal {
|
pub struct Signal {
|
||||||
pub username: String,
|
signal_type: SignalType,
|
||||||
pub signal_type: SignalType,
|
data: String,
|
||||||
pub data: String,
|
|
||||||
time: DateTime<Utc>,
|
time: DateTime<Utc>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl Display for SignalType {
|
||||||
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
match self {
|
||||||
|
SignalType::Auth => write!(f, "Auth"),
|
||||||
|
SignalType::Offer => write!(f, "Offer"),
|
||||||
|
SignalType::Answer => write!(f, "Answer"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Signal {
|
impl Signal {
|
||||||
pub fn new(username: &String, signal_type: &SignalType, data: &String) -> Signal {
|
pub fn new(signal_type: &SignalType, data: &String) -> Signal {
|
||||||
let username = username.to_owned();
|
|
||||||
let signal_type = *signal_type;
|
let signal_type = *signal_type;
|
||||||
let data = data.to_owned();
|
let data = data.to_owned();
|
||||||
Signal {
|
Signal {
|
||||||
username,
|
|
||||||
signal_type,
|
signal_type,
|
||||||
data,
|
data,
|
||||||
time: DateTime::default(),
|
time: DateTime::default(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_signal_type(&self) -> SignalType {
|
||||||
|
self.signal_type
|
||||||
|
}
|
||||||
|
pub fn get_data(&self) -> String {
|
||||||
|
self.data.to_owned()
|
||||||
|
}
|
||||||
pub fn get_time(&self) -> DateTime<Utc> {
|
pub fn get_time(&self) -> DateTime<Utc> {
|
||||||
self.time
|
self.time
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue