core-runtime 0.1.1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- api/__init__.py +4 -0
- api/cli/__init__.py +10 -0
- api/cli/audit_client.py +92 -0
- api/cli/census_client.py +77 -0
- api/cli/client.py +508 -0
- api/cli/coverage_client.py +121 -0
- api/cli/daemon_client.py +42 -0
- api/cli/fix_client.py +101 -0
- api/cli/inspect_client.py +143 -0
- api/cli/integration_client.py +42 -0
- api/cli/integrity_client.py +45 -0
- api/cli/proposals_client.py +101 -0
- api/cli/quality_client.py +83 -0
- api/cli/refactor_client.py +82 -0
- api/cli/sync_client.py +106 -0
- api/dependencies.py +37 -0
- api/errors.py +74 -0
- api/main.py +88 -0
- api/v1/__init__.py +4 -0
- api/v1/audit_routes.py +302 -0
- api/v1/census_routes.py +207 -0
- api/v1/coverage_routes.py +352 -0
- api/v1/daemon_routes.py +86 -0
- api/v1/development_routes.py +70 -0
- api/v1/fix_routes.py +428 -0
- api/v1/inspect_routes.py +220 -0
- api/v1/integration_routes.py +56 -0
- api/v1/integrity_routes.py +72 -0
- api/v1/knowledge_routes.py +36 -0
- api/v1/lint_routes.py +40 -0
- api/v1/proposals_routes.py +267 -0
- api/v1/quality_routes.py +272 -0
- api/v1/refactor_routes.py +225 -0
- api/v1/sync_routes.py +261 -0
- body/__init__.py +4 -0
- body/analyzers/__init__.py +25 -0
- body/analyzers/base_analyzer.py +28 -0
- body/analyzers/constitutional_path_analyzer.py +63 -0
- body/analyzers/file_analyzer.py +211 -0
- body/analyzers/knowledge_graph_analyzer.py +86 -0
- body/analyzers/prompt_analyzer.py +155 -0
- body/analyzers/symbol_extractor.py +280 -0
- body/atomic/__init__.py +74 -0
- body/atomic/build_tests_action.py +354 -0
- body/atomic/check_actions.py +142 -0
- body/atomic/crate_ops.py +59 -0
- body/atomic/executor.py +470 -0
- body/atomic/file_ops.py +153 -0
- body/atomic/fix_actions.py +1142 -0
- body/atomic/import_resolver.py +200 -0
- body/atomic/metadata_ops.py +161 -0
- body/atomic/modularity_fix.py +839 -0
- body/atomic/modularity_splitter.py +521 -0
- body/atomic/proposal_lifecycle_actions.py +171 -0
- body/atomic/registry.py +326 -0
- body/atomic/remediate_cognitive_role.py +104 -0
- body/atomic/sandbox_lifecycle.py +252 -0
- body/atomic/split_plan.py +155 -0
- body/atomic/sync_actions/__init__.py +22 -0
- body/atomic/sync_actions/chunking_helpers.py +218 -0
- body/atomic/sync_actions/sync_actions.py +431 -0
- body/atomic/test_actions.py +47 -0
- body/autonomy/__init__.py +16 -0
- body/autonomy/audit_analyzer.py +343 -0
- body/autonomy/micro_proposal_executor.py +316 -0
- body/crate_processing/canary_executor.py +144 -0
- body/evaluators/__init__.py +27 -0
- body/evaluators/atomic_actions_evaluator.py +162 -0
- body/evaluators/atomic_actions_format.py +45 -0
- body/evaluators/atomic_actions_rules.py +278 -0
- body/evaluators/base_evaluator.py +67 -0
- body/evaluators/clarity_evaluator.py +83 -0
- body/evaluators/constitutional_evaluator.py +227 -0
- body/evaluators/failure_evaluator.py +136 -0
- body/evaluators/performance_evaluator.py +341 -0
- body/evaluators/security_evaluator.py +393 -0
- body/flows/__init__.py +33 -0
- body/flows/executor.py +275 -0
- body/flows/registry.py +272 -0
- body/flows/result.py +113 -0
- body/governance/__init__.py +29 -0
- body/governance/body_contracts_service.py +317 -0
- body/governance/code_validator.py +118 -0
- body/governance/engine_dispatcher.py +128 -0
- body/governance/intent_guard.py +592 -0
- body/governance/intent_pattern_validators.py +197 -0
- body/governance/key_management_service.py +100 -0
- body/governance/path_validator.py +187 -0
- body/governance/remediation_service.py +263 -0
- body/governance/runtime_validator.py +184 -0
- body/infrastructure/bootstrap.py +135 -0
- body/infrastructure/lifespan.py +85 -0
- body/infrastructure/repositories/__init__.py +1 -0
- body/infrastructure/repositories/decision_trace_repository.py +210 -0
- body/infrastructure/repositories/refusal_repository.py +294 -0
- body/introspection/__init__.py +4 -0
- body/introspection/capability_discovery_service.py +107 -0
- body/introspection/discovery/from_kgb.py +33 -0
- body/introspection/discovery/from_source_scan.py +40 -0
- body/introspection/discovery/loader.py +62 -0
- body/introspection/discovery/registry.py +22 -0
- body/introspection/discovery/semantics.py +21 -0
- body/introspection/discovery/sync.py +47 -0
- body/introspection/drift_detector.py +81 -0
- body/introspection/drift_service.py +48 -0
- body/introspection/export_vectors.py +133 -0
- body/introspection/generate_capability_docs.py +130 -0
- body/introspection/generate_correction_map.py +98 -0
- body/introspection/graph_analysis_service.py +66 -0
- body/introspection/knowledge_graph_service.py +170 -0
- body/introspection/semantic_clusterer.py +128 -0
- body/introspection/symbol_index_builder.py +244 -0
- body/introspection/sync/engine.py +92 -0
- body/introspection/sync/scanner.py +56 -0
- body/introspection/sync/visitor.py +83 -0
- body/introspection/sync_service.py +62 -0
- body/invokers/__init__.py +4 -0
- body/invokers/capability_invoker.py +4 -0
- body/maintenance/command_sync_service.py +73 -0
- body/maintenance/dotenv_sync_service.py +99 -0
- body/maintenance/idempotency_harness.py +70 -0
- body/maintenance/maintenance_service.py +123 -0
- body/maintenance/memory_cleanup_service.py +131 -0
- body/maintenance/refactor_settings_access.py +274 -0
- body/maintenance/scripts/__init__.py +5 -0
- body/maintenance/scripts/context_export.py +278 -0
- body/maintenance/scripts/vector_verify.py +73 -0
- body/maintenance/sync_vectors.py +338 -0
- body/models/__init__.py +4 -0
- body/project_lifecycle/__init__.py +4 -0
- body/project_lifecycle/bootstrap_service.py +157 -0
- body/project_lifecycle/definition_service.py +264 -0
- body/project_lifecycle/integration_service.py +113 -0
- body/project_lifecycle/scaffolding_service.py +187 -0
- body/quality/coverage_analyzer.py +177 -0
- body/repositories/__init__.py +4 -0
- body/self_healing/atomic_actions_fixer.py +113 -0
- body/self_healing/body_ui_fixer.py +193 -0
- body/self_healing/capability_parser.py +65 -0
- body/self_healing/code_style_service.py +51 -0
- body/self_healing/complexity_filter.py +70 -0
- body/self_healing/docstring_service.py +345 -0
- body/self_healing/duplicate_id_service.py +407 -0
- body/self_healing/duplicates_service.py +165 -0
- body/self_healing/handlers/__init__.py +1 -0
- body/self_healing/handlers/id_assignment_handler.py +201 -0
- body/self_healing/handlers/import_sorting_handler.py +181 -0
- body/self_healing/header_service.py +308 -0
- body/self_healing/id_tagging_service.py +227 -0
- body/self_healing/knowledge_consolidation_service.py +80 -0
- body/self_healing/logging_service.py +292 -0
- body/self_healing/owner_tagging_service.py +5 -0
- body/self_healing/placeholder_fixer_service.py +27 -0
- body/self_healing/prune_private_capabilities.py +144 -0
- body/self_healing/purge_legacy_tags_service.py +146 -0
- body/self_healing/remediation_models.py +238 -0
- body/self_healing/test_context/__init__.py +10 -0
- body/self_healing/test_context/detectors.py +74 -0
- body/self_healing/test_context/examples.py +53 -0
- body/self_healing/test_context/formatter.py +65 -0
- body/self_healing/test_context/metrics.py +62 -0
- body/self_healing/test_context/models.py +83 -0
- body/self_healing/test_context/parsers.py +70 -0
- body/self_healing/test_context_analyzer.py +79 -0
- body/self_healing/test_failure_analyzer.py +259 -0
- body/self_healing/test_target_analyzer.py +118 -0
- body/self_healing/vulture_healer.py +161 -0
- body/services/__init__.py +4 -0
- body/services/artifact_service.py +155 -0
- body/services/blackboard_service/__init__.py +22 -0
- body/services/blackboard_service/blackboard_claim_service.py +216 -0
- body/services/blackboard_service/blackboard_proposal_service.py +305 -0
- body/services/blackboard_service/blackboard_query_service.py +333 -0
- body/services/blackboard_service/blackboard_service.py +602 -0
- body/services/capabilities.py +51 -0
- body/services/cim/__init__.py +22 -0
- body/services/cim/baselines.py +102 -0
- body/services/cim/census_service.py +190 -0
- body/services/cim/cim_constants.py +116 -0
- body/services/cim/cim_path_utils.py +123 -0
- body/services/cim/diff.py +152 -0
- body/services/cim/history.py +94 -0
- body/services/cim/models.py +319 -0
- body/services/cim/policy.py +149 -0
- body/services/cim/scanners.py +332 -0
- body/services/coherence_service.py +552 -0
- body/services/consequence_log_service.py +189 -0
- body/services/constitutional_rule_loader.py +141 -0
- body/services/constitutional_validator.py +366 -0
- body/services/crate_creation_service.py +217 -0
- body/services/crate_processing_service.py +279 -0
- body/services/crawl_service/__init__.py +10 -0
- body/services/crawl_service/main_module.py +531 -0
- body/services/crawl_service/orchestrator.py +452 -0
- body/services/crawl_service/symbol_processing.py +279 -0
- body/services/database_service.py +242 -0
- body/services/doc_service.py +57 -0
- body/services/file_service.py +260 -0
- body/services/governance_claims_service.py +240 -0
- body/services/governance_init.py +41 -0
- body/services/health_log_service.py +167 -0
- body/services/intent_schema_validator.py +211 -0
- body/services/llm_client.py +87 -0
- body/services/mind_state_service.py +129 -0
- body/services/policy_expression_evaluator.py +154 -0
- body/services/proposal_supervision_service.py +187 -0
- body/services/representation_coherence_service.py +209 -0
- body/services/service_registry.py +431 -0
- body/services/session_attached_service.py +51 -0
- body/services/symbol_query_service.py +218 -0
- body/services/symbol_service.py +94 -0
- body/services/validation/__init__.py +14 -0
- body/services/validation/python_validator.py +89 -0
- body/services/validation/validation_policies.py +121 -0
- body/services/worker_registry_service.py +184 -0
- body/validators/__init__.py +1 -0
- body/validators/logic_conservation_validator.py +201 -0
- body/workers/call_site_rewriter.py +527 -0
- body/workers/prompt_artifact_writer.py +323 -0
- cli/__init__.py +4 -0
- cli/admin_cli.py +98 -0
- cli/cli_user.py +121 -0
- cli/commands/__init__.py +4 -0
- cli/commands/audit_reporter.py +272 -0
- cli/commands/check/__init__.py +115 -0
- cli/commands/check/audit.py +130 -0
- cli/commands/check/converters.py +129 -0
- cli/commands/check/diagnostics_commands.py +70 -0
- cli/commands/check/formatters.py +310 -0
- cli/commands/check/imports.py +73 -0
- cli/commands/check/quality.py +71 -0
- cli/commands/check/quality_gates.py +107 -0
- cli/commands/check/rule.py +136 -0
- cli/commands/check/utils.py +28 -0
- cli/commands/check_atomic_actions.py +167 -0
- cli/commands/components.py +66 -0
- cli/commands/coverage/__init__.py +22 -0
- cli/commands/coverage/analysis_commands.py +87 -0
- cli/commands/coverage/check_commands.py +173 -0
- cli/commands/coverage/generation_commands.py +155 -0
- cli/commands/coverage/services/__init__.py +15 -0
- cli/commands/coverage/services/coverage_checker.py +50 -0
- cli/commands/coverage/services/coverage_reporter.py +81 -0
- cli/commands/coverage/services/gaps_analyzer.py +114 -0
- cli/commands/daemon.py +908 -0
- cli/commands/develop.py +127 -0
- cli/commands/diagnostics.py +32 -0
- cli/commands/fix/__init__.py +84 -0
- cli/commands/fix/all_commands.py +94 -0
- cli/commands/fix/atomic_actions.py +48 -0
- cli/commands/fix/audit.py +146 -0
- cli/commands/fix/body_ui.py +93 -0
- cli/commands/fix/code_style.py +52 -0
- cli/commands/fix/db_tools.py +90 -0
- cli/commands/fix/fix_ir.py +79 -0
- cli/commands/fix/handler_discovery.py +54 -0
- cli/commands/fix/imports.py +55 -0
- cli/commands/fix/list_commands.py +54 -0
- cli/commands/fix/metadata.py +160 -0
- cli/commands/fix/modularity.py +88 -0
- cli/commands/fix/settings_access.py +65 -0
- cli/commands/fix_governed.py +103 -0
- cli/commands/fix_logging.py +24 -0
- cli/commands/governance.py +294 -0
- cli/commands/guard.py +125 -0
- cli/commands/inspect/__init__.py +79 -0
- cli/commands/inspect/_helpers.py +226 -0
- cli/commands/inspect/analysis.py +158 -0
- cli/commands/inspect/decisions.py +140 -0
- cli/commands/inspect/diagnostics.py +126 -0
- cli/commands/inspect/drift.py +100 -0
- cli/commands/inspect/patterns.py +102 -0
- cli/commands/inspect/refusals.py +211 -0
- cli/commands/inspect/repo_census.py +175 -0
- cli/commands/inspect/status.py +48 -0
- cli/commands/interactive_test.py +85 -0
- cli/commands/mind.py +49 -0
- cli/commands/refactor.py +234 -0
- cli/commands/refactor_support/__init__.py +7 -0
- cli/commands/refactor_support/analyzer.py +107 -0
- cli/commands/refactor_support/config.py +67 -0
- cli/commands/refactor_support/display.py +170 -0
- cli/commands/refactor_support/recommendations.py +55 -0
- cli/commands/run.py +60 -0
- cli/commands/search.py +103 -0
- cli/commands/status.py +86 -0
- cli/commands/submit.py +23 -0
- cli/interactive.py +177 -0
- cli/logic/__init__.py +7 -0
- cli/logic/agent.py +110 -0
- cli/logic/audit_capability_domains.py +106 -0
- cli/logic/audit_renderer.py +150 -0
- cli/logic/autonomy/actions.py +36 -0
- cli/logic/autonomy/views.py +116 -0
- cli/logic/body_contracts_checker.py +23 -0
- cli/logic/build.py +27 -0
- cli/logic/byor.py +148 -0
- cli/logic/capability.py +27 -0
- cli/logic/cli_utils.py +210 -0
- cli/logic/context.py +7 -0
- cli/logic/db.py +154 -0
- cli/logic/db_manage.py +22 -0
- cli/logic/decision_inspect_logic.py +62 -0
- cli/logic/diagnostics.py +148 -0
- cli/logic/diagnostics_policy.py +100 -0
- cli/logic/diagnostics_registry.py +165 -0
- cli/logic/duplicates.py +19 -0
- cli/logic/embeddings_cli.py +43 -0
- cli/logic/governance/__init__.py +16 -0
- cli/logic/governance/engine.py +216 -0
- cli/logic/governance/forensics_service.py +67 -0
- cli/logic/governance/limb_status_service.py +83 -0
- cli/logic/governance/renderer.py +115 -0
- cli/logic/governance/traceability_service.py +78 -0
- cli/logic/governance_logic.py +33 -0
- cli/logic/hub/__init__.py +14 -0
- cli/logic/hub/app.py +107 -0
- cli/logic/hub/formatter.py +29 -0
- cli/logic/hub/introspection.py +20 -0
- cli/logic/hub/repository.py +17 -0
- cli/logic/init.py +22 -0
- cli/logic/interactive_test/__init__.py +21 -0
- cli/logic/interactive_test/session.py +102 -0
- cli/logic/interactive_test/steps/__init__.py +23 -0
- cli/logic/interactive_test/steps/execution.py +53 -0
- cli/logic/interactive_test/steps/generation.py +88 -0
- cli/logic/interactive_test/steps/healing.py +79 -0
- cli/logic/interactive_test/steps/utils.py +31 -0
- cli/logic/interactive_test/steps/verification.py +71 -0
- cli/logic/interactive_test/ui.py +203 -0
- cli/logic/interactive_test/workflow.py +168 -0
- cli/logic/interactive_test_logic.py +41 -0
- cli/logic/knowledge.py +47 -0
- cli/logic/legacy_scan_logic.py +306 -0
- cli/logic/list_audits.py +49 -0
- cli/logic/log_audit.py +53 -0
- cli/logic/new.py +8 -0
- cli/logic/project_docs.py +28 -0
- cli/logic/reconcile.py +127 -0
- cli/logic/refusal_inspect_logic.py +208 -0
- cli/logic/report.py +47 -0
- cli/logic/status.py +47 -0
- cli/logic/symbol_drift.py +77 -0
- cli/logic/sync.py +48 -0
- cli/logic/sync_domains.py +72 -0
- cli/logic/sync_manifest.py +31 -0
- cli/logic/tools.py +133 -0
- cli/logic/utils_migration.py +43 -0
- cli/logic/validate.py +107 -0
- cli/logic/vector_drift.py +109 -0
- cli/logic/yaml_processor.py +5 -0
- cli/renderers/audit_detail.py +37 -0
- cli/renderers/audit_overview.py +39 -0
- cli/resources/__init__.py +27 -0
- cli/resources/admin/__init__.py +23 -0
- cli/resources/admin/coverage.py +63 -0
- cli/resources/admin/debt_scan.py +195 -0
- cli/resources/admin/forensics.py +97 -0
- cli/resources/admin/health.py +66 -0
- cli/resources/admin/hub.py +9 -0
- cli/resources/admin/meta.py +47 -0
- cli/resources/admin/patterns.py +28 -0
- cli/resources/admin/refusals.py +31 -0
- cli/resources/admin/self_check.py +175 -0
- cli/resources/admin/status.py +66 -0
- cli/resources/admin/summary.py +67 -0
- cli/resources/admin/traces.py +46 -0
- cli/resources/admin/validate_env.py +56 -0
- cli/resources/code/__init__.py +31 -0
- cli/resources/code/actions.py +48 -0
- cli/resources/code/audit.py +416 -0
- cli/resources/code/audit_duplicates.py +22 -0
- cli/resources/code/check_imports.py +75 -0
- cli/resources/code/check_ui.py +62 -0
- cli/resources/code/clarity.py +51 -0
- cli/resources/code/complexity.py +55 -0
- cli/resources/code/docstrings.py +51 -0
- cli/resources/code/fix_atomic.py +51 -0
- cli/resources/code/format.py +62 -0
- cli/resources/code/hub.py +10 -0
- cli/resources/code/integrity.py +75 -0
- cli/resources/code/lint.py +37 -0
- cli/resources/code/logging.py +49 -0
- cli/resources/code/refactor.py +32 -0
- cli/resources/code/test.py +30 -0
- cli/resources/coherence/__init__.py +13 -0
- cli/resources/coherence/check.py +111 -0
- cli/resources/coherence/hub.py +13 -0
- cli/resources/coherence/repair_counts.py +73 -0
- cli/resources/coherence/report.py +144 -0
- cli/resources/coherence/seed.py +297 -0
- cli/resources/coherence/supersede.py +124 -0
- cli/resources/coherence/triage.py +81 -0
- cli/resources/constitution/__init__.py +19 -0
- cli/resources/constitution/audit.py +49 -0
- cli/resources/constitution/query.py +45 -0
- cli/resources/constitution/status.py +34 -0
- cli/resources/constitution/validate.py +36 -0
- cli/resources/context/__init__.py +21 -0
- cli/resources/context/build.py +374 -0
- cli/resources/context/cache.py +156 -0
- cli/resources/context/explain.py +140 -0
- cli/resources/context/hub.py +11 -0
- cli/resources/context/search.py +114 -0
- cli/resources/database/__init__.py +13 -0
- cli/resources/database/cleanup.py +107 -0
- cli/resources/database/export.py +61 -0
- cli/resources/database/hub.py +11 -0
- cli/resources/database/migrate.py +57 -0
- cli/resources/database/status.py +101 -0
- cli/resources/database/sync.py +84 -0
- cli/resources/database/sync_env.py +76 -0
- cli/resources/database/sync_registry.py +48 -0
- cli/resources/dev/__init__.py +14 -0
- cli/resources/dev/hub.py +11 -0
- cli/resources/dev/refactor.py +92 -0
- cli/resources/dev/stability.py +60 -0
- cli/resources/dev/strategic_audit.py +113 -0
- cli/resources/dev/sync.py +51 -0
- cli/resources/dev/test.py +34 -0
- cli/resources/intent/__init__.py +11 -0
- cli/resources/intent/hub.py +9 -0
- cli/resources/intent/sync_vocabulary.py +396 -0
- cli/resources/project/__init__.py +19 -0
- cli/resources/project/docs.py +41 -0
- cli/resources/project/new.py +40 -0
- cli/resources/project/onboard.py +31 -0
- cli/resources/proposals/__init__.py +28 -0
- cli/resources/proposals/create.py +82 -0
- cli/resources/proposals/integrate.py +49 -0
- cli/resources/proposals/list.py +76 -0
- cli/resources/proposals/manage.py +117 -0
- cli/resources/runtime/__init__.py +9 -0
- cli/resources/runtime/health.py +925 -0
- cli/resources/secrets/__init__.py +10 -0
- cli/resources/secrets/hub.py +9 -0
- cli/resources/secrets/manage.py +309 -0
- cli/resources/symbols/__init__.py +13 -0
- cli/resources/symbols/audit.py +46 -0
- cli/resources/symbols/fix_ids.py +43 -0
- cli/resources/symbols/hub.py +11 -0
- cli/resources/symbols/resolve_duplicates.py +30 -0
- cli/resources/symbols/sync.py +39 -0
- cli/resources/symbols/tag.py +47 -0
- cli/resources/vectors/__init__.py +11 -0
- cli/resources/vectors/cleanup.py +95 -0
- cli/resources/vectors/hub.py +9 -0
- cli/resources/vectors/query.py +105 -0
- cli/resources/vectors/status.py +30 -0
- cli/resources/vectors/sync.py +57 -0
- cli/resources/vectors/sync_code.py +67 -0
- cli/resources/workers/__init__.py +13 -0
- cli/resources/workers/blackboard.py +253 -0
- cli/resources/workers/remediate.py +337 -0
- cli/resources/workers/run.py +140 -0
- cli/utils/__init__.py +32 -0
- cli/utils/annotation_formatter.py +154 -0
- cli/utils/decorators.py +184 -0
- cli/utils/display.py +79 -0
- cli/utils/exit_codes.py +59 -0
- cli/utils/helpers.py +34 -0
- cli/utils/prompts.py +21 -0
- core_runtime-0.1.1.dist-info/LICENSE +21 -0
- core_runtime-0.1.1.dist-info/METADATA +346 -0
- core_runtime-0.1.1.dist-info/RECORD +962 -0
- core_runtime-0.1.1.dist-info/WHEEL +4 -0
- core_runtime-0.1.1.dist-info/entry_points.txt +4 -0
- mind/__init__.py +4 -0
- mind/coherence/__init__.py +1 -0
- mind/coherence/checker.py +314 -0
- mind/coherence/checks/__init__.py +4 -0
- mind/coherence/checks/base.py +34 -0
- mind/coherence/checks/r1_scoped.py +228 -0
- mind/coherence/checks/row2_grounding.py +69 -0
- mind/coherence/checks/row3_citation.py +119 -0
- mind/coherence/checks/row4_naming.py +126 -0
- mind/coherence/checks/sameconcern.py +136 -0
- mind/coherence/checks/specgap.py +233 -0
- mind/coherence/checks/vocabulary.py +112 -0
- mind/coherence/llm_judge.py +207 -0
- mind/enforcement/audit.py +78 -0
- mind/governance/__init__.py +22 -0
- mind/governance/assumption_extractor.py +326 -0
- mind/governance/audit_context.py +520 -0
- mind/governance/audit_postprocessor.py +36 -0
- mind/governance/audit_report_writer.py +46 -0
- mind/governance/audit_types.py +98 -0
- mind/governance/auditor.py +179 -0
- mind/governance/authority_package_builder.py +502 -0
- mind/governance/constitutional_auditor_dynamic.py +362 -0
- mind/governance/enforcement/__init__.py +24 -0
- mind/governance/enforcement_loader.py +245 -0
- mind/governance/enforcement_methods.py +28 -0
- mind/governance/entry_point_policy.py +62 -0
- mind/governance/executable_rule.py +127 -0
- mind/governance/filtered_audit.py +272 -0
- mind/governance/finding_processor.py +76 -0
- mind/governance/meta_validator.py +259 -0
- mind/governance/micro_proposal_validator.py +169 -0
- mind/governance/policy_coverage_service.py +183 -0
- mind/governance/policy_rule.py +94 -0
- mind/governance/rule_conflict_detector.py +127 -0
- mind/governance/rule_executor.py +306 -0
- mind/governance/rule_extractor.py +376 -0
- mind/governance/stateless_audit.py +206 -0
- mind/governance/violation_report.py +136 -0
- mind/logic/engines/_knowledge_gate_duplication.py +117 -0
- mind/logic/engines/action_gate.py +76 -0
- mind/logic/engines/artifact_gate.py +1168 -0
- mind/logic/engines/ast_gate/__init__.py +9 -0
- mind/logic/engines/ast_gate/base.py +263 -0
- mind/logic/engines/ast_gate/checks/__init__.py +35 -0
- mind/logic/engines/ast_gate/checks/async_checks.py +276 -0
- mind/logic/engines/ast_gate/checks/capability_checks.py +197 -0
- mind/logic/engines/ast_gate/checks/conservation_checks.py +126 -0
- mind/logic/engines/ast_gate/checks/generic_checks.py +244 -0
- mind/logic/engines/ast_gate/checks/import_checks.py +164 -0
- mind/logic/engines/ast_gate/checks/knowledge_source_check.py +88 -0
- mind/logic/engines/ast_gate/checks/logging_checks.py +133 -0
- mind/logic/engines/ast_gate/checks/metadata_checks.py +242 -0
- mind/logic/engines/ast_gate/checks/modularity_checks.py +436 -0
- mind/logic/engines/ast_gate/checks/naming_checks.py +120 -0
- mind/logic/engines/ast_gate/checks/prompt_model_checks.py +83 -0
- mind/logic/engines/ast_gate/checks/protected_namespace_access_check.py +298 -0
- mind/logic/engines/ast_gate/checks/purity_checks.py +421 -0
- mind/logic/engines/ast_gate/checks/purity_enforcement_check.py +56 -0
- mind/logic/engines/ast_gate/checks/runtime_import_boundary.py +198 -0
- mind/logic/engines/ast_gate/checks/schema_conformance_checks.py +130 -0
- mind/logic/engines/ast_gate/engine.py +317 -0
- mind/logic/engines/ast_gate.py +19 -0
- mind/logic/engines/base.py +106 -0
- mind/logic/engines/cli_gate/__init__.py +25 -0
- mind/logic/engines/cli_gate/base_check.py +45 -0
- mind/logic/engines/cli_gate/checks/__init__.py +31 -0
- mind/logic/engines/cli_gate/checks/async_execution.py +65 -0
- mind/logic/engines/cli_gate/checks/dangerous_explicit.py +60 -0
- mind/logic/engines/cli_gate/checks/discovery_strict.py +167 -0
- mind/logic/engines/cli_gate/checks/help_required.py +43 -0
- mind/logic/engines/cli_gate/checks/no_duplicates.py +57 -0
- mind/logic/engines/cli_gate/checks/no_layer_exposure.py +48 -0
- mind/logic/engines/cli_gate/checks/resource_first.py +58 -0
- mind/logic/engines/cli_gate/checks/standard_verbs.py +50 -0
- mind/logic/engines/cli_gate/engine.py +211 -0
- mind/logic/engines/glob_gate.py +214 -0
- mind/logic/engines/knowledge_gate.py +410 -0
- mind/logic/engines/llm_gate.py +407 -0
- mind/logic/engines/llm_gate_stub.py +67 -0
- mind/logic/engines/passive_gate.py +45 -0
- mind/logic/engines/regex_gate.py +97 -0
- mind/logic/engines/registry.py +134 -0
- mind/logic/engines/runtime_gate.py +265 -0
- mind/logic/engines/taxonomy_gate.py +229 -0
- mind/logic/engines/workflow_gate/__init__.py +22 -0
- mind/logic/engines/workflow_gate/base_check.py +42 -0
- mind/logic/engines/workflow_gate/checks/__init__.py +32 -0
- mind/logic/engines/workflow_gate/checks/alignment.py +93 -0
- mind/logic/engines/workflow_gate/checks/audit.py +80 -0
- mind/logic/engines/workflow_gate/checks/canary.py +47 -0
- mind/logic/engines/workflow_gate/checks/coverage.py +74 -0
- mind/logic/engines/workflow_gate/checks/dead_code.py +53 -0
- mind/logic/engines/workflow_gate/checks/import_resolution.py +97 -0
- mind/logic/engines/workflow_gate/checks/linter.py +104 -0
- mind/logic/engines/workflow_gate/checks/quality.py +49 -0
- mind/logic/engines/workflow_gate/checks/ruff_format.py +99 -0
- mind/logic/engines/workflow_gate/checks/tests.py +81 -0
- mind/logic/engines/workflow_gate/engine.py +207 -0
- shared/__init__.py +32 -0
- shared/action_logger.py +61 -0
- shared/action_types.py +199 -0
- shared/activity_logging.py +149 -0
- shared/ai/constitutional_envelope.py +341 -0
- shared/ai/prompt_model.py +585 -0
- shared/ai/response_parser.py +191 -0
- shared/ast_utility.py +279 -0
- shared/atomic_action.py +117 -0
- shared/cli/__init__.py +6 -0
- shared/cli/app_introspection.py +134 -0
- shared/cli/command_meta.py +224 -0
- shared/cli_types.py +92 -0
- shared/component_primitive.py +216 -0
- shared/config.py +216 -0
- shared/config_loader.py +54 -0
- shared/context.py +113 -0
- shared/exceptions.py +100 -0
- shared/governance/__init__.py +9 -0
- shared/governance/coherence_harvester.py +258 -0
- shared/governance_token.py +77 -0
- shared/infrastructure/__init__.py +5 -0
- shared/infrastructure/adapters/__init__.py +5 -0
- shared/infrastructure/adapters/embedding_provider.py +66 -0
- shared/infrastructure/bootstrap_registry.py +57 -0
- shared/infrastructure/clients/__init__.py +5 -0
- shared/infrastructure/clients/qdrant_client.py +455 -0
- shared/infrastructure/config_service.py +382 -0
- shared/infrastructure/config_validator.py +70 -0
- shared/infrastructure/context/__init__.py +45 -0
- shared/infrastructure/context/builder.py +804 -0
- shared/infrastructure/context/cache.py +101 -0
- shared/infrastructure/context/database.py +205 -0
- shared/infrastructure/context/limb_workspace.py +134 -0
- shared/infrastructure/context/models.py +65 -0
- shared/infrastructure/context/providers/__init__.py +18 -0
- shared/infrastructure/context/providers/ast.py +211 -0
- shared/infrastructure/context/providers/db.py +165 -0
- shared/infrastructure/context/providers/vectors.py +195 -0
- shared/infrastructure/context/redactor.py +109 -0
- shared/infrastructure/context/serializers.py +144 -0
- shared/infrastructure/context/service.py +271 -0
- shared/infrastructure/context/validator.py +247 -0
- shared/infrastructure/database/models/__init__.py +80 -0
- shared/infrastructure/database/models/autonomous_proposals.py +83 -0
- shared/infrastructure/database/models/decision_traces.py +129 -0
- shared/infrastructure/database/models/governance.py +183 -0
- shared/infrastructure/database/models/knowledge.py +205 -0
- shared/infrastructure/database/models/learning.py +99 -0
- shared/infrastructure/database/models/llm_config.py +274 -0
- shared/infrastructure/database/models/operations.py +152 -0
- shared/infrastructure/database/models/refusals.py +147 -0
- shared/infrastructure/database/models/system.py +124 -0
- shared/infrastructure/database/models/vectors.py +113 -0
- shared/infrastructure/database/models/workers.py +96 -0
- shared/infrastructure/database/session_manager.py +166 -0
- shared/infrastructure/diagnostic_service.py +103 -0
- shared/infrastructure/events/__init__.py +5 -0
- shared/infrastructure/events/base.py +44 -0
- shared/infrastructure/events/bus.py +76 -0
- shared/infrastructure/git_service.py +385 -0
- shared/infrastructure/intent/action_risk.py +135 -0
- shared/infrastructure/intent/audit_verdict.py +131 -0
- shared/infrastructure/intent/autonomy_dirty_tree.py +104 -0
- shared/infrastructure/intent/canonical_enums.py +116 -0
- shared/infrastructure/intent/cognitive_roles.py +96 -0
- shared/infrastructure/intent/errors.py +13 -0
- shared/infrastructure/intent/filesystem_operations.py +359 -0
- shared/infrastructure/intent/intent_connector.py +157 -0
- shared/infrastructure/intent/intent_repository.py +707 -0
- shared/infrastructure/intent/intent_validator.py +248 -0
- shared/infrastructure/intent/operational_capabilities.py +470 -0
- shared/infrastructure/intent/operational_config.py +1343 -0
- shared/infrastructure/intent/operational_mode.py +66 -0
- shared/infrastructure/intent/task_type_phases.py +180 -0
- shared/infrastructure/intent/test_coverage_paths.py +181 -0
- shared/infrastructure/intent/vocabulary_projection.py +241 -0
- shared/infrastructure/knowledge/knowledge_service.py +155 -0
- shared/infrastructure/knowledge_graph_service.py +214 -0
- shared/infrastructure/llm/client.py +448 -0
- shared/infrastructure/llm/client_registry.py +153 -0
- shared/infrastructure/llm/fallback_client.py +144 -0
- shared/infrastructure/llm/providers/anthropic.py +113 -0
- shared/infrastructure/llm/providers/base.py +130 -0
- shared/infrastructure/llm/providers/ollama.py +265 -0
- shared/infrastructure/llm/providers/openai.py +168 -0
- shared/infrastructure/repositories/__init__.py +5 -0
- shared/infrastructure/repositories/db/__init__.py +5 -0
- shared/infrastructure/repositories/db/common.py +138 -0
- shared/infrastructure/repositories/db/engine.py +26 -0
- shared/infrastructure/repositories/db/migration_service.py +75 -0
- shared/infrastructure/repositories/db/status_service.py +61 -0
- shared/infrastructure/repositories/memory_repository.py +134 -0
- shared/infrastructure/repositories/symbol_definition_repository.py +170 -0
- shared/infrastructure/repositories/task_repository.py +59 -0
- shared/infrastructure/repositories/vector_link_repository.py +83 -0
- shared/infrastructure/rooted_repository.py +50 -0
- shared/infrastructure/secrets_service.py +317 -0
- shared/infrastructure/specs/__init__.py +9 -0
- shared/infrastructure/specs/specs_repository.py +100 -0
- shared/infrastructure/storage/file_classifier.py +32 -0
- shared/infrastructure/storage/file_handler.py +330 -0
- shared/infrastructure/storage/file_provider.py +233 -0
- shared/infrastructure/storage/integrity_service.py +108 -0
- shared/infrastructure/validation/black_formatter.py +41 -0
- shared/infrastructure/validation/quality.py +46 -0
- shared/infrastructure/validation/ruff_linter.py +104 -0
- shared/infrastructure/validation/syntax_checker.py +45 -0
- shared/infrastructure/validation/test_runner.py +167 -0
- shared/infrastructure/validation/yaml_validator.py +45 -0
- shared/infrastructure/vector/__init__.py +15 -0
- shared/infrastructure/vector/adapters/__init__.py +20 -0
- shared/infrastructure/vector/adapters/constitutional/__init__.py +26 -0
- shared/infrastructure/vector/adapters/constitutional/chunker.py +246 -0
- shared/infrastructure/vector/adapters/constitutional/doc_key_resolver.py +109 -0
- shared/infrastructure/vector/adapters/constitutional/item_builder.py +158 -0
- shared/infrastructure/vector/adapters/constitutional/utils.py +39 -0
- shared/infrastructure/vector/adapters/constitutional_adapter.py +309 -0
- shared/infrastructure/vector/adapters/specs_adapter.py +171 -0
- shared/infrastructure/vector/cognitive_adapter.py +119 -0
- shared/infrastructure/vector/vector_index_service.py +230 -0
- shared/logger.py +195 -0
- shared/models/__init__.py +47 -0
- shared/models/action_result.py +77 -0
- shared/models/audit_models.py +106 -0
- shared/models/audit_rendering.py +30 -0
- shared/models/capability_models.py +22 -0
- shared/models/constitutional_validation.py +185 -0
- shared/models/drift_models.py +24 -0
- shared/models/embedding_payload.py +45 -0
- shared/models/execution_models.py +71 -0
- shared/models/pattern_graph.py +62 -0
- shared/models/prompt_model.py +244 -0
- shared/models/refusal_result.py +294 -0
- shared/models/remediation.py +35 -0
- shared/models/validation_result.py +34 -0
- shared/models/vector_models.py +62 -0
- shared/models/workflow_models.py +242 -0
- shared/path_resolver.py +408 -0
- shared/path_utils.py +60 -0
- shared/processors/base_processor.py +171 -0
- shared/processors/yaml_processor.py +72 -0
- shared/protocols/__init__.py +21 -0
- shared/protocols/brain_services.py +35 -0
- shared/protocols/cognitive.py +35 -0
- shared/protocols/executor.py +47 -0
- shared/protocols/interpreter.py +24 -0
- shared/protocols/knowledge.py +21 -0
- shared/protocols/llm.py +25 -0
- shared/protocols/typer_protocols.py +37 -0
- shared/time.py +18 -0
- shared/universal.py +43 -0
- shared/utils/__init__.py +81 -0
- shared/utils/audit_grouping.py +50 -0
- shared/utils/common_knowledge.py +82 -0
- shared/utils/domain_mapper.py +61 -0
- shared/utils/embedding_utils.py +182 -0
- shared/utils/glob_match.py +93 -0
- shared/utils/header_tools.py +177 -0
- shared/utils/parallel_processor.py +60 -0
- shared/utils/parsing.py +189 -0
- shared/utils/path_utils.py +268 -0
- shared/utils/subprocess_utils.py +87 -0
- shared/workers/__init__.py +19 -0
- shared/workers/base.py +533 -0
- shared/workers/declaration_validator.py +124 -0
- shared/workers/loop_hold_telemetry.py +210 -0
- shared/workers/schedule.py +123 -0
- will/__init__.py +4 -0
- will/agents/__init__.py +4 -0
- will/agents/base_planner.py +133 -0
- will/agents/code_generation/__init__.py +15 -0
- will/agents/code_generation/code_generator.py +247 -0
- will/agents/code_generation/context_formatters.py +99 -0
- will/agents/code_generation/correction_engine.py +157 -0
- will/agents/code_generation/extraction.py +165 -0
- will/agents/code_generation/pattern_validator.py +264 -0
- will/agents/code_generation/prompt_builders.py +209 -0
- will/agents/coder_agent.py +229 -0
- will/agents/coder_agent_refusal_handler.py +168 -0
- will/agents/cognitive_orchestrator.py +152 -0
- will/agents/conversational/__init__.py +13 -0
- will/agents/conversational/agent.py +271 -0
- will/agents/conversational/factory.py +72 -0
- will/agents/conversational/helpers.py +116 -0
- will/agents/execution_agent.py +294 -0
- will/agents/governance_mixin.py +132 -0
- will/agents/planner_agent.py +261 -0
- will/agents/resource_selector.py +228 -0
- will/agents/strategic_auditor/__init__.py +15 -0
- will/agents/strategic_auditor/agent.py +199 -0
- will/agents/strategic_auditor/context_gatherer.py +586 -0
- will/agents/strategic_auditor/effects.py +136 -0
- will/agents/strategic_auditor/models.py +61 -0
- will/agents/strategic_auditor/reasoning.py +169 -0
- will/agents/tagger_agent.py +294 -0
- will/agents/traced_agent_mixin.py +33 -0
- will/autonomy/__init__.py +20 -0
- will/autonomy/autonomous_developer.py +127 -0
- will/autonomy/proposal.py +585 -0
- will/autonomy/proposal_execution_pipeline.py +264 -0
- will/autonomy/proposal_executor.py +410 -0
- will/autonomy/proposal_mapper.py +187 -0
- will/autonomy/proposal_repository.py +118 -0
- will/autonomy/proposal_service.py +251 -0
- will/autonomy/proposal_state_manager.py +239 -0
- will/deciders/__init__.py +9 -0
- will/deciders/governance_decider.py +207 -0
- will/governance/__init__.py +13 -0
- will/governance/audit_remediation_runner.py +197 -0
- will/governance/audit_runner.py +368 -0
- will/governance/census_runner.py +278 -0
- will/governance/coverage_runner.py +489 -0
- will/governance/daemon_runner.py +164 -0
- will/governance/fix_runner.py +693 -0
- will/governance/inspect_runner.py +521 -0
- will/governance/integrity_runner.py +66 -0
- will/governance/lint_runner.py +93 -0
- will/governance/refactor_runner.py +372 -0
- will/governance/sync_runner.py +186 -0
- will/interpreters/__init__.py +44 -0
- will/interpreters/cli_args_interpreter.py +106 -0
- will/interpreters/natural_language_interpreter.py +276 -0
- will/interpreters/request_interpreter.py +126 -0
- will/lifecycle/__init__.py +12 -0
- will/lifecycle/integration_runner.py +54 -0
- will/maintenance/metadata_scribe_service.py +64 -0
- will/orchestration/__init__.py +4 -0
- will/orchestration/cognitive_service.py +185 -0
- will/orchestration/decision_tracer.py +257 -0
- will/orchestration/intent_alignment.py +59 -0
- will/orchestration/intent_guard.py +20 -0
- will/orchestration/phase_registry.py +92 -0
- will/orchestration/process_orchestrator.py +270 -0
- will/orchestration/prompt_pipeline.py +174 -0
- will/orchestration/remediation_orchestrator.py +292 -0
- will/orchestration/self_correction_engine.py +154 -0
- will/orchestration/validation_pipeline.py +45 -0
- will/orchestration/workflow_orchestrator.py +277 -0
- will/phases/__init__.py +24 -0
- will/phases/audit_phase.py +152 -0
- will/phases/canary/pytest_runner.py +156 -0
- will/phases/canary/result_builder.py +130 -0
- will/phases/canary/test_discovery.py +104 -0
- will/phases/canary_validation_phase.py +188 -0
- will/phases/code_generation/artifact_saver.py +175 -0
- will/phases/code_generation/code_sensor.py +117 -0
- will/phases/code_generation/file_path_extractor.py +53 -0
- will/phases/code_generation/work_directory_manager.py +83 -0
- will/phases/code_generation_phase.py +480 -0
- will/phases/execution_phase.py +179 -0
- will/phases/interpret_phase.py +266 -0
- will/phases/load_phase.py +102 -0
- will/phases/parse_phase.py +117 -0
- will/phases/planning_phase.py +182 -0
- will/phases/runtime_phase.py +112 -0
- will/phases/sandbox_validation_phase.py +130 -0
- will/phases/style_check_phase.py +209 -0
- will/phases/test_generation_phase.py +159 -0
- will/self_healing/alignment/persistence.py +53 -0
- will/self_healing/alignment/sandbox.py +51 -0
- will/self_healing/alignment/specialists.py +165 -0
- will/self_healing/alignment_orchestrator.py +140 -0
- will/self_healing/audit_remediation_service.py +199 -0
- will/self_healing/batch_remediation_service.py +280 -0
- will/self_healing/capability_reconciliation_service.py +96 -0
- will/self_healing/capability_tagging_service.py +224 -0
- will/self_healing/clarity_service.py +204 -0
- will/self_healing/complexity_service.py +260 -0
- will/self_healing/context_aware_test_generator.py +298 -0
- will/self_healing/coverage_remediation_service.py +97 -0
- will/self_healing/coverage_watcher.py +192 -0
- will/self_healing/enrichment_service.py +211 -0
- will/self_healing/linelength_service.py +168 -0
- will/self_healing/modularity_remediation_service.py +203 -0
- will/self_healing/remediation_evidence_writer.py +144 -0
- will/self_healing/remediation_executor.py +113 -0
- will/self_healing/remediation_interpretation/__init__.py +1 -0
- will/self_healing/remediation_interpretation/file_context_assembler.py +383 -0
- will/self_healing/remediation_interpretation/file_role_detector.py +599 -0
- will/self_healing/remediation_interpretation/finding_normalizer.py +221 -0
- will/self_healing/remediation_interpretation/models.py +198 -0
- will/self_healing/remediation_interpretation/reasoning_brief_builder.py +235 -0
- will/self_healing/remediation_interpretation/responsibility_extractor.py +421 -0
- will/self_healing/remediation_interpretation/service.py +202 -0
- will/self_healing/remediation_interpretation/strategy_catalog.py +252 -0
- will/self_healing/remediation_interpretation/strategy_selector.py +395 -0
- will/self_healing/remediation_pattern_matcher.py +126 -0
- will/self_healing/simple_test_generator.py +252 -0
- will/self_healing/single_file_remediation.py +137 -0
- will/self_healing/test_generation/automatic_repair.py +377 -0
- will/self_healing/test_generation/code_extractor.py +238 -0
- will/self_healing/test_generation/context_builder.py +140 -0
- will/self_healing/test_generation/executor.py +64 -0
- will/self_healing/test_generation/failure_parser.py +37 -0
- will/self_healing/test_generation/generation_workflow.py +140 -0
- will/self_healing/test_generation/generator.py +283 -0
- will/self_healing/test_generation/llm_correction.py +160 -0
- will/self_healing/test_generation/repair_workflow.py +128 -0
- will/self_healing/test_generation/single_test_fixer.py +77 -0
- will/self_healing/test_generation/test_extractor.py +50 -0
- will/self_healing/test_generation/test_scorer.py +53 -0
- will/self_healing/test_generation/test_validator.py +64 -0
- will/self_healing/test_generator.py +12 -0
- will/strategists/__init__.py +46 -0
- will/strategists/base_strategist.py +29 -0
- will/strategists/clarity_strategist.py +55 -0
- will/strategists/complexity_strategist.py +55 -0
- will/strategists/fix_strategist.py +467 -0
- will/strategists/sync_strategist.py +369 -0
- will/strategists/test_strategist.py +140 -0
- will/strategists/validation_strategist.py +315 -0
- will/test_generation/__init__.py +46 -0
- will/test_generation/adaptive_test_generator.py +123 -0
- will/test_generation/artifacts.py +102 -0
- will/test_generation/harness_detection.py +103 -0
- will/test_generation/helpers/__init__.py +14 -0
- will/test_generation/helpers/context_extractor.py +100 -0
- will/test_generation/helpers/test_executor.py +230 -0
- will/test_generation/llm_output.py +62 -0
- will/test_generation/models.py +25 -0
- will/test_generation/persistence.py +248 -0
- will/test_generation/phases/__init__.py +16 -0
- will/test_generation/phases/generation_phase.py +150 -0
- will/test_generation/phases/load_phase.py +53 -0
- will/test_generation/phases/parse_phase.py +50 -0
- will/test_generation/prompt_engine.py +123 -0
- will/test_generation/result_aggregator.py +73 -0
- will/test_generation/sandbox.py +203 -0
- will/test_generation/strategy_link.py +56 -0
- will/test_generation/test_extractor.py +140 -0
- will/test_generation/validation.py +89 -0
- will/tools/__init__.py +13 -0
- will/tools/anchor_builder.py +111 -0
- will/tools/anchor_search.py +73 -0
- will/tools/anchors/discovery.py +55 -0
- will/tools/anchors/storage.py +32 -0
- will/tools/architectural_context_builder.py +94 -0
- will/tools/cognitive_toolbox.py +47 -0
- will/tools/context/code_snippet_extractor.py +83 -0
- will/tools/context/embedding_search.py +76 -0
- will/tools/context/formatter.py +87 -0
- will/tools/context/models.py +38 -0
- will/tools/context/query_builder.py +42 -0
- will/tools/context/retriever.py +182 -0
- will/tools/context/standards.py +53 -0
- will/tools/file_navigator.py +180 -0
- will/tools/layers.py +31 -0
- will/tools/module_anchor_generator.py +137 -0
- will/tools/module_descriptor.py +154 -0
- will/tools/policy_vectorizer.py +184 -0
- will/tools/symbol_finder.py +188 -0
- will/tools/tool_generator.py +103 -0
- will/workers/audit_ingest_worker.py +207 -0
- will/workers/audit_violation_filter.py +108 -0
- will/workers/audit_violation_normalizer.py +108 -0
- will/workers/audit_violation_sensor.py +370 -0
- will/workers/blackboard_shop_manager.py +280 -0
- will/workers/capability_tagger.py +153 -0
- will/workers/circuit_breaker.py +335 -0
- will/workers/coherence_sensor.py +212 -0
- will/workers/commit_reachability_auditor.py +135 -0
- will/workers/db_sync_worker.py +96 -0
- will/workers/governance_embedding/__init__.py +9 -0
- will/workers/governance_embedding/governance_embedder_worker.py +189 -0
- will/workers/intent_inspector.py +599 -0
- will/workers/observer_worker.py +158 -0
- will/workers/prompt_extractor_worker.py +241 -0
- will/workers/proposal_consumer_effects.py +216 -0
- will/workers/proposal_consumer_revival.py +131 -0
- will/workers/proposal_consumer_worker.py +271 -0
- will/workers/proposal_pipeline_shop_manager.py +273 -0
- will/workers/repo_crawler.py +171 -0
- will/workers/repo_embedding/__init__.py +18 -0
- will/workers/repo_embedding/helpers.py +245 -0
- will/workers/repo_embedding/repo_embedder_workers.py +163 -0
- will/workers/test_coverage_sensor.py +208 -0
- will/workers/test_remediator/__init__.py +12 -0
- will/workers/test_remediator/_operations.py +295 -0
- will/workers/test_remediator/worker.py +187 -0
- will/workers/test_runner_sensor.py +430 -0
- will/workers/violation_executor.py +496 -0
- will/workers/violation_remediator.py +394 -0
- will/workers/violation_remediator_blackboard.py +225 -0
- will/workers/violation_remediator_body/__init__.py +12 -0
- will/workers/violation_remediator_body/blackboard.py +139 -0
- will/workers/violation_remediator_body/ceremony.py +154 -0
- will/workers/violation_remediator_body/context.py +70 -0
- will/workers/violation_remediator_body/llm.py +112 -0
- will/workers/violation_remediator_body/models.py +35 -0
- will/workers/violation_remediator_body/worker.py +518 -0
- will/workers/violation_remediator_proposal.py +328 -0
- will/workers/worker_shop_manager.py +244 -0
- will/workflows/__init__.py +23 -0
- will/workflows/dev_sync_reporter.py +274 -0
- will/workflows/dev_sync_workflow.py +118 -0
|
@@ -0,0 +1,1343 @@
|
|
|
1
|
+
# src/shared/infrastructure/intent/operational_config.py
|
|
2
|
+
"""
|
|
3
|
+
Loader for .intent/enforcement/config/operational_config.yaml (ADR-040).
|
|
4
|
+
|
|
5
|
+
Every runtime-behavior knob that previously lived as a literal in src/ is
|
|
6
|
+
declared in operational_config.yaml; this module reads the file via
|
|
7
|
+
IntentRepository and returns a tree of frozen dataclasses callers can
|
|
8
|
+
consume. On any failure — missing file, parse error, malformed section —
|
|
9
|
+
the loader logs a warning and falls back to defaults that match the
|
|
10
|
+
shipped YAML values. It never raises, so the daemon can boot and the
|
|
11
|
+
remediation loop can keep running while a governor reviews the failure.
|
|
12
|
+
|
|
13
|
+
Pattern mirrors src/will/workers/circuit_breaker.py: one frozen dataclass
|
|
14
|
+
per top-level YAML section, plus a single public load_*_config function.
|
|
15
|
+
The workers section is nested — each sub-key becomes its own Worker*Config
|
|
16
|
+
collected into WorkersConfig.
|
|
17
|
+
"""
|
|
18
|
+
|
|
19
|
+
from __future__ import annotations
|
|
20
|
+
|
|
21
|
+
from dataclasses import dataclass, field
|
|
22
|
+
from typing import Any
|
|
23
|
+
|
|
24
|
+
from shared.logger import getLogger
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
logger = getLogger(__name__)
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
# ---------------------------------------------------------------------------
|
|
31
|
+
# Coercion helpers
|
|
32
|
+
# ---------------------------------------------------------------------------
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
def _section(raw: dict[str, Any] | None, name: str) -> dict[str, Any]:
|
|
36
|
+
if not raw:
|
|
37
|
+
return {}
|
|
38
|
+
sub = raw.get(name)
|
|
39
|
+
if sub is None:
|
|
40
|
+
return {}
|
|
41
|
+
if not isinstance(sub, dict):
|
|
42
|
+
logger.warning(
|
|
43
|
+
"operational_config: section %r is not a mapping — using fallback defaults.",
|
|
44
|
+
name,
|
|
45
|
+
)
|
|
46
|
+
return {}
|
|
47
|
+
return sub
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
def _get_int(sec: dict[str, Any], key: str, default: int) -> int:
|
|
51
|
+
val = sec.get(key)
|
|
52
|
+
if val is None:
|
|
53
|
+
return default
|
|
54
|
+
try:
|
|
55
|
+
return int(val)
|
|
56
|
+
except (TypeError, ValueError):
|
|
57
|
+
logger.warning(
|
|
58
|
+
"operational_config: %s should be int, got %r — using fallback %d.",
|
|
59
|
+
key,
|
|
60
|
+
val,
|
|
61
|
+
default,
|
|
62
|
+
)
|
|
63
|
+
return default
|
|
64
|
+
|
|
65
|
+
|
|
66
|
+
def _get_float(sec: dict[str, Any], key: str, default: float) -> float:
|
|
67
|
+
val = sec.get(key)
|
|
68
|
+
if val is None:
|
|
69
|
+
return default
|
|
70
|
+
try:
|
|
71
|
+
return float(val)
|
|
72
|
+
except (TypeError, ValueError):
|
|
73
|
+
logger.warning(
|
|
74
|
+
"operational_config: %s should be float, got %r — using fallback %r.",
|
|
75
|
+
key,
|
|
76
|
+
val,
|
|
77
|
+
default,
|
|
78
|
+
)
|
|
79
|
+
return default
|
|
80
|
+
|
|
81
|
+
|
|
82
|
+
# ID: 4d2a8e4c-1a8b-4b6e-9c2a-3f0e7a8b5d11
|
|
83
|
+
def _get_bool(sec: dict[str, Any], key: str, default: bool) -> bool:
|
|
84
|
+
val = sec.get(key)
|
|
85
|
+
if val is None:
|
|
86
|
+
return default
|
|
87
|
+
if isinstance(val, bool):
|
|
88
|
+
return val
|
|
89
|
+
logger.warning(
|
|
90
|
+
"operational_config: %s should be bool, got %r — using fallback %r.",
|
|
91
|
+
key,
|
|
92
|
+
val,
|
|
93
|
+
default,
|
|
94
|
+
)
|
|
95
|
+
return default
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
# ID: 9b4f3e2c-7a8d-4e1f-b3c5-2d6e9f0a1b8c
|
|
99
|
+
def _get_str_tuple(
|
|
100
|
+
sec: dict[str, Any], key: str, default: tuple[str, ...]
|
|
101
|
+
) -> tuple[str, ...]:
|
|
102
|
+
val = sec.get(key)
|
|
103
|
+
if val is None:
|
|
104
|
+
return default
|
|
105
|
+
if isinstance(val, list) and all(isinstance(x, str) for x in val):
|
|
106
|
+
return tuple(val)
|
|
107
|
+
logger.warning(
|
|
108
|
+
"operational_config: %s should be a list of strings, got %r — using fallback %r.",
|
|
109
|
+
key,
|
|
110
|
+
val,
|
|
111
|
+
default,
|
|
112
|
+
)
|
|
113
|
+
return default
|
|
114
|
+
|
|
115
|
+
|
|
116
|
+
# ---------------------------------------------------------------------------
|
|
117
|
+
# Section dataclasses
|
|
118
|
+
# ---------------------------------------------------------------------------
|
|
119
|
+
|
|
120
|
+
|
|
121
|
+
@dataclass(frozen=True)
|
|
122
|
+
# ID: d077c23b-94b9-48eb-966c-92ade3d25d5c
|
|
123
|
+
class LLMConfig:
|
|
124
|
+
default_max_tokens: int = 4096
|
|
125
|
+
default_max_length: int = 4096
|
|
126
|
+
http_timeout_sec: int = 60
|
|
127
|
+
request_timeout_sec: int = 300
|
|
128
|
+
provider_timeout_sec: int = 180
|
|
129
|
+
|
|
130
|
+
|
|
131
|
+
@dataclass(frozen=True)
|
|
132
|
+
# ID: 570aadb4-d174-4abc-bb31-dbb578c80401
|
|
133
|
+
class EmbeddingConfig:
|
|
134
|
+
chunk_size: int = 512
|
|
135
|
+
chunk_overlap: int = 50
|
|
136
|
+
max_chars: int = 20000
|
|
137
|
+
provider_request_timeout_sec: float = 120.0
|
|
138
|
+
provider_connect_timeout_sec: float = 10.0
|
|
139
|
+
utils_request_timeout_sec: float = 30.0
|
|
140
|
+
|
|
141
|
+
|
|
142
|
+
@dataclass(frozen=True)
|
|
143
|
+
# ID: 4b29ce9f-d734-44ff-9bc3-f9b956878f4a
|
|
144
|
+
class ChunkingConfig:
|
|
145
|
+
max_chunk_chars: int = 1500
|
|
146
|
+
|
|
147
|
+
|
|
148
|
+
@dataclass(frozen=True)
|
|
149
|
+
# ID: dee98ce9-d8e4-4ad7-bc41-f0c9a2291389
|
|
150
|
+
class BlackboardConfig:
|
|
151
|
+
"""Blackboard hygiene + ADR-082 writer-as-sensor retention knobs.
|
|
152
|
+
|
|
153
|
+
sla_default_seconds — fallback SLA tier when entry_type is unmapped.
|
|
154
|
+
|
|
155
|
+
ADR-082 retention policy — two sweep mechanisms hosted in
|
|
156
|
+
BlackboardShopManager:
|
|
157
|
+
|
|
158
|
+
- Mechanism 1 (terminal telemetry): hard DELETE rows whose subject
|
|
159
|
+
starts with one of telemetry_subject_prefixes, status is already
|
|
160
|
+
terminal, and created_at is older than telemetry_ttl_days.
|
|
161
|
+
- Mechanism 2 (DELEGATE OPEN findings): transition status open →
|
|
162
|
+
resolved for rows whose subject is in delegate_finding_subjects
|
|
163
|
+
and created_at is older than delegate_finding_ttl_days. The
|
|
164
|
+
writer's run.complete report preserves the event payload, so
|
|
165
|
+
auto-resolution is information-preserving.
|
|
166
|
+
|
|
167
|
+
sweep_batch_max — row cap per sweep run (rails per
|
|
168
|
+
feedback_destructive_autonomous_needs_rails_first).
|
|
169
|
+
"""
|
|
170
|
+
|
|
171
|
+
sla_default_seconds: int = 3600
|
|
172
|
+
telemetry_ttl_days: int = 7
|
|
173
|
+
telemetry_subject_prefixes: tuple[str, ...] = ("loop_hold.sample::",)
|
|
174
|
+
delegate_finding_ttl_days: int = 7
|
|
175
|
+
delegate_finding_subjects: tuple[str, ...] = (
|
|
176
|
+
"coherence.violation_executor.blast_bound",
|
|
177
|
+
"coherence.repo_artifacts.drift",
|
|
178
|
+
)
|
|
179
|
+
sweep_batch_max: int = 500
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
@dataclass(frozen=True)
|
|
183
|
+
# ID: eeee047a-d8a0-46d7-858a-1c6bb47079b5
|
|
184
|
+
class HealthLogConfig:
|
|
185
|
+
stale_threshold_seconds: int = 3600
|
|
186
|
+
|
|
187
|
+
|
|
188
|
+
@dataclass(frozen=True)
|
|
189
|
+
# ID: d6b4d3bb-cb67-4a62-90a7-1a6ca68e50e0
|
|
190
|
+
class DaemonConfig:
|
|
191
|
+
one_shot_interval_sec: int = 300
|
|
192
|
+
# ADR-081 Step 0 — loop-hold instrumentation. Defaults are the OFF state
|
|
193
|
+
# so a YAML revert returns to clean baseline. Step 3a-telemetry subscribes
|
|
194
|
+
# a structured handler to the slow-callback warnings these settings emit.
|
|
195
|
+
slow_callback_duration_sec: float = 0.1
|
|
196
|
+
set_debug: bool = False
|
|
197
|
+
|
|
198
|
+
|
|
199
|
+
@dataclass(frozen=True)
|
|
200
|
+
# ID: 7e8f9a0b-1c2d-3e4f-5a6b-7c8d9e0f1a2b
|
|
201
|
+
class WorkerClassificationConfig:
|
|
202
|
+
"""ADR-081 D7 — gates for the runtime.worker_process_classification rule.
|
|
203
|
+
|
|
204
|
+
The rule consumes loop_hold.sample blackboard entries (Step 3a-telemetry)
|
|
205
|
+
and fires advisory findings when observed loop-hold contradicts the
|
|
206
|
+
declared requires_dedicated_process state on a worker. The three gates
|
|
207
|
+
here are the thresholds D7 specifies; values are tunable via
|
|
208
|
+
.intent/enforcement/config/operational_config.yaml without code change.
|
|
209
|
+
"""
|
|
210
|
+
|
|
211
|
+
loop_hold_escalation_sec: float = 5.0
|
|
212
|
+
loop_hold_deescalation_sec: float = 1.0
|
|
213
|
+
cycle_window: int = 5
|
|
214
|
+
|
|
215
|
+
|
|
216
|
+
@dataclass(frozen=True)
|
|
217
|
+
# ID: 546c1ad9-c7b5-43a7-af49-d2083f7fe865
|
|
218
|
+
class ProposalsConfig:
|
|
219
|
+
list_limit: int = 100
|
|
220
|
+
pending_limit: int = 50
|
|
221
|
+
|
|
222
|
+
|
|
223
|
+
@dataclass(frozen=True)
|
|
224
|
+
# ID: 367521a6-1521-4fb1-89f1-f1ac6c01a1a1
|
|
225
|
+
class ConsequenceLogConfig:
|
|
226
|
+
default_lookback_seconds: int = 3600
|
|
227
|
+
|
|
228
|
+
|
|
229
|
+
@dataclass(frozen=True)
|
|
230
|
+
# ID: 8b3c6f4e-2a91-43d7-b582-7e1d4a9c0f6b
|
|
231
|
+
class AuditConfig:
|
|
232
|
+
"""ADR-044 — incremental llm_gate verdict cache knobs.
|
|
233
|
+
|
|
234
|
+
- llm_gate_verdict_cache_ttl_days: rows older than this are swept at
|
|
235
|
+
the start of each audit run. TTL is hygiene, not correctness —
|
|
236
|
+
content + rule hash mismatches are the correctness mechanism.
|
|
237
|
+
- llm_gate_cache_staleness_threshold_seconds: when the crawler's
|
|
238
|
+
repo_artifacts.last_crawled_at is older than this, the engine
|
|
239
|
+
recomputes file_content_hash inline rather than trusting the
|
|
240
|
+
stored value. Bounds the window in which a stale crawler hash
|
|
241
|
+
could produce an incorrect cache hit.
|
|
242
|
+
"""
|
|
243
|
+
|
|
244
|
+
llm_gate_verdict_cache_ttl_days: int = 30
|
|
245
|
+
llm_gate_cache_staleness_threshold_seconds: int = 3600
|
|
246
|
+
|
|
247
|
+
|
|
248
|
+
@dataclass(frozen=True)
|
|
249
|
+
# ID: 3101bd97-4957-40cc-85f5-96fa0e874cd4
|
|
250
|
+
class CoverageConfig:
|
|
251
|
+
gap_threshold_pct: float = 75.0
|
|
252
|
+
warn_pct: int = 75
|
|
253
|
+
low_bucket_pct: int = 50
|
|
254
|
+
gap_list_limit: int = 10
|
|
255
|
+
collect_timeout_sec: int = 120
|
|
256
|
+
full_run_timeout_sec: int = 300
|
|
257
|
+
quality_min_pct: int = 75
|
|
258
|
+
watcher_required_pct: float = 75.0
|
|
259
|
+
watcher_rescan_hours: int = 24
|
|
260
|
+
batch_remediation_threshold_pct: float = 75.0
|
|
261
|
+
batch_remediation_partial_success_pct: int = 50
|
|
262
|
+
single_file_target_pct: float = 75.0
|
|
263
|
+
|
|
264
|
+
|
|
265
|
+
@dataclass(frozen=True)
|
|
266
|
+
# ID: c1625d9c-2e4a-44a4-a009-55e2a75e07fe
|
|
267
|
+
class WorkflowGateConfig:
|
|
268
|
+
linter_timeout_sec: float = 30.0
|
|
269
|
+
quality_timeout_sec: float = 60.0
|
|
270
|
+
ruff_format_timeout_sec: float = 60.0
|
|
271
|
+
import_timeout_sec: float = 60.0
|
|
272
|
+
|
|
273
|
+
|
|
274
|
+
@dataclass(frozen=True)
|
|
275
|
+
# ID: e37c8ce2-6a3a-45d7-a63e-f9b3ec810b14
|
|
276
|
+
class ContextConfig:
|
|
277
|
+
score_target_file: int = 100
|
|
278
|
+
score_target_path: int = 80
|
|
279
|
+
score_target_symbol: int = 120
|
|
280
|
+
score_has_content: int = 30
|
|
281
|
+
vector_top_k: int = 10
|
|
282
|
+
db_provider_max_items: int = 100
|
|
283
|
+
token_estimate_overhead: int = 300
|
|
284
|
+
cache_ttl_hours: int = 24
|
|
285
|
+
db_recent_packets_limit: int = 10
|
|
286
|
+
|
|
287
|
+
|
|
288
|
+
@dataclass(frozen=True)
|
|
289
|
+
# ID: a77084a2-9655-4884-a17a-95d0d3f16d91
|
|
290
|
+
class HealthConfig:
|
|
291
|
+
worker_alive_threshold_sec: int = 600
|
|
292
|
+
worker_warn_threshold_sec: int = 3600
|
|
293
|
+
long_lookback_hours: int = 24
|
|
294
|
+
medium_lookback_minutes: int = 60
|
|
295
|
+
short_lookback_minutes: int = 30
|
|
296
|
+
recent_lookback_minutes: int = 10
|
|
297
|
+
|
|
298
|
+
|
|
299
|
+
@dataclass(frozen=True)
|
|
300
|
+
# ID: a199bb79-5c14-408c-a116-256f72347d9f
|
|
301
|
+
class TestingConfig:
|
|
302
|
+
pytest_collection_timeout_sec: int = 30
|
|
303
|
+
pytest_execution_timeout_sec: int = 300
|
|
304
|
+
sandbox_timeout_sec: int = 30
|
|
305
|
+
executor_timeout_sec: int = 60
|
|
306
|
+
metrics_timeout_sec: int = 30
|
|
307
|
+
simple_gen_timeout_sec: float = 20.0
|
|
308
|
+
context_aware_gen_timeout_sec: float = 15.0
|
|
309
|
+
runtime_validator_timeout_sec: int = 60
|
|
310
|
+
max_failures: int = 10
|
|
311
|
+
snippet_max_lines: int = 20
|
|
312
|
+
|
|
313
|
+
|
|
314
|
+
@dataclass(frozen=True)
|
|
315
|
+
# ID: 399b9dd7-d2cf-4be5-9721-b8e020e51250
|
|
316
|
+
class StrategySelectorConfig:
|
|
317
|
+
min_recommended_score: int = 15
|
|
318
|
+
score_role_preferred: int = 25
|
|
319
|
+
score_role_discouraged: int = 25
|
|
320
|
+
score_generalized_match: int = 16
|
|
321
|
+
score_rule_preferred: int = 12
|
|
322
|
+
score_rule_discouraged: int = 12
|
|
323
|
+
score_size_bonus: int = 10
|
|
324
|
+
score_size_penalty: int = 10
|
|
325
|
+
score_strong_split: int = 14
|
|
326
|
+
score_cluster_count_bonus: int = 8
|
|
327
|
+
score_cluster_count_penalty: int = 8
|
|
328
|
+
score_constraint_role_bonus: int = 9
|
|
329
|
+
score_constraint_role_penalty: int = 8
|
|
330
|
+
score_conservatism_bias_bonus: int = 8
|
|
331
|
+
score_conservatism_structural_bonus: int = 5
|
|
332
|
+
large_file_lines: int = 400
|
|
333
|
+
small_file_lines: int = 200
|
|
334
|
+
strong_split_lines: int = 450
|
|
335
|
+
|
|
336
|
+
|
|
337
|
+
@dataclass(frozen=True)
|
|
338
|
+
# ID: cea759ac-b5e2-4204-adb3-c0c5c6c1bab1
|
|
339
|
+
class AnalyzersConfig:
|
|
340
|
+
file_complexity_high_threshold: int = 15
|
|
341
|
+
class_methods_high_threshold: int = 10
|
|
342
|
+
function_body_high_threshold: int = 25
|
|
343
|
+
function_body_low_threshold: int = 10
|
|
344
|
+
max_file_lines: int = 400
|
|
345
|
+
max_function_lines: int = 50
|
|
346
|
+
max_module_lines: int = 400
|
|
347
|
+
|
|
348
|
+
|
|
349
|
+
@dataclass(frozen=True)
|
|
350
|
+
# ID: 046dc166-28df-4900-9c59-0dcf5eece8df
|
|
351
|
+
class RefactorConfig:
|
|
352
|
+
responsibilities_threshold: int = 20
|
|
353
|
+
cohesion_threshold: int = 12
|
|
354
|
+
coupling_threshold: int = 10
|
|
355
|
+
loc_threshold: int = 400
|
|
356
|
+
|
|
357
|
+
|
|
358
|
+
@dataclass(frozen=True)
|
|
359
|
+
# ID: d2c55fd2-9508-4863-a1d1-ed5c171914e5
|
|
360
|
+
class ClarityConfig:
|
|
361
|
+
structural_complexity: int = 20
|
|
362
|
+
structural_lines: int = 300
|
|
363
|
+
logic_simplification_threshold: int = 10
|
|
364
|
+
|
|
365
|
+
|
|
366
|
+
@dataclass(frozen=True)
|
|
367
|
+
# ID: ca897e8c-2d2a-4384-9c0e-e50a7a150e63
|
|
368
|
+
class ComplexityConfig:
|
|
369
|
+
god_method_threshold: int = 30
|
|
370
|
+
extraction_threshold: int = 15
|
|
371
|
+
|
|
372
|
+
|
|
373
|
+
@dataclass(frozen=True)
|
|
374
|
+
# ID: 9f5cb6d0-a2e8-4e7e-850f-5d52cacad63a
|
|
375
|
+
class ParsingConfig:
|
|
376
|
+
min_block_len: int = 10
|
|
377
|
+
score_test_fn: int = 1000
|
|
378
|
+
score_test_class: int = 1000
|
|
379
|
+
score_import: int = 100
|
|
380
|
+
score_pytest: int = 500
|
|
381
|
+
|
|
382
|
+
|
|
383
|
+
@dataclass(frozen=True)
|
|
384
|
+
# ID: 531bbd4c-d181-44d7-a951-2d1ed6f3f092
|
|
385
|
+
class ExecutionConfig:
|
|
386
|
+
task_timeout_sec: int = 300
|
|
387
|
+
workflow_timeout_minutes: int = 30
|
|
388
|
+
orchestrator_max_steps: int = 10
|
|
389
|
+
|
|
390
|
+
|
|
391
|
+
@dataclass(frozen=True)
|
|
392
|
+
# ID: 4f332080-09c6-4ee6-b93b-41ab22095174
|
|
393
|
+
class ActionConfig:
|
|
394
|
+
max_data_size_bytes: int = 5_242_880
|
|
395
|
+
|
|
396
|
+
|
|
397
|
+
@dataclass(frozen=True)
|
|
398
|
+
# ID: 4ed8b90f-159e-4147-af1d-d5a01cbc4ef7
|
|
399
|
+
class PromptPipelineConfig:
|
|
400
|
+
max_file_size_bytes: int = 1_048_576
|
|
401
|
+
|
|
402
|
+
|
|
403
|
+
@dataclass(frozen=True)
|
|
404
|
+
# ID: d586577a-437e-4c26-8dd1-ba5283b8a6f0
|
|
405
|
+
class ValidatorConfig:
|
|
406
|
+
lru_cache_size: int = 1024
|
|
407
|
+
lru_cache_size_small: int = 512
|
|
408
|
+
|
|
409
|
+
|
|
410
|
+
@dataclass(frozen=True)
|
|
411
|
+
# ID: 15bf16dc-c670-4742-a338-39a134a8d744
|
|
412
|
+
class MemoryConfig:
|
|
413
|
+
recency_days: int = 30
|
|
414
|
+
episode_retention_days: int = 30
|
|
415
|
+
reflection_retention_days: int = 90
|
|
416
|
+
|
|
417
|
+
|
|
418
|
+
@dataclass(frozen=True)
|
|
419
|
+
# ID: 972301d5-6370-47c1-a9b2-1668aa89b332
|
|
420
|
+
class RepositoriesConfig:
|
|
421
|
+
decision_trace_default_limit: int = 10
|
|
422
|
+
decision_trace_max_limit: int = 100
|
|
423
|
+
decision_trace_retention_days: int = 30
|
|
424
|
+
refusal_default_limit: int = 20
|
|
425
|
+
refusal_by_type_limit: int = 50
|
|
426
|
+
symbol_definition_default_limit: int = 500
|
|
427
|
+
project_def_max_limit: int = 500
|
|
428
|
+
project_def_default_limit: int = 100
|
|
429
|
+
|
|
430
|
+
|
|
431
|
+
@dataclass(frozen=True)
|
|
432
|
+
# ID: c21addc5-f8d0-41b5-a716-8984e28da0d8
|
|
433
|
+
class GitConfig:
|
|
434
|
+
recent_commits_n: int = 10
|
|
435
|
+
changed_files_log_n: int = 20
|
|
436
|
+
|
|
437
|
+
|
|
438
|
+
@dataclass(frozen=True)
|
|
439
|
+
# ID: 51388277-8f97-4655-b5a2-a704716ef4fe
|
|
440
|
+
class VectorsConfig:
|
|
441
|
+
index_batch_size: int = 10
|
|
442
|
+
scan_limit: int = 10000
|
|
443
|
+
report_preview_count: int = 10
|
|
444
|
+
policy_vectorizer_batch_size: int = 10
|
|
445
|
+
|
|
446
|
+
|
|
447
|
+
@dataclass(frozen=True)
|
|
448
|
+
# ID: 2d33c98b-1ed4-499b-a821-4764ed72a4ec
|
|
449
|
+
class SyncConfig:
|
|
450
|
+
artifact_embed_batch_size: int = 10
|
|
451
|
+
policy_index_batch_size: int = 10
|
|
452
|
+
pattern_index_batch_size: int = 10
|
|
453
|
+
specs_index_batch_size: int = 10
|
|
454
|
+
|
|
455
|
+
|
|
456
|
+
@dataclass(frozen=True)
|
|
457
|
+
# ID: 87095648-7a0f-4b32-b430-eb54cba9aa39
|
|
458
|
+
class AuthorityPackageConfig:
|
|
459
|
+
search_limit: int = 10
|
|
460
|
+
|
|
461
|
+
|
|
462
|
+
@dataclass(frozen=True)
|
|
463
|
+
# ID: eb02fecc-3b0e-4b78-8aef-48eac9572b85
|
|
464
|
+
class StrategicAuditorConfig:
|
|
465
|
+
sample_limit: int = 100
|
|
466
|
+
commit_lookback: int = 15
|
|
467
|
+
compact_max_chars: int = 1500
|
|
468
|
+
|
|
469
|
+
|
|
470
|
+
@dataclass(frozen=True)
|
|
471
|
+
# ID: 1db478c8-329c-401f-864c-c7a3982f22f4
|
|
472
|
+
class MiscConfig:
|
|
473
|
+
linelength_max_line_chars: int = 100
|
|
474
|
+
enrichment_description_max_chars: int = 500
|
|
475
|
+
conversation_max_content_chars: int = 2000
|
|
476
|
+
code_snippet_context_lines: int = 20
|
|
477
|
+
embedding_search_default_limit: int = 10
|
|
478
|
+
retriever_search_limit: int = 10
|
|
479
|
+
retriever_context_lines: int = 20
|
|
480
|
+
file_navigator_read_max_lines: int = 200
|
|
481
|
+
file_navigator_max_read_bytes: int = 1_048_576
|
|
482
|
+
knowledge_consolidation_max_lines: int = 10
|
|
483
|
+
context_export_http_timeout_sec: int = 10
|
|
484
|
+
metadata_max_comment_length: int = 120
|
|
485
|
+
census_hotspot_limit: int = 10
|
|
486
|
+
clustering_default_n_clusters: int = 15
|
|
487
|
+
legacy_scan_display_limit: int = 10
|
|
488
|
+
limb_status_recent_limit: int = 15
|
|
489
|
+
refusal_inspect_default_limit: int = 20
|
|
490
|
+
refusal_inspect_by_type_limit: int = 20
|
|
491
|
+
capability_tagging_default_llm_confidence: float = 0.70
|
|
492
|
+
knowledge_min_occurrences: int = 3
|
|
493
|
+
knowledge_max_lines: int = 10
|
|
494
|
+
context_aware_test_context_lines: int = 40
|
|
495
|
+
perf_overhead_warning_pct: int = 50
|
|
496
|
+
perf_overhead_error_pct: int = 100
|
|
497
|
+
context_search_display_limit: int = 20
|
|
498
|
+
proposals_display_limit: int = 20
|
|
499
|
+
|
|
500
|
+
|
|
501
|
+
# ---------------------------------------------------------------------------
|
|
502
|
+
# Workers section — one dataclass per worker sub-key
|
|
503
|
+
# ---------------------------------------------------------------------------
|
|
504
|
+
|
|
505
|
+
|
|
506
|
+
@dataclass(frozen=True)
|
|
507
|
+
# ID: 2b9a3a7b-f6c2-404b-8b3d-05ecf70b618d
|
|
508
|
+
class WorkerCallSiteRewriterConfig:
|
|
509
|
+
claim_limit: int = 50
|
|
510
|
+
|
|
511
|
+
|
|
512
|
+
@dataclass(frozen=True)
|
|
513
|
+
# ID: cd230702-b80c-41a2-8d52-a0297aa989c0
|
|
514
|
+
class WorkerDocWriterConfig:
|
|
515
|
+
batch_size: int = 25
|
|
516
|
+
|
|
517
|
+
|
|
518
|
+
@dataclass(frozen=True)
|
|
519
|
+
# ID: d627b73c-8a7c-4260-adff-c7a2d274d12e
|
|
520
|
+
class WorkerDocWorkerConfig:
|
|
521
|
+
batch_size: int = 50
|
|
522
|
+
|
|
523
|
+
|
|
524
|
+
@dataclass(frozen=True)
|
|
525
|
+
# ID: 7cd69bc3-41f2-48b7-b330-5d170cf86860
|
|
526
|
+
class WorkerPromptArtifactWriterConfig:
|
|
527
|
+
claim_limit: int = 25
|
|
528
|
+
|
|
529
|
+
|
|
530
|
+
@dataclass(frozen=True)
|
|
531
|
+
# ID: 123297dc-8907-4baf-9602-f33f79002b48
|
|
532
|
+
class WorkerPromptExtractorConfig:
|
|
533
|
+
claim_limit: int = 25
|
|
534
|
+
context_lines: int = 40
|
|
535
|
+
|
|
536
|
+
|
|
537
|
+
@dataclass(frozen=True)
|
|
538
|
+
# ID: 593b96fb-329b-46e4-b490-3029df029e47
|
|
539
|
+
class WorkerCapabilityTaggerConfig:
|
|
540
|
+
batch_size: int = 20
|
|
541
|
+
|
|
542
|
+
|
|
543
|
+
@dataclass(frozen=True)
|
|
544
|
+
# ID: 76350f2c-892a-41ef-8562-1bee90a5e69b
|
|
545
|
+
class WorkerProposalConsumerConfig:
|
|
546
|
+
claim_limit: int = 5
|
|
547
|
+
|
|
548
|
+
|
|
549
|
+
@dataclass(frozen=True)
|
|
550
|
+
# ID: 47236015-9d93-4f93-af91-1334353de07f
|
|
551
|
+
class WorkerViolationExecutorConfig:
|
|
552
|
+
claim_limit: int = 50
|
|
553
|
+
|
|
554
|
+
|
|
555
|
+
@dataclass(frozen=True)
|
|
556
|
+
# ID: accbcdf4-23be-44bd-b0c0-4212dfe9fd4e
|
|
557
|
+
class WorkerViolationRemediatorConfig:
|
|
558
|
+
claim_limit: int = 50
|
|
559
|
+
scan_limit: int = 200
|
|
560
|
+
ceremony_timeout_sec: int = 30
|
|
561
|
+
semantic_examples_limit: int = 3
|
|
562
|
+
min_role_confidence: float = 0.55
|
|
563
|
+
|
|
564
|
+
|
|
565
|
+
@dataclass(frozen=True)
|
|
566
|
+
# ID: 4f4f42b4-c4eb-4d05-b97a-5dcd97dbca5c
|
|
567
|
+
class WorkerShopConfig:
|
|
568
|
+
glide_off_multiplier: float = 0.10
|
|
569
|
+
fallback_threshold_sec: int = 600
|
|
570
|
+
findings_scan_limit: int = 200
|
|
571
|
+
|
|
572
|
+
|
|
573
|
+
@dataclass(frozen=True)
|
|
574
|
+
# ID: db4c3515-9de4-44ee-9bb5-283ef53b87b6
|
|
575
|
+
class WorkerProposalPipelineShopConfig:
|
|
576
|
+
stuck_approved_sla_sec: int = 1800
|
|
577
|
+
stuck_executing_sla_sec: int = 900
|
|
578
|
+
repeated_failure_threshold: int = 3
|
|
579
|
+
repeated_failure_lookback_sec: int = 86400
|
|
580
|
+
findings_scan_limit: int = 200
|
|
581
|
+
|
|
582
|
+
|
|
583
|
+
@dataclass(frozen=True)
|
|
584
|
+
# ID: 9447633e-e6c3-49e5-8a2b-34570dfb0d74
|
|
585
|
+
class WorkerTestRemediatorConfig:
|
|
586
|
+
scan_limit: int = 200
|
|
587
|
+
|
|
588
|
+
|
|
589
|
+
@dataclass(frozen=True)
|
|
590
|
+
# ID: 87dc2e43-4fa4-4f06-9729-5863e4e970bf
|
|
591
|
+
class WorkerTestRunnerSensorConfig:
|
|
592
|
+
scan_limit: int = 50
|
|
593
|
+
|
|
594
|
+
|
|
595
|
+
@dataclass(frozen=True)
|
|
596
|
+
# ID: 382dfb51-5dde-4934-8ede-f89042f2c3df
|
|
597
|
+
class WorkerIntentInspectorConfig:
|
|
598
|
+
alignment_batch: int = 20
|
|
599
|
+
|
|
600
|
+
|
|
601
|
+
@dataclass(frozen=True)
|
|
602
|
+
# ID: b4073ed0-e290-4ce0-95d3-14f11647e428
|
|
603
|
+
class WorkerObserverConfig:
|
|
604
|
+
stale_threshold_seconds: int = 3600
|
|
605
|
+
|
|
606
|
+
|
|
607
|
+
@dataclass(frozen=True)
|
|
608
|
+
# ID: 0e3397a8-6a9a-49c6-a253-0829101e8a4e
|
|
609
|
+
class WorkerCoherenceSensorConfig:
|
|
610
|
+
lookback_seconds: int = 7200
|
|
611
|
+
|
|
612
|
+
|
|
613
|
+
@dataclass(frozen=True)
|
|
614
|
+
# ID: e1b5e532-edb4-405f-b09f-57339041baf9
|
|
615
|
+
class WorkersConfig:
|
|
616
|
+
call_site_rewriter: WorkerCallSiteRewriterConfig = field(
|
|
617
|
+
default_factory=WorkerCallSiteRewriterConfig
|
|
618
|
+
)
|
|
619
|
+
doc_writer: WorkerDocWriterConfig = field(default_factory=WorkerDocWriterConfig)
|
|
620
|
+
doc_worker: WorkerDocWorkerConfig = field(default_factory=WorkerDocWorkerConfig)
|
|
621
|
+
prompt_artifact_writer: WorkerPromptArtifactWriterConfig = field(
|
|
622
|
+
default_factory=WorkerPromptArtifactWriterConfig
|
|
623
|
+
)
|
|
624
|
+
prompt_extractor: WorkerPromptExtractorConfig = field(
|
|
625
|
+
default_factory=WorkerPromptExtractorConfig
|
|
626
|
+
)
|
|
627
|
+
capability_tagger: WorkerCapabilityTaggerConfig = field(
|
|
628
|
+
default_factory=WorkerCapabilityTaggerConfig
|
|
629
|
+
)
|
|
630
|
+
proposal_consumer: WorkerProposalConsumerConfig = field(
|
|
631
|
+
default_factory=WorkerProposalConsumerConfig
|
|
632
|
+
)
|
|
633
|
+
violation_executor: WorkerViolationExecutorConfig = field(
|
|
634
|
+
default_factory=WorkerViolationExecutorConfig
|
|
635
|
+
)
|
|
636
|
+
violation_remediator: WorkerViolationRemediatorConfig = field(
|
|
637
|
+
default_factory=WorkerViolationRemediatorConfig
|
|
638
|
+
)
|
|
639
|
+
worker_shop: WorkerShopConfig = field(default_factory=WorkerShopConfig)
|
|
640
|
+
proposal_pipeline_shop: WorkerProposalPipelineShopConfig = field(
|
|
641
|
+
default_factory=WorkerProposalPipelineShopConfig
|
|
642
|
+
)
|
|
643
|
+
test_remediator: WorkerTestRemediatorConfig = field(
|
|
644
|
+
default_factory=WorkerTestRemediatorConfig
|
|
645
|
+
)
|
|
646
|
+
test_runner_sensor: WorkerTestRunnerSensorConfig = field(
|
|
647
|
+
default_factory=WorkerTestRunnerSensorConfig
|
|
648
|
+
)
|
|
649
|
+
intent_inspector: WorkerIntentInspectorConfig = field(
|
|
650
|
+
default_factory=WorkerIntentInspectorConfig
|
|
651
|
+
)
|
|
652
|
+
observer: WorkerObserverConfig = field(default_factory=WorkerObserverConfig)
|
|
653
|
+
coherence_sensor: WorkerCoherenceSensorConfig = field(
|
|
654
|
+
default_factory=WorkerCoherenceSensorConfig
|
|
655
|
+
)
|
|
656
|
+
|
|
657
|
+
|
|
658
|
+
# ---------------------------------------------------------------------------
|
|
659
|
+
# Top-level config
|
|
660
|
+
# ---------------------------------------------------------------------------
|
|
661
|
+
|
|
662
|
+
|
|
663
|
+
@dataclass(frozen=True)
|
|
664
|
+
# ID: 973dd73d-45af-4909-a275-c4fd44af56fb
|
|
665
|
+
class OperationalConfig:
|
|
666
|
+
llm: LLMConfig = field(default_factory=LLMConfig)
|
|
667
|
+
embedding: EmbeddingConfig = field(default_factory=EmbeddingConfig)
|
|
668
|
+
chunking: ChunkingConfig = field(default_factory=ChunkingConfig)
|
|
669
|
+
workers: WorkersConfig = field(default_factory=WorkersConfig)
|
|
670
|
+
blackboard: BlackboardConfig = field(default_factory=BlackboardConfig)
|
|
671
|
+
health_log: HealthLogConfig = field(default_factory=HealthLogConfig)
|
|
672
|
+
daemon: DaemonConfig = field(default_factory=DaemonConfig)
|
|
673
|
+
worker_classification: WorkerClassificationConfig = field(
|
|
674
|
+
default_factory=WorkerClassificationConfig
|
|
675
|
+
)
|
|
676
|
+
proposals: ProposalsConfig = field(default_factory=ProposalsConfig)
|
|
677
|
+
consequence_log: ConsequenceLogConfig = field(default_factory=ConsequenceLogConfig)
|
|
678
|
+
audit: AuditConfig = field(default_factory=AuditConfig)
|
|
679
|
+
coverage: CoverageConfig = field(default_factory=CoverageConfig)
|
|
680
|
+
workflow_gate: WorkflowGateConfig = field(default_factory=WorkflowGateConfig)
|
|
681
|
+
context: ContextConfig = field(default_factory=ContextConfig)
|
|
682
|
+
health: HealthConfig = field(default_factory=HealthConfig)
|
|
683
|
+
testing: TestingConfig = field(default_factory=TestingConfig)
|
|
684
|
+
strategy_selector: StrategySelectorConfig = field(
|
|
685
|
+
default_factory=StrategySelectorConfig
|
|
686
|
+
)
|
|
687
|
+
analyzers: AnalyzersConfig = field(default_factory=AnalyzersConfig)
|
|
688
|
+
refactor: RefactorConfig = field(default_factory=RefactorConfig)
|
|
689
|
+
clarity: ClarityConfig = field(default_factory=ClarityConfig)
|
|
690
|
+
complexity: ComplexityConfig = field(default_factory=ComplexityConfig)
|
|
691
|
+
parsing: ParsingConfig = field(default_factory=ParsingConfig)
|
|
692
|
+
execution: ExecutionConfig = field(default_factory=ExecutionConfig)
|
|
693
|
+
action: ActionConfig = field(default_factory=ActionConfig)
|
|
694
|
+
prompt_pipeline: PromptPipelineConfig = field(default_factory=PromptPipelineConfig)
|
|
695
|
+
validator: ValidatorConfig = field(default_factory=ValidatorConfig)
|
|
696
|
+
memory: MemoryConfig = field(default_factory=MemoryConfig)
|
|
697
|
+
repositories: RepositoriesConfig = field(default_factory=RepositoriesConfig)
|
|
698
|
+
git: GitConfig = field(default_factory=GitConfig)
|
|
699
|
+
vectors: VectorsConfig = field(default_factory=VectorsConfig)
|
|
700
|
+
sync: SyncConfig = field(default_factory=SyncConfig)
|
|
701
|
+
authority_package: AuthorityPackageConfig = field(
|
|
702
|
+
default_factory=AuthorityPackageConfig
|
|
703
|
+
)
|
|
704
|
+
strategic_auditor: StrategicAuditorConfig = field(
|
|
705
|
+
default_factory=StrategicAuditorConfig
|
|
706
|
+
)
|
|
707
|
+
misc: MiscConfig = field(default_factory=MiscConfig)
|
|
708
|
+
|
|
709
|
+
|
|
710
|
+
# ---------------------------------------------------------------------------
|
|
711
|
+
# Per-section factories
|
|
712
|
+
# ---------------------------------------------------------------------------
|
|
713
|
+
|
|
714
|
+
|
|
715
|
+
def _load_llm(raw: dict[str, Any]) -> LLMConfig:
|
|
716
|
+
sec = _section(raw, "llm")
|
|
717
|
+
return LLMConfig(
|
|
718
|
+
default_max_tokens=_get_int(sec, "default_max_tokens", 4096),
|
|
719
|
+
default_max_length=_get_int(sec, "default_max_length", 4096),
|
|
720
|
+
http_timeout_sec=_get_int(sec, "http_timeout_sec", 60),
|
|
721
|
+
request_timeout_sec=_get_int(sec, "request_timeout_sec", 300),
|
|
722
|
+
provider_timeout_sec=_get_int(sec, "provider_timeout_sec", 180),
|
|
723
|
+
)
|
|
724
|
+
|
|
725
|
+
|
|
726
|
+
def _load_embedding(raw: dict[str, Any]) -> EmbeddingConfig:
|
|
727
|
+
sec = _section(raw, "embedding")
|
|
728
|
+
return EmbeddingConfig(
|
|
729
|
+
chunk_size=_get_int(sec, "chunk_size", 512),
|
|
730
|
+
chunk_overlap=_get_int(sec, "chunk_overlap", 50),
|
|
731
|
+
max_chars=_get_int(sec, "max_chars", 20000),
|
|
732
|
+
provider_request_timeout_sec=_get_float(
|
|
733
|
+
sec, "provider_request_timeout_sec", 120.0
|
|
734
|
+
),
|
|
735
|
+
provider_connect_timeout_sec=_get_float(
|
|
736
|
+
sec, "provider_connect_timeout_sec", 10.0
|
|
737
|
+
),
|
|
738
|
+
utils_request_timeout_sec=_get_float(sec, "utils_request_timeout_sec", 30.0),
|
|
739
|
+
)
|
|
740
|
+
|
|
741
|
+
|
|
742
|
+
def _load_chunking(raw: dict[str, Any]) -> ChunkingConfig:
|
|
743
|
+
sec = _section(raw, "chunking")
|
|
744
|
+
return ChunkingConfig(max_chunk_chars=_get_int(sec, "max_chunk_chars", 1500))
|
|
745
|
+
|
|
746
|
+
|
|
747
|
+
def _load_blackboard(raw: dict[str, Any]) -> BlackboardConfig:
|
|
748
|
+
sec = _section(raw, "blackboard")
|
|
749
|
+
return BlackboardConfig(
|
|
750
|
+
sla_default_seconds=_get_int(sec, "sla_default_seconds", 3600),
|
|
751
|
+
telemetry_ttl_days=_get_int(sec, "telemetry_ttl_days", 7),
|
|
752
|
+
telemetry_subject_prefixes=_get_str_tuple(
|
|
753
|
+
sec, "telemetry_subject_prefixes", ("loop_hold.sample::",)
|
|
754
|
+
),
|
|
755
|
+
delegate_finding_ttl_days=_get_int(sec, "delegate_finding_ttl_days", 7),
|
|
756
|
+
delegate_finding_subjects=_get_str_tuple(
|
|
757
|
+
sec,
|
|
758
|
+
"delegate_finding_subjects",
|
|
759
|
+
(
|
|
760
|
+
"coherence.violation_executor.blast_bound",
|
|
761
|
+
"coherence.repo_artifacts.drift",
|
|
762
|
+
),
|
|
763
|
+
),
|
|
764
|
+
sweep_batch_max=_get_int(sec, "sweep_batch_max", 500),
|
|
765
|
+
)
|
|
766
|
+
|
|
767
|
+
|
|
768
|
+
def _load_health_log(raw: dict[str, Any]) -> HealthLogConfig:
|
|
769
|
+
sec = _section(raw, "health_log")
|
|
770
|
+
return HealthLogConfig(
|
|
771
|
+
stale_threshold_seconds=_get_int(sec, "stale_threshold_seconds", 3600)
|
|
772
|
+
)
|
|
773
|
+
|
|
774
|
+
|
|
775
|
+
def _load_daemon(raw: dict[str, Any]) -> DaemonConfig:
|
|
776
|
+
sec = _section(raw, "daemon")
|
|
777
|
+
return DaemonConfig(
|
|
778
|
+
one_shot_interval_sec=_get_int(sec, "one_shot_interval_sec", 300),
|
|
779
|
+
slow_callback_duration_sec=_get_float(sec, "slow_callback_duration_sec", 0.1),
|
|
780
|
+
set_debug=_get_bool(sec, "set_debug", False),
|
|
781
|
+
)
|
|
782
|
+
|
|
783
|
+
|
|
784
|
+
# ID: 6a7b8c9d-0e1f-2a3b-4c5d-6e7f8a9b0c1d
|
|
785
|
+
def _load_worker_classification(raw: dict[str, Any]) -> WorkerClassificationConfig:
|
|
786
|
+
sec = _section(raw, "worker_classification")
|
|
787
|
+
return WorkerClassificationConfig(
|
|
788
|
+
loop_hold_escalation_sec=_get_float(sec, "loop_hold_escalation_sec", 5.0),
|
|
789
|
+
loop_hold_deescalation_sec=_get_float(sec, "loop_hold_deescalation_sec", 1.0),
|
|
790
|
+
cycle_window=_get_int(sec, "cycle_window", 5),
|
|
791
|
+
)
|
|
792
|
+
|
|
793
|
+
|
|
794
|
+
def _load_proposals(raw: dict[str, Any]) -> ProposalsConfig:
|
|
795
|
+
sec = _section(raw, "proposals")
|
|
796
|
+
return ProposalsConfig(
|
|
797
|
+
list_limit=_get_int(sec, "list_limit", 100),
|
|
798
|
+
pending_limit=_get_int(sec, "pending_limit", 50),
|
|
799
|
+
)
|
|
800
|
+
|
|
801
|
+
|
|
802
|
+
def _load_consequence_log(raw: dict[str, Any]) -> ConsequenceLogConfig:
|
|
803
|
+
sec = _section(raw, "consequence_log")
|
|
804
|
+
return ConsequenceLogConfig(
|
|
805
|
+
default_lookback_seconds=_get_int(sec, "default_lookback_seconds", 3600)
|
|
806
|
+
)
|
|
807
|
+
|
|
808
|
+
|
|
809
|
+
def _load_audit(raw: dict[str, Any]) -> AuditConfig:
|
|
810
|
+
sec = _section(raw, "audit")
|
|
811
|
+
return AuditConfig(
|
|
812
|
+
llm_gate_verdict_cache_ttl_days=_get_int(
|
|
813
|
+
sec, "llm_gate_verdict_cache_ttl_days", 30
|
|
814
|
+
),
|
|
815
|
+
llm_gate_cache_staleness_threshold_seconds=_get_int(
|
|
816
|
+
sec, "llm_gate_cache_staleness_threshold_seconds", 3600
|
|
817
|
+
),
|
|
818
|
+
)
|
|
819
|
+
|
|
820
|
+
|
|
821
|
+
def _load_coverage(raw: dict[str, Any]) -> CoverageConfig:
|
|
822
|
+
sec = _section(raw, "coverage")
|
|
823
|
+
return CoverageConfig(
|
|
824
|
+
gap_threshold_pct=_get_float(sec, "gap_threshold_pct", 75.0),
|
|
825
|
+
warn_pct=_get_int(sec, "warn_pct", 75),
|
|
826
|
+
low_bucket_pct=_get_int(sec, "low_bucket_pct", 50),
|
|
827
|
+
gap_list_limit=_get_int(sec, "gap_list_limit", 10),
|
|
828
|
+
collect_timeout_sec=_get_int(sec, "collect_timeout_sec", 120),
|
|
829
|
+
full_run_timeout_sec=_get_int(sec, "full_run_timeout_sec", 300),
|
|
830
|
+
quality_min_pct=_get_int(sec, "quality_min_pct", 75),
|
|
831
|
+
watcher_required_pct=_get_float(sec, "watcher_required_pct", 75.0),
|
|
832
|
+
watcher_rescan_hours=_get_int(sec, "watcher_rescan_hours", 24),
|
|
833
|
+
batch_remediation_threshold_pct=_get_float(
|
|
834
|
+
sec, "batch_remediation_threshold_pct", 75.0
|
|
835
|
+
),
|
|
836
|
+
batch_remediation_partial_success_pct=_get_int(
|
|
837
|
+
sec, "batch_remediation_partial_success_pct", 50
|
|
838
|
+
),
|
|
839
|
+
single_file_target_pct=_get_float(sec, "single_file_target_pct", 75.0),
|
|
840
|
+
)
|
|
841
|
+
|
|
842
|
+
|
|
843
|
+
def _load_workflow_gate(raw: dict[str, Any]) -> WorkflowGateConfig:
|
|
844
|
+
sec = _section(raw, "workflow_gate")
|
|
845
|
+
return WorkflowGateConfig(
|
|
846
|
+
linter_timeout_sec=_get_float(sec, "linter_timeout_sec", 30.0),
|
|
847
|
+
quality_timeout_sec=_get_float(sec, "quality_timeout_sec", 60.0),
|
|
848
|
+
ruff_format_timeout_sec=_get_float(sec, "ruff_format_timeout_sec", 60.0),
|
|
849
|
+
import_timeout_sec=_get_float(sec, "import_timeout_sec", 60.0),
|
|
850
|
+
)
|
|
851
|
+
|
|
852
|
+
|
|
853
|
+
def _load_context(raw: dict[str, Any]) -> ContextConfig:
|
|
854
|
+
sec = _section(raw, "context")
|
|
855
|
+
return ContextConfig(
|
|
856
|
+
score_target_file=_get_int(sec, "score_target_file", 100),
|
|
857
|
+
score_target_path=_get_int(sec, "score_target_path", 80),
|
|
858
|
+
score_target_symbol=_get_int(sec, "score_target_symbol", 120),
|
|
859
|
+
score_has_content=_get_int(sec, "score_has_content", 30),
|
|
860
|
+
vector_top_k=_get_int(sec, "vector_top_k", 10),
|
|
861
|
+
db_provider_max_items=_get_int(sec, "db_provider_max_items", 100),
|
|
862
|
+
token_estimate_overhead=_get_int(sec, "token_estimate_overhead", 300),
|
|
863
|
+
cache_ttl_hours=_get_int(sec, "cache_ttl_hours", 24),
|
|
864
|
+
db_recent_packets_limit=_get_int(sec, "db_recent_packets_limit", 10),
|
|
865
|
+
)
|
|
866
|
+
|
|
867
|
+
|
|
868
|
+
def _load_health(raw: dict[str, Any]) -> HealthConfig:
|
|
869
|
+
sec = _section(raw, "health")
|
|
870
|
+
return HealthConfig(
|
|
871
|
+
worker_alive_threshold_sec=_get_int(sec, "worker_alive_threshold_sec", 600),
|
|
872
|
+
worker_warn_threshold_sec=_get_int(sec, "worker_warn_threshold_sec", 3600),
|
|
873
|
+
long_lookback_hours=_get_int(sec, "long_lookback_hours", 24),
|
|
874
|
+
medium_lookback_minutes=_get_int(sec, "medium_lookback_minutes", 60),
|
|
875
|
+
short_lookback_minutes=_get_int(sec, "short_lookback_minutes", 30),
|
|
876
|
+
recent_lookback_minutes=_get_int(sec, "recent_lookback_minutes", 10),
|
|
877
|
+
)
|
|
878
|
+
|
|
879
|
+
|
|
880
|
+
def _load_testing(raw: dict[str, Any]) -> TestingConfig:
|
|
881
|
+
sec = _section(raw, "testing")
|
|
882
|
+
return TestingConfig(
|
|
883
|
+
pytest_collection_timeout_sec=_get_int(
|
|
884
|
+
sec, "pytest_collection_timeout_sec", 30
|
|
885
|
+
),
|
|
886
|
+
pytest_execution_timeout_sec=_get_int(sec, "pytest_execution_timeout_sec", 300),
|
|
887
|
+
sandbox_timeout_sec=_get_int(sec, "sandbox_timeout_sec", 30),
|
|
888
|
+
executor_timeout_sec=_get_int(sec, "executor_timeout_sec", 60),
|
|
889
|
+
metrics_timeout_sec=_get_int(sec, "metrics_timeout_sec", 30),
|
|
890
|
+
simple_gen_timeout_sec=_get_float(sec, "simple_gen_timeout_sec", 20.0),
|
|
891
|
+
context_aware_gen_timeout_sec=_get_float(
|
|
892
|
+
sec, "context_aware_gen_timeout_sec", 15.0
|
|
893
|
+
),
|
|
894
|
+
runtime_validator_timeout_sec=_get_int(
|
|
895
|
+
sec, "runtime_validator_timeout_sec", 60
|
|
896
|
+
),
|
|
897
|
+
max_failures=_get_int(sec, "max_failures", 10),
|
|
898
|
+
snippet_max_lines=_get_int(sec, "snippet_max_lines", 20),
|
|
899
|
+
)
|
|
900
|
+
|
|
901
|
+
|
|
902
|
+
def _load_strategy_selector(raw: dict[str, Any]) -> StrategySelectorConfig:
|
|
903
|
+
sec = _section(raw, "strategy_selector")
|
|
904
|
+
return StrategySelectorConfig(
|
|
905
|
+
min_recommended_score=_get_int(sec, "min_recommended_score", 15),
|
|
906
|
+
score_role_preferred=_get_int(sec, "score_role_preferred", 25),
|
|
907
|
+
score_role_discouraged=_get_int(sec, "score_role_discouraged", 25),
|
|
908
|
+
score_generalized_match=_get_int(sec, "score_generalized_match", 16),
|
|
909
|
+
score_rule_preferred=_get_int(sec, "score_rule_preferred", 12),
|
|
910
|
+
score_rule_discouraged=_get_int(sec, "score_rule_discouraged", 12),
|
|
911
|
+
score_size_bonus=_get_int(sec, "score_size_bonus", 10),
|
|
912
|
+
score_size_penalty=_get_int(sec, "score_size_penalty", 10),
|
|
913
|
+
score_strong_split=_get_int(sec, "score_strong_split", 14),
|
|
914
|
+
score_cluster_count_bonus=_get_int(sec, "score_cluster_count_bonus", 8),
|
|
915
|
+
score_cluster_count_penalty=_get_int(sec, "score_cluster_count_penalty", 8),
|
|
916
|
+
score_constraint_role_bonus=_get_int(sec, "score_constraint_role_bonus", 9),
|
|
917
|
+
score_constraint_role_penalty=_get_int(sec, "score_constraint_role_penalty", 8),
|
|
918
|
+
score_conservatism_bias_bonus=_get_int(sec, "score_conservatism_bias_bonus", 8),
|
|
919
|
+
score_conservatism_structural_bonus=_get_int(
|
|
920
|
+
sec, "score_conservatism_structural_bonus", 5
|
|
921
|
+
),
|
|
922
|
+
large_file_lines=_get_int(sec, "large_file_lines", 400),
|
|
923
|
+
small_file_lines=_get_int(sec, "small_file_lines", 200),
|
|
924
|
+
strong_split_lines=_get_int(sec, "strong_split_lines", 450),
|
|
925
|
+
)
|
|
926
|
+
|
|
927
|
+
|
|
928
|
+
def _load_analyzers(raw: dict[str, Any]) -> AnalyzersConfig:
|
|
929
|
+
sec = _section(raw, "analyzers")
|
|
930
|
+
return AnalyzersConfig(
|
|
931
|
+
file_complexity_high_threshold=_get_int(
|
|
932
|
+
sec, "file_complexity_high_threshold", 15
|
|
933
|
+
),
|
|
934
|
+
class_methods_high_threshold=_get_int(sec, "class_methods_high_threshold", 10),
|
|
935
|
+
function_body_high_threshold=_get_int(sec, "function_body_high_threshold", 25),
|
|
936
|
+
function_body_low_threshold=_get_int(sec, "function_body_low_threshold", 10),
|
|
937
|
+
max_file_lines=_get_int(sec, "max_file_lines", 400),
|
|
938
|
+
max_function_lines=_get_int(sec, "max_function_lines", 50),
|
|
939
|
+
max_module_lines=_get_int(sec, "max_module_lines", 400),
|
|
940
|
+
)
|
|
941
|
+
|
|
942
|
+
|
|
943
|
+
def _load_refactor(raw: dict[str, Any]) -> RefactorConfig:
|
|
944
|
+
sec = _section(raw, "refactor")
|
|
945
|
+
return RefactorConfig(
|
|
946
|
+
responsibilities_threshold=_get_int(sec, "responsibilities_threshold", 20),
|
|
947
|
+
cohesion_threshold=_get_int(sec, "cohesion_threshold", 12),
|
|
948
|
+
coupling_threshold=_get_int(sec, "coupling_threshold", 10),
|
|
949
|
+
loc_threshold=_get_int(sec, "loc_threshold", 400),
|
|
950
|
+
)
|
|
951
|
+
|
|
952
|
+
|
|
953
|
+
def _load_clarity(raw: dict[str, Any]) -> ClarityConfig:
|
|
954
|
+
sec = _section(raw, "clarity")
|
|
955
|
+
return ClarityConfig(
|
|
956
|
+
structural_complexity=_get_int(sec, "structural_complexity", 20),
|
|
957
|
+
structural_lines=_get_int(sec, "structural_lines", 300),
|
|
958
|
+
logic_simplification_threshold=_get_int(
|
|
959
|
+
sec, "logic_simplification_threshold", 10
|
|
960
|
+
),
|
|
961
|
+
)
|
|
962
|
+
|
|
963
|
+
|
|
964
|
+
def _load_complexity(raw: dict[str, Any]) -> ComplexityConfig:
|
|
965
|
+
sec = _section(raw, "complexity")
|
|
966
|
+
return ComplexityConfig(
|
|
967
|
+
god_method_threshold=_get_int(sec, "god_method_threshold", 30),
|
|
968
|
+
extraction_threshold=_get_int(sec, "extraction_threshold", 15),
|
|
969
|
+
)
|
|
970
|
+
|
|
971
|
+
|
|
972
|
+
def _load_parsing(raw: dict[str, Any]) -> ParsingConfig:
|
|
973
|
+
sec = _section(raw, "parsing")
|
|
974
|
+
return ParsingConfig(
|
|
975
|
+
min_block_len=_get_int(sec, "min_block_len", 10),
|
|
976
|
+
score_test_fn=_get_int(sec, "score_test_fn", 1000),
|
|
977
|
+
score_test_class=_get_int(sec, "score_test_class", 1000),
|
|
978
|
+
score_import=_get_int(sec, "score_import", 100),
|
|
979
|
+
score_pytest=_get_int(sec, "score_pytest", 500),
|
|
980
|
+
)
|
|
981
|
+
|
|
982
|
+
|
|
983
|
+
def _load_execution(raw: dict[str, Any]) -> ExecutionConfig:
|
|
984
|
+
sec = _section(raw, "execution")
|
|
985
|
+
return ExecutionConfig(
|
|
986
|
+
task_timeout_sec=_get_int(sec, "task_timeout_sec", 300),
|
|
987
|
+
workflow_timeout_minutes=_get_int(sec, "workflow_timeout_minutes", 30),
|
|
988
|
+
orchestrator_max_steps=_get_int(sec, "orchestrator_max_steps", 10),
|
|
989
|
+
)
|
|
990
|
+
|
|
991
|
+
|
|
992
|
+
def _load_action(raw: dict[str, Any]) -> ActionConfig:
|
|
993
|
+
sec = _section(raw, "action")
|
|
994
|
+
return ActionConfig(
|
|
995
|
+
max_data_size_bytes=_get_int(sec, "max_data_size_bytes", 5_242_880)
|
|
996
|
+
)
|
|
997
|
+
|
|
998
|
+
|
|
999
|
+
def _load_prompt_pipeline(raw: dict[str, Any]) -> PromptPipelineConfig:
|
|
1000
|
+
sec = _section(raw, "prompt_pipeline")
|
|
1001
|
+
return PromptPipelineConfig(
|
|
1002
|
+
max_file_size_bytes=_get_int(sec, "max_file_size_bytes", 1_048_576)
|
|
1003
|
+
)
|
|
1004
|
+
|
|
1005
|
+
|
|
1006
|
+
def _load_validator(raw: dict[str, Any]) -> ValidatorConfig:
|
|
1007
|
+
sec = _section(raw, "validator")
|
|
1008
|
+
return ValidatorConfig(
|
|
1009
|
+
lru_cache_size=_get_int(sec, "lru_cache_size", 1024),
|
|
1010
|
+
lru_cache_size_small=_get_int(sec, "lru_cache_size_small", 512),
|
|
1011
|
+
)
|
|
1012
|
+
|
|
1013
|
+
|
|
1014
|
+
def _load_memory(raw: dict[str, Any]) -> MemoryConfig:
|
|
1015
|
+
sec = _section(raw, "memory")
|
|
1016
|
+
return MemoryConfig(
|
|
1017
|
+
recency_days=_get_int(sec, "recency_days", 30),
|
|
1018
|
+
episode_retention_days=_get_int(sec, "episode_retention_days", 30),
|
|
1019
|
+
reflection_retention_days=_get_int(sec, "reflection_retention_days", 90),
|
|
1020
|
+
)
|
|
1021
|
+
|
|
1022
|
+
|
|
1023
|
+
def _load_repositories(raw: dict[str, Any]) -> RepositoriesConfig:
|
|
1024
|
+
sec = _section(raw, "repositories")
|
|
1025
|
+
return RepositoriesConfig(
|
|
1026
|
+
decision_trace_default_limit=_get_int(sec, "decision_trace_default_limit", 10),
|
|
1027
|
+
decision_trace_max_limit=_get_int(sec, "decision_trace_max_limit", 100),
|
|
1028
|
+
decision_trace_retention_days=_get_int(
|
|
1029
|
+
sec, "decision_trace_retention_days", 30
|
|
1030
|
+
),
|
|
1031
|
+
refusal_default_limit=_get_int(sec, "refusal_default_limit", 20),
|
|
1032
|
+
refusal_by_type_limit=_get_int(sec, "refusal_by_type_limit", 50),
|
|
1033
|
+
symbol_definition_default_limit=_get_int(
|
|
1034
|
+
sec, "symbol_definition_default_limit", 500
|
|
1035
|
+
),
|
|
1036
|
+
project_def_max_limit=_get_int(sec, "project_def_max_limit", 500),
|
|
1037
|
+
project_def_default_limit=_get_int(sec, "project_def_default_limit", 100),
|
|
1038
|
+
)
|
|
1039
|
+
|
|
1040
|
+
|
|
1041
|
+
def _load_git(raw: dict[str, Any]) -> GitConfig:
|
|
1042
|
+
sec = _section(raw, "git")
|
|
1043
|
+
return GitConfig(
|
|
1044
|
+
recent_commits_n=_get_int(sec, "recent_commits_n", 10),
|
|
1045
|
+
changed_files_log_n=_get_int(sec, "changed_files_log_n", 20),
|
|
1046
|
+
)
|
|
1047
|
+
|
|
1048
|
+
|
|
1049
|
+
def _load_vectors(raw: dict[str, Any]) -> VectorsConfig:
|
|
1050
|
+
sec = _section(raw, "vectors")
|
|
1051
|
+
return VectorsConfig(
|
|
1052
|
+
index_batch_size=_get_int(sec, "index_batch_size", 10),
|
|
1053
|
+
scan_limit=_get_int(sec, "scan_limit", 10000),
|
|
1054
|
+
report_preview_count=_get_int(sec, "report_preview_count", 10),
|
|
1055
|
+
policy_vectorizer_batch_size=_get_int(sec, "policy_vectorizer_batch_size", 10),
|
|
1056
|
+
)
|
|
1057
|
+
|
|
1058
|
+
|
|
1059
|
+
def _load_sync(raw: dict[str, Any]) -> SyncConfig:
|
|
1060
|
+
sec = _section(raw, "sync")
|
|
1061
|
+
return SyncConfig(
|
|
1062
|
+
artifact_embed_batch_size=_get_int(sec, "artifact_embed_batch_size", 10),
|
|
1063
|
+
policy_index_batch_size=_get_int(sec, "policy_index_batch_size", 10),
|
|
1064
|
+
pattern_index_batch_size=_get_int(sec, "pattern_index_batch_size", 10),
|
|
1065
|
+
specs_index_batch_size=_get_int(sec, "specs_index_batch_size", 10),
|
|
1066
|
+
)
|
|
1067
|
+
|
|
1068
|
+
|
|
1069
|
+
def _load_authority_package(raw: dict[str, Any]) -> AuthorityPackageConfig:
|
|
1070
|
+
sec = _section(raw, "authority_package")
|
|
1071
|
+
return AuthorityPackageConfig(search_limit=_get_int(sec, "search_limit", 10))
|
|
1072
|
+
|
|
1073
|
+
|
|
1074
|
+
def _load_strategic_auditor(raw: dict[str, Any]) -> StrategicAuditorConfig:
|
|
1075
|
+
sec = _section(raw, "strategic_auditor")
|
|
1076
|
+
return StrategicAuditorConfig(
|
|
1077
|
+
sample_limit=_get_int(sec, "sample_limit", 100),
|
|
1078
|
+
commit_lookback=_get_int(sec, "commit_lookback", 15),
|
|
1079
|
+
compact_max_chars=_get_int(sec, "compact_max_chars", 1500),
|
|
1080
|
+
)
|
|
1081
|
+
|
|
1082
|
+
|
|
1083
|
+
def _load_misc(raw: dict[str, Any]) -> MiscConfig:
|
|
1084
|
+
sec = _section(raw, "misc")
|
|
1085
|
+
return MiscConfig(
|
|
1086
|
+
linelength_max_line_chars=_get_int(sec, "linelength_max_line_chars", 100),
|
|
1087
|
+
enrichment_description_max_chars=_get_int(
|
|
1088
|
+
sec, "enrichment_description_max_chars", 500
|
|
1089
|
+
),
|
|
1090
|
+
conversation_max_content_chars=_get_int(
|
|
1091
|
+
sec, "conversation_max_content_chars", 2000
|
|
1092
|
+
),
|
|
1093
|
+
code_snippet_context_lines=_get_int(sec, "code_snippet_context_lines", 20),
|
|
1094
|
+
embedding_search_default_limit=_get_int(
|
|
1095
|
+
sec, "embedding_search_default_limit", 10
|
|
1096
|
+
),
|
|
1097
|
+
retriever_search_limit=_get_int(sec, "retriever_search_limit", 10),
|
|
1098
|
+
retriever_context_lines=_get_int(sec, "retriever_context_lines", 20),
|
|
1099
|
+
file_navigator_read_max_lines=_get_int(
|
|
1100
|
+
sec, "file_navigator_read_max_lines", 200
|
|
1101
|
+
),
|
|
1102
|
+
file_navigator_max_read_bytes=_get_int(
|
|
1103
|
+
sec, "file_navigator_max_read_bytes", 1_048_576
|
|
1104
|
+
),
|
|
1105
|
+
knowledge_consolidation_max_lines=_get_int(
|
|
1106
|
+
sec, "knowledge_consolidation_max_lines", 10
|
|
1107
|
+
),
|
|
1108
|
+
context_export_http_timeout_sec=_get_int(
|
|
1109
|
+
sec, "context_export_http_timeout_sec", 10
|
|
1110
|
+
),
|
|
1111
|
+
metadata_max_comment_length=_get_int(sec, "metadata_max_comment_length", 120),
|
|
1112
|
+
census_hotspot_limit=_get_int(sec, "census_hotspot_limit", 10),
|
|
1113
|
+
clustering_default_n_clusters=_get_int(
|
|
1114
|
+
sec, "clustering_default_n_clusters", 15
|
|
1115
|
+
),
|
|
1116
|
+
legacy_scan_display_limit=_get_int(sec, "legacy_scan_display_limit", 10),
|
|
1117
|
+
limb_status_recent_limit=_get_int(sec, "limb_status_recent_limit", 15),
|
|
1118
|
+
refusal_inspect_default_limit=_get_int(
|
|
1119
|
+
sec, "refusal_inspect_default_limit", 20
|
|
1120
|
+
),
|
|
1121
|
+
refusal_inspect_by_type_limit=_get_int(
|
|
1122
|
+
sec, "refusal_inspect_by_type_limit", 20
|
|
1123
|
+
),
|
|
1124
|
+
capability_tagging_default_llm_confidence=_get_float(
|
|
1125
|
+
sec, "capability_tagging_default_llm_confidence", 0.70
|
|
1126
|
+
),
|
|
1127
|
+
knowledge_min_occurrences=_get_int(sec, "knowledge_min_occurrences", 3),
|
|
1128
|
+
knowledge_max_lines=_get_int(sec, "knowledge_max_lines", 10),
|
|
1129
|
+
context_aware_test_context_lines=_get_int(
|
|
1130
|
+
sec, "context_aware_test_context_lines", 40
|
|
1131
|
+
),
|
|
1132
|
+
perf_overhead_warning_pct=_get_int(sec, "perf_overhead_warning_pct", 50),
|
|
1133
|
+
perf_overhead_error_pct=_get_int(sec, "perf_overhead_error_pct", 100),
|
|
1134
|
+
context_search_display_limit=_get_int(sec, "context_search_display_limit", 20),
|
|
1135
|
+
proposals_display_limit=_get_int(sec, "proposals_display_limit", 20),
|
|
1136
|
+
)
|
|
1137
|
+
|
|
1138
|
+
|
|
1139
|
+
def _load_workers(raw: dict[str, Any]) -> WorkersConfig:
|
|
1140
|
+
workers = _section(raw, "workers")
|
|
1141
|
+
return WorkersConfig(
|
|
1142
|
+
call_site_rewriter=WorkerCallSiteRewriterConfig(
|
|
1143
|
+
claim_limit=_get_int(
|
|
1144
|
+
_section(workers, "call_site_rewriter"), "claim_limit", 50
|
|
1145
|
+
)
|
|
1146
|
+
),
|
|
1147
|
+
doc_writer=WorkerDocWriterConfig(
|
|
1148
|
+
batch_size=_get_int(_section(workers, "doc_writer"), "batch_size", 25)
|
|
1149
|
+
),
|
|
1150
|
+
doc_worker=WorkerDocWorkerConfig(
|
|
1151
|
+
batch_size=_get_int(_section(workers, "doc_worker"), "batch_size", 50)
|
|
1152
|
+
),
|
|
1153
|
+
prompt_artifact_writer=WorkerPromptArtifactWriterConfig(
|
|
1154
|
+
claim_limit=_get_int(
|
|
1155
|
+
_section(workers, "prompt_artifact_writer"), "claim_limit", 25
|
|
1156
|
+
)
|
|
1157
|
+
),
|
|
1158
|
+
prompt_extractor=WorkerPromptExtractorConfig(
|
|
1159
|
+
claim_limit=_get_int(
|
|
1160
|
+
_section(workers, "prompt_extractor"), "claim_limit", 25
|
|
1161
|
+
),
|
|
1162
|
+
context_lines=_get_int(
|
|
1163
|
+
_section(workers, "prompt_extractor"), "context_lines", 40
|
|
1164
|
+
),
|
|
1165
|
+
),
|
|
1166
|
+
capability_tagger=WorkerCapabilityTaggerConfig(
|
|
1167
|
+
batch_size=_get_int(
|
|
1168
|
+
_section(workers, "capability_tagger"), "batch_size", 20
|
|
1169
|
+
)
|
|
1170
|
+
),
|
|
1171
|
+
proposal_consumer=WorkerProposalConsumerConfig(
|
|
1172
|
+
claim_limit=_get_int(
|
|
1173
|
+
_section(workers, "proposal_consumer"), "claim_limit", 5
|
|
1174
|
+
)
|
|
1175
|
+
),
|
|
1176
|
+
violation_executor=WorkerViolationExecutorConfig(
|
|
1177
|
+
claim_limit=_get_int(
|
|
1178
|
+
_section(workers, "violation_executor"), "claim_limit", 50
|
|
1179
|
+
)
|
|
1180
|
+
),
|
|
1181
|
+
violation_remediator=WorkerViolationRemediatorConfig(
|
|
1182
|
+
claim_limit=_get_int(
|
|
1183
|
+
_section(workers, "violation_remediator"), "claim_limit", 50
|
|
1184
|
+
),
|
|
1185
|
+
scan_limit=_get_int(
|
|
1186
|
+
_section(workers, "violation_remediator"), "scan_limit", 200
|
|
1187
|
+
),
|
|
1188
|
+
ceremony_timeout_sec=_get_int(
|
|
1189
|
+
_section(workers, "violation_remediator"), "ceremony_timeout_sec", 30
|
|
1190
|
+
),
|
|
1191
|
+
semantic_examples_limit=_get_int(
|
|
1192
|
+
_section(workers, "violation_remediator"),
|
|
1193
|
+
"semantic_examples_limit",
|
|
1194
|
+
3,
|
|
1195
|
+
),
|
|
1196
|
+
min_role_confidence=_get_float(
|
|
1197
|
+
_section(workers, "violation_remediator"),
|
|
1198
|
+
"min_role_confidence",
|
|
1199
|
+
0.55,
|
|
1200
|
+
),
|
|
1201
|
+
),
|
|
1202
|
+
worker_shop=WorkerShopConfig(
|
|
1203
|
+
glide_off_multiplier=_get_float(
|
|
1204
|
+
_section(workers, "worker_shop"), "glide_off_multiplier", 0.10
|
|
1205
|
+
),
|
|
1206
|
+
fallback_threshold_sec=_get_int(
|
|
1207
|
+
_section(workers, "worker_shop"), "fallback_threshold_sec", 600
|
|
1208
|
+
),
|
|
1209
|
+
findings_scan_limit=_get_int(
|
|
1210
|
+
_section(workers, "worker_shop"), "findings_scan_limit", 200
|
|
1211
|
+
),
|
|
1212
|
+
),
|
|
1213
|
+
proposal_pipeline_shop=WorkerProposalPipelineShopConfig(
|
|
1214
|
+
stuck_approved_sla_sec=_get_int(
|
|
1215
|
+
_section(workers, "proposal_pipeline_shop"),
|
|
1216
|
+
"stuck_approved_sla_sec",
|
|
1217
|
+
1800,
|
|
1218
|
+
),
|
|
1219
|
+
stuck_executing_sla_sec=_get_int(
|
|
1220
|
+
_section(workers, "proposal_pipeline_shop"),
|
|
1221
|
+
"stuck_executing_sla_sec",
|
|
1222
|
+
900,
|
|
1223
|
+
),
|
|
1224
|
+
repeated_failure_threshold=_get_int(
|
|
1225
|
+
_section(workers, "proposal_pipeline_shop"),
|
|
1226
|
+
"repeated_failure_threshold",
|
|
1227
|
+
3,
|
|
1228
|
+
),
|
|
1229
|
+
repeated_failure_lookback_sec=_get_int(
|
|
1230
|
+
_section(workers, "proposal_pipeline_shop"),
|
|
1231
|
+
"repeated_failure_lookback_sec",
|
|
1232
|
+
86400,
|
|
1233
|
+
),
|
|
1234
|
+
findings_scan_limit=_get_int(
|
|
1235
|
+
_section(workers, "proposal_pipeline_shop"),
|
|
1236
|
+
"findings_scan_limit",
|
|
1237
|
+
200,
|
|
1238
|
+
),
|
|
1239
|
+
),
|
|
1240
|
+
test_remediator=WorkerTestRemediatorConfig(
|
|
1241
|
+
scan_limit=_get_int(_section(workers, "test_remediator"), "scan_limit", 200)
|
|
1242
|
+
),
|
|
1243
|
+
test_runner_sensor=WorkerTestRunnerSensorConfig(
|
|
1244
|
+
scan_limit=_get_int(
|
|
1245
|
+
_section(workers, "test_runner_sensor"), "scan_limit", 50
|
|
1246
|
+
)
|
|
1247
|
+
),
|
|
1248
|
+
intent_inspector=WorkerIntentInspectorConfig(
|
|
1249
|
+
alignment_batch=_get_int(
|
|
1250
|
+
_section(workers, "intent_inspector"), "alignment_batch", 20
|
|
1251
|
+
)
|
|
1252
|
+
),
|
|
1253
|
+
observer=WorkerObserverConfig(
|
|
1254
|
+
stale_threshold_seconds=_get_int(
|
|
1255
|
+
_section(workers, "observer"), "stale_threshold_seconds", 3600
|
|
1256
|
+
)
|
|
1257
|
+
),
|
|
1258
|
+
coherence_sensor=WorkerCoherenceSensorConfig(
|
|
1259
|
+
lookback_seconds=_get_int(
|
|
1260
|
+
_section(workers, "coherence_sensor"), "lookback_seconds", 7200
|
|
1261
|
+
)
|
|
1262
|
+
),
|
|
1263
|
+
)
|
|
1264
|
+
|
|
1265
|
+
|
|
1266
|
+
# ---------------------------------------------------------------------------
|
|
1267
|
+
# Public loader
|
|
1268
|
+
# ---------------------------------------------------------------------------
|
|
1269
|
+
|
|
1270
|
+
|
|
1271
|
+
# ID: f5b20a98-a3b5-4e8d-a19e-f310639cd2a9
|
|
1272
|
+
def load_operational_config() -> OperationalConfig:
|
|
1273
|
+
"""
|
|
1274
|
+
Load .intent/enforcement/config/operational_config.yaml via IntentRepository.
|
|
1275
|
+
|
|
1276
|
+
Returns an OperationalConfig with every section populated from the
|
|
1277
|
+
YAML file. On any failure — missing file, parse error, non-mapping
|
|
1278
|
+
section, type-coercion error on a single field — the loader logs a
|
|
1279
|
+
warning at WARNING level and substitutes the matching fallback
|
|
1280
|
+
default. It never raises, so callers can use the result unconditionally.
|
|
1281
|
+
|
|
1282
|
+
The drift window is bounded by IntentRepository.reload() on the next
|
|
1283
|
+
audit-sensor cycle (ADR-039).
|
|
1284
|
+
"""
|
|
1285
|
+
raw: dict[str, Any] = {}
|
|
1286
|
+
try:
|
|
1287
|
+
from shared.infrastructure.intent.intent_repository import (
|
|
1288
|
+
get_intent_repository,
|
|
1289
|
+
)
|
|
1290
|
+
|
|
1291
|
+
repo = get_intent_repository()
|
|
1292
|
+
config_path = repo.resolve_rel("enforcement/config/operational_config.yaml")
|
|
1293
|
+
loaded = repo.load_document(config_path)
|
|
1294
|
+
if isinstance(loaded, dict):
|
|
1295
|
+
raw = loaded
|
|
1296
|
+
else:
|
|
1297
|
+
logger.warning(
|
|
1298
|
+
"operational_config: operational_config.yaml did not parse as a "
|
|
1299
|
+
"dict — using fallback defaults."
|
|
1300
|
+
)
|
|
1301
|
+
except Exception as exc:
|
|
1302
|
+
logger.warning(
|
|
1303
|
+
"operational_config: could not load .intent/enforcement/config/"
|
|
1304
|
+
"operational_config.yaml (%s) — using fallback defaults.",
|
|
1305
|
+
exc,
|
|
1306
|
+
)
|
|
1307
|
+
|
|
1308
|
+
return OperationalConfig(
|
|
1309
|
+
llm=_load_llm(raw),
|
|
1310
|
+
embedding=_load_embedding(raw),
|
|
1311
|
+
chunking=_load_chunking(raw),
|
|
1312
|
+
workers=_load_workers(raw),
|
|
1313
|
+
blackboard=_load_blackboard(raw),
|
|
1314
|
+
health_log=_load_health_log(raw),
|
|
1315
|
+
daemon=_load_daemon(raw),
|
|
1316
|
+
worker_classification=_load_worker_classification(raw),
|
|
1317
|
+
proposals=_load_proposals(raw),
|
|
1318
|
+
consequence_log=_load_consequence_log(raw),
|
|
1319
|
+
audit=_load_audit(raw),
|
|
1320
|
+
coverage=_load_coverage(raw),
|
|
1321
|
+
workflow_gate=_load_workflow_gate(raw),
|
|
1322
|
+
context=_load_context(raw),
|
|
1323
|
+
health=_load_health(raw),
|
|
1324
|
+
testing=_load_testing(raw),
|
|
1325
|
+
strategy_selector=_load_strategy_selector(raw),
|
|
1326
|
+
analyzers=_load_analyzers(raw),
|
|
1327
|
+
refactor=_load_refactor(raw),
|
|
1328
|
+
clarity=_load_clarity(raw),
|
|
1329
|
+
complexity=_load_complexity(raw),
|
|
1330
|
+
parsing=_load_parsing(raw),
|
|
1331
|
+
execution=_load_execution(raw),
|
|
1332
|
+
action=_load_action(raw),
|
|
1333
|
+
prompt_pipeline=_load_prompt_pipeline(raw),
|
|
1334
|
+
validator=_load_validator(raw),
|
|
1335
|
+
memory=_load_memory(raw),
|
|
1336
|
+
repositories=_load_repositories(raw),
|
|
1337
|
+
git=_load_git(raw),
|
|
1338
|
+
vectors=_load_vectors(raw),
|
|
1339
|
+
sync=_load_sync(raw),
|
|
1340
|
+
authority_package=_load_authority_package(raw),
|
|
1341
|
+
strategic_auditor=_load_strategic_auditor(raw),
|
|
1342
|
+
misc=_load_misc(raw),
|
|
1343
|
+
)
|