reqon-dsl 0.2.0 → 0.4.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/CHANGELOG.md +7 -0
- package/README.md +45 -3
- package/dist/ast/nodes.d.ts +91 -4
- package/dist/ast/nodes.js +14 -0
- package/dist/auth/circuit-breaker.d.ts +11 -0
- package/dist/auth/circuit-breaker.js +90 -18
- package/dist/auth/credentials.d.ts +6 -1
- package/dist/auth/credentials.js +12 -4
- package/dist/auth/oauth2-provider.js +13 -3
- package/dist/auth/rate-limiter.d.ts +12 -1
- package/dist/auth/rate-limiter.js +39 -26
- package/dist/auth/token-store.js +8 -1
- package/dist/cli.d.ts +24 -1
- package/dist/cli.js +149 -10
- package/dist/config/constants.d.ts +152 -0
- package/dist/config/constants.js +139 -0
- package/dist/config/index.d.ts +4 -0
- package/dist/config/index.js +4 -0
- package/dist/control/index.d.ts +2 -0
- package/dist/control/index.js +1 -0
- package/dist/control/server.d.ts +105 -0
- package/dist/control/server.js +315 -0
- package/dist/control/types.d.ts +61 -0
- package/dist/control/types.js +7 -0
- package/dist/debug/cli-debugger.d.ts +17 -0
- package/dist/debug/cli-debugger.js +185 -0
- package/dist/debug/controller.d.ts +94 -0
- package/dist/debug/controller.js +45 -0
- package/dist/debug/index.d.ts +6 -0
- package/dist/debug/index.js +5 -0
- package/dist/errors/index.d.ts +67 -0
- package/dist/errors/index.js +89 -1
- package/dist/execution/index.d.ts +1 -1
- package/dist/execution/state.d.ts +24 -0
- package/dist/execution/store.js +2 -2
- package/dist/execution-log/events.d.ts +125 -0
- package/dist/execution-log/events.js +17 -0
- package/dist/execution-log/fold.d.ts +38 -0
- package/dist/execution-log/fold.js +54 -0
- package/dist/execution-log/index.d.ts +18 -0
- package/dist/execution-log/index.js +6 -0
- package/dist/execution-log/postgres-store.d.ts +36 -0
- package/dist/execution-log/postgres-store.js +108 -0
- package/dist/execution-log/resume.d.ts +11 -0
- package/dist/execution-log/resume.js +5 -0
- package/dist/execution-log/sqlite-store.d.ts +16 -0
- package/dist/execution-log/sqlite-store.js +101 -0
- package/dist/execution-log/store.d.ts +72 -0
- package/dist/execution-log/store.js +182 -0
- package/dist/index.d.ts +23 -2
- package/dist/index.js +35 -3
- package/dist/interpreter/context.d.ts +29 -0
- package/dist/interpreter/context.js +18 -0
- package/dist/interpreter/evaluator.d.ts +63 -1
- package/dist/interpreter/evaluator.js +219 -42
- package/dist/interpreter/executor.d.ts +132 -14
- package/dist/interpreter/executor.js +883 -178
- package/dist/interpreter/fetch-handler.d.ts +48 -1
- package/dist/interpreter/fetch-handler.js +216 -38
- package/dist/interpreter/http.d.ts +34 -0
- package/dist/interpreter/http.js +203 -28
- package/dist/interpreter/index.d.ts +5 -3
- package/dist/interpreter/index.js +4 -2
- package/dist/interpreter/pagination.d.ts +12 -3
- package/dist/interpreter/pagination.js +102 -32
- package/dist/interpreter/signals.d.ts +8 -0
- package/dist/interpreter/signals.js +12 -0
- package/dist/interpreter/source-manager.d.ts +75 -0
- package/dist/interpreter/source-manager.js +157 -0
- package/dist/interpreter/step-handlers/apply-handler.d.ts +29 -0
- package/dist/interpreter/step-handlers/apply-handler.js +79 -0
- package/dist/interpreter/step-handlers/for-handler.d.ts +16 -0
- package/dist/interpreter/step-handlers/for-handler.js +89 -7
- package/dist/interpreter/step-handlers/index.d.ts +4 -2
- package/dist/interpreter/step-handlers/index.js +4 -2
- package/dist/interpreter/step-handlers/match-handler.d.ts +9 -0
- package/dist/interpreter/step-handlers/match-handler.js +47 -17
- package/dist/interpreter/step-handlers/pause-handler.d.ts +52 -0
- package/dist/interpreter/step-handlers/pause-handler.js +87 -0
- package/dist/interpreter/step-handlers/store-handler.d.ts +17 -1
- package/dist/interpreter/step-handlers/store-handler.js +61 -20
- package/dist/interpreter/step-handlers/types.d.ts +3 -0
- package/dist/interpreter/step-handlers/validate-handler.d.ts +2 -1
- package/dist/interpreter/step-handlers/validate-handler.js +7 -2
- package/dist/interpreter/step-handlers/webhook-handler.d.ts +4 -0
- package/dist/interpreter/step-handlers/webhook-handler.js +31 -5
- package/dist/interpreter/store-manager.d.ts +46 -0
- package/dist/interpreter/store-manager.js +70 -0
- package/dist/lexer/index.d.ts +11 -4
- package/dist/lexer/index.js +11 -4
- package/dist/lexer/tokens.d.ts +17 -1
- package/dist/lexer/tokens.js +36 -0
- package/dist/loader/index.js +5 -8
- package/dist/mcp/index.d.ts +11 -0
- package/dist/mcp/index.js +11 -0
- package/dist/mcp/sandbox.d.ts +41 -0
- package/dist/mcp/sandbox.js +76 -0
- package/dist/mcp/server.d.ts +17 -0
- package/dist/mcp/server.js +504 -0
- package/dist/oas/index.d.ts +2 -0
- package/dist/oas/index.js +1 -0
- package/dist/oas/loader.d.ts +13 -1
- package/dist/oas/loader.js +25 -3
- package/dist/oas/mock-generator.d.ts +12 -0
- package/dist/oas/mock-generator.js +196 -0
- package/dist/oas/validator.js +45 -5
- package/dist/observability/events.d.ts +248 -0
- package/dist/observability/events.js +85 -0
- package/dist/observability/index.d.ts +15 -0
- package/dist/observability/index.js +12 -0
- package/dist/observability/logger.d.ts +106 -0
- package/dist/observability/logger.js +266 -0
- package/dist/observability/otel.d.ts +143 -0
- package/dist/observability/otel.js +421 -0
- package/dist/parser/action-parser.d.ts +105 -0
- package/dist/parser/action-parser.js +645 -0
- package/dist/parser/base.d.ts +7 -0
- package/dist/parser/base.js +11 -0
- package/dist/parser/expressions.d.ts +14 -0
- package/dist/parser/expressions.js +89 -6
- package/dist/parser/fetch-parser.d.ts +27 -0
- package/dist/parser/fetch-parser.js +280 -0
- package/dist/parser/index.d.ts +17 -0
- package/dist/parser/index.js +17 -0
- package/dist/parser/parser.d.ts +44 -46
- package/dist/parser/parser.js +122 -1070
- package/dist/parser/pipeline-parser.d.ts +12 -0
- package/dist/parser/pipeline-parser.js +52 -0
- package/dist/parser/schedule-parser.d.ts +7 -0
- package/dist/parser/schedule-parser.js +137 -0
- package/dist/parser/source-parser.d.ts +9 -0
- package/dist/parser/source-parser.js +151 -0
- package/dist/pause/index.d.ts +15 -0
- package/dist/pause/index.js +12 -0
- package/dist/pause/log-store.d.ts +33 -0
- package/dist/pause/log-store.js +98 -0
- package/dist/pause/manager.d.ts +130 -0
- package/dist/pause/manager.js +294 -0
- package/dist/pause/state.d.ts +93 -0
- package/dist/pause/state.js +103 -0
- package/dist/pause/store.d.ts +61 -0
- package/dist/pause/store.js +158 -0
- package/dist/plugin.d.ts +9 -12
- package/dist/plugin.js +10 -13
- package/dist/scheduler/cron-parser.d.ts +10 -3
- package/dist/scheduler/cron-parser.js +227 -48
- package/dist/scheduler/scheduler.js +56 -22
- package/dist/stores/factory.d.ts +7 -1
- package/dist/stores/factory.js +14 -3
- package/dist/stores/file.d.ts +26 -0
- package/dist/stores/file.js +67 -21
- package/dist/stores/index.d.ts +16 -1
- package/dist/stores/index.js +16 -1
- package/dist/stores/memory.d.ts +4 -0
- package/dist/stores/memory.js +8 -6
- package/dist/stores/postgrest.d.ts +28 -0
- package/dist/stores/postgrest.js +84 -37
- package/dist/stores/types.d.ts +17 -0
- package/dist/stores/types.js +12 -0
- package/dist/sync/index.d.ts +3 -2
- package/dist/sync/index.js +2 -1
- package/dist/sync/log-store.d.ts +30 -0
- package/dist/sync/log-store.js +45 -0
- package/dist/sync/store.js +1 -1
- package/dist/trace/index.d.ts +18 -0
- package/dist/trace/index.js +13 -0
- package/dist/trace/log-view.d.ts +57 -0
- package/dist/trace/log-view.js +76 -0
- package/dist/trace/recorder.d.ts +75 -0
- package/dist/trace/recorder.js +157 -0
- package/dist/trace/replay.d.ts +132 -0
- package/dist/trace/replay.js +264 -0
- package/dist/trace/state.d.ts +102 -0
- package/dist/trace/state.js +86 -0
- package/dist/trace/store.d.ts +75 -0
- package/dist/trace/store.js +250 -0
- package/dist/utils/deep-merge.d.ts +10 -0
- package/dist/utils/deep-merge.js +23 -0
- package/dist/utils/file.d.ts +13 -4
- package/dist/utils/file.js +70 -12
- package/dist/utils/index.d.ts +2 -1
- package/dist/utils/index.js +2 -1
- package/dist/utils/long-timeout.d.ts +19 -0
- package/dist/utils/long-timeout.js +33 -0
- package/dist/utils/path.d.ts +22 -1
- package/dist/utils/path.js +46 -1
- package/dist/utils/redact.d.ts +22 -0
- package/dist/utils/redact.js +42 -0
- package/dist/utils/type-guards.d.ts +58 -0
- package/dist/utils/type-guards.js +92 -0
- package/dist/webhook/server.d.ts +9 -0
- package/dist/webhook/server.js +122 -36
- package/dist/webhook/types.d.ts +9 -1
- package/package.json +76 -9
- package/.claude/settings.local.json +0 -31
- package/.claude/skills/api-integration.md +0 -125
- package/.claude/skills/database-schema.md +0 -51
- package/.claude/skills/dsl-design.md +0 -80
- package/.claude/skills/property-testing.md +0 -143
- package/.claude/skills/reqon/SKILL.md +0 -44
- package/.claude/skills/reqon/references/examples.md +0 -206
- package/.claude/skills/reqon/references/syntax.md +0 -263
- package/.claude/skills/vscode-extension.md +0 -113
- package/.github/dependabot.yml +0 -32
- package/.github/pull_request_template.md +0 -21
- package/.github/workflows/ci.yml +0 -174
- package/.github/workflows/release.yml +0 -73
- package/CLAUDE.md +0 -72
- package/CONTRIBUTING.md +0 -161
- package/TODO.md +0 -51
- package/dist/auth/auth.test.d.ts +0 -1
- package/dist/auth/auth.test.js +0 -255
- package/dist/errors/errors.test.d.ts +0 -1
- package/dist/errors/errors.test.js +0 -165
- package/dist/execution/execution.test.d.ts +0 -1
- package/dist/execution/execution.test.js +0 -246
- package/dist/integration.test.d.ts +0 -1
- package/dist/integration.test.js +0 -168
- package/dist/interpreter/evaluator.test.d.ts +0 -1
- package/dist/interpreter/evaluator.test.js +0 -512
- package/dist/interpreter/http.test.d.ts +0 -1
- package/dist/interpreter/http.test.js +0 -299
- package/dist/interpreter/progress.test.d.ts +0 -1
- package/dist/interpreter/progress.test.js +0 -216
- package/dist/interpreter/schema-matcher.test.d.ts +0 -1
- package/dist/interpreter/schema-matcher.test.js +0 -122
- package/dist/lexer/lexer.d.ts +0 -24
- package/dist/lexer/lexer.js +0 -264
- package/dist/lexer/lexer.test.d.ts +0 -1
- package/dist/lexer/lexer.test.js +0 -259
- package/dist/loader/loader.test.d.ts +0 -1
- package/dist/loader/loader.test.js +0 -287
- package/dist/oas/oas.test.d.ts +0 -1
- package/dist/oas/oas.test.js +0 -218
- package/dist/parser/expressions.test.d.ts +0 -1
- package/dist/parser/expressions.test.js +0 -378
- package/dist/parser/match.test.d.ts +0 -1
- package/dist/parser/match.test.js +0 -254
- package/dist/parser/parser.test.d.ts +0 -1
- package/dist/parser/parser.test.js +0 -333
- package/dist/parser/schedule.test.d.ts +0 -1
- package/dist/parser/schedule.test.js +0 -241
- package/dist/scheduler/cron-parser.test.d.ts +0 -1
- package/dist/scheduler/cron-parser.test.js +0 -188
- package/dist/stores/file.test.d.ts +0 -1
- package/dist/stores/file.test.js +0 -165
- package/dist/stores/memory.test.d.ts +0 -1
- package/dist/stores/memory.test.js +0 -157
- package/dist/stores/stores.test.d.ts +0 -1
- package/dist/stores/stores.test.js +0 -158
- package/dist/sync/sync.test.d.ts +0 -1
- package/dist/sync/sync.test.js +0 -221
- package/docusaurus/README.md +0 -41
- package/docusaurus/docs/advanced/execution-state.md +0 -283
- package/docusaurus/docs/advanced/extending-reqon.md +0 -388
- package/docusaurus/docs/advanced/multi-file-missions.md +0 -250
- package/docusaurus/docs/advanced/parallel-execution.md +0 -353
- package/docusaurus/docs/api-reference.md +0 -443
- package/docusaurus/docs/authentication/api-key.md +0 -339
- package/docusaurus/docs/authentication/basic.md +0 -276
- package/docusaurus/docs/authentication/bearer.md +0 -282
- package/docusaurus/docs/authentication/oauth2.md +0 -317
- package/docusaurus/docs/authentication/overview.md +0 -251
- package/docusaurus/docs/cli.md +0 -229
- package/docusaurus/docs/core-concepts/actions.md +0 -286
- package/docusaurus/docs/core-concepts/missions.md +0 -264
- package/docusaurus/docs/core-concepts/schemas.md +0 -353
- package/docusaurus/docs/core-concepts/sources.md +0 -339
- package/docusaurus/docs/core-concepts/stores.md +0 -332
- package/docusaurus/docs/dsl-syntax/expressions.md +0 -361
- package/docusaurus/docs/dsl-syntax/fetch.md +0 -293
- package/docusaurus/docs/dsl-syntax/for-loops.md +0 -324
- package/docusaurus/docs/dsl-syntax/map.md +0 -345
- package/docusaurus/docs/dsl-syntax/match.md +0 -387
- package/docusaurus/docs/dsl-syntax/pipelines.md +0 -397
- package/docusaurus/docs/dsl-syntax/validate.md +0 -401
- package/docusaurus/docs/error-handling/dead-letter-queues.md +0 -399
- package/docusaurus/docs/error-handling/flow-control.md +0 -337
- package/docusaurus/docs/error-handling/retry-strategies.md +0 -368
- package/docusaurus/docs/examples.md +0 -488
- package/docusaurus/docs/getting-started.md +0 -256
- package/docusaurus/docs/http/circuit-breaker.md +0 -401
- package/docusaurus/docs/http/incremental-sync.md +0 -394
- package/docusaurus/docs/http/pagination.md +0 -361
- package/docusaurus/docs/http/rate-limiting.md +0 -383
- package/docusaurus/docs/http/requests.md +0 -328
- package/docusaurus/docs/http/retry.md +0 -402
- package/docusaurus/docs/intro.md +0 -90
- package/docusaurus/docs/openapi/loading-specs.md +0 -305
- package/docusaurus/docs/openapi/operation-calls.md +0 -314
- package/docusaurus/docs/openapi/overview.md +0 -212
- package/docusaurus/docs/openapi/response-validation.md +0 -344
- package/docusaurus/docs/scheduling/cron.md +0 -305
- package/docusaurus/docs/scheduling/daemon-mode.md +0 -317
- package/docusaurus/docs/scheduling/intervals.md +0 -289
- package/docusaurus/docs/scheduling/overview.md +0 -231
- package/docusaurus/docs/stores/custom-adapters.md +0 -376
- package/docusaurus/docs/stores/file.md +0 -236
- package/docusaurus/docs/stores/memory.md +0 -193
- package/docusaurus/docs/stores/overview.md +0 -274
- package/docusaurus/docs/stores/postgrest.md +0 -316
- package/docusaurus/docusaurus.config.ts +0 -148
- package/docusaurus/package-lock.json +0 -18029
- package/docusaurus/package.json +0 -47
- package/docusaurus/sidebars.ts +0 -155
- package/docusaurus/src/components/HomepageFeatures/index.tsx +0 -105
- package/docusaurus/src/components/HomepageFeatures/styles.module.css +0 -12
- package/docusaurus/src/css/custom.css +0 -169
- package/docusaurus/src/pages/index.module.css +0 -48
- package/docusaurus/src/pages/index.tsx +0 -110
- package/docusaurus/src/pages/markdown-page.md +0 -7
- package/docusaurus/static/.nojekyll +0 -0
- package/docusaurus/static/img/docusaurus-social-card.jpg +0 -0
- package/docusaurus/static/img/docusaurus.png +0 -0
- package/docusaurus/static/img/favicon.ico +0 -0
- package/docusaurus/static/img/logo.svg +0 -10
- package/docusaurus/static/img/undraw_docusaurus_mountain.svg +0 -171
- package/docusaurus/static/img/undraw_docusaurus_react.svg +0 -170
- package/docusaurus/static/img/undraw_docusaurus_tree.svg +0 -40
- package/docusaurus/tsconfig.json +0 -8
- package/examples/README.md +0 -112
- package/examples/error-handling/README.md +0 -150
- package/examples/error-handling/payment-processor.vague +0 -287
- package/examples/github-sync/README.md +0 -74
- package/examples/github-sync/fetch-issues.vague +0 -47
- package/examples/github-sync/fetch-prs.vague +0 -40
- package/examples/github-sync/mission.vague +0 -101
- package/examples/github-sync/normalize.vague +0 -70
- package/examples/jsonplaceholder/README.md +0 -28
- package/examples/jsonplaceholder/posts.vague +0 -48
- package/examples/petstore/README.md +0 -35
- package/examples/petstore/openapi.yaml +0 -97
- package/examples/petstore/sync.vague +0 -52
- package/examples/temporal-comparison/README.md +0 -297
- package/examples/temporal-comparison/reconciliation.vague +0 -355
- package/examples/temporal-comparison/temporal/activities/index.ts +0 -8
- package/examples/temporal-comparison/temporal/activities/shipstation.ts +0 -225
- package/examples/temporal-comparison/temporal/activities/shopify.ts +0 -257
- package/examples/temporal-comparison/temporal/activities/storage.ts +0 -198
- package/examples/temporal-comparison/temporal/activities/stripe.ts +0 -169
- package/examples/temporal-comparison/temporal/activities/validation.ts +0 -205
- package/examples/temporal-comparison/temporal/client/schedule.ts +0 -218
- package/examples/temporal-comparison/temporal/config/retry.ts +0 -63
- package/examples/temporal-comparison/temporal/types/index.ts +0 -129
- package/examples/temporal-comparison/temporal/workers/main.ts +0 -130
- package/examples/temporal-comparison/temporal/workflows/orderReconciliation.ts +0 -262
- package/examples/xero/README.md +0 -88
- package/examples/xero/invoices.vague +0 -189
- package/src/api-integration.test.ts +0 -954
- package/src/ast/index.ts +0 -1
- package/src/ast/nodes.ts +0 -310
- package/src/auth/auth.test.ts +0 -326
- package/src/auth/circuit-breaker.test.ts +0 -390
- package/src/auth/circuit-breaker.ts +0 -379
- package/src/auth/credentials.test.ts +0 -273
- package/src/auth/credentials.ts +0 -246
- package/src/auth/index.ts +0 -40
- package/src/auth/oauth2-provider.ts +0 -177
- package/src/auth/rate-limiter.ts +0 -459
- package/src/auth/token-store.ts +0 -177
- package/src/auth/types.ts +0 -159
- package/src/benchmark/e2e.bench.ts +0 -288
- package/src/benchmark/evaluator.bench.ts +0 -331
- package/src/benchmark/fixtures.ts +0 -295
- package/src/benchmark/index.ts +0 -108
- package/src/benchmark/lexer.bench.ts +0 -69
- package/src/benchmark/parser.bench.ts +0 -103
- package/src/benchmark/resilience.bench.ts +0 -193
- package/src/benchmark/store.bench.ts +0 -147
- package/src/benchmark/utils.ts +0 -230
- package/src/cli.ts +0 -313
- package/src/errors/errors.test.ts +0 -234
- package/src/errors/index.ts +0 -223
- package/src/execution/execution.test.ts +0 -307
- package/src/execution/index.ts +0 -21
- package/src/execution/state.ts +0 -207
- package/src/execution/store.ts +0 -188
- package/src/index.ts +0 -169
- package/src/integration.test.ts +0 -192
- package/src/interpreter/context.ts +0 -57
- package/src/interpreter/evaluator.test.ts +0 -796
- package/src/interpreter/evaluator.ts +0 -245
- package/src/interpreter/executor.ts +0 -946
- package/src/interpreter/fetch-handler.ts +0 -302
- package/src/interpreter/http.test.ts +0 -423
- package/src/interpreter/http.ts +0 -308
- package/src/interpreter/index.ts +0 -32
- package/src/interpreter/pagination.ts +0 -207
- package/src/interpreter/progress.test.ts +0 -276
- package/src/interpreter/schema-matcher.test.ts +0 -160
- package/src/interpreter/schema-matcher.ts +0 -168
- package/src/interpreter/signals.ts +0 -73
- package/src/interpreter/step-handlers/for-handler.ts +0 -65
- package/src/interpreter/step-handlers/index.ts +0 -17
- package/src/interpreter/step-handlers/map-handler.ts +0 -24
- package/src/interpreter/step-handlers/match-handler.ts +0 -101
- package/src/interpreter/step-handlers/store-handler.ts +0 -78
- package/src/interpreter/step-handlers/types.ts +0 -17
- package/src/interpreter/step-handlers/validate-handler.ts +0 -30
- package/src/interpreter/step-handlers/webhook-handler.ts +0 -142
- package/src/lexer/index.ts +0 -18
- package/src/lexer/lexer.test.ts +0 -316
- package/src/lexer/tokens.ts +0 -179
- package/src/loader/index.ts +0 -288
- package/src/loader/loader.test.ts +0 -360
- package/src/oas/index.ts +0 -4
- package/src/oas/loader.ts +0 -126
- package/src/oas/oas.test.ts +0 -254
- package/src/oas/validator.ts +0 -299
- package/src/parser/base.ts +0 -124
- package/src/parser/expressions.test.ts +0 -525
- package/src/parser/expressions.ts +0 -314
- package/src/parser/index.ts +0 -3
- package/src/parser/match.test.ts +0 -296
- package/src/parser/parser.test.ts +0 -739
- package/src/parser/parser.ts +0 -1469
- package/src/parser/schedule.test.ts +0 -287
- package/src/parser/webhook.test.ts +0 -248
- package/src/plugin.ts +0 -83
- package/src/scheduler/cron-parser.test.ts +0 -236
- package/src/scheduler/cron-parser.ts +0 -236
- package/src/scheduler/index.ts +0 -10
- package/src/scheduler/scheduler.ts +0 -443
- package/src/scheduler/types.ts +0 -71
- package/src/stores/factory.ts +0 -104
- package/src/stores/file.test.ts +0 -276
- package/src/stores/file.ts +0 -211
- package/src/stores/index.ts +0 -6
- package/src/stores/memory.test.ts +0 -238
- package/src/stores/memory.ts +0 -63
- package/src/stores/postgrest.test.ts +0 -488
- package/src/stores/postgrest.ts +0 -263
- package/src/stores/stores.test.ts +0 -197
- package/src/stores/types.ts +0 -58
- package/src/sync/index.ts +0 -16
- package/src/sync/state.ts +0 -126
- package/src/sync/store.ts +0 -139
- package/src/sync/sync.test.ts +0 -271
- package/src/utils/async.ts +0 -10
- package/src/utils/file.ts +0 -106
- package/src/utils/index.ts +0 -14
- package/src/utils/logger.ts +0 -53
- package/src/utils/path.ts +0 -47
- package/src/webhook/index.ts +0 -15
- package/src/webhook/server.test.ts +0 -253
- package/src/webhook/server.ts +0 -389
- package/src/webhook/store.ts +0 -239
- package/src/webhook/types.ts +0 -93
- package/tsconfig.json +0 -17
- package/vitest.config.ts +0 -39
package/src/stores/file.test.ts
DELETED
|
@@ -1,276 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
-
import { existsSync, rmSync, mkdirSync, readFileSync } from 'node:fs';
|
|
3
|
-
import { join } from 'node:path';
|
|
4
|
-
import { FileStore } from './file.js';
|
|
5
|
-
|
|
6
|
-
describe('FileStore', () => {
|
|
7
|
-
const TEST_DIR = '.reqon-test-stores';
|
|
8
|
-
|
|
9
|
-
beforeEach(() => {
|
|
10
|
-
if (existsSync(TEST_DIR)) {
|
|
11
|
-
rmSync(TEST_DIR, { recursive: true, force: true });
|
|
12
|
-
}
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
afterEach(() => {
|
|
16
|
-
if (existsSync(TEST_DIR)) {
|
|
17
|
-
rmSync(TEST_DIR, { recursive: true, force: true });
|
|
18
|
-
}
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
it('should create directory and file on first write', async () => {
|
|
22
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
23
|
-
|
|
24
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
25
|
-
|
|
26
|
-
expect(existsSync(join(TEST_DIR, 'test-store.json'))).toBe(true);
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
it('should create .gitignore in data directory', async () => {
|
|
30
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
31
|
-
// Trigger initialization by calling any store method
|
|
32
|
-
await store.get('nonexistent');
|
|
33
|
-
|
|
34
|
-
const gitignorePath = join(TEST_DIR, '.gitignore');
|
|
35
|
-
expect(existsSync(gitignorePath)).toBe(true);
|
|
36
|
-
const content = readFileSync(gitignorePath, 'utf-8');
|
|
37
|
-
expect(content).toContain('*.json');
|
|
38
|
-
});
|
|
39
|
-
|
|
40
|
-
it('should get a record by key', async () => {
|
|
41
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
42
|
-
|
|
43
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
44
|
-
const record = await store.get('1');
|
|
45
|
-
|
|
46
|
-
expect(record).toEqual({ id: '1', name: 'Alice' });
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
it('should return null for non-existent key', async () => {
|
|
50
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
51
|
-
|
|
52
|
-
const record = await store.get('nonexistent');
|
|
53
|
-
expect(record).toBeNull();
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
it('should update existing record', async () => {
|
|
57
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
58
|
-
|
|
59
|
-
await store.set('1', { id: '1', name: 'Alice', age: 30 });
|
|
60
|
-
await store.update('1', { age: 31 });
|
|
61
|
-
|
|
62
|
-
const record = await store.get('1');
|
|
63
|
-
expect(record).toEqual({ id: '1', name: 'Alice', age: 31 });
|
|
64
|
-
});
|
|
65
|
-
|
|
66
|
-
it('should create record on update if not exists', async () => {
|
|
67
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
68
|
-
|
|
69
|
-
await store.update('1', { name: 'Alice' });
|
|
70
|
-
|
|
71
|
-
const record = await store.get('1');
|
|
72
|
-
expect(record).toEqual({ name: 'Alice' });
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
it('should delete a record', async () => {
|
|
76
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
77
|
-
|
|
78
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
79
|
-
await store.delete('1');
|
|
80
|
-
|
|
81
|
-
const record = await store.get('1');
|
|
82
|
-
expect(record).toBeNull();
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
it('should list all records', async () => {
|
|
86
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
87
|
-
|
|
88
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
89
|
-
await store.set('2', { id: '2', name: 'Bob' });
|
|
90
|
-
|
|
91
|
-
const records = await store.list();
|
|
92
|
-
expect(records).toHaveLength(2);
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
it('should filter records with where clause', async () => {
|
|
96
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
97
|
-
|
|
98
|
-
await store.set('1', { id: '1', name: 'Alice', active: true });
|
|
99
|
-
await store.set('2', { id: '2', name: 'Bob', active: false });
|
|
100
|
-
await store.set('3', { id: '3', name: 'Charlie', active: true });
|
|
101
|
-
|
|
102
|
-
const records = await store.list({ where: { active: true } });
|
|
103
|
-
expect(records).toHaveLength(2);
|
|
104
|
-
expect(records.map(r => r.name)).toContain('Alice');
|
|
105
|
-
expect(records.map(r => r.name)).toContain('Charlie');
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
it('should support limit and offset', async () => {
|
|
109
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
110
|
-
|
|
111
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
112
|
-
await store.set('2', { id: '2', name: 'Bob' });
|
|
113
|
-
await store.set('3', { id: '3', name: 'Charlie' });
|
|
114
|
-
|
|
115
|
-
const records = await store.list({ offset: 1, limit: 1 });
|
|
116
|
-
expect(records).toHaveLength(1);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
it('should clear all records', async () => {
|
|
120
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
121
|
-
|
|
122
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
123
|
-
await store.set('2', { id: '2', name: 'Bob' });
|
|
124
|
-
await store.clear();
|
|
125
|
-
|
|
126
|
-
const records = await store.list();
|
|
127
|
-
expect(records).toHaveLength(0);
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
describe('batch mode', () => {
|
|
131
|
-
it('should not write to disk until flush in batch mode', async () => {
|
|
132
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR, persist: 'batch' });
|
|
133
|
-
const filePath = store.getFilePath();
|
|
134
|
-
|
|
135
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
136
|
-
|
|
137
|
-
// File exists but should be empty or not contain data yet
|
|
138
|
-
const contentBefore = existsSync(filePath) ? readFileSync(filePath, 'utf-8') : '{}';
|
|
139
|
-
const parsedBefore = JSON.parse(contentBefore);
|
|
140
|
-
expect(Object.keys(parsedBefore)).toHaveLength(0);
|
|
141
|
-
|
|
142
|
-
// After flush, data should be persisted
|
|
143
|
-
store.flush();
|
|
144
|
-
|
|
145
|
-
const contentAfter = readFileSync(filePath, 'utf-8');
|
|
146
|
-
const parsedAfter = JSON.parse(contentAfter);
|
|
147
|
-
expect(parsedAfter['1']).toEqual({ id: '1', name: 'Alice' });
|
|
148
|
-
});
|
|
149
|
-
});
|
|
150
|
-
|
|
151
|
-
describe('persistence', () => {
|
|
152
|
-
it('should persist data across store instances', async () => {
|
|
153
|
-
const store1 = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
154
|
-
await store1.set('1', { id: '1', name: 'Alice' });
|
|
155
|
-
|
|
156
|
-
const store2 = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
157
|
-
const record = await store2.get('1');
|
|
158
|
-
|
|
159
|
-
expect(record).toEqual({ id: '1', name: 'Alice' });
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
it('should reload data from disk', async () => {
|
|
163
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
164
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
165
|
-
|
|
166
|
-
// Manually modify the file
|
|
167
|
-
const filePath = store.getFilePath();
|
|
168
|
-
const content = JSON.parse(readFileSync(filePath, 'utf-8'));
|
|
169
|
-
content['1'].name = 'Modified';
|
|
170
|
-
require('fs').writeFileSync(filePath, JSON.stringify(content));
|
|
171
|
-
|
|
172
|
-
// Reload and check
|
|
173
|
-
await store.reload();
|
|
174
|
-
const record = await store.get('1');
|
|
175
|
-
expect(record?.name).toBe('Modified');
|
|
176
|
-
});
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
describe('pretty printing', () => {
|
|
180
|
-
it('should pretty-print JSON by default', async () => {
|
|
181
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
182
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
183
|
-
|
|
184
|
-
const content = readFileSync(store.getFilePath(), 'utf-8');
|
|
185
|
-
expect(content).toContain('\n'); // Pretty printed has newlines
|
|
186
|
-
});
|
|
187
|
-
|
|
188
|
-
it('should compact JSON when pretty is false', async () => {
|
|
189
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR, pretty: false });
|
|
190
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
191
|
-
|
|
192
|
-
const content = readFileSync(store.getFilePath(), 'utf-8');
|
|
193
|
-
expect(content).not.toContain('\n'); // Compact has no newlines
|
|
194
|
-
});
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
describe('count', () => {
|
|
198
|
-
it('should return total count when no filter', async () => {
|
|
199
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
200
|
-
|
|
201
|
-
await store.set('1', { id: '1', name: 'Alice', status: 'active' });
|
|
202
|
-
await store.set('2', { id: '2', name: 'Bob', status: 'inactive' });
|
|
203
|
-
await store.set('3', { id: '3', name: 'Charlie', status: 'active' });
|
|
204
|
-
|
|
205
|
-
const count = await store.count();
|
|
206
|
-
expect(count).toBe(3);
|
|
207
|
-
});
|
|
208
|
-
|
|
209
|
-
it('should return count matching where clause', async () => {
|
|
210
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
211
|
-
|
|
212
|
-
await store.set('1', { id: '1', name: 'Alice', status: 'active' });
|
|
213
|
-
await store.set('2', { id: '2', name: 'Bob', status: 'inactive' });
|
|
214
|
-
await store.set('3', { id: '3', name: 'Charlie', status: 'active' });
|
|
215
|
-
|
|
216
|
-
const count = await store.count({ where: { status: 'active' } });
|
|
217
|
-
expect(count).toBe(2);
|
|
218
|
-
});
|
|
219
|
-
|
|
220
|
-
it('should return 0 when no records match', async () => {
|
|
221
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
222
|
-
|
|
223
|
-
await store.set('1', { id: '1', status: 'active' });
|
|
224
|
-
|
|
225
|
-
const count = await store.count({ where: { status: 'unknown' } });
|
|
226
|
-
expect(count).toBe(0);
|
|
227
|
-
});
|
|
228
|
-
|
|
229
|
-
it('should ignore limit and offset for counting', async () => {
|
|
230
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
231
|
-
|
|
232
|
-
await store.set('1', { id: '1', status: 'active' });
|
|
233
|
-
await store.set('2', { id: '2', status: 'active' });
|
|
234
|
-
await store.set('3', { id: '3', status: 'active' });
|
|
235
|
-
|
|
236
|
-
// limit/offset should not affect count - count returns total matching records
|
|
237
|
-
const count = await store.count({ where: { status: 'active' }, limit: 1, offset: 1 });
|
|
238
|
-
expect(count).toBe(3);
|
|
239
|
-
});
|
|
240
|
-
|
|
241
|
-
it('should return 0 for empty store', async () => {
|
|
242
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
243
|
-
|
|
244
|
-
const count = await store.count();
|
|
245
|
-
expect(count).toBe(0);
|
|
246
|
-
});
|
|
247
|
-
});
|
|
248
|
-
|
|
249
|
-
describe('utilities', () => {
|
|
250
|
-
it('should report size correctly', async () => {
|
|
251
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
252
|
-
|
|
253
|
-
expect(store.size()).toBe(0);
|
|
254
|
-
|
|
255
|
-
await store.set('1', { id: '1' });
|
|
256
|
-
await store.set('2', { id: '2' });
|
|
257
|
-
|
|
258
|
-
expect(store.size()).toBe(2);
|
|
259
|
-
});
|
|
260
|
-
|
|
261
|
-
it('should dump all records', async () => {
|
|
262
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
263
|
-
|
|
264
|
-
await store.set('1', { id: '1', name: 'Alice' });
|
|
265
|
-
await store.set('2', { id: '2', name: 'Bob' });
|
|
266
|
-
|
|
267
|
-
const dump = store.dump();
|
|
268
|
-
expect(dump).toHaveLength(2);
|
|
269
|
-
});
|
|
270
|
-
|
|
271
|
-
it('should return file path', () => {
|
|
272
|
-
const store = new FileStore('test-store', { baseDir: TEST_DIR });
|
|
273
|
-
expect(store.getFilePath()).toBe(join(TEST_DIR, 'test-store.json'));
|
|
274
|
-
});
|
|
275
|
-
});
|
|
276
|
-
});
|
package/src/stores/file.ts
DELETED
|
@@ -1,211 +0,0 @@
|
|
|
1
|
-
import { writeFile } from 'node:fs/promises';
|
|
2
|
-
import { writeFileSync, existsSync } from 'node:fs';
|
|
3
|
-
import { join, dirname } from 'node:path';
|
|
4
|
-
import type { StoreAdapter, StoreFilter } from './types.js';
|
|
5
|
-
import { applyStoreFilter } from './types.js';
|
|
6
|
-
import {
|
|
7
|
-
ensureDirectory,
|
|
8
|
-
readJsonFile,
|
|
9
|
-
serialize,
|
|
10
|
-
} from '../utils/file.js';
|
|
11
|
-
|
|
12
|
-
export interface FileStoreOptions {
|
|
13
|
-
/** Base directory for data files (default: '.reqon-data') */
|
|
14
|
-
baseDir?: string;
|
|
15
|
-
/** Write mode: 'immediate' writes on every change, 'batch' only on flush/close, 'debounce' batches writes */
|
|
16
|
-
persist?: 'immediate' | 'batch' | 'debounce';
|
|
17
|
-
/** Pretty-print JSON for readability (default: true) */
|
|
18
|
-
pretty?: boolean;
|
|
19
|
-
/** Debounce delay in milliseconds (default: 100ms, only used with persist: 'debounce') */
|
|
20
|
-
debounceMs?: number;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const DEFAULT_OPTIONS: Required<FileStoreOptions> = {
|
|
24
|
-
baseDir: '.reqon-data',
|
|
25
|
-
persist: 'immediate',
|
|
26
|
-
pretty: true,
|
|
27
|
-
debounceMs: 100,
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* File-based JSON store for local development
|
|
32
|
-
* Persists data to .reqon-data/{name}.json
|
|
33
|
-
*/
|
|
34
|
-
export class FileStore implements StoreAdapter {
|
|
35
|
-
private data: Map<string, Record<string, unknown>> = new Map();
|
|
36
|
-
private filePath: string;
|
|
37
|
-
private options: Required<FileStoreOptions>;
|
|
38
|
-
private dirty = false;
|
|
39
|
-
private initialized: Promise<void>;
|
|
40
|
-
private debounceTimer: ReturnType<typeof setTimeout> | null = null;
|
|
41
|
-
private pendingWrite: Promise<void> | null = null;
|
|
42
|
-
|
|
43
|
-
constructor(name: string, options: FileStoreOptions = {}) {
|
|
44
|
-
this.options = { ...DEFAULT_OPTIONS, ...options };
|
|
45
|
-
this.filePath = join(this.options.baseDir, `${name}.json`);
|
|
46
|
-
this.initialized = this.init();
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
private async init(): Promise<void> {
|
|
50
|
-
const dir = dirname(this.filePath);
|
|
51
|
-
await ensureDirectory(dir);
|
|
52
|
-
// Create .gitignore if it doesn't exist
|
|
53
|
-
const gitignorePath = join(dir, '.gitignore');
|
|
54
|
-
if (!existsSync(gitignorePath)) {
|
|
55
|
-
await writeFile(gitignorePath, '# Reqon local data\n*.json\n', 'utf-8');
|
|
56
|
-
}
|
|
57
|
-
await this.load();
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
private async load(): Promise<void> {
|
|
61
|
-
const parsed = await readJsonFile<Record<string, Record<string, unknown>>>(this.filePath);
|
|
62
|
-
if (parsed) {
|
|
63
|
-
this.data = new Map(Object.entries(parsed));
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
private async persist(): Promise<void> {
|
|
68
|
-
if (this.options.persist === 'batch') {
|
|
69
|
-
this.dirty = true;
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
if (this.options.persist === 'debounce') {
|
|
73
|
-
this.dirty = true;
|
|
74
|
-
this.scheduleDebouncedWrite();
|
|
75
|
-
return;
|
|
76
|
-
}
|
|
77
|
-
await this.writeToDisk();
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
private scheduleDebouncedWrite(): void {
|
|
81
|
-
// Clear existing timer if any
|
|
82
|
-
if (this.debounceTimer) {
|
|
83
|
-
clearTimeout(this.debounceTimer);
|
|
84
|
-
}
|
|
85
|
-
// Schedule new write
|
|
86
|
-
this.debounceTimer = setTimeout(() => {
|
|
87
|
-
this.debounceTimer = null;
|
|
88
|
-
if (this.dirty && !this.pendingWrite) {
|
|
89
|
-
this.pendingWrite = this.writeToDisk().finally(() => {
|
|
90
|
-
this.pendingWrite = null;
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
}, this.options.debounceMs);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
private async writeToDisk(): Promise<void> {
|
|
97
|
-
const obj = Object.fromEntries(this.data);
|
|
98
|
-
const content = serialize(obj, this.options.pretty);
|
|
99
|
-
await writeFile(this.filePath, content, 'utf-8');
|
|
100
|
-
this.dirty = false;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
/** Synchronous write for flush/close operations */
|
|
104
|
-
private writeToDiskSync(): void {
|
|
105
|
-
const obj = Object.fromEntries(this.data);
|
|
106
|
-
const content = serialize(obj, this.options.pretty);
|
|
107
|
-
writeFileSync(this.filePath, content, 'utf-8');
|
|
108
|
-
this.dirty = false;
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
async get(key: string): Promise<Record<string, unknown> | null> {
|
|
112
|
-
await this.initialized;
|
|
113
|
-
return this.data.get(key) ?? null;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
async set(key: string, value: Record<string, unknown>): Promise<void> {
|
|
117
|
-
await this.initialized;
|
|
118
|
-
this.data.set(key, { ...value });
|
|
119
|
-
await this.persist();
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
async bulkSet(records: Array<{ key: string; value: Record<string, unknown> }>): Promise<void> {
|
|
123
|
-
await this.initialized;
|
|
124
|
-
// Set all records in memory first (no disk I/O per record)
|
|
125
|
-
for (const { key, value } of records) {
|
|
126
|
-
this.data.set(key, { ...value });
|
|
127
|
-
}
|
|
128
|
-
// Single persist operation for all records
|
|
129
|
-
await this.persist();
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
async update(key: string, value: Partial<Record<string, unknown>>): Promise<void> {
|
|
133
|
-
await this.initialized;
|
|
134
|
-
const existing = this.data.get(key);
|
|
135
|
-
if (existing) {
|
|
136
|
-
this.data.set(key, { ...existing, ...value });
|
|
137
|
-
} else {
|
|
138
|
-
this.data.set(key, value as Record<string, unknown>);
|
|
139
|
-
}
|
|
140
|
-
await this.persist();
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
async delete(key: string): Promise<void> {
|
|
144
|
-
await this.initialized;
|
|
145
|
-
this.data.delete(key);
|
|
146
|
-
await this.persist();
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
async list(filter?: StoreFilter): Promise<Record<string, unknown>[]> {
|
|
150
|
-
await this.initialized;
|
|
151
|
-
return applyStoreFilter(Array.from(this.data.values()), filter);
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
async count(filter?: StoreFilter): Promise<number> {
|
|
155
|
-
await this.initialized;
|
|
156
|
-
// Apply only the where clause for counting (ignore limit/offset)
|
|
157
|
-
const filtered = applyStoreFilter(Array.from(this.data.values()), {
|
|
158
|
-
where: filter?.where,
|
|
159
|
-
});
|
|
160
|
-
return filtered.length;
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
async clear(): Promise<void> {
|
|
164
|
-
await this.initialized;
|
|
165
|
-
this.data.clear();
|
|
166
|
-
await this.persist();
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
/**
|
|
170
|
-
* Flush pending changes to disk (needed in 'batch' or 'debounce' mode)
|
|
171
|
-
* Uses synchronous I/O to ensure data is written before process exits
|
|
172
|
-
*/
|
|
173
|
-
flush(): void {
|
|
174
|
-
// Cancel any pending debounce timer
|
|
175
|
-
if (this.debounceTimer) {
|
|
176
|
-
clearTimeout(this.debounceTimer);
|
|
177
|
-
this.debounceTimer = null;
|
|
178
|
-
}
|
|
179
|
-
if (this.dirty) {
|
|
180
|
-
this.writeToDiskSync();
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
/**
|
|
185
|
-
* Close the store, ensuring all pending changes are written to disk.
|
|
186
|
-
* Should be called before the process exits to prevent data loss in batch mode.
|
|
187
|
-
*/
|
|
188
|
-
close(): void {
|
|
189
|
-
this.flush();
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
/**
|
|
193
|
-
* Reload data from disk (useful if file was modified externally)
|
|
194
|
-
*/
|
|
195
|
-
async reload(): Promise<void> {
|
|
196
|
-
await this.load();
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
// For debugging
|
|
200
|
-
size(): number {
|
|
201
|
-
return this.data.size;
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
dump(): Record<string, unknown>[] {
|
|
205
|
-
return Array.from(this.data.values());
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
getFilePath(): string {
|
|
209
|
-
return this.filePath;
|
|
210
|
-
}
|
|
211
|
-
}
|
package/src/stores/index.ts
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export type { StoreAdapter, StoreFilter, StoreConfig } from './types.js';
|
|
2
|
-
export { applyStoreFilter } from './types.js';
|
|
3
|
-
export { MemoryStore } from './memory.js';
|
|
4
|
-
export { FileStore, type FileStoreOptions } from './file.js';
|
|
5
|
-
export { PostgRESTStore, PostgRESTError, type PostgRESTOptions } from './postgrest.js';
|
|
6
|
-
export { createStore, resolveStoreType, type StoreType, type CreateStoreOptions } from './factory.js';
|