From bde3596d8a51a119f7129075b8c75cce3bac5207 Mon Sep 17 00:00:00 2001 From: Clement Delafargue Date: Thu, 7 Dec 2023 10:15:49 +0100 Subject: [PATCH] increase default authorization timeout The default 1ms timeout makes sense in the rust library, but the wasm library typically needs more time to run --- src/authorizer.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/authorizer.rs b/src/authorizer.rs index 1e60642..18172cb 100644 --- a/src/authorizer.rs +++ b/src/authorizer.rs @@ -14,6 +14,8 @@ pub struct RunLimits { pub max_time_micro: Option, } +const DEFAULT_TIMEOUT: Duration = Duration::from_millis(10); + impl RunLimits { pub fn to_rust_limits(&self) -> biscuit::datalog::RunLimits { let defaults = biscuit::datalog::RunLimits::default(); @@ -23,7 +25,7 @@ impl RunLimits { max_time: self .max_time_micro .map(Duration::from_micros) - .unwrap_or(defaults.max_time), + .unwrap_or(DEFAULT_TIMEOUT), } } } @@ -139,12 +141,15 @@ impl Authorizer { #[wasm_bindgen(js_name = authorize)] pub fn authorize(&mut self) -> Result { self.0 - .authorize() + .authorize_with_limits(biscuit::datalog::RunLimits { + max_time: DEFAULT_TIMEOUT, + ..Default::default() + }) .map_err(|e| serde_wasm_bindgen::to_value(&e).unwrap()) } #[wasm_bindgen(js_name = authorizeWithLimits)] - pub fn authorizer_with_limits(&mut self, limits: JsValue) -> Result { + pub fn authorize_with_limits(&mut self, limits: JsValue) -> Result { let limits: RunLimits = serde_wasm_bindgen::from_value(limits)?; self.0 .authorize_with_limits(limits.to_rust_limits())