delete captcha option and sudo page

This commit is contained in:
realaravinth
2021-07-20 15:22:15 +05:30
parent 00768cce34
commit db941d51b7
17 changed files with 320 additions and 34 deletions

View File

@@ -17,6 +17,7 @@
pub mod login;
pub mod register;
pub mod sudo;
pub fn services(cfg: &mut actix_web::web::ServiceConfig) {
cfg.service(login::login);

85
src/pages/auth/sudo.rs Normal file
View File

@@ -0,0 +1,85 @@
/*
* Copyright (C) 2021 Aravinth Manivannan <realaravinth@batsense.net>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
use std::fmt::Display;
use sailfish::TemplateOnce;
#[derive(Clone, TemplateOnce)]
#[template(path = "auth/sudo/index.html")]
pub struct SudoPage<'a> {
url: &'a str,
data: Option<String>,
}
pub const PAGE: &str = "Confirm Access";
impl<'a> SudoPage<'a> {
//pub fn new(url: &'a str, data: Option<Vec<(&'a str, &'a str)>>) -> Self {
pub fn new<K, V>(url: &'a str, data: Option<Vec<(K, V)>>) -> Self
where
K: Display,
V: Display,
{
let data = if let Some(data) = data {
if !data.is_empty() {
let mut s = String::new();
for (k, v) in data.iter() {
s.push_str(&format!(" data-{}={}", k, v));
}
Some(s)
} else {
None
}
} else {
None
};
Self { url, data }
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn sudo_page_works() {
let data = vec![
("firefox", "mozilla"),
("chrome", "google"),
("servo", "mozilla"),
];
assert!(SudoPage::new::<String, String>("foo", None).data.is_none());
let sudo = SudoPage::new("foo", Some(data.clone()));
data.iter().for_each(|(k, v)| {
assert!(
sudo.data.as_ref().unwrap().contains(k)
&& sudo.data.as_ref().unwrap().contains(v)
)
});
let data_str = " data-firefox=mozilla data-chrome=google data-servo=mozilla";
assert_eq!(sudo.data.as_ref().unwrap(), data_str);
assert!(SudoPage::new::<String, String>("foo", Some(Vec::default()))
.data
.is_none());
}
}

View File

@@ -15,31 +15,21 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
use actix_web::{HttpResponse, Responder};
use lazy_static::lazy_static;
use actix_web::{web, HttpResponse, Responder};
use my_codegen::get;
use sailfish::TemplateOnce;
use crate::PAGES;
#[derive(Clone, TemplateOnce)]
#[template(path = "panel/sitekey/delete/index.html")]
struct IndexPage;
const PAGE: &str = "Confirm Access";
impl Default for IndexPage {
fn default() -> Self {
IndexPage
}
}
lazy_static! {
static ref INDEX: String = IndexPage::default().render_once().unwrap();
}
use crate::pages::auth::sudo::SudoPage;
use crate::{PAGES, V1_API_ROUTES};
#[get(path = "PAGES.panel.sitekey.delete", wrap = "crate::CheckLogin")]
pub async fn delete_sitekey() -> impl Responder {
pub async fn delete_sitekey(path: web::Path<String>) -> impl Responder {
let key = path.into_inner();
let data = vec![("sitekey", key)];
let page = SudoPage::new(V1_API_ROUTES.mcaptcha.delete, Some(data))
.render_once()
.unwrap();
HttpResponse::Ok()
.content_type("text/html; charset=utf-8")
.body(&*INDEX)
.body(&page)
}