@codemieai/code 0.0.16 → 0.0.17
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/README.md +62 -5
- package/bin/agent-executor.js +7 -28
- package/bin/codemie-claude.js +18 -0
- package/bin/codemie-codex.js +18 -0
- package/bin/codemie-deepagents.js +18 -0
- package/bin/codemie-gemini.js +18 -0
- package/dist/agents/codemie-code/agent.d.ts.map +1 -1
- package/dist/agents/codemie-code/agent.js +3 -32
- package/dist/agents/codemie-code/agent.js.map +1 -1
- package/dist/agents/codemie-code/tools/planning.d.ts +2 -2
- package/dist/agents/core/AgentCLI.d.ts.map +1 -1
- package/dist/agents/core/AgentCLI.js +25 -59
- package/dist/agents/core/AgentCLI.js.map +1 -1
- package/dist/agents/core/BaseAgentAdapter.d.ts +9 -1
- package/dist/agents/core/BaseAgentAdapter.d.ts.map +1 -1
- package/dist/agents/core/BaseAgentAdapter.js +103 -10
- package/dist/agents/core/BaseAgentAdapter.js.map +1 -1
- package/dist/agents/core/BaseMetricsAdapter.d.ts +64 -0
- package/dist/agents/core/BaseMetricsAdapter.d.ts.map +1 -0
- package/dist/agents/core/BaseMetricsAdapter.js +74 -0
- package/dist/agents/core/BaseMetricsAdapter.js.map +1 -0
- package/dist/agents/core/types.d.ts +1 -0
- package/dist/agents/core/types.d.ts.map +1 -1
- package/dist/agents/plugins/claude.metrics.d.ts +112 -0
- package/dist/agents/plugins/claude.metrics.d.ts.map +1 -0
- package/dist/agents/plugins/claude.metrics.js +700 -0
- package/dist/agents/plugins/claude.metrics.js.map +1 -0
- package/dist/agents/plugins/claude.plugin.d.ts +9 -0
- package/dist/agents/plugins/claude.plugin.d.ts.map +1 -1
- package/dist/agents/plugins/claude.plugin.js +52 -10
- package/dist/agents/plugins/claude.plugin.js.map +1 -1
- package/dist/agents/plugins/codemie-code.plugin.d.ts.map +1 -1
- package/dist/agents/plugins/codemie-code.plugin.js +45 -13
- package/dist/agents/plugins/codemie-code.plugin.js.map +1 -1
- package/dist/agents/plugins/codex.plugin.d.ts.map +1 -1
- package/dist/agents/plugins/codex.plugin.js +0 -2
- package/dist/agents/plugins/codex.plugin.js.map +1 -1
- package/dist/agents/plugins/gemini.plugin.d.ts.map +1 -1
- package/dist/agents/plugins/gemini.plugin.js +0 -7
- package/dist/agents/plugins/gemini.plugin.js.map +1 -1
- package/dist/agents/plugins/history-parser.d.ts +52 -0
- package/dist/agents/plugins/history-parser.d.ts.map +1 -0
- package/dist/agents/plugins/history-parser.js +155 -0
- package/dist/agents/plugins/history-parser.js.map +1 -0
- package/dist/cli/commands/analytics/aggregator.d.ts +58 -0
- package/dist/cli/commands/analytics/aggregator.d.ts.map +1 -0
- package/dist/cli/commands/analytics/aggregator.js +702 -0
- package/dist/cli/commands/analytics/aggregator.js.map +1 -0
- package/dist/cli/commands/analytics/data-loader.d.ts +84 -0
- package/dist/cli/commands/analytics/data-loader.d.ts.map +1 -0
- package/dist/cli/commands/analytics/data-loader.js +211 -0
- package/dist/cli/commands/analytics/data-loader.js.map +1 -0
- package/dist/cli/commands/analytics/exporter.d.ts +20 -0
- package/dist/cli/commands/analytics/exporter.d.ts.map +1 -0
- package/dist/cli/commands/analytics/exporter.js +103 -0
- package/dist/cli/commands/analytics/exporter.js.map +1 -0
- package/dist/cli/commands/analytics/formatter.d.ts +49 -0
- package/dist/cli/commands/analytics/formatter.d.ts.map +1 -0
- package/dist/cli/commands/analytics/formatter.js +309 -0
- package/dist/cli/commands/analytics/formatter.js.map +1 -0
- package/dist/cli/commands/analytics/index.d.ts +6 -0
- package/dist/cli/commands/analytics/index.d.ts.map +1 -0
- package/dist/cli/commands/analytics/index.js +157 -0
- package/dist/cli/commands/analytics/index.js.map +1 -0
- package/dist/cli/commands/analytics/model-normalizer.d.ts +21 -0
- package/dist/cli/commands/analytics/model-normalizer.d.ts.map +1 -0
- package/dist/cli/commands/analytics/model-normalizer.js +44 -0
- package/dist/cli/commands/analytics/model-normalizer.js.map +1 -0
- package/dist/cli/commands/analytics/types.d.ts +188 -0
- package/dist/cli/commands/analytics/types.d.ts.map +1 -0
- package/dist/cli/commands/analytics/types.js +6 -0
- package/dist/cli/commands/analytics/types.js.map +1 -0
- package/dist/cli/commands/doctor/checks/AwsCliCheck.d.ts +9 -0
- package/dist/cli/commands/doctor/checks/AwsCliCheck.d.ts.map +1 -0
- package/dist/cli/commands/doctor/checks/AwsCliCheck.js +28 -0
- package/dist/cli/commands/doctor/checks/AwsCliCheck.js.map +1 -0
- package/dist/cli/commands/doctor/checks/PythonCheck.d.ts.map +1 -1
- package/dist/cli/commands/doctor/checks/PythonCheck.js +10 -0
- package/dist/cli/commands/doctor/checks/PythonCheck.js.map +1 -1
- package/dist/cli/commands/doctor/checks/WorkflowsCheck.d.ts.map +1 -1
- package/dist/cli/commands/doctor/checks/WorkflowsCheck.js +2 -1
- package/dist/cli/commands/doctor/checks/WorkflowsCheck.js.map +1 -1
- package/dist/cli/commands/doctor/checks/index.d.ts +1 -0
- package/dist/cli/commands/doctor/checks/index.d.ts.map +1 -1
- package/dist/cli/commands/doctor/checks/index.js +1 -0
- package/dist/cli/commands/doctor/checks/index.js.map +1 -1
- package/dist/cli/commands/doctor/index.d.ts.map +1 -1
- package/dist/cli/commands/doctor/index.js +85 -3
- package/dist/cli/commands/doctor/index.js.map +1 -1
- package/dist/cli/commands/profile.d.ts.map +1 -1
- package/dist/cli/commands/profile.js +49 -89
- package/dist/cli/commands/profile.js.map +1 -1
- package/dist/cli/commands/setup.js +1 -21
- package/dist/cli/commands/setup.js.map +1 -1
- package/dist/cli/index.js +1 -1
- package/dist/cli/index.js.map +1 -1
- package/dist/env/types.d.ts +14 -2
- package/dist/env/types.d.ts.map +1 -1
- package/dist/env/types.js.map +1 -1
- package/dist/metrics/MetricsOrchestrator.d.ts +67 -0
- package/dist/metrics/MetricsOrchestrator.d.ts.map +1 -0
- package/dist/metrics/MetricsOrchestrator.js +287 -0
- package/dist/metrics/MetricsOrchestrator.js.map +1 -0
- package/dist/metrics/config.d.ts +38 -0
- package/dist/metrics/config.d.ts.map +1 -0
- package/dist/metrics/config.js +80 -0
- package/dist/metrics/config.js.map +1 -0
- package/dist/metrics/core/DeltaWriter.d.ts +49 -0
- package/dist/metrics/core/DeltaWriter.d.ts.map +1 -0
- package/dist/metrics/core/DeltaWriter.js +146 -0
- package/dist/metrics/core/DeltaWriter.js.map +1 -0
- package/dist/metrics/core/FileSnapshotter.d.ts +22 -0
- package/dist/metrics/core/FileSnapshotter.d.ts.map +1 -0
- package/dist/metrics/core/FileSnapshotter.js +74 -0
- package/dist/metrics/core/FileSnapshotter.js.map +1 -0
- package/dist/metrics/core/SessionCorrelator.d.ts +34 -0
- package/dist/metrics/core/SessionCorrelator.d.ts.map +1 -0
- package/dist/metrics/core/SessionCorrelator.js +115 -0
- package/dist/metrics/core/SessionCorrelator.js.map +1 -0
- package/dist/metrics/core/SyncStateManager.d.ts +69 -0
- package/dist/metrics/core/SyncStateManager.d.ts.map +1 -0
- package/dist/metrics/core/SyncStateManager.js +284 -0
- package/dist/metrics/core/SyncStateManager.js.map +1 -0
- package/dist/metrics/index.d.ts +9 -0
- package/dist/metrics/index.d.ts.map +1 -0
- package/dist/metrics/index.js +11 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/metrics/session/SessionStore.d.ts +43 -0
- package/dist/metrics/session/SessionStore.d.ts.map +1 -0
- package/dist/metrics/session/SessionStore.js +142 -0
- package/dist/metrics/session/SessionStore.js.map +1 -0
- package/dist/metrics/sync/MetricsApiClient.d.ts +32 -0
- package/dist/metrics/sync/MetricsApiClient.d.ts.map +1 -0
- package/dist/metrics/sync/MetricsApiClient.js +155 -0
- package/dist/metrics/sync/MetricsApiClient.js.map +1 -0
- package/dist/metrics/sync/aggregator.d.ts +13 -0
- package/dist/metrics/sync/aggregator.d.ts.map +1 -0
- package/dist/metrics/sync/aggregator.js +196 -0
- package/dist/metrics/sync/aggregator.js.map +1 -0
- package/dist/metrics/sync/index.d.ts +10 -0
- package/dist/metrics/sync/index.d.ts.map +1 -0
- package/dist/metrics/sync/index.js +10 -0
- package/dist/metrics/sync/index.js.map +1 -0
- package/dist/metrics/sync/jsonl-writer.d.ts +28 -0
- package/dist/metrics/sync/jsonl-writer.d.ts.map +1 -0
- package/dist/metrics/sync/jsonl-writer.js +72 -0
- package/dist/metrics/sync/jsonl-writer.js.map +1 -0
- package/dist/metrics/sync/types.d.ts +72 -0
- package/dist/metrics/sync/types.d.ts.map +1 -0
- package/dist/metrics/sync/types.js +7 -0
- package/dist/metrics/sync/types.js.map +1 -0
- package/dist/metrics/types.d.ts +308 -0
- package/dist/metrics/types.d.ts.map +1 -0
- package/dist/metrics/types.js +8 -0
- package/dist/metrics/types.js.map +1 -0
- package/dist/providers/index.d.ts +2 -0
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js +2 -0
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/integration/setup-ui.d.ts +1 -1
- package/dist/providers/integration/setup-ui.d.ts.map +1 -1
- package/dist/providers/integration/setup-ui.js +51 -6
- package/dist/providers/integration/setup-ui.js.map +1 -1
- package/dist/providers/plugins/bedrock/bedrock.health.d.ts +53 -0
- package/dist/providers/plugins/bedrock/bedrock.health.d.ts.map +1 -0
- package/dist/providers/plugins/bedrock/bedrock.health.js +115 -0
- package/dist/providers/plugins/bedrock/bedrock.health.js.map +1 -0
- package/dist/providers/plugins/bedrock/bedrock.models.d.ts +26 -0
- package/dist/providers/plugins/bedrock/bedrock.models.d.ts.map +1 -0
- package/dist/providers/plugins/bedrock/bedrock.models.js +89 -0
- package/dist/providers/plugins/bedrock/bedrock.models.js.map +1 -0
- package/dist/providers/plugins/bedrock/bedrock.setup-steps.d.ts +12 -0
- package/dist/providers/plugins/bedrock/bedrock.setup-steps.d.ts.map +1 -0
- package/dist/providers/plugins/bedrock/bedrock.setup-steps.js +308 -0
- package/dist/providers/plugins/bedrock/bedrock.setup-steps.js.map +1 -0
- package/dist/providers/plugins/bedrock/bedrock.template.d.ts +11 -0
- package/dist/providers/plugins/bedrock/bedrock.template.d.ts.map +1 -0
- package/dist/providers/plugins/bedrock/bedrock.template.js +85 -0
- package/dist/providers/plugins/bedrock/bedrock.template.js.map +1 -0
- package/dist/providers/plugins/bedrock/index.d.ts +11 -0
- package/dist/providers/plugins/bedrock/index.d.ts.map +1 -0
- package/dist/providers/plugins/bedrock/index.js +11 -0
- package/dist/providers/plugins/bedrock/index.js.map +1 -0
- package/dist/providers/plugins/ollama/ollama.template.d.ts.map +1 -1
- package/dist/providers/plugins/ollama/ollama.template.js +2 -0
- package/dist/providers/plugins/ollama/ollama.template.js.map +1 -1
- package/dist/providers/plugins/sso/sso.http-client.d.ts +2 -0
- package/dist/providers/plugins/sso/sso.http-client.d.ts.map +1 -1
- package/dist/providers/plugins/sso/sso.http-client.js +9 -3
- package/dist/providers/plugins/sso/sso.http-client.js.map +1 -1
- package/dist/proxy/http-client.d.ts.map +1 -1
- package/dist/proxy/http-client.js +49 -14
- package/dist/proxy/http-client.js.map +1 -1
- package/dist/proxy/plugins/endpoint-blocker.plugin.d.ts +19 -0
- package/dist/proxy/plugins/endpoint-blocker.plugin.d.ts.map +1 -0
- package/dist/proxy/plugins/endpoint-blocker.plugin.js +61 -0
- package/dist/proxy/plugins/endpoint-blocker.plugin.js.map +1 -0
- package/dist/proxy/plugins/header-injection.plugin.js +3 -0
- package/dist/proxy/plugins/header-injection.plugin.js.map +1 -1
- package/dist/proxy/plugins/index.d.ts +3 -1
- package/dist/proxy/plugins/index.d.ts.map +1 -1
- package/dist/proxy/plugins/index.js +5 -1
- package/dist/proxy/plugins/index.js.map +1 -1
- package/dist/proxy/plugins/logging.plugin.d.ts +3 -3
- package/dist/proxy/plugins/logging.plugin.js +84 -20
- package/dist/proxy/plugins/logging.plugin.js.map +1 -1
- package/dist/proxy/plugins/metrics-sync.plugin.d.ts +33 -0
- package/dist/proxy/plugins/metrics-sync.plugin.d.ts.map +1 -0
- package/dist/proxy/plugins/metrics-sync.plugin.js +310 -0
- package/dist/proxy/plugins/metrics-sync.plugin.js.map +1 -0
- package/dist/proxy/plugins/registry.d.ts.map +1 -1
- package/dist/proxy/plugins/registry.js +8 -1
- package/dist/proxy/plugins/registry.js.map +1 -1
- package/dist/proxy/plugins/types.d.ts +6 -2
- package/dist/proxy/plugins/types.d.ts.map +1 -1
- package/dist/proxy/types.d.ts +7 -0
- package/dist/proxy/types.d.ts.map +1 -1
- package/dist/utils/ascii-logo.d.ts +21 -0
- package/dist/utils/ascii-logo.d.ts.map +1 -0
- package/dist/utils/ascii-logo.js +75 -0
- package/dist/utils/ascii-logo.js.map +1 -0
- package/dist/utils/codemie-proxy.d.ts +0 -6
- package/dist/utils/codemie-proxy.d.ts.map +1 -1
- package/dist/utils/codemie-proxy.js +46 -56
- package/dist/utils/codemie-proxy.js.map +1 -1
- package/dist/utils/config-loader.d.ts.map +1 -1
- package/dist/utils/config-loader.js +22 -6
- package/dist/utils/config-loader.js.map +1 -1
- package/dist/utils/exec.d.ts +11 -0
- package/dist/utils/exec.d.ts.map +1 -1
- package/dist/utils/exec.js +17 -1
- package/dist/utils/exec.js.map +1 -1
- package/dist/utils/goodbye-messages.d.ts +13 -0
- package/dist/utils/goodbye-messages.d.ts.map +1 -0
- package/dist/utils/goodbye-messages.js +245 -0
- package/dist/utils/goodbye-messages.js.map +1 -0
- package/dist/utils/json-parser.d.ts +52 -0
- package/dist/utils/json-parser.d.ts.map +1 -0
- package/dist/utils/json-parser.js +126 -0
- package/dist/utils/json-parser.js.map +1 -0
- package/dist/utils/logger.d.ts +37 -1
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +92 -20
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/sanitize.d.ts.map +1 -1
- package/dist/utils/sanitize.js +0 -1
- package/dist/utils/sanitize.js.map +1 -1
- package/dist/utils/which.d.ts +20 -0
- package/dist/utils/which.d.ts.map +1 -0
- package/dist/utils/which.js +47 -0
- package/dist/utils/which.js.map +1 -0
- package/package.json +10 -5
- package/dist/analytics/aggregation/adapters/claude.adapter.d.ts +0 -37
- package/dist/analytics/aggregation/adapters/claude.adapter.d.ts.map +0 -1
- package/dist/analytics/aggregation/adapters/claude.adapter.js +0 -531
- package/dist/analytics/aggregation/adapters/claude.adapter.js.map +0 -1
- package/dist/analytics/aggregation/adapters/codex.adapter.d.ts +0 -25
- package/dist/analytics/aggregation/adapters/codex.adapter.d.ts.map +0 -1
- package/dist/analytics/aggregation/adapters/codex.adapter.js +0 -396
- package/dist/analytics/aggregation/adapters/codex.adapter.js.map +0 -1
- package/dist/analytics/aggregation/adapters/gemini.adapter.d.ts +0 -36
- package/dist/analytics/aggregation/adapters/gemini.adapter.d.ts.map +0 -1
- package/dist/analytics/aggregation/adapters/gemini.adapter.js +0 -365
- package/dist/analytics/aggregation/adapters/gemini.adapter.js.map +0 -1
- package/dist/analytics/aggregation/adapters/index.d.ts +0 -7
- package/dist/analytics/aggregation/adapters/index.d.ts.map +0 -1
- package/dist/analytics/aggregation/adapters/index.js +0 -7
- package/dist/analytics/aggregation/adapters/index.js.map +0 -1
- package/dist/analytics/aggregation/aggregator.d.ts +0 -49
- package/dist/analytics/aggregation/aggregator.d.ts.map +0 -1
- package/dist/analytics/aggregation/aggregator.js +0 -239
- package/dist/analytics/aggregation/aggregator.js.map +0 -1
- package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.d.ts +0 -99
- package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.js +0 -110
- package/dist/analytics/aggregation/core/BaseAnalyticsAdapter.js.map +0 -1
- package/dist/analytics/aggregation/core/adapter.interface.d.ts +0 -76
- package/dist/analytics/aggregation/core/adapter.interface.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/adapter.interface.js +0 -9
- package/dist/analytics/aggregation/core/adapter.interface.js.map +0 -1
- package/dist/analytics/aggregation/core/aggregation-utils.d.ts +0 -86
- package/dist/analytics/aggregation/core/aggregation-utils.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/aggregation-utils.js +0 -126
- package/dist/analytics/aggregation/core/aggregation-utils.js.map +0 -1
- package/dist/analytics/aggregation/core/discovery.d.ts +0 -40
- package/dist/analytics/aggregation/core/discovery.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/discovery.js +0 -132
- package/dist/analytics/aggregation/core/discovery.js.map +0 -1
- package/dist/analytics/aggregation/core/file-utils.d.ts +0 -24
- package/dist/analytics/aggregation/core/file-utils.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/file-utils.js +0 -143
- package/dist/analytics/aggregation/core/file-utils.js.map +0 -1
- package/dist/analytics/aggregation/core/index.d.ts +0 -14
- package/dist/analytics/aggregation/core/index.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/index.js +0 -14
- package/dist/analytics/aggregation/core/index.js.map +0 -1
- package/dist/analytics/aggregation/core/project-mapping.d.ts +0 -50
- package/dist/analytics/aggregation/core/project-mapping.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/project-mapping.js +0 -102
- package/dist/analytics/aggregation/core/project-mapping.js.map +0 -1
- package/dist/analytics/aggregation/core/streaming.d.ts +0 -26
- package/dist/analytics/aggregation/core/streaming.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/streaming.js +0 -58
- package/dist/analytics/aggregation/core/streaming.js.map +0 -1
- package/dist/analytics/aggregation/core/user-prompt-source.d.ts +0 -81
- package/dist/analytics/aggregation/core/user-prompt-source.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/user-prompt-source.js +0 -69
- package/dist/analytics/aggregation/core/user-prompt-source.js.map +0 -1
- package/dist/analytics/aggregation/core/user-prompt-sources/json.d.ts +0 -49
- package/dist/analytics/aggregation/core/user-prompt-sources/json.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/user-prompt-sources/json.js +0 -66
- package/dist/analytics/aggregation/core/user-prompt-sources/json.js.map +0 -1
- package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.d.ts +0 -43
- package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.d.ts.map +0 -1
- package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.js +0 -56
- package/dist/analytics/aggregation/core/user-prompt-sources/jsonl.js.map +0 -1
- package/dist/analytics/aggregation/index.d.ts +0 -8
- package/dist/analytics/aggregation/index.d.ts.map +0 -1
- package/dist/analytics/aggregation/index.js +0 -8
- package/dist/analytics/aggregation/index.js.map +0 -1
- package/dist/analytics/aggregation/types.d.ts +0 -278
- package/dist/analytics/aggregation/types.d.ts.map +0 -1
- package/dist/analytics/aggregation/types.js +0 -8
- package/dist/analytics/aggregation/types.js.map +0 -1
- package/dist/analytics/collector.d.ts +0 -46
- package/dist/analytics/collector.d.ts.map +0 -1
- package/dist/analytics/collector.js +0 -83
- package/dist/analytics/collector.js.map +0 -1
- package/dist/analytics/config.d.ts +0 -15
- package/dist/analytics/config.d.ts.map +0 -1
- package/dist/analytics/config.js +0 -65
- package/dist/analytics/config.js.map +0 -1
- package/dist/analytics/index.d.ts +0 -99
- package/dist/analytics/index.d.ts.map +0 -1
- package/dist/analytics/index.js +0 -280
- package/dist/analytics/index.js.map +0 -1
- package/dist/analytics/plugins/api-metrics.plugin.d.ts +0 -26
- package/dist/analytics/plugins/api-metrics.plugin.d.ts.map +0 -1
- package/dist/analytics/plugins/api-metrics.plugin.js +0 -97
- package/dist/analytics/plugins/api-metrics.plugin.js.map +0 -1
- package/dist/analytics/plugins/index.d.ts +0 -15
- package/dist/analytics/plugins/index.d.ts.map +0 -1
- package/dist/analytics/plugins/index.js +0 -15
- package/dist/analytics/plugins/index.js.map +0 -1
- package/dist/analytics/plugins/model-metrics.plugin.d.ts +0 -39
- package/dist/analytics/plugins/model-metrics.plugin.d.ts.map +0 -1
- package/dist/analytics/plugins/model-metrics.plugin.js +0 -105
- package/dist/analytics/plugins/model-metrics.plugin.js.map +0 -1
- package/dist/analytics/plugins/provider-metrics.plugin.d.ts +0 -41
- package/dist/analytics/plugins/provider-metrics.plugin.d.ts.map +0 -1
- package/dist/analytics/plugins/provider-metrics.plugin.js +0 -123
- package/dist/analytics/plugins/provider-metrics.plugin.js.map +0 -1
- package/dist/analytics/plugins/types.d.ts +0 -61
- package/dist/analytics/plugins/types.d.ts.map +0 -1
- package/dist/analytics/plugins/types.js +0 -54
- package/dist/analytics/plugins/types.js.map +0 -1
- package/dist/analytics/privacy.d.ts +0 -10
- package/dist/analytics/privacy.d.ts.map +0 -1
- package/dist/analytics/privacy.js +0 -20
- package/dist/analytics/privacy.js.map +0 -1
- package/dist/analytics/remote-submission/cursor-manager.d.ts +0 -71
- package/dist/analytics/remote-submission/cursor-manager.d.ts.map +0 -1
- package/dist/analytics/remote-submission/cursor-manager.js +0 -204
- package/dist/analytics/remote-submission/cursor-manager.js.map +0 -1
- package/dist/analytics/remote-submission/index.d.ts +0 -12
- package/dist/analytics/remote-submission/index.d.ts.map +0 -1
- package/dist/analytics/remote-submission/index.js +0 -11
- package/dist/analytics/remote-submission/index.js.map +0 -1
- package/dist/analytics/remote-submission/lock-manager.d.ts +0 -71
- package/dist/analytics/remote-submission/lock-manager.d.ts.map +0 -1
- package/dist/analytics/remote-submission/lock-manager.js +0 -238
- package/dist/analytics/remote-submission/lock-manager.js.map +0 -1
- package/dist/analytics/remote-submission/metric-transformer.d.ts +0 -21
- package/dist/analytics/remote-submission/metric-transformer.d.ts.map +0 -1
- package/dist/analytics/remote-submission/metric-transformer.js +0 -82
- package/dist/analytics/remote-submission/metric-transformer.js.map +0 -1
- package/dist/analytics/remote-submission/submitter.d.ts +0 -79
- package/dist/analytics/remote-submission/submitter.d.ts.map +0 -1
- package/dist/analytics/remote-submission/submitter.js +0 -362
- package/dist/analytics/remote-submission/submitter.js.map +0 -1
- package/dist/analytics/remote-submission/types.d.ts +0 -123
- package/dist/analytics/remote-submission/types.d.ts.map +0 -1
- package/dist/analytics/remote-submission/types.js +0 -13
- package/dist/analytics/remote-submission/types.js.map +0 -1
- package/dist/analytics/session.d.ts +0 -56
- package/dist/analytics/session.d.ts.map +0 -1
- package/dist/analytics/session.js +0 -95
- package/dist/analytics/session.js.map +0 -1
- package/dist/analytics/types.d.ts +0 -104
- package/dist/analytics/types.d.ts.map +0 -1
- package/dist/analytics/types.js +0 -15
- package/dist/analytics/types.js.map +0 -1
- package/dist/analytics/writer.d.ts +0 -18
- package/dist/analytics/writer.d.ts.map +0 -1
- package/dist/analytics/writer.js +0 -44
- package/dist/analytics/writer.js.map +0 -1
- package/dist/cli/commands/analytics.d.ts +0 -3
- package/dist/cli/commands/analytics.d.ts.map +0 -1
- package/dist/cli/commands/analytics.js +0 -748
- package/dist/cli/commands/analytics.js.map +0 -1
- package/dist/utils/analytics-reader.d.ts +0 -117
- package/dist/utils/analytics-reader.d.ts.map +0 -1
- package/dist/utils/analytics-reader.js +0 -421
- package/dist/utils/analytics-reader.js.map +0 -1
- package/dist/utils/date-formatter.d.ts +0 -88
- package/dist/utils/date-formatter.d.ts.map +0 -1
- package/dist/utils/date-formatter.js +0 -133
- package/dist/utils/date-formatter.js.map +0 -1
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Logging Plugin - Request/Response Logging
|
|
2
|
+
* Logging Plugin - Request/Response Logging
|
|
3
3
|
* Priority: 50 (runs before analytics)
|
|
4
4
|
*
|
|
5
|
-
* Purpose: Logs detailed proxy request/response information
|
|
5
|
+
* Purpose: Logs detailed proxy request/response information
|
|
6
6
|
* Separates operational logging from analytics metrics
|
|
7
7
|
*
|
|
8
|
-
* Log Level:
|
|
8
|
+
* Log Level: DEBUG (file + console when CODEMIE_DEBUG=1)
|
|
9
9
|
* Log Location: ~/.codemie/logs/debug-YYYY-MM-DD.log
|
|
10
10
|
*
|
|
11
11
|
* SOLID: Single responsibility = log proxy activity
|
|
@@ -23,12 +23,20 @@ export class LoggingPlugin {
|
|
|
23
23
|
}
|
|
24
24
|
class LoggingInterceptor {
|
|
25
25
|
name = 'logging';
|
|
26
|
+
chunkCount = 0;
|
|
27
|
+
totalBytes = 0;
|
|
26
28
|
async onRequest(context) {
|
|
27
29
|
try {
|
|
28
|
-
|
|
30
|
+
// Reset counters for new request
|
|
31
|
+
this.chunkCount = 0;
|
|
32
|
+
this.totalBytes = 0;
|
|
33
|
+
logger.debug(`[proxy-request] ${context.method} ${context.url}`, {
|
|
29
34
|
requestId: context.requestId,
|
|
30
35
|
sessionId: context.sessionId,
|
|
31
36
|
agent: context.agentName,
|
|
37
|
+
profile: context.profile,
|
|
38
|
+
provider: context.provider,
|
|
39
|
+
model: context.model,
|
|
32
40
|
targetUrl: context.targetUrl,
|
|
33
41
|
bodySize: context.requestBody?.length || 0,
|
|
34
42
|
headers: this.sanitizeHeaders(context.headers)
|
|
@@ -39,14 +47,71 @@ class LoggingInterceptor {
|
|
|
39
47
|
logger.error(`[${this.name}] Error logging request:`, error);
|
|
40
48
|
}
|
|
41
49
|
}
|
|
50
|
+
async onResponseHeaders(context, headers) {
|
|
51
|
+
try {
|
|
52
|
+
logger.debug(`[proxy-response-headers] ${context.url}`, {
|
|
53
|
+
requestId: context.requestId,
|
|
54
|
+
sessionId: context.sessionId,
|
|
55
|
+
agent: context.agentName,
|
|
56
|
+
profile: context.profile,
|
|
57
|
+
provider: context.provider,
|
|
58
|
+
model: context.model,
|
|
59
|
+
headers: {
|
|
60
|
+
'content-type': headers['content-type'],
|
|
61
|
+
'content-length': headers['content-length'],
|
|
62
|
+
'transfer-encoding': headers['transfer-encoding']
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
catch (error) {
|
|
67
|
+
logger.error(`[${this.name}] Error logging response headers:`, error);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
async onResponseChunk(context, chunk) {
|
|
71
|
+
try {
|
|
72
|
+
this.chunkCount++;
|
|
73
|
+
this.totalBytes += chunk.length;
|
|
74
|
+
// Log every 1000th chunk to avoid spam (or first/last chunks)
|
|
75
|
+
if (this.chunkCount === 1 || this.chunkCount % 1000 === 0) {
|
|
76
|
+
logger.debug(`[proxy-streaming] ${context.url}`, {
|
|
77
|
+
requestId: context.requestId,
|
|
78
|
+
sessionId: context.sessionId,
|
|
79
|
+
chunkNumber: this.chunkCount,
|
|
80
|
+
chunkSize: chunk.length,
|
|
81
|
+
totalBytes: this.totalBytes
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
catch (error) {
|
|
86
|
+
logger.error(`[${this.name}] Error logging chunk:`, error);
|
|
87
|
+
}
|
|
88
|
+
return chunk;
|
|
89
|
+
}
|
|
42
90
|
async onResponseComplete(context, metadata) {
|
|
43
91
|
try {
|
|
44
|
-
logger.
|
|
92
|
+
logger.debug(`[proxy-response] ${metadata.statusCode} ${context.url} (${metadata.durationMs}ms)`, {
|
|
45
93
|
requestId: context.requestId,
|
|
94
|
+
sessionId: context.sessionId,
|
|
95
|
+
agent: context.agentName,
|
|
96
|
+
profile: context.profile,
|
|
97
|
+
provider: context.provider,
|
|
98
|
+
model: context.model,
|
|
46
99
|
statusCode: metadata.statusCode,
|
|
47
100
|
statusMessage: metadata.statusMessage,
|
|
48
101
|
bytesSent: metadata.bytesSent,
|
|
49
|
-
durationMs: metadata.durationMs
|
|
102
|
+
durationMs: metadata.durationMs,
|
|
103
|
+
totalChunks: this.chunkCount,
|
|
104
|
+
totalBytesStreamed: this.totalBytes
|
|
105
|
+
});
|
|
106
|
+
// Log completion marker to track if we reach this point
|
|
107
|
+
logger.debug(`[proxy-complete] Request fully processed for ${context.url}`, {
|
|
108
|
+
requestId: context.requestId,
|
|
109
|
+
sessionId: context.sessionId,
|
|
110
|
+
agent: context.agentName,
|
|
111
|
+
profile: context.profile,
|
|
112
|
+
provider: context.provider,
|
|
113
|
+
model: context.model,
|
|
114
|
+
finalStatus: 'success'
|
|
50
115
|
});
|
|
51
116
|
}
|
|
52
117
|
catch (error) {
|
|
@@ -56,10 +121,16 @@ class LoggingInterceptor {
|
|
|
56
121
|
}
|
|
57
122
|
async onError(context, error) {
|
|
58
123
|
try {
|
|
59
|
-
logger.
|
|
124
|
+
logger.debug(`[proxy-error] ${error.name}: ${error.message}`, {
|
|
60
125
|
requestId: context.requestId,
|
|
126
|
+
sessionId: context.sessionId,
|
|
127
|
+
agent: context.agentName,
|
|
128
|
+
profile: context.profile,
|
|
129
|
+
provider: context.provider,
|
|
130
|
+
model: context.model,
|
|
61
131
|
url: context.url,
|
|
62
132
|
errorType: error.name,
|
|
133
|
+
errorMessage: error.message,
|
|
63
134
|
errorStack: error.stack
|
|
64
135
|
});
|
|
65
136
|
}
|
|
@@ -69,24 +140,17 @@ class LoggingInterceptor {
|
|
|
69
140
|
}
|
|
70
141
|
}
|
|
71
142
|
/**
|
|
72
|
-
*
|
|
143
|
+
* Filter headers to only include X-Codemie headers
|
|
73
144
|
*/
|
|
74
145
|
sanitizeHeaders(headers) {
|
|
75
|
-
const
|
|
146
|
+
const filtered = {};
|
|
76
147
|
for (const [key, value] of Object.entries(headers)) {
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
lowerKey.includes('api-key') ||
|
|
81
|
-
lowerKey.includes('token') ||
|
|
82
|
-
lowerKey.includes('cookie')) {
|
|
83
|
-
sanitized[key] = '[REDACTED]';
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
sanitized[key] = value;
|
|
148
|
+
// Only include X-Codemie headers
|
|
149
|
+
if (key.toLowerCase().startsWith('x-codemie')) {
|
|
150
|
+
filtered[key] = value;
|
|
87
151
|
}
|
|
88
152
|
}
|
|
89
|
-
return
|
|
153
|
+
return filtered;
|
|
90
154
|
}
|
|
91
155
|
}
|
|
92
156
|
//# sourceMappingURL=logging.plugin.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logging.plugin.js","sourceRoot":"","sources":["../../../src/proxy/plugins/logging.plugin.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAIH,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C,MAAM,OAAO,aAAa;IACxB,EAAE,GAAG,wBAAwB,CAAC;IAC9B,IAAI,GAAG,SAAS,CAAC;IACjB,OAAO,GAAG,OAAO,CAAC;IAClB,QAAQ,GAAG,EAAE,CAAC,CAAC,uBAAuB;IAEtC,KAAK,CAAC,iBAAiB,CAAC,QAAuB;QAC7C,OAAO,IAAI,kBAAkB,EAAE,CAAC;IAClC,CAAC;CACF;AAED,MAAM,kBAAkB;IACtB,IAAI,GAAG,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"logging.plugin.js","sourceRoot":"","sources":["../../../src/proxy/plugins/logging.plugin.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Metrics Sync Plugin
|
|
3
|
+
* Priority: 100 (runs after logging plugin)
|
|
4
|
+
*
|
|
5
|
+
* Purpose: Syncs metrics to CodeMie API in background
|
|
6
|
+
* - Runs only in SSO mode (ai-run-sso provider)
|
|
7
|
+
* - Background timer (every 5 minutes)
|
|
8
|
+
* - Aggregates pending deltas into single metric
|
|
9
|
+
* - Marks deltas as synced in JSONL
|
|
10
|
+
* - Final sync on proxy shutdown
|
|
11
|
+
*
|
|
12
|
+
* SOLID: Single responsibility = sync metrics
|
|
13
|
+
* KISS: Simple timer-based sync
|
|
14
|
+
*/
|
|
15
|
+
import { ProxyPlugin, PluginContext, ProxyInterceptor } from './types.js';
|
|
16
|
+
export declare class MetricsSyncPlugin implements ProxyPlugin {
|
|
17
|
+
id: string;
|
|
18
|
+
name: string;
|
|
19
|
+
version: string;
|
|
20
|
+
priority: number;
|
|
21
|
+
createInterceptor(context: PluginContext): Promise<ProxyInterceptor>;
|
|
22
|
+
/**
|
|
23
|
+
* Check if metrics sync is enabled
|
|
24
|
+
* Priority: ENV > Profile config > Default (true)
|
|
25
|
+
*/
|
|
26
|
+
private isSyncEnabled;
|
|
27
|
+
/**
|
|
28
|
+
* Check if dry-run mode is enabled
|
|
29
|
+
* Priority: ENV > Profile config > Default (false)
|
|
30
|
+
*/
|
|
31
|
+
private isDryRunEnabled;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=metrics-sync.plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics-sync.plugin.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/metrics-sync.plugin.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAQ1E,qBAAa,iBAAkB,YAAW,WAAW;IACnD,EAAE,SAAiC;IACnC,IAAI,SAAkB;IACtB,OAAO,SAAW;IAClB,QAAQ,SAAO;IAET,iBAAiB,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,gBAAgB,CAAC;IAkC1E;;;OAGG;IACH,OAAO,CAAC,aAAa;IAgBrB;;;OAGG;IACH,OAAO,CAAC,eAAe;CAexB"}
|
|
@@ -0,0 +1,310 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Metrics Sync Plugin
|
|
3
|
+
* Priority: 100 (runs after logging plugin)
|
|
4
|
+
*
|
|
5
|
+
* Purpose: Syncs metrics to CodeMie API in background
|
|
6
|
+
* - Runs only in SSO mode (ai-run-sso provider)
|
|
7
|
+
* - Background timer (every 5 minutes)
|
|
8
|
+
* - Aggregates pending deltas into single metric
|
|
9
|
+
* - Marks deltas as synced in JSONL
|
|
10
|
+
* - Final sync on proxy shutdown
|
|
11
|
+
*
|
|
12
|
+
* SOLID: Single responsibility = sync metrics
|
|
13
|
+
* KISS: Simple timer-based sync
|
|
14
|
+
*/
|
|
15
|
+
import { logger } from '../../utils/logger.js';
|
|
16
|
+
import { MetricsApiClient } from '../../metrics/sync/MetricsApiClient.js';
|
|
17
|
+
import { readJSONL, writeJSONLAtomic } from '../../metrics/sync/jsonl-writer.js';
|
|
18
|
+
import { aggregateDeltas } from '../../metrics/sync/aggregator.js';
|
|
19
|
+
import { SessionStore } from '../../metrics/session/SessionStore.js';
|
|
20
|
+
import { getSessionMetricsPath } from '../../metrics/config.js';
|
|
21
|
+
export class MetricsSyncPlugin {
|
|
22
|
+
id = '@codemie/proxy-metrics-sync';
|
|
23
|
+
name = 'Metrics Sync';
|
|
24
|
+
version = '1.0.0';
|
|
25
|
+
priority = 100; // Run after logging (priority 50)
|
|
26
|
+
async createInterceptor(context) {
|
|
27
|
+
// Only create interceptor if we have necessary context
|
|
28
|
+
if (!context.config.sessionId) {
|
|
29
|
+
logger.debug('[MetricsSyncPlugin] Skipping: Session ID not available');
|
|
30
|
+
throw new Error('Session ID not available (metrics sync disabled)');
|
|
31
|
+
}
|
|
32
|
+
if (!context.credentials) {
|
|
33
|
+
logger.debug('[MetricsSyncPlugin] Skipping: SSO credentials not available');
|
|
34
|
+
throw new Error('SSO credentials not available (metrics sync disabled)');
|
|
35
|
+
}
|
|
36
|
+
// Check if metrics sync is enabled (from config or env var)
|
|
37
|
+
const syncEnabled = this.isSyncEnabled(context);
|
|
38
|
+
if (!syncEnabled) {
|
|
39
|
+
logger.debug('[MetricsSyncPlugin] Skipping: Metrics sync disabled by configuration');
|
|
40
|
+
throw new Error('Metrics sync disabled by configuration');
|
|
41
|
+
}
|
|
42
|
+
logger.info('[MetricsSyncPlugin] Initializing metrics sync');
|
|
43
|
+
// Check if dry-run mode is enabled
|
|
44
|
+
const dryRun = this.isDryRunEnabled(context);
|
|
45
|
+
return new MetricsSyncInterceptor(context.config.sessionId, context.config.targetApiUrl, context.credentials.cookies, context.config.clientType, context.config.version, dryRun);
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Check if metrics sync is enabled
|
|
49
|
+
* Priority: ENV > Profile config > Default (true)
|
|
50
|
+
*/
|
|
51
|
+
isSyncEnabled(context) {
|
|
52
|
+
// Check environment variable first
|
|
53
|
+
const envEnabled = process.env.CODEMIE_METRICS_SYNC_ENABLED;
|
|
54
|
+
if (envEnabled !== undefined) {
|
|
55
|
+
return envEnabled === 'true' || envEnabled === '1';
|
|
56
|
+
}
|
|
57
|
+
// Check profile config (if available)
|
|
58
|
+
if (context.profileConfig?.metrics?.sync?.enabled !== undefined) {
|
|
59
|
+
return context.profileConfig.metrics.sync.enabled;
|
|
60
|
+
}
|
|
61
|
+
// Default to enabled for SSO mode
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Check if dry-run mode is enabled
|
|
66
|
+
* Priority: ENV > Profile config > Default (false)
|
|
67
|
+
*/
|
|
68
|
+
isDryRunEnabled(context) {
|
|
69
|
+
// Check environment variable first
|
|
70
|
+
const envDryRun = process.env.CODEMIE_METRICS_DRY_RUN;
|
|
71
|
+
if (envDryRun !== undefined) {
|
|
72
|
+
return envDryRun === 'true' || envDryRun === '1';
|
|
73
|
+
}
|
|
74
|
+
// Check profile config (if available)
|
|
75
|
+
if (context.profileConfig?.metrics?.sync?.dryRun !== undefined) {
|
|
76
|
+
return context.profileConfig.metrics.sync.dryRun;
|
|
77
|
+
}
|
|
78
|
+
// Default to disabled
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
class MetricsSyncInterceptor {
|
|
83
|
+
sessionId;
|
|
84
|
+
name = 'metrics-sync';
|
|
85
|
+
syncTimer;
|
|
86
|
+
sessionStore = new SessionStore();
|
|
87
|
+
apiClient;
|
|
88
|
+
syncInterval;
|
|
89
|
+
isSyncing = false;
|
|
90
|
+
version;
|
|
91
|
+
dryRun;
|
|
92
|
+
constructor(sessionId, baseUrl, cookies, clientType, version, dryRun = false) {
|
|
93
|
+
this.sessionId = sessionId;
|
|
94
|
+
// Get version from proxy config (passed from AgentCLI)
|
|
95
|
+
this.version = version || '0.0.0';
|
|
96
|
+
// Set dry-run mode (passed from plugin)
|
|
97
|
+
this.dryRun = dryRun;
|
|
98
|
+
if (this.dryRun) {
|
|
99
|
+
logger.info('[metrics-sync] Dry-run mode enabled - metrics will be logged but not sent');
|
|
100
|
+
}
|
|
101
|
+
// Build cookie header
|
|
102
|
+
const cookieHeader = Object.entries(cookies)
|
|
103
|
+
.map(([key, value]) => `${key}=${value}`)
|
|
104
|
+
.join('; ');
|
|
105
|
+
this.apiClient = new MetricsApiClient({
|
|
106
|
+
baseUrl,
|
|
107
|
+
cookies: cookieHeader,
|
|
108
|
+
timeout: 30000,
|
|
109
|
+
retryAttempts: 3,
|
|
110
|
+
version: this.version,
|
|
111
|
+
clientType: clientType || 'codemie-cli'
|
|
112
|
+
});
|
|
113
|
+
// Get sync interval from env or default to 5 minutes
|
|
114
|
+
this.syncInterval = Number.parseInt(process.env.CODEMIE_METRICS_SYNC_INTERVAL || '300000', 10);
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Called when proxy starts - initialize background timer
|
|
118
|
+
*/
|
|
119
|
+
async onProxyStart() {
|
|
120
|
+
logger.info(`[${this.name}] Starting metrics sync (interval: ${this.syncInterval}ms)`);
|
|
121
|
+
// Start background timer
|
|
122
|
+
this.syncTimer = setInterval(() => {
|
|
123
|
+
this.syncMetrics().catch(error => {
|
|
124
|
+
logger.error(`[${this.name}] Sync failed:`, error);
|
|
125
|
+
});
|
|
126
|
+
}, this.syncInterval);
|
|
127
|
+
logger.debug(`[${this.name}] Background timer started`);
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Called when proxy stops - cleanup and final sync
|
|
131
|
+
*/
|
|
132
|
+
async onProxyStop() {
|
|
133
|
+
logger.info(`[${this.name}] Stopping metrics sync`);
|
|
134
|
+
// Stop timer
|
|
135
|
+
if (this.syncTimer) {
|
|
136
|
+
clearInterval(this.syncTimer);
|
|
137
|
+
this.syncTimer = undefined;
|
|
138
|
+
}
|
|
139
|
+
// Final sync (ensure all pending metrics are sent)
|
|
140
|
+
try {
|
|
141
|
+
await this.syncMetrics();
|
|
142
|
+
logger.info(`[${this.name}] Final sync completed`);
|
|
143
|
+
}
|
|
144
|
+
catch (error) {
|
|
145
|
+
logger.error(`[${this.name}] Final sync failed:`, error);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Sync metrics to API
|
|
150
|
+
*/
|
|
151
|
+
async syncMetrics() {
|
|
152
|
+
// Skip if already syncing (prevent concurrent syncs)
|
|
153
|
+
if (this.isSyncing) {
|
|
154
|
+
logger.debug(`[${this.name}] Sync already in progress, skipping`);
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
this.isSyncing = true;
|
|
158
|
+
try {
|
|
159
|
+
const metricsFile = getSessionMetricsPath(this.sessionId);
|
|
160
|
+
// 1. Read all deltas from JSONL
|
|
161
|
+
const allDeltas = await readJSONL(metricsFile);
|
|
162
|
+
// 2. Filter for pending deltas only
|
|
163
|
+
const pendingDeltas = allDeltas.filter(d => d.syncStatus === 'pending');
|
|
164
|
+
if (pendingDeltas.length === 0) {
|
|
165
|
+
logger.debug(`[${this.name}] No pending deltas to sync`);
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
logger.info(`[${this.name}] Syncing ${pendingDeltas.length} pending deltas`);
|
|
169
|
+
// Debug: Log collected deltas
|
|
170
|
+
logger.debug(`[${this.name}] Collected pending deltas:`, {
|
|
171
|
+
count: pendingDeltas.length,
|
|
172
|
+
deltas: pendingDeltas.map(d => {
|
|
173
|
+
// Calculate tool stats from tools and toolStatus
|
|
174
|
+
const totalTools = Object.values(d.tools || {}).reduce((sum, count) => sum + count, 0);
|
|
175
|
+
let successCount = 0;
|
|
176
|
+
let failureCount = 0;
|
|
177
|
+
if (d.toolStatus) {
|
|
178
|
+
for (const status of Object.values(d.toolStatus)) {
|
|
179
|
+
successCount += status.success || 0;
|
|
180
|
+
failureCount += status.failure || 0;
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
// Calculate file operation totals
|
|
184
|
+
const fileOps = d.fileOperations || [];
|
|
185
|
+
const linesAdded = fileOps.reduce((sum, op) => sum + (op.linesAdded || 0), 0);
|
|
186
|
+
const linesRemoved = fileOps.reduce((sum, op) => sum + (op.linesRemoved || 0), 0);
|
|
187
|
+
const writeOps = fileOps.filter(op => op.type === 'write').length;
|
|
188
|
+
const editOps = fileOps.filter(op => op.type === 'edit').length;
|
|
189
|
+
const deleteOps = fileOps.filter(op => op.type === 'delete').length;
|
|
190
|
+
return {
|
|
191
|
+
recordId: d.recordId,
|
|
192
|
+
timestamp: typeof d.timestamp === 'number'
|
|
193
|
+
? new Date(d.timestamp).toISOString()
|
|
194
|
+
: d.timestamp,
|
|
195
|
+
tokens: d.tokens,
|
|
196
|
+
tools: {
|
|
197
|
+
total: totalTools,
|
|
198
|
+
success: successCount,
|
|
199
|
+
failure: failureCount,
|
|
200
|
+
breakdown: d.tools
|
|
201
|
+
},
|
|
202
|
+
fileOperations: {
|
|
203
|
+
created: writeOps,
|
|
204
|
+
modified: editOps,
|
|
205
|
+
deleted: deleteOps,
|
|
206
|
+
linesAdded,
|
|
207
|
+
linesRemoved
|
|
208
|
+
}
|
|
209
|
+
};
|
|
210
|
+
})
|
|
211
|
+
});
|
|
212
|
+
// 3. Load session metadata
|
|
213
|
+
const session = await this.sessionStore.loadSession(this.sessionId);
|
|
214
|
+
if (!session) {
|
|
215
|
+
logger.error(`[${this.name}] Session not found: ${this.sessionId}`);
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
// 4. Aggregate pending deltas into single metric
|
|
219
|
+
const metric = aggregateDeltas(pendingDeltas, session, this.version);
|
|
220
|
+
// Debug: Log aggregated metric
|
|
221
|
+
logger.debug(`[${this.name}] Aggregated metric:`, {
|
|
222
|
+
name: metric.name,
|
|
223
|
+
attributes: {
|
|
224
|
+
// Identity
|
|
225
|
+
agent: metric.attributes.agent,
|
|
226
|
+
agent_version: metric.attributes.agent_version,
|
|
227
|
+
llm_model: metric.attributes.llm_model,
|
|
228
|
+
project: metric.attributes.project,
|
|
229
|
+
session_id: metric.attributes.session_id,
|
|
230
|
+
// Interaction totals
|
|
231
|
+
total_user_prompts: metric.attributes.total_user_prompts,
|
|
232
|
+
// Token totals
|
|
233
|
+
total_input_tokens: metric.attributes.total_input_tokens,
|
|
234
|
+
total_output_tokens: metric.attributes.total_output_tokens,
|
|
235
|
+
total_cache_read_input_tokens: metric.attributes.total_cache_read_input_tokens,
|
|
236
|
+
total_cache_creation_tokens: metric.attributes.total_cache_creation_tokens,
|
|
237
|
+
// Tool totals
|
|
238
|
+
total_tool_calls: metric.attributes.total_tool_calls,
|
|
239
|
+
successful_tool_calls: metric.attributes.successful_tool_calls,
|
|
240
|
+
failed_tool_calls: metric.attributes.failed_tool_calls,
|
|
241
|
+
// File operation totals
|
|
242
|
+
files_created: metric.attributes.files_created,
|
|
243
|
+
files_modified: metric.attributes.files_modified,
|
|
244
|
+
files_deleted: metric.attributes.files_deleted,
|
|
245
|
+
total_lines_added: metric.attributes.total_lines_added,
|
|
246
|
+
total_lines_removed: metric.attributes.total_lines_removed,
|
|
247
|
+
// Session info
|
|
248
|
+
session_duration_ms: metric.attributes.session_duration_ms,
|
|
249
|
+
count: metric.attributes.count
|
|
250
|
+
}
|
|
251
|
+
});
|
|
252
|
+
// 5. Send to API (single aggregated metric) or log in dry-run mode
|
|
253
|
+
if (this.dryRun) {
|
|
254
|
+
// Dry-run mode: Log what would be sent without actually sending
|
|
255
|
+
logger.info(`[${this.name}] [DRY-RUN] Would send metric to API:`, {
|
|
256
|
+
endpoint: `${this.apiClient['config'].baseUrl}/v1/metrics`,
|
|
257
|
+
method: 'POST',
|
|
258
|
+
headers: {
|
|
259
|
+
'Content-Type': 'application/json',
|
|
260
|
+
'User-Agent': `CodeMie-CLI/${this.version}`,
|
|
261
|
+
'X-CodeMie-Client': this.apiClient['config'].clientType,
|
|
262
|
+
'Cookie': '[REDACTED]'
|
|
263
|
+
},
|
|
264
|
+
payload: {
|
|
265
|
+
name: metric.name,
|
|
266
|
+
attributes: metric.attributes
|
|
267
|
+
}
|
|
268
|
+
});
|
|
269
|
+
logger.info(`[${this.name}] [DRY-RUN] Skipping actual API call - ${pendingDeltas.length} deltas would be synced`);
|
|
270
|
+
}
|
|
271
|
+
else {
|
|
272
|
+
// Normal mode: Actually send to API
|
|
273
|
+
const response = await this.apiClient.sendMetric(metric);
|
|
274
|
+
if (!response.success) {
|
|
275
|
+
logger.error(`[${this.name}] Sync failed: ${response.message}`);
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
// 6. Mark deltas as synced in JSONL (atomic rewrite)
|
|
280
|
+
const syncedAt = Date.now();
|
|
281
|
+
const pendingRecordIds = new Set(pendingDeltas.map(d => d.recordId));
|
|
282
|
+
const updatedDeltas = allDeltas.map(d => pendingRecordIds.has(d.recordId)
|
|
283
|
+
? {
|
|
284
|
+
...d,
|
|
285
|
+
syncStatus: 'synced',
|
|
286
|
+
syncAttempts: d.syncAttempts + 1,
|
|
287
|
+
syncedAt
|
|
288
|
+
}
|
|
289
|
+
: d);
|
|
290
|
+
await writeJSONLAtomic(metricsFile, updatedDeltas);
|
|
291
|
+
logger.info(`[${this.name}] Successfully synced ${pendingDeltas.length} deltas`);
|
|
292
|
+
// Debug: Log which deltas were marked as synced
|
|
293
|
+
logger.debug(`[${this.name}] Marked deltas as synced:`, {
|
|
294
|
+
syncedAt: new Date(syncedAt).toISOString(),
|
|
295
|
+
recordIds: Array.from(pendingRecordIds),
|
|
296
|
+
totalDeltasInFile: updatedDeltas.length,
|
|
297
|
+
syncedCount: updatedDeltas.filter(d => d.syncStatus === 'synced').length,
|
|
298
|
+
pendingCount: updatedDeltas.filter(d => d.syncStatus === 'pending').length
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
catch (error) {
|
|
302
|
+
logger.error(`[${this.name}] Sync failed:`, error);
|
|
303
|
+
throw error;
|
|
304
|
+
}
|
|
305
|
+
finally {
|
|
306
|
+
this.isSyncing = false;
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
//# sourceMappingURL=metrics-sync.plugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics-sync.plugin.js","sourceRoot":"","sources":["../../../src/proxy/plugins/metrics-sync.plugin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAGxF;;GAEG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,OAAO,CAAmC;IAClD,OAAO,CAAC,YAAY,CAAuC;IAE3D;;OAEG;IACH,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI;IAanE;;OAEG;IACG,UAAU,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAGxF;;GAEG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,OAAO,CAAmC;IAClD,OAAO,CAAC,YAAY,CAAuC;IAE3D;;OAEG;IACH,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI;IAanE;;OAEG;IACG,UAAU,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IA0BrE;;OAEG;IACH,OAAO,CAAC,uBAAuB;IAiB/B;;OAEG;IACG,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBnE;;OAEG;IACH,MAAM,IAAI,WAAW,EAAE;IAIvB;;OAEG;IACH,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS;IAIrD;;OAEG;IACH,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,IAAI;IAOpE;;OAEG;IACH,KAAK,IAAI,IAAI;CAKd;AAKD,wBAAgB,iBAAiB,IAAI,cAAc,CAKlD;AAED,wBAAgB,mBAAmB,IAAI,IAAI,CAE1C"}
|
|
@@ -39,7 +39,14 @@ export class PluginRegistry {
|
|
|
39
39
|
logger.debug(`[PluginRegistry] Initialized plugin: ${plugin.id} (priority: ${plugin.priority})`);
|
|
40
40
|
}
|
|
41
41
|
catch (error) {
|
|
42
|
-
|
|
42
|
+
// Log as info/debug for graceful skips, error for unexpected failures
|
|
43
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
44
|
+
if (errorMessage.includes('disabled') || errorMessage.includes('not available')) {
|
|
45
|
+
logger.info(`[PluginRegistry] Skipped plugin ${plugin.id}: ${errorMessage}`);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
logger.error(`[PluginRegistry] Failed to initialize plugin ${plugin.id}:`, error);
|
|
49
|
+
}
|
|
43
50
|
// Continue with other plugins (fail gracefully)
|
|
44
51
|
}
|
|
45
52
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C;;GAEG;AACH,MAAM,OAAO,cAAc;IACjB,OAAO,GAAG,IAAI,GAAG,EAAuB,CAAC;IACzC,OAAO,GAAG,IAAI,GAAG,EAAwB,CAAC;IAC1C,YAAY,GAAG,IAAI,GAAG,EAA4B,CAAC;IAE3D;;OAEG;IACH,QAAQ,CAAC,MAAmB,EAAE,MAA8B;QAC1D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;QAEpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE;YAC1B,EAAE,EAAE,MAAM,CAAC,EAAE;YACb,OAAO,EAAE,IAAI,EAAE,kBAAkB;YACjC,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,GAAG,MAAM;SACV,CAAC,CAAC;QAEH,MAAM,CAAC,KAAK,CAAC,uCAAuC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;IACnE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,OAAsB;QACrC,MAAM,cAAc,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACtD,MAAM,YAAY,GAAuB,EAAE,CAAC;QAE5C,KAAK,MAAM,MAAM,IAAI,cAAc,EAAE,CAAC;YACpC,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;gBAC5D,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC;gBAC9C,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAE/B,MAAM,CAAC,KAAK,CAAC,wCAAwC,MAAM,CAAC,EAAE,eAAe,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAC;YACnG,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,CAAC,KAAK,CAAC,gDAAgD,MAAM,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/proxy/plugins/registry.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE/C;;GAEG;AACH,MAAM,OAAO,cAAc;IACjB,OAAO,GAAG,IAAI,GAAG,EAAuB,CAAC;IACzC,OAAO,GAAG,IAAI,GAAG,EAAwB,CAAC;IAC1C,YAAY,GAAG,IAAI,GAAG,EAA4B,CAAC;IAE3D;;OAEG;IACH,QAAQ,CAAC,MAAmB,EAAE,MAA8B;QAC1D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;QAEpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE;YAC1B,EAAE,EAAE,MAAM,CAAC,EAAE;YACb,OAAO,EAAE,IAAI,EAAE,kBAAkB;YACjC,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,GAAG,MAAM;SACV,CAAC,CAAC;QAEH,MAAM,CAAC,KAAK,CAAC,uCAAuC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC;IACnE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,OAAsB;QACrC,MAAM,cAAc,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACtD,MAAM,YAAY,GAAuB,EAAE,CAAC;QAE5C,KAAK,MAAM,MAAM,IAAI,cAAc,EAAE,CAAC;YACpC,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;gBAC5D,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC;gBAC9C,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAE/B,MAAM,CAAC,KAAK,CAAC,wCAAwC,MAAM,CAAC,EAAE,eAAe,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAC;YACnG,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,sEAAsE;gBACtE,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC5E,IAAI,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,YAAY,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;oBAChF,MAAM,CAAC,IAAI,CAAC,mCAAmC,MAAM,CAAC,EAAE,KAAK,YAAY,EAAE,CAAC,CAAC;gBAC/E,CAAC;qBAAM,CAAC;oBACN,MAAM,CAAC,KAAK,CAAC,gDAAgD,MAAM,CAAC,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;gBACpF,CAAC;gBACD,gDAAgD;YAClD,CAAC;QACH,CAAC;QAED,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACK,uBAAuB;QAC7B,MAAM,OAAO,GAAqD,EAAE,CAAC;QAErE,KAAK,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACxC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBACpB,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC;gBACpD,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;YACrC,CAAC;QACH,CAAC;QAED,qCAAqC;QACrC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC;QAEhD,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,QAAgB,EAAE,OAAgB;QACjD,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC1C,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,qBAAqB,QAAQ,EAAE,CAAC,CAAC;QACnD,CAAC;QAED,MAAM,CAAC,OAAO,GAAG,OAAO,CAAC;QAEzB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC1C,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,OAAO,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAC/B,MAAM,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC1B,CAAC;iBAAM,IAAI,CAAC,OAAO,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;gBACxC,MAAM,MAAM,CAAC,SAAS,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACH,MAAM;QACJ,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,SAAS,CAAC,QAAgB;QACxB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,QAAgB,EAAE,OAA8B;QAC3D,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC1C,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;CACF;AAED,qBAAqB;AACrB,IAAI,gBAAgB,GAA0B,IAAI,CAAC;AAEnD,MAAM,UAAU,iBAAiB;IAC/B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtB,gBAAgB,GAAG,IAAI,cAAc,EAAE,CAAC;IAC1C,CAAC;IACD,OAAO,gBAAgB,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,mBAAmB;IACjC,gBAAgB,GAAG,IAAI,CAAC;AAC1B,CAAC"}
|
|
@@ -7,8 +7,8 @@
|
|
|
7
7
|
import { IncomingHttpHeaders } from 'http';
|
|
8
8
|
import { ProxyConfig, ProxyContext } from '../types.js';
|
|
9
9
|
import { logger } from '../../utils/logger.js';
|
|
10
|
-
import { Analytics } from '../../analytics/index.js';
|
|
11
10
|
import { SSOCredentials } from '../../providers/core/types.js';
|
|
11
|
+
import type { CodeMieConfigOptions } from '../../env/types.js';
|
|
12
12
|
/**
|
|
13
13
|
* Plugin metadata and lifecycle
|
|
14
14
|
*/
|
|
@@ -38,7 +38,7 @@ export interface PluginContext {
|
|
|
38
38
|
config: ProxyConfig;
|
|
39
39
|
logger: typeof logger;
|
|
40
40
|
credentials?: SSOCredentials;
|
|
41
|
-
|
|
41
|
+
profileConfig?: CodeMieConfigOptions;
|
|
42
42
|
[key: string]: unknown;
|
|
43
43
|
}
|
|
44
44
|
/**
|
|
@@ -55,6 +55,10 @@ export interface PluginConfig {
|
|
|
55
55
|
*/
|
|
56
56
|
export interface ProxyInterceptor {
|
|
57
57
|
name: string;
|
|
58
|
+
/** Called when proxy starts (for initialization) */
|
|
59
|
+
onProxyStart?(): Promise<void>;
|
|
60
|
+
/** Called when proxy stops (for cleanup) */
|
|
61
|
+
onProxyStop?(): Promise<void>;
|
|
58
62
|
/** Called before forwarding request */
|
|
59
63
|
onRequest?(context: ProxyContext): Promise<void>;
|
|
60
64
|
/** Called after response headers received (BEFORE body streaming) */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,mBAAmB,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/proxy/plugins/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,mBAAmB,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAE/D;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,kEAAkE;IAClE,EAAE,EAAE,MAAM,CAAC;IAEX,mBAAmB;IACnB,IAAI,EAAE,MAAM,CAAC;IAEb,qBAAqB;IACrB,OAAO,EAAE,MAAM,CAAC;IAEhB,mDAAmD;IACnD,QAAQ,EAAE,MAAM,CAAC;IAEjB,6CAA6C;IAC7C,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IAExB,kCAAkC;IAClC,iBAAiB,CAAC,OAAO,EAAE,aAAa,GAAG,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;IAExF,sBAAsB;IACtB,SAAS,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,WAAW,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9B,QAAQ,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,SAAS,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,WAAW,CAAC;IACpB,MAAM,EAAE,OAAO,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,aAAa,CAAC,EAAE,oBAAoB,CAAC;IACrC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IAEb,oDAAoD;IACpD,YAAY,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAE/B,4CAA4C;IAC5C,WAAW,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAE9B,uCAAuC;IACvC,SAAS,CAAC,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEjD,qEAAqE;IACrE,iBAAiB,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvF,mEAAmE;IACnE,eAAe,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IAE/E,2CAA2C;IAC3C,kBAAkB,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEtF,0BAA0B;IAC1B,OAAO,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9D;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,mBAAmB,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB"}
|