@fragno-dev/db 0.2.2 → 0.4.1
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/.turbo/turbo-build.log +404 -175
- package/CHANGELOG.md +109 -0
- package/README.md +54 -9
- package/dist/adapters/adapters.d.ts +23 -21
- package/dist/adapters/adapters.d.ts.map +1 -1
- package/dist/adapters/adapters.js.map +1 -1
- package/dist/adapters/generic-sql/driver-config.d.ts +16 -1
- package/dist/adapters/generic-sql/driver-config.d.ts.map +1 -1
- package/dist/adapters/generic-sql/driver-config.js +23 -1
- package/dist/adapters/generic-sql/driver-config.js.map +1 -1
- package/dist/adapters/generic-sql/generic-sql-adapter.d.ts +24 -9
- package/dist/adapters/generic-sql/generic-sql-adapter.d.ts.map +1 -1
- package/dist/adapters/generic-sql/generic-sql-adapter.js +60 -22
- package/dist/adapters/generic-sql/generic-sql-adapter.js.map +1 -1
- package/dist/adapters/generic-sql/generic-sql-uow-executor.js +169 -3
- package/dist/adapters/generic-sql/generic-sql-uow-executor.js.map +1 -1
- package/dist/adapters/generic-sql/migration/cold-kysely.js.map +1 -1
- package/dist/adapters/generic-sql/migration/dialect/mysql.js +25 -6
- package/dist/adapters/generic-sql/migration/dialect/mysql.js.map +1 -1
- package/dist/adapters/generic-sql/migration/dialect/postgres.js +7 -6
- package/dist/adapters/generic-sql/migration/dialect/postgres.js.map +1 -1
- package/dist/adapters/generic-sql/migration/dialect/sqlite.js +193 -16
- package/dist/adapters/generic-sql/migration/dialect/sqlite.js.map +1 -1
- package/dist/adapters/generic-sql/migration/executor.d.ts.map +1 -1
- package/dist/adapters/generic-sql/migration/executor.js +30 -3
- package/dist/adapters/generic-sql/migration/executor.js.map +1 -1
- package/dist/adapters/generic-sql/migration/prepared-migrations.d.ts.map +1 -1
- package/dist/adapters/generic-sql/migration/prepared-migrations.js +9 -9
- package/dist/adapters/generic-sql/migration/prepared-migrations.js.map +1 -1
- package/dist/adapters/generic-sql/migration/sql-generator.js +75 -52
- package/dist/adapters/generic-sql/migration/sql-generator.js.map +1 -1
- package/dist/adapters/generic-sql/query/create-sql-query-compiler.js +7 -6
- package/dist/adapters/generic-sql/query/create-sql-query-compiler.js.map +1 -1
- package/dist/adapters/generic-sql/query/cursor-utils.js +42 -4
- package/dist/adapters/generic-sql/query/cursor-utils.js.map +1 -1
- package/dist/adapters/generic-sql/query/db-now-sql.js +27 -0
- package/dist/adapters/generic-sql/query/db-now-sql.js.map +1 -0
- package/dist/adapters/generic-sql/query/generic-sql-uow-operation-compiler.js +32 -21
- package/dist/adapters/generic-sql/query/generic-sql-uow-operation-compiler.js.map +1 -1
- package/dist/adapters/generic-sql/query/select-builder.js +5 -3
- package/dist/adapters/generic-sql/query/select-builder.js.map +1 -1
- package/dist/adapters/generic-sql/query/sql-query-compiler.js +49 -18
- package/dist/adapters/generic-sql/query/sql-query-compiler.js.map +1 -1
- package/dist/adapters/generic-sql/query/where-builder.js +43 -29
- package/dist/adapters/generic-sql/query/where-builder.js.map +1 -1
- package/dist/adapters/generic-sql/sqlite-storage.d.ts +13 -0
- package/dist/adapters/generic-sql/sqlite-storage.d.ts.map +1 -0
- package/dist/adapters/generic-sql/sqlite-storage.js +15 -0
- package/dist/adapters/generic-sql/sqlite-storage.js.map +1 -0
- package/dist/adapters/generic-sql/uow-decoder.js +6 -2
- package/dist/adapters/generic-sql/uow-decoder.js.map +1 -1
- package/dist/adapters/generic-sql/uow-encoder.js +27 -8
- package/dist/adapters/generic-sql/uow-encoder.js.map +1 -1
- package/dist/adapters/in-memory/condition-evaluator.js +135 -0
- package/dist/adapters/in-memory/condition-evaluator.js.map +1 -0
- package/dist/adapters/in-memory/errors.d.ts +13 -0
- package/dist/adapters/in-memory/errors.d.ts.map +1 -0
- package/dist/adapters/in-memory/errors.js +23 -0
- package/dist/adapters/in-memory/errors.js.map +1 -0
- package/dist/adapters/in-memory/in-memory-adapter.d.ts +27 -0
- package/dist/adapters/in-memory/in-memory-adapter.d.ts.map +1 -0
- package/dist/adapters/in-memory/in-memory-adapter.js +196 -0
- package/dist/adapters/in-memory/in-memory-adapter.js.map +1 -0
- package/dist/adapters/in-memory/in-memory-uow.js +871 -0
- package/dist/adapters/in-memory/in-memory-uow.js.map +1 -0
- package/dist/adapters/in-memory/index.d.ts +4 -0
- package/dist/adapters/in-memory/index.js +4 -0
- package/dist/adapters/in-memory/options.d.ts +30 -0
- package/dist/adapters/in-memory/options.d.ts.map +1 -0
- package/dist/adapters/in-memory/options.js +62 -0
- package/dist/adapters/in-memory/options.js.map +1 -0
- package/dist/adapters/in-memory/reference-resolution.js +26 -0
- package/dist/adapters/in-memory/reference-resolution.js.map +1 -0
- package/dist/adapters/in-memory/sorted-array-index.js +129 -0
- package/dist/adapters/in-memory/sorted-array-index.js.map +1 -0
- package/dist/adapters/in-memory/store.js +71 -0
- package/dist/adapters/in-memory/store.js.map +1 -0
- package/dist/adapters/in-memory/value-comparison.js +28 -0
- package/dist/adapters/in-memory/value-comparison.js.map +1 -0
- package/dist/adapters/shared/from-unit-of-work-compiler.js +51 -24
- package/dist/adapters/shared/from-unit-of-work-compiler.js.map +1 -1
- package/dist/adapters/shared/uow-operation-compiler.js +11 -11
- package/dist/adapters/shared/uow-operation-compiler.js.map +1 -1
- package/dist/adapters/sql/index.d.ts +5 -0
- package/dist/adapters/sql/index.js +4 -0
- package/dist/browser/adapters/adapters.d.ts +61 -0
- package/dist/browser/adapters/adapters.d.ts.map +1 -0
- package/dist/browser/adapters/generic-sql/migration/executor.d.ts +15 -0
- package/dist/browser/adapters/generic-sql/migration/executor.d.ts.map +1 -0
- package/dist/browser/adapters/generic-sql/migration/prepared-migrations.d.ts +66 -0
- package/dist/browser/adapters/generic-sql/migration/prepared-migrations.d.ts.map +1 -0
- package/dist/browser/adapters/generic-sql/sqlite-storage.d.ts +11 -0
- package/dist/browser/adapters/generic-sql/sqlite-storage.d.ts.map +1 -0
- package/dist/browser/adapters/in-memory/in-memory-adapter.d.ts +5 -0
- package/dist/browser/adapters/in-memory/index.d.ts +2 -0
- package/dist/browser/adapters/in-memory/options.d.ts +1 -0
- package/dist/browser/db-fragment-definition-builder.d.ts +237 -0
- package/dist/browser/db-fragment-definition-builder.d.ts.map +1 -0
- package/dist/browser/durable-hooks.d.ts +3 -0
- package/dist/browser/fragments/internal-fragment.d.ts +317 -0
- package/dist/browser/fragments/internal-fragment.d.ts.map +1 -0
- package/dist/browser/fragments/internal-fragment.schema.d.ts +1 -0
- package/dist/browser/hooks/durable-hooks-logger.d.ts +10 -0
- package/dist/browser/hooks/durable-hooks-logger.d.ts.map +1 -0
- package/dist/browser/hooks/hooks.d.ts +146 -0
- package/dist/browser/hooks/hooks.d.ts.map +1 -0
- package/dist/browser/id.js +1 -0
- package/dist/browser/internal/adapter-registry.d.ts +4 -0
- package/dist/browser/internal/outbox-state.d.ts +2 -0
- package/dist/browser/mod.d.ts +15 -0
- package/dist/browser/mod.d.ts.map +1 -0
- package/dist/browser/mod.js +17 -0
- package/dist/browser/mod.js.map +1 -0
- package/dist/browser/mod2.d.ts +48 -0
- package/dist/browser/mod2.d.ts.map +1 -0
- package/dist/browser/naming/sql-naming.d.ts +19 -0
- package/dist/browser/naming/sql-naming.d.ts.map +1 -0
- package/dist/browser/outbox/outbox.d.ts +21 -0
- package/dist/browser/outbox/outbox.d.ts.map +1 -0
- package/dist/browser/query/column-defaults.js +1 -0
- package/dist/browser/query/condition-builder.d.ts +44 -0
- package/dist/browser/query/condition-builder.d.ts.map +1 -0
- package/dist/browser/query/condition-builder.js +97 -0
- package/dist/browser/query/condition-builder.js.map +1 -0
- package/dist/browser/query/cursor.d.ts +105 -0
- package/dist/browser/query/cursor.d.ts.map +1 -0
- package/dist/browser/query/cursor.js +150 -0
- package/dist/browser/query/cursor.js.map +1 -0
- package/dist/browser/query/db-now.d.ts +22 -0
- package/dist/browser/query/db-now.d.ts.map +1 -0
- package/dist/browser/query/db-now.js +33 -0
- package/dist/browser/query/db-now.js.map +1 -0
- package/dist/browser/query/orm/orm.d.ts +18 -0
- package/dist/browser/query/orm/orm.d.ts.map +1 -0
- package/dist/browser/query/simple-query-interface.d.ts +108 -0
- package/dist/browser/query/simple-query-interface.d.ts.map +1 -0
- package/dist/browser/query/unit-of-work/execute-unit-of-work.d.ts +423 -0
- package/dist/browser/query/unit-of-work/execute-unit-of-work.d.ts.map +1 -0
- package/dist/browser/query/unit-of-work/execute-unit-of-work.js +507 -0
- package/dist/browser/query/unit-of-work/execute-unit-of-work.js.map +1 -0
- package/dist/browser/query/unit-of-work/retry-policy.d.ts +23 -0
- package/dist/browser/query/unit-of-work/retry-policy.d.ts.map +1 -0
- package/dist/browser/query/unit-of-work/retry-policy.js +40 -0
- package/dist/browser/query/unit-of-work/retry-policy.js.map +1 -0
- package/dist/browser/query/unit-of-work/unit-of-work.d.ts +703 -0
- package/dist/browser/query/unit-of-work/unit-of-work.d.ts.map +1 -0
- package/dist/browser/query/unit-of-work/unit-of-work.js +1206 -0
- package/dist/browser/query/unit-of-work/unit-of-work.js.map +1 -0
- package/dist/browser/query/value-encoding.js +38 -0
- package/dist/browser/query/value-encoding.js.map +1 -0
- package/dist/browser/schema/create.d.ts +326 -0
- package/dist/browser/schema/create.d.ts.map +1 -0
- package/dist/browser/schema/create.js +89 -0
- package/dist/browser/schema/create.js.map +1 -0
- package/dist/browser/schema/generate-id.js +28 -0
- package/dist/browser/schema/generate-id.js.map +1 -0
- package/dist/browser/shared/providers.d.ts +6 -0
- package/dist/browser/shared/providers.d.ts.map +1 -0
- package/dist/browser/sql-driver/connection/connection-provider.d.ts +13 -0
- package/dist/browser/sql-driver/connection/connection-provider.d.ts.map +1 -0
- package/dist/browser/sql-driver/dialect-adapter/dialect-adapter.d.ts +7 -0
- package/dist/browser/sql-driver/dialect-adapter/dialect-adapter.d.ts.map +1 -0
- package/dist/browser/sql-driver/driver/runtime-driver.d.ts +23 -0
- package/dist/browser/sql-driver/driver/runtime-driver.d.ts.map +1 -0
- package/dist/browser/sql-driver/query-executor/plugin.d.ts +17 -0
- package/dist/browser/sql-driver/query-executor/plugin.d.ts.map +1 -0
- package/dist/browser/sql-driver/query-executor/query-executor.d.ts +36 -0
- package/dist/browser/sql-driver/query-executor/query-executor.d.ts.map +1 -0
- package/dist/browser/sql-driver/sql-driver-adapter.d.ts +29 -0
- package/dist/browser/sql-driver/sql-driver-adapter.d.ts.map +1 -0
- package/dist/browser/sql-driver/sql-driver.d.ts +38 -0
- package/dist/browser/sql-driver/sql-driver.d.ts.map +1 -0
- package/dist/browser/sync/commands.d.ts +15 -0
- package/dist/browser/sync/commands.d.ts.map +1 -0
- package/dist/browser/sync/commands.js +27 -0
- package/dist/browser/sync/commands.js.map +1 -0
- package/dist/browser/sync/types.d.ts +63 -0
- package/dist/browser/sync/types.d.ts.map +1 -0
- package/dist/browser/util/types.d.ts +8 -0
- package/dist/browser/util/types.d.ts.map +1 -0
- package/dist/browser/with-database.d.ts +29 -0
- package/dist/browser/with-database.d.ts.map +1 -0
- package/dist/client.d.ts +4 -0
- package/dist/client.js +5 -0
- package/dist/db-fragment-definition-builder.d.ts +101 -33
- package/dist/db-fragment-definition-builder.d.ts.map +1 -1
- package/dist/db-fragment-definition-builder.js +450 -60
- package/dist/db-fragment-definition-builder.js.map +1 -1
- package/dist/dispatchers/cloudflare-do/dispatcher.d.ts +20 -0
- package/dist/dispatchers/cloudflare-do/dispatcher.d.ts.map +1 -0
- package/dist/dispatchers/cloudflare-do/dispatcher.js +147 -0
- package/dist/dispatchers/cloudflare-do/dispatcher.js.map +1 -0
- package/dist/dispatchers/cloudflare-do/index.d.ts +11 -0
- package/dist/dispatchers/cloudflare-do/index.d.ts.map +1 -0
- package/dist/dispatchers/cloudflare-do/index.js +31 -0
- package/dist/dispatchers/cloudflare-do/index.js.map +1 -0
- package/dist/dispatchers/node/dispatcher.d.ts +14 -0
- package/dist/dispatchers/node/dispatcher.d.ts.map +1 -0
- package/dist/dispatchers/node/dispatcher.js +80 -0
- package/dist/dispatchers/node/dispatcher.js.map +1 -0
- package/dist/dispatchers/node/index.d.ts +12 -0
- package/dist/dispatchers/node/index.d.ts.map +1 -0
- package/dist/dispatchers/node/index.js +27 -0
- package/dist/dispatchers/node/index.js.map +1 -0
- package/dist/durable-hooks.d.ts +31 -0
- package/dist/durable-hooks.d.ts.map +1 -0
- package/dist/durable-hooks.js +23 -0
- package/dist/durable-hooks.js.map +1 -0
- package/dist/fragments/internal-fragment.d.ts +186 -8
- package/dist/fragments/internal-fragment.d.ts.map +1 -1
- package/dist/fragments/internal-fragment.js +203 -38
- package/dist/fragments/internal-fragment.js.map +1 -1
- package/dist/fragments/internal-fragment.routes.js +164 -0
- package/dist/fragments/internal-fragment.routes.js.map +1 -0
- package/dist/fragments/internal-fragment.schema.d.ts +15 -0
- package/dist/fragments/internal-fragment.schema.d.ts.map +1 -0
- package/dist/fragments/internal-fragment.schema.js +39 -0
- package/dist/fragments/internal-fragment.schema.js.map +1 -0
- package/dist/hooks/durable-hooks-logger.d.ts +10 -0
- package/dist/hooks/durable-hooks-logger.d.ts.map +1 -0
- package/dist/hooks/durable-hooks-logger.js +75 -0
- package/dist/hooks/durable-hooks-logger.js.map +1 -0
- package/dist/hooks/durable-hooks-processor.d.ts +1 -0
- package/dist/hooks/durable-hooks-processor.js +80 -0
- package/dist/hooks/durable-hooks-processor.js.map +1 -0
- package/dist/hooks/durable-hooks-runtime.js +44 -0
- package/dist/hooks/durable-hooks-runtime.js.map +1 -0
- package/dist/hooks/hooks.d.ts +100 -1
- package/dist/hooks/hooks.d.ts.map +1 -1
- package/dist/hooks/hooks.js +254 -27
- package/dist/hooks/hooks.js.map +1 -1
- package/dist/id.d.ts +2 -2
- package/dist/id.js +2 -2
- package/dist/internal/adapter-registry.d.ts +11 -0
- package/dist/internal/adapter-registry.d.ts.map +1 -0
- package/dist/internal/adapter-registry.js +135 -0
- package/dist/internal/adapter-registry.js.map +1 -0
- package/dist/internal/outbox-state.d.ts +2 -0
- package/dist/internal/outbox-state.js +26 -0
- package/dist/internal/outbox-state.js.map +1 -0
- package/dist/migration-engine/auto-from-schema.d.ts +33 -0
- package/dist/migration-engine/auto-from-schema.d.ts.map +1 -0
- package/dist/migration-engine/auto-from-schema.js +223 -37
- package/dist/migration-engine/auto-from-schema.js.map +1 -1
- package/dist/migration-engine/generation-engine.d.ts +16 -10
- package/dist/migration-engine/generation-engine.d.ts.map +1 -1
- package/dist/migration-engine/generation-engine.js +86 -35
- package/dist/migration-engine/generation-engine.js.map +1 -1
- package/dist/migration-engine/shared.d.ts +113 -0
- package/dist/migration-engine/shared.d.ts.map +1 -0
- package/dist/migration-engine/shared.js.map +1 -1
- package/dist/mod.d.ts +20 -12
- package/dist/mod.d.ts.map +1 -1
- package/dist/mod.js +18 -12
- package/dist/mod.js.map +1 -1
- package/dist/naming/sql-naming.d.ts +19 -0
- package/dist/naming/sql-naming.d.ts.map +1 -0
- package/dist/naming/sql-naming.js +116 -0
- package/dist/naming/sql-naming.js.map +1 -0
- package/dist/outbox/outbox-builder.js +156 -0
- package/dist/outbox/outbox-builder.js.map +1 -0
- package/dist/outbox/outbox.d.ts +54 -0
- package/dist/outbox/outbox.d.ts.map +1 -0
- package/dist/outbox/outbox.js +37 -0
- package/dist/outbox/outbox.js.map +1 -0
- package/dist/query/column-defaults.js +20 -4
- package/dist/query/column-defaults.js.map +1 -1
- package/dist/query/condition-builder.d.ts +7 -1
- package/dist/query/condition-builder.d.ts.map +1 -1
- package/dist/query/condition-builder.js +5 -1
- package/dist/query/condition-builder.js.map +1 -1
- package/dist/query/cursor-client.d.ts +105 -0
- package/dist/query/cursor-client.d.ts.map +1 -0
- package/dist/query/cursor-client.js +165 -0
- package/dist/query/cursor-client.js.map +1 -0
- package/dist/query/cursor.d.ts +3 -1
- package/dist/query/cursor.d.ts.map +1 -1
- package/dist/query/cursor.js +51 -14
- package/dist/query/cursor.js.map +1 -1
- package/dist/query/db-now.d.ts +22 -0
- package/dist/query/db-now.d.ts.map +1 -0
- package/dist/query/db-now.js +35 -0
- package/dist/query/db-now.js.map +1 -0
- package/dist/query/orm/orm.js.map +1 -1
- package/dist/query/serialize/create-sql-serializer.js +5 -4
- package/dist/query/serialize/create-sql-serializer.js.map +1 -1
- package/dist/query/serialize/dialect/mysql-serializer.js +12 -6
- package/dist/query/serialize/dialect/mysql-serializer.js.map +1 -1
- package/dist/query/serialize/dialect/postgres-serializer.js +25 -7
- package/dist/query/serialize/dialect/postgres-serializer.js.map +1 -1
- package/dist/query/serialize/dialect/sqlite-serializer.js +60 -12
- package/dist/query/serialize/dialect/sqlite-serializer.js.map +1 -1
- package/dist/query/serialize/sql-serializer.js +2 -2
- package/dist/query/serialize/sql-serializer.js.map +1 -1
- package/dist/query/simple-query-interface.d.ts +13 -4
- package/dist/query/simple-query-interface.d.ts.map +1 -1
- package/dist/query/unit-of-work/execute-unit-of-work.d.ts +37 -2
- package/dist/query/unit-of-work/execute-unit-of-work.d.ts.map +1 -1
- package/dist/query/unit-of-work/execute-unit-of-work.js +50 -24
- package/dist/query/unit-of-work/execute-unit-of-work.js.map +1 -1
- package/dist/query/unit-of-work/unit-of-work.d.ts +92 -30
- package/dist/query/unit-of-work/unit-of-work.d.ts.map +1 -1
- package/dist/query/unit-of-work/unit-of-work.js +136 -11
- package/dist/query/unit-of-work/unit-of-work.js.map +1 -1
- package/dist/query/value-decoding.js +16 -6
- package/dist/query/value-decoding.js.map +1 -1
- package/dist/query/value-encoding.js +29 -9
- package/dist/query/value-encoding.js.map +1 -1
- package/dist/schema/create.d.ts +103 -35
- package/dist/schema/create.d.ts.map +1 -1
- package/dist/schema/create.js +172 -58
- package/dist/schema/create.js.map +1 -1
- package/dist/schema/generate-id.js +2 -2
- package/dist/schema/generate-id.js.map +1 -1
- package/dist/schema/type-conversion/create-sql-type-mapper.js +4 -3
- package/dist/schema/type-conversion/create-sql-type-mapper.js.map +1 -1
- package/dist/schema/type-conversion/dialect/sqlite.js +9 -0
- package/dist/schema/type-conversion/dialect/sqlite.js.map +1 -1
- package/dist/schema/validator.d.ts +10 -0
- package/dist/schema/validator.d.ts.map +1 -0
- package/dist/schema/validator.js +123 -0
- package/dist/schema/validator.js.map +1 -0
- package/dist/schema-output/drizzle.d.ts +30 -0
- package/dist/schema-output/drizzle.d.ts.map +1 -0
- package/dist/{adapters/drizzle/generate.js → schema-output/drizzle.js} +88 -60
- package/dist/schema-output/drizzle.js.map +1 -0
- package/dist/schema-output/prisma.d.ts +17 -0
- package/dist/schema-output/prisma.d.ts.map +1 -0
- package/dist/schema-output/prisma.js +307 -0
- package/dist/schema-output/prisma.js.map +1 -0
- package/dist/sql-driver/dialects/durable-object-dialect.js +3 -9
- package/dist/sql-driver/dialects/durable-object-dialect.js.map +1 -1
- package/dist/sql-driver/query-executor/default-query-executor.js.map +1 -1
- package/dist/sql-driver/query-executor/query-executor-base.js.map +1 -1
- package/dist/sql-driver/sql-driver-adapter.js.map +1 -1
- package/dist/sql-driver/sql.js.map +1 -1
- package/dist/sync/commands.d.ts +15 -0
- package/dist/sync/commands.d.ts.map +1 -0
- package/dist/sync/commands.js +27 -0
- package/dist/sync/commands.js.map +1 -0
- package/dist/sync/index.d.ts +4 -0
- package/dist/sync/index.js +4 -0
- package/dist/sync/read-tracking.d.ts +25 -0
- package/dist/sync/read-tracking.d.ts.map +1 -0
- package/dist/sync/read-tracking.js +148 -0
- package/dist/sync/read-tracking.js.map +1 -0
- package/dist/sync/submit.js +213 -0
- package/dist/sync/submit.js.map +1 -0
- package/dist/sync/types.d.ts +63 -0
- package/dist/sync/types.d.ts.map +1 -0
- package/dist/util/default-database-adapter.js +66 -0
- package/dist/util/default-database-adapter.js.map +1 -0
- package/dist/with-database.d.ts +3 -6
- package/dist/with-database.d.ts.map +1 -1
- package/dist/with-database.js +8 -7
- package/dist/with-database.js.map +1 -1
- package/package.json +62 -55
- package/src/adapters/adapters.ts +33 -26
- package/src/adapters/drizzle/migrate-drizzle.test.ts +99 -41
- package/src/adapters/drizzle/migration-parity-drizzle-kit.test.ts +601 -0
- package/src/adapters/drizzle/test-utils.ts +13 -8
- package/src/adapters/generic-sql/driver-config.ts +38 -0
- package/src/adapters/generic-sql/generic-sql-adapter.test.ts +10 -8
- package/src/adapters/generic-sql/generic-sql-adapter.ts +117 -34
- package/src/adapters/generic-sql/generic-sql-uow-executor.test.ts +55 -0
- package/src/adapters/generic-sql/generic-sql-uow-executor.ts +297 -3
- package/src/adapters/generic-sql/migration/adapter-migration-parity.test.ts +120 -0
- package/src/adapters/generic-sql/migration/cold-kysely.ts +1 -0
- package/src/adapters/generic-sql/migration/dialect/mysql.test.ts +27 -8
- package/src/adapters/generic-sql/migration/dialect/mysql.ts +47 -8
- package/src/adapters/generic-sql/migration/dialect/postgres.test.ts +28 -9
- package/src/adapters/generic-sql/migration/dialect/postgres.ts +9 -4
- package/src/adapters/generic-sql/migration/dialect/sqlite.test.ts +839 -8
- package/src/adapters/generic-sql/migration/dialect/sqlite.ts +396 -53
- package/src/adapters/generic-sql/migration/executor.test.ts +52 -0
- package/src/adapters/generic-sql/migration/executor.ts +47 -4
- package/src/adapters/generic-sql/migration/prepared-migrations.test.ts +238 -46
- package/src/adapters/generic-sql/migration/prepared-migrations.ts +21 -13
- package/src/adapters/generic-sql/migration/sql-generator.ts +145 -66
- package/src/adapters/generic-sql/query/create-sql-query-compiler.ts +11 -8
- package/src/adapters/generic-sql/query/cursor-utils.test.ts +272 -0
- package/src/adapters/generic-sql/query/cursor-utils.ts +42 -7
- package/src/adapters/generic-sql/query/db-now-sql.ts +49 -0
- package/src/adapters/generic-sql/query/generic-sql-uow-operation-compiler.test.ts +171 -35
- package/src/adapters/generic-sql/query/generic-sql-uow-operation-compiler.ts +53 -40
- package/src/adapters/generic-sql/query/select-builder.test.ts +16 -11
- package/src/adapters/generic-sql/query/select-builder.ts +7 -3
- package/src/adapters/generic-sql/query/sql-query-compiler.test.ts +75 -6
- package/src/adapters/generic-sql/query/sql-query-compiler.ts +129 -24
- package/src/adapters/generic-sql/query/where-builder.test.ts +96 -20
- package/src/adapters/generic-sql/query/where-builder.ts +112 -41
- package/src/adapters/{kysely/kysely-adapter-pglite.test.ts → generic-sql/sql-adapter-pglite-migrations.test.ts} +11 -20
- package/src/adapters/generic-sql/sql-adapter-pglite-pagination.test.ts +851 -0
- package/src/adapters/{drizzle/drizzle-adapter-pglite.test.ts → generic-sql/sql-adapter-pglite-queries.test.ts} +18 -15
- package/src/adapters/generic-sql/{test/generic-drizzle-adapter-sqlite3.test.ts → sql-adapter-sqlite3-driver.test.ts} +282 -14
- package/src/adapters/{drizzle/drizzle-adapter-sqlite3.test.ts → generic-sql/sql-adapter-sqlite3-uow.test.ts} +129 -12
- package/src/adapters/{kysely/kysely-adapter-sqlocal.test.ts → generic-sql/sql-adapter-sqlocal.test.ts} +9 -7
- package/src/adapters/generic-sql/sqlite-storage.ts +20 -0
- package/src/adapters/generic-sql/uow-decoder.test.ts +5 -4
- package/src/adapters/generic-sql/uow-decoder.ts +23 -5
- package/src/adapters/generic-sql/uow-encoder.test.ts +36 -3
- package/src/adapters/generic-sql/uow-encoder.ts +48 -13
- package/src/adapters/in-memory/condition-evaluator.test.ts +194 -0
- package/src/adapters/in-memory/condition-evaluator.ts +280 -0
- package/src/adapters/in-memory/errors.ts +20 -0
- package/src/adapters/in-memory/in-memory-adapter.ts +388 -0
- package/src/adapters/in-memory/in-memory-uow.mutations.test.ts +344 -0
- package/src/adapters/in-memory/in-memory-uow.retrieval.test.ts +255 -0
- package/src/adapters/in-memory/in-memory-uow.ts +1724 -0
- package/src/adapters/in-memory/index.ts +3 -0
- package/src/adapters/in-memory/options.test.ts +42 -0
- package/src/adapters/in-memory/options.ts +91 -0
- package/src/adapters/in-memory/outbox.test.ts +361 -0
- package/src/adapters/in-memory/reference-resolution.test.ts +51 -0
- package/src/adapters/in-memory/reference-resolution.ts +67 -0
- package/src/adapters/in-memory/sorted-array-index.test.ts +124 -0
- package/src/adapters/in-memory/sorted-array-index.ts +228 -0
- package/src/adapters/in-memory/store.test.ts +69 -0
- package/src/adapters/in-memory/store.ts +145 -0
- package/src/adapters/in-memory/value-comparison.ts +53 -0
- package/src/adapters/in-memory/value-normalization.test.ts +58 -0
- package/src/adapters/prisma/prisma-adapter-sqlite3.test.ts +1207 -0
- package/src/adapters/shared/from-unit-of-work-compiler.ts +159 -47
- package/src/adapters/shared/uow-operation-compiler.ts +28 -18
- package/src/adapters/sql/index.ts +12 -0
- package/src/browser/mod.ts +64 -0
- package/src/client.ts +19 -0
- package/src/db-fragment-definition-builder.test.ts +845 -53
- package/src/db-fragment-definition-builder.ts +911 -95
- package/src/db-fragment-instantiator.test.ts +210 -94
- package/src/db-fragment-integration.test.ts +17 -12
- package/src/dispatchers/cloudflare-do/dispatcher.ts +204 -0
- package/src/dispatchers/cloudflare-do/index.test.ts +206 -0
- package/src/dispatchers/cloudflare-do/index.ts +63 -0
- package/src/dispatchers/node/dispatcher.ts +112 -0
- package/src/dispatchers/node/index.test.ts +120 -0
- package/src/dispatchers/node/index.ts +50 -0
- package/src/durable-hooks.test.ts +80 -0
- package/src/durable-hooks.ts +67 -0
- package/src/fragments/internal-fragment.routes.test.ts +570 -0
- package/src/fragments/internal-fragment.routes.ts +334 -0
- package/src/fragments/internal-fragment.schema.ts +95 -0
- package/src/fragments/internal-fragment.test.ts +505 -83
- package/src/fragments/internal-fragment.ts +453 -70
- package/src/hooks/durable-hooks-logger.ts +126 -0
- package/src/hooks/durable-hooks-processor.pglite.test.ts +87 -0
- package/src/hooks/durable-hooks-processor.test.ts +282 -0
- package/src/hooks/durable-hooks-processor.ts +173 -0
- package/src/hooks/durable-hooks-runtime.test.ts +65 -0
- package/src/hooks/durable-hooks-runtime.ts +81 -0
- package/src/hooks/hooks.test.ts +455 -34
- package/src/hooks/hooks.ts +501 -34
- package/src/id.test.ts +34 -0
- package/src/id.ts +1 -3
- package/src/internal/adapter-registry.test.ts +93 -0
- package/src/internal/adapter-registry.ts +239 -0
- package/src/internal/outbox-state.ts +43 -0
- package/src/migration-engine/auto-from-schema.test.ts +107 -14
- package/src/migration-engine/auto-from-schema.ts +365 -44
- package/src/migration-engine/create.test.ts +4 -3
- package/src/migration-engine/create.ts +1 -1
- package/src/migration-engine/generation-engine.test.ts +292 -110
- package/src/migration-engine/generation-engine.ts +117 -66
- package/src/migration-engine/shared.ts +14 -0
- package/src/mod.ts +95 -39
- package/src/naming/sql-naming.ts +181 -0
- package/src/outbox/outbox-builder.ts +241 -0
- package/src/outbox/outbox.test.ts +424 -0
- package/src/outbox/outbox.ts +139 -0
- package/src/query/column-defaults.ts +42 -4
- package/src/query/condition-builder.test.ts +18 -3
- package/src/query/condition-builder.ts +7 -0
- package/src/query/cursor-client.test.ts +70 -0
- package/src/query/cursor-client.ts +263 -0
- package/src/query/cursor.test.ts +119 -20
- package/src/query/cursor.ts +88 -27
- package/src/query/db-now.ts +73 -0
- package/src/query/orm/orm.ts +2 -2
- package/src/query/query-type.test.ts +4 -3
- package/src/query/serialize/create-sql-serializer.ts +10 -5
- package/src/query/serialize/dialect/mysql-serializer.ts +13 -5
- package/src/query/serialize/dialect/postgres-serializer.ts +35 -5
- package/src/query/serialize/dialect/sqlite-serializer.test.ts +90 -3
- package/src/query/serialize/dialect/sqlite-serializer.ts +108 -12
- package/src/query/serialize/sql-serializer.ts +4 -4
- package/src/query/simple-query-interface.ts +15 -4
- package/src/query/unit-of-work/execute-unit-of-work.test.ts +372 -10
- package/src/query/unit-of-work/execute-unit-of-work.ts +87 -27
- package/src/query/unit-of-work/retry-policy.test.ts +1 -0
- package/src/query/unit-of-work/tx-builder.test.ts +73 -1
- package/src/query/unit-of-work/unit-of-work-coordinator.test.ts +17 -16
- package/src/query/unit-of-work/unit-of-work-types.test.ts +42 -12
- package/src/query/unit-of-work/unit-of-work.test.ts +196 -39
- package/src/query/unit-of-work/unit-of-work.ts +309 -38
- package/src/query/value-decoding.test.ts +63 -4
- package/src/query/value-decoding.ts +32 -6
- package/src/query/value-encoding.test.ts +86 -2
- package/src/query/value-encoding.ts +56 -6
- package/src/schema/create.test.ts +293 -47
- package/src/schema/create.ts +406 -70
- package/src/schema/generate-id.test.ts +3 -2
- package/src/schema/generate-id.ts +2 -2
- package/src/schema/serialize.test.ts +18 -5
- package/src/schema/type-conversion/create-sql-type-mapper.ts +8 -3
- package/src/schema/type-conversion/dialect/sqlite.ts +18 -0
- package/src/schema/type-conversion/type-mapping.test.ts +26 -1
- package/src/schema/validator.test.ts +199 -0
- package/src/schema/validator.ts +232 -0
- package/src/{adapters/drizzle/generate.test.ts → schema-output/drizzle.test.ts} +232 -129
- package/src/{adapters/drizzle/generate.ts → schema-output/drizzle.ts} +155 -99
- package/src/schema-output/prisma.test.ts +694 -0
- package/src/schema-output/prisma.ts +593 -0
- package/src/sql-driver/better-sqlite3.test.ts +5 -3
- package/src/sql-driver/dialects/durable-object-dialect.ts +3 -8
- package/src/sql-driver/query-executor/default-query-executor.ts +1 -1
- package/src/sql-driver/query-executor/query-executor-base.ts +1 -1
- package/src/sql-driver/query-executor/query-executor.ts +1 -1
- package/src/sql-driver/sql-driver-adapter.ts +2 -2
- package/src/sql-driver/sql.ts +2 -1
- package/src/sql-driver/sqlocal.test.ts +4 -2
- package/src/sync/commands.test.ts +39 -0
- package/src/sync/commands.ts +51 -0
- package/src/sync/conflict-checker.test.ts +450 -0
- package/src/sync/conflict-checker.ts +248 -0
- package/src/sync/index.ts +14 -0
- package/src/sync/plan.ts +9 -0
- package/src/sync/read-tracking.test.ts +177 -0
- package/src/sync/read-tracking.ts +287 -0
- package/src/sync/submit.test.ts +205 -0
- package/src/sync/submit.ts +328 -0
- package/src/sync/types.ts +80 -0
- package/src/util/default-database-adapter.ts +119 -0
- package/src/with-database.ts +20 -31
- package/tsconfig.json +1 -1
- package/tsdown.config.ts +38 -24
- package/vitest.config.ts +1 -0
- package/dist/adapters/drizzle/drizzle-adapter.d.ts +0 -20
- package/dist/adapters/drizzle/drizzle-adapter.d.ts.map +0 -1
- package/dist/adapters/drizzle/drizzle-adapter.js +0 -27
- package/dist/adapters/drizzle/drizzle-adapter.js.map +0 -1
- package/dist/adapters/drizzle/generate.d.ts +0 -30
- package/dist/adapters/drizzle/generate.d.ts.map +0 -1
- package/dist/adapters/drizzle/generate.js.map +0 -1
- package/dist/adapters/kysely/kysely-adapter.d.ts +0 -19
- package/dist/adapters/kysely/kysely-adapter.d.ts.map +0 -1
- package/dist/adapters/kysely/kysely-adapter.js +0 -17
- package/dist/adapters/kysely/kysely-adapter.js.map +0 -1
- package/dist/adapters/shared/table-name-mapper.d.ts +0 -12
- package/dist/adapters/shared/table-name-mapper.d.ts.map +0 -1
- package/dist/adapters/shared/table-name-mapper.js +0 -43
- package/dist/adapters/shared/table-name-mapper.js.map +0 -1
- package/dist/node_modules/.pnpm/rou3@0.7.10/node_modules/rou3/dist/index.js +0 -165
- package/dist/node_modules/.pnpm/rou3@0.7.10/node_modules/rou3/dist/index.js.map +0 -1
- package/dist/packages/fragno/dist/api/bind-services.js +0 -20
- package/dist/packages/fragno/dist/api/bind-services.js.map +0 -1
- package/dist/packages/fragno/dist/api/error.js +0 -48
- package/dist/packages/fragno/dist/api/error.js.map +0 -1
- package/dist/packages/fragno/dist/api/fragment-definition-builder.js +0 -320
- package/dist/packages/fragno/dist/api/fragment-definition-builder.js.map +0 -1
- package/dist/packages/fragno/dist/api/fragment-instantiator.js +0 -525
- package/dist/packages/fragno/dist/api/fragment-instantiator.js.map +0 -1
- package/dist/packages/fragno/dist/api/fragno-response.js +0 -73
- package/dist/packages/fragno/dist/api/fragno-response.js.map +0 -1
- package/dist/packages/fragno/dist/api/internal/response-stream.js +0 -81
- package/dist/packages/fragno/dist/api/internal/response-stream.js.map +0 -1
- package/dist/packages/fragno/dist/api/internal/route.js +0 -10
- package/dist/packages/fragno/dist/api/internal/route.js.map +0 -1
- package/dist/packages/fragno/dist/api/mutable-request-state.js +0 -97
- package/dist/packages/fragno/dist/api/mutable-request-state.js.map +0 -1
- package/dist/packages/fragno/dist/api/request-context-storage.js +0 -43
- package/dist/packages/fragno/dist/api/request-context-storage.js.map +0 -1
- package/dist/packages/fragno/dist/api/request-input-context.js +0 -118
- package/dist/packages/fragno/dist/api/request-input-context.js.map +0 -1
- package/dist/packages/fragno/dist/api/request-middleware.js +0 -83
- package/dist/packages/fragno/dist/api/request-middleware.js.map +0 -1
- package/dist/packages/fragno/dist/api/request-output-context.js +0 -119
- package/dist/packages/fragno/dist/api/request-output-context.js.map +0 -1
- package/dist/packages/fragno/dist/api/route.js +0 -17
- package/dist/packages/fragno/dist/api/route.js.map +0 -1
- package/dist/packages/fragno/dist/internal/symbols.js +0 -10
- package/dist/packages/fragno/dist/internal/symbols.js.map +0 -1
- package/dist/schema-generator/schema-generator.d.ts +0 -15
- package/dist/schema-generator/schema-generator.d.ts.map +0 -1
- package/src/adapters/drizzle/drizzle-adapter.ts +0 -39
- package/src/adapters/kysely/kysely-adapter.ts +0 -27
- package/src/adapters/shared/table-name-mapper.ts +0 -50
- package/src/schema-generator/schema-generator.ts +0 -12
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { DbNow } from "../query/db-now.js";
|
|
2
|
+
import { AnyColumn, AnyRelation, Column, FragnoId, IdColumn, Index, Schema, Table } from "../schema/create.js";
|
|
3
|
+
import "../mod.js";
|
|
4
|
+
|
|
5
|
+
//#region src/fragments/internal-fragment.schema.d.ts
|
|
6
|
+
declare const internalSchema: Schema<{
|
|
7
|
+
fragno_db_settings: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"key", Column<"string", string, string>> & Record<"value", Column<"string", string, string>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"unique_key", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["key"]>>>;
|
|
8
|
+
fragno_hooks: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"namespace", Column<"string", string, string>> & Record<"hookName", Column<"string", string, string>> & Record<"payload", Column<"json", unknown, unknown>> & Record<"status", Column<"string", string, string>> & Record<"attempts", Column<"integer", number | null, number>> & Record<"maxAttempts", Column<"integer", number | null, number>> & Record<"lastAttemptAt", Column<"timestamp", (Date | DbNow) | null, Date | null>> & Record<"nextRetryAt", Column<"timestamp", (Date | DbNow) | null, Date | null>> & Record<"error", Column<"string", string | null, string | null>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>> & Record<"nonce", Column<"string", string, string>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_namespace_created_at", Index<readonly [Column<"string", string, string>, Column<"timestamp", (Date | DbNow) | null, Date>, IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>] & AnyColumn[], readonly ["namespace", "createdAt", "id"]>>>;
|
|
9
|
+
fragno_db_outbox: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"versionstamp", Column<"string", string, string>> & Record<"uowId", Column<"string", string, string>> & Record<"payload", Column<"json", unknown, unknown>> & Record<"refMap", Column<"json", unknown, unknown>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_outbox_versionstamp", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["versionstamp"]>> & Record<"idx_outbox_uow", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["uowId"]>>>;
|
|
10
|
+
fragno_db_outbox_mutations: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"entryVersionstamp", Column<"string", string, string>> & Record<"mutationVersionstamp", Column<"string", string, string>> & Record<"uowId", Column<"string", string, string>> & Record<"schema", Column<"string", string, string>> & Record<"table", Column<"string", string, string>> & Record<"externalId", Column<"string", string, string>> & Record<"op", Column<"string", string, string>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_outbox_mutations_entry", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["entryVersionstamp"]>> & Record<"idx_outbox_mutations_key", Index<readonly [Column<"string", string, string>, Column<"string", string, string>, Column<"string", string, string>, Column<"string", string, string>] & AnyColumn[], readonly ["schema", "table", "externalId", "entryVersionstamp"]>> & Record<"idx_outbox_mutations_uow", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["uowId"]>>>;
|
|
11
|
+
fragno_db_sync_requests: Table<Record<"id", IdColumn<"varchar(128)", string | FragnoId | null, FragnoId>> & Record<"requestId", Column<"string", string, string>> & Record<"status", Column<"string", string, string>> & Record<"confirmedCommandIds", Column<"json", unknown, unknown>> & Record<"conflictCommandId", Column<"string", string | null, string | null>> & Record<"baseVersionstamp", Column<"string", string | null, string | null>> & Record<"lastVersionstamp", Column<"string", string | null, string | null>> & Record<"createdAt", Column<"timestamp", (Date | DbNow) | null, Date>>, Record<string, AnyRelation>, Record<string, Index<AnyColumn[], readonly string[]>> & Record<"idx_sync_request_id", Index<readonly [Column<"string", string, string>] & AnyColumn[], readonly ["requestId"]>>>;
|
|
12
|
+
}>;
|
|
13
|
+
//#endregion
|
|
14
|
+
export { internalSchema };
|
|
15
|
+
//# sourceMappingURL=internal-fragment.schema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-fragment.schema.d.ts","names":[],"sources":["../../src/fragments/internal-fragment.schema.ts"],"sourcesContent":[],"mappings":";;;;;cAOa;2EAuFX,QAAA;;EAvFW,gBAAA,OAuFX,OAAA,CAAA,IAAA,UAAA,CAAA,cAAA,EAAA,MAAA,cAAA,IAAA,WAAA,CAAA,SAAA,CAAA,cAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,OAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,SAAA,QAAA,CAAA,MAAA,EAAA,OAAA,EAAA,OAAA,CAAA,CAAA,SAAA,CAAA,QAAA,QAAA,CAAA,MAAA,EAAA,OAAA,EAAA,OAAA,CAAA,CAAA,SAAA,CAAA,WAAA,QAAA,CAAA,WAAA,EAAA,KAAA,QAAA,CAAA,GAAA,IAAA,MAAA,CAAA,CAAA,QAAA,CAAA,MAAA,cAAA,QAAA,CAAA,MAAA,OAAA,YAAA,EAAA,SAAA,MAAA,EAAA,CAAA,CAAA,SAAA,CAAA,yBAAA,OAAA,CAAA,SAAA,OAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,cAAA,EAAA,SAAA,CAAA,cAAA,CAAA,CAAA,CAAA,SAAA,CAAA,gBAAA,OAAA,CAAA,SAAA,OAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,cAAA,EAAA,SAAA,CAAA,OAAA,CAAA,CAAA,CAAA,CAAA;EAAA,0BAAA,OAAA,OAAA,CAAA,IAAA,UAAA,CAAA,cAAA,EAAA,MAAA,cAAA,IAAA,WAAA,CAAA,SAAA,CAAA,mBAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,sBAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,OAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,QAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,OAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,YAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,IAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,SAAA,CAAA,WAAA,QAAA,CAAA,WAAA,EAAA,KAAA,QAAA,CAAA,GAAA,IAAA,MAAA,CAAA,CAAA,QAAA,CAAA,MAAA,cAAA,QAAA,CAAA,MAAA,OAAA,YAAA,EAAA,SAAA,MAAA,EAAA,CAAA,CAAA,SAAA,CAAA,4BAAA,OAAA,CAAA,SAAA,OAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,cAAA,EAAA,SAAA,CAAA,mBAAA,CAAA,CAAA,CAAA,SAAA,CAAA,0BAAA,OAAA,CAAA,SAAA,OAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,QAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,cAAA,EAAA,SAAA,CAAA,QAAA,EAAA,OAAA,EAAA,YAAA,EAAA,mBAAA,CAAA,CAAA,CAAA,SAAA,CAAA,0BAAA,OAAA,CAAA,SAAA,OAAA,CAAA,QAAA,EAAA,MAAA,EAAA,MAAA,CAAA,CAAA,cAAA,EAAA,SAAA,CAAA,OAAA,CAAA,CAAA,CAAA,CAAA"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { column, idColumn, schema } from "../schema/create.js";
|
|
2
|
+
|
|
3
|
+
//#region src/fragments/internal-fragment.schema.ts
|
|
4
|
+
const SETTINGS_TABLE_NAME = "fragno_db_settings";
|
|
5
|
+
const SETTINGS_NAMESPACE = "fragno-db-settings";
|
|
6
|
+
const internalSchema = schema("fragno_internal", (s) => {
|
|
7
|
+
return s.addTable(SETTINGS_TABLE_NAME, (t) => {
|
|
8
|
+
return t.addColumn("id", idColumn()).addColumn("key", column("string")).addColumn("value", column("string")).createIndex("unique_key", ["key"], { unique: true });
|
|
9
|
+
}).addTable("fragno_hooks", (t) => {
|
|
10
|
+
return t.addColumn("id", idColumn()).addColumn("namespace", column("string")).addColumn("hookName", column("string")).addColumn("payload", column("json")).addColumn("status", column("string")).addColumn("attempts", column("integer").defaultTo(0)).addColumn("maxAttempts", column("integer").defaultTo(5)).addColumn("lastAttemptAt", column("timestamp").nullable()).addColumn("nextRetryAt", column("timestamp").nullable()).addColumn("error", column("string").nullable()).addColumn("createdAt", column("timestamp").defaultTo((b) => b.now())).addColumn("nonce", column("string")).createIndex("idx_namespace_status_retry", [
|
|
11
|
+
"namespace",
|
|
12
|
+
"status",
|
|
13
|
+
"nextRetryAt"
|
|
14
|
+
]).createIndex("idx_nonce", ["nonce"]);
|
|
15
|
+
}).addTable("fragno_db_outbox", (t) => {
|
|
16
|
+
return t.addColumn("id", idColumn()).addColumn("versionstamp", column("string")).addColumn("uowId", column("string")).addColumn("payload", column("json")).addColumn("refMap", column("json").nullable()).addColumn("createdAt", column("timestamp").defaultTo((b) => b.now())).createIndex("idx_outbox_versionstamp", ["versionstamp"], { unique: true }).createIndex("idx_outbox_uow", ["uowId"]);
|
|
17
|
+
}).addTable("fragno_db_outbox_mutations", (t) => {
|
|
18
|
+
return t.addColumn("id", idColumn()).addColumn("entryVersionstamp", column("string")).addColumn("mutationVersionstamp", column("string")).addColumn("uowId", column("string")).addColumn("schema", column("string")).addColumn("table", column("string")).addColumn("externalId", column("string")).addColumn("op", column("string")).addColumn("createdAt", column("timestamp").defaultTo((b) => b.now())).createIndex("idx_outbox_mutations_entry", ["entryVersionstamp"]).createIndex("idx_outbox_mutations_key", [
|
|
19
|
+
"schema",
|
|
20
|
+
"table",
|
|
21
|
+
"externalId",
|
|
22
|
+
"entryVersionstamp"
|
|
23
|
+
]).createIndex("idx_outbox_mutations_uow", ["uowId"]);
|
|
24
|
+
}).addTable("fragno_db_sync_requests", (t) => {
|
|
25
|
+
return t.addColumn("id", idColumn()).addColumn("requestId", column("string")).addColumn("status", column("string")).addColumn("confirmedCommandIds", column("json")).addColumn("conflictCommandId", column("string").nullable()).addColumn("baseVersionstamp", column("string").nullable()).addColumn("lastVersionstamp", column("string").nullable()).addColumn("createdAt", column("timestamp").defaultTo((b) => b.now())).createIndex("idx_sync_request_id", ["requestId"], { unique: true });
|
|
26
|
+
}).alterTable("fragno_hooks", (t) => t.createIndex("idx_namespace_status_last_attempt", [
|
|
27
|
+
"namespace",
|
|
28
|
+
"status",
|
|
29
|
+
"lastAttemptAt"
|
|
30
|
+
])).alterTable("fragno_hooks", (t) => t.createIndex("idx_namespace_created_at", [
|
|
31
|
+
"namespace",
|
|
32
|
+
"createdAt",
|
|
33
|
+
"id"
|
|
34
|
+
]));
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
//#endregion
|
|
38
|
+
export { SETTINGS_NAMESPACE, SETTINGS_TABLE_NAME, internalSchema };
|
|
39
|
+
//# sourceMappingURL=internal-fragment.schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-fragment.schema.js","names":[],"sources":["../../src/fragments/internal-fragment.schema.ts"],"sourcesContent":["import { schema, idColumn, column } from \"../schema/create\";\n\n// Constants for Fragno's internal settings table\nexport const SETTINGS_TABLE_NAME = \"fragno_db_settings\" as const;\n// FIXME: In some places we simply use empty string \"\" as namespace, which is not correct.\nexport const SETTINGS_NAMESPACE = \"fragno-db-settings\" as const;\n\nexport const internalSchema = schema(\"fragno_internal\", (s) => {\n return s\n .addTable(SETTINGS_TABLE_NAME, (t) => {\n return t\n .addColumn(\"id\", idColumn())\n .addColumn(\"key\", column(\"string\"))\n .addColumn(\"value\", column(\"string\"))\n .createIndex(\"unique_key\", [\"key\"], { unique: true });\n })\n .addTable(\"fragno_hooks\", (t) => {\n return t\n .addColumn(\"id\", idColumn())\n .addColumn(\"namespace\", column(\"string\"))\n .addColumn(\"hookName\", column(\"string\"))\n .addColumn(\"payload\", column(\"json\"))\n .addColumn(\"status\", column(\"string\")) // \"pending\" | \"processing\" | \"completed\" | \"failed\"\n .addColumn(\"attempts\", column(\"integer\").defaultTo(0))\n .addColumn(\"maxAttempts\", column(\"integer\").defaultTo(5))\n .addColumn(\"lastAttemptAt\", column(\"timestamp\").nullable())\n .addColumn(\"nextRetryAt\", column(\"timestamp\").nullable())\n .addColumn(\"error\", column(\"string\").nullable())\n .addColumn(\n \"createdAt\",\n column(\"timestamp\").defaultTo((b) => b.now()),\n )\n .addColumn(\"nonce\", column(\"string\"))\n .createIndex(\"idx_namespace_status_retry\", [\"namespace\", \"status\", \"nextRetryAt\"])\n .createIndex(\"idx_nonce\", [\"nonce\"]);\n })\n .addTable(\"fragno_db_outbox\", (t) => {\n return t\n .addColumn(\"id\", idColumn())\n .addColumn(\"versionstamp\", column(\"string\"))\n .addColumn(\"uowId\", column(\"string\"))\n .addColumn(\"payload\", column(\"json\"))\n .addColumn(\"refMap\", column(\"json\").nullable())\n .addColumn(\n \"createdAt\",\n column(\"timestamp\").defaultTo((b) => b.now()),\n )\n .createIndex(\"idx_outbox_versionstamp\", [\"versionstamp\"], { unique: true })\n .createIndex(\"idx_outbox_uow\", [\"uowId\"]);\n })\n .addTable(\"fragno_db_outbox_mutations\", (t) => {\n return t\n .addColumn(\"id\", idColumn())\n .addColumn(\"entryVersionstamp\", column(\"string\"))\n .addColumn(\"mutationVersionstamp\", column(\"string\"))\n .addColumn(\"uowId\", column(\"string\"))\n .addColumn(\"schema\", column(\"string\"))\n .addColumn(\"table\", column(\"string\"))\n .addColumn(\"externalId\", column(\"string\"))\n .addColumn(\"op\", column(\"string\"))\n .addColumn(\n \"createdAt\",\n column(\"timestamp\").defaultTo((b) => b.now()),\n )\n .createIndex(\"idx_outbox_mutations_entry\", [\"entryVersionstamp\"])\n .createIndex(\"idx_outbox_mutations_key\", [\n \"schema\",\n \"table\",\n \"externalId\",\n \"entryVersionstamp\",\n ])\n .createIndex(\"idx_outbox_mutations_uow\", [\"uowId\"]);\n })\n .addTable(\"fragno_db_sync_requests\", (t) => {\n return t\n .addColumn(\"id\", idColumn())\n .addColumn(\"requestId\", column(\"string\"))\n .addColumn(\"status\", column(\"string\"))\n .addColumn(\"confirmedCommandIds\", column(\"json\"))\n .addColumn(\"conflictCommandId\", column(\"string\").nullable())\n .addColumn(\"baseVersionstamp\", column(\"string\").nullable())\n .addColumn(\"lastVersionstamp\", column(\"string\").nullable())\n .addColumn(\n \"createdAt\",\n column(\"timestamp\").defaultTo((b) => b.now()),\n )\n .createIndex(\"idx_sync_request_id\", [\"requestId\"], { unique: true });\n })\n .alterTable(\"fragno_hooks\", (t) =>\n t.createIndex(\"idx_namespace_status_last_attempt\", [\"namespace\", \"status\", \"lastAttemptAt\"]),\n )\n .alterTable(\"fragno_hooks\", (t) =>\n t.createIndex(\"idx_namespace_created_at\", [\"namespace\", \"createdAt\", \"id\"]),\n );\n});\n"],"mappings":";;;AAGA,MAAa,sBAAsB;AAEnC,MAAa,qBAAqB;AAElC,MAAa,iBAAiB,OAAO,oBAAoB,MAAM;AAC7D,QAAO,EACJ,SAAS,sBAAsB,MAAM;AACpC,SAAO,EACJ,UAAU,MAAM,UAAU,CAAC,CAC3B,UAAU,OAAO,OAAO,SAAS,CAAC,CAClC,UAAU,SAAS,OAAO,SAAS,CAAC,CACpC,YAAY,cAAc,CAAC,MAAM,EAAE,EAAE,QAAQ,MAAM,CAAC;GACvD,CACD,SAAS,iBAAiB,MAAM;AAC/B,SAAO,EACJ,UAAU,MAAM,UAAU,CAAC,CAC3B,UAAU,aAAa,OAAO,SAAS,CAAC,CACxC,UAAU,YAAY,OAAO,SAAS,CAAC,CACvC,UAAU,WAAW,OAAO,OAAO,CAAC,CACpC,UAAU,UAAU,OAAO,SAAS,CAAC,CACrC,UAAU,YAAY,OAAO,UAAU,CAAC,UAAU,EAAE,CAAC,CACrD,UAAU,eAAe,OAAO,UAAU,CAAC,UAAU,EAAE,CAAC,CACxD,UAAU,iBAAiB,OAAO,YAAY,CAAC,UAAU,CAAC,CAC1D,UAAU,eAAe,OAAO,YAAY,CAAC,UAAU,CAAC,CACxD,UAAU,SAAS,OAAO,SAAS,CAAC,UAAU,CAAC,CAC/C,UACC,aACA,OAAO,YAAY,CAAC,WAAW,MAAM,EAAE,KAAK,CAAC,CAC9C,CACA,UAAU,SAAS,OAAO,SAAS,CAAC,CACpC,YAAY,8BAA8B;GAAC;GAAa;GAAU;GAAc,CAAC,CACjF,YAAY,aAAa,CAAC,QAAQ,CAAC;GACtC,CACD,SAAS,qBAAqB,MAAM;AACnC,SAAO,EACJ,UAAU,MAAM,UAAU,CAAC,CAC3B,UAAU,gBAAgB,OAAO,SAAS,CAAC,CAC3C,UAAU,SAAS,OAAO,SAAS,CAAC,CACpC,UAAU,WAAW,OAAO,OAAO,CAAC,CACpC,UAAU,UAAU,OAAO,OAAO,CAAC,UAAU,CAAC,CAC9C,UACC,aACA,OAAO,YAAY,CAAC,WAAW,MAAM,EAAE,KAAK,CAAC,CAC9C,CACA,YAAY,2BAA2B,CAAC,eAAe,EAAE,EAAE,QAAQ,MAAM,CAAC,CAC1E,YAAY,kBAAkB,CAAC,QAAQ,CAAC;GAC3C,CACD,SAAS,+BAA+B,MAAM;AAC7C,SAAO,EACJ,UAAU,MAAM,UAAU,CAAC,CAC3B,UAAU,qBAAqB,OAAO,SAAS,CAAC,CAChD,UAAU,wBAAwB,OAAO,SAAS,CAAC,CACnD,UAAU,SAAS,OAAO,SAAS,CAAC,CACpC,UAAU,UAAU,OAAO,SAAS,CAAC,CACrC,UAAU,SAAS,OAAO,SAAS,CAAC,CACpC,UAAU,cAAc,OAAO,SAAS,CAAC,CACzC,UAAU,MAAM,OAAO,SAAS,CAAC,CACjC,UACC,aACA,OAAO,YAAY,CAAC,WAAW,MAAM,EAAE,KAAK,CAAC,CAC9C,CACA,YAAY,8BAA8B,CAAC,oBAAoB,CAAC,CAChE,YAAY,4BAA4B;GACvC;GACA;GACA;GACA;GACD,CAAC,CACD,YAAY,4BAA4B,CAAC,QAAQ,CAAC;GACrD,CACD,SAAS,4BAA4B,MAAM;AAC1C,SAAO,EACJ,UAAU,MAAM,UAAU,CAAC,CAC3B,UAAU,aAAa,OAAO,SAAS,CAAC,CACxC,UAAU,UAAU,OAAO,SAAS,CAAC,CACrC,UAAU,uBAAuB,OAAO,OAAO,CAAC,CAChD,UAAU,qBAAqB,OAAO,SAAS,CAAC,UAAU,CAAC,CAC3D,UAAU,oBAAoB,OAAO,SAAS,CAAC,UAAU,CAAC,CAC1D,UAAU,oBAAoB,OAAO,SAAS,CAAC,UAAU,CAAC,CAC1D,UACC,aACA,OAAO,YAAY,CAAC,WAAW,MAAM,EAAE,KAAK,CAAC,CAC9C,CACA,YAAY,uBAAuB,CAAC,YAAY,EAAE,EAAE,QAAQ,MAAM,CAAC;GACtE,CACD,WAAW,iBAAiB,MAC3B,EAAE,YAAY,qCAAqC;EAAC;EAAa;EAAU;EAAgB,CAAC,CAC7F,CACA,WAAW,iBAAiB,MAC3B,EAAE,YAAY,4BAA4B;EAAC;EAAa;EAAa;EAAK,CAAC,CAC5E;EACH"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
//#region src/hooks/durable-hooks-logger.d.ts
|
|
2
|
+
|
|
3
|
+
type DurableHooksLogLevel = "off" | "error" | "warn" | "info" | "debug";
|
|
4
|
+
type DurableHooksLoggerConfig = {
|
|
5
|
+
enabled?: boolean;
|
|
6
|
+
level?: DurableHooksLogLevel;
|
|
7
|
+
};
|
|
8
|
+
//#endregion
|
|
9
|
+
export { DurableHooksLoggerConfig };
|
|
10
|
+
//# sourceMappingURL=durable-hooks-logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"durable-hooks-logger.d.ts","names":[],"sources":["../../src/hooks/durable-hooks-logger.ts"],"sourcesContent":[],"mappings":";;AAmBY,KAFA,oBAAA,GAEwB,KAAA,GAAA,OAE1B,GAAA,MAAA,GAAA,MAAoB,GAAA,OAAA;KAFlB,wBAAA;;UAEF"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
//#region src/hooks/durable-hooks-logger.ts
|
|
2
|
+
const LOG_LEVEL_PRIORITY = {
|
|
3
|
+
off: 0,
|
|
4
|
+
error: 1,
|
|
5
|
+
warn: 2,
|
|
6
|
+
info: 3,
|
|
7
|
+
debug: 4
|
|
8
|
+
};
|
|
9
|
+
const DEFAULT_SCOPE = {
|
|
10
|
+
enabled: true,
|
|
11
|
+
level: "warn"
|
|
12
|
+
};
|
|
13
|
+
var DurableHooksLogger = class DurableHooksLogger {
|
|
14
|
+
static #defaultScope = { ...DEFAULT_SCOPE };
|
|
15
|
+
static #namespaceScopes = /* @__PURE__ */ new Map();
|
|
16
|
+
static configure(config, namespace) {
|
|
17
|
+
if (!config) return;
|
|
18
|
+
const target = namespace ? DurableHooksLogger.#namespaceScopes.get(namespace) ?? { ...DurableHooksLogger.#defaultScope } : { ...DurableHooksLogger.#defaultScope };
|
|
19
|
+
if (config.enabled !== void 0) target.enabled = config.enabled;
|
|
20
|
+
if (config.level !== void 0) target.level = config.level;
|
|
21
|
+
if (namespace) {
|
|
22
|
+
DurableHooksLogger.#namespaceScopes.set(namespace, target);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
DurableHooksLogger.#defaultScope = target;
|
|
26
|
+
}
|
|
27
|
+
static enable(namespace) {
|
|
28
|
+
DurableHooksLogger.configure({ enabled: true }, namespace);
|
|
29
|
+
}
|
|
30
|
+
static disable(namespace) {
|
|
31
|
+
DurableHooksLogger.configure({ enabled: false }, namespace);
|
|
32
|
+
}
|
|
33
|
+
static setLogLevel(level, namespace) {
|
|
34
|
+
DurableHooksLogger.configure({ level }, namespace);
|
|
35
|
+
}
|
|
36
|
+
static debug(message, options) {
|
|
37
|
+
DurableHooksLogger.#log("debug", message, options);
|
|
38
|
+
}
|
|
39
|
+
static info(message, options) {
|
|
40
|
+
DurableHooksLogger.#log("info", message, options);
|
|
41
|
+
}
|
|
42
|
+
static warn(message, options) {
|
|
43
|
+
DurableHooksLogger.#log("warn", message, options);
|
|
44
|
+
}
|
|
45
|
+
static error(message, options) {
|
|
46
|
+
DurableHooksLogger.#log("error", message, options);
|
|
47
|
+
}
|
|
48
|
+
static toErrorMessage(error) {
|
|
49
|
+
return error instanceof Error ? error.message : String(error);
|
|
50
|
+
}
|
|
51
|
+
static #log(level, message, options) {
|
|
52
|
+
const scope = DurableHooksLogger.#resolveScope(options?.namespace);
|
|
53
|
+
if (!scope.enabled) return;
|
|
54
|
+
if (LOG_LEVEL_PRIORITY[level] > LOG_LEVEL_PRIORITY[scope.level]) return;
|
|
55
|
+
const fields = DurableHooksLogger.#resolveFields(options?.fields);
|
|
56
|
+
const payload = {
|
|
57
|
+
at: (/* @__PURE__ */ new Date()).toISOString(),
|
|
58
|
+
...options?.namespace ? { namespace: options.namespace } : {},
|
|
59
|
+
...fields
|
|
60
|
+
};
|
|
61
|
+
console[level](`[fragno-db] ${message}`, payload);
|
|
62
|
+
}
|
|
63
|
+
static #resolveScope(namespace) {
|
|
64
|
+
if (!namespace) return DurableHooksLogger.#defaultScope;
|
|
65
|
+
return DurableHooksLogger.#namespaceScopes.get(namespace) ?? DurableHooksLogger.#defaultScope;
|
|
66
|
+
}
|
|
67
|
+
static #resolveFields(fields) {
|
|
68
|
+
if (!fields) return {};
|
|
69
|
+
return typeof fields === "function" ? fields() : fields;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
//#endregion
|
|
74
|
+
export { DurableHooksLogger };
|
|
75
|
+
//# sourceMappingURL=durable-hooks-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"durable-hooks-logger.js","names":["LOG_LEVEL_PRIORITY: Record<DurableHooksLogLevel, number>","DEFAULT_SCOPE: Required<DurableHooksLoggerConfig>","#defaultScope","#namespaceScopes","#log","#resolveScope","#resolveFields"],"sources":["../../src/hooks/durable-hooks-logger.ts"],"sourcesContent":["type LogFields = Record<string, unknown>;\ntype LogFieldsInput = LogFields | (() => LogFields);\n\ntype LogLevel = \"debug\" | \"info\" | \"warn\" | \"error\";\nconst LOG_LEVEL_PRIORITY: Record<DurableHooksLogLevel, number> = {\n off: 0,\n error: 1,\n warn: 2,\n info: 3,\n debug: 4,\n};\n\nconst DEFAULT_SCOPE: Required<DurableHooksLoggerConfig> = {\n enabled: true,\n level: \"warn\",\n};\n\nexport type DurableHooksLogLevel = \"off\" | \"error\" | \"warn\" | \"info\" | \"debug\";\n\nexport type DurableHooksLoggerConfig = {\n enabled?: boolean;\n level?: DurableHooksLogLevel;\n};\n\ntype LoggerScope = Required<DurableHooksLoggerConfig>;\n\ntype LogOptions = {\n namespace?: string;\n fields?: LogFieldsInput;\n};\n\nexport class DurableHooksLogger {\n static #defaultScope: LoggerScope = { ...DEFAULT_SCOPE };\n static #namespaceScopes = new Map<string, LoggerScope>();\n\n static configure(config?: DurableHooksLoggerConfig, namespace?: string): void {\n if (!config) {\n return;\n }\n\n const target = namespace\n ? (DurableHooksLogger.#namespaceScopes.get(namespace) ?? {\n ...DurableHooksLogger.#defaultScope,\n })\n : { ...DurableHooksLogger.#defaultScope };\n\n if (config.enabled !== undefined) {\n target.enabled = config.enabled;\n }\n if (config.level !== undefined) {\n target.level = config.level;\n }\n\n if (namespace) {\n DurableHooksLogger.#namespaceScopes.set(namespace, target);\n return;\n }\n\n DurableHooksLogger.#defaultScope = target;\n }\n\n static enable(namespace?: string): void {\n DurableHooksLogger.configure({ enabled: true }, namespace);\n }\n\n static disable(namespace?: string): void {\n DurableHooksLogger.configure({ enabled: false }, namespace);\n }\n\n static setLogLevel(level: DurableHooksLogLevel, namespace?: string): void {\n DurableHooksLogger.configure({ level }, namespace);\n }\n\n static debug(message: string, options?: LogOptions): void {\n DurableHooksLogger.#log(\"debug\", message, options);\n }\n\n static info(message: string, options?: LogOptions): void {\n DurableHooksLogger.#log(\"info\", message, options);\n }\n\n static warn(message: string, options?: LogOptions): void {\n DurableHooksLogger.#log(\"warn\", message, options);\n }\n\n static error(message: string, options?: LogOptions): void {\n DurableHooksLogger.#log(\"error\", message, options);\n }\n\n static toErrorMessage(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n }\n\n static #log(level: LogLevel, message: string, options?: LogOptions): void {\n const scope = DurableHooksLogger.#resolveScope(options?.namespace);\n if (!scope.enabled) {\n return;\n }\n if (LOG_LEVEL_PRIORITY[level] > LOG_LEVEL_PRIORITY[scope.level]) {\n return;\n }\n\n const fields = DurableHooksLogger.#resolveFields(options?.fields);\n const payload = {\n at: new Date().toISOString(),\n ...(options?.namespace ? { namespace: options.namespace } : {}),\n ...fields,\n };\n\n console[level](`[fragno-db] ${message}`, payload);\n }\n\n static #resolveScope(namespace?: string): LoggerScope {\n if (!namespace) {\n return DurableHooksLogger.#defaultScope;\n }\n return DurableHooksLogger.#namespaceScopes.get(namespace) ?? DurableHooksLogger.#defaultScope;\n }\n\n static #resolveFields(fields?: LogFieldsInput): LogFields {\n if (!fields) {\n return {};\n }\n return typeof fields === \"function\" ? fields() : fields;\n }\n}\n"],"mappings":";AAIA,MAAMA,qBAA2D;CAC/D,KAAK;CACL,OAAO;CACP,MAAM;CACN,MAAM;CACN,OAAO;CACR;AAED,MAAMC,gBAAoD;CACxD,SAAS;CACT,OAAO;CACR;AAgBD,IAAa,qBAAb,MAAa,mBAAmB;CAC9B,QAAOC,eAA6B,EAAE,GAAG,eAAe;CACxD,QAAOC,kCAAmB,IAAI,KAA0B;CAExD,OAAO,UAAU,QAAmC,WAA0B;AAC5E,MAAI,CAAC,OACH;EAGF,MAAM,SAAS,YACV,oBAAmBA,gBAAiB,IAAI,UAAU,IAAI,EACrD,GAAG,oBAAmBD,cACvB,GACD,EAAE,GAAG,oBAAmBA,cAAe;AAE3C,MAAI,OAAO,YAAY,OACrB,QAAO,UAAU,OAAO;AAE1B,MAAI,OAAO,UAAU,OACnB,QAAO,QAAQ,OAAO;AAGxB,MAAI,WAAW;AACb,uBAAmBC,gBAAiB,IAAI,WAAW,OAAO;AAC1D;;AAGF,sBAAmBD,eAAgB;;CAGrC,OAAO,OAAO,WAA0B;AACtC,qBAAmB,UAAU,EAAE,SAAS,MAAM,EAAE,UAAU;;CAG5D,OAAO,QAAQ,WAA0B;AACvC,qBAAmB,UAAU,EAAE,SAAS,OAAO,EAAE,UAAU;;CAG7D,OAAO,YAAY,OAA6B,WAA0B;AACxE,qBAAmB,UAAU,EAAE,OAAO,EAAE,UAAU;;CAGpD,OAAO,MAAM,SAAiB,SAA4B;AACxD,sBAAmBE,IAAK,SAAS,SAAS,QAAQ;;CAGpD,OAAO,KAAK,SAAiB,SAA4B;AACvD,sBAAmBA,IAAK,QAAQ,SAAS,QAAQ;;CAGnD,OAAO,KAAK,SAAiB,SAA4B;AACvD,sBAAmBA,IAAK,QAAQ,SAAS,QAAQ;;CAGnD,OAAO,MAAM,SAAiB,SAA4B;AACxD,sBAAmBA,IAAK,SAAS,SAAS,QAAQ;;CAGpD,OAAO,eAAe,OAAwB;AAC5C,SAAO,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;;CAG/D,QAAOA,IAAK,OAAiB,SAAiB,SAA4B;EACxE,MAAM,QAAQ,oBAAmBC,aAAc,SAAS,UAAU;AAClE,MAAI,CAAC,MAAM,QACT;AAEF,MAAI,mBAAmB,SAAS,mBAAmB,MAAM,OACvD;EAGF,MAAM,SAAS,oBAAmBC,cAAe,SAAS,OAAO;EACjE,MAAM,UAAU;GACd,qBAAI,IAAI,MAAM,EAAC,aAAa;GAC5B,GAAI,SAAS,YAAY,EAAE,WAAW,QAAQ,WAAW,GAAG,EAAE;GAC9D,GAAG;GACJ;AAED,UAAQ,OAAO,eAAe,WAAW,QAAQ;;CAGnD,QAAOD,aAAc,WAAiC;AACpD,MAAI,CAAC,UACH,QAAO,oBAAmBH;AAE5B,SAAO,oBAAmBC,gBAAiB,IAAI,UAAU,IAAI,oBAAmBD;;CAGlF,QAAOI,cAAe,QAAoC;AACxD,MAAI,CAAC,OACH,QAAO,EAAE;AAEX,SAAO,OAAO,WAAW,aAAa,QAAQ,GAAG"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "../mod.js";
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { getDurableHooksRuntimeByToken } from "./durable-hooks-runtime.js";
|
|
2
|
+
import { createDurableHooksRunner } from "./hooks.js";
|
|
3
|
+
|
|
4
|
+
//#region src/hooks/durable-hooks-processor.ts
|
|
5
|
+
const DEFAULT_STUCK_PROCESSING_TIMEOUT_MINUTES = 10;
|
|
6
|
+
function resolveStuckProcessingTimeoutMinutes(value) {
|
|
7
|
+
if (value === false) return false;
|
|
8
|
+
if (typeof value === "number") return value > 0 ? value : false;
|
|
9
|
+
return DEFAULT_STUCK_PROCESSING_TIMEOUT_MINUTES;
|
|
10
|
+
}
|
|
11
|
+
function hasDurableHooksConfigured(fragment) {
|
|
12
|
+
const internal = fragment.$internal;
|
|
13
|
+
return Boolean(internal?.durableHooksToken);
|
|
14
|
+
}
|
|
15
|
+
function createDurableHooksProcessor(fragment) {
|
|
16
|
+
const durableHooksToken = fragment.$internal.durableHooksToken;
|
|
17
|
+
if (!durableHooksToken) throw new Error(`[fragno-db] Durable hooks not configured for fragment "${fragment.name}".`);
|
|
18
|
+
const runtime = getDurableHooksRuntimeByToken(durableHooksToken);
|
|
19
|
+
if (!runtime) throw new Error(`[fragno-db] Durable hooks runtime missing for fragment "${fragment.name}".`);
|
|
20
|
+
runtime.dispatcherRegistered = true;
|
|
21
|
+
const durableHooks = runtime.config;
|
|
22
|
+
const { namespace, internalFragment } = durableHooks;
|
|
23
|
+
const stuckProcessingTimeoutMinutes = resolveStuckProcessingTimeoutMinutes(durableHooks.stuckProcessingTimeoutMinutes);
|
|
24
|
+
const runner = durableHooks.runner ?? (durableHooks.runner = durableHooks.scheduler ? {
|
|
25
|
+
processDue: () => durableHooks.scheduler.schedule(),
|
|
26
|
+
drain: () => durableHooks.scheduler.drain()
|
|
27
|
+
} : createDurableHooksRunner(durableHooks));
|
|
28
|
+
return {
|
|
29
|
+
namespace,
|
|
30
|
+
processDue: async () => runner.processDue(),
|
|
31
|
+
process: async () => runner.processDue(),
|
|
32
|
+
drain: async () => runner.drain(),
|
|
33
|
+
getNextWakeAt: async () => {
|
|
34
|
+
return await internalFragment.inContext(async function() {
|
|
35
|
+
return await this.handlerTx().withServiceCalls(() => [internalFragment.services.hookService.getNextHookWakeAt(namespace, stuckProcessingTimeoutMinutes)]).transform(({ serviceResult: [result] }) => result).execute();
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
function createDurableHooksProcessorGroup(fragments, options = {}) {
|
|
41
|
+
const configuredFragments = fragments.filter(hasDurableHooksConfigured);
|
|
42
|
+
if (configuredFragments.length === 0) throw new Error("[fragno-db] No fragments provided for durable hooks processing.");
|
|
43
|
+
return createDurableHooksProcessorGroupFromProcessors(configuredFragments.map((fragment) => createDurableHooksProcessor(fragment)), options);
|
|
44
|
+
}
|
|
45
|
+
function createDurableHooksProcessorGroupFromProcessors(processors, options = {}) {
|
|
46
|
+
if (processors.length === 0) throw new Error("[fragno-db] No processors provided for durable hooks processing.");
|
|
47
|
+
if (processors.length === 1) return processors[0];
|
|
48
|
+
const onError = options.onError ?? (() => {});
|
|
49
|
+
const namespace = processors.map((processor) => processor.namespace).join(",");
|
|
50
|
+
const processDue = async () => {
|
|
51
|
+
const results = await Promise.allSettled(processors.map(async (processor) => await processor.processDue()));
|
|
52
|
+
let processed = 0;
|
|
53
|
+
for (const result of results) if (result.status === "fulfilled") processed += result.value;
|
|
54
|
+
else onError(result.reason);
|
|
55
|
+
return processed;
|
|
56
|
+
};
|
|
57
|
+
return {
|
|
58
|
+
namespace,
|
|
59
|
+
processDue,
|
|
60
|
+
process: processDue,
|
|
61
|
+
drain: async () => {
|
|
62
|
+
const results = await Promise.allSettled(processors.map(async (processor) => await processor.drain()));
|
|
63
|
+
for (const result of results) if (result.status === "rejected") onError(result.reason);
|
|
64
|
+
},
|
|
65
|
+
getNextWakeAt: async () => {
|
|
66
|
+
const results = await Promise.allSettled(processors.map(async (processor) => await processor.getNextWakeAt()));
|
|
67
|
+
let nextWakeAt = null;
|
|
68
|
+
for (const result of results) if (result.status === "fulfilled") {
|
|
69
|
+
const wakeAt = result.value;
|
|
70
|
+
if (!wakeAt) continue;
|
|
71
|
+
if (!nextWakeAt || wakeAt.getTime() < nextWakeAt.getTime()) nextWakeAt = wakeAt;
|
|
72
|
+
} else onError(result.reason);
|
|
73
|
+
return nextWakeAt;
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
//#endregion
|
|
79
|
+
export { createDurableHooksProcessorGroup };
|
|
80
|
+
//# sourceMappingURL=durable-hooks-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"durable-hooks-processor.js","names":["nextWakeAt: Date | null"],"sources":["../../src/hooks/durable-hooks-processor.ts"],"sourcesContent":["import type { AnyFragnoInstantiatedDatabaseFragment } from \"../mod\";\nimport type { AnySchema } from \"../schema/create\";\nimport { getDurableHooksRuntimeByToken } from \"./durable-hooks-runtime\";\nimport { createDurableHooksRunner } from \"./hooks\";\n\nexport type DurableHooksProcessor = {\n processDue: () => Promise<number>;\n /**\n * @deprecated Use processDue().\n */\n process: () => Promise<number>;\n getNextWakeAt: () => Promise<Date | null>;\n drain: () => Promise<void>;\n namespace: string;\n};\n\nexport type DurableHooksProcessorGroupOptions = {\n onError?: (error: unknown) => void;\n};\n\ntype DurableHooksInternal = {\n durableHooksToken?: object;\n};\n\nconst DEFAULT_STUCK_PROCESSING_TIMEOUT_MINUTES = 10;\n\nfunction resolveStuckProcessingTimeoutMinutes(value: number | false | undefined): number | false {\n if (value === false) {\n return false;\n }\n if (typeof value === \"number\") {\n return value > 0 ? value : false;\n }\n return DEFAULT_STUCK_PROCESSING_TIMEOUT_MINUTES;\n}\n\nfunction hasDurableHooksConfigured(\n fragment: AnyFragnoInstantiatedDatabaseFragment,\n): fragment is AnyFragnoInstantiatedDatabaseFragment {\n const internal = fragment.$internal as DurableHooksInternal | undefined;\n return Boolean(internal?.durableHooksToken);\n}\n\nexport function createDurableHooksProcessor<TSchema extends AnySchema>(\n fragment: AnyFragnoInstantiatedDatabaseFragment<TSchema>,\n): DurableHooksProcessor {\n const durableHooksToken = (fragment.$internal as DurableHooksInternal).durableHooksToken;\n if (!durableHooksToken) {\n throw new Error(`[fragno-db] Durable hooks not configured for fragment \"${fragment.name}\".`);\n }\n const runtime = getDurableHooksRuntimeByToken(durableHooksToken);\n if (!runtime) {\n throw new Error(`[fragno-db] Durable hooks runtime missing for fragment \"${fragment.name}\".`);\n }\n runtime.dispatcherRegistered = true;\n\n const durableHooks = runtime.config;\n\n const { namespace, internalFragment } = durableHooks;\n const stuckProcessingTimeoutMinutes = resolveStuckProcessingTimeoutMinutes(\n durableHooks.stuckProcessingTimeoutMinutes,\n );\n const runner =\n durableHooks.runner ??\n (durableHooks.runner = durableHooks.scheduler\n ? {\n processDue: () => durableHooks.scheduler!.schedule(),\n drain: () => durableHooks.scheduler!.drain(),\n }\n : createDurableHooksRunner(durableHooks));\n\n return {\n namespace,\n processDue: async () => runner.processDue(),\n process: async () => runner.processDue(),\n drain: async () => runner.drain(),\n getNextWakeAt: async () => {\n return await internalFragment.inContext(async function () {\n return await this.handlerTx()\n .withServiceCalls(\n () =>\n [\n internalFragment.services.hookService.getNextHookWakeAt(\n namespace,\n stuckProcessingTimeoutMinutes,\n ),\n ] as const,\n )\n .transform(({ serviceResult: [result] }) => result)\n .execute();\n });\n },\n };\n}\n\nexport function createDurableHooksProcessorGroup(\n fragments: readonly AnyFragnoInstantiatedDatabaseFragment[],\n options: DurableHooksProcessorGroupOptions = {},\n): DurableHooksProcessor {\n const configuredFragments = fragments.filter(hasDurableHooksConfigured);\n if (configuredFragments.length === 0) {\n throw new Error(\"[fragno-db] No fragments provided for durable hooks processing.\");\n }\n const processors = configuredFragments.map((fragment) => createDurableHooksProcessor(fragment));\n\n return createDurableHooksProcessorGroupFromProcessors(processors, options);\n}\n\nexport function createDurableHooksProcessorGroupFromProcessors(\n processors: readonly DurableHooksProcessor[],\n options: DurableHooksProcessorGroupOptions = {},\n): DurableHooksProcessor {\n if (processors.length === 0) {\n throw new Error(\"[fragno-db] No processors provided for durable hooks processing.\");\n }\n if (processors.length === 1) {\n return processors[0];\n }\n\n const onError = options.onError ?? (() => {});\n const namespace = processors.map((processor) => processor.namespace).join(\",\");\n\n const processDue = async () => {\n const results = await Promise.allSettled(\n processors.map(async (processor) => await processor.processDue()),\n );\n let processed = 0;\n for (const result of results) {\n if (result.status === \"fulfilled\") {\n processed += result.value;\n } else {\n onError(result.reason);\n }\n }\n return processed;\n };\n\n return {\n namespace,\n processDue,\n process: processDue,\n drain: async () => {\n const results = await Promise.allSettled(\n processors.map(async (processor) => await processor.drain()),\n );\n for (const result of results) {\n if (result.status === \"rejected\") {\n onError(result.reason);\n }\n }\n },\n getNextWakeAt: async () => {\n const results = await Promise.allSettled(\n processors.map(async (processor) => await processor.getNextWakeAt()),\n );\n let nextWakeAt: Date | null = null;\n for (const result of results) {\n if (result.status === \"fulfilled\") {\n const wakeAt = result.value;\n if (!wakeAt) {\n continue;\n }\n if (!nextWakeAt || wakeAt.getTime() < nextWakeAt.getTime()) {\n nextWakeAt = wakeAt;\n }\n } else {\n onError(result.reason);\n }\n }\n return nextWakeAt;\n },\n };\n}\n"],"mappings":";;;;AAwBA,MAAM,2CAA2C;AAEjD,SAAS,qCAAqC,OAAmD;AAC/F,KAAI,UAAU,MACZ,QAAO;AAET,KAAI,OAAO,UAAU,SACnB,QAAO,QAAQ,IAAI,QAAQ;AAE7B,QAAO;;AAGT,SAAS,0BACP,UACmD;CACnD,MAAM,WAAW,SAAS;AAC1B,QAAO,QAAQ,UAAU,kBAAkB;;AAG7C,SAAgB,4BACd,UACuB;CACvB,MAAM,oBAAqB,SAAS,UAAmC;AACvE,KAAI,CAAC,kBACH,OAAM,IAAI,MAAM,0DAA0D,SAAS,KAAK,IAAI;CAE9F,MAAM,UAAU,8BAA8B,kBAAkB;AAChE,KAAI,CAAC,QACH,OAAM,IAAI,MAAM,2DAA2D,SAAS,KAAK,IAAI;AAE/F,SAAQ,uBAAuB;CAE/B,MAAM,eAAe,QAAQ;CAE7B,MAAM,EAAE,WAAW,qBAAqB;CACxC,MAAM,gCAAgC,qCACpC,aAAa,8BACd;CACD,MAAM,SACJ,aAAa,WACZ,aAAa,SAAS,aAAa,YAChC;EACE,kBAAkB,aAAa,UAAW,UAAU;EACpD,aAAa,aAAa,UAAW,OAAO;EAC7C,GACD,yBAAyB,aAAa;AAE5C,QAAO;EACL;EACA,YAAY,YAAY,OAAO,YAAY;EAC3C,SAAS,YAAY,OAAO,YAAY;EACxC,OAAO,YAAY,OAAO,OAAO;EACjC,eAAe,YAAY;AACzB,UAAO,MAAM,iBAAiB,UAAU,iBAAkB;AACxD,WAAO,MAAM,KAAK,WAAW,CAC1B,uBAEG,CACE,iBAAiB,SAAS,YAAY,kBACpC,WACA,8BACD,CACF,CACJ,CACA,WAAW,EAAE,eAAe,CAAC,cAAc,OAAO,CAClD,SAAS;KACZ;;EAEL;;AAGH,SAAgB,iCACd,WACA,UAA6C,EAAE,EACxB;CACvB,MAAM,sBAAsB,UAAU,OAAO,0BAA0B;AACvE,KAAI,oBAAoB,WAAW,EACjC,OAAM,IAAI,MAAM,kEAAkE;AAIpF,QAAO,+CAFY,oBAAoB,KAAK,aAAa,4BAA4B,SAAS,CAAC,EAE7B,QAAQ;;AAG5E,SAAgB,+CACd,YACA,UAA6C,EAAE,EACxB;AACvB,KAAI,WAAW,WAAW,EACxB,OAAM,IAAI,MAAM,mEAAmE;AAErF,KAAI,WAAW,WAAW,EACxB,QAAO,WAAW;CAGpB,MAAM,UAAU,QAAQ,kBAAkB;CAC1C,MAAM,YAAY,WAAW,KAAK,cAAc,UAAU,UAAU,CAAC,KAAK,IAAI;CAE9E,MAAM,aAAa,YAAY;EAC7B,MAAM,UAAU,MAAM,QAAQ,WAC5B,WAAW,IAAI,OAAO,cAAc,MAAM,UAAU,YAAY,CAAC,CAClE;EACD,IAAI,YAAY;AAChB,OAAK,MAAM,UAAU,QACnB,KAAI,OAAO,WAAW,YACpB,cAAa,OAAO;MAEpB,SAAQ,OAAO,OAAO;AAG1B,SAAO;;AAGT,QAAO;EACL;EACA;EACA,SAAS;EACT,OAAO,YAAY;GACjB,MAAM,UAAU,MAAM,QAAQ,WAC5B,WAAW,IAAI,OAAO,cAAc,MAAM,UAAU,OAAO,CAAC,CAC7D;AACD,QAAK,MAAM,UAAU,QACnB,KAAI,OAAO,WAAW,WACpB,SAAQ,OAAO,OAAO;;EAI5B,eAAe,YAAY;GACzB,MAAM,UAAU,MAAM,QAAQ,WAC5B,WAAW,IAAI,OAAO,cAAc,MAAM,UAAU,eAAe,CAAC,CACrE;GACD,IAAIA,aAA0B;AAC9B,QAAK,MAAM,UAAU,QACnB,KAAI,OAAO,WAAW,aAAa;IACjC,MAAM,SAAS,OAAO;AACtB,QAAI,CAAC,OACH;AAEF,QAAI,CAAC,cAAc,OAAO,SAAS,GAAG,WAAW,SAAS,CACxD,cAAa;SAGf,SAAQ,OAAO,OAAO;AAG1B,UAAO;;EAEV"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { DurableHooksLogger } from "./durable-hooks-logger.js";
|
|
2
|
+
|
|
3
|
+
//#region src/hooks/durable-hooks-runtime.ts
|
|
4
|
+
const runtimeByToken = /* @__PURE__ */ new WeakMap();
|
|
5
|
+
const runtimeByConfig = /* @__PURE__ */ new WeakMap();
|
|
6
|
+
const runtimesByInternalFragment = /* @__PURE__ */ new WeakMap();
|
|
7
|
+
function getNamespaceRuntimeMap(internalFragment, createIfMissing = false) {
|
|
8
|
+
const existing = runtimesByInternalFragment.get(internalFragment);
|
|
9
|
+
if (existing || !createIfMissing) return existing;
|
|
10
|
+
const created = /* @__PURE__ */ new Map();
|
|
11
|
+
runtimesByInternalFragment.set(internalFragment, created);
|
|
12
|
+
return created;
|
|
13
|
+
}
|
|
14
|
+
function registerDurableHooksRuntime(config) {
|
|
15
|
+
const existing = runtimeByConfig.get(config);
|
|
16
|
+
if (existing) return existing.token;
|
|
17
|
+
const token = {};
|
|
18
|
+
const runtime = {
|
|
19
|
+
token,
|
|
20
|
+
config,
|
|
21
|
+
dispatcherRegistered: false,
|
|
22
|
+
dispatcherWarningEmitted: false
|
|
23
|
+
};
|
|
24
|
+
runtimeByToken.set(token, runtime);
|
|
25
|
+
runtimeByConfig.set(config, runtime);
|
|
26
|
+
const runtimeByNamespace = getNamespaceRuntimeMap(config.internalFragment, true);
|
|
27
|
+
const existingForNamespace = runtimeByNamespace?.get(config.namespace);
|
|
28
|
+
if (existingForNamespace && existingForNamespace.config !== config) DurableHooksLogger.warn("Durable hooks runtime already registered for namespace", { namespace: config.namespace });
|
|
29
|
+
runtimeByNamespace?.set(config.namespace, runtime);
|
|
30
|
+
return token;
|
|
31
|
+
}
|
|
32
|
+
function getDurableHooksRuntimeByToken(token) {
|
|
33
|
+
return runtimeByToken.get(token);
|
|
34
|
+
}
|
|
35
|
+
function getDurableHooksRuntimeByConfig(config) {
|
|
36
|
+
return runtimeByConfig.get(config);
|
|
37
|
+
}
|
|
38
|
+
function getDurableHooksRuntimeByNamespace(namespace, internalFragment) {
|
|
39
|
+
return getNamespaceRuntimeMap(internalFragment)?.get(namespace);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
//#endregion
|
|
43
|
+
export { getDurableHooksRuntimeByConfig, getDurableHooksRuntimeByNamespace, getDurableHooksRuntimeByToken, registerDurableHooksRuntime };
|
|
44
|
+
//# sourceMappingURL=durable-hooks-runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"durable-hooks-runtime.js","names":["runtime: DurableHooksRuntimeState"],"sources":["../../src/hooks/durable-hooks-runtime.ts"],"sourcesContent":["import { DurableHooksLogger } from \"./durable-hooks-logger\";\nimport type { HookProcessorConfig } from \"./hooks\";\n\ntype DurableHooksRuntimeState = {\n token: object;\n config: HookProcessorConfig;\n dispatcherRegistered: boolean;\n dispatcherWarningEmitted: boolean;\n};\n\nconst runtimeByToken = new WeakMap<object, DurableHooksRuntimeState>();\nconst runtimeByConfig = new WeakMap<HookProcessorConfig, DurableHooksRuntimeState>();\nconst runtimesByInternalFragment = new WeakMap<\n HookProcessorConfig[\"internalFragment\"],\n Map<string, DurableHooksRuntimeState>\n>();\n\nfunction getNamespaceRuntimeMap(\n internalFragment: HookProcessorConfig[\"internalFragment\"],\n createIfMissing = false,\n) {\n const existing = runtimesByInternalFragment.get(internalFragment);\n if (existing || !createIfMissing) {\n return existing;\n }\n const created = new Map<string, DurableHooksRuntimeState>();\n runtimesByInternalFragment.set(internalFragment, created);\n return created;\n}\n\nexport function registerDurableHooksRuntime(config: HookProcessorConfig): object {\n const existing = runtimeByConfig.get(config);\n if (existing) {\n return existing.token;\n }\n\n const token = {};\n const runtime: DurableHooksRuntimeState = {\n token,\n config,\n dispatcherRegistered: false,\n dispatcherWarningEmitted: false,\n };\n\n runtimeByToken.set(token, runtime);\n runtimeByConfig.set(config, runtime);\n const runtimeByNamespace = getNamespaceRuntimeMap(config.internalFragment, true);\n const existingForNamespace = runtimeByNamespace?.get(config.namespace);\n if (existingForNamespace && existingForNamespace.config !== config) {\n DurableHooksLogger.warn(\"Durable hooks runtime already registered for namespace\", {\n namespace: config.namespace,\n });\n }\n runtimeByNamespace?.set(config.namespace, runtime);\n\n return token;\n}\n\nexport function getDurableHooksRuntimeByToken(token: object): DurableHooksRuntimeState | undefined {\n return runtimeByToken.get(token);\n}\n\nexport function getDurableHooksRuntimeByConfig(\n config: HookProcessorConfig,\n): DurableHooksRuntimeState | undefined {\n return runtimeByConfig.get(config);\n}\n\nexport function getDurableHooksRuntimeByNamespace(\n namespace: string,\n internalFragment: HookProcessorConfig[\"internalFragment\"],\n): DurableHooksRuntimeState | undefined {\n return getNamespaceRuntimeMap(internalFragment)?.get(namespace);\n}\n\nexport function getDurableHooksNotifierByNamespace(\n namespace: string,\n internalFragment: HookProcessorConfig[\"internalFragment\"],\n) {\n return getNamespaceRuntimeMap(internalFragment)?.get(namespace)?.config.notifier;\n}\n"],"mappings":";;;AAUA,MAAM,iCAAiB,IAAI,SAA2C;AACtE,MAAM,kCAAkB,IAAI,SAAwD;AACpF,MAAM,6CAA6B,IAAI,SAGpC;AAEH,SAAS,uBACP,kBACA,kBAAkB,OAClB;CACA,MAAM,WAAW,2BAA2B,IAAI,iBAAiB;AACjE,KAAI,YAAY,CAAC,gBACf,QAAO;CAET,MAAM,0BAAU,IAAI,KAAuC;AAC3D,4BAA2B,IAAI,kBAAkB,QAAQ;AACzD,QAAO;;AAGT,SAAgB,4BAA4B,QAAqC;CAC/E,MAAM,WAAW,gBAAgB,IAAI,OAAO;AAC5C,KAAI,SACF,QAAO,SAAS;CAGlB,MAAM,QAAQ,EAAE;CAChB,MAAMA,UAAoC;EACxC;EACA;EACA,sBAAsB;EACtB,0BAA0B;EAC3B;AAED,gBAAe,IAAI,OAAO,QAAQ;AAClC,iBAAgB,IAAI,QAAQ,QAAQ;CACpC,MAAM,qBAAqB,uBAAuB,OAAO,kBAAkB,KAAK;CAChF,MAAM,uBAAuB,oBAAoB,IAAI,OAAO,UAAU;AACtE,KAAI,wBAAwB,qBAAqB,WAAW,OAC1D,oBAAmB,KAAK,0DAA0D,EAChF,WAAW,OAAO,WACnB,CAAC;AAEJ,qBAAoB,IAAI,OAAO,WAAW,QAAQ;AAElD,QAAO;;AAGT,SAAgB,8BAA8B,OAAqD;AACjG,QAAO,eAAe,IAAI,MAAM;;AAGlC,SAAgB,+BACd,QACsC;AACtC,QAAO,gBAAgB,IAAI,OAAO;;AAGpC,SAAgB,kCACd,WACA,kBACsC;AACtC,QAAO,uBAAuB,iBAAiB,EAAE,IAAI,UAAU"}
|
package/dist/hooks/hooks.d.ts
CHANGED
|
@@ -1,5 +1,9 @@
|
|
|
1
|
+
import { DbNow } from "../query/db-now.js";
|
|
2
|
+
import { FragnoId } from "../schema/create.js";
|
|
1
3
|
import { RetryPolicy } from "../query/unit-of-work/retry-policy.js";
|
|
4
|
+
import { ExecuteTxOptions, HandlerTxBuilder } from "../query/unit-of-work/execute-unit-of-work.js";
|
|
2
5
|
import "../fragments/internal-fragment.js";
|
|
6
|
+
import { DurableHooksLoggerConfig } from "./durable-hooks-logger.js";
|
|
3
7
|
import "../query/unit-of-work/unit-of-work.js";
|
|
4
8
|
|
|
5
9
|
//#region src/hooks/hooks.d.ts
|
|
@@ -14,7 +18,45 @@ interface HookContext {
|
|
|
14
18
|
* Use this for idempotency checks in your hook implementation.
|
|
15
19
|
*/
|
|
16
20
|
idempotencyKey: string;
|
|
21
|
+
/**
|
|
22
|
+
* Hook event identifier (versioned FragnoId).
|
|
23
|
+
*/
|
|
24
|
+
hookId: FragnoId;
|
|
25
|
+
/**
|
|
26
|
+
* Hook name for this event.
|
|
27
|
+
*/
|
|
28
|
+
hookName: string;
|
|
29
|
+
/**
|
|
30
|
+
* Current status of the hook event.
|
|
31
|
+
*/
|
|
32
|
+
status: HookStatus;
|
|
33
|
+
/**
|
|
34
|
+
* Attempt count for this hook event.
|
|
35
|
+
*/
|
|
36
|
+
attempts: number;
|
|
37
|
+
/**
|
|
38
|
+
* Maximum attempts configured for this hook event.
|
|
39
|
+
*/
|
|
40
|
+
maxAttempts: number;
|
|
41
|
+
/**
|
|
42
|
+
* Timestamp of the last attempt (if any).
|
|
43
|
+
*/
|
|
44
|
+
lastAttemptAt: Date | null;
|
|
45
|
+
/**
|
|
46
|
+
* Next scheduled retry timestamp (if any).
|
|
47
|
+
*/
|
|
48
|
+
nextRetryAt: Date | null;
|
|
49
|
+
/**
|
|
50
|
+
* When the hook event was created.
|
|
51
|
+
*/
|
|
52
|
+
createdAt: Date;
|
|
53
|
+
/**
|
|
54
|
+
* Create a handler transaction builder to run atomic operations.
|
|
55
|
+
*/
|
|
56
|
+
handlerTx: HookHandlerTx;
|
|
17
57
|
}
|
|
58
|
+
declare const hookStatusValues: readonly ["pending", "processing", "completed", "failed"];
|
|
59
|
+
type HookStatus = (typeof hookStatusValues)[number];
|
|
18
60
|
/**
|
|
19
61
|
* A hook function signature.
|
|
20
62
|
* Hooks receive a typed payload and access context via `this`.
|
|
@@ -38,16 +80,73 @@ interface TriggerHookOptions {
|
|
|
38
80
|
* If not provided, uses the default retry policy.
|
|
39
81
|
*/
|
|
40
82
|
retryPolicy?: RetryPolicy;
|
|
83
|
+
/**
|
|
84
|
+
* Optional hook event ID. When provided, the hook insert will fail if a hook
|
|
85
|
+
* with the same ID already exists.
|
|
86
|
+
*/
|
|
87
|
+
id?: string | FragnoId;
|
|
88
|
+
/**
|
|
89
|
+
* Absolute time for the first attempt. If in the future, the hook is
|
|
90
|
+
* scheduled for that time; if in the past, it runs immediately.
|
|
91
|
+
*/
|
|
92
|
+
processAt?: Date | DbNow;
|
|
41
93
|
}
|
|
42
94
|
/**
|
|
43
95
|
* Internal representation of a triggered hook.
|
|
44
96
|
* Stored in the Unit of Work before execution.
|
|
45
97
|
*/
|
|
46
98
|
interface TriggeredHook {
|
|
99
|
+
namespace: string;
|
|
47
100
|
hookName: string;
|
|
48
101
|
payload: unknown;
|
|
49
102
|
options?: TriggerHookOptions;
|
|
50
103
|
}
|
|
104
|
+
type HookNotifySource = "request" | "hook" | "alarm";
|
|
105
|
+
type HookNotifyContext = {
|
|
106
|
+
source: HookNotifySource;
|
|
107
|
+
route?: string | null;
|
|
108
|
+
waitUntil?: (promise: Promise<unknown>) => void;
|
|
109
|
+
};
|
|
110
|
+
type StuckHookProcessingTimeoutMinutes = number | false;
|
|
111
|
+
type StuckHookProcessingEvent = {
|
|
112
|
+
id: FragnoId;
|
|
113
|
+
hookName: string;
|
|
114
|
+
attempts: number;
|
|
115
|
+
maxAttempts: number;
|
|
116
|
+
lastAttemptAt: Date | null;
|
|
117
|
+
nextRetryAt: Date | null;
|
|
118
|
+
};
|
|
119
|
+
type StuckHookProcessingInfo = {
|
|
120
|
+
namespace: string;
|
|
121
|
+
timeoutMinutes: number;
|
|
122
|
+
events: StuckHookProcessingEvent[];
|
|
123
|
+
};
|
|
124
|
+
type DurableHooksProcessingOptions = {
|
|
125
|
+
/**
|
|
126
|
+
* Re-queue hooks that have been in `processing` for at least this many minutes.
|
|
127
|
+
* Use `false` to disable stuck-processing recovery entirely.
|
|
128
|
+
* Values <= 0 are treated as `false`.
|
|
129
|
+
*
|
|
130
|
+
* Default: 10 minutes.
|
|
131
|
+
*/
|
|
132
|
+
stuckProcessingTimeoutMinutes?: StuckHookProcessingTimeoutMinutes;
|
|
133
|
+
/**
|
|
134
|
+
* Automatically schedule hook processing after successful mutations.
|
|
135
|
+
* Defaults to true. Set false to disable auto scheduling (manual drain only).
|
|
136
|
+
*/
|
|
137
|
+
autoSchedule?: boolean;
|
|
138
|
+
/**
|
|
139
|
+
* Called when stuck processing hooks are detected and re-queued.
|
|
140
|
+
* Invoked after the hooks are moved back to `pending`.
|
|
141
|
+
*/
|
|
142
|
+
onStuckProcessingHooks?: (info: StuckHookProcessingInfo) => void;
|
|
143
|
+
/**
|
|
144
|
+
* Durable hooks logging controls.
|
|
145
|
+
* Defaults: enabled=true, level="warn".
|
|
146
|
+
*/
|
|
147
|
+
logging?: DurableHooksLoggerConfig;
|
|
148
|
+
};
|
|
149
|
+
type HookHandlerTx = (execOptions?: Omit<ExecuteTxOptions, "createUnitOfWork">) => HandlerTxBuilder<readonly [], [], [], unknown, unknown, false, false, false, false, HooksMap>;
|
|
51
150
|
//#endregion
|
|
52
|
-
export { HookContext, HookFn, HookPayload, HooksMap, TriggerHookOptions, TriggeredHook };
|
|
151
|
+
export { DurableHooksProcessingOptions, HookContext, HookFn, HookHandlerTx, HookNotifyContext, HookPayload, HookStatus, HooksMap, StuckHookProcessingEvent, StuckHookProcessingInfo, StuckHookProcessingTimeoutMinutes, TriggerHookOptions, TriggeredHook };
|
|
53
152
|
//# sourceMappingURL=hooks.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hooks.d.ts","names":[],"sources":["../../src/hooks/hooks.ts"],"sourcesContent":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"hooks.d.ts","names":[],"sources":["../../src/hooks/hooks.ts"],"sourcesContent":[],"mappings":";;;;;;;;;;;;AAgBA;;AAiBU,UAjBO,WAAA,CAiBP;EAYO;;;;EAYS,cAAA,EAAA,MAAA;EAGb;AAEb;AAgBA;EAOY,MAAA,EA5DF,QA4DU;EAKR;;;EAA6C,QAAA,EAAA,MAAA;EAAC;AAK1D;;EAUgB,MAAA,EAxEN,UAwEM;EAKF;;;EAOG,QAAA,EAAA,MAAa;EAOlB;AAEZ;AAgEA;EAEY,WAAA,EAAA,MAAA;EACN;;;EAKa,aAAA,EAzJF,IAyJE,GAAA,IAAA;EAGP;AAMZ;;EAkBkC,WAAA,EAhLnB,IAgLmB,GAAA,IAAA;EAKtB;;AAGZ;EACqB,SAAA,EArLR,IAqLQ;EAAL;;;EACK,SAAA,EAlLR,aAkLQ;;cA/KR;KAED,UAAA,WAAqB;;;;;KAgBrB,uCAAuC,oBAAoB;;;;;KAO3D,QAAA,GAAW,eAAe;;;;KAK1B,iBAAiB,UAAU,kBAAkB;;;;UAKxC,kBAAA;;;;;gBAKD;;;;;gBAKA;;;;;cAKF,OAAO;;;;;;UAOJ,aAAA;;;;YAIL;;KAGA,gBAAA;KAEA,iBAAA;UACF;;wBAEc;;KA6DZ,iCAAA;KAEA,wBAAA;MACN;;;;iBAIW;eACF;;KAGH,uBAAA;;;UAGF;;KAGE,6BAAA;;;;;;;;kCAQsB;;;;;;;;;;kCAUA;;;;;YAKtB;;KAGA,aAAA,kBACI,KAAK,0CAChB,oFAAoF"}
|