forked from neri/datatrash
refactor: move template filling into module
This commit is contained in:
parent
4cd3cead88
commit
0a469ae367
5 changed files with 55 additions and 42 deletions
2
Cargo.lock
generated
2
Cargo.lock
generated
|
@ -424,7 +424,7 @@ dependencies = [
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "datatrash"
|
name = "datatrash"
|
||||||
version = "2.1.1"
|
version = "2.2.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"actix-files",
|
"actix-files",
|
||||||
"actix-governor",
|
"actix-governor",
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
[package]
|
[package]
|
||||||
name = "datatrash"
|
name = "datatrash"
|
||||||
version = "2.1.1"
|
version = "2.2.0"
|
||||||
authors = ["neri"]
|
authors = ["neri"]
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
|
|
|
@ -15,13 +15,9 @@ use sqlx::postgres::PgPool;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
use time::OffsetDateTime;
|
use time::OffsetDateTime;
|
||||||
use tokio::fs;
|
use tokio::fs;
|
||||||
use url::Url;
|
|
||||||
|
|
||||||
use crate::{config::Config, deleter, mime_relations, template};
|
use crate::{config::Config, deleter, mime_relations, template};
|
||||||
|
|
||||||
const TEXT_VIEW_HTML: &str = include_str!("../template/text-view.html");
|
|
||||||
const URL_VIEW_HTML: &str = include_str!("../template/url-view.html");
|
|
||||||
|
|
||||||
const TEXT_VIEW_SIZE_LIMIT: u64 = 512 * 1024; // 512KiB
|
const TEXT_VIEW_SIZE_LIMIT: u64 = 512 * 1024; // 512KiB
|
||||||
|
|
||||||
enum ViewType {
|
enum ViewType {
|
||||||
|
@ -130,20 +126,10 @@ async fn build_html_response(
|
||||||
log::error!("file could not be read {:?}", file_err);
|
log::error!("file could not be read {:?}", file_err);
|
||||||
error::ErrorInternalServerError("this file should be here but could not be found")
|
error::ErrorInternalServerError("this file should be here but could not be found")
|
||||||
})?;
|
})?;
|
||||||
let encoded = htmlescape::encode_minimal(&content);
|
let html_view = template::build_html_view_template(&content, req, config);
|
||||||
let mut html =
|
|
||||||
if !content.trim().contains(['\n', '\r']) && Url::from_str(content.trim()).is_ok() {
|
|
||||||
let attribute_encoded = htmlescape::encode_attribute(&content);
|
|
||||||
URL_VIEW_HTML
|
|
||||||
.replace("{link_content}", &encoded)
|
|
||||||
.replace("{link_attribute}", &attribute_encoded)
|
|
||||||
} else {
|
|
||||||
TEXT_VIEW_HTML.replace("{text}", &encoded)
|
|
||||||
};
|
|
||||||
html = template::insert_abuse_template(html, Some(req), config);
|
|
||||||
Ok(HttpResponse::Ok()
|
Ok(HttpResponse::Ok()
|
||||||
.content_type(TEXT_HTML.to_string())
|
.content_type(TEXT_HTML.to_string())
|
||||||
.body(html))
|
.body(html_view))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn build_file_response(
|
fn build_file_response(
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
use std::{cmp, io::ErrorKind};
|
use std::{cmp, io::ErrorKind, str::FromStr};
|
||||||
|
|
||||||
use actix_web::HttpRequest;
|
use actix_web::HttpRequest;
|
||||||
use time::Duration;
|
use time::Duration;
|
||||||
use tokio::fs;
|
use tokio::fs;
|
||||||
|
use url::Url;
|
||||||
|
|
||||||
use crate::config::Config;
|
use crate::config::Config;
|
||||||
|
|
||||||
|
@ -10,8 +11,54 @@ const INDEX_HTML: &str = include_str!("../template/index.html");
|
||||||
const AUTH_HIDE_JS: &str = include_str!("../template/auth-hide.js");
|
const AUTH_HIDE_JS: &str = include_str!("../template/auth-hide.js");
|
||||||
const AUTH_SNIPPET_HTML: &str = include_str!("../snippet/auth.html.snippet");
|
const AUTH_SNIPPET_HTML: &str = include_str!("../snippet/auth.html.snippet");
|
||||||
const MAX_SIZE_SNIPPET_HTML: &str = include_str!("../snippet/max_size.html.snippet");
|
const MAX_SIZE_SNIPPET_HTML: &str = include_str!("../snippet/max_size.html.snippet");
|
||||||
|
|
||||||
const ABUSE_SNIPPET_HTML: &str = include_str!("../snippet/abuse.html.snippet");
|
const ABUSE_SNIPPET_HTML: &str = include_str!("../snippet/abuse.html.snippet");
|
||||||
|
|
||||||
|
const UPLOAD_HTML: &str = include_str!("../template/upload.html");
|
||||||
|
const UPLOAD_SHORT_HTML: &str = include_str!("../template/upload-short.html");
|
||||||
|
|
||||||
|
const TEXT_VIEW_HTML: &str = include_str!("../template/text-view.html");
|
||||||
|
const URL_VIEW_HTML: &str = include_str!("../template/url-view.html");
|
||||||
|
|
||||||
|
pub fn build_uploaded_html(
|
||||||
|
req: &HttpRequest,
|
||||||
|
id: &str,
|
||||||
|
name: Option<&str>,
|
||||||
|
config: &Config,
|
||||||
|
) -> String {
|
||||||
|
let upload_html = if name.is_some() {
|
||||||
|
UPLOAD_SHORT_HTML
|
||||||
|
.replace("{link}", &get_file_url(req, id, name))
|
||||||
|
.replace("{shortlink}", &get_file_url(req, id, None))
|
||||||
|
} else {
|
||||||
|
UPLOAD_HTML.replace("{link}", &get_file_url(req, id, name))
|
||||||
|
};
|
||||||
|
insert_abuse_template(upload_html, None, config)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn get_file_url(req: &HttpRequest, id: &str, name: Option<&str>) -> String {
|
||||||
|
let host = get_host_url(req);
|
||||||
|
if let Some(name) = name {
|
||||||
|
let encoded_name = urlencoding::encode(name);
|
||||||
|
format!("{host}/{id}/{encoded_name}")
|
||||||
|
} else {
|
||||||
|
format!("{host}/{id}")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn build_html_view_template(content: &str, req: &HttpRequest, config: &Config) -> String {
|
||||||
|
let encoded = htmlescape::encode_minimal(content);
|
||||||
|
let html = if !content.trim().contains(['\n', '\r']) && Url::from_str(content.trim()).is_ok() {
|
||||||
|
let attribute_encoded = htmlescape::encode_attribute(content);
|
||||||
|
URL_VIEW_HTML
|
||||||
|
.replace("{link_content}", &encoded)
|
||||||
|
.replace("{link_attribute}", &attribute_encoded)
|
||||||
|
} else {
|
||||||
|
TEXT_VIEW_HTML.replace("{text}", &encoded)
|
||||||
|
};
|
||||||
|
insert_abuse_template(html, Some(req), config)
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn write_prefillable_templates(config: &Config) {
|
pub async fn write_prefillable_templates(config: &Config) {
|
||||||
let index_path = config.static_dir.join("index.html");
|
let index_path = config.static_dir.join("index.html");
|
||||||
fs::write(index_path, build_index_html(config))
|
fs::write(index_path, build_index_html(config))
|
||||||
|
|
|
@ -13,9 +13,6 @@ use std::path::PathBuf;
|
||||||
use tokio::fs::{self, OpenOptions};
|
use tokio::fs::{self, OpenOptions};
|
||||||
use tokio::sync::mpsc::Sender;
|
use tokio::sync::mpsc::Sender;
|
||||||
|
|
||||||
const UPLOAD_HTML: &str = include_str!("../template/upload.html");
|
|
||||||
const UPLOAD_SHORT_HTML: &str = include_str!("../template/upload-short.html");
|
|
||||||
|
|
||||||
const ID_CHARS: &[char] = &[
|
const ID_CHARS: &[char] = &[
|
||||||
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'm', 'n', 'p', 'q', 'r', 's', 't', 'u',
|
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'm', 'n', 'p', 'q', 'r', 's', 't', 'u',
|
||||||
'v', 'w', 'x', 'y', 'z', '1', '2', '3', '4', '5', '6', '7', '8', '9',
|
'v', 'w', 'x', 'y', 'z', '1', '2', '3', '4', '5', '6', '7', '8', '9',
|
||||||
|
@ -63,7 +60,7 @@ pub async fn upload(
|
||||||
expiry_watch_sender.send(()).await.unwrap();
|
expiry_watch_sender.send(()).await.unwrap();
|
||||||
|
|
||||||
let redirect = get_redirect_url(&file_id, upload_config.original_name.as_deref());
|
let redirect = get_redirect_url(&file_id, upload_config.original_name.as_deref());
|
||||||
let url = get_file_url(&req, &file_id, upload_config.original_name.as_deref());
|
let url = template::get_file_url(&req, &file_id, upload_config.original_name.as_deref());
|
||||||
Ok(HttpResponse::SeeOther()
|
Ok(HttpResponse::SeeOther()
|
||||||
.insert_header((LOCATION, redirect))
|
.insert_header((LOCATION, redirect))
|
||||||
.body(format!("{url}\n")))
|
.body(format!("{url}\n")))
|
||||||
|
@ -125,16 +122,6 @@ fn gen_file_id() -> String {
|
||||||
.collect()
|
.collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_file_url(req: &HttpRequest, id: &str, name: Option<&str>) -> String {
|
|
||||||
let host = template::get_host_url(req);
|
|
||||||
if let Some(name) = name {
|
|
||||||
let encoded_name = urlencoding::encode(name);
|
|
||||||
format!("{host}/{id}/{encoded_name}")
|
|
||||||
} else {
|
|
||||||
format!("{host}/{id}")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn get_redirect_url(id: &str, name: Option<&str>) -> String {
|
fn get_redirect_url(id: &str, name: Option<&str>) -> String {
|
||||||
if let Some(name) = name {
|
if let Some(name) = name {
|
||||||
let encoded_name = urlencoding::encode(name);
|
let encoded_name = urlencoding::encode(name);
|
||||||
|
@ -152,15 +139,8 @@ pub async fn uploaded(req: HttpRequest, config: web::Data<Config>) -> Result<Htt
|
||||||
.map(urlencoding::decode)
|
.map(urlencoding::decode)
|
||||||
.transpose()
|
.transpose()
|
||||||
.map_err(|_| error::ErrorBadRequest("name is invalid utf-8"))?;
|
.map_err(|_| error::ErrorBadRequest("name is invalid utf-8"))?;
|
||||||
let mut upload_html = if name.is_some() {
|
let uploaded_html = template::build_uploaded_html(&req, id, name.as_deref(), &config);
|
||||||
UPLOAD_SHORT_HTML
|
|
||||||
.replace("{link}", &get_file_url(&req, id, name.as_deref()))
|
|
||||||
.replace("{shortlink}", &get_file_url(&req, id, None))
|
|
||||||
} else {
|
|
||||||
UPLOAD_HTML.replace("{link}", &get_file_url(&req, id, name.as_deref()))
|
|
||||||
};
|
|
||||||
upload_html = template::insert_abuse_template(upload_html, None, &config);
|
|
||||||
Ok(HttpResponse::Ok()
|
Ok(HttpResponse::Ok()
|
||||||
.content_type("text/html")
|
.content_type("text/html")
|
||||||
.body(upload_html))
|
.body(uploaded_html))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue