mirror of
https://github.com/n08i40k/schedule-parser-rusted.git
synced 2025-12-06 09:47:50 +03:00
Реформат путей к эндпоинтам.
Добавлен экстрактор пользователя с дополнительными полями.
Добавлена связь таблиц User и FCM.
Завершена реализация авторизации с помощью VK ID.
Добавлен эндпоинт fcm/update-callback/{version}.
This commit is contained in:
82
src/main.rs
82
src/main.rs
@@ -1,18 +1,10 @@
|
||||
use crate::app_state::{AppState, app_state};
|
||||
use crate::middlewares::authorization::JWTAuthorization;
|
||||
use crate::routes::auth::sign_in::{sign_in_default, sign_in_vk};
|
||||
use crate::routes::auth::sign_up::{sign_up_default, sign_up_vk};
|
||||
use crate::routes::schedule::get_cache_status::get_cache_status;
|
||||
use crate::routes::schedule::get_group::get_group;
|
||||
use crate::routes::schedule::get_group_names::get_group_names;
|
||||
use crate::routes::schedule::get_schedule::get_schedule;
|
||||
use crate::routes::schedule::get_teacher::get_teacher;
|
||||
use crate::routes::schedule::get_teacher_names::get_teacher_names;
|
||||
use crate::routes::schedule::update_download_url::update_download_url;
|
||||
use crate::routes::users::me::me;
|
||||
use actix_web::{App, HttpServer};
|
||||
use actix_web::dev::{ServiceFactory, ServiceRequest};
|
||||
use actix_web::{App, Error, HttpServer};
|
||||
use dotenvy::dotenv;
|
||||
use utoipa_actix_web::AppExt;
|
||||
use utoipa_actix_web::scope::Scope;
|
||||
use utoipa_rapidoc::RapiDoc;
|
||||
|
||||
mod app_state;
|
||||
@@ -30,6 +22,47 @@ mod utility;
|
||||
|
||||
mod test_env;
|
||||
|
||||
pub fn get_api_scope<
|
||||
I: Into<Scope<T>>,
|
||||
T: ServiceFactory<ServiceRequest, Config = (), Error = Error, InitError = ()>,
|
||||
>(
|
||||
scope: I,
|
||||
) -> Scope<T> {
|
||||
let auth_scope = utoipa_actix_web::scope("/auth")
|
||||
.service(routes::auth::sign_in)
|
||||
.service(routes::auth::sign_in_vk)
|
||||
.service(routes::auth::sign_up)
|
||||
.service(routes::auth::sign_up_vk);
|
||||
|
||||
let users_scope = utoipa_actix_web::scope("/users")
|
||||
.wrap(JWTAuthorization)
|
||||
.service(routes::users::me);
|
||||
|
||||
let schedule_scope = utoipa_actix_web::scope("/schedule")
|
||||
.wrap(JWTAuthorization)
|
||||
.service(routes::schedule::schedule)
|
||||
.service(routes::schedule::update_download_url)
|
||||
.service(routes::schedule::cache_status)
|
||||
.service(routes::schedule::group)
|
||||
.service(routes::schedule::group_names)
|
||||
.service(routes::schedule::teacher)
|
||||
.service(routes::schedule::teacher_names);
|
||||
|
||||
let fcm_scope = utoipa_actix_web::scope("/fcm")
|
||||
.wrap(JWTAuthorization)
|
||||
.service(routes::fcm::update_callback);
|
||||
|
||||
let vk_id_scope = utoipa_actix_web::scope("/vkid") //
|
||||
.service(routes::vk_id::oauth);
|
||||
|
||||
utoipa_actix_web::scope(scope)
|
||||
.service(auth_scope)
|
||||
.service(users_scope)
|
||||
.service(schedule_scope)
|
||||
.service(fcm_scope)
|
||||
.service(vk_id_scope)
|
||||
}
|
||||
|
||||
#[actix_web::main]
|
||||
async fn main() {
|
||||
dotenv().ok();
|
||||
@@ -40,35 +73,10 @@ async fn main() {
|
||||
let app_state = app_state();
|
||||
|
||||
HttpServer::new(move || {
|
||||
let auth_scope = utoipa_actix_web::scope("/auth")
|
||||
.service(sign_in_default)
|
||||
.service(sign_in_vk)
|
||||
.service(sign_up_default)
|
||||
.service(sign_up_vk);
|
||||
|
||||
let users_scope = utoipa_actix_web::scope("/users")
|
||||
.wrap(JWTAuthorization)
|
||||
.service(me);
|
||||
|
||||
let schedule_scope = utoipa_actix_web::scope("/schedule")
|
||||
.wrap(JWTAuthorization)
|
||||
.service(get_schedule)
|
||||
.service(update_download_url)
|
||||
.service(get_cache_status)
|
||||
.service(get_group)
|
||||
.service(get_group_names)
|
||||
.service(get_teacher)
|
||||
.service(get_teacher_names);
|
||||
|
||||
let api_scope = utoipa_actix_web::scope("/api/v1")
|
||||
.service(auth_scope)
|
||||
.service(users_scope)
|
||||
.service(schedule_scope);
|
||||
|
||||
let (app, api) = App::new()
|
||||
.into_utoipa_app()
|
||||
.app_data(app_state.clone())
|
||||
.service(api_scope)
|
||||
.service(get_api_scope("/api/v1"))
|
||||
.split_for_parts();
|
||||
|
||||
let rapidoc_service = RapiDoc::with_openapi("/api-docs-json", api).path("/api-docs");
|
||||
|
||||
Reference in New Issue
Block a user