From 089efa225cc0a4e7be12608129ddbff28d11f320 Mon Sep 17 00:00:00 2001 From: rtkay123 Date: Wed, 23 Jul 2025 13:39:40 +0200 Subject: feat(auth): discord oauth --- crates/auth/src/server/routes/authorised.rs | 23 ++++++++++++++++++++++ crates/auth/src/server/routes/discord.rs | 10 ++++++++++ .../auth/src/server/routes/discord/discord_auth.rs | 20 +++++++++++++++++++ 3 files changed, 53 insertions(+) create mode 100644 crates/auth/src/server/routes/authorised.rs create mode 100644 crates/auth/src/server/routes/discord.rs create mode 100644 crates/auth/src/server/routes/discord/discord_auth.rs (limited to 'crates/auth/src/server/routes') diff --git a/crates/auth/src/server/routes/authorised.rs b/crates/auth/src/server/routes/authorised.rs new file mode 100644 index 0000000..ddf048d --- /dev/null +++ b/crates/auth/src/server/routes/authorised.rs @@ -0,0 +1,23 @@ +use axum::{ + extract::{Query, State}, + response::IntoResponse, +}; +use axum_extra::{TypedHeader, headers}; +use serde::Deserialize; + +use crate::{error::AppError, server::routes::Provider, state::AppHandle}; + +#[derive(Debug, Deserialize)] +pub struct AuthRequest { + provider: Provider, + code: String, + state: String, +} + +async fn login_authorized( + Query(query): Query, + State(state): State, + TypedHeader(cookies): TypedHeader, +) -> Result { + Ok("") +} diff --git a/crates/auth/src/server/routes/discord.rs b/crates/auth/src/server/routes/discord.rs new file mode 100644 index 0000000..e1a834f --- /dev/null +++ b/crates/auth/src/server/routes/discord.rs @@ -0,0 +1,10 @@ +mod discord_auth; +use axum::{Router, routing::get}; + +use crate::state::AppHandle; + +pub fn discord_router(state: AppHandle) -> Router { + Router::new() + .route("/auth/discord", get(discord_auth::discord_auth)) + .with_state(state) +} diff --git a/crates/auth/src/server/routes/discord/discord_auth.rs b/crates/auth/src/server/routes/discord/discord_auth.rs new file mode 100644 index 0000000..b07fa7a --- /dev/null +++ b/crates/auth/src/server/routes/discord/discord_auth.rs @@ -0,0 +1,20 @@ +use axum::{ + extract::State, + http::HeaderMap, + response::{IntoResponse, Redirect}, +}; +use oauth2::{CsrfToken, Scope}; + +use crate::{error::AppError, state::AppHandle}; + +pub async fn discord_auth(State(state): State) -> Result { + let (auth_url, csrf_token) = state + .discord_client + .authorize_url(CsrfToken::new_random) + .add_scope(Scope::new("identify".to_string())) + .url(); + + let mut headers = HeaderMap::new(); + + Ok((headers, Redirect::to(auth_url.as_ref()))) +} -- cgit v1.2.3