codex-multi-auth 0.1.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 +1 -0
- package/README.md +162 -0
- package/assets/opencode-logo-ornate-dark.svg +18 -0
- package/assets/readme-hero.svg +31 -0
- package/config/README.md +87 -0
- package/config/minimal-opencode.json +13 -0
- package/config/opencode-legacy.json +571 -0
- package/config/opencode-modern.json +239 -0
- package/dist/index.d.ts +45 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3160 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/accounts/rate-limits.d.ts +22 -0
- package/dist/lib/accounts/rate-limits.d.ts.map +1 -0
- package/dist/lib/accounts/rate-limits.js +63 -0
- package/dist/lib/accounts/rate-limits.js.map +1 -0
- package/dist/lib/accounts.d.ts +95 -0
- package/dist/lib/accounts.d.ts.map +1 -0
- package/dist/lib/accounts.js +668 -0
- package/dist/lib/accounts.js.map +1 -0
- package/dist/lib/audit.d.ts +45 -0
- package/dist/lib/audit.d.ts.map +1 -0
- package/dist/lib/audit.js +131 -0
- package/dist/lib/audit.js.map +1 -0
- package/dist/lib/auth/auth.d.ts +56 -0
- package/dist/lib/auth/auth.d.ts.map +1 -0
- package/dist/lib/auth/auth.js +214 -0
- package/dist/lib/auth/auth.js.map +1 -0
- package/dist/lib/auth/browser.d.ts +34 -0
- package/dist/lib/auth/browser.d.ts.map +1 -0
- package/dist/lib/auth/browser.js +185 -0
- package/dist/lib/auth/browser.js.map +1 -0
- package/dist/lib/auth/server.d.ts +24 -0
- package/dist/lib/auth/server.d.ts.map +1 -0
- package/dist/lib/auth/server.js +116 -0
- package/dist/lib/auth/server.js.map +1 -0
- package/dist/lib/auth/token-utils.d.ts +59 -0
- package/dist/lib/auth/token-utils.d.ts.map +1 -0
- package/dist/lib/auth/token-utils.js +331 -0
- package/dist/lib/auth/token-utils.js.map +1 -0
- package/dist/lib/auth-rate-limit.d.ts +20 -0
- package/dist/lib/auth-rate-limit.d.ts.map +1 -0
- package/dist/lib/auth-rate-limit.js +91 -0
- package/dist/lib/auth-rate-limit.js.map +1 -0
- package/dist/lib/auto-update-checker.d.ts +10 -0
- package/dist/lib/auto-update-checker.d.ts.map +1 -0
- package/dist/lib/auto-update-checker.js +216 -0
- package/dist/lib/auto-update-checker.js.map +1 -0
- package/dist/lib/capability-policy.d.ts +18 -0
- package/dist/lib/capability-policy.d.ts.map +1 -0
- package/dist/lib/capability-policy.js +150 -0
- package/dist/lib/capability-policy.js.map +1 -0
- package/dist/lib/circuit-breaker.d.ts +34 -0
- package/dist/lib/circuit-breaker.d.ts.map +1 -0
- package/dist/lib/circuit-breaker.js +124 -0
- package/dist/lib/circuit-breaker.js.map +1 -0
- package/dist/lib/cli.d.ts +64 -0
- package/dist/lib/cli.d.ts.map +1 -0
- package/dist/lib/cli.js +274 -0
- package/dist/lib/cli.js.map +1 -0
- package/dist/lib/codex-cli/observability.d.ts +22 -0
- package/dist/lib/codex-cli/observability.d.ts.map +1 -0
- package/dist/lib/codex-cli/observability.js +36 -0
- package/dist/lib/codex-cli/observability.js.map +1 -0
- package/dist/lib/codex-cli/state.d.ts +86 -0
- package/dist/lib/codex-cli/state.d.ts.map +1 -0
- package/dist/lib/codex-cli/state.js +470 -0
- package/dist/lib/codex-cli/state.js.map +1 -0
- package/dist/lib/codex-cli/sync.d.ts +27 -0
- package/dist/lib/codex-cli/sync.d.ts.map +1 -0
- package/dist/lib/codex-cli/sync.js +325 -0
- package/dist/lib/codex-cli/sync.js.map +1 -0
- package/dist/lib/codex-cli/writer.d.ts +12 -0
- package/dist/lib/codex-cli/writer.d.ts.map +1 -0
- package/dist/lib/codex-cli/writer.js +388 -0
- package/dist/lib/codex-cli/writer.js.map +1 -0
- package/dist/lib/codex-manager.d.ts +2 -0
- package/dist/lib/codex-manager.d.ts.map +1 -0
- package/dist/lib/codex-manager.js +4841 -0
- package/dist/lib/codex-manager.js.map +1 -0
- package/dist/lib/config.d.ts +269 -0
- package/dist/lib/config.d.ts.map +1 -0
- package/dist/lib/config.js +789 -0
- package/dist/lib/config.js.map +1 -0
- package/dist/lib/constants.d.ts +78 -0
- package/dist/lib/constants.d.ts.map +1 -0
- package/dist/lib/constants.js +78 -0
- package/dist/lib/constants.js.map +1 -0
- package/dist/lib/context-overflow.d.ts +27 -0
- package/dist/lib/context-overflow.d.ts.map +1 -0
- package/dist/lib/context-overflow.js +124 -0
- package/dist/lib/context-overflow.js.map +1 -0
- package/dist/lib/dashboard-settings.d.ts +90 -0
- package/dist/lib/dashboard-settings.d.ts.map +1 -0
- package/dist/lib/dashboard-settings.js +327 -0
- package/dist/lib/dashboard-settings.js.map +1 -0
- package/dist/lib/entitlement-cache.d.ts +41 -0
- package/dist/lib/entitlement-cache.d.ts.map +1 -0
- package/dist/lib/entitlement-cache.js +137 -0
- package/dist/lib/entitlement-cache.js.map +1 -0
- package/dist/lib/errors.d.ts +113 -0
- package/dist/lib/errors.d.ts.map +1 -0
- package/dist/lib/errors.js +103 -0
- package/dist/lib/errors.js.map +1 -0
- package/dist/lib/forecast.d.ts +42 -0
- package/dist/lib/forecast.d.ts.map +1 -0
- package/dist/lib/forecast.js +256 -0
- package/dist/lib/forecast.js.map +1 -0
- package/dist/lib/health.d.ts +33 -0
- package/dist/lib/health.d.ts.map +1 -0
- package/dist/lib/health.js +70 -0
- package/dist/lib/health.js.map +1 -0
- package/dist/lib/index.d.ts +32 -0
- package/dist/lib/index.d.ts.map +1 -0
- package/dist/lib/index.js +32 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/live-account-sync.d.ts +39 -0
- package/dist/lib/live-account-sync.d.ts.map +1 -0
- package/dist/lib/live-account-sync.js +196 -0
- package/dist/lib/live-account-sync.js.map +1 -0
- package/dist/lib/logger.d.ts +40 -0
- package/dist/lib/logger.d.ts.map +1 -0
- package/dist/lib/logger.js +364 -0
- package/dist/lib/logger.js.map +1 -0
- package/dist/lib/oauth-success.html +338 -0
- package/dist/lib/parallel-probe.d.ts +28 -0
- package/dist/lib/parallel-probe.d.ts.map +1 -0
- package/dist/lib/parallel-probe.js +97 -0
- package/dist/lib/parallel-probe.js.map +1 -0
- package/dist/lib/preemptive-quota-scheduler.d.ts +53 -0
- package/dist/lib/preemptive-quota-scheduler.d.ts.map +1 -0
- package/dist/lib/preemptive-quota-scheduler.js +220 -0
- package/dist/lib/preemptive-quota-scheduler.js.map +1 -0
- package/dist/lib/proactive-refresh.d.ts +66 -0
- package/dist/lib/proactive-refresh.d.ts.map +1 -0
- package/dist/lib/proactive-refresh.js +143 -0
- package/dist/lib/proactive-refresh.js.map +1 -0
- package/dist/lib/prompts/codex-opencode-bridge.d.ts +19 -0
- package/dist/lib/prompts/codex-opencode-bridge.d.ts.map +1 -0
- package/dist/lib/prompts/codex-opencode-bridge.js +169 -0
- package/dist/lib/prompts/codex-opencode-bridge.js.map +1 -0
- package/dist/lib/prompts/codex.d.ts +41 -0
- package/dist/lib/prompts/codex.d.ts.map +1 -0
- package/dist/lib/prompts/codex.js +383 -0
- package/dist/lib/prompts/codex.js.map +1 -0
- package/dist/lib/prompts/opencode-codex.d.ts +25 -0
- package/dist/lib/prompts/opencode-codex.d.ts.map +1 -0
- package/dist/lib/prompts/opencode-codex.js +270 -0
- package/dist/lib/prompts/opencode-codex.js.map +1 -0
- package/dist/lib/quota-cache.d.ts +68 -0
- package/dist/lib/quota-cache.d.ts.map +1 -0
- package/dist/lib/quota-cache.js +224 -0
- package/dist/lib/quota-cache.js.map +1 -0
- package/dist/lib/quota-probe.d.ts +49 -0
- package/dist/lib/quota-probe.d.ts.map +1 -0
- package/dist/lib/quota-probe.js +368 -0
- package/dist/lib/quota-probe.js.map +1 -0
- package/dist/lib/recovery/constants.d.ts +12 -0
- package/dist/lib/recovery/constants.d.ts.map +1 -0
- package/dist/lib/recovery/constants.js +31 -0
- package/dist/lib/recovery/constants.js.map +1 -0
- package/dist/lib/recovery/index.d.ts +12 -0
- package/dist/lib/recovery/index.d.ts.map +1 -0
- package/dist/lib/recovery/index.js +12 -0
- package/dist/lib/recovery/index.js.map +1 -0
- package/dist/lib/recovery/storage.d.ts +24 -0
- package/dist/lib/recovery/storage.d.ts.map +1 -0
- package/dist/lib/recovery/storage.js +362 -0
- package/dist/lib/recovery/storage.js.map +1 -0
- package/dist/lib/recovery/types.d.ts +116 -0
- package/dist/lib/recovery/types.d.ts.map +1 -0
- package/dist/lib/recovery/types.js +7 -0
- package/dist/lib/recovery/types.js.map +1 -0
- package/dist/lib/recovery.d.ts +31 -0
- package/dist/lib/recovery.d.ts.map +1 -0
- package/dist/lib/recovery.js +313 -0
- package/dist/lib/recovery.js.map +1 -0
- package/dist/lib/refresh-guardian.d.ts +31 -0
- package/dist/lib/refresh-guardian.d.ts.map +1 -0
- package/dist/lib/refresh-guardian.js +151 -0
- package/dist/lib/refresh-guardian.js.map +1 -0
- package/dist/lib/refresh-lease.d.ts +37 -0
- package/dist/lib/refresh-lease.d.ts.map +1 -0
- package/dist/lib/refresh-lease.js +335 -0
- package/dist/lib/refresh-lease.js.map +1 -0
- package/dist/lib/refresh-queue.d.ts +117 -0
- package/dist/lib/refresh-queue.d.ts.map +1 -0
- package/dist/lib/refresh-queue.js +297 -0
- package/dist/lib/refresh-queue.js.map +1 -0
- package/dist/lib/request/failure-policy.d.ts +42 -0
- package/dist/lib/request/failure-policy.d.ts.map +1 -0
- package/dist/lib/request/failure-policy.js +133 -0
- package/dist/lib/request/failure-policy.js.map +1 -0
- package/dist/lib/request/fetch-helpers.d.ts +152 -0
- package/dist/lib/request/fetch-helpers.d.ts.map +1 -0
- package/dist/lib/request/fetch-helpers.js +704 -0
- package/dist/lib/request/fetch-helpers.js.map +1 -0
- package/dist/lib/request/helpers/input-utils.d.ts +7 -0
- package/dist/lib/request/helpers/input-utils.d.ts.map +1 -0
- package/dist/lib/request/helpers/input-utils.js +214 -0
- package/dist/lib/request/helpers/input-utils.js.map +1 -0
- package/dist/lib/request/helpers/model-map.d.ts +28 -0
- package/dist/lib/request/helpers/model-map.d.ts.map +1 -0
- package/dist/lib/request/helpers/model-map.js +133 -0
- package/dist/lib/request/helpers/model-map.js.map +1 -0
- package/dist/lib/request/helpers/tool-utils.d.ts +29 -0
- package/dist/lib/request/helpers/tool-utils.d.ts.map +1 -0
- package/dist/lib/request/helpers/tool-utils.js +117 -0
- package/dist/lib/request/helpers/tool-utils.js.map +1 -0
- package/dist/lib/request/rate-limit-backoff.d.ts +17 -0
- package/dist/lib/request/rate-limit-backoff.d.ts.map +1 -0
- package/dist/lib/request/rate-limit-backoff.js +83 -0
- package/dist/lib/request/rate-limit-backoff.js.map +1 -0
- package/dist/lib/request/request-transformer.d.ts +107 -0
- package/dist/lib/request/request-transformer.d.ts.map +1 -0
- package/dist/lib/request/request-transformer.js +814 -0
- package/dist/lib/request/request-transformer.js.map +1 -0
- package/dist/lib/request/response-handler.d.ts +23 -0
- package/dist/lib/request/response-handler.d.ts.map +1 -0
- package/dist/lib/request/response-handler.js +155 -0
- package/dist/lib/request/response-handler.js.map +1 -0
- package/dist/lib/request/stream-failover.d.ts +21 -0
- package/dist/lib/request/stream-failover.d.ts.map +1 -0
- package/dist/lib/request/stream-failover.js +204 -0
- package/dist/lib/request/stream-failover.js.map +1 -0
- package/dist/lib/rotation.d.ts +146 -0
- package/dist/lib/rotation.d.ts.map +1 -0
- package/dist/lib/rotation.js +321 -0
- package/dist/lib/rotation.js.map +1 -0
- package/dist/lib/runtime-paths.d.ts +58 -0
- package/dist/lib/runtime-paths.d.ts.map +1 -0
- package/dist/lib/runtime-paths.js +164 -0
- package/dist/lib/runtime-paths.js.map +1 -0
- package/dist/lib/schemas.d.ts +435 -0
- package/dist/lib/schemas.d.ts.map +1 -0
- package/dist/lib/schemas.js +268 -0
- package/dist/lib/schemas.js.map +1 -0
- package/dist/lib/session-affinity.d.ts +23 -0
- package/dist/lib/session-affinity.d.ts.map +1 -0
- package/dist/lib/session-affinity.js +127 -0
- package/dist/lib/session-affinity.js.map +1 -0
- package/dist/lib/shutdown.d.ts +7 -0
- package/dist/lib/shutdown.d.ts.map +1 -0
- package/dist/lib/shutdown.js +43 -0
- package/dist/lib/shutdown.js.map +1 -0
- package/dist/lib/storage/migrations.d.ts +59 -0
- package/dist/lib/storage/migrations.d.ts.map +1 -0
- package/dist/lib/storage/migrations.js +41 -0
- package/dist/lib/storage/migrations.js.map +1 -0
- package/dist/lib/storage/paths.d.ts +51 -0
- package/dist/lib/storage/paths.d.ts.map +1 -0
- package/dist/lib/storage/paths.js +152 -0
- package/dist/lib/storage/paths.js.map +1 -0
- package/dist/lib/storage.d.ts +106 -0
- package/dist/lib/storage.d.ts.map +1 -0
- package/dist/lib/storage.js +896 -0
- package/dist/lib/storage.js.map +1 -0
- package/dist/lib/table-formatter.d.ts +32 -0
- package/dist/lib/table-formatter.d.ts.map +1 -0
- package/dist/lib/table-formatter.js +44 -0
- package/dist/lib/table-formatter.js.map +1 -0
- package/dist/lib/tools/hashline-tools.d.ts +51 -0
- package/dist/lib/tools/hashline-tools.d.ts.map +1 -0
- package/dist/lib/tools/hashline-tools.js +456 -0
- package/dist/lib/tools/hashline-tools.js.map +1 -0
- package/dist/lib/types.d.ts +130 -0
- package/dist/lib/types.d.ts.map +1 -0
- package/dist/lib/types.js +2 -0
- package/dist/lib/types.js.map +1 -0
- package/dist/lib/ui/ansi.d.ts +40 -0
- package/dist/lib/ui/ansi.d.ts.map +1 -0
- package/dist/lib/ui/ansi.js +68 -0
- package/dist/lib/ui/ansi.js.map +1 -0
- package/dist/lib/ui/auth-menu.d.ts +76 -0
- package/dist/lib/ui/auth-menu.d.ts.map +1 -0
- package/dist/lib/ui/auth-menu.js +590 -0
- package/dist/lib/ui/auth-menu.js.map +1 -0
- package/dist/lib/ui/confirm.d.ts +11 -0
- package/dist/lib/ui/confirm.d.ts.map +1 -0
- package/dist/lib/ui/confirm.js +29 -0
- package/dist/lib/ui/confirm.js.map +1 -0
- package/dist/lib/ui/copy.d.ts +123 -0
- package/dist/lib/ui/copy.d.ts.map +1 -0
- package/dist/lib/ui/copy.js +127 -0
- package/dist/lib/ui/copy.js.map +1 -0
- package/dist/lib/ui/format.d.ts +62 -0
- package/dist/lib/ui/format.d.ts.map +1 -0
- package/dist/lib/ui/format.js +205 -0
- package/dist/lib/ui/format.js.map +1 -0
- package/dist/lib/ui/runtime.d.ts +43 -0
- package/dist/lib/ui/runtime.d.ts.map +1 -0
- package/dist/lib/ui/runtime.js +69 -0
- package/dist/lib/ui/runtime.js.map +1 -0
- package/dist/lib/ui/select.d.ts +60 -0
- package/dist/lib/ui/select.d.ts.map +1 -0
- package/dist/lib/ui/select.js +467 -0
- package/dist/lib/ui/select.js.map +1 -0
- package/dist/lib/ui/theme.d.ts +56 -0
- package/dist/lib/ui/theme.d.ts.map +1 -0
- package/dist/lib/ui/theme.js +186 -0
- package/dist/lib/ui/theme.js.map +1 -0
- package/dist/lib/unified-settings.d.ts +71 -0
- package/dist/lib/unified-settings.d.ts.map +1 -0
- package/dist/lib/unified-settings.js +299 -0
- package/dist/lib/unified-settings.js.map +1 -0
- package/dist/lib/utils.d.ts +29 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +54 -0
- package/dist/lib/utils.js.map +1 -0
- package/package.json +115 -0
- package/scripts/audit-dev-allowlist.js +128 -0
- package/scripts/bench-format/hashline-v2.mjs +642 -0
- package/scripts/bench-format/models.mjs +105 -0
- package/scripts/bench-format/opencode.mjs +205 -0
- package/scripts/bench-format/render.mjs +496 -0
- package/scripts/bench-format/stats.mjs +54 -0
- package/scripts/bench-format/tasks.mjs +151 -0
- package/scripts/benchmark-edit-formats.mjs +1161 -0
- package/scripts/benchmark-render-dashboard.mjs +49 -0
- package/scripts/codex-multi-auth.js +6 -0
- package/scripts/codex-routing.js +34 -0
- package/scripts/codex.js +122 -0
- package/scripts/copy-oauth-success.js +37 -0
- package/scripts/install-opencode-codex-auth.js +193 -0
- package/scripts/test-all-models.sh +7 -0
- package/scripts/test-model-matrix.js +424 -0
- package/scripts/validate-model-map.sh +7 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-account-sync.d.ts","sourceRoot":"","sources":["../../lib/live-account-sync.ts"],"names":[],"mappings":"AAMA,MAAM,WAAW,sBAAsB;IACtC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,uBAAuB;IACvC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,OAAO,EAAE,OAAO,CAAC;IACjB,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACnB;AA0CD;;;GAGG;AACH,qBAAa,eAAe;IAC3B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsB;IAC7C,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,OAAO,CAA0B;IACzC,OAAO,CAAC,SAAS,CAA+C;IAChE,OAAO,CAAC,aAAa,CAA8C;IACnE,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,gBAAgB,CAAuB;IAC/C,OAAO,CAAC,UAAU,CAAuB;IACzC,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,UAAU,CAAK;IACvB,OAAO,CAAC,cAAc,CAA8B;gBAExC,MAAM,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,GAAE,sBAA2B;IAMvE,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwC7C,IAAI,IAAI,IAAI;IAgBZ,WAAW,IAAI,uBAAuB;IAWtC,OAAO,CAAC,cAAc;YAUR,QAAQ;YAiBR,SAAS;CAkCvB"}
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
import { promises as fs, watch as fsWatch } from "node:fs";
|
|
2
|
+
import { basename, dirname } from "node:path";
|
|
3
|
+
import { createLogger } from "./logger.js";
|
|
4
|
+
const log = createLogger("live-account-sync");
|
|
5
|
+
/**
|
|
6
|
+
* Convert an fs.watch filename value to a UTF-8 string or null.
|
|
7
|
+
*
|
|
8
|
+
* @param filename - The value supplied by fs.watch listeners; may be a `string`, `Buffer`, or `null`. Buffers are decoded as UTF-8.
|
|
9
|
+
* @returns `filename` as a UTF-8 string, or `null` when the input is `null`.
|
|
10
|
+
*/
|
|
11
|
+
function normalizeFsWatchFilename(filename) {
|
|
12
|
+
if (filename === null)
|
|
13
|
+
return null;
|
|
14
|
+
if (typeof filename === "string")
|
|
15
|
+
return filename;
|
|
16
|
+
return filename.toString("utf-8");
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Read the file modification time (mtime) for a given filesystem path in milliseconds.
|
|
20
|
+
*
|
|
21
|
+
* This is a point-in-time snapshot — the value may change immediately due to concurrent writes and callers
|
|
22
|
+
* should not assume stability across subsequent operations. On some platforms (notably Windows) timestamp
|
|
23
|
+
* resolution can be coarse; callers should account for that when comparing mtime values.
|
|
24
|
+
*
|
|
25
|
+
* Treat `path` as sensitive when logging: redact any tokens or secrets before emitting it.
|
|
26
|
+
*
|
|
27
|
+
* @param path - Filesystem path to inspect
|
|
28
|
+
* @returns The file's mtime in milliseconds, or `null` if the path does not exist or the mtime is not finite
|
|
29
|
+
*/
|
|
30
|
+
async function readMtimeMs(path) {
|
|
31
|
+
try {
|
|
32
|
+
const stats = await fs.stat(path);
|
|
33
|
+
return Number.isFinite(stats.mtimeMs) ? stats.mtimeMs : null;
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
const code = error.code;
|
|
37
|
+
if (code === "ENOENT" || code === "EBUSY" || code === "EACCES")
|
|
38
|
+
return null;
|
|
39
|
+
throw error;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
function summarizeWatchPath(path) {
|
|
43
|
+
if (!path)
|
|
44
|
+
return "<unknown>";
|
|
45
|
+
return basename(path);
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Watches account storage and triggers a reload callback when file content
|
|
49
|
+
* changes. Uses fs.watch + polling fallback for Windows reliability.
|
|
50
|
+
*/
|
|
51
|
+
export class LiveAccountSync {
|
|
52
|
+
reload;
|
|
53
|
+
debounceMs;
|
|
54
|
+
pollIntervalMs;
|
|
55
|
+
watcher = null;
|
|
56
|
+
pollTimer = null;
|
|
57
|
+
debounceTimer = null;
|
|
58
|
+
currentPath = null;
|
|
59
|
+
running = false;
|
|
60
|
+
lastKnownMtimeMs = null;
|
|
61
|
+
lastSyncAt = null;
|
|
62
|
+
reloadCount = 0;
|
|
63
|
+
errorCount = 0;
|
|
64
|
+
reloadInFlight = null;
|
|
65
|
+
constructor(reload, options = {}) {
|
|
66
|
+
this.reload = reload;
|
|
67
|
+
this.debounceMs = Math.max(50, Math.floor(options.debounceMs ?? 250));
|
|
68
|
+
this.pollIntervalMs = Math.max(500, Math.floor(options.pollIntervalMs ?? 2_000));
|
|
69
|
+
}
|
|
70
|
+
async syncToPath(path) {
|
|
71
|
+
if (!path)
|
|
72
|
+
return;
|
|
73
|
+
if (this.currentPath === path && this.running)
|
|
74
|
+
return;
|
|
75
|
+
this.stop();
|
|
76
|
+
this.currentPath = path;
|
|
77
|
+
this.lastKnownMtimeMs = await readMtimeMs(path);
|
|
78
|
+
const targetDir = dirname(path);
|
|
79
|
+
const targetName = basename(path);
|
|
80
|
+
try {
|
|
81
|
+
this.watcher = fsWatch(targetDir, { persistent: false }, (_eventType, filename) => {
|
|
82
|
+
const name = normalizeFsWatchFilename(filename);
|
|
83
|
+
if (!name) {
|
|
84
|
+
this.scheduleReload("watch");
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (name === targetName || name.startsWith(`${targetName}.`)) {
|
|
88
|
+
this.scheduleReload("watch");
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
catch (error) {
|
|
93
|
+
this.errorCount += 1;
|
|
94
|
+
log.warn("Failed to start fs.watch for account storage", {
|
|
95
|
+
path: summarizeWatchPath(path),
|
|
96
|
+
error: error instanceof Error ? error.message : String(error),
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
this.pollTimer = setInterval(() => {
|
|
100
|
+
void this.pollOnce();
|
|
101
|
+
}, this.pollIntervalMs);
|
|
102
|
+
if (typeof this.pollTimer === "object" && "unref" in this.pollTimer && typeof this.pollTimer.unref === "function") {
|
|
103
|
+
this.pollTimer.unref();
|
|
104
|
+
}
|
|
105
|
+
this.running = true;
|
|
106
|
+
}
|
|
107
|
+
stop() {
|
|
108
|
+
this.running = false;
|
|
109
|
+
if (this.watcher) {
|
|
110
|
+
this.watcher.close();
|
|
111
|
+
this.watcher = null;
|
|
112
|
+
}
|
|
113
|
+
if (this.pollTimer) {
|
|
114
|
+
clearInterval(this.pollTimer);
|
|
115
|
+
this.pollTimer = null;
|
|
116
|
+
}
|
|
117
|
+
if (this.debounceTimer) {
|
|
118
|
+
clearTimeout(this.debounceTimer);
|
|
119
|
+
this.debounceTimer = null;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
getSnapshot() {
|
|
123
|
+
return {
|
|
124
|
+
path: this.currentPath,
|
|
125
|
+
running: this.running,
|
|
126
|
+
lastKnownMtimeMs: this.lastKnownMtimeMs,
|
|
127
|
+
lastSyncAt: this.lastSyncAt,
|
|
128
|
+
reloadCount: this.reloadCount,
|
|
129
|
+
errorCount: this.errorCount,
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
scheduleReload(reason) {
|
|
133
|
+
if (!this.running)
|
|
134
|
+
return;
|
|
135
|
+
if (this.debounceTimer) {
|
|
136
|
+
clearTimeout(this.debounceTimer);
|
|
137
|
+
}
|
|
138
|
+
this.debounceTimer = setTimeout(() => {
|
|
139
|
+
void this.runReload(reason);
|
|
140
|
+
}, this.debounceMs);
|
|
141
|
+
}
|
|
142
|
+
async pollOnce() {
|
|
143
|
+
if (!this.running || !this.currentPath)
|
|
144
|
+
return;
|
|
145
|
+
try {
|
|
146
|
+
const currentMtime = await readMtimeMs(this.currentPath);
|
|
147
|
+
if (currentMtime !== this.lastKnownMtimeMs) {
|
|
148
|
+
this.lastKnownMtimeMs = currentMtime;
|
|
149
|
+
this.scheduleReload("poll");
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
catch (error) {
|
|
153
|
+
this.errorCount += 1;
|
|
154
|
+
log.debug("Live account sync poll failed", {
|
|
155
|
+
path: summarizeWatchPath(this.currentPath),
|
|
156
|
+
error: error instanceof Error ? error.message : String(error),
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
async runReload(reason) {
|
|
161
|
+
if (!this.running || !this.currentPath)
|
|
162
|
+
return;
|
|
163
|
+
const targetPath = this.currentPath;
|
|
164
|
+
if (this.reloadInFlight) {
|
|
165
|
+
await this.reloadInFlight;
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
this.reloadInFlight = (async () => {
|
|
169
|
+
try {
|
|
170
|
+
await this.reload();
|
|
171
|
+
this.lastSyncAt = Date.now();
|
|
172
|
+
this.reloadCount += 1;
|
|
173
|
+
this.lastKnownMtimeMs = await readMtimeMs(targetPath);
|
|
174
|
+
log.debug("Reloaded account manager from live storage update", {
|
|
175
|
+
reason,
|
|
176
|
+
path: summarizeWatchPath(targetPath),
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
catch (error) {
|
|
180
|
+
this.errorCount += 1;
|
|
181
|
+
log.warn("Live account sync reload failed", {
|
|
182
|
+
reason,
|
|
183
|
+
path: summarizeWatchPath(targetPath),
|
|
184
|
+
error: error instanceof Error ? error.message : String(error),
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
})();
|
|
188
|
+
try {
|
|
189
|
+
await this.reloadInFlight;
|
|
190
|
+
}
|
|
191
|
+
finally {
|
|
192
|
+
this.reloadInFlight = null;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
//# sourceMappingURL=live-account-sync.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"live-account-sync.js","sourceRoot":"","sources":["../../lib/live-account-sync.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export type LogLevel = "debug" | "info" | "warn" | "error";
|
|
2
|
+
export interface LogClient {
|
|
3
|
+
app?: {
|
|
4
|
+
log?: (options: {
|
|
5
|
+
body: {
|
|
6
|
+
service: string;
|
|
7
|
+
level: LogLevel;
|
|
8
|
+
message: string;
|
|
9
|
+
extra?: Record<string, unknown>;
|
|
10
|
+
};
|
|
11
|
+
}) => unknown;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
declare function maskEmail(email: string): string;
|
|
15
|
+
export declare const LOGGING_ENABLED: boolean;
|
|
16
|
+
export declare const REQUEST_BODY_LOGGING_ENABLED: boolean;
|
|
17
|
+
export declare const DEBUG_ENABLED: boolean;
|
|
18
|
+
export declare const LOG_LEVEL: LogLevel;
|
|
19
|
+
export declare function setCorrelationId(id?: string): string;
|
|
20
|
+
export declare function getCorrelationId(): string | null;
|
|
21
|
+
export declare function clearCorrelationId(): void;
|
|
22
|
+
export declare function initLogger(newClient: LogClient): void;
|
|
23
|
+
declare function formatDuration(ms: number): string;
|
|
24
|
+
export declare function logRequest(stage: string, data: Record<string, unknown>): void;
|
|
25
|
+
export declare function logDebug(message: string, data?: unknown): void;
|
|
26
|
+
export declare function logInfo(message: string, data?: unknown): void;
|
|
27
|
+
export declare function logWarn(message: string, data?: unknown): void;
|
|
28
|
+
export declare function logError(message: string, data?: unknown): void;
|
|
29
|
+
export interface ScopedLogger {
|
|
30
|
+
debug(message: string, data?: unknown): void;
|
|
31
|
+
info(message: string, data?: unknown): void;
|
|
32
|
+
warn(message: string, data?: unknown): void;
|
|
33
|
+
error(message: string, data?: unknown): void;
|
|
34
|
+
time(label: string): () => number;
|
|
35
|
+
timeEnd(label: string, startTime: number): void;
|
|
36
|
+
}
|
|
37
|
+
export declare function createLogger(scope: string): ScopedLogger;
|
|
38
|
+
export declare function getRequestId(): number;
|
|
39
|
+
export { formatDuration, maskEmail };
|
|
40
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../lib/logger.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAE3D,MAAM,WAAW,SAAS;IACzB,GAAG,CAAC,EAAE;QACL,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE;YACf,IAAI,EAAE;gBACL,OAAO,EAAE,MAAM,CAAC;gBAChB,KAAK,EAAE,QAAQ,CAAC;gBAChB,OAAO,EAAE,MAAM,CAAC;gBAChB,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;aAChC,CAAC;SACF,KAAK,OAAO,CAAC;KACd,CAAC;CACF;AA4CD,iBAAS,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CASxC;AA8CD,eAAO,MAAM,eAAe,SAAoD,CAAC;AACjF,eAAO,MAAM,4BAA4B,SAA8C,CAAC;AACxF,eAAO,MAAM,aAAa,SAA4D,CAAC;AACvF,eAAO,MAAM,SAAS,UAAoD,CAAC;AAU3E,wBAAgB,gBAAgB,CAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAGpD;AAED,wBAAgB,gBAAgB,IAAI,MAAM,GAAG,IAAI,CAEhD;AAED,wBAAgB,kBAAkB,IAAI,IAAI,CAEzC;AAED,wBAAgB,UAAU,CAAC,SAAS,EAAE,SAAS,GAAG,IAAI,CAErD;AAsGD,iBAAS,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAM1C;AA+BD,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAqC7E;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAM9D;AAED,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAM7D;AAED,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAK7D;AAED,wBAAgB,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAI9D;AAED,MAAM,WAAW,YAAY;IAC5B,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC7C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC5C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC5C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IAC7C,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,MAAM,CAAC;IAClC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAChD;AAKD,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY,CA0DxD;AAED,wBAAgB,YAAY,IAAI,MAAM,CAErC;AAED,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,CAAC"}
|
|
@@ -0,0 +1,364 @@
|
|
|
1
|
+
import { writeFileSync, mkdirSync, existsSync } from "node:fs";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { randomUUID } from "node:crypto";
|
|
4
|
+
import { PLUGIN_NAME } from "./constants.js";
|
|
5
|
+
import { getCodexLogDir } from "./runtime-paths.js";
|
|
6
|
+
const LOG_LEVEL_PRIORITY = {
|
|
7
|
+
debug: 0,
|
|
8
|
+
info: 1,
|
|
9
|
+
warn: 2,
|
|
10
|
+
error: 3,
|
|
11
|
+
};
|
|
12
|
+
const TOKEN_PATTERNS = [
|
|
13
|
+
/eyJ[A-Za-z0-9_-]+\.eyJ[A-Za-z0-9_-]+\.[A-Za-z0-9_-]+/g,
|
|
14
|
+
/[a-f0-9]{40,}/gi,
|
|
15
|
+
/sk-[A-Za-z0-9]{20,}/g,
|
|
16
|
+
/Bearer\s+\S+/gi,
|
|
17
|
+
];
|
|
18
|
+
const EMAIL_PATTERN = /[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/g;
|
|
19
|
+
const SENSITIVE_KEYS = new Set([
|
|
20
|
+
"access",
|
|
21
|
+
"accesstoken",
|
|
22
|
+
"access_token",
|
|
23
|
+
"refresh",
|
|
24
|
+
"refreshtoken",
|
|
25
|
+
"refresh_token",
|
|
26
|
+
"token",
|
|
27
|
+
"authorization",
|
|
28
|
+
"apikey",
|
|
29
|
+
"api_key",
|
|
30
|
+
"secret",
|
|
31
|
+
"password",
|
|
32
|
+
"credential",
|
|
33
|
+
"id_token",
|
|
34
|
+
"idtoken",
|
|
35
|
+
"email",
|
|
36
|
+
"accountid",
|
|
37
|
+
"account_id",
|
|
38
|
+
]);
|
|
39
|
+
function maskToken(token) {
|
|
40
|
+
if (token.length <= 12)
|
|
41
|
+
return "***MASKED***";
|
|
42
|
+
return `${token.slice(0, 6)}...${token.slice(-4)}`;
|
|
43
|
+
}
|
|
44
|
+
function maskEmail(email) {
|
|
45
|
+
const atIndex = email.indexOf("@");
|
|
46
|
+
if (atIndex < 0)
|
|
47
|
+
return "***@***";
|
|
48
|
+
const local = email.slice(0, atIndex);
|
|
49
|
+
const domain = email.slice(atIndex + 1);
|
|
50
|
+
const parts = domain.split(".");
|
|
51
|
+
const tld = parts.pop() || "";
|
|
52
|
+
const prefix = local.slice(0, Math.min(2, local.length));
|
|
53
|
+
return `${prefix}***@***.${tld}`;
|
|
54
|
+
}
|
|
55
|
+
function maskString(value) {
|
|
56
|
+
let result = value;
|
|
57
|
+
// Mask emails first (before token patterns might match parts of them)
|
|
58
|
+
result = result.replace(EMAIL_PATTERN, (match) => maskEmail(match));
|
|
59
|
+
for (const pattern of TOKEN_PATTERNS) {
|
|
60
|
+
result = result.replace(pattern, (match) => maskToken(match));
|
|
61
|
+
}
|
|
62
|
+
return result;
|
|
63
|
+
}
|
|
64
|
+
function sanitizeValue(value, depth = 0) {
|
|
65
|
+
if (depth > 10)
|
|
66
|
+
return "[max depth]";
|
|
67
|
+
if (typeof value === "string") {
|
|
68
|
+
return maskString(value);
|
|
69
|
+
}
|
|
70
|
+
if (Array.isArray(value)) {
|
|
71
|
+
return value.map((item) => sanitizeValue(item, depth + 1));
|
|
72
|
+
}
|
|
73
|
+
if (value !== null && typeof value === "object") {
|
|
74
|
+
const sanitized = {};
|
|
75
|
+
for (const [key, val] of Object.entries(value)) {
|
|
76
|
+
const normalizedKey = key.toLowerCase().replace(/[-_]/g, "");
|
|
77
|
+
if (SENSITIVE_KEYS.has(normalizedKey)) {
|
|
78
|
+
sanitized[key] = typeof val === "string" ? maskToken(val) : "***MASKED***";
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
sanitized[key] = sanitizeValue(val, depth + 1);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return sanitized;
|
|
85
|
+
}
|
|
86
|
+
return value;
|
|
87
|
+
}
|
|
88
|
+
function parseLogLevel(value) {
|
|
89
|
+
if (!value)
|
|
90
|
+
return "info";
|
|
91
|
+
const normalized = value.toLowerCase().trim();
|
|
92
|
+
if (normalized in LOG_LEVEL_PRIORITY)
|
|
93
|
+
return normalized;
|
|
94
|
+
return "info";
|
|
95
|
+
}
|
|
96
|
+
export const LOGGING_ENABLED = process.env.ENABLE_PLUGIN_REQUEST_LOGGING === "1";
|
|
97
|
+
export const REQUEST_BODY_LOGGING_ENABLED = process.env.CODEX_PLUGIN_LOG_BODIES === "1";
|
|
98
|
+
export const DEBUG_ENABLED = process.env.DEBUG_CODEX_PLUGIN === "1" || LOGGING_ENABLED;
|
|
99
|
+
export const LOG_LEVEL = parseLogLevel(process.env.CODEX_PLUGIN_LOG_LEVEL);
|
|
100
|
+
const CONSOLE_LOG_ENABLED = process.env.CODEX_CONSOLE_LOG === "1";
|
|
101
|
+
const LOG_DIR = join(getCodexLogDir(), "codex-plugin");
|
|
102
|
+
const LOG_DIR_RETRYABLE_ERRORS = new Set(["EBUSY", "EPERM"]);
|
|
103
|
+
const LOG_DIR_MAX_ATTEMPTS = 3;
|
|
104
|
+
const LOG_DIR_RETRY_BASE_DELAY_MS = 10;
|
|
105
|
+
let client = null;
|
|
106
|
+
let currentCorrelationId = null;
|
|
107
|
+
export function setCorrelationId(id) {
|
|
108
|
+
currentCorrelationId = id ?? randomUUID();
|
|
109
|
+
return currentCorrelationId;
|
|
110
|
+
}
|
|
111
|
+
export function getCorrelationId() {
|
|
112
|
+
return currentCorrelationId;
|
|
113
|
+
}
|
|
114
|
+
export function clearCorrelationId() {
|
|
115
|
+
currentCorrelationId = null;
|
|
116
|
+
}
|
|
117
|
+
export function initLogger(newClient) {
|
|
118
|
+
client = newClient;
|
|
119
|
+
}
|
|
120
|
+
function logToApp(level, message, data, service = PLUGIN_NAME) {
|
|
121
|
+
const appLog = client?.app?.log;
|
|
122
|
+
if (!appLog)
|
|
123
|
+
return;
|
|
124
|
+
const sanitizedMessage = maskString(message).replace(/[\r\n]+/g, " ");
|
|
125
|
+
const sanitizedData = data === undefined ? undefined : sanitizeValue(data);
|
|
126
|
+
const correlationId = currentCorrelationId;
|
|
127
|
+
const extraData = {};
|
|
128
|
+
if (correlationId) {
|
|
129
|
+
extraData.correlationId = correlationId;
|
|
130
|
+
}
|
|
131
|
+
if (sanitizedData !== undefined) {
|
|
132
|
+
extraData.data = typeof sanitizedData === "object" ? sanitizedData : { value: sanitizedData };
|
|
133
|
+
}
|
|
134
|
+
const extra = Object.keys(extraData).length > 0 ? extraData : undefined;
|
|
135
|
+
try {
|
|
136
|
+
const result = appLog({
|
|
137
|
+
body: {
|
|
138
|
+
service,
|
|
139
|
+
level,
|
|
140
|
+
message: sanitizedMessage,
|
|
141
|
+
extra,
|
|
142
|
+
},
|
|
143
|
+
});
|
|
144
|
+
if (result && typeof result.catch === "function") {
|
|
145
|
+
result.catch(() => { });
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
catch {
|
|
149
|
+
// Ignore app log failures
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
function logToConsole(level, message, data) {
|
|
153
|
+
if (!CONSOLE_LOG_ENABLED)
|
|
154
|
+
return;
|
|
155
|
+
const sanitizedMessage = maskString(message);
|
|
156
|
+
const sanitizedData = data === undefined ? undefined : sanitizeValue(data);
|
|
157
|
+
if (sanitizedData !== undefined) {
|
|
158
|
+
if (level === "warn")
|
|
159
|
+
console.warn(sanitizedMessage, sanitizedData);
|
|
160
|
+
else if (level === "error")
|
|
161
|
+
console.error(sanitizedMessage, sanitizedData);
|
|
162
|
+
else
|
|
163
|
+
console.log(sanitizedMessage, sanitizedData);
|
|
164
|
+
return;
|
|
165
|
+
}
|
|
166
|
+
if (level === "warn")
|
|
167
|
+
console.warn(sanitizedMessage);
|
|
168
|
+
else if (level === "error")
|
|
169
|
+
console.error(sanitizedMessage);
|
|
170
|
+
else
|
|
171
|
+
console.log(sanitizedMessage);
|
|
172
|
+
}
|
|
173
|
+
if (LOGGING_ENABLED) {
|
|
174
|
+
logToConsole("info", REQUEST_BODY_LOGGING_ENABLED
|
|
175
|
+
? `[${PLUGIN_NAME}] Request logging ENABLED (raw payload capture ON) - logs will be saved to: ${LOG_DIR}`
|
|
176
|
+
: `[${PLUGIN_NAME}] Request logging ENABLED (metadata only; set CODEX_PLUGIN_LOG_BODIES=1 for raw payloads) - logs will be saved to: ${LOG_DIR}`);
|
|
177
|
+
}
|
|
178
|
+
if (DEBUG_ENABLED && !LOGGING_ENABLED) {
|
|
179
|
+
logToConsole("info", `[${PLUGIN_NAME}] Debug logging ENABLED (level: ${LOG_LEVEL})`);
|
|
180
|
+
}
|
|
181
|
+
let requestCounter = 0;
|
|
182
|
+
function sanitizeRequestLogData(data) {
|
|
183
|
+
if (REQUEST_BODY_LOGGING_ENABLED) {
|
|
184
|
+
return data;
|
|
185
|
+
}
|
|
186
|
+
let omittedPayloads = false;
|
|
187
|
+
const sanitized = {};
|
|
188
|
+
for (const [key, value] of Object.entries(data)) {
|
|
189
|
+
const normalizedKey = key.toLowerCase().replace(/[-_]/g, "");
|
|
190
|
+
if (normalizedKey === "body" || normalizedKey === "fullcontent") {
|
|
191
|
+
omittedPayloads = true;
|
|
192
|
+
continue;
|
|
193
|
+
}
|
|
194
|
+
sanitized[key] = value;
|
|
195
|
+
}
|
|
196
|
+
if (omittedPayloads) {
|
|
197
|
+
sanitized.payloadsOmitted = true;
|
|
198
|
+
}
|
|
199
|
+
return sanitized;
|
|
200
|
+
}
|
|
201
|
+
function shouldLog(level) {
|
|
202
|
+
if (level === "error")
|
|
203
|
+
return true;
|
|
204
|
+
if (!DEBUG_ENABLED && !LOGGING_ENABLED)
|
|
205
|
+
return false;
|
|
206
|
+
return LOG_LEVEL_PRIORITY[level] >= LOG_LEVEL_PRIORITY[LOG_LEVEL];
|
|
207
|
+
}
|
|
208
|
+
function formatDuration(ms) {
|
|
209
|
+
if (ms < 1000)
|
|
210
|
+
return `${Math.round(ms)}ms`;
|
|
211
|
+
if (ms < 60000)
|
|
212
|
+
return `${(ms / 1000).toFixed(2)}s`;
|
|
213
|
+
const minutes = Math.floor(ms / 60000);
|
|
214
|
+
const seconds = ((ms % 60000) / 1000).toFixed(1);
|
|
215
|
+
return `${minutes}m ${seconds}s`;
|
|
216
|
+
}
|
|
217
|
+
function ensureLogDir(path) {
|
|
218
|
+
for (let attempt = 0; attempt < LOG_DIR_MAX_ATTEMPTS; attempt += 1) {
|
|
219
|
+
try {
|
|
220
|
+
if (!existsSync(path)) {
|
|
221
|
+
mkdirSync(path, { recursive: true, mode: 0o700 });
|
|
222
|
+
}
|
|
223
|
+
return true;
|
|
224
|
+
}
|
|
225
|
+
catch (error) {
|
|
226
|
+
const code = error.code ?? "";
|
|
227
|
+
const canRetry = LOG_DIR_RETRYABLE_ERRORS.has(code);
|
|
228
|
+
if (canRetry && attempt + 1 < LOG_DIR_MAX_ATTEMPTS) {
|
|
229
|
+
Atomics.wait(new Int32Array(new SharedArrayBuffer(4)), 0, 0, LOG_DIR_RETRY_BASE_DELAY_MS * 2 ** attempt);
|
|
230
|
+
continue;
|
|
231
|
+
}
|
|
232
|
+
logToConsole("warn", `[${PLUGIN_NAME}] Failed to ensure log directory`, {
|
|
233
|
+
path,
|
|
234
|
+
error: error instanceof Error ? error.message : String(error),
|
|
235
|
+
});
|
|
236
|
+
return false;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
return false;
|
|
240
|
+
}
|
|
241
|
+
export function logRequest(stage, data) {
|
|
242
|
+
if (!LOGGING_ENABLED)
|
|
243
|
+
return;
|
|
244
|
+
if (!ensureLogDir(LOG_DIR)) {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
const timestamp = new Date().toISOString();
|
|
248
|
+
const requestId = ++requestCounter;
|
|
249
|
+
const correlationId = currentCorrelationId;
|
|
250
|
+
const filename = join(LOG_DIR, `request-${requestId}-${stage}.json`);
|
|
251
|
+
const requestData = sanitizeRequestLogData(data);
|
|
252
|
+
const sanitizedData = sanitizeValue(requestData);
|
|
253
|
+
try {
|
|
254
|
+
writeFileSync(filename, JSON.stringify({
|
|
255
|
+
timestamp,
|
|
256
|
+
requestId,
|
|
257
|
+
...(correlationId ? { correlationId } : {}),
|
|
258
|
+
stage,
|
|
259
|
+
...sanitizedData,
|
|
260
|
+
}, null, 2), { encoding: "utf8", mode: 0o600 });
|
|
261
|
+
logToApp("info", `Logged ${stage} to ${filename}`);
|
|
262
|
+
logToConsole("info", `[${PLUGIN_NAME}] Logged ${stage} to ${filename}`);
|
|
263
|
+
}
|
|
264
|
+
catch (e) {
|
|
265
|
+
const error = e;
|
|
266
|
+
logToApp("error", `Failed to write log: ${error.message}`);
|
|
267
|
+
logToConsole("error", `[${PLUGIN_NAME}] Failed to write log: ${error.message}`);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
export function logDebug(message, data) {
|
|
271
|
+
if (!shouldLog("debug"))
|
|
272
|
+
return;
|
|
273
|
+
logToApp("debug", message, data);
|
|
274
|
+
const text = `[${PLUGIN_NAME}] ${message}`;
|
|
275
|
+
logToConsole("debug", text, data);
|
|
276
|
+
}
|
|
277
|
+
export function logInfo(message, data) {
|
|
278
|
+
if (!shouldLog("info"))
|
|
279
|
+
return;
|
|
280
|
+
logToApp("info", message, data);
|
|
281
|
+
const text = `[${PLUGIN_NAME}] ${message}`;
|
|
282
|
+
logToConsole("info", text, data);
|
|
283
|
+
}
|
|
284
|
+
export function logWarn(message, data) {
|
|
285
|
+
if (!shouldLog("warn"))
|
|
286
|
+
return;
|
|
287
|
+
logToApp("warn", message, data);
|
|
288
|
+
const text = `[${PLUGIN_NAME}] ${message}`;
|
|
289
|
+
logToConsole("warn", text, data);
|
|
290
|
+
}
|
|
291
|
+
export function logError(message, data) {
|
|
292
|
+
logToApp("error", message, data);
|
|
293
|
+
const text = `[${PLUGIN_NAME}] ${message}`;
|
|
294
|
+
logToConsole("error", text, data);
|
|
295
|
+
}
|
|
296
|
+
const MAX_TIMERS = 100;
|
|
297
|
+
const timers = new Map();
|
|
298
|
+
export function createLogger(scope) {
|
|
299
|
+
const prefix = `[${PLUGIN_NAME}:${scope}]`;
|
|
300
|
+
const service = `${PLUGIN_NAME}.${scope}`;
|
|
301
|
+
return {
|
|
302
|
+
debug(message, data) {
|
|
303
|
+
if (!shouldLog("debug"))
|
|
304
|
+
return;
|
|
305
|
+
const text = `${prefix} ${message}`;
|
|
306
|
+
logToApp("debug", text, data, service);
|
|
307
|
+
logToConsole("debug", text, data);
|
|
308
|
+
},
|
|
309
|
+
info(message, data) {
|
|
310
|
+
if (!shouldLog("info"))
|
|
311
|
+
return;
|
|
312
|
+
const text = `${prefix} ${message}`;
|
|
313
|
+
logToApp("info", text, data, service);
|
|
314
|
+
logToConsole("info", text, data);
|
|
315
|
+
},
|
|
316
|
+
warn(message, data) {
|
|
317
|
+
if (!shouldLog("warn"))
|
|
318
|
+
return;
|
|
319
|
+
const text = `${prefix} ${message}`;
|
|
320
|
+
logToApp("warn", text, data, service);
|
|
321
|
+
logToConsole("warn", text, data);
|
|
322
|
+
},
|
|
323
|
+
error(message, data) {
|
|
324
|
+
const text = `${prefix} ${message}`;
|
|
325
|
+
logToApp("error", text, data, service);
|
|
326
|
+
logToConsole("error", text, data);
|
|
327
|
+
},
|
|
328
|
+
time(label) {
|
|
329
|
+
const key = `${scope}:${label}`;
|
|
330
|
+
const startTime = performance.now();
|
|
331
|
+
if (timers.size >= MAX_TIMERS) {
|
|
332
|
+
const firstKey = timers.keys().next().value;
|
|
333
|
+
// istanbul ignore next -- defensive: firstKey always exists when size >= MAX_TIMERS
|
|
334
|
+
if (firstKey)
|
|
335
|
+
timers.delete(firstKey);
|
|
336
|
+
}
|
|
337
|
+
timers.set(key, startTime);
|
|
338
|
+
return () => {
|
|
339
|
+
const endTime = performance.now();
|
|
340
|
+
const duration = endTime - startTime;
|
|
341
|
+
timers.delete(key);
|
|
342
|
+
if (shouldLog("debug")) {
|
|
343
|
+
const text = `${prefix} ${label}: ${formatDuration(duration)}`;
|
|
344
|
+
logToApp("debug", text, undefined, service);
|
|
345
|
+
logToConsole("debug", text);
|
|
346
|
+
}
|
|
347
|
+
return duration;
|
|
348
|
+
};
|
|
349
|
+
},
|
|
350
|
+
timeEnd(label, startTime) {
|
|
351
|
+
const duration = performance.now() - startTime;
|
|
352
|
+
if (shouldLog("debug")) {
|
|
353
|
+
const text = `${prefix} ${label}: ${formatDuration(duration)}`;
|
|
354
|
+
logToApp("debug", text, undefined, service);
|
|
355
|
+
logToConsole("debug", text);
|
|
356
|
+
}
|
|
357
|
+
},
|
|
358
|
+
};
|
|
359
|
+
}
|
|
360
|
+
export function getRequestId() {
|
|
361
|
+
return requestCounter;
|
|
362
|
+
}
|
|
363
|
+
export { formatDuration, maskEmail };
|
|
364
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../lib/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAiBpD,MAAM,kBAAkB,GAA6B;IACpD,KAAK,EAAE,CAAC;IACR,IAAI,EAAE,CAAC;IACP,IAAI,EAAE,CAAC;IACP,KAAK,EAAE,CAAC;CACR,CAAC;AAEF,MAAM,cAAc,GAAG;IACtB,uDAAuD;IACvD,iBAAiB;IACjB,sBAAsB;IACtB,gBAAgB;CAChB,CAAC;AAEF,MAAM,aAAa,GAAG,iDAAiD,CAAC;AAExE,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC;IAC9B,QAAQ;IACR,aAAa;IACb,cAAc;IACd,SAAS;IACT,cAAc;IACd,eAAe;IACf,OAAO;IACP,eAAe;IACf,QAAQ;IACR,SAAS;IACT,QAAQ;IACR,UAAU;IACV,YAAY;IACZ,UAAU;IACV,SAAS;IACT,OAAO;IACP,WAAW;IACX,YAAY;CACZ,CAAC,CAAC;AAEH,SAAS,SAAS,CAAC,KAAa;IAC/B,IAAI,KAAK,CAAC,MAAM,IAAI,EAAE;QAAE,OAAO,cAAc,CAAC;IAC9C,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AACpD,CAAC;AAED,SAAS,SAAS,CAAC,KAAa;IAC/B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACnC,IAAI,OAAO,GAAG,CAAC;QAAE,OAAO,SAAS,CAAC;IAClC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IACtC,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC;IACxC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAChC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC;IAC9B,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IACzD,OAAO,GAAG,MAAM,WAAW,GAAG,EAAE,CAAC;AAClC,CAAC;AAED,SAAS,UAAU,CAAC,KAAa;IAChC,IAAI,MAAM,GAAG,KAAK,CAAC;IACnB,sEAAsE;IACtE,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IACpE,KAAK,MAAM,OAAO,IAAI,cAAc,EAAE,CAAC;QACtC,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IAC/D,CAAC;IACD,OAAO,MAAM,CAAC;AACf,CAAC;AAED,SAAS,aAAa,CAAC,KAAc,EAAE,KAAK,GAAG,CAAC;IAC/C,IAAI,KAAK,GAAG,EAAE;QAAE,OAAO,aAAa,CAAC;IAErC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC/B,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,IAAI,KAAK,KAAK,IAAI,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QACjD,MAAM,SAAS,GAA4B,EAAE,CAAC;QAC9C,KAAK,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAChD,MAAM,aAAa,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YAC7D,IAAI,cAAc,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,CAAC;gBACvC,SAAS,CAAC,GAAG,CAAC,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC;YAC5E,CAAC;iBAAM,CAAC;gBACP,SAAS,CAAC,GAAG,CAAC,GAAG,aAAa,CAAC,GAAG,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;YAChD,CAAC;QACF,CAAC;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;IAED,OAAO,KAAK,CAAC;AACd,CAAC;AAED,SAAS,aAAa,CAAC,KAAyB;IAC/C,IAAI,CAAC,KAAK;QAAE,OAAO,MAAM,CAAC;IAC1B,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAc,CAAC;IAC1D,IAAI,UAAU,IAAI,kBAAkB;QAAE,OAAO,UAAU,CAAC;IACxD,OAAO,MAAM,CAAC;AACf,CAAC;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC,6BAA6B,KAAK,GAAG,CAAC;AACjF,MAAM,CAAC,MAAM,4BAA4B,GAAG,OAAO,CAAC,GAAG,CAAC,uBAAuB,KAAK,GAAG,CAAC;AACxF,MAAM,CAAC,MAAM,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,KAAK,GAAG,IAAI,eAAe,CAAC;AACvF,MAAM,CAAC,MAAM,SAAS,GAAG,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;AAC3E,MAAM,mBAAmB,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB,KAAK,GAAG,CAAC;AAClE,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,EAAE,EAAE,cAAc,CAAC,CAAC;AACvD,MAAM,wBAAwB,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;AAC7D,MAAM,oBAAoB,GAAG,CAAC,CAAC;AAC/B,MAAM,2BAA2B,GAAG,EAAE,CAAC;AAEvC,IAAI,MAAM,GAAqB,IAAI,CAAC;AACpC,IAAI,oBAAoB,GAAkB,IAAI,CAAC;AAE/C,MAAM,UAAU,gBAAgB,CAAC,EAAW;IAC3C,oBAAoB,GAAG,EAAE,IAAI,UAAU,EAAE,CAAC;IAC1C,OAAO,oBAAoB,CAAC;AAC7B,CAAC;AAED,MAAM,UAAU,gBAAgB;IAC/B,OAAO,oBAAoB,CAAC;AAC7B,CAAC;AAED,MAAM,UAAU,kBAAkB;IACjC,oBAAoB,GAAG,IAAI,CAAC;AAC7B,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,SAAoB;IAC9C,MAAM,GAAG,SAAS,CAAC;AACpB,CAAC;AAED,SAAS,QAAQ,CAChB,KAAe,EACf,OAAe,EACf,IAAc,EACd,UAAkB,WAAW;IAE7B,MAAM,MAAM,GAAG,MAAM,EAAE,GAAG,EAAE,GAAG,CAAC;IAChC,IAAI,CAAC,MAAM;QAAE,OAAO;IAEpB,MAAM,gBAAgB,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;IACtE,MAAM,aAAa,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC3E,MAAM,aAAa,GAAG,oBAAoB,CAAC;IAC3C,MAAM,SAAS,GAA4B,EAAE,CAAC;IAE9C,IAAI,aAAa,EAAE,CAAC;QACnB,SAAS,CAAC,aAAa,GAAG,aAAa,CAAC;IACzC,CAAC;IACD,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;QACjC,SAAS,CAAC,IAAI,GAAG,OAAO,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC;IAC/F,CAAC;IAED,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IAExE,IAAI,CAAC;QACJ,MAAM,MAAM,GAAG,MAAM,CAAC;YACrB,IAAI,EAAE;gBACL,OAAO;gBACP,KAAK;gBACL,OAAO,EAAE,gBAAgB;gBACzB,KAAK;aACL;SACD,CAAC,CAAC;QACH,IAAI,MAAM,IAAI,OAAQ,MAA2B,CAAC,KAAK,KAAK,UAAU,EAAE,CAAC;YACvE,MAA2B,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;QAC9C,CAAC;IACF,CAAC;IAAC,MAAM,CAAC;QACR,0BAA0B;IAC3B,CAAC;AACF,CAAC;AAED,SAAS,YAAY,CAAC,KAAe,EAAE,OAAe,EAAE,IAAc;IACrE,IAAI,CAAC,mBAAmB;QAAE,OAAO;IACjC,MAAM,gBAAgB,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC;IAC7C,MAAM,aAAa,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;IAC3E,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;QACjC,IAAI,KAAK,KAAK,MAAM;YAAE,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;aAC/D,IAAI,KAAK,KAAK,OAAO;YAAE,OAAO,CAAC,KAAK,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;;YACtE,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;QAClD,OAAO;IACR,CAAC;IAED,IAAI,KAAK,KAAK,MAAM;QAAE,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;SAChD,IAAI,KAAK,KAAK,OAAO;QAAE,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;;QACvD,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;AACpC,CAAC;AAED,IAAI,eAAe,EAAE,CAAC;IACrB,YAAY,CACX,MAAM,EACN,4BAA4B;QAC3B,CAAC,CAAC,IAAI,WAAW,+EAA+E,OAAO,EAAE;QACzG,CAAC,CAAC,IAAI,WAAW,sHAAsH,OAAO,EAAE,CACjJ,CAAC;AACH,CAAC;AACD,IAAI,aAAa,IAAI,CAAC,eAAe,EAAE,CAAC;IACvC,YAAY,CACX,MAAM,EACN,IAAI,WAAW,mCAAmC,SAAS,GAAG,CAC9D,CAAC;AACH,CAAC;AAED,IAAI,cAAc,GAAG,CAAC,CAAC;AAEvB,SAAS,sBAAsB,CAAC,IAA6B;IAC5D,IAAI,4BAA4B,EAAE,CAAC;QAClC,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI,eAAe,GAAG,KAAK,CAAC;IAC5B,MAAM,SAAS,GAA4B,EAAE,CAAC;IAC9C,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACjD,MAAM,aAAa,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAC7D,IAAI,aAAa,KAAK,MAAM,IAAI,aAAa,KAAK,aAAa,EAAE,CAAC;YACjE,eAAe,GAAG,IAAI,CAAC;YACvB,SAAS;QACV,CAAC;QACD,SAAS,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IACxB,CAAC;IACD,IAAI,eAAe,EAAE,CAAC;QACrB,SAAS,CAAC,eAAe,GAAG,IAAI,CAAC;IAClC,CAAC;IACD,OAAO,SAAS,CAAC;AAClB,CAAC;AAED,SAAS,SAAS,CAAC,KAAe;IACjC,IAAI,KAAK,KAAK,OAAO;QAAE,OAAO,IAAI,CAAC;IACnC,IAAI,CAAC,aAAa,IAAI,CAAC,eAAe;QAAE,OAAO,KAAK,CAAC;IACrD,OAAO,kBAAkB,CAAC,KAAK,CAAC,IAAI,kBAAkB,CAAC,SAAS,CAAC,CAAC;AACnE,CAAC;AAED,SAAS,cAAc,CAAC,EAAU;IACjC,IAAI,EAAE,GAAG,IAAI;QAAE,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC;IAC5C,IAAI,EAAE,GAAG,KAAK;QAAE,OAAO,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;IACpD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC;IACvC,MAAM,OAAO,GAAG,CAAC,CAAC,EAAE,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACjD,OAAO,GAAG,OAAO,KAAK,OAAO,GAAG,CAAC;AAClC,CAAC;AAED,SAAS,YAAY,CAAC,IAAY;IACjC,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,GAAG,oBAAoB,EAAE,OAAO,IAAI,CAAC,EAAE,CAAC;QACpE,IAAI,CAAC;YACJ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;gBACvB,SAAS,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;YACnD,CAAC;YACD,OAAO,IAAI,CAAC;QACb,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,MAAM,IAAI,GAAI,KAA+B,CAAC,IAAI,IAAI,EAAE,CAAC;YACzD,MAAM,QAAQ,GAAG,wBAAwB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACpD,IAAI,QAAQ,IAAI,OAAO,GAAG,CAAC,GAAG,oBAAoB,EAAE,CAAC;gBACpD,OAAO,CAAC,IAAI,CACX,IAAI,UAAU,CAAC,IAAI,iBAAiB,CAAC,CAAC,CAAC,CAAC,EACxC,CAAC,EACD,CAAC,EACD,2BAA2B,GAAG,CAAC,IAAI,OAAO,CAC1C,CAAC;gBACF,SAAS;YACV,CAAC;YACD,YAAY,CAAC,MAAM,EAAE,IAAI,WAAW,kCAAkC,EAAE;gBACvE,IAAI;gBACJ,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;aAC7D,CAAC,CAAC;YACH,OAAO,KAAK,CAAC;QACd,CAAC;IACF,CAAC;IACD,OAAO,KAAK,CAAC;AACd,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,KAAa,EAAE,IAA6B;IACtE,IAAI,CAAC,eAAe;QAAE,OAAO;IAE7B,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,OAAO;IACR,CAAC;IAED,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC3C,MAAM,SAAS,GAAG,EAAE,cAAc,CAAC;IACnC,MAAM,aAAa,GAAG,oBAAoB,CAAC;IAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,EAAE,WAAW,SAAS,IAAI,KAAK,OAAO,CAAC,CAAC;IACrE,MAAM,WAAW,GAAG,sBAAsB,CAAC,IAAI,CAAC,CAAC;IACjD,MAAM,aAAa,GAAG,aAAa,CAAC,WAAW,CAA4B,CAAC;IAE5E,IAAI,CAAC;QACJ,aAAa,CACZ,QAAQ,EACR,IAAI,CAAC,SAAS,CACb;YACC,SAAS;YACT,SAAS;YACT,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3C,KAAK;YACL,GAAG,aAAa;SAChB,EACD,IAAI,EACJ,CAAC,CACD,EACD,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CACjC,CAAC;QACF,QAAQ,CAAC,MAAM,EAAE,UAAU,KAAK,OAAO,QAAQ,EAAE,CAAC,CAAC;QACnD,YAAY,CAAC,MAAM,EAAE,IAAI,WAAW,YAAY,KAAK,OAAO,QAAQ,EAAE,CAAC,CAAC;IACzE,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACZ,MAAM,KAAK,GAAG,CAAU,CAAC;QACzB,QAAQ,CAAC,OAAO,EAAE,wBAAwB,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QAC3D,YAAY,CAAC,OAAO,EAAE,IAAI,WAAW,0BAA0B,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;IACjF,CAAC;AACF,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,OAAe,EAAE,IAAc;IACvD,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;QAAE,OAAO;IAChC,QAAQ,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAEjC,MAAM,IAAI,GAAG,IAAI,WAAW,KAAK,OAAO,EAAE,CAAC;IAC3C,YAAY,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,OAAe,EAAE,IAAc;IACtD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;QAAE,OAAO;IAC/B,QAAQ,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAEhC,MAAM,IAAI,GAAG,IAAI,WAAW,KAAK,OAAO,EAAE,CAAC;IAC3C,YAAY,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,OAAe,EAAE,IAAc;IACtD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;QAAE,OAAO;IAC/B,QAAQ,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAChC,MAAM,IAAI,GAAG,IAAI,WAAW,KAAK,OAAO,EAAE,CAAC;IAC3C,YAAY,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,OAAe,EAAE,IAAc;IACvD,QAAQ,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACjC,MAAM,IAAI,GAAG,IAAI,WAAW,KAAK,OAAO,EAAE,CAAC;IAC3C,YAAY,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AACnC,CAAC;AAWD,MAAM,UAAU,GAAG,GAAG,CAAC;AACvB,MAAM,MAAM,GAAwB,IAAI,GAAG,EAAE,CAAC;AAE9C,MAAM,UAAU,YAAY,CAAC,KAAa;IACzC,MAAM,MAAM,GAAG,IAAI,WAAW,IAAI,KAAK,GAAG,CAAC;IAC3C,MAAM,OAAO,GAAG,GAAG,WAAW,IAAI,KAAK,EAAE,CAAC;IAE1C,OAAO;QACN,KAAK,CAAC,OAAe,EAAE,IAAc;YACpC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;gBAAE,OAAO;YAChC,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,OAAO,EAAE,CAAC;YACpC,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YACvC,YAAY,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,OAAe,EAAE,IAAc;YACnC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;gBAAE,OAAO;YAC/B,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,OAAO,EAAE,CAAC;YACpC,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YACtC,YAAY,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAClC,CAAC;QACD,IAAI,CAAC,OAAe,EAAE,IAAc;YACnC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;gBAAE,OAAO;YAC/B,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,OAAO,EAAE,CAAC;YACpC,QAAQ,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YACtC,YAAY,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAClC,CAAC;QACD,KAAK,CAAC,OAAe,EAAE,IAAc;YACpC,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,OAAO,EAAE,CAAC;YACpC,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YACvC,YAAY,CAAC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,KAAa;YACjB,MAAM,GAAG,GAAG,GAAG,KAAK,IAAI,KAAK,EAAE,CAAC;YAChC,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC;YACrC,IAAI,MAAM,CAAC,IAAI,IAAI,UAAU,EAAE,CAAC;gBAC/B,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC;gBAC5C,oFAAoF;gBACpF,IAAI,QAAQ;oBAAE,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACvC,CAAC;YACA,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YAC3B,OAAO,GAAG,EAAE;gBACX,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC;gBAClC,MAAM,QAAQ,GAAG,OAAO,GAAG,SAAS,CAAC;gBACrC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;gBACnB,IAAI,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;oBACxB,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,KAAK,KAAK,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC;oBAC/D,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;oBAC5C,YAAY,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;gBAC7B,CAAC;gBACD,OAAO,QAAQ,CAAC;YACjB,CAAC,CAAC;QACH,CAAC;QACD,OAAO,CAAC,KAAa,EAAE,SAAiB;YACvC,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;YAC/C,IAAI,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;gBACxB,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,KAAK,KAAK,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC/D,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;gBAC5C,YAAY,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;YAC7B,CAAC;QACF,CAAC;KACD,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY;IAC3B,OAAO,cAAc,CAAC;AACvB,CAAC;AAED,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,CAAC"}
|