diff --git a/server/src/api/mod.rs b/server/src/api/mod.rs index f654167fca..8711e0b50a 100644 --- a/server/src/api/mod.rs +++ b/server/src/api/mod.rs @@ -75,7 +75,7 @@ impl Oper { } pub trait Perform { - type Response: serde::ser::Serialize; + type Response: serde::ser::Serialize + Send; fn perform( &self, diff --git a/server/src/routes/api.rs b/server/src/routes/api.rs index 74ad7239b8..1565afb80c 100644 --- a/server/src/routes/api.rs +++ b/server/src/routes/api.rs @@ -5,7 +5,6 @@ use crate::api::post::*; use crate::api::site::*; use crate::api::user::*; use crate::rate_limit::RateLimit; -use actix_web::guard; pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimit) { cfg.service( @@ -140,13 +139,14 @@ pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimit) { ); } -fn perform( +async fn perform( data: Request, db: DbPoolParam, chat_server: ChatServerParam, ) -> Result where Oper: Perform, + Request: Send + 'static, { let ws_info = WebsocketInfo { chatserver: chat_server.get_ref().to_owned(), @@ -155,9 +155,11 @@ where let oper: Oper = Oper::new(data); - let res = oper.perform(db.get_ref().to_owned(), Some(ws_info)); - - Ok(HttpResponse::Ok().json(res?)) + let res = web::block(move || oper.perform(db.get_ref().to_owned(), Some(ws_info))) + .await + .map(|json| HttpResponse::Ok().json(json)) + .map_err(ErrorBadRequest)?; + Ok(res) } async fn route_get( @@ -166,10 +168,10 @@ async fn route_get( chat_server: ChatServerParam, ) -> Result where - Data: Serialize, + Data: Serialize + Send + 'static, Oper: Perform, { - perform::(data.0, db, chat_server) + perform::(data.0, db, chat_server).await } async fn route_post( @@ -178,8 +180,8 @@ async fn route_post( chat_server: ChatServerParam, ) -> Result where - Data: Serialize, + Data: Serialize + Send + 'static, Oper: Perform, { - perform::(data.0, db, chat_server) + perform::(data.0, db, chat_server).await } diff --git a/server/src/routes/feeds.rs b/server/src/routes/feeds.rs index 8eefe02a07..815953c55a 100644 --- a/server/src/routes/feeds.rs +++ b/server/src/routes/feeds.rs @@ -28,7 +28,7 @@ pub fn config(cfg: &mut web::ServiceConfig) { async fn get_all_feed( info: web::Query, db: web::Data>>, -) -> Result { +) -> Result { let res = web::block(move || { let conn = db.get()?; get_feed_all_data(&conn, &get_sort_type(info)?) @@ -39,7 +39,7 @@ async fn get_all_feed( .content_type("application/rss+xml") .body(rss) }) - .map_err(|_| HttpResponse::InternalServerError())?; + .map_err(ErrorBadRequest)?; Ok(res) } @@ -70,7 +70,7 @@ async fn get_feed( path: web::Path<(String, String)>, info: web::Query, db: web::Data>>, -) -> Result { +) -> Result { let res = web::block(move || { let conn = db.get()?; @@ -100,7 +100,7 @@ async fn get_feed( .content_type("application/rss+xml") .body(rss) }) - .map_err(|_| HttpResponse::InternalServerError())?; + .map_err(ErrorBadRequest)?; Ok(res) } @@ -116,7 +116,7 @@ fn get_feed_user( conn: &PgConnection, sort_type: &SortType, user_name: String, -) -> Result { +) -> Result { let site_view = SiteView::read(&conn)?; let user = User_::find_by_username(&conn, &user_name)?; let user_url = user.get_profile_url(); @@ -142,7 +142,7 @@ fn get_feed_community( conn: &PgConnection, sort_type: &SortType, community_name: String, -) -> Result { +) -> Result { let site_view = SiteView::read(&conn)?; let community = Community::read_from_name(&conn, community_name)?; let community_url = community.get_url(); @@ -172,7 +172,7 @@ fn get_feed_front( conn: &PgConnection, sort_type: &SortType, jwt: String, -) -> Result { +) -> Result { let site_view = SiteView::read(&conn)?; let user_id = Claims::decode(&jwt)?.claims.id; @@ -197,7 +197,7 @@ fn get_feed_front( Ok(channel_builder) } -fn get_feed_inbox(conn: &PgConnection, jwt: String) -> Result { +fn get_feed_inbox(conn: &PgConnection, jwt: String) -> Result { let site_view = SiteView::read(&conn)?; let user_id = Claims::decode(&jwt)?.claims.id; diff --git a/server/src/routes/index.rs b/server/src/routes/index.rs index 9f18b64d81..895af43500 100644 --- a/server/src/routes/index.rs +++ b/server/src/routes/index.rs @@ -41,7 +41,7 @@ pub fn config(cfg: &mut web::ServiceConfig) { .route("/password_change/{token}", web::get().to(index)); } -async fn index() -> Result { +async fn index() -> Result { Ok(NamedFile::open( Settings::get().front_end_dir + "/index.html", )?) diff --git a/server/src/routes/mod.rs b/server/src/routes/mod.rs index ad79bd9483..109dbd76d4 100644 --- a/server/src/routes/mod.rs +++ b/server/src/routes/mod.rs @@ -6,14 +6,13 @@ use crate::websocket::{server::ChatServer, WebsocketInfo}; use crate::{get_ip, markdown_to_html, version, Settings}; use actix::prelude::*; use actix_files::NamedFile; -use actix_web::{body::Body, web::Query, *}; +use actix_web::{body::Body, error::ErrorBadRequest, web::Query, *}; use actix_web_actors::ws; use chrono::{DateTime, NaiveDateTime, Utc}; use diesel::{ r2d2::{ConnectionManager, Pool}, PgConnection, }; -use failure::Error; use log::{error, info}; use regex::Regex; use rss::{CategoryBuilder, ChannelBuilder, GuidBuilder, Item, ItemBuilder}; diff --git a/server/src/routes/nodeinfo.rs b/server/src/routes/nodeinfo.rs index 7d3bbf7507..60c3fb8ec9 100644 --- a/server/src/routes/nodeinfo.rs +++ b/server/src/routes/nodeinfo.rs @@ -22,7 +22,7 @@ async fn node_info_well_known() -> Result, Error> { async fn node_info( db: web::Data>>, -) -> Result { +) -> Result { let res = web::block(move || { let conn = db.get()?; let site_view = match SiteView::read(&conn) { @@ -53,7 +53,7 @@ async fn node_info( }) .await .map(|json| HttpResponse::Ok().json(json)) - .map_err(|_| HttpResponse::InternalServerError())?; + .map_err(ErrorBadRequest)?; Ok(res) } diff --git a/server/src/routes/webfinger.rs b/server/src/routes/webfinger.rs index 489318eb7e..0f30acaf22 100644 --- a/server/src/routes/webfinger.rs +++ b/server/src/routes/webfinger.rs @@ -32,7 +32,7 @@ lazy_static! { async fn get_webfinger_response( info: Query, db: web::Data>>, -) -> Result { +) -> Result { let res = web::block(move || { let conn = db.get()?; @@ -79,6 +79,6 @@ async fn get_webfinger_response( }) .await .map(|json| HttpResponse::Ok().json(json)) - .map_err(|_| HttpResponse::InternalServerError())?; + .map_err(ErrorBadRequest)?; Ok(res) } diff --git a/server/src/routes/websocket.rs b/server/src/routes/websocket.rs index 8088594519..48b7d08fb0 100644 --- a/server/src/routes/websocket.rs +++ b/server/src/routes/websocket.rs @@ -1,6 +1,5 @@ use super::*; use crate::websocket::server::*; -use actix_web::{Error, Result}; /// How often heartbeat pings are sent const HEARTBEAT_INTERVAL: Duration = Duration::from_secs(5); @@ -120,7 +119,7 @@ impl StreamHandler> for WSSession { .then(|res, _, ctx| { match res { Ok(Ok(res)) => ctx.text(res), - Ok(Err(e)) => match e {}, + Ok(Err(_)) => {} Err(e) => error!("{}", &e), } actix::fut::ready(()) diff --git a/server/src/websocket/server.rs b/server/src/websocket/server.rs index 0e7c1a4af6..da5098e917 100644 --- a/server/src/websocket/server.rs +++ b/server/src/websocket/server.rs @@ -896,10 +896,18 @@ where let data = data.to_string(); let op2 = op.clone(); + let fut = async move { - let parsed_data: Data = serde_json::from_str(&data)?; - let res = Oper::new(parsed_data).perform(pool, Some(ws_info))?; - to_json_string(&op, &res) + actix_web::web::block(move || { + let parsed_data: Data = serde_json::from_str(&data)?; + let res = Oper::new(parsed_data).perform(pool, Some(ws_info))?; + to_json_string(&op, &res) + }) + .await + .map_err(|e| match e { + actix_web::error::BlockingError::Error(e) => e, + _ => APIError::err("Operation canceled").into(), + }) }; match op2 {