add temporary redirects and bad requests
This commit is contained in:
parent
0daf01fd3e
commit
931c3fbbc2
|
@ -1,4 +1,7 @@
|
||||||
|
use std::convert::TryInto;
|
||||||
|
|
||||||
use anyhow::*;
|
use anyhow::*;
|
||||||
|
use uriparse::URIReference;
|
||||||
use crate::types::{ResponseHeader, Body, Mime, Document};
|
use crate::types::{ResponseHeader, Body, Mime, Document};
|
||||||
use crate::util::Cowy;
|
use crate::util::Cowy;
|
||||||
use crate::GEMINI_MIME;
|
use crate::GEMINI_MIME;
|
||||||
|
@ -35,6 +38,11 @@ impl Response {
|
||||||
Self::new(header)
|
Self::new(header)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn redirect_temporary_lossy<'a>(location: impl TryInto<URIReference<'a>>) -> Self {
|
||||||
|
let header = ResponseHeader::redirect_temporary_lossy(location);
|
||||||
|
Self::new(header)
|
||||||
|
}
|
||||||
|
|
||||||
/// Create a successful response with a preconfigured body
|
/// Create a successful response with a preconfigured body
|
||||||
///
|
///
|
||||||
/// This is equivilent to:
|
/// This is equivilent to:
|
||||||
|
@ -58,6 +66,11 @@ impl Response {
|
||||||
Self::new(header)
|
Self::new(header)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn bad_request_lossy(reason: impl Cowy<str>) -> Self {
|
||||||
|
let header = ResponseHeader::bad_request_lossy(reason);
|
||||||
|
Self::new(header)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn client_certificate_required() -> Self {
|
pub fn client_certificate_required() -> Self {
|
||||||
let header = ResponseHeader::client_certificate_required();
|
let header = ResponseHeader::client_certificate_required();
|
||||||
Self::new(header)
|
Self::new(header)
|
||||||
|
|
|
@ -1,4 +1,7 @@
|
||||||
|
use std::convert::TryInto;
|
||||||
|
|
||||||
use anyhow::*;
|
use anyhow::*;
|
||||||
|
use uriparse::URIReference;
|
||||||
use crate::Mime;
|
use crate::Mime;
|
||||||
use crate::util::Cowy;
|
use crate::util::Cowy;
|
||||||
use crate::types::{Status, Meta};
|
use crate::types::{Status, Meta};
|
||||||
|
@ -31,6 +34,18 @@ impl ResponseHeader {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn redirect_temporary_lossy<'a>(location: impl TryInto<URIReference<'a>>) -> Self {
|
||||||
|
let location = match location.try_into() {
|
||||||
|
Ok(location) => location,
|
||||||
|
Err(_) => return Self::bad_request_lossy("Invalid redirect location"),
|
||||||
|
};
|
||||||
|
|
||||||
|
Self {
|
||||||
|
status: Status::REDIRECT_TEMPORARY,
|
||||||
|
meta: Meta::new_lossy(location.to_string()),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn server_error(reason: impl Cowy<str>) -> Result<Self> {
|
pub fn server_error(reason: impl Cowy<str>) -> Result<Self> {
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
status: Status::PERMANENT_FAILURE,
|
status: Status::PERMANENT_FAILURE,
|
||||||
|
@ -52,6 +67,13 @@ impl ResponseHeader {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn bad_request_lossy(reason: impl Cowy<str>) -> Self {
|
||||||
|
Self {
|
||||||
|
status: Status::BAD_REQUEST,
|
||||||
|
meta: Meta::new_lossy(reason),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn client_certificate_required() -> Self {
|
pub fn client_certificate_required() -> Self {
|
||||||
Self {
|
Self {
|
||||||
status: Status::CLIENT_CERTIFICATE_REQUIRED,
|
status: Status::CLIENT_CERTIFICATE_REQUIRED,
|
||||||
|
|
Loading…
Reference in New Issue