summaryrefslogtreecommitdiff
path: root/src/models/client.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/models/client.rs')
-rw-r--r--src/models/client.rs14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/models/client.rs b/src/models/client.rs
index 56b0ae6..38be37f 100644
--- a/src/models/client.rs
+++ b/src/models/client.rs
@@ -60,6 +60,10 @@ pub enum CreateClientError {
NoSecret,
#[error("Only confidential clients may be trusted")]
TrustedError,
+ #[error("Redirect URIs must not include a fragment component")]
+ UriFragment,
+ #[error("Redirect URIs must use HTTPS")]
+ NonHttpsUri,
}
impl ResponseError for CreateClientError {
@@ -93,6 +97,16 @@ impl Client {
yeet!(CreateClientError::TrustedError.into());
}
+ for redirect_uri in redirect_uris {
+ if redirect_uri.scheme() != "https" {
+ yeet!(CreateClientError::NonHttpsUri.into())
+ }
+
+ if redirect_uri.fragment().is_some() {
+ yeet!(CreateClientError::UriFragment.into())
+ }
+ }
+
Ok(Self {
id,
alias: Box::from(alias),