Added in autorewrite as an option to Server

This commit is contained in:
Emii Tatsuo 2020-12-01 21:59:00 -05:00
parent 8f86bac608
commit 05e4d25a53
Signed by: Emi
GPG key ID: 68FAB2E2E6DFC98B
2 changed files with 34 additions and 2 deletions

View file

@ -77,6 +77,7 @@ struct ServerInner {
routes: Arc<RoutingNode<Handler>>, routes: Arc<RoutingNode<Handler>>,
timeout: Duration, timeout: Duration,
complex_timeout: Option<Duration>, complex_timeout: Option<Duration>,
autorewrite: bool,
#[cfg(feature="ratelimiting")] #[cfg(feature="ratelimiting")]
rate_limits: Arc<RoutingNode<RateLimiter<IpAddr>>>, rate_limits: Arc<RoutingNode<RateLimiter<IpAddr>>>,
#[cfg(feature="user_management")] #[cfg(feature="user_management")]
@ -206,13 +207,22 @@ impl ServerInner {
request.set_cert(client_cert); request.set_cert(client_cert);
} }
let response = if let Some((trailing, handler)) = self.routes.match_request(&request) { let mut response = if let Some((trailing, handler)) = self.routes.match_request(&request) {
request.set_trailing(trailing); request.set_trailing(trailing);
handler.handle(request).await handler.handle(request.clone()).await
} else { } else {
Response::not_found() Response::not_found()
}; };
match response.rewrite_all(&request).await {
Ok(true) => { /* all is well */ }
Ok(false) => panic!("Upstream did not include SCRIPT_PATH or SCRIPT_NAME"),
Err(e) => {
error!("Error reading text/gemini file from Response reader: {}", e);
response = Response::not_found();
}
}
self.send_response(response, &mut stream).await self.send_response(response, &mut stream).await
.context("Failed to send response")?; .context("Failed to send response")?;
@ -417,6 +427,7 @@ pub struct Server {
timeout: Duration, timeout: Duration,
complex_body_timeout_override: Option<Duration>, complex_body_timeout_override: Option<Duration>,
routes: RoutingNode<Handler>, routes: RoutingNode<Handler>,
autorewrite: bool,
#[cfg(feature = "gemini_srv")] #[cfg(feature = "gemini_srv")]
cert_path: PathBuf, cert_path: PathBuf,
#[cfg(feature = "gemini_srv")] #[cfg(feature = "gemini_srv")]
@ -437,6 +448,7 @@ impl Server {
timeout: Duration::from_secs(1), timeout: Duration::from_secs(1),
complex_body_timeout_override: Some(Duration::from_secs(30)), complex_body_timeout_override: Some(Duration::from_secs(30)),
routes: RoutingNode::default(), routes: RoutingNode::default(),
autorewrite: false,
#[cfg(feature = "gemini_srv")] #[cfg(feature = "gemini_srv")]
cert_path: PathBuf::from("cert/cert.pem"), cert_path: PathBuf::from("cert/cert.pem"),
#[cfg(feature = "gemini_srv")] #[cfg(feature = "gemini_srv")]
@ -621,6 +633,24 @@ impl Server {
self self
} }
/// Enable or disable autorewrite
///
/// Autorewrite automatically detects links in responses being sent out through kochab
/// and rewrites them to match the base of the script. For example, if the script is
/// mounted on "/app", any links to "/page" would be rewritten as "/app/page". This
/// does nothing when in `gemini_srv` mode.
///
/// **Note:** If you are serving *very long* `text/gemini` files using `serve_dir`,
/// then you should avoid setting this to true. Additionally, if using this option,
/// do not try to rewrite your links using [`Request::rewrite_path`] or
/// [`Response::rewrite_all`], as this will apply the rewrite twice.
///
/// For more information about rewriting, see [`Request::rewrite_path`].
pub fn set_autorewrite(mut self, autorewrite: bool) -> Self {
self.autorewrite = autorewrite;
self
}
fn build(mut self) -> Result<ServerInner> { fn build(mut self) -> Result<ServerInner> {
#[cfg(feature = "gemini_srv")] #[cfg(feature = "gemini_srv")]
let config = tls_config( let config = tls_config(
@ -639,6 +669,7 @@ impl Server {
routes: Arc::new(self.routes), routes: Arc::new(self.routes),
timeout: self.timeout, timeout: self.timeout,
complex_timeout: self.complex_body_timeout_override, complex_timeout: self.complex_body_timeout_override,
autorewrite: self.autorewrite,
#[cfg(feature = "gemini_srv")] #[cfg(feature = "gemini_srv")]
tls_acceptor: TlsAcceptor::from(config), tls_acceptor: TlsAcceptor::from(config),
#[cfg(feature="ratelimiting")] #[cfg(feature="ratelimiting")]

View file

@ -17,6 +17,7 @@ use ring::digest;
#[cfg(feature="user_management")] #[cfg(feature="user_management")]
use crate::user_management::{UserManager, User}; use crate::user_management::{UserManager, User};
#[derive(Clone)]
pub struct Request { pub struct Request {
uri: URIReference<'static>, uri: URIReference<'static>,
input: Option<String>, input: Option<String>,