fix(web/converse): Bare minimum changes to build in 2021
This project depends on Tokio, via actix, and both of those are bad ideas. This wasn't as clear 3 years ago as it is now, but to demonstrate it the project has amassed issues which required at least this minimum of changes to be buildable in 2021 (using a modern rustc). Yes, this adds dozens of new dependencies again (because of a top-level update) but don't worry: They will be gone when I'm done here. Change-Id: I1dde9dc0325da7bdcb6608359fab33e27692dc1d Reviewed-on: https://cl.tvl.fyi/c/depot/+/2857 Tested-by: BuildkiteCI Reviewed-by: tazjin <mail@tazj.in>
This commit is contained in:
parent
5387cc9e7d
commit
a0c4b91955
7 changed files with 1936 additions and 6664 deletions
|
|
@ -46,13 +46,13 @@ const NEW_THREAD_LENGTH_ERR: &'static str = "Title and body can not be empty!";
|
|||
/// Represents the state carried by the web server actors.
|
||||
pub struct AppState {
|
||||
/// Address of the database actor
|
||||
pub db: Addr<Syn, DbExecutor>,
|
||||
pub db: Addr<DbExecutor>,
|
||||
|
||||
/// Address of the OIDC actor
|
||||
pub oidc: Addr<Syn, OidcExecutor>,
|
||||
pub oidc: Addr<OidcExecutor>,
|
||||
|
||||
/// Address of the rendering actor
|
||||
pub renderer: Addr<Syn, Renderer>,
|
||||
pub renderer: Addr<Renderer>,
|
||||
}
|
||||
|
||||
pub fn forum_index(state: State<AppState>) -> ConverseResponse {
|
||||
|
|
@ -113,9 +113,9 @@ pub struct NewThreadForm {
|
|||
|
||||
/// This handler receives a "New thread"-form and redirects the user
|
||||
/// to the new thread after creation.
|
||||
pub fn submit_thread(state: State<AppState>,
|
||||
input: Form<NewThreadForm>,
|
||||
req: HttpRequest<AppState>) -> ConverseResponse {
|
||||
pub fn submit_thread((state, input, req): (State<AppState>,
|
||||
Form<NewThreadForm>,
|
||||
HttpRequest<AppState>)) -> ConverseResponse {
|
||||
// Trim whitespace out of inputs:
|
||||
let input = NewThreadForm {
|
||||
title: input.title.trim().into(),
|
||||
|
|
@ -328,7 +328,7 @@ impl EmbeddedFile for App<AppState> {
|
|||
pub struct RequireLogin;
|
||||
|
||||
impl <S> Middleware<S> for RequireLogin {
|
||||
fn start(&self, req: &mut HttpRequest<S>) -> actix_web::Result<Started> {
|
||||
fn start(&self, req: &HttpRequest<S>) -> actix_web::Result<Started> {
|
||||
let logged_in = req.identity().is_some();
|
||||
let is_oidc_req = req.path().starts_with("/oidc");
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue