Return plaintext to CLI requests
Diff
src/main.rs | 54 ++++++++++++++++++++++++++++++++++++++++++------------
1 file changed, 42 insertions(+), 12 deletions(-)
@@ -1,5 +1,6 @@
#![feature(proc_macro_hygiene, decl_macro)]
#![feature(uniform_paths)]
#![feature(type_alias_enum_variants)]
#[macro_use] extern crate lazy_static;
@@ -17,9 +18,11 @@
use askama::Template;
use askama_escape::{MarkupDisplay, Html};
use rocket::{Request, Data};
use rocket::request::{Form, FromRequest, Outcome};
use rocket::response::Redirect;
use rocket::request::Form;
use rocket::Data;
use rocket::response::content::Content;
use rocket::http::ContentType;
use std::io::Read;
@@ -37,10 +40,11 @@
struct IndexForm {
val: String
}
#[post("/", data = "<input>")]
fn submit(input: Form<IndexForm>) -> Redirect {
let id = store_paste(input.into_inner().val);
Redirect::to(format!("/{}", id))
Redirect::to(uri!(render: id))
}
#[put("/", data = "<input>")]
@@ -54,25 +58,51 @@
#[derive(Template)]
#[template(path = "paste.html")]
struct Render {
content: MarkupDisplay<Html, String>
content: MarkupDisplay<Html, String>,
}
struct IsPlaintextRequest(bool);
impl<'a, 'r> FromRequest<'a, 'r> for IsPlaintextRequest {
type Error = ();
fn from_request(request: &'a Request<'r>) -> Outcome<IsPlaintextRequest, ()> {
if let Some(format) = request.format() {
if format.is_plain() {
return Outcome::Success(IsPlaintextRequest(true));
}
}
match request.headers().get_one("User-Agent").and_then(|u| u.splitn(2, '/').next()) {
None | Some("Wget") | Some("curl") | Some("HTTPie") => Outcome::Success(IsPlaintextRequest(true)),
_ => Outcome::Success(IsPlaintextRequest(false))
}
}
}
#[get("/<key>")]
fn render(key: String) -> Option<Render> {
fn render(key: String, plaintext: IsPlaintextRequest) -> Option<Content<String>> {
let mut splitter = key.splitn(2, '.');
let key = splitter.next().unwrap();
let key = splitter.next()?;
let ext = splitter.next();
let entry = get_paste(key)?;
Some(Render {
content: match ext {
None => MarkupDisplay::new_unsafe(entry, Html),
Some(extension) => MarkupDisplay::new_safe(highlight(&entry, extension)?, Html)
}
})
if plaintext.0 {
Some(Content(ContentType::Plain, entry))
} else {
Some(Content(ContentType::HTML, Render {
content: match ext {
None => MarkupDisplay::new_unsafe(entry, Html),
Some(extension) => MarkupDisplay::new_safe(highlight(&entry, extension)?, Html)
},
}.render().unwrap()))
}
}