@rbalchii/anchor-engine 4.7.0
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.
- package/LICENSE +609 -0
- package/README.md +317 -0
- package/anchor.bat +5 -0
- package/docs/API.md +314 -0
- package/docs/DEPLOYMENT.md +448 -0
- package/docs/INDEX.md +226 -0
- package/docs/STAR_Whitepaper_Executive.md +216 -0
- package/docs/TROUBLESHOOTING.md +535 -0
- package/docs/archive/GIT_BACKUP_VERIFICATION.md +297 -0
- package/docs/archive/adoption-guide.md +264 -0
- package/docs/archive/adoption-preparation.md +179 -0
- package/docs/archive/agent-harness-integration.md +227 -0
- package/docs/archive/api-reference.md +106 -0
- package/docs/archive/api_flows_diagram.md +118 -0
- package/docs/archive/architecture.md +410 -0
- package/docs/archive/architecture_diagram.md +174 -0
- package/docs/archive/broader-adoption-preparation.md +175 -0
- package/docs/archive/browser-paradigm-architecture.md +163 -0
- package/docs/archive/chat-integration.md +124 -0
- package/docs/archive/community-adoption-materials.md +103 -0
- package/docs/archive/community-adoption.md +147 -0
- package/docs/archive/comparison-with-siloed-solutions.md +192 -0
- package/docs/archive/comprehensive-docs.md +156 -0
- package/docs/archive/data_flow_diagram.md +251 -0
- package/docs/archive/enhancement-implementation-summary.md +146 -0
- package/docs/archive/evolution-summary.md +141 -0
- package/docs/archive/ingestion_pipeline_diagram.md +198 -0
- package/docs/archive/native-module-profiling-results.md +135 -0
- package/docs/archive/positioning-document.md +158 -0
- package/docs/archive/positioning.md +175 -0
- package/docs/archive/query-builder-documentation.md +218 -0
- package/docs/archive/quick-reference.md +40 -0
- package/docs/archive/quickstart.md +63 -0
- package/docs/archive/relationship-narrative-discovery.md +141 -0
- package/docs/archive/search-logic-improvement-plan.md +336 -0
- package/docs/archive/search_architecture_diagram.md +212 -0
- package/docs/archive/semantic-architecture-guide.md +97 -0
- package/docs/archive/sequence-diagrams.md +128 -0
- package/docs/archive/system_components_diagram.md +296 -0
- package/docs/archive/test-framework-integration.md +109 -0
- package/docs/archive/testing-framework-documentation.md +397 -0
- package/docs/archive/testing-framework-summary.md +121 -0
- package/docs/archive/testing-framework.md +377 -0
- package/docs/archive/ui-architecture.md +75 -0
- package/docs/arxiv/BIBLIOGRAPHY.bib +145 -0
- package/docs/arxiv/RELATED_WORK.tex +39 -0
- package/docs/arxiv/compile.bat +48 -0
- package/docs/arxiv/joss_response.md +33 -0
- package/docs/arxiv/prepare-submission.bat +46 -0
- package/docs/arxiv/review.md +128 -0
- package/docs/arxiv/star-whitepaper.tex +657 -0
- package/docs/code-patterns.md +289 -0
- package/docs/whitepaper.md +445 -0
- package/engine/dist/agent/runtime.d.ts +41 -0
- package/engine/dist/agent/runtime.d.ts.map +1 -0
- package/engine/dist/agent/runtime.js +73 -0
- package/engine/dist/agent/runtime.js.map +1 -0
- package/engine/dist/commands/audit-tags.d.ts +14 -0
- package/engine/dist/commands/audit-tags.d.ts.map +1 -0
- package/engine/dist/commands/audit-tags.js +180 -0
- package/engine/dist/commands/audit-tags.js.map +1 -0
- package/engine/dist/commands/distill.d.ts +19 -0
- package/engine/dist/commands/distill.d.ts.map +1 -0
- package/engine/dist/commands/distill.js +114 -0
- package/engine/dist/commands/distill.js.map +1 -0
- package/engine/dist/commands/generate-synonyms.d.ts +14 -0
- package/engine/dist/commands/generate-synonyms.d.ts.map +1 -0
- package/engine/dist/commands/generate-synonyms.js +91 -0
- package/engine/dist/commands/generate-synonyms.js.map +1 -0
- package/engine/dist/config/index.d.ts +115 -0
- package/engine/dist/config/index.d.ts.map +1 -0
- package/engine/dist/config/index.js +326 -0
- package/engine/dist/config/index.js.map +1 -0
- package/engine/dist/config/max-recall-config.d.ts +102 -0
- package/engine/dist/config/max-recall-config.d.ts.map +1 -0
- package/engine/dist/config/max-recall-config.js +102 -0
- package/engine/dist/config/max-recall-config.js.map +1 -0
- package/engine/dist/config/paths.d.ts +40 -0
- package/engine/dist/config/paths.d.ts.map +1 -0
- package/engine/dist/config/paths.js +49 -0
- package/engine/dist/config/paths.js.map +1 -0
- package/engine/dist/core/batch.d.ts +19 -0
- package/engine/dist/core/batch.d.ts.map +1 -0
- package/engine/dist/core/batch.js +37 -0
- package/engine/dist/core/batch.js.map +1 -0
- package/engine/dist/core/db.d.ts +58 -0
- package/engine/dist/core/db.d.ts.map +1 -0
- package/engine/dist/core/db.js +563 -0
- package/engine/dist/core/db.js.map +1 -0
- package/engine/dist/core/inference/ChatWorker.d.ts +2 -0
- package/engine/dist/core/inference/ChatWorker.d.ts.map +1 -0
- package/engine/dist/core/inference/ChatWorker.js +28 -0
- package/engine/dist/core/inference/ChatWorker.js.map +1 -0
- package/engine/dist/core/inference/context_manager.d.ts +49 -0
- package/engine/dist/core/inference/context_manager.d.ts.map +1 -0
- package/engine/dist/core/inference/context_manager.js +199 -0
- package/engine/dist/core/inference/context_manager.js.map +1 -0
- package/engine/dist/core/inference/llamaLoaderWorker.d.ts +2 -0
- package/engine/dist/core/inference/llamaLoaderWorker.d.ts.map +1 -0
- package/engine/dist/core/inference/llamaLoaderWorker.js +23 -0
- package/engine/dist/core/inference/llamaLoaderWorker.js.map +1 -0
- package/engine/dist/core/vector.d.ts +40 -0
- package/engine/dist/core/vector.d.ts.map +1 -0
- package/engine/dist/core/vector.js +167 -0
- package/engine/dist/core/vector.js.map +1 -0
- package/engine/dist/index.d.ts +4 -0
- package/engine/dist/index.d.ts.map +1 -0
- package/engine/dist/index.js +400 -0
- package/engine/dist/index.js.map +1 -0
- package/engine/dist/middleware/auth.d.ts +14 -0
- package/engine/dist/middleware/auth.d.ts.map +1 -0
- package/engine/dist/middleware/auth.js +44 -0
- package/engine/dist/middleware/auth.js.map +1 -0
- package/engine/dist/middleware/request-tracing.d.ts +29 -0
- package/engine/dist/middleware/request-tracing.d.ts.map +1 -0
- package/engine/dist/middleware/request-tracing.js +115 -0
- package/engine/dist/middleware/request-tracing.js.map +1 -0
- package/engine/dist/middleware/validate.d.ts +30 -0
- package/engine/dist/middleware/validate.d.ts.map +1 -0
- package/engine/dist/middleware/validate.js +117 -0
- package/engine/dist/middleware/validate.js.map +1 -0
- package/engine/dist/native/index.d.ts +106 -0
- package/engine/dist/native/index.d.ts.map +1 -0
- package/engine/dist/native/index.js +230 -0
- package/engine/dist/native/index.js.map +1 -0
- package/engine/dist/native/types.d.ts +45 -0
- package/engine/dist/native/types.d.ts.map +1 -0
- package/engine/dist/native/types.js +6 -0
- package/engine/dist/native/types.js.map +1 -0
- package/engine/dist/profiling/atomization-profiling.d.ts +8 -0
- package/engine/dist/profiling/atomization-profiling.d.ts.map +1 -0
- package/engine/dist/profiling/atomization-profiling.js +108 -0
- package/engine/dist/profiling/atomization-profiling.js.map +1 -0
- package/engine/dist/profiling/bottleneck-identification.d.ts +8 -0
- package/engine/dist/profiling/bottleneck-identification.d.ts.map +1 -0
- package/engine/dist/profiling/bottleneck-identification.js +249 -0
- package/engine/dist/profiling/bottleneck-identification.js.map +1 -0
- package/engine/dist/profiling/content-sanitization-profiling.d.ts +12 -0
- package/engine/dist/profiling/content-sanitization-profiling.d.ts.map +1 -0
- package/engine/dist/profiling/content-sanitization-profiling.js +266 -0
- package/engine/dist/profiling/content-sanitization-profiling.js.map +1 -0
- package/engine/dist/profiling/simhash-profiling.d.ts +11 -0
- package/engine/dist/profiling/simhash-profiling.d.ts.map +1 -0
- package/engine/dist/profiling/simhash-profiling.js +168 -0
- package/engine/dist/profiling/simhash-profiling.js.map +1 -0
- package/engine/dist/routes/api.d.ts +9 -0
- package/engine/dist/routes/api.d.ts.map +1 -0
- package/engine/dist/routes/api.js +37 -0
- package/engine/dist/routes/api.js.map +1 -0
- package/engine/dist/routes/enhanced-api.d.ts +9 -0
- package/engine/dist/routes/enhanced-api.d.ts.map +1 -0
- package/engine/dist/routes/enhanced-api.js +139 -0
- package/engine/dist/routes/enhanced-api.js.map +1 -0
- package/engine/dist/routes/health.d.ts +8 -0
- package/engine/dist/routes/health.d.ts.map +1 -0
- package/engine/dist/routes/health.js +89 -0
- package/engine/dist/routes/health.js.map +1 -0
- package/engine/dist/routes/monitoring.d.ts +8 -0
- package/engine/dist/routes/monitoring.d.ts.map +1 -0
- package/engine/dist/routes/monitoring.js +509 -0
- package/engine/dist/routes/monitoring.js.map +1 -0
- package/engine/dist/routes/v1/admin.d.ts +3 -0
- package/engine/dist/routes/v1/admin.d.ts.map +1 -0
- package/engine/dist/routes/v1/admin.js +261 -0
- package/engine/dist/routes/v1/admin.js.map +1 -0
- package/engine/dist/routes/v1/atoms.d.ts +3 -0
- package/engine/dist/routes/v1/atoms.d.ts.map +1 -0
- package/engine/dist/routes/v1/atoms.js +172 -0
- package/engine/dist/routes/v1/atoms.js.map +1 -0
- package/engine/dist/routes/v1/backup.d.ts +3 -0
- package/engine/dist/routes/v1/backup.d.ts.map +1 -0
- package/engine/dist/routes/v1/backup.js +100 -0
- package/engine/dist/routes/v1/backup.js.map +1 -0
- package/engine/dist/routes/v1/git.d.ts +3 -0
- package/engine/dist/routes/v1/git.d.ts.map +1 -0
- package/engine/dist/routes/v1/git.js +316 -0
- package/engine/dist/routes/v1/git.js.map +1 -0
- package/engine/dist/routes/v1/ingest.d.ts +3 -0
- package/engine/dist/routes/v1/ingest.d.ts.map +1 -0
- package/engine/dist/routes/v1/ingest.js +66 -0
- package/engine/dist/routes/v1/ingest.js.map +1 -0
- package/engine/dist/routes/v1/memory.d.ts +14 -0
- package/engine/dist/routes/v1/memory.d.ts.map +1 -0
- package/engine/dist/routes/v1/memory.js +87 -0
- package/engine/dist/routes/v1/memory.js.map +1 -0
- package/engine/dist/routes/v1/research.d.ts +3 -0
- package/engine/dist/routes/v1/research.d.ts.map +1 -0
- package/engine/dist/routes/v1/research.js +109 -0
- package/engine/dist/routes/v1/research.js.map +1 -0
- package/engine/dist/routes/v1/search.d.ts +3 -0
- package/engine/dist/routes/v1/search.d.ts.map +1 -0
- package/engine/dist/routes/v1/search.js +180 -0
- package/engine/dist/routes/v1/search.js.map +1 -0
- package/engine/dist/routes/v1/settings.d.ts +8 -0
- package/engine/dist/routes/v1/settings.d.ts.map +1 -0
- package/engine/dist/routes/v1/settings.js +211 -0
- package/engine/dist/routes/v1/settings.js.map +1 -0
- package/engine/dist/routes/v1/system.d.ts +3 -0
- package/engine/dist/routes/v1/system.d.ts.map +1 -0
- package/engine/dist/routes/v1/system.js +326 -0
- package/engine/dist/routes/v1/system.js.map +1 -0
- package/engine/dist/routes/v1/tags.d.ts +3 -0
- package/engine/dist/routes/v1/tags.d.ts.map +1 -0
- package/engine/dist/routes/v1/tags.js +102 -0
- package/engine/dist/routes/v1/tags.js.map +1 -0
- package/engine/dist/server-8080.d.ts +2 -0
- package/engine/dist/server-8080.d.ts.map +1 -0
- package/engine/dist/server-8080.js +74 -0
- package/engine/dist/server-8080.js.map +1 -0
- package/engine/dist/services/backup/backup-restore.d.ts +37 -0
- package/engine/dist/services/backup/backup-restore.d.ts.map +1 -0
- package/engine/dist/services/backup/backup-restore.js +385 -0
- package/engine/dist/services/backup/backup-restore.js.map +1 -0
- package/engine/dist/services/backup/backup.d.ts +14 -0
- package/engine/dist/services/backup/backup.d.ts.map +1 -0
- package/engine/dist/services/backup/backup.js +442 -0
- package/engine/dist/services/backup/backup.js.map +1 -0
- package/engine/dist/services/distillation/radial-distiller-v2.d.ts +127 -0
- package/engine/dist/services/distillation/radial-distiller-v2.d.ts.map +1 -0
- package/engine/dist/services/distillation/radial-distiller-v2.js +503 -0
- package/engine/dist/services/distillation/radial-distiller-v2.js.map +1 -0
- package/engine/dist/services/distillation/radial-distiller.d.ts +63 -0
- package/engine/dist/services/distillation/radial-distiller.d.ts.map +1 -0
- package/engine/dist/services/distillation/radial-distiller.js +394 -0
- package/engine/dist/services/distillation/radial-distiller.js.map +1 -0
- package/engine/dist/services/health-check-enhanced.d.ts +89 -0
- package/engine/dist/services/health-check-enhanced.d.ts.map +1 -0
- package/engine/dist/services/health-check-enhanced.js +417 -0
- package/engine/dist/services/health-check-enhanced.js.map +1 -0
- package/engine/dist/services/idle-manager.d.ts +56 -0
- package/engine/dist/services/idle-manager.d.ts.map +1 -0
- package/engine/dist/services/idle-manager.js +210 -0
- package/engine/dist/services/idle-manager.js.map +1 -0
- package/engine/dist/services/inference/inference-service.d.ts +27 -0
- package/engine/dist/services/inference/inference-service.d.ts.map +1 -0
- package/engine/dist/services/inference/inference-service.js +89 -0
- package/engine/dist/services/inference/inference-service.js.map +1 -0
- package/engine/dist/services/inference/inference.d.ts +59 -0
- package/engine/dist/services/inference/inference.d.ts.map +1 -0
- package/engine/dist/services/inference/inference.js +131 -0
- package/engine/dist/services/inference/inference.js.map +1 -0
- package/engine/dist/services/ingest/atomizer-service.d.ts +74 -0
- package/engine/dist/services/ingest/atomizer-service.d.ts.map +1 -0
- package/engine/dist/services/ingest/atomizer-service.js +982 -0
- package/engine/dist/services/ingest/atomizer-service.js.map +1 -0
- package/engine/dist/services/ingest/content-cleaner.d.ts +43 -0
- package/engine/dist/services/ingest/content-cleaner.d.ts.map +1 -0
- package/engine/dist/services/ingest/content-cleaner.js +166 -0
- package/engine/dist/services/ingest/content-cleaner.js.map +1 -0
- package/engine/dist/services/ingest/github-ingest-service.d.ts +103 -0
- package/engine/dist/services/ingest/github-ingest-service.d.ts.map +1 -0
- package/engine/dist/services/ingest/github-ingest-service.js +537 -0
- package/engine/dist/services/ingest/github-ingest-service.js.map +1 -0
- package/engine/dist/services/ingest/ingest-atomic.d.ts +16 -0
- package/engine/dist/services/ingest/ingest-atomic.d.ts.map +1 -0
- package/engine/dist/services/ingest/ingest-atomic.js +437 -0
- package/engine/dist/services/ingest/ingest-atomic.js.map +1 -0
- package/engine/dist/services/ingest/ingest.d.ts +50 -0
- package/engine/dist/services/ingest/ingest.d.ts.map +1 -0
- package/engine/dist/services/ingest/ingest.js +230 -0
- package/engine/dist/services/ingest/ingest.js.map +1 -0
- package/engine/dist/services/ingest/watchdog.d.ts +31 -0
- package/engine/dist/services/ingest/watchdog.d.ts.map +1 -0
- package/engine/dist/services/ingest/watchdog.js +400 -0
- package/engine/dist/services/ingest/watchdog.js.map +1 -0
- package/engine/dist/services/llm/context.d.ts +6 -0
- package/engine/dist/services/llm/context.d.ts.map +1 -0
- package/engine/dist/services/llm/context.js +80 -0
- package/engine/dist/services/llm/context.js.map +1 -0
- package/engine/dist/services/llm/provider.d.ts +23 -0
- package/engine/dist/services/llm/provider.d.ts.map +1 -0
- package/engine/dist/services/llm/provider.js +338 -0
- package/engine/dist/services/llm/provider.js.map +1 -0
- package/engine/dist/services/llm/reader.d.ts +12 -0
- package/engine/dist/services/llm/reader.d.ts.map +1 -0
- package/engine/dist/services/llm/reader.js +40 -0
- package/engine/dist/services/llm/reader.js.map +1 -0
- package/engine/dist/services/mirror/mirror.d.ts +28 -0
- package/engine/dist/services/mirror/mirror.d.ts.map +1 -0
- package/engine/dist/services/mirror/mirror.js +208 -0
- package/engine/dist/services/mirror/mirror.js.map +1 -0
- package/engine/dist/services/nlp/nlp-service.d.ts +70 -0
- package/engine/dist/services/nlp/nlp-service.d.ts.map +1 -0
- package/engine/dist/services/nlp/nlp-service.js +151 -0
- package/engine/dist/services/nlp/nlp-service.js.map +1 -0
- package/engine/dist/services/nlp/query-parser.d.ts +9 -0
- package/engine/dist/services/nlp/query-parser.d.ts.map +1 -0
- package/engine/dist/services/nlp/query-parser.js +29 -0
- package/engine/dist/services/nlp/query-parser.js.map +1 -0
- package/engine/dist/services/query-builder/DataFrame.d.ts +95 -0
- package/engine/dist/services/query-builder/DataFrame.d.ts.map +1 -0
- package/engine/dist/services/query-builder/DataFrame.js +263 -0
- package/engine/dist/services/query-builder/DataFrame.js.map +1 -0
- package/engine/dist/services/query-builder/QueryBuilder.d.ts +106 -0
- package/engine/dist/services/query-builder/QueryBuilder.d.ts.map +1 -0
- package/engine/dist/services/query-builder/QueryBuilder.js +235 -0
- package/engine/dist/services/query-builder/QueryBuilder.js.map +1 -0
- package/engine/dist/services/query-builder/utils/export.d.ts +11 -0
- package/engine/dist/services/query-builder/utils/export.d.ts.map +1 -0
- package/engine/dist/services/query-builder/utils/export.js +130 -0
- package/engine/dist/services/query-builder/utils/export.js.map +1 -0
- package/engine/dist/services/research/researcher.d.ts +15 -0
- package/engine/dist/services/research/researcher.d.ts.map +1 -0
- package/engine/dist/services/research/researcher.js +123 -0
- package/engine/dist/services/research/researcher.js.map +1 -0
- package/engine/dist/services/scribe/scribe.d.ts +43 -0
- package/engine/dist/services/scribe/scribe.d.ts.map +1 -0
- package/engine/dist/services/scribe/scribe.js +135 -0
- package/engine/dist/services/scribe/scribe.js.map +1 -0
- package/engine/dist/services/search/bright-nodes.d.ts +41 -0
- package/engine/dist/services/search/bright-nodes.d.ts.map +1 -0
- package/engine/dist/services/search/bright-nodes.js +117 -0
- package/engine/dist/services/search/bright-nodes.js.map +1 -0
- package/engine/dist/services/search/context-inflator.d.ts +63 -0
- package/engine/dist/services/search/context-inflator.d.ts.map +1 -0
- package/engine/dist/services/search/context-inflator.js +649 -0
- package/engine/dist/services/search/context-inflator.js.map +1 -0
- package/engine/dist/services/search/context-manager.d.ts +34 -0
- package/engine/dist/services/search/context-manager.d.ts.map +1 -0
- package/engine/dist/services/search/context-manager.js +124 -0
- package/engine/dist/services/search/context-manager.js.map +1 -0
- package/engine/dist/services/search/distributed-query.d.ts +38 -0
- package/engine/dist/services/search/distributed-query.d.ts.map +1 -0
- package/engine/dist/services/search/distributed-query.js +105 -0
- package/engine/dist/services/search/distributed-query.js.map +1 -0
- package/engine/dist/services/search/explore.d.ts +73 -0
- package/engine/dist/services/search/explore.d.ts.map +1 -0
- package/engine/dist/services/search/explore.js +388 -0
- package/engine/dist/services/search/explore.js.map +1 -0
- package/engine/dist/services/search/graph-context-serializer.d.ts +76 -0
- package/engine/dist/services/search/graph-context-serializer.d.ts.map +1 -0
- package/engine/dist/services/search/graph-context-serializer.js +435 -0
- package/engine/dist/services/search/graph-context-serializer.js.map +1 -0
- package/engine/dist/services/search/llm-context-formatter.d.ts +122 -0
- package/engine/dist/services/search/llm-context-formatter.d.ts.map +1 -0
- package/engine/dist/services/search/llm-context-formatter.js +394 -0
- package/engine/dist/services/search/llm-context-formatter.js.map +1 -0
- package/engine/dist/services/search/physics-tag-walker.d.ts +115 -0
- package/engine/dist/services/search/physics-tag-walker.d.ts.map +1 -0
- package/engine/dist/services/search/physics-tag-walker.js +611 -0
- package/engine/dist/services/search/physics-tag-walker.js.map +1 -0
- package/engine/dist/services/search/query-parser.d.ts +66 -0
- package/engine/dist/services/search/query-parser.d.ts.map +1 -0
- package/engine/dist/services/search/query-parser.js +346 -0
- package/engine/dist/services/search/query-parser.js.map +1 -0
- package/engine/dist/services/search/search-utils.d.ts +100 -0
- package/engine/dist/services/search/search-utils.d.ts.map +1 -0
- package/engine/dist/services/search/search-utils.js +473 -0
- package/engine/dist/services/search/search-utils.js.map +1 -0
- package/engine/dist/services/search/search.d.ts +116 -0
- package/engine/dist/services/search/search.d.ts.map +1 -0
- package/engine/dist/services/search/search.js +1286 -0
- package/engine/dist/services/search/search.js.map +1 -0
- package/engine/dist/services/search/sovereign-system-prompt.d.ts +48 -0
- package/engine/dist/services/search/sovereign-system-prompt.d.ts.map +1 -0
- package/engine/dist/services/search/sovereign-system-prompt.js +101 -0
- package/engine/dist/services/search/sovereign-system-prompt.js.map +1 -0
- package/engine/dist/services/search/streaming-search.d.ts +51 -0
- package/engine/dist/services/search/streaming-search.d.ts.map +1 -0
- package/engine/dist/services/search/streaming-search.js +94 -0
- package/engine/dist/services/search/streaming-search.js.map +1 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.d.ts +53 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.js +625 -0
- package/engine/dist/services/semantic/semantic-ingestion-service.js.map +1 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.d.ts +68 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.js +176 -0
- package/engine/dist/services/semantic/semantic-molecule-processor.js.map +1 -0
- package/engine/dist/services/semantic/semantic-search.d.ts +52 -0
- package/engine/dist/services/semantic/semantic-search.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-search.js +649 -0
- package/engine/dist/services/semantic/semantic-search.js.map +1 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.d.ts +64 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.d.ts.map +1 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.js +191 -0
- package/engine/dist/services/semantic/semantic-tag-deriver.js.map +1 -0
- package/engine/dist/services/semantic/types/semantic.d.ts +26 -0
- package/engine/dist/services/semantic/types/semantic.d.ts.map +1 -0
- package/engine/dist/services/semantic/types/semantic.js +7 -0
- package/engine/dist/services/semantic/types/semantic.js.map +1 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.d.ts +79 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.d.ts.map +1 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.js +415 -0
- package/engine/dist/services/synonyms/auto-synonym-generator.js.map +1 -0
- package/engine/dist/services/system-status.d.ts +68 -0
- package/engine/dist/services/system-status.d.ts.map +1 -0
- package/engine/dist/services/system-status.js +107 -0
- package/engine/dist/services/system-status.js.map +1 -0
- package/engine/dist/services/tags/discovery.d.ts +16 -0
- package/engine/dist/services/tags/discovery.d.ts.map +1 -0
- package/engine/dist/services/tags/discovery.js +206 -0
- package/engine/dist/services/tags/discovery.js.map +1 -0
- package/engine/dist/services/tags/gliner.d.ts +18 -0
- package/engine/dist/services/tags/gliner.d.ts.map +1 -0
- package/engine/dist/services/tags/gliner.js +119 -0
- package/engine/dist/services/tags/gliner.js.map +1 -0
- package/engine/dist/services/tags/infector.d.ts +21 -0
- package/engine/dist/services/tags/infector.d.ts.map +1 -0
- package/engine/dist/services/tags/infector.js +168 -0
- package/engine/dist/services/tags/infector.js.map +1 -0
- package/engine/dist/services/tags/tag-auditor.d.ts +77 -0
- package/engine/dist/services/tags/tag-auditor.d.ts.map +1 -0
- package/engine/dist/services/tags/tag-auditor.js +283 -0
- package/engine/dist/services/tags/tag-auditor.js.map +1 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.d.ts +50 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.d.ts.map +1 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.js +291 -0
- package/engine/dist/services/taxonomy/taxonomy-manager.js.map +1 -0
- package/engine/dist/services/vision/vision_service.d.ts +4 -0
- package/engine/dist/services/vision/vision_service.d.ts.map +1 -0
- package/engine/dist/services/vision/vision_service.js +197 -0
- package/engine/dist/services/vision/vision_service.js.map +1 -0
- package/engine/dist/test-framework/core.d.ts +133 -0
- package/engine/dist/test-framework/core.d.ts.map +1 -0
- package/engine/dist/test-framework/core.js +313 -0
- package/engine/dist/test-framework/core.js.map +1 -0
- package/engine/dist/test-framework/dataset-runner.d.ts +78 -0
- package/engine/dist/test-framework/dataset-runner.d.ts.map +1 -0
- package/engine/dist/test-framework/dataset-runner.js +223 -0
- package/engine/dist/test-framework/dataset-runner.js.map +1 -0
- package/engine/dist/test-framework/diagnostic-tests.d.ts +38 -0
- package/engine/dist/test-framework/diagnostic-tests.d.ts.map +1 -0
- package/engine/dist/test-framework/diagnostic-tests.js +283 -0
- package/engine/dist/test-framework/diagnostic-tests.js.map +1 -0
- package/engine/dist/test-framework/performance-regression-tests.d.ts +30 -0
- package/engine/dist/test-framework/performance-regression-tests.d.ts.map +1 -0
- package/engine/dist/test-framework/performance-regression-tests.js +331 -0
- package/engine/dist/test-framework/performance-regression-tests.js.map +1 -0
- package/engine/dist/types/api.d.ts +53 -0
- package/engine/dist/types/api.d.ts.map +1 -0
- package/engine/dist/types/api.js +2 -0
- package/engine/dist/types/api.js.map +1 -0
- package/engine/dist/types/atomic.d.ts +42 -0
- package/engine/dist/types/atomic.d.ts.map +1 -0
- package/engine/dist/types/atomic.js +10 -0
- package/engine/dist/types/atomic.js.map +1 -0
- package/engine/dist/types/context-protocol.d.ts +137 -0
- package/engine/dist/types/context-protocol.d.ts.map +1 -0
- package/engine/dist/types/context-protocol.js +28 -0
- package/engine/dist/types/context-protocol.js.map +1 -0
- package/engine/dist/types/context.d.ts +2 -0
- package/engine/dist/types/context.d.ts.map +1 -0
- package/engine/dist/types/context.js +2 -0
- package/engine/dist/types/context.js.map +1 -0
- package/engine/dist/types/index.d.ts +20 -0
- package/engine/dist/types/index.d.ts.map +1 -0
- package/engine/dist/types/index.js +18 -0
- package/engine/dist/types/index.js.map +1 -0
- package/engine/dist/types/search.d.ts +31 -0
- package/engine/dist/types/search.d.ts.map +1 -0
- package/engine/dist/types/search.js +2 -0
- package/engine/dist/types/search.js.map +1 -0
- package/engine/dist/types/taxonomy.d.ts +137 -0
- package/engine/dist/types/taxonomy.d.ts.map +1 -0
- package/engine/dist/types/taxonomy.js +138 -0
- package/engine/dist/types/taxonomy.js.map +1 -0
- package/engine/dist/types/taxonomy.simple.d.ts +131 -0
- package/engine/dist/types/taxonomy.simple.d.ts.map +1 -0
- package/engine/dist/types/taxonomy.simple.js +132 -0
- package/engine/dist/types/taxonomy.simple.js.map +1 -0
- package/engine/dist/types/tool-call.d.ts +16 -0
- package/engine/dist/types/tool-call.d.ts.map +1 -0
- package/engine/dist/types/tool-call.js +6 -0
- package/engine/dist/types/tool-call.js.map +1 -0
- package/engine/dist/types/trace.d.ts +25 -0
- package/engine/dist/types/trace.d.ts.map +1 -0
- package/engine/dist/types/trace.js +5 -0
- package/engine/dist/types/trace.js.map +1 -0
- package/engine/dist/utils/adaptive-concurrency.d.ts +81 -0
- package/engine/dist/utils/adaptive-concurrency.d.ts.map +1 -0
- package/engine/dist/utils/adaptive-concurrency.js +266 -0
- package/engine/dist/utils/adaptive-concurrency.js.map +1 -0
- package/engine/dist/utils/date_extractor.d.ts +2 -0
- package/engine/dist/utils/date_extractor.d.ts.map +1 -0
- package/engine/dist/utils/date_extractor.js +32 -0
- package/engine/dist/utils/date_extractor.js.map +1 -0
- package/engine/dist/utils/native-module-manager.d.ts +48 -0
- package/engine/dist/utils/native-module-manager.d.ts.map +1 -0
- package/engine/dist/utils/native-module-manager.js +265 -0
- package/engine/dist/utils/native-module-manager.js.map +1 -0
- package/engine/dist/utils/native-module-profiler.d.ts +66 -0
- package/engine/dist/utils/native-module-profiler.d.ts.map +1 -0
- package/engine/dist/utils/native-module-profiler.js +182 -0
- package/engine/dist/utils/native-module-profiler.js.map +1 -0
- package/engine/dist/utils/path-manager.d.ts +59 -0
- package/engine/dist/utils/path-manager.d.ts.map +1 -0
- package/engine/dist/utils/path-manager.js +154 -0
- package/engine/dist/utils/path-manager.js.map +1 -0
- package/engine/dist/utils/performance-monitor.d.ts +92 -0
- package/engine/dist/utils/performance-monitor.d.ts.map +1 -0
- package/engine/dist/utils/performance-monitor.js +221 -0
- package/engine/dist/utils/performance-monitor.js.map +1 -0
- package/engine/dist/utils/process-manager.d.ts +18 -0
- package/engine/dist/utils/process-manager.d.ts.map +1 -0
- package/engine/dist/utils/process-manager.js +100 -0
- package/engine/dist/utils/process-manager.js.map +1 -0
- package/engine/dist/utils/request-tracer.d.ts +131 -0
- package/engine/dist/utils/request-tracer.d.ts.map +1 -0
- package/engine/dist/utils/request-tracer.js +414 -0
- package/engine/dist/utils/request-tracer.js.map +1 -0
- package/engine/dist/utils/resource-manager.d.ts +108 -0
- package/engine/dist/utils/resource-manager.d.ts.map +1 -0
- package/engine/dist/utils/resource-manager.js +235 -0
- package/engine/dist/utils/resource-manager.js.map +1 -0
- package/engine/dist/utils/safe-dns.d.ts +14 -0
- package/engine/dist/utils/safe-dns.d.ts.map +1 -0
- package/engine/dist/utils/safe-dns.js +105 -0
- package/engine/dist/utils/safe-dns.js.map +1 -0
- package/engine/dist/utils/structured-logger.d.ts +124 -0
- package/engine/dist/utils/structured-logger.d.ts.map +1 -0
- package/engine/dist/utils/structured-logger.js +332 -0
- package/engine/dist/utils/structured-logger.js.map +1 -0
- package/engine/dist/utils/tag-cleanup.d.ts +11 -0
- package/engine/dist/utils/tag-cleanup.d.ts.map +1 -0
- package/engine/dist/utils/tag-cleanup.js +111 -0
- package/engine/dist/utils/tag-cleanup.js.map +1 -0
- package/engine/dist/utils/tag-filter.d.ts +19 -0
- package/engine/dist/utils/tag-filter.d.ts.map +1 -0
- package/engine/dist/utils/tag-filter.js +147 -0
- package/engine/dist/utils/tag-filter.js.map +1 -0
- package/engine/dist/utils/tag-modulation.d.ts +80 -0
- package/engine/dist/utils/tag-modulation.d.ts.map +1 -0
- package/engine/dist/utils/tag-modulation.js +284 -0
- package/engine/dist/utils/tag-modulation.js.map +1 -0
- package/engine/dist/utils/timer.d.ts +40 -0
- package/engine/dist/utils/timer.d.ts.map +1 -0
- package/engine/dist/utils/timer.js +76 -0
- package/engine/dist/utils/timer.js.map +1 -0
- package/engine/dist/utils/token-utils.d.ts +19 -0
- package/engine/dist/utils/token-utils.d.ts.map +1 -0
- package/engine/dist/utils/token-utils.js +71 -0
- package/engine/dist/utils/token-utils.js.map +1 -0
- package/engine/dist/utils/wasm-module-loader.d.ts +50 -0
- package/engine/dist/utils/wasm-module-loader.d.ts.map +1 -0
- package/engine/dist/utils/wasm-module-loader.js +136 -0
- package/engine/dist/utils/wasm-module-loader.js.map +1 -0
- package/engine/package.json +105 -0
- package/package.json +106 -0
|
@@ -0,0 +1,332 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Structured Logger for Anchor Engine
|
|
3
|
+
*
|
|
4
|
+
* Implements standardized, structured logging with metrics collection
|
|
5
|
+
*/
|
|
6
|
+
import winston from 'winston';
|
|
7
|
+
import DailyRotateFile from 'winston-daily-rotate-file';
|
|
8
|
+
import path from 'path';
|
|
9
|
+
import fs from 'fs';
|
|
10
|
+
import { format } from 'winston';
|
|
11
|
+
import { fileURLToPath } from 'url';
|
|
12
|
+
// Get absolute path to project root (anchor-os directory)
|
|
13
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
14
|
+
const __dirname = path.dirname(__filename);
|
|
15
|
+
const PROJECT_ROOT = path.resolve(__dirname, '../../..');
|
|
16
|
+
// Define log levels with numerical values
|
|
17
|
+
const logLevels = {
|
|
18
|
+
error: 0,
|
|
19
|
+
warn: 1,
|
|
20
|
+
info: 2,
|
|
21
|
+
verbose: 3,
|
|
22
|
+
debug: 4,
|
|
23
|
+
silly: 5
|
|
24
|
+
};
|
|
25
|
+
// Create logs directory at project root
|
|
26
|
+
const LOGS_DIR = path.join(PROJECT_ROOT, 'logs');
|
|
27
|
+
if (!fs.existsSync(LOGS_DIR)) {
|
|
28
|
+
fs.mkdirSync(LOGS_DIR, { recursive: true });
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Truncate log files to last N lines to prevent unbounded growth
|
|
32
|
+
* Runs at startup to clean up existing logs
|
|
33
|
+
*/
|
|
34
|
+
function truncateLogFiles(maxLines = 10000) {
|
|
35
|
+
try {
|
|
36
|
+
const files = fs.readdirSync(LOGS_DIR);
|
|
37
|
+
let totalTruncated = 0;
|
|
38
|
+
for (const file of files) {
|
|
39
|
+
if (!file.endsWith('.log') && !file.includes('.log.'))
|
|
40
|
+
continue;
|
|
41
|
+
const filePath = path.join(LOGS_DIR, file);
|
|
42
|
+
const stats = fs.statSync(filePath);
|
|
43
|
+
// Skip if file is small (< 1MB)
|
|
44
|
+
if (stats.size < 1024 * 1024)
|
|
45
|
+
continue;
|
|
46
|
+
// Read file and truncate to last N lines
|
|
47
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
48
|
+
const lines = content.split('\n');
|
|
49
|
+
if (lines.length > maxLines) {
|
|
50
|
+
const truncated = lines.slice(-maxLines).join('\n');
|
|
51
|
+
fs.writeFileSync(filePath, truncated, 'utf-8');
|
|
52
|
+
totalTruncated++;
|
|
53
|
+
console.log(`[Logger] Truncated ${file} from ${lines.length} to ${maxLines} lines`);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
if (totalTruncated > 0) {
|
|
57
|
+
console.log(`[Logger] Truncated ${totalTruncated} log files to ${maxLines} lines max`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
catch (e) {
|
|
61
|
+
console.error('[Logger] Failed to truncate logs:', e);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
// Truncate logs at startup
|
|
65
|
+
truncateLogFiles(10000);
|
|
66
|
+
// Custom format for structured logging
|
|
67
|
+
const structuredFormat = winston.format.combine(winston.format.timestamp(), winston.format.errors({ stack: true }), winston.format.splat(), winston.format.json());
|
|
68
|
+
// Create logger instance
|
|
69
|
+
const logger = winston.createLogger({
|
|
70
|
+
levels: logLevels,
|
|
71
|
+
level: 'silly', // Capture all log levels including debug
|
|
72
|
+
format: structuredFormat,
|
|
73
|
+
transports: [
|
|
74
|
+
// Main anchor_engine.log file with size-based rotation (10KB)
|
|
75
|
+
new DailyRotateFile({
|
|
76
|
+
filename: path.join(LOGS_DIR, 'anchor_engine.log'),
|
|
77
|
+
datePattern: 'YYYY-MM-DD',
|
|
78
|
+
zippedArchive: false,
|
|
79
|
+
maxSize: '10k',
|
|
80
|
+
maxFiles: '7d',
|
|
81
|
+
format: format.combine(format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), format.errors({ stack: true }), format.splat(), format.printf(({ timestamp, level, message, ...metadata }) => {
|
|
82
|
+
const metaStr = Object.keys(metadata).length > 0 ? ` ${JSON.stringify(metadata)}` : '';
|
|
83
|
+
return `[${timestamp}] [${level.toUpperCase()}] ${message}${metaStr}`;
|
|
84
|
+
}))
|
|
85
|
+
}),
|
|
86
|
+
// Separate error file
|
|
87
|
+
new DailyRotateFile({
|
|
88
|
+
level: 'error',
|
|
89
|
+
filename: path.join(LOGS_DIR, 'anchor_engine_error-%DATE%.log'),
|
|
90
|
+
datePattern: 'YYYY-MM-DD',
|
|
91
|
+
zippedArchive: true,
|
|
92
|
+
maxSize: '10k',
|
|
93
|
+
maxFiles: '14d',
|
|
94
|
+
format: format.combine(format.timestamp(), format.errors({ stack: true }), format.splat(), format.json())
|
|
95
|
+
}),
|
|
96
|
+
// Console transport for development
|
|
97
|
+
new winston.transports.Console({
|
|
98
|
+
format: format.combine(format.colorize(), format.printf(({ level, message, timestamp, ...metadata }) => {
|
|
99
|
+
let msg = `${timestamp} [${level}] ${message}`;
|
|
100
|
+
if (Object.keys(metadata).length > 0) {
|
|
101
|
+
msg += ` ${JSON.stringify(metadata)}`;
|
|
102
|
+
}
|
|
103
|
+
return msg;
|
|
104
|
+
}))
|
|
105
|
+
})
|
|
106
|
+
]
|
|
107
|
+
});
|
|
108
|
+
// Performance metrics tracker
|
|
109
|
+
class MetricsTracker {
|
|
110
|
+
metrics;
|
|
111
|
+
startTime;
|
|
112
|
+
constructor() {
|
|
113
|
+
this.metrics = new Map();
|
|
114
|
+
this.startTime = Date.now();
|
|
115
|
+
}
|
|
116
|
+
startTimer(operation) {
|
|
117
|
+
const startTime = Date.now();
|
|
118
|
+
return () => {
|
|
119
|
+
const duration = Date.now() - startTime;
|
|
120
|
+
this.recordMetric(operation, duration);
|
|
121
|
+
return duration;
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
recordMetric(operation, duration) {
|
|
125
|
+
if (!this.metrics.has(operation)) {
|
|
126
|
+
this.metrics.set(operation, { count: 0, total: 0, min: Infinity, max: -Infinity, last: 0 });
|
|
127
|
+
}
|
|
128
|
+
const metric = this.metrics.get(operation);
|
|
129
|
+
metric.count++;
|
|
130
|
+
metric.total += duration;
|
|
131
|
+
metric.min = Math.min(metric.min, duration);
|
|
132
|
+
metric.max = Math.max(metric.max, duration);
|
|
133
|
+
metric.last = duration;
|
|
134
|
+
}
|
|
135
|
+
getMetrics(operation) {
|
|
136
|
+
return this.metrics.get(operation);
|
|
137
|
+
}
|
|
138
|
+
getAllMetrics() {
|
|
139
|
+
const result = {};
|
|
140
|
+
const now = Date.now();
|
|
141
|
+
for (const [name, data] of this.metrics.entries()) {
|
|
142
|
+
result[name] = {
|
|
143
|
+
count: data.count,
|
|
144
|
+
total: data.total,
|
|
145
|
+
average: data.count > 0 ? data.total / data.count : 0,
|
|
146
|
+
min: data.min === Infinity ? 0 : data.min,
|
|
147
|
+
max: data.max === -Infinity ? 0 : data.max,
|
|
148
|
+
last: data.last,
|
|
149
|
+
uptime: now - this.startTime
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
return result;
|
|
153
|
+
}
|
|
154
|
+
reset() {
|
|
155
|
+
this.metrics.clear();
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Prune old metrics to free memory (called during idle cleanup)
|
|
159
|
+
* Removes metrics older than TTL and enforces maximum size limit
|
|
160
|
+
*/
|
|
161
|
+
pruneOldMetrics() {
|
|
162
|
+
const METRIC_TTL_MS = 10 * 60 * 1000; // 10 minutes TTL
|
|
163
|
+
const MAX_METRICS = 500; // Maximum number of metrics to keep
|
|
164
|
+
const now = Date.now();
|
|
165
|
+
// Remove metrics that haven't been updated in TTL period
|
|
166
|
+
let prunedCount = 0;
|
|
167
|
+
for (const [key, metric] of this.metrics.entries()) {
|
|
168
|
+
// If last operation was more than TTL ago, remove it
|
|
169
|
+
if (metric.last && (now - metric.last) > METRIC_TTL_MS) {
|
|
170
|
+
this.metrics.delete(key);
|
|
171
|
+
prunedCount++;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
// Enforce hard limit if still too many metrics
|
|
175
|
+
if (this.metrics.size > MAX_METRICS) {
|
|
176
|
+
const keys = Array.from(this.metrics.keys());
|
|
177
|
+
const toDelete = keys.slice(0, keys.length - MAX_METRICS);
|
|
178
|
+
for (const key of toDelete) {
|
|
179
|
+
this.metrics.delete(key);
|
|
180
|
+
prunedCount++;
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
if (prunedCount > 0) {
|
|
184
|
+
console.log(`[StructuredLogger] Pruned ${prunedCount} old metrics (${this.metrics.size} remaining)`);
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
// Initialize metrics tracker
|
|
189
|
+
const metricsTracker = new MetricsTracker();
|
|
190
|
+
// Enhanced logging functions with metrics
|
|
191
|
+
export const logWithContext = {
|
|
192
|
+
/**
|
|
193
|
+
* Log an info message with context and metrics
|
|
194
|
+
*/
|
|
195
|
+
info: (message, context) => {
|
|
196
|
+
if (context && context.metrics) {
|
|
197
|
+
for (const [name, value] of Object.entries(context.metrics)) {
|
|
198
|
+
metricsTracker.recordMetric(name, value);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
logger.info(message, {
|
|
202
|
+
context,
|
|
203
|
+
pid: process.pid,
|
|
204
|
+
module: 'structured-logger'
|
|
205
|
+
});
|
|
206
|
+
},
|
|
207
|
+
/**
|
|
208
|
+
* Log a warning with context
|
|
209
|
+
*/
|
|
210
|
+
warn: (message, context) => {
|
|
211
|
+
logger.warn(message, {
|
|
212
|
+
context,
|
|
213
|
+
pid: process.pid,
|
|
214
|
+
module: 'structured-logger'
|
|
215
|
+
});
|
|
216
|
+
},
|
|
217
|
+
/**
|
|
218
|
+
* Log an error with context
|
|
219
|
+
*/
|
|
220
|
+
error: (message, error, context) => {
|
|
221
|
+
logger.error(message, {
|
|
222
|
+
error: error instanceof Error ? { message: error.message, stack: error.stack } : error,
|
|
223
|
+
context,
|
|
224
|
+
pid: process.pid,
|
|
225
|
+
module: 'structured-logger'
|
|
226
|
+
});
|
|
227
|
+
},
|
|
228
|
+
/**
|
|
229
|
+
* Log a debug message with context
|
|
230
|
+
*/
|
|
231
|
+
debug: (message, context) => {
|
|
232
|
+
logger.debug(message, {
|
|
233
|
+
context,
|
|
234
|
+
pid: process.pid,
|
|
235
|
+
module: 'structured-logger'
|
|
236
|
+
});
|
|
237
|
+
},
|
|
238
|
+
/**
|
|
239
|
+
* Log a silly/verbose message with context
|
|
240
|
+
*/
|
|
241
|
+
silly: (message, context) => {
|
|
242
|
+
logger.silly(message, {
|
|
243
|
+
context,
|
|
244
|
+
pid: process.pid,
|
|
245
|
+
module: 'structured-logger'
|
|
246
|
+
});
|
|
247
|
+
},
|
|
248
|
+
/**
|
|
249
|
+
* Log a performance metric
|
|
250
|
+
*/
|
|
251
|
+
performance: (operation, duration, context) => {
|
|
252
|
+
metricsTracker.recordMetric(operation, duration);
|
|
253
|
+
logger.info('PERFORMANCE_METRIC', {
|
|
254
|
+
operation,
|
|
255
|
+
duration_ms: duration,
|
|
256
|
+
average: metricsTracker.getMetrics(operation)?.total / metricsTracker.getMetrics(operation)?.count,
|
|
257
|
+
context,
|
|
258
|
+
pid: process.pid,
|
|
259
|
+
module: 'structured-logger'
|
|
260
|
+
});
|
|
261
|
+
},
|
|
262
|
+
/**
|
|
263
|
+
* Start a timed operation
|
|
264
|
+
*/
|
|
265
|
+
startTimer: (operation) => {
|
|
266
|
+
return metricsTracker.startTimer(operation);
|
|
267
|
+
},
|
|
268
|
+
/**
|
|
269
|
+
* Get current metrics
|
|
270
|
+
*/
|
|
271
|
+
getMetrics: () => {
|
|
272
|
+
return metricsTracker.getAllMetrics();
|
|
273
|
+
},
|
|
274
|
+
/**
|
|
275
|
+
* Log ingestion event
|
|
276
|
+
*/
|
|
277
|
+
ingestion: (status, details) => {
|
|
278
|
+
metricsTracker.recordMetric('ingestion_attempts', 1);
|
|
279
|
+
if (status === 'success') {
|
|
280
|
+
metricsTracker.recordMetric('ingestion_successes', 1);
|
|
281
|
+
}
|
|
282
|
+
else if (status === 'failed') {
|
|
283
|
+
metricsTracker.recordMetric('ingestion_failures', 1);
|
|
284
|
+
}
|
|
285
|
+
logger.info('INGESTION_EVENT', {
|
|
286
|
+
event: 'ingestion',
|
|
287
|
+
status,
|
|
288
|
+
details,
|
|
289
|
+
pid: process.pid,
|
|
290
|
+
module: 'structured-logger'
|
|
291
|
+
});
|
|
292
|
+
},
|
|
293
|
+
/**
|
|
294
|
+
* Log search event
|
|
295
|
+
*/
|
|
296
|
+
search: (query, resultCount, duration, context) => {
|
|
297
|
+
metricsTracker.recordMetric('search_queries', 1);
|
|
298
|
+
metricsTracker.recordMetric('search_results', resultCount);
|
|
299
|
+
metricsTracker.recordMetric('search_duration', duration);
|
|
300
|
+
logger.info('SEARCH_EVENT', {
|
|
301
|
+
event: 'search',
|
|
302
|
+
query: query.substring(0, 100), // Truncate long queries
|
|
303
|
+
resultCount,
|
|
304
|
+
duration_ms: duration,
|
|
305
|
+
context,
|
|
306
|
+
pid: process.pid,
|
|
307
|
+
module: 'structured-logger'
|
|
308
|
+
});
|
|
309
|
+
},
|
|
310
|
+
/**
|
|
311
|
+
* Log system health event
|
|
312
|
+
*/
|
|
313
|
+
health: (status, details) => {
|
|
314
|
+
logger.info('HEALTH_EVENT', {
|
|
315
|
+
event: 'health-check',
|
|
316
|
+
status,
|
|
317
|
+
details,
|
|
318
|
+
pid: process.pid,
|
|
319
|
+
module: 'structured-logger'
|
|
320
|
+
});
|
|
321
|
+
}
|
|
322
|
+
};
|
|
323
|
+
// Export the base logger as well
|
|
324
|
+
export { logger, metricsTracker };
|
|
325
|
+
// Export a function to get formatted metrics for monitoring endpoints
|
|
326
|
+
export function getFormattedMetrics() {
|
|
327
|
+
const metrics = metricsTracker.getAllMetrics();
|
|
328
|
+
return JSON.stringify(metrics, null, 2);
|
|
329
|
+
}
|
|
330
|
+
// Export alias for backward compatibility
|
|
331
|
+
export const StructuredLogger = logWithContext;
|
|
332
|
+
//# sourceMappingURL=structured-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"structured-logger.js","sourceRoot":"","sources":["../../src/utils/structured-logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tag Cleanup Script - Run on startup to prune blacklisted tags
|
|
3
|
+
*
|
|
4
|
+
* Removes all blacklisted tags from existing atoms in the database.
|
|
5
|
+
* This ensures the tag space stays clean even for previously ingested content.
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Main cleanup function - run on startup
|
|
9
|
+
*/
|
|
10
|
+
export declare function cleanupBlacklistedTags(): Promise<void>;
|
|
11
|
+
//# sourceMappingURL=tag-cleanup.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tag-cleanup.d.ts","sourceRoot":"","sources":["../../src/utils/tag-cleanup.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AA0FH;;GAEG;AACH,wBAAsB,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC,CAoC5D"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tag Cleanup Script - Run on startup to prune blacklisted tags
|
|
3
|
+
*
|
|
4
|
+
* Removes all blacklisted tags from existing atoms in the database.
|
|
5
|
+
* This ensures the tag space stays clean even for previously ingested content.
|
|
6
|
+
*/
|
|
7
|
+
import { db } from '../core/db.js';
|
|
8
|
+
import { filterTags } from '../utils/tag-filter.js';
|
|
9
|
+
const BATCH_SIZE = 1000;
|
|
10
|
+
/**
|
|
11
|
+
* Get all distinct tags from the database
|
|
12
|
+
*/
|
|
13
|
+
async function getAllTags() {
|
|
14
|
+
const result = await db.run('SELECT DISTINCT tag FROM tags');
|
|
15
|
+
return result.rows?.map((row) => row.tag) || [];
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Find blacklisted tags
|
|
19
|
+
*/
|
|
20
|
+
async function findBlacklistedTags() {
|
|
21
|
+
const allTags = await getAllTags();
|
|
22
|
+
const blacklisted = [];
|
|
23
|
+
for (const tag of allTags) {
|
|
24
|
+
const filtered = filterTags([tag]);
|
|
25
|
+
if (filtered.length === 0) {
|
|
26
|
+
blacklisted.push(tag);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return blacklisted;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Remove a tag from all atoms
|
|
33
|
+
*/
|
|
34
|
+
async function removeTag(tag) {
|
|
35
|
+
const result = await db.run('DELETE FROM tags WHERE tag = $1', [tag]);
|
|
36
|
+
return result.changes || 0;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Cleanup atoms with blacklisted tags
|
|
40
|
+
* Updates the tags TEXT[] array in the atoms table
|
|
41
|
+
*/
|
|
42
|
+
async function cleanupAtomTags() {
|
|
43
|
+
let totalCleaned = 0;
|
|
44
|
+
try {
|
|
45
|
+
// Get atoms that have tags (tags is TEXT[] not JSONB)
|
|
46
|
+
const result = await db.run(`
|
|
47
|
+
SELECT id, tags
|
|
48
|
+
FROM atoms
|
|
49
|
+
WHERE tags IS NOT NULL
|
|
50
|
+
AND array_length(tags, 1) > 0
|
|
51
|
+
`);
|
|
52
|
+
if (!result.rows || result.rows.length === 0) {
|
|
53
|
+
return 0;
|
|
54
|
+
}
|
|
55
|
+
console.log(`[TagCleanup] Checking ${result.rows.length} atoms for blacklisted tags...`);
|
|
56
|
+
for (const row of result.rows) {
|
|
57
|
+
const atomId = row.id;
|
|
58
|
+
const currentTags = row.tags || [];
|
|
59
|
+
// Filter out blacklisted tags
|
|
60
|
+
const filteredTags = filterTags(currentTags);
|
|
61
|
+
// If tags were removed, update the atom
|
|
62
|
+
if (filteredTags.length < currentTags.length) {
|
|
63
|
+
await db.run('UPDATE atoms SET tags = $1 WHERE id = $2', [filteredTags, atomId]);
|
|
64
|
+
totalCleaned++;
|
|
65
|
+
if (totalCleaned % 100 === 0) {
|
|
66
|
+
console.log(`[TagCleanup] Cleaned ${totalCleaned} atoms...`);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return totalCleaned;
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
console.error('[TagCleanup] Error cleaning atom tags:', error);
|
|
74
|
+
return 0;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Main cleanup function - run on startup
|
|
79
|
+
*/
|
|
80
|
+
export async function cleanupBlacklistedTags() {
|
|
81
|
+
const startTime = Date.now();
|
|
82
|
+
console.log('[TagCleanup] Starting tag cleanup on startup...');
|
|
83
|
+
try {
|
|
84
|
+
// Step 1: Remove blacklisted tags from tags table
|
|
85
|
+
const blacklistedTags = await findBlacklistedTags();
|
|
86
|
+
if (blacklistedTags.length > 0) {
|
|
87
|
+
console.log(`[TagCleanup] Found ${blacklistedTags.length} blacklisted tags to remove:`);
|
|
88
|
+
console.log(`[TagCleanup] ${blacklistedTags.slice(0, 20).join(', ')}${blacklistedTags.length > 20 ? ` ... and ${blacklistedTags.length - 20} more` : ''}`);
|
|
89
|
+
let totalDeleted = 0;
|
|
90
|
+
for (const tag of blacklistedTags) {
|
|
91
|
+
const deleted = await removeTag(tag);
|
|
92
|
+
totalDeleted += deleted;
|
|
93
|
+
}
|
|
94
|
+
console.log(`[TagCleanup] Removed ${totalDeleted} tag entries from ${blacklistedTags.length} blacklisted tags`);
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
console.log('[TagCleanup] No blacklisted tags found in tags table');
|
|
98
|
+
}
|
|
99
|
+
// Step 2: Cleanup tags in atoms table
|
|
100
|
+
const atomsCleaned = await cleanupAtomTags();
|
|
101
|
+
if (atomsCleaned > 0) {
|
|
102
|
+
console.log(`[TagCleanup] Updated ${atomsCleaned} atoms with filtered tags`);
|
|
103
|
+
}
|
|
104
|
+
const duration = ((Date.now() - startTime) / 1000).toFixed(2);
|
|
105
|
+
console.log(`[TagCleanup] ✅ Cleanup complete in ${duration}s`);
|
|
106
|
+
}
|
|
107
|
+
catch (error) {
|
|
108
|
+
console.error('[TagCleanup] ❌ Cleanup failed:', error);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
//# sourceMappingURL=tag-cleanup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tag-cleanup.js","sourceRoot":"","sources":["../../src/utils/tag-cleanup.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tag Filter - Blacklist for noise/system tags
|
|
3
|
+
*
|
|
4
|
+
* Prevents low-value tags from being stored in the database.
|
|
5
|
+
* Applied at ingestion time to keep the tag space clean.
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Check if a tag should be filtered out
|
|
9
|
+
*/
|
|
10
|
+
export declare function isTagBlacklisted(tag: string): boolean;
|
|
11
|
+
/**
|
|
12
|
+
* Filter an array of tags, removing blacklisted ones
|
|
13
|
+
*/
|
|
14
|
+
export declare function filterTags(tags: string[]): string[];
|
|
15
|
+
/**
|
|
16
|
+
* Filter tags and log what was removed (for debugging)
|
|
17
|
+
*/
|
|
18
|
+
export declare function filterTagsWithLogging(tags: string[], context?: string): string[];
|
|
19
|
+
//# sourceMappingURL=tag-filter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tag-filter.d.ts","sourceRoot":"","sources":["../../src/utils/tag-filter.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAqGH;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAkBrD;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAOnD;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAmBhF"}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tag Filter - Blacklist for noise/system tags
|
|
3
|
+
*
|
|
4
|
+
* Prevents low-value tags from being stored in the database.
|
|
5
|
+
* Applied at ingestion time to keep the tag space clean.
|
|
6
|
+
*/
|
|
7
|
+
// Blacklist patterns - tags matching these will be rejected
|
|
8
|
+
const TAG_BLACKLIST_PATTERNS = [
|
|
9
|
+
// Color codes (hex)
|
|
10
|
+
/^#[0-9a-fA-F]{3,8}$/,
|
|
11
|
+
// Pure numbers or too short
|
|
12
|
+
/^#\d{1,3}$/,
|
|
13
|
+
/^#_\w*$/,
|
|
14
|
+
/^#__[\w\d_]+$/, // __lottie_element_, etc.
|
|
15
|
+
// HTML/DOM artifacts
|
|
16
|
+
/^#btn\b/,
|
|
17
|
+
/^#class\b/,
|
|
18
|
+
/^#div\b/,
|
|
19
|
+
/^#id\b/,
|
|
20
|
+
/^#span\b/,
|
|
21
|
+
/^#href\b/,
|
|
22
|
+
/^#src\b/,
|
|
23
|
+
// Code artifacts
|
|
24
|
+
/^#fn\b/,
|
|
25
|
+
/^#elif\b/,
|
|
26
|
+
/^#else\b/,
|
|
27
|
+
/^#endif\b/,
|
|
28
|
+
/^#ifdef\b/,
|
|
29
|
+
/^#ifndef\b/,
|
|
30
|
+
/^#include\b/,
|
|
31
|
+
/^#define\b/,
|
|
32
|
+
/^#pragma\b/,
|
|
33
|
+
// Scraping artifacts (Wikipedia, etc.)
|
|
34
|
+
/^#cite_note/,
|
|
35
|
+
/^#cite_ref/,
|
|
36
|
+
/^#amp_tf/,
|
|
37
|
+
/^#details_of_atom/,
|
|
38
|
+
/^#entry_lin/,
|
|
39
|
+
/^#entry_links/,
|
|
40
|
+
/^#entry_metadata/,
|
|
41
|
+
/^#feed_metadata/,
|
|
42
|
+
/^#opensearch_extension/,
|
|
43
|
+
/^#extension_elements/,
|
|
44
|
+
/^#simple_examples/,
|
|
45
|
+
/^#query_interface/,
|
|
46
|
+
/^#api_response/,
|
|
47
|
+
/^#response_example/,
|
|
48
|
+
/^#examples?$/,
|
|
49
|
+
/^#overview$/,
|
|
50
|
+
/^#preface$/,
|
|
51
|
+
/^#appendix/,
|
|
52
|
+
/^#appendices$/,
|
|
53
|
+
/^#bib\b/,
|
|
54
|
+
/^#ref\b/,
|
|
55
|
+
/^#fn\b/,
|
|
56
|
+
// Error/artifact tags
|
|
57
|
+
/^#incorrect_/,
|
|
58
|
+
/^#error_/,
|
|
59
|
+
/^#null\b/,
|
|
60
|
+
/^#undefined\b/,
|
|
61
|
+
/^#nan\b/,
|
|
62
|
+
// Too generic / low signal
|
|
63
|
+
/^#slow_pickup$/,
|
|
64
|
+
/^#late_night$/,
|
|
65
|
+
/^#early_morning$/,
|
|
66
|
+
/^#monday\b/,
|
|
67
|
+
/^#tuesday\b/,
|
|
68
|
+
/^#wednesday\b/,
|
|
69
|
+
/^#thursday\b/,
|
|
70
|
+
/^#friday\b/,
|
|
71
|
+
/^#saturday\b/,
|
|
72
|
+
/^#sunday\b/,
|
|
73
|
+
/^#manual\b/,
|
|
74
|
+
/^#manually_/,
|
|
75
|
+
/^#test_/,
|
|
76
|
+
/^#tmp\b/,
|
|
77
|
+
/^#temp\b/,
|
|
78
|
+
/^#untagged$/,
|
|
79
|
+
// Old project names / deprecated
|
|
80
|
+
/^#agentgpt$/,
|
|
81
|
+
/^#babyagi$/,
|
|
82
|
+
/^#autogen$/,
|
|
83
|
+
/^#chimaera$/,
|
|
84
|
+
// System tags (not user-meaningful)
|
|
85
|
+
/^#manually_quarantined$/,
|
|
86
|
+
/^#quarantined$/,
|
|
87
|
+
/^#system$/,
|
|
88
|
+
/^#internal$/,
|
|
89
|
+
/^#external$/,
|
|
90
|
+
];
|
|
91
|
+
// Also maintain a simple blacklist for exact matches
|
|
92
|
+
const TAG_BLACKLIST_EXACT = new Set([
|
|
93
|
+
'#_', '#0', '#1', '#2', '#3', '#4', '#5', '#6', '#7', '#8', '#9',
|
|
94
|
+
'#00', '#000', '#0000', '#00000', '#000000',
|
|
95
|
+
]);
|
|
96
|
+
/**
|
|
97
|
+
* Check if a tag should be filtered out
|
|
98
|
+
*/
|
|
99
|
+
export function isTagBlacklisted(tag) {
|
|
100
|
+
if (!tag || typeof tag !== 'string')
|
|
101
|
+
return true;
|
|
102
|
+
const normalizedTag = tag.trim();
|
|
103
|
+
// Check exact blacklist
|
|
104
|
+
if (TAG_BLACKLIST_EXACT.has(normalizedTag)) {
|
|
105
|
+
return true;
|
|
106
|
+
}
|
|
107
|
+
// Check pattern blacklist
|
|
108
|
+
for (const pattern of TAG_BLACKLIST_PATTERNS) {
|
|
109
|
+
if (pattern.test(normalizedTag)) {
|
|
110
|
+
return true;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return false;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Filter an array of tags, removing blacklisted ones
|
|
117
|
+
*/
|
|
118
|
+
export function filterTags(tags) {
|
|
119
|
+
if (!tags || !Array.isArray(tags))
|
|
120
|
+
return [];
|
|
121
|
+
return tags
|
|
122
|
+
.filter(tag => !isTagBlacklisted(tag))
|
|
123
|
+
.map(tag => tag.trim())
|
|
124
|
+
.filter(tag => tag.length > 0);
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Filter tags and log what was removed (for debugging)
|
|
128
|
+
*/
|
|
129
|
+
export function filterTagsWithLogging(tags, context) {
|
|
130
|
+
if (!tags || !Array.isArray(tags))
|
|
131
|
+
return [];
|
|
132
|
+
const filtered = tags.filter(tag => {
|
|
133
|
+
if (isTagBlacklisted(tag)) {
|
|
134
|
+
if (context) {
|
|
135
|
+
console.debug(`[TagFilter] ${context}: Filtered out "${tag}"`);
|
|
136
|
+
}
|
|
137
|
+
return false;
|
|
138
|
+
}
|
|
139
|
+
return true;
|
|
140
|
+
});
|
|
141
|
+
const removedCount = tags.length - filtered.length;
|
|
142
|
+
if (removedCount > 0 && context) {
|
|
143
|
+
console.debug(`[TagFilter] ${context}: Removed ${removedCount}/${tags.length} blacklisted tags`);
|
|
144
|
+
}
|
|
145
|
+
return filtered.map(tag => tag.trim());
|
|
146
|
+
}
|
|
147
|
+
//# sourceMappingURL=tag-filter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tag-filter.js","sourceRoot":"","sources":["../../src/utils/tag-filter.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,4DAA4D;AAC5D,MAAM,sBAAsB,GAAG;IAC7B,oBAAoB;IACpB,qBAAqB;IAErB,4BAA4B;IAC5B,YAAY;IACZ,SAAS;IACT,eAAe,EAAG,0BAA0B;IAE5C,qBAAqB;IACrB,SAAS;IACT,WAAW;IACX,SAAS;IACT,QAAQ;IACR,UAAU;IACV,UAAU;IACV,SAAS;IAET,iBAAiB;IACjB,QAAQ;IACR,UAAU;IACV,UAAU;IACV,WAAW;IACX,WAAW;IACX,YAAY;IACZ,aAAa;IACb,YAAY;IACZ,YAAY;IAEZ,uCAAuC;IACvC,aAAa;IACb,YAAY;IACZ,UAAU;IACV,mBAAmB;IACnB,aAAa;IACb,eAAe;IACf,kBAAkB;IAClB,iBAAiB;IACjB,wBAAwB;IACxB,sBAAsB;IACtB,mBAAmB;IACnB,mBAAmB;IACnB,gBAAgB;IAChB,oBAAoB;IACpB,cAAc;IACd,aAAa;IACb,YAAY;IACZ,YAAY;IACZ,eAAe;IACf,SAAS;IACT,SAAS;IACT,QAAQ;IAER,sBAAsB;IACtB,cAAc;IACd,UAAU;IACV,UAAU;IACV,eAAe;IACf,SAAS;IAET,2BAA2B;IAC3B,gBAAgB;IAChB,eAAe;IACf,kBAAkB;IAClB,YAAY;IACZ,aAAa;IACb,eAAe;IACf,cAAc;IACd,YAAY;IACZ,cAAc;IACd,YAAY;IACZ,YAAY;IACZ,aAAa;IACb,SAAS;IACT,SAAS;IACT,UAAU;IACV,aAAa;IAEb,iCAAiC;IACjC,aAAa;IACb,YAAY;IACZ,YAAY;IACZ,aAAa;IAEb,oCAAoC;IACpC,yBAAyB;IACzB,gBAAgB;IAChB,WAAW;IACX,aAAa;IACb,aAAa;CACd,CAAC;AAEF,qDAAqD;AACrD,MAAM,mBAAmB,GAAG,IAAI,GAAG,CAAC;IAClC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI;IAChE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS;CAC5C,CAAC,CAAC;AAEH;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,GAAW;IAC1C,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC;IAEjD,MAAM,aAAa,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;IAEjC,wBAAwB;IACxB,IAAI,mBAAmB,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;QAC3C,OAAO,IAAI,CAAC;IACd,CAAC;IAED,0BAA0B;IAC1B,KAAK,MAAM,OAAO,IAAI,sBAAsB,EAAE,CAAC;QAC7C,IAAI,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;YAChC,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,UAAU,CAAC,IAAc;IACvC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;QAAE,OAAO,EAAE,CAAC;IAE7C,OAAO,IAAI;SACR,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;SACrC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;SACtB,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AACnC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,qBAAqB,CAAC,IAAc,EAAE,OAAgB;IACpE,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;QAAE,OAAO,EAAE,CAAC;IAE7C,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;QACjC,IAAI,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,CAAC,KAAK,CAAC,eAAe,OAAO,mBAAmB,GAAG,GAAG,CAAC,CAAC;YACjE,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC;IACnD,IAAI,YAAY,GAAG,CAAC,IAAI,OAAO,EAAE,CAAC;QAChC,OAAO,CAAC,KAAK,CAAC,eAAe,OAAO,aAAa,YAAY,IAAI,IAAI,CAAC,MAAM,mBAAmB,CAAC,CAAC;IACnG,CAAC;IAED,OAAO,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;AACzC,CAAC"}
|