a2b9d7ec44
* Password reset * Various improvements and fixes for password reset - Reorganize src/mail.rs to make it cleaner - add a build_mail function - only make the requests invalid after 2 hours - avoid infintely-growing list of requests by deleting them once completed, or after 24 hours - avoid sending many requests for the same user - validate the password reset form * Avoid locking so many times Fix durations * Remove old requests even if the current one is not valid * Remove unused feature * Also remove the custom_derive and plugin features while we are at it * Forgot a 0 è_é * Avoid panicking while owning a request lock * Use master branch of lettre so that we can build with the latest OpenSSL * Fix the debug mailer
21 lines
784 B
HTML
21 lines
784 B
HTML
@use template_utils::*;
|
|
@use templates::base;
|
|
@use validator::ValidationErrors;
|
|
@use routes::session::LoginForm;
|
|
@use routes::*;
|
|
|
|
@(ctx: BaseContext, message: Option<String>, form: &LoginForm, errors: ValidationErrors)
|
|
|
|
@:base(ctx, i18n!(ctx.1, "Login"), {}, {}, {
|
|
<h1>@i18n!(ctx.1, "Login")</h1>
|
|
@if let Some(message) = message {
|
|
<p>@message</p>
|
|
}
|
|
<form method="post" action="@uri!(session::create)">
|
|
@input!(ctx.1, email_or_name (text), "Username or email", form, errors.clone(), "minlenght=\"1\"")
|
|
@input!(ctx.1, password (password), "Password", form, errors, "minlenght=\"1\"")
|
|
<input type="submit" value="@i18n!(ctx.1, "Login")" />
|
|
</form>
|
|
<a href="@uri!(session::password_reset_request_form)">Forgot your password?</a>
|
|
})
|