From 8e593abadd9d3723810c644af01e1124badca244 Mon Sep 17 00:00:00 2001 From: Leigh McCulloch <351529+leighmcculloch@users.noreply.github.com> Date: Fri, 17 Nov 2023 17:03:02 -0800 Subject: [PATCH] Fix top contract invocation hook and auth interaction (#1231) ### What Trigger top contract invocation finish hook after storing the auth manager. ### Why So that hook implementations can access the auth state that occurred during the run. ### Merging Intended to be merged to `main` after: - #1230 --- soroban-env-host/src/host/frame.rs | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/soroban-env-host/src/host/frame.rs b/soroban-env-host/src/host/frame.rs index 1a4c412a2..c9097c3a7 100644 --- a/soroban-env-host/src/host/frame.rs +++ b/soroban-env-host/src/host/frame.rs @@ -466,6 +466,15 @@ impl Host { } #[cfg(any(test, feature = "testutils"))] if end_depth == 0 { + // Empty call stack in tests means that some contract function call + // has been finished and hence the authorization manager can be reset. + // In non-test scenarios, there should be no need to ever reset + // the authorization manager as the host instance shouldn't be + // shared between the contract invocations. + *self.try_borrow_previous_authorization_manager_mut()? = + Some(self.try_borrow_authorization_manager()?.clone()); + self.try_borrow_authorization_manager_mut()?.reset(); + // Call the contract invocation hook for contract invocations only. if is_top_contract_invocation { if let Some(top_contract_invocation_hook) = @@ -477,14 +486,6 @@ impl Host { ); } } - // Empty call stack in tests means that some contract function call - // has been finished and hence the authorization manager can be reset. - // In non-test scenarios, there should be no need to ever reset - // the authorization manager as the host instance shouldn't be - // shared between the contract invocations. - *self.try_borrow_previous_authorization_manager_mut()? = - Some(self.try_borrow_authorization_manager()?.clone()); - self.try_borrow_authorization_manager_mut()?.reset(); } res }