pub struct ToolAuthorization {
pub allow_unknown_with_admin: bool,
}Expand description
Tool authorization configuration (CRIT-003).
Maps tool names to required scopes for fine-grained access control.
Unknown tools are explicitly denied by returning None from required_scope.
Fields§
§allow_unknown_with_admin: boolWhether to allow unknown tools with admin scope (default: false, deny unknown).
Implementations§
Source§impl ToolAuthorization
impl ToolAuthorization
Sourceconst KNOWN_TOOLS: &'static [(&'static str, &'static str)]
const KNOWN_TOOLS: &'static [(&'static str, &'static str)]
Known tools and their scopes (compile-time constant for security).
Sourcepub fn required_scope(&self, tool_name: &str) -> Option<&'static str>
pub fn required_scope(&self, tool_name: &str) -> Option<&'static str>
Returns the required scope for a tool, or None if the tool is unknown.
§Security
Unknown tools return None to enforce explicit denial by default.
This prevents authorization bypass via unrecognized tool names.
Tool scope mapping:
subcog_capture,subcog_enrich,subcog_consolidate: “write”subcog_recall,subcog_status,subcog_namespaces,prompt_understanding: “read”subcog_sync,subcog_reindex: “admin”prompt_save,prompt_delete: “write”prompt_list,prompt_get,prompt_run: “read”- Unknown tools:
None(explicit deny) or “admin” ifallow_unknown_with_admin
Sourcepub fn is_known_tool(tool_name: &str) -> bool
pub fn is_known_tool(tool_name: &str) -> bool
Checks if a tool name is known to the authorization system.
This is part of the public API for callers to verify tool names before making authorization requests.
Trait Implementations§
Source§impl Clone for ToolAuthorization
impl Clone for ToolAuthorization
Source§fn clone(&self) -> ToolAuthorization
fn clone(&self) -> ToolAuthorization
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for ToolAuthorization
impl Debug for ToolAuthorization
Source§impl Default for ToolAuthorization
impl Default for ToolAuthorization
Source§fn default() -> ToolAuthorization
fn default() -> ToolAuthorization
Returns the “default value” for a type. Read more
Auto Trait Implementations§
impl Freeze for ToolAuthorization
impl RefUnwindSafe for ToolAuthorization
impl Send for ToolAuthorization
impl Sync for ToolAuthorization
impl Unpin for ToolAuthorization
impl UnwindSafe for ToolAuthorization
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].