1#![allow(clippy::use_self)]
7#![allow(clippy::doc_markdown)]
8#![allow(clippy::needless_raw_string_hashes)]
9#![allow(clippy::needless_borrows_for_generic_args)]
10#![allow(clippy::if_same_then_else)]
11#![allow(clippy::map_unwrap_or)]
12#![allow(clippy::unused_self)]
13#![allow(clippy::too_many_arguments)]
14#![allow(clippy::struct_excessive_bools)]
15#![allow(clippy::cast_possible_wrap)]
16#![allow(clippy::only_used_in_recursion)]
17#![allow(clippy::self_only_used_in_recursion)]
18#![allow(clippy::redundant_pub_crate)]
19#![allow(clippy::manual_is_variant_and)]
20#![allow(clippy::unnecessary_literal_bound)]
21
22mod code_executor;
59
60pub mod config;
61mod explanation;
62mod graphql;
63pub mod handler;
64mod token;
65mod types;
66pub mod validation;
67
68pub mod templates;
70
71pub mod schema_exposure;
73
74pub mod policy;
76
77pub mod policy_annotations;
79
80#[cfg(test)]
82pub mod cedar_validation;
83
84#[cfg(feature = "openapi-code-mode")]
86mod javascript;
87
88#[cfg(feature = "sql-code-mode")]
90pub mod sql;
91
92#[cfg(feature = "avp")]
94pub mod avp;
95
96#[cfg(feature = "js-runtime")]
98pub mod executor;
99
100#[cfg(feature = "js-runtime")]
102mod eval;
103
104pub use async_trait::async_trait;
106
107pub use code_executor::CodeExecutor;
109
110pub use config::{resolve_server_id_from_env, CodeModeConfig};
112
113pub use explanation::{ExplanationGenerator, TemplateExplanationGenerator};
114
115pub use graphql::{GraphQLOperationType, GraphQLQueryInfo, GraphQLValidator};
116
117#[cfg(feature = "openapi-code-mode")]
119pub use javascript::{
120 ApiCall, HttpMethod, JavaScriptCodeInfo, JavaScriptValidator, OutputDeclaration,
121 SafetyViolation, SafetyViolationType,
122};
123
124#[cfg(feature = "sql-code-mode")]
126pub use sql::{SqlStatementInfo, SqlStatementType, SqlValidator};
127
128#[cfg(feature = "js-runtime")]
130pub use executor::{
131 filter_blocked_fields, find_blocked_fields_in_output, ApiCallLog, ArrayMethodCall,
132 BinaryOperator, BuiltinFunction, CompileError, ExecutionConfig, ExecutionPlan, ExecutionResult,
133 HttpExecutor, JsExecutor, MockExecutionMode, MockHttpExecutor, MockedCall, PathPart,
134 PathTemplate, PlanCompiler, PlanExecutor, PlanMetadata, PlanStep, SdkExecutor, UnaryOperator,
135 ValueExpr,
136};
137
138#[cfg(feature = "js-runtime")]
140pub use code_executor::{JsCodeExecutor, SdkCodeExecutor};
141
142#[cfg(feature = "mcp-code-mode")]
144pub use executor::McpExecutor;
145
146#[cfg(feature = "mcp-code-mode")]
147pub use code_executor::McpCodeExecutor;
148
149pub use token::{
150 canonicalize_code, compute_context_hash, hash_code, ApprovalToken, HmacTokenGenerator,
151 TokenGenerator, TokenSecret,
152};
153
154pub use types::{
155 CodeLanguage, CodeLocation, CodeType, Complexity, ExecutionError, PolicyViolation, RiskLevel,
156 SecurityAnalysis, SecurityIssue, SecurityIssueType, TokenError, UnifiedAction, ValidationError,
157 ValidationMetadata, ValidationResult,
158};
159
160pub use validation::{ValidationContext, ValidationPipeline};
161
162pub use templates::TemplateContext;
164
165pub use handler::{
167 format_error_response, format_execution_error, CodeModeHandler, CodeModeToolBuilder,
168 ExecuteCodeInput, ValidateCodeInput, ValidationResponse,
169};
170
171pub use policy::{
173 get_baseline_policies, get_code_mode_schema_json, AuthorizationDecision, NoopPolicyEvaluator,
174 OperationEntity, PolicyEvaluationError, PolicyEvaluator, ServerConfigEntity,
175};
176
177#[cfg(feature = "openapi-code-mode")]
178pub use policy::{
179 get_openapi_baseline_policies, get_openapi_code_mode_schema_json, normalize_operation_format,
180 normalize_path_to_pattern, OpenAPIServerEntity, ScriptEntity,
181};
182
183#[cfg(feature = "sql-code-mode")]
184pub use policy::{
185 get_sql_baseline_policies, get_sql_code_mode_schema_json, SqlServerEntity, StatementEntity,
186};
187
188#[cfg(feature = "cedar")]
190pub use policy::cedar::CedarPolicyEvaluator;
191
192#[cfg(feature = "avp")]
194pub use avp::{AvpClient, AvpConfig, AvpError, AvpPolicyEvaluator};
195
196pub use schema_exposure::{
198 CodeModeExposurePolicy, DerivationMetadata, DerivationStats, DerivedSchema, ExposureMode,
199 FilterReason, FilteredOperation, GlobalBlocklist, McpExposurePolicy, MethodExposurePolicy,
200 Operation, OperationCategory, OperationDetails, OperationParameter, OperationRiskLevel,
201 SchemaDeriver, SchemaFormat, SchemaMetadata, SchemaSource, ToolExposurePolicy, ToolOverride,
202};