in proxy_agent/src/proxy/proxy_authorizer.rs [53:77]
fn authorize(
&self,
logger: &mut ConnectionLogger,
request_url: hyper::Uri,
access_control_rules: Option<ComputedAuthorizationItem>,
) -> AuthorizeResult {
if !self.claims.runAsElevated {
return AuthorizeResult::Forbidden;
}
if let Some(rules) = access_control_rules {
if rules.is_allowed(logger, request_url.clone(), self.claims.clone()) {
return AuthorizeResult::Ok;
} else {
if rules.mode == AuthorizationMode::Audit {
logger.write(
LoggerLevel::Info, format!("WireServer request {} denied in audit mode, continue forward the request", request_url));
return AuthorizeResult::OkWithAudit;
}
return AuthorizeResult::Forbidden;
}
}
AuthorizeResult::Ok
}