pipework 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +128 -0
- package/bin/pipework.js +5 -0
- package/dist/audit/emit.d.ts +3 -0
- package/dist/audit/emit.d.ts.map +1 -0
- package/dist/audit/emit.js +66 -0
- package/dist/audit/emit.js.map +1 -0
- package/dist/audit/index.d.ts +3 -0
- package/dist/audit/index.d.ts.map +1 -0
- package/dist/audit/index.js +2 -0
- package/dist/audit/index.js.map +1 -0
- package/dist/audit/namespace.d.ts +5 -0
- package/dist/audit/namespace.d.ts.map +1 -0
- package/dist/audit/namespace.js +5 -0
- package/dist/audit/namespace.js.map +1 -0
- package/dist/audit/types.d.ts +17 -0
- package/dist/audit/types.d.ts.map +1 -0
- package/dist/audit/types.js +2 -0
- package/dist/audit/types.js.map +1 -0
- package/dist/auth/chain.d.ts +21 -0
- package/dist/auth/chain.d.ts.map +1 -0
- package/dist/auth/chain.js +45 -0
- package/dist/auth/chain.js.map +1 -0
- package/dist/auth/cookie.d.ts +18 -0
- package/dist/auth/cookie.d.ts.map +1 -0
- package/dist/auth/cookie.js +55 -0
- package/dist/auth/cookie.js.map +1 -0
- package/dist/auth/index.d.ts +10 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +5 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/multi-org.d.ts +68 -0
- package/dist/auth/multi-org.d.ts.map +1 -0
- package/dist/auth/multi-org.js +163 -0
- package/dist/auth/multi-org.js.map +1 -0
- package/dist/auth/namespace.d.ts +14 -0
- package/dist/auth/namespace.d.ts.map +1 -0
- package/dist/auth/namespace.js +14 -0
- package/dist/auth/namespace.js.map +1 -0
- package/dist/auth/sessions.d.ts +64 -0
- package/dist/auth/sessions.d.ts.map +1 -0
- package/dist/auth/sessions.js +230 -0
- package/dist/auth/sessions.js.map +1 -0
- package/dist/auth/types.d.ts +14 -0
- package/dist/auth/types.d.ts.map +1 -0
- package/dist/auth/types.js +2 -0
- package/dist/auth/types.js.map +1 -0
- package/dist/behavior/audited.d.ts +5 -0
- package/dist/behavior/audited.d.ts.map +1 -0
- package/dist/behavior/audited.js +78 -0
- package/dist/behavior/audited.js.map +1 -0
- package/dist/behavior/cached.d.ts +7 -0
- package/dist/behavior/cached.d.ts.map +1 -0
- package/dist/behavior/cached.js +48 -0
- package/dist/behavior/cached.js.map +1 -0
- package/dist/behavior/compose.d.ts +4 -0
- package/dist/behavior/compose.d.ts.map +1 -0
- package/dist/behavior/compose.js +18 -0
- package/dist/behavior/compose.js.map +1 -0
- package/dist/behavior/index.d.ts +6 -0
- package/dist/behavior/index.d.ts.map +1 -0
- package/dist/behavior/index.js +5 -0
- package/dist/behavior/index.js.map +1 -0
- package/dist/behavior/namespace.d.ts +11 -0
- package/dist/behavior/namespace.d.ts.map +1 -0
- package/dist/behavior/namespace.js +11 -0
- package/dist/behavior/namespace.js.map +1 -0
- package/dist/behavior/types.d.ts +23 -0
- package/dist/behavior/types.d.ts.map +1 -0
- package/dist/behavior/types.js +2 -0
- package/dist/behavior/types.js.map +1 -0
- package/dist/behavior/versioned.d.ts +4 -0
- package/dist/behavior/versioned.d.ts.map +1 -0
- package/dist/behavior/versioned.js +39 -0
- package/dist/behavior/versioned.js.map +1 -0
- package/dist/cache/create.d.ts +3 -0
- package/dist/cache/create.d.ts.map +1 -0
- package/dist/cache/create.js +90 -0
- package/dist/cache/create.js.map +1 -0
- package/dist/cache/index.d.ts +5 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +3 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cache/namespace.d.ts +7 -0
- package/dist/cache/namespace.d.ts.map +1 -0
- package/dist/cache/namespace.js +7 -0
- package/dist/cache/namespace.js.map +1 -0
- package/dist/cache/tenant.d.ts +21 -0
- package/dist/cache/tenant.d.ts.map +1 -0
- package/dist/cache/tenant.js +101 -0
- package/dist/cache/tenant.js.map +1 -0
- package/dist/cache/types.d.ts +22 -0
- package/dist/cache/types.d.ts.map +1 -0
- package/dist/cache/types.js +2 -0
- package/dist/cache/types.js.map +1 -0
- package/dist/cli/commands/check.d.ts +2 -0
- package/dist/cli/commands/check.d.ts.map +1 -0
- package/dist/cli/commands/check.js +28 -0
- package/dist/cli/commands/check.js.map +1 -0
- package/dist/cli/commands/dev.d.ts +7 -0
- package/dist/cli/commands/dev.d.ts.map +1 -0
- package/dist/cli/commands/dev.js +19 -0
- package/dist/cli/commands/dev.js.map +1 -0
- package/dist/cli/commands/init.d.ts +2 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +33 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/migrate.d.ts +7 -0
- package/dist/cli/commands/migrate.d.ts.map +1 -0
- package/dist/cli/commands/migrate.js +45 -0
- package/dist/cli/commands/migrate.js.map +1 -0
- package/dist/cli/errors.d.ts +2 -0
- package/dist/cli/errors.d.ts.map +1 -0
- package/dist/cli/errors.js +11 -0
- package/dist/cli/errors.js.map +1 -0
- package/dist/cli/index.d.ts +2 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +84 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/output.d.ts +10 -0
- package/dist/cli/output.d.ts.map +1 -0
- package/dist/cli/output.js +16 -0
- package/dist/cli/output.js.map +1 -0
- package/dist/config/index.d.ts +4 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +4 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/load.d.ts +23 -0
- package/dist/config/load.d.ts.map +1 -0
- package/dist/config/load.js +103 -0
- package/dist/config/load.js.map +1 -0
- package/dist/config/namespace.d.ts +38 -0
- package/dist/config/namespace.d.ts.map +1 -0
- package/dist/config/namespace.js +7 -0
- package/dist/config/namespace.js.map +1 -0
- package/dist/config/resolve.d.ts +8 -0
- package/dist/config/resolve.d.ts.map +1 -0
- package/dist/config/resolve.js +35 -0
- package/dist/config/resolve.js.map +1 -0
- package/dist/config/schema.d.ts +75 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +26 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/context/create.d.ts +20 -0
- package/dist/context/create.d.ts.map +1 -0
- package/dist/context/create.js +38 -0
- package/dist/context/create.js.map +1 -0
- package/dist/context/guard.d.ts +5 -0
- package/dist/context/guard.d.ts.map +1 -0
- package/dist/context/guard.js +30 -0
- package/dist/context/guard.js.map +1 -0
- package/dist/context/index.d.ts +5 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +4 -0
- package/dist/context/index.js.map +1 -0
- package/dist/context/store.d.ts +7 -0
- package/dist/context/store.d.ts.map +1 -0
- package/dist/context/store.js +18 -0
- package/dist/context/store.js.map +1 -0
- package/dist/context/types.d.ts +25 -0
- package/dist/context/types.d.ts.map +1 -0
- package/dist/context/types.js +2 -0
- package/dist/context/types.js.map +1 -0
- package/dist/db/col/index.d.ts +2 -0
- package/dist/db/col/index.d.ts.map +1 -0
- package/dist/db/col/index.js +5 -0
- package/dist/db/col/index.js.map +1 -0
- package/dist/db/context.d.ts +4 -0
- package/dist/db/context.d.ts.map +1 -0
- package/dist/db/context.js +3 -0
- package/dist/db/context.js.map +1 -0
- package/dist/db/db.d.ts +6 -0
- package/dist/db/db.d.ts.map +1 -0
- package/dist/db/db.js +50 -0
- package/dist/db/db.js.map +1 -0
- package/dist/db/filter.d.ts +46 -0
- package/dist/db/filter.d.ts.map +1 -0
- package/dist/db/filter.js +9 -0
- package/dist/db/filter.js.map +1 -0
- package/dist/db/generated/drizzle-orm/aggregate.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/aggregate.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/aggregate.js +5 -0
- package/dist/db/generated/drizzle-orm/aggregate.js.map +1 -0
- package/dist/db/generated/drizzle-orm/introspection.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/introspection.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/introspection.js +5 -0
- package/dist/db/generated/drizzle-orm/introspection.js.map +1 -0
- package/dist/db/generated/drizzle-orm/operator.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/operator.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/operator.js +5 -0
- package/dist/db/generated/drizzle-orm/operator.js.map +1 -0
- package/dist/db/generated/drizzle-orm/relation.d.ts +2 -0
- package/dist/db/generated/drizzle-orm/relation.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/relation.js +5 -0
- package/dist/db/generated/drizzle-orm/relation.js.map +1 -0
- package/dist/db/generated/drizzle-orm/type.d.ts +3 -0
- package/dist/db/generated/drizzle-orm/type.d.ts.map +1 -0
- package/dist/db/generated/drizzle-orm/type.js +5 -0
- package/dist/db/generated/drizzle-orm/type.js.map +1 -0
- package/dist/db/generated/pg-core/introspection.d.ts +2 -0
- package/dist/db/generated/pg-core/introspection.d.ts.map +1 -0
- package/dist/db/generated/pg-core/introspection.js +5 -0
- package/dist/db/generated/pg-core/introspection.js.map +1 -0
- package/dist/db/generated/pg-core/set-operation.d.ts +2 -0
- package/dist/db/generated/pg-core/set-operation.d.ts.map +1 -0
- package/dist/db/generated/pg-core/set-operation.js +5 -0
- package/dist/db/generated/pg-core/set-operation.js.map +1 -0
- package/dist/db/generated/pg-core/type.d.ts +3 -0
- package/dist/db/generated/pg-core/type.d.ts.map +1 -0
- package/dist/db/generated/pg-core/type.js +5 -0
- package/dist/db/generated/pg-core/type.js.map +1 -0
- package/dist/db/identifiers.d.ts +3 -0
- package/dist/db/identifiers.d.ts.map +1 -0
- package/dist/db/identifiers.js +13 -0
- package/dist/db/identifiers.js.map +1 -0
- package/dist/db/idx/index.d.ts +2 -0
- package/dist/db/idx/index.d.ts.map +1 -0
- package/dist/db/idx/index.js +5 -0
- package/dist/db/idx/index.js.map +1 -0
- package/dist/db/index.d.ts +8 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +6 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/namespace.d.ts +66 -0
- package/dist/db/namespace.d.ts.map +1 -0
- package/dist/db/namespace.js +22 -0
- package/dist/db/namespace.js.map +1 -0
- package/dist/db/pool.d.ts +16 -0
- package/dist/db/pool.d.ts.map +1 -0
- package/dist/db/pool.js +36 -0
- package/dist/db/pool.js.map +1 -0
- package/dist/db/schema-features.d.ts +2 -0
- package/dist/db/schema-features.d.ts.map +1 -0
- package/dist/db/schema-features.js +4 -0
- package/dist/db/schema-features.js.map +1 -0
- package/dist/db/sql.d.ts +2 -0
- package/dist/db/sql.d.ts.map +1 -0
- package/dist/db/sql.js +2 -0
- package/dist/db/sql.js.map +1 -0
- package/dist/db/types.d.ts +7 -0
- package/dist/db/types.d.ts.map +1 -0
- package/dist/db/types.js +2 -0
- package/dist/db/types.js.map +1 -0
- package/dist/di/builder.d.ts +60 -0
- package/dist/di/builder.d.ts.map +1 -0
- package/dist/di/builder.js +152 -0
- package/dist/di/builder.js.map +1 -0
- package/dist/di/index.d.ts +5 -0
- package/dist/di/index.d.ts.map +1 -0
- package/dist/di/index.js +5 -0
- package/dist/di/index.js.map +1 -0
- package/dist/di/resolve.d.ts +8 -0
- package/dist/di/resolve.d.ts.map +1 -0
- package/dist/di/resolve.js +76 -0
- package/dist/di/resolve.js.map +1 -0
- package/dist/di/types.d.ts +35 -0
- package/dist/di/types.d.ts.map +1 -0
- package/dist/di/types.js +2 -0
- package/dist/di/types.js.map +1 -0
- package/dist/drizzle/index.d.ts +3 -0
- package/dist/drizzle/index.d.ts.map +1 -0
- package/dist/drizzle/index.js +3 -0
- package/dist/drizzle/index.js.map +1 -0
- package/dist/errors/base.d.ts +7 -0
- package/dist/errors/base.d.ts.map +1 -0
- package/dist/errors/base.js +9 -0
- package/dist/errors/base.js.map +1 -0
- package/dist/errors/index.d.ts +3 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +3 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/errors/namespace.d.ts +10 -0
- package/dist/errors/namespace.d.ts.map +1 -0
- package/dist/errors/namespace.js +10 -0
- package/dist/errors/namespace.js.map +1 -0
- package/dist/errors/types.d.ts +29 -0
- package/dist/errors/types.d.ts.map +1 -0
- package/dist/errors/types.js +46 -0
- package/dist/errors/types.js.map +1 -0
- package/dist/fitting/namespace.d.ts +5 -0
- package/dist/fitting/namespace.d.ts.map +1 -0
- package/dist/fitting/namespace.js +6 -0
- package/dist/fitting/namespace.js.map +1 -0
- package/dist/fixture/batch.d.ts +17 -0
- package/dist/fixture/batch.d.ts.map +1 -0
- package/dist/fixture/batch.js +47 -0
- package/dist/fixture/batch.js.map +1 -0
- package/dist/fixture/builder.d.ts +11 -0
- package/dist/fixture/builder.d.ts.map +1 -0
- package/dist/fixture/builder.js +12 -0
- package/dist/fixture/builder.js.map +1 -0
- package/dist/fixture/errors.d.ts +7 -0
- package/dist/fixture/errors.d.ts.map +1 -0
- package/dist/fixture/errors.js +9 -0
- package/dist/fixture/errors.js.map +1 -0
- package/dist/fixture/index.d.ts +9 -0
- package/dist/fixture/index.d.ts.map +1 -0
- package/dist/fixture/index.js +6 -0
- package/dist/fixture/index.js.map +1 -0
- package/dist/fixture/namespace.d.ts +15 -0
- package/dist/fixture/namespace.d.ts.map +1 -0
- package/dist/fixture/namespace.js +15 -0
- package/dist/fixture/namespace.js.map +1 -0
- package/dist/fixture/paginate.d.ts +13 -0
- package/dist/fixture/paginate.d.ts.map +1 -0
- package/dist/fixture/paginate.js +29 -0
- package/dist/fixture/paginate.js.map +1 -0
- package/dist/fixture/register.d.ts +16 -0
- package/dist/fixture/register.d.ts.map +1 -0
- package/dist/fixture/register.js +181 -0
- package/dist/fixture/register.js.map +1 -0
- package/dist/fixture/types.d.ts +69 -0
- package/dist/fixture/types.d.ts.map +1 -0
- package/dist/fixture/types.js +2 -0
- package/dist/fixture/types.js.map +1 -0
- package/dist/flow/namespace.d.ts +14 -0
- package/dist/flow/namespace.d.ts.map +1 -0
- package/dist/flow/namespace.js +14 -0
- package/dist/flow/namespace.js.map +1 -0
- package/dist/http/index.d.ts +4 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +3 -0
- package/dist/http/index.js.map +1 -0
- package/dist/http/middleware.d.ts +20 -0
- package/dist/http/middleware.d.ts.map +1 -0
- package/dist/http/middleware.js +62 -0
- package/dist/http/middleware.js.map +1 -0
- package/dist/http/namespace.d.ts +5 -0
- package/dist/http/namespace.d.ts.map +1 -0
- package/dist/http/namespace.js +5 -0
- package/dist/http/namespace.js.map +1 -0
- package/dist/http/response.d.ts +5 -0
- package/dist/http/response.d.ts.map +1 -0
- package/dist/http/response.js +22 -0
- package/dist/http/response.js.map +1 -0
- package/dist/http/server.d.ts +15 -0
- package/dist/http/server.d.ts.map +1 -0
- package/dist/http/server.js +362 -0
- package/dist/http/server.js.map +1 -0
- package/dist/http/types.d.ts +116 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +2 -0
- package/dist/http/types.js.map +1 -0
- package/dist/index.d.ts +55 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +26 -0
- package/dist/index.js.map +1 -0
- package/dist/invariants/assert.d.ts +7 -0
- package/dist/invariants/assert.d.ts.map +1 -0
- package/dist/invariants/assert.js +21 -0
- package/dist/invariants/assert.js.map +1 -0
- package/dist/invariants/index.d.ts +2 -0
- package/dist/invariants/index.d.ts.map +1 -0
- package/dist/invariants/index.js +2 -0
- package/dist/invariants/index.js.map +1 -0
- package/dist/jobs/cron.d.ts +10 -0
- package/dist/jobs/cron.d.ts.map +1 -0
- package/dist/jobs/cron.js +176 -0
- package/dist/jobs/cron.js.map +1 -0
- package/dist/jobs/execute.d.ts +12 -0
- package/dist/jobs/execute.d.ts.map +1 -0
- package/dist/jobs/execute.js +19 -0
- package/dist/jobs/execute.js.map +1 -0
- package/dist/jobs/index.d.ts +8 -0
- package/dist/jobs/index.d.ts.map +1 -0
- package/dist/jobs/index.js +4 -0
- package/dist/jobs/index.js.map +1 -0
- package/dist/jobs/listener.d.ts +32 -0
- package/dist/jobs/listener.d.ts.map +1 -0
- package/dist/jobs/listener.js +95 -0
- package/dist/jobs/listener.js.map +1 -0
- package/dist/jobs/namespace.d.ts +10 -0
- package/dist/jobs/namespace.d.ts.map +1 -0
- package/dist/jobs/namespace.js +10 -0
- package/dist/jobs/namespace.js.map +1 -0
- package/dist/jobs/queue.d.ts +53 -0
- package/dist/jobs/queue.d.ts.map +1 -0
- package/dist/jobs/queue.js +162 -0
- package/dist/jobs/queue.js.map +1 -0
- package/dist/jobs/scheduler.d.ts +31 -0
- package/dist/jobs/scheduler.d.ts.map +1 -0
- package/dist/jobs/scheduler.js +94 -0
- package/dist/jobs/scheduler.js.map +1 -0
- package/dist/lifecycle/drain.d.ts +7 -0
- package/dist/lifecycle/drain.d.ts.map +1 -0
- package/dist/lifecycle/drain.js +24 -0
- package/dist/lifecycle/drain.js.map +1 -0
- package/dist/lifecycle/health.d.ts +8 -0
- package/dist/lifecycle/health.d.ts.map +1 -0
- package/dist/lifecycle/health.js +62 -0
- package/dist/lifecycle/health.js.map +1 -0
- package/dist/lifecycle/index.d.ts +5 -0
- package/dist/lifecycle/index.d.ts.map +1 -0
- package/dist/lifecycle/index.js +4 -0
- package/dist/lifecycle/index.js.map +1 -0
- package/dist/lifecycle/namespace.d.ts +5 -0
- package/dist/lifecycle/namespace.d.ts.map +1 -0
- package/dist/lifecycle/namespace.js +5 -0
- package/dist/lifecycle/namespace.js.map +1 -0
- package/dist/lifecycle/startup.d.ts +8 -0
- package/dist/lifecycle/startup.d.ts.map +1 -0
- package/dist/lifecycle/startup.js +43 -0
- package/dist/lifecycle/startup.js.map +1 -0
- package/dist/lifecycle/types.d.ts +30 -0
- package/dist/lifecycle/types.d.ts.map +1 -0
- package/dist/lifecycle/types.js +2 -0
- package/dist/lifecycle/types.js.map +1 -0
- package/dist/log/namespace.d.ts +9 -0
- package/dist/log/namespace.d.ts.map +1 -0
- package/dist/log/namespace.js +10 -0
- package/dist/log/namespace.js.map +1 -0
- package/dist/logging/context.d.ts +11 -0
- package/dist/logging/context.d.ts.map +1 -0
- package/dist/logging/context.js +46 -0
- package/dist/logging/context.js.map +1 -0
- package/dist/logging/index.d.ts +4 -0
- package/dist/logging/index.d.ts.map +1 -0
- package/dist/logging/index.js +3 -0
- package/dist/logging/index.js.map +1 -0
- package/dist/logging/logger.d.ts +8 -0
- package/dist/logging/logger.d.ts.map +1 -0
- package/dist/logging/logger.js +39 -0
- package/dist/logging/logger.js.map +1 -0
- package/dist/logging/proxy.d.ts +3 -0
- package/dist/logging/proxy.d.ts.map +1 -0
- package/dist/logging/proxy.js +12 -0
- package/dist/logging/proxy.js.map +1 -0
- package/dist/logging/types.d.ts +36 -0
- package/dist/logging/types.d.ts.map +1 -0
- package/dist/logging/types.js +2 -0
- package/dist/logging/types.js.map +1 -0
- package/dist/migrate/index.d.ts +2 -0
- package/dist/migrate/index.d.ts.map +1 -0
- package/dist/migrate/index.js +2 -0
- package/dist/migrate/index.js.map +1 -0
- package/dist/migrate/run.d.ts +10 -0
- package/dist/migrate/run.d.ts.map +1 -0
- package/dist/migrate/run.js +45 -0
- package/dist/migrate/run.js.map +1 -0
- package/dist/openapi/generate.d.ts +13 -0
- package/dist/openapi/generate.d.ts.map +1 -0
- package/dist/openapi/generate.js +82 -0
- package/dist/openapi/generate.js.map +1 -0
- package/dist/openapi/index.d.ts +3 -0
- package/dist/openapi/index.d.ts.map +1 -0
- package/dist/openapi/index.js +2 -0
- package/dist/openapi/index.js.map +1 -0
- package/dist/openapi/namespace.d.ts +5 -0
- package/dist/openapi/namespace.d.ts.map +1 -0
- package/dist/openapi/namespace.js +5 -0
- package/dist/openapi/namespace.js.map +1 -0
- package/dist/pipeline/define.d.ts +3 -0
- package/dist/pipeline/define.d.ts.map +1 -0
- package/dist/pipeline/define.js +44 -0
- package/dist/pipeline/define.js.map +1 -0
- package/dist/pipeline/errors.d.ts +17 -0
- package/dist/pipeline/errors.d.ts.map +1 -0
- package/dist/pipeline/errors.js +28 -0
- package/dist/pipeline/errors.js.map +1 -0
- package/dist/pipeline/execute.d.ts +4 -0
- package/dist/pipeline/execute.d.ts.map +1 -0
- package/dist/pipeline/execute.js +90 -0
- package/dist/pipeline/execute.js.map +1 -0
- package/dist/pipeline/index.d.ts +4 -0
- package/dist/pipeline/index.d.ts.map +1 -0
- package/dist/pipeline/index.js +3 -0
- package/dist/pipeline/index.js.map +1 -0
- package/dist/pipeline/namespace.d.ts +8 -0
- package/dist/pipeline/namespace.d.ts.map +1 -0
- package/dist/pipeline/namespace.js +8 -0
- package/dist/pipeline/namespace.js.map +1 -0
- package/dist/pipeline/resume.d.ts +4 -0
- package/dist/pipeline/resume.d.ts.map +1 -0
- package/dist/pipeline/resume.js +100 -0
- package/dist/pipeline/resume.js.map +1 -0
- package/dist/pipeline/types.d.ts +50 -0
- package/dist/pipeline/types.d.ts.map +1 -0
- package/dist/pipeline/types.js +2 -0
- package/dist/pipeline/types.js.map +1 -0
- package/dist/pipework.d.ts +35 -0
- package/dist/pipework.d.ts.map +1 -0
- package/dist/pipework.js +102 -0
- package/dist/pipework.js.map +1 -0
- package/dist/rbac/cache.d.ts +13 -0
- package/dist/rbac/cache.d.ts.map +1 -0
- package/dist/rbac/cache.js +43 -0
- package/dist/rbac/cache.js.map +1 -0
- package/dist/rbac/check.d.ts +4 -0
- package/dist/rbac/check.d.ts.map +1 -0
- package/dist/rbac/check.js +20 -0
- package/dist/rbac/check.js.map +1 -0
- package/dist/rbac/index.d.ts +7 -0
- package/dist/rbac/index.d.ts.map +1 -0
- package/dist/rbac/index.js +31 -0
- package/dist/rbac/index.js.map +1 -0
- package/dist/rbac/middleware.d.ts +4 -0
- package/dist/rbac/middleware.d.ts.map +1 -0
- package/dist/rbac/middleware.js +9 -0
- package/dist/rbac/middleware.js.map +1 -0
- package/dist/rbac/namespace.d.ts +9 -0
- package/dist/rbac/namespace.d.ts.map +1 -0
- package/dist/rbac/namespace.js +9 -0
- package/dist/rbac/namespace.js.map +1 -0
- package/dist/rbac/resolve.d.ts +4 -0
- package/dist/rbac/resolve.d.ts.map +1 -0
- package/dist/rbac/resolve.js +24 -0
- package/dist/rbac/resolve.js.map +1 -0
- package/dist/rbac/seed.d.ts +4 -0
- package/dist/rbac/seed.d.ts.map +1 -0
- package/dist/rbac/seed.js +63 -0
- package/dist/rbac/seed.js.map +1 -0
- package/dist/rbac/types.d.ts +56 -0
- package/dist/rbac/types.d.ts.map +1 -0
- package/dist/rbac/types.js +2 -0
- package/dist/rbac/types.js.map +1 -0
- package/dist/resource/batch.d.ts +17 -0
- package/dist/resource/batch.d.ts.map +1 -0
- package/dist/resource/batch.js +47 -0
- package/dist/resource/batch.js.map +1 -0
- package/dist/resource/builder.d.ts +11 -0
- package/dist/resource/builder.d.ts.map +1 -0
- package/dist/resource/builder.js +12 -0
- package/dist/resource/builder.js.map +1 -0
- package/dist/resource/errors.d.ts +7 -0
- package/dist/resource/errors.d.ts.map +1 -0
- package/dist/resource/errors.js +9 -0
- package/dist/resource/errors.js.map +1 -0
- package/dist/resource/index.d.ts +9 -0
- package/dist/resource/index.d.ts.map +1 -0
- package/dist/resource/index.js +6 -0
- package/dist/resource/index.js.map +1 -0
- package/dist/resource/paginate.d.ts +13 -0
- package/dist/resource/paginate.d.ts.map +1 -0
- package/dist/resource/paginate.js +29 -0
- package/dist/resource/paginate.js.map +1 -0
- package/dist/resource/register.d.ts +16 -0
- package/dist/resource/register.d.ts.map +1 -0
- package/dist/resource/register.js +181 -0
- package/dist/resource/register.js.map +1 -0
- package/dist/resource/types.d.ts +69 -0
- package/dist/resource/types.d.ts.map +1 -0
- package/dist/resource/types.js +2 -0
- package/dist/resource/types.js.map +1 -0
- package/dist/schema/branded.d.ts +3 -0
- package/dist/schema/branded.d.ts.map +1 -0
- package/dist/schema/branded.js +8 -0
- package/dist/schema/branded.js.map +1 -0
- package/dist/schema/generated/coerce.d.ts +2 -0
- package/dist/schema/generated/coerce.d.ts.map +1 -0
- package/dist/schema/generated/coerce.js +5 -0
- package/dist/schema/generated/coerce.js.map +1 -0
- package/dist/schema/generated/combinator.d.ts +3 -0
- package/dist/schema/generated/combinator.d.ts.map +1 -0
- package/dist/schema/generated/combinator.js +5 -0
- package/dist/schema/generated/combinator.js.map +1 -0
- package/dist/schema/generated/encoding.d.ts +2 -0
- package/dist/schema/generated/encoding.d.ts.map +1 -0
- package/dist/schema/generated/encoding.js +5 -0
- package/dist/schema/generated/encoding.js.map +1 -0
- package/dist/schema/generated/error.d.ts +3 -0
- package/dist/schema/generated/error.d.ts.map +1 -0
- package/dist/schema/generated/error.js +5 -0
- package/dist/schema/generated/error.js.map +1 -0
- package/dist/schema/generated/format.d.ts +2 -0
- package/dist/schema/generated/format.d.ts.map +1 -0
- package/dist/schema/generated/format.js +5 -0
- package/dist/schema/generated/format.js.map +1 -0
- package/dist/schema/generated/type-constructor.d.ts +3 -0
- package/dist/schema/generated/type-constructor.d.ts.map +1 -0
- package/dist/schema/generated/type-constructor.js +5 -0
- package/dist/schema/generated/type-constructor.js.map +1 -0
- package/dist/schema/generated/type.d.ts +3 -0
- package/dist/schema/generated/type.d.ts.map +1 -0
- package/dist/schema/generated/type.js +5 -0
- package/dist/schema/generated/type.js.map +1 -0
- package/dist/schema/index.d.ts +6 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +5 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/json-schema.d.ts +5 -0
- package/dist/schema/json-schema.d.ts.map +1 -0
- package/dist/schema/json-schema.js +5 -0
- package/dist/schema/json-schema.js.map +1 -0
- package/dist/schema/namespace.d.ts +128 -0
- package/dist/schema/namespace.d.ts.map +1 -0
- package/dist/schema/namespace.js +37 -0
- package/dist/schema/namespace.js.map +1 -0
- package/dist/schema/parse.d.ts +11 -0
- package/dist/schema/parse.d.ts.map +1 -0
- package/dist/schema/parse.js +30 -0
- package/dist/schema/parse.js.map +1 -0
- package/dist/schema/types.d.ts +4 -0
- package/dist/schema/types.d.ts.map +1 -0
- package/dist/schema/types.js +2 -0
- package/dist/schema/types.js.map +1 -0
- package/dist/state-machine/define.d.ts +3 -0
- package/dist/state-machine/define.d.ts.map +1 -0
- package/dist/state-machine/define.js +46 -0
- package/dist/state-machine/define.js.map +1 -0
- package/dist/state-machine/errors.d.ts +12 -0
- package/dist/state-machine/errors.d.ts.map +1 -0
- package/dist/state-machine/errors.js +19 -0
- package/dist/state-machine/errors.js.map +1 -0
- package/dist/state-machine/index.d.ts +4 -0
- package/dist/state-machine/index.d.ts.map +1 -0
- package/dist/state-machine/index.js +3 -0
- package/dist/state-machine/index.js.map +1 -0
- package/dist/state-machine/namespace.d.ts +8 -0
- package/dist/state-machine/namespace.d.ts.map +1 -0
- package/dist/state-machine/namespace.js +8 -0
- package/dist/state-machine/namespace.js.map +1 -0
- package/dist/state-machine/transition.d.ts +7 -0
- package/dist/state-machine/transition.d.ts.map +1 -0
- package/dist/state-machine/transition.js +57 -0
- package/dist/state-machine/transition.js.map +1 -0
- package/dist/state-machine/types.d.ts +33 -0
- package/dist/state-machine/types.d.ts.map +1 -0
- package/dist/state-machine/types.js +2 -0
- package/dist/state-machine/types.js.map +1 -0
- package/dist/temporal/close.d.ts +3 -0
- package/dist/temporal/close.d.ts.map +1 -0
- package/dist/temporal/close.js +19 -0
- package/dist/temporal/close.js.map +1 -0
- package/dist/temporal/columns.d.ts +7 -0
- package/dist/temporal/columns.d.ts.map +1 -0
- package/dist/temporal/columns.js +10 -0
- package/dist/temporal/columns.js.map +1 -0
- package/dist/temporal/errors.d.ts +7 -0
- package/dist/temporal/errors.d.ts.map +1 -0
- package/dist/temporal/errors.js +9 -0
- package/dist/temporal/errors.js.map +1 -0
- package/dist/temporal/get-current.d.ts +3 -0
- package/dist/temporal/get-current.d.ts.map +1 -0
- package/dist/temporal/get-current.js +18 -0
- package/dist/temporal/get-current.js.map +1 -0
- package/dist/temporal/index.d.ts +8 -0
- package/dist/temporal/index.d.ts.map +1 -0
- package/dist/temporal/index.js +7 -0
- package/dist/temporal/index.js.map +1 -0
- package/dist/temporal/namespace.d.ts +16 -0
- package/dist/temporal/namespace.d.ts.map +1 -0
- package/dist/temporal/namespace.js +16 -0
- package/dist/temporal/namespace.js.map +1 -0
- package/dist/temporal/query.d.ts +10 -0
- package/dist/temporal/query.d.ts.map +1 -0
- package/dist/temporal/query.js +11 -0
- package/dist/temporal/query.js.map +1 -0
- package/dist/temporal/revise.d.ts +3 -0
- package/dist/temporal/revise.d.ts.map +1 -0
- package/dist/temporal/revise.js +52 -0
- package/dist/temporal/revise.js.map +1 -0
- package/dist/temporal/types.d.ts +19 -0
- package/dist/temporal/types.d.ts.map +1 -0
- package/dist/temporal/types.js +2 -0
- package/dist/temporal/types.js.map +1 -0
- package/dist/tenant/extract.d.ts +6 -0
- package/dist/tenant/extract.d.ts.map +1 -0
- package/dist/tenant/extract.js +18 -0
- package/dist/tenant/extract.js.map +1 -0
- package/dist/tenant/index.d.ts +6 -0
- package/dist/tenant/index.d.ts.map +1 -0
- package/dist/tenant/index.js +5 -0
- package/dist/tenant/index.js.map +1 -0
- package/dist/tenant/namespace.d.ts +13 -0
- package/dist/tenant/namespace.d.ts.map +1 -0
- package/dist/tenant/namespace.js +13 -0
- package/dist/tenant/namespace.js.map +1 -0
- package/dist/tenant/propagate.d.ts +4 -0
- package/dist/tenant/propagate.d.ts.map +1 -0
- package/dist/tenant/propagate.js +15 -0
- package/dist/tenant/propagate.js.map +1 -0
- package/dist/tenant/rls.d.ts +5 -0
- package/dist/tenant/rls.d.ts.map +1 -0
- package/dist/tenant/rls.js +33 -0
- package/dist/tenant/rls.js.map +1 -0
- package/dist/tenant/types.d.ts +12 -0
- package/dist/tenant/types.d.ts.map +1 -0
- package/dist/tenant/types.js +2 -0
- package/dist/tenant/types.js.map +1 -0
- package/dist/tenant/validate.d.ts +4 -0
- package/dist/tenant/validate.d.ts.map +1 -0
- package/dist/tenant/validate.js +20 -0
- package/dist/tenant/validate.js.map +1 -0
- package/dist/test/auth.d.ts +7 -0
- package/dist/test/auth.d.ts.map +1 -0
- package/dist/test/auth.js +11 -0
- package/dist/test/auth.js.map +1 -0
- package/dist/test/context.d.ts +10 -0
- package/dist/test/context.d.ts.map +1 -0
- package/dist/test/context.js +26 -0
- package/dist/test/context.js.map +1 -0
- package/dist/test/index.d.ts +6 -0
- package/dist/test/index.d.ts.map +1 -0
- package/dist/test/index.js +6 -0
- package/dist/test/index.js.map +1 -0
- package/dist/test/plugin.d.ts +16 -0
- package/dist/test/plugin.d.ts.map +1 -0
- package/dist/test/plugin.js +63 -0
- package/dist/test/plugin.js.map +1 -0
- package/dist/test/setup.d.ts +11 -0
- package/dist/test/setup.d.ts.map +1 -0
- package/dist/test/setup.js +76 -0
- package/dist/test/setup.js.map +1 -0
- package/dist/test/vitest.d.ts +9 -0
- package/dist/test/vitest.d.ts.map +1 -0
- package/dist/test/vitest.js +58 -0
- package/dist/test/vitest.js.map +1 -0
- package/dist/trunk.d.ts +35 -0
- package/dist/trunk.d.ts.map +1 -0
- package/dist/trunk.js +102 -0
- package/dist/trunk.js.map +1 -0
- package/dist/vector/index.d.ts +4 -0
- package/dist/vector/index.d.ts.map +1 -0
- package/dist/vector/index.js +4 -0
- package/dist/vector/index.js.map +1 -0
- package/dist/vector/namespace.d.ts +16 -0
- package/dist/vector/namespace.d.ts.map +1 -0
- package/dist/vector/namespace.js +16 -0
- package/dist/vector/namespace.js.map +1 -0
- package/dist/vector/query.d.ts +9 -0
- package/dist/vector/query.d.ts.map +1 -0
- package/dist/vector/query.js +33 -0
- package/dist/vector/query.js.map +1 -0
- package/dist/vector/types.d.ts +19 -0
- package/dist/vector/types.d.ts.map +1 -0
- package/dist/vector/types.js +26 -0
- package/dist/vector/types.js.map +1 -0
- package/dist/vector/validate.d.ts +3 -0
- package/dist/vector/validate.d.ts.map +1 -0
- package/dist/vector/validate.js +10 -0
- package/dist/vector/validate.js.map +1 -0
- package/package.json +138 -0
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { SignJWT, jwtVerify, importPKCS8, importSPKI } from 'jose';
|
|
2
|
+
import { sql } from '../db/sql.js';
|
|
3
|
+
import { ForbiddenError, UnauthorizedError, ConflictError, NotFoundError } from '../errors/index.js';
|
|
4
|
+
import { assertValidIdentifier } from '../db/identifiers.js';
|
|
5
|
+
export function createMultiOrgSessions(config) {
|
|
6
|
+
const tableName = config.table ?? 'pipework_user_orgs';
|
|
7
|
+
assertValidIdentifier(tableName, 'multi-org membership table');
|
|
8
|
+
const t = sql.raw(`"${tableName}"`);
|
|
9
|
+
const orgSelectAudience = `${config.audience}:org-select`;
|
|
10
|
+
const orgSelectExpiresIn = config.orgSelectToken?.expiresIn ?? '10m';
|
|
11
|
+
let cachedPrivateKey = null;
|
|
12
|
+
let cachedPublicKey = null;
|
|
13
|
+
async function getPrivateKey() {
|
|
14
|
+
if (cachedPrivateKey === null) {
|
|
15
|
+
cachedPrivateKey = await importPKCS8(config.signing.privateKey, config.signing.algorithm);
|
|
16
|
+
}
|
|
17
|
+
return cachedPrivateKey;
|
|
18
|
+
}
|
|
19
|
+
async function getPublicKey() {
|
|
20
|
+
if (cachedPublicKey === null) {
|
|
21
|
+
cachedPublicKey = await importSPKI(config.signing.publicKey, config.signing.algorithm);
|
|
22
|
+
}
|
|
23
|
+
return cachedPublicKey;
|
|
24
|
+
}
|
|
25
|
+
function parseExpiry(exp) {
|
|
26
|
+
const match = exp.match(/^(\d+)([smhd])$/);
|
|
27
|
+
if (match === null)
|
|
28
|
+
throw new Error(`Invalid expiry format: ${exp}`);
|
|
29
|
+
const value = parseInt(match[1], 10);
|
|
30
|
+
const unit = match[2];
|
|
31
|
+
switch (unit) {
|
|
32
|
+
case 's': return value;
|
|
33
|
+
case 'm': return value * 60;
|
|
34
|
+
case 'h': return value * 3600;
|
|
35
|
+
case 'd': return value * 86400;
|
|
36
|
+
default: return value;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
async function signOrgSelectToken(userId) {
|
|
40
|
+
const key = await getPrivateKey();
|
|
41
|
+
const expiresInSeconds = parseExpiry(orgSelectExpiresIn);
|
|
42
|
+
return new SignJWT({ purpose: 'org_select' })
|
|
43
|
+
.setProtectedHeader({ alg: config.signing.algorithm })
|
|
44
|
+
.setSubject(userId)
|
|
45
|
+
.setIssuer(config.issuer)
|
|
46
|
+
.setAudience(orgSelectAudience)
|
|
47
|
+
.setIssuedAt()
|
|
48
|
+
.setExpirationTime(`${expiresInSeconds}s`)
|
|
49
|
+
.sign(key);
|
|
50
|
+
}
|
|
51
|
+
async function verifyOrgSelectToken(token) {
|
|
52
|
+
const key = await getPublicKey();
|
|
53
|
+
try {
|
|
54
|
+
const { payload } = await jwtVerify(token, key, {
|
|
55
|
+
algorithms: [config.signing.algorithm],
|
|
56
|
+
issuer: config.issuer,
|
|
57
|
+
audience: orgSelectAudience,
|
|
58
|
+
});
|
|
59
|
+
if (payload['purpose'] !== 'org_select') {
|
|
60
|
+
throw new Error('wrong purpose');
|
|
61
|
+
}
|
|
62
|
+
return payload.sub;
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
throw new UnauthorizedError('Invalid or expired organization selection token. Please log in again.');
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
async function requireMembership(db, userId, orgId) {
|
|
69
|
+
const rows = await db.execute(sql `SELECT 1 FROM ${t} WHERE user_id = ${userId} AND org_id = ${orgId}`);
|
|
70
|
+
if (rows.length === 0) {
|
|
71
|
+
throw new ForbiddenError('You are not a member of this organization.');
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
async function resolveLogin(response, db, user) {
|
|
75
|
+
const rows = await db.execute(sql `SELECT org_id, role FROM ${t} WHERE user_id = ${user.id} ORDER BY joined_at`);
|
|
76
|
+
if (rows.length === 0) {
|
|
77
|
+
throw new ForbiddenError('User has no organization memberships. Contact your administrator to be added to an organization.');
|
|
78
|
+
}
|
|
79
|
+
if (rows.length === 1) {
|
|
80
|
+
const orgId = rows[0]['org_id'];
|
|
81
|
+
const result = await config.sessions.issueTokensHttp(response, db, { id: user.id, tenantId: orgId });
|
|
82
|
+
return { type: 'authenticated', accessToken: result.accessToken, expiresIn: result.expiresIn };
|
|
83
|
+
}
|
|
84
|
+
const orgIds = rows.map(r => r['org_id']);
|
|
85
|
+
let orgNames = null;
|
|
86
|
+
if (config.resolveOrgNames !== undefined) {
|
|
87
|
+
orgNames = await config.resolveOrgNames(db, orgIds);
|
|
88
|
+
}
|
|
89
|
+
const orgs = orgIds.map(id => ({
|
|
90
|
+
id,
|
|
91
|
+
name: orgNames?.get(id) ?? id,
|
|
92
|
+
}));
|
|
93
|
+
const sessionToken = await signOrgSelectToken(user.id);
|
|
94
|
+
return { type: 'org_select', sessionToken, orgs };
|
|
95
|
+
}
|
|
96
|
+
async function selectOrg(response, db, sessionToken, orgId) {
|
|
97
|
+
const userId = await verifyOrgSelectToken(sessionToken);
|
|
98
|
+
await requireMembership(db, userId, orgId);
|
|
99
|
+
return config.sessions.issueTokensHttp(response, db, { id: userId, tenantId: orgId });
|
|
100
|
+
}
|
|
101
|
+
async function switchOrg(response, db, _request, orgId, userId) {
|
|
102
|
+
await requireMembership(db, userId, orgId);
|
|
103
|
+
return config.sessions.issueTokensHttp(response, db, { id: userId, tenantId: orgId });
|
|
104
|
+
}
|
|
105
|
+
async function listOrgs(db, userId) {
|
|
106
|
+
const rows = await db.execute(sql `SELECT org_id, role FROM ${t} WHERE user_id = ${userId} ORDER BY joined_at`);
|
|
107
|
+
const orgIds = rows.map(r => r['org_id']);
|
|
108
|
+
let orgNames = null;
|
|
109
|
+
if (config.resolveOrgNames !== undefined && orgIds.length > 0) {
|
|
110
|
+
orgNames = await config.resolveOrgNames(db, orgIds);
|
|
111
|
+
}
|
|
112
|
+
const orgs = rows.map(r => {
|
|
113
|
+
const orgId = r['org_id'];
|
|
114
|
+
return {
|
|
115
|
+
id: orgId,
|
|
116
|
+
name: orgNames?.get(orgId) ?? orgId,
|
|
117
|
+
role: r['role'] ?? null,
|
|
118
|
+
};
|
|
119
|
+
});
|
|
120
|
+
return { orgs };
|
|
121
|
+
}
|
|
122
|
+
async function addMember(db, params) {
|
|
123
|
+
const role = params.role ?? null;
|
|
124
|
+
const addedBy = params.addedBy ?? null;
|
|
125
|
+
const rows = await db.execute(sql `INSERT INTO ${t} (user_id, org_id, role, added_by)
|
|
126
|
+
VALUES (${params.userId}, ${params.orgId}, ${role}, ${addedBy})
|
|
127
|
+
ON CONFLICT (user_id, org_id) DO NOTHING
|
|
128
|
+
RETURNING id`);
|
|
129
|
+
if (rows.length === 0) {
|
|
130
|
+
throw new ConflictError('User is already a member of this organization.');
|
|
131
|
+
}
|
|
132
|
+
return { id: rows[0]['id'] };
|
|
133
|
+
}
|
|
134
|
+
async function removeMember(db, params) {
|
|
135
|
+
const rows = await db.execute(sql `DELETE FROM ${t} WHERE user_id = ${params.userId} AND org_id = ${params.orgId} RETURNING id`);
|
|
136
|
+
if (rows.length === 0) {
|
|
137
|
+
throw new NotFoundError('Membership');
|
|
138
|
+
}
|
|
139
|
+
await config.sessions.bumpVersion(db, params.userId);
|
|
140
|
+
}
|
|
141
|
+
async function checkMembershipFn(db, userId, orgId) {
|
|
142
|
+
const rows = await db.execute(sql `SELECT id, org_id, role, joined_at FROM ${t} WHERE user_id = ${userId} AND org_id = ${orgId}`);
|
|
143
|
+
if (rows.length === 0)
|
|
144
|
+
return null;
|
|
145
|
+
const row = rows[0];
|
|
146
|
+
return {
|
|
147
|
+
id: row['id'],
|
|
148
|
+
orgId: row['org_id'],
|
|
149
|
+
role: row['role'] ?? null,
|
|
150
|
+
joinedAt: new Date(row['joined_at']),
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
return {
|
|
154
|
+
resolveLogin,
|
|
155
|
+
selectOrg,
|
|
156
|
+
switchOrg,
|
|
157
|
+
listOrgs,
|
|
158
|
+
addMember,
|
|
159
|
+
removeMember,
|
|
160
|
+
checkMembership: checkMembershipFn,
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=multi-org.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multi-org.js","sourceRoot":"","sources":["../../src/auth/multi-org.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createSessions } from './sessions.js';
|
|
2
|
+
import { createMultiOrgSessions } from './multi-org.js';
|
|
3
|
+
import { runAuthChain } from './chain.js';
|
|
4
|
+
import { resolveCookieConfig, parseCookieHeader, buildSetCookieHeader, buildClearCookieHeader } from './cookie.js';
|
|
5
|
+
export declare const auth: {
|
|
6
|
+
createSessions: typeof createSessions;
|
|
7
|
+
createMultiOrg: typeof createMultiOrgSessions;
|
|
8
|
+
runChain: typeof runAuthChain;
|
|
9
|
+
resolveCookie: typeof resolveCookieConfig;
|
|
10
|
+
parseCookie: typeof parseCookieHeader;
|
|
11
|
+
buildSetCookie: typeof buildSetCookieHeader;
|
|
12
|
+
buildClearCookie: typeof buildClearCookieHeader;
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=namespace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.d.ts","sourceRoot":"","sources":["../../src/auth/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAA;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AACzC,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAA;AAElH,eAAO,MAAM,IAAI;;;;;;;;CAQhB,CAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createSessions } from './sessions.js';
|
|
2
|
+
import { createMultiOrgSessions } from './multi-org.js';
|
|
3
|
+
import { runAuthChain } from './chain.js';
|
|
4
|
+
import { resolveCookieConfig, parseCookieHeader, buildSetCookieHeader, buildClearCookieHeader } from './cookie.js';
|
|
5
|
+
export const auth = {
|
|
6
|
+
createSessions,
|
|
7
|
+
createMultiOrg: createMultiOrgSessions,
|
|
8
|
+
runChain: runAuthChain,
|
|
9
|
+
resolveCookie: resolveCookieConfig,
|
|
10
|
+
parseCookie: parseCookieHeader,
|
|
11
|
+
buildSetCookie: buildSetCookieHeader,
|
|
12
|
+
buildClearCookie: buildClearCookieHeader,
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=namespace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"namespace.js","sourceRoot":"","sources":["../../src/auth/namespace.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAA;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AACzC,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAA;AAElH,MAAM,CAAC,MAAM,IAAI,GAAG;IAClB,cAAc;IACd,cAAc,EAAE,sBAAsB;IACtC,QAAQ,EAAE,YAAY;IACtB,aAAa,EAAE,mBAAmB;IAClC,WAAW,EAAE,iBAAiB;IAC9B,cAAc,EAAE,oBAAoB;IACpC,gBAAgB,EAAE,sBAAsB;CACzC,CAAA"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import type { DB } from '../db/index.js';
|
|
2
|
+
import type { CookieConfig } from './cookie.js';
|
|
3
|
+
import type { HttpRequest, HttpResponse } from '../http/types.js';
|
|
4
|
+
export interface SessionConfig {
|
|
5
|
+
readonly signing: {
|
|
6
|
+
algorithm: 'ES256';
|
|
7
|
+
privateKey: string;
|
|
8
|
+
publicKey: string;
|
|
9
|
+
};
|
|
10
|
+
readonly issuer: string;
|
|
11
|
+
readonly audience: string;
|
|
12
|
+
readonly accessToken: {
|
|
13
|
+
expiresIn: string;
|
|
14
|
+
};
|
|
15
|
+
readonly refreshToken: {
|
|
16
|
+
expiresIn: string;
|
|
17
|
+
rotateOnUse: boolean;
|
|
18
|
+
reuseDetection: boolean;
|
|
19
|
+
cookie?: CookieConfig;
|
|
20
|
+
};
|
|
21
|
+
readonly versionCheck: boolean;
|
|
22
|
+
readonly versionCacheTtlMs?: number;
|
|
23
|
+
readonly resolveRoles?: (db: DB, userId: string, tenantId: string) => Promise<string[]>;
|
|
24
|
+
readonly environment?: string;
|
|
25
|
+
}
|
|
26
|
+
export interface TokenPair {
|
|
27
|
+
readonly accessToken: string;
|
|
28
|
+
readonly refreshToken: string;
|
|
29
|
+
readonly expiresIn: number;
|
|
30
|
+
}
|
|
31
|
+
export interface TokenPayload {
|
|
32
|
+
readonly sub: string;
|
|
33
|
+
readonly tid: string;
|
|
34
|
+
readonly av: number;
|
|
35
|
+
readonly roles: string[] | undefined;
|
|
36
|
+
}
|
|
37
|
+
export interface HttpTokenResult {
|
|
38
|
+
readonly accessToken: string;
|
|
39
|
+
readonly expiresIn: number;
|
|
40
|
+
}
|
|
41
|
+
export type { HttpRequest, HttpResponse };
|
|
42
|
+
export interface Sessions {
|
|
43
|
+
issueTokens(db: DB, user: {
|
|
44
|
+
id: string;
|
|
45
|
+
tenantId: string;
|
|
46
|
+
roles?: string[];
|
|
47
|
+
}): Promise<TokenPair>;
|
|
48
|
+
refresh(db: DB, refreshToken: string): Promise<TokenPair>;
|
|
49
|
+
revokeAll(db: DB, userId: string): Promise<void>;
|
|
50
|
+
bumpVersion(db: DB, userId: string): Promise<void>;
|
|
51
|
+
verifyAccessToken(token: string): Promise<TokenPayload>;
|
|
52
|
+
checkVersion(db: DB, userId: string, tokenVersion: number): Promise<boolean>;
|
|
53
|
+
cleanExpiredTokens(db: DB): Promise<number>;
|
|
54
|
+
issueTokensHttp(response: HttpResponse, db: DB, user: {
|
|
55
|
+
id: string;
|
|
56
|
+
tenantId: string;
|
|
57
|
+
roles?: string[];
|
|
58
|
+
}): Promise<HttpTokenResult>;
|
|
59
|
+
refreshHttp(response: HttpResponse, db: DB, request: HttpRequest): Promise<HttpTokenResult>;
|
|
60
|
+
revokeHttp(response: HttpResponse, db: DB, request: HttpRequest): Promise<void>;
|
|
61
|
+
revokeAllHttp(response: HttpResponse, db: DB, userId: string): Promise<void>;
|
|
62
|
+
}
|
|
63
|
+
export declare function createSessions(config: SessionConfig): Sessions;
|
|
64
|
+
//# sourceMappingURL=sessions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../src/auth/sessions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
import { SignJWT, jwtVerify, importPKCS8, importSPKI } from 'jose';
|
|
2
|
+
import { sql } from '../db/sql.js';
|
|
3
|
+
import { UnauthorizedError } from '../errors/index.js';
|
|
4
|
+
import { resolveCookieConfig, buildSetCookieHeader, buildClearCookieHeader, parseCookieHeader } from './cookie.js';
|
|
5
|
+
export function createSessions(config) {
|
|
6
|
+
const environment = config.environment ?? 'production';
|
|
7
|
+
if (environment === 'production') {
|
|
8
|
+
validateSigningKeys(config);
|
|
9
|
+
}
|
|
10
|
+
let privateKey = null;
|
|
11
|
+
let publicKey = null;
|
|
12
|
+
const versionCache = new Map();
|
|
13
|
+
const cacheTtl = config.versionCacheTtlMs ?? 60_000;
|
|
14
|
+
async function getPrivateKey() {
|
|
15
|
+
if (!privateKey)
|
|
16
|
+
privateKey = await importPKCS8(config.signing.privateKey, config.signing.algorithm);
|
|
17
|
+
return privateKey;
|
|
18
|
+
}
|
|
19
|
+
async function getPublicKey() {
|
|
20
|
+
if (!publicKey)
|
|
21
|
+
publicKey = await importSPKI(config.signing.publicKey, config.signing.algorithm);
|
|
22
|
+
return publicKey;
|
|
23
|
+
}
|
|
24
|
+
function parseExpiry(exp) {
|
|
25
|
+
const match = exp.match(/^(\d+)([smhd])$/);
|
|
26
|
+
if (!match)
|
|
27
|
+
throw new Error(`Invalid expiry format: ${exp}`);
|
|
28
|
+
const value = parseInt(match[1], 10);
|
|
29
|
+
const unit = match[2];
|
|
30
|
+
switch (unit) {
|
|
31
|
+
case 's': return value;
|
|
32
|
+
case 'm': return value * 60;
|
|
33
|
+
case 'h': return value * 3600;
|
|
34
|
+
case 'd': return value * 86400;
|
|
35
|
+
default: return value;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
async function getOrCreateVersion(db, userId) {
|
|
39
|
+
const rows = await db.execute(sql `INSERT INTO pipework_auth_versions (user_id, version) VALUES (${userId}, 1)
|
|
40
|
+
ON CONFLICT (user_id) DO NOTHING
|
|
41
|
+
RETURNING version`);
|
|
42
|
+
if (rows.length > 0)
|
|
43
|
+
return rows[0]['version'];
|
|
44
|
+
const existing = await db.execute(sql `SELECT version FROM pipework_auth_versions WHERE user_id = ${userId}`);
|
|
45
|
+
const row = existing[0];
|
|
46
|
+
if (row === undefined)
|
|
47
|
+
return 1;
|
|
48
|
+
return row['version'];
|
|
49
|
+
}
|
|
50
|
+
async function issueTokens(db, user) {
|
|
51
|
+
const key = await getPrivateKey();
|
|
52
|
+
const version = config.versionCheck ? await getOrCreateVersion(db, user.id) : 1;
|
|
53
|
+
const expiresInSeconds = parseExpiry(config.accessToken.expiresIn);
|
|
54
|
+
const accessToken = await new SignJWT({ tid: user.tenantId, av: version, roles: user.roles })
|
|
55
|
+
.setProtectedHeader({ alg: config.signing.algorithm })
|
|
56
|
+
.setSubject(user.id)
|
|
57
|
+
.setIssuer(config.issuer)
|
|
58
|
+
.setAudience(config.audience)
|
|
59
|
+
.setIssuedAt()
|
|
60
|
+
.setExpirationTime(`${expiresInSeconds}s`)
|
|
61
|
+
.sign(key);
|
|
62
|
+
const familyId = crypto.randomUUID();
|
|
63
|
+
const refreshTokenValue = crypto.randomUUID();
|
|
64
|
+
const refreshHash = await hashToken(refreshTokenValue);
|
|
65
|
+
const refreshExpiresIn = parseExpiry(config.refreshToken.expiresIn);
|
|
66
|
+
const expiresAt = new Date(Date.now() + refreshExpiresIn * 1000);
|
|
67
|
+
await db.execute(sql `INSERT INTO pipework_refresh_tokens (user_id, tenant_id, token_hash, family_id, expires_at)
|
|
68
|
+
VALUES (${user.id}, ${user.tenantId}, ${refreshHash}, ${familyId}::uuid, ${expiresAt.toISOString()}::timestamptz)`);
|
|
69
|
+
return { accessToken, refreshToken: refreshTokenValue, expiresIn: expiresInSeconds };
|
|
70
|
+
}
|
|
71
|
+
async function refresh(db, refreshToken) {
|
|
72
|
+
const tokenHash = await hashToken(refreshToken);
|
|
73
|
+
return db.transaction(async (tx) => {
|
|
74
|
+
const rows = await tx.execute(sql `SELECT id, user_id, tenant_id, family_id, revoked_at, expires_at
|
|
75
|
+
FROM pipework_refresh_tokens
|
|
76
|
+
WHERE token_hash = ${tokenHash}
|
|
77
|
+
FOR UPDATE`);
|
|
78
|
+
if (rows.length === 0) {
|
|
79
|
+
throw new UnauthorizedError('Invalid refresh token');
|
|
80
|
+
}
|
|
81
|
+
const row = rows[0];
|
|
82
|
+
const userId = row['user_id'];
|
|
83
|
+
const tenantId = row['tenant_id'];
|
|
84
|
+
const familyId = row['family_id'];
|
|
85
|
+
const revokedAt = row['revoked_at'];
|
|
86
|
+
const expiresAt = new Date(row['expires_at']);
|
|
87
|
+
if (expiresAt < new Date()) {
|
|
88
|
+
throw new UnauthorizedError('Refresh token expired');
|
|
89
|
+
}
|
|
90
|
+
if (revokedAt !== null) {
|
|
91
|
+
if (config.refreshToken.reuseDetection) {
|
|
92
|
+
await tx.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now()
|
|
93
|
+
WHERE family_id = ${familyId}::uuid AND revoked_at IS NULL`);
|
|
94
|
+
}
|
|
95
|
+
throw new UnauthorizedError('Refresh token reuse detected — all sessions revoked');
|
|
96
|
+
}
|
|
97
|
+
if (config.refreshToken.rotateOnUse) {
|
|
98
|
+
await tx.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now() WHERE token_hash = ${tokenHash}`);
|
|
99
|
+
}
|
|
100
|
+
const roles = config.resolveRoles
|
|
101
|
+
? await config.resolveRoles(tx, userId, tenantId)
|
|
102
|
+
: undefined;
|
|
103
|
+
return issueTokens(tx, roles ? { id: userId, tenantId, roles } : { id: userId, tenantId });
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
async function revokeAll(db, userId) {
|
|
107
|
+
await db.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now()
|
|
108
|
+
WHERE user_id = ${userId} AND revoked_at IS NULL`);
|
|
109
|
+
}
|
|
110
|
+
async function bumpVersion(db, userId) {
|
|
111
|
+
await db.execute(sql `INSERT INTO pipework_auth_versions (user_id, version, updated_at)
|
|
112
|
+
VALUES (${userId}, 2, now())
|
|
113
|
+
ON CONFLICT (user_id)
|
|
114
|
+
DO UPDATE SET version = pipework_auth_versions.version + 1, updated_at = now()`);
|
|
115
|
+
versionCache.delete(userId);
|
|
116
|
+
}
|
|
117
|
+
async function verifyAccessToken(token) {
|
|
118
|
+
const key = await getPublicKey();
|
|
119
|
+
try {
|
|
120
|
+
const { payload } = await jwtVerify(token, key, {
|
|
121
|
+
algorithms: [config.signing.algorithm],
|
|
122
|
+
issuer: config.issuer,
|
|
123
|
+
audience: config.audience,
|
|
124
|
+
});
|
|
125
|
+
return {
|
|
126
|
+
sub: payload.sub,
|
|
127
|
+
tid: payload['tid'],
|
|
128
|
+
av: payload['av'],
|
|
129
|
+
roles: payload['roles'],
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
catch {
|
|
133
|
+
throw new UnauthorizedError('Invalid access token');
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
async function checkVersion(db, userId, tokenVersion) {
|
|
137
|
+
const cached = versionCache.get(userId);
|
|
138
|
+
if (cached && cached.expiresAt > Date.now()) {
|
|
139
|
+
return cached.version === tokenVersion;
|
|
140
|
+
}
|
|
141
|
+
const rows = await db.execute(sql `SELECT version FROM pipework_auth_versions WHERE user_id = ${userId}`);
|
|
142
|
+
const currentVersion = rows.length > 0 ? rows[0]['version'] : 1;
|
|
143
|
+
versionCache.set(userId, { version: currentVersion, expiresAt: Date.now() + cacheTtl });
|
|
144
|
+
return currentVersion === tokenVersion;
|
|
145
|
+
}
|
|
146
|
+
async function cleanExpiredTokens(db) {
|
|
147
|
+
const rows = await db.execute(sql `DELETE FROM pipework_refresh_tokens WHERE expires_at < now() RETURNING id`);
|
|
148
|
+
return rows.length;
|
|
149
|
+
}
|
|
150
|
+
function getCookieConfig() {
|
|
151
|
+
const cookie = config.refreshToken.cookie;
|
|
152
|
+
if (cookie === undefined) {
|
|
153
|
+
throw new Error('Cookie-based session methods require refreshToken.cookie configuration');
|
|
154
|
+
}
|
|
155
|
+
return resolveCookieConfig(cookie, config.environment ?? 'production');
|
|
156
|
+
}
|
|
157
|
+
function getRefreshMaxAge() {
|
|
158
|
+
return parseExpiry(config.refreshToken.expiresIn);
|
|
159
|
+
}
|
|
160
|
+
async function issueTokensHttp(response, db, user) {
|
|
161
|
+
const resolved = getCookieConfig();
|
|
162
|
+
const pair = await issueTokens(db, user);
|
|
163
|
+
response.header('Set-Cookie', buildSetCookieHeader(resolved, pair.refreshToken, getRefreshMaxAge()));
|
|
164
|
+
return { accessToken: pair.accessToken, expiresIn: pair.expiresIn };
|
|
165
|
+
}
|
|
166
|
+
async function refreshHttp(response, db, request) {
|
|
167
|
+
const resolved = getCookieConfig();
|
|
168
|
+
const token = parseCookieHeader(request.headers['cookie'], resolved.name);
|
|
169
|
+
if (token === undefined) {
|
|
170
|
+
throw new UnauthorizedError('Missing refresh token cookie');
|
|
171
|
+
}
|
|
172
|
+
const pair = await refresh(db, token);
|
|
173
|
+
response.header('Set-Cookie', buildSetCookieHeader(resolved, pair.refreshToken, getRefreshMaxAge()));
|
|
174
|
+
return { accessToken: pair.accessToken, expiresIn: pair.expiresIn };
|
|
175
|
+
}
|
|
176
|
+
async function revokeHttp(response, db, request) {
|
|
177
|
+
const resolved = getCookieConfig();
|
|
178
|
+
const token = parseCookieHeader(request.headers['cookie'], resolved.name);
|
|
179
|
+
if (token === undefined) {
|
|
180
|
+
throw new UnauthorizedError('Missing refresh token cookie');
|
|
181
|
+
}
|
|
182
|
+
const tokenHash = await hashToken(token);
|
|
183
|
+
await db.execute(sql `UPDATE pipework_refresh_tokens SET revoked_at = now()
|
|
184
|
+
WHERE token_hash = ${tokenHash} AND revoked_at IS NULL`);
|
|
185
|
+
response.header('Set-Cookie', buildClearCookieHeader(resolved));
|
|
186
|
+
}
|
|
187
|
+
async function revokeAllHttp(response, db, userId) {
|
|
188
|
+
const resolved = getCookieConfig();
|
|
189
|
+
await revokeAll(db, userId);
|
|
190
|
+
response.header('Set-Cookie', buildClearCookieHeader(resolved));
|
|
191
|
+
}
|
|
192
|
+
return {
|
|
193
|
+
issueTokens, refresh, revokeAll, bumpVersion, verifyAccessToken, checkVersion, cleanExpiredTokens,
|
|
194
|
+
issueTokensHttp, refreshHttp, revokeHttp, revokeAllHttp,
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
const TEST_KEY_PATTERNS = [
|
|
198
|
+
'test', 'example', 'dummy', 'placeholder', 'changeme', 'insecure', 'dev-only',
|
|
199
|
+
];
|
|
200
|
+
function validateSigningKeys(config) {
|
|
201
|
+
const problems = [];
|
|
202
|
+
const { privateKey, publicKey } = config.signing;
|
|
203
|
+
if (privateKey.length < 100) {
|
|
204
|
+
problems.push('Private key appears too short for ES256. Ensure you are using a real PKCS#8 key.');
|
|
205
|
+
}
|
|
206
|
+
if (publicKey.length < 80) {
|
|
207
|
+
problems.push('Public key appears too short for ES256. Ensure you are using a real SPKI key.');
|
|
208
|
+
}
|
|
209
|
+
const combined = (privateKey + publicKey).toLowerCase();
|
|
210
|
+
for (const pattern of TEST_KEY_PATTERNS) {
|
|
211
|
+
if (combined.includes(pattern)) {
|
|
212
|
+
problems.push(`Signing key material contains "${pattern}" — this looks like a test key.`);
|
|
213
|
+
break;
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
if (!privateKey.includes('BEGIN') || !publicKey.includes('BEGIN')) {
|
|
217
|
+
problems.push('Keys should be PEM-encoded (BEGIN PRIVATE KEY / BEGIN PUBLIC KEY).');
|
|
218
|
+
}
|
|
219
|
+
if (problems.length > 0) {
|
|
220
|
+
throw new Error(`[pipework] Session signing keys are not suitable for production:\n\n${problems.map(p => ` - ${p}`).join('\n')}\n\n` +
|
|
221
|
+
' Generate production keys with: openssl ecparam -genkey -name prime256v1 -noout | openssl pkcs8 -topk8 -nocrypt\n');
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
async function hashToken(token) {
|
|
225
|
+
const encoder = new TextEncoder();
|
|
226
|
+
const data = encoder.encode(token);
|
|
227
|
+
const hash = await crypto.subtle.digest('SHA-256', data);
|
|
228
|
+
return Buffer.from(hash).toString('hex');
|
|
229
|
+
}
|
|
230
|
+
//# sourceMappingURL=sessions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.js","sourceRoot":"","sources":["../../src/auth/sessions.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface AuthStrategy<TAuth> {
|
|
2
|
+
readonly name: string;
|
|
3
|
+
extract(request: AuthRequest): Promise<TAuth | null>;
|
|
4
|
+
verify(extracted: TAuth): Promise<TAuth>;
|
|
5
|
+
}
|
|
6
|
+
export interface AuthRequest {
|
|
7
|
+
readonly headers: Readonly<Record<string, string | undefined>>;
|
|
8
|
+
readonly cookies: Readonly<Record<string, string | undefined>>;
|
|
9
|
+
}
|
|
10
|
+
export interface BaseAuth {
|
|
11
|
+
readonly userId: string;
|
|
12
|
+
readonly tenantId: string;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/auth/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY,CAAC,KAAK;IACjC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,OAAO,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,CAAA;IACpD,MAAM,CAAC,SAAS,EAAE,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAA;CACzC;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAA;IAC9D,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC,CAAA;CAC/D;AAED,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAA;CAC1B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/auth/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ResourceOperations } from '../fixture/types.js';
|
|
2
|
+
import type { AuditedBehaviorConfig } from './types.js';
|
|
3
|
+
import type { Audit } from '../audit/types.js';
|
|
4
|
+
export declare function applyAudited<TAuth>(ops: ResourceOperations<TAuth>, config: AuditedBehaviorConfig | Audit, resourceName: string): ResourceOperations<TAuth>;
|
|
5
|
+
//# sourceMappingURL=audited.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audited.d.ts","sourceRoot":"","sources":["../../src/behavior/audited.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAc,MAAM,qBAAqB,CAAA;AACzE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAA;AACvD,OAAO,KAAK,EAAE,KAAK,EAAoB,MAAM,mBAAmB,CAAA;AAEhE,wBAAgB,YAAY,CAAC,KAAK,EAChC,GAAG,EAAE,kBAAkB,CAAC,KAAK,CAAC,EAC9B,MAAM,EAAE,qBAAqB,GAAG,KAAK,EACrC,YAAY,EAAE,MAAM,GACnB,kBAAkB,CAAC,KAAK,CAAC,CAkE3B"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
export function applyAudited(ops, config, resourceName) {
|
|
2
|
+
const audit = 'emit' in config ? config : config.audit;
|
|
3
|
+
const isConfig = !('emit' in config);
|
|
4
|
+
const entityType = isConfig && config.entityType !== undefined
|
|
5
|
+
? config.entityType
|
|
6
|
+
: singularize(resourceName);
|
|
7
|
+
const prefix = isConfig && config.actionPrefix !== undefined
|
|
8
|
+
? config.actionPrefix
|
|
9
|
+
: entityType;
|
|
10
|
+
const result = { ...ops };
|
|
11
|
+
if (ops.create !== undefined) {
|
|
12
|
+
const original = ops.create;
|
|
13
|
+
result['create'] = {
|
|
14
|
+
input: original.input,
|
|
15
|
+
handler: async (db, auth, tenant, input) => {
|
|
16
|
+
const created = await original.handler(db, auth, tenant, input);
|
|
17
|
+
const opts = {
|
|
18
|
+
actionType: `${prefix}.created`,
|
|
19
|
+
entityType,
|
|
20
|
+
entityId: extractEntityId(created),
|
|
21
|
+
after: created,
|
|
22
|
+
};
|
|
23
|
+
await audit.emit(opts);
|
|
24
|
+
return created;
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
if (ops.update !== undefined) {
|
|
29
|
+
const original = ops.update;
|
|
30
|
+
result['update'] = {
|
|
31
|
+
input: original.input,
|
|
32
|
+
handler: async (db, auth, tenant, id, input) => {
|
|
33
|
+
const before = ops.get !== undefined ? await ops.get(db, auth, tenant, id) : null;
|
|
34
|
+
const updated = await original.handler(db, auth, tenant, id, input);
|
|
35
|
+
const opts = {
|
|
36
|
+
actionType: `${prefix}.updated`,
|
|
37
|
+
entityType,
|
|
38
|
+
entityId: id,
|
|
39
|
+
before: before ?? undefined,
|
|
40
|
+
after: updated,
|
|
41
|
+
};
|
|
42
|
+
await audit.emit(opts);
|
|
43
|
+
return updated;
|
|
44
|
+
},
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
if (ops.delete !== undefined) {
|
|
48
|
+
const original = ops.delete;
|
|
49
|
+
result['delete'] = async (db, auth, tenant, id) => {
|
|
50
|
+
const before = ops.get !== undefined ? await ops.get(db, auth, tenant, id) : null;
|
|
51
|
+
await original(db, auth, tenant, id);
|
|
52
|
+
const opts = {
|
|
53
|
+
actionType: `${prefix}.deleted`,
|
|
54
|
+
entityType,
|
|
55
|
+
entityId: id,
|
|
56
|
+
before: before ?? undefined,
|
|
57
|
+
};
|
|
58
|
+
await audit.emit(opts);
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
return result;
|
|
62
|
+
}
|
|
63
|
+
function extractEntityId(result) {
|
|
64
|
+
if (result !== null && typeof result === 'object' && 'id' in result) {
|
|
65
|
+
return String(result.id);
|
|
66
|
+
}
|
|
67
|
+
return 'unknown';
|
|
68
|
+
}
|
|
69
|
+
function singularize(s) {
|
|
70
|
+
if (s.endsWith('ies'))
|
|
71
|
+
return s.slice(0, -3) + 'y';
|
|
72
|
+
if (s.endsWith('ses') || s.endsWith('xes'))
|
|
73
|
+
return s.slice(0, -2);
|
|
74
|
+
if (s.endsWith('s') && !s.endsWith('ss'))
|
|
75
|
+
return s.slice(0, -1);
|
|
76
|
+
return s;
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=audited.js.map
|