diff options
author | Alex Auvolat <alex@adnab.me> | 2023-08-28 12:16:44 +0200 |
---|---|---|
committer | Alex Auvolat <alex@adnab.me> | 2023-08-28 12:17:10 +0200 |
commit | 9b4ce4a8ad645a012d5bd31d4d588cb7c3962b1a (patch) | |
tree | 2c65366ee08a8f4fc7e1e0f5b74e60bf17afbd63 /src | |
parent | 2bbe2da5adb044d3dfd7be22052cb2962318f9d5 (diff) | |
download | garage-9b4ce4a8ad645a012d5bd31d4d588cb7c3962b1a.tar.gz garage-9b4ce4a8ad645a012d5bd31d4d588cb7c3962b1a.zip |
admin api: refactor caddy check api code
Diffstat (limited to 'src')
-rw-r--r-- | src/api/admin/api_server.rs | 39 |
1 files changed, 22 insertions, 17 deletions
diff --git a/src/api/admin/api_server.rs b/src/api/admin/api_server.rs index 8bf467dc..50c79120 100644 --- a/src/api/admin/api_server.rs +++ b/src/api/admin/api_server.rs @@ -100,6 +100,20 @@ impl AdminApiServer { .get("domain") .ok_or_internal_error("Could not parse domain query string")?; + if self.check_domain(domain).await? { + Ok(Response::builder() + .status(StatusCode::OK) + .body(Body::from(format!( + "Domain '{domain}' is managed by Garage" + )))?) + } else { + Err(Error::bad_request(format!( + "Domain '{domain}' is not managed by Garage" + ))) + } + } + + async fn check_domain(&self, domain: &str) -> Result<bool, Error> { // Resolve bucket from domain name, inferring if the website must be activated for the // domain to be valid. let (bucket_name, must_check_website) = if let Some(bname) = self @@ -123,19 +137,18 @@ impl AdminApiServer { (domain.to_string(), true) }; - let bucket_id = self + let bucket_id = match self .garage .bucket_helper() .resolve_global_bucket_name(&bucket_name) .await? - .ok_or(HelperError::NoSuchBucket(bucket_name.to_string()))?; + { + Some(bucket_id) => bucket_id, + None => return Ok(false), + }; if !must_check_website { - return Ok(Response::builder() - .status(StatusCode::OK) - .body(Body::from(format!( - "Domain '{domain}' is managed by Garage" - )))?); + return Ok(true); } let bucket = self @@ -148,16 +161,8 @@ impl AdminApiServer { let bucket_website_config = bucket_state.website_config.get(); match bucket_website_config { - Some(_v) => { - Ok(Response::builder() - .status(StatusCode::OK) - .body(Body::from(format!( - "Domain '{domain}' is managed by Garage" - )))?) - } - None => Err(Error::bad_request(format!( - "Domain '{domain}' is not managed by Garage" - ))), + Some(_v) => Ok(true), + None => Ok(false), } } |