semola 0.5.3 → 0.5.4
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/dist/index-BhGNDjPq.d.mts +13 -0
- package/dist/index-DxSbeGP-.d.cts +13 -0
- package/dist/lib/api/index.cjs +522 -4
- package/dist/lib/api/index.d.cts +270 -4
- package/dist/lib/api/index.d.mts +270 -4
- package/dist/lib/api/index.mjs +520 -2
- package/dist/lib/cache/index.d.cts +16 -4
- package/dist/lib/cache/index.d.mts +16 -4
- package/dist/lib/cache/index.mjs +0 -2
- package/dist/lib/cron/index.cjs +734 -12
- package/dist/lib/cron/index.d.cts +145 -3
- package/dist/lib/cron/index.d.mts +145 -3
- package/dist/lib/cron/index.mjs +725 -3
- package/dist/lib/errors/index.d.cts +2 -13
- package/dist/lib/errors/index.d.mts +2 -13
- package/dist/lib/errors/index.mjs +0 -2
- package/dist/lib/i18n/index.d.cts +12 -4
- package/dist/lib/i18n/index.d.mts +12 -4
- package/dist/lib/i18n/index.mjs +0 -2
- package/dist/lib/logging/index.cjs +386 -17
- package/dist/lib/logging/index.d.cts +107 -6
- package/dist/lib/logging/index.d.mts +107 -6
- package/dist/lib/logging/index.mjs +373 -4
- package/dist/lib/policy/index.cjs +206 -20
- package/dist/lib/policy/index.d.cts +61 -5
- package/dist/lib/policy/index.d.mts +61 -5
- package/dist/lib/policy/index.mjs +187 -3
- package/dist/lib/prompts/index.cjs +374 -14
- package/dist/lib/prompts/index.d.cts +69 -4
- package/dist/lib/prompts/index.d.mts +69 -4
- package/dist/lib/prompts/index.mjs +362 -4
- package/dist/lib/pubsub/index.d.cts +9 -4
- package/dist/lib/pubsub/index.d.mts +9 -4
- package/dist/lib/pubsub/index.mjs +0 -2
- package/dist/lib/queue/index.d.cts +48 -6
- package/dist/lib/queue/index.d.mts +48 -6
- package/dist/lib/queue/index.mjs +0 -2
- package/dist/lib/workflow/index.d.cts +82 -4
- package/dist/lib/workflow/index.d.mts +82 -4
- package/dist/lib/workflow/index.mjs +0 -2
- package/package.json +1 -1
- package/dist/api/core/index.cjs +0 -206
- package/dist/api/core/index.d.cts +0 -21
- package/dist/api/core/index.d.cts.map +0 -1
- package/dist/api/core/index.d.mts +0 -21
- package/dist/api/core/index.d.mts.map +0 -1
- package/dist/api/core/index.mjs +0 -208
- package/dist/api/core/index.mjs.map +0 -1
- package/dist/api/core/types.d.cts +0 -107
- package/dist/api/core/types.d.cts.map +0 -1
- package/dist/api/core/types.d.mts +0 -107
- package/dist/api/core/types.d.mts.map +0 -1
- package/dist/api/middleware/index.cjs +0 -8
- package/dist/api/middleware/index.d.cts +0 -11
- package/dist/api/middleware/index.d.cts.map +0 -1
- package/dist/api/middleware/index.d.mts +0 -11
- package/dist/api/middleware/index.d.mts.map +0 -1
- package/dist/api/middleware/index.mjs +0 -10
- package/dist/api/middleware/index.mjs.map +0 -1
- package/dist/api/middleware/types.d.cts +0 -16
- package/dist/api/middleware/types.d.cts.map +0 -1
- package/dist/api/middleware/types.d.mts +0 -16
- package/dist/api/middleware/types.d.mts.map +0 -1
- package/dist/api/openapi/index.cjs +0 -254
- package/dist/api/openapi/index.mjs +0 -256
- package/dist/api/openapi/index.mjs.map +0 -1
- package/dist/api/openapi/types.d.cts +0 -60
- package/dist/api/openapi/types.d.cts.map +0 -1
- package/dist/api/openapi/types.d.mts +0 -60
- package/dist/api/openapi/types.d.mts.map +0 -1
- package/dist/api/validation/index.cjs +0 -64
- package/dist/api/validation/index.mjs +0 -61
- package/dist/api/validation/index.mjs.map +0 -1
- package/dist/cache/types.d.cts +0 -17
- package/dist/cache/types.d.cts.map +0 -1
- package/dist/cache/types.d.mts +0 -17
- package/dist/cache/types.d.mts.map +0 -1
- package/dist/cron/builder/index.cjs +0 -166
- package/dist/cron/builder/index.d.cts +0 -28
- package/dist/cron/builder/index.d.cts.map +0 -1
- package/dist/cron/builder/index.d.mts +0 -28
- package/dist/cron/builder/index.d.mts.map +0 -1
- package/dist/cron/builder/index.mjs +0 -163
- package/dist/cron/builder/index.mjs.map +0 -1
- package/dist/cron/builder/types.cjs +0 -27
- package/dist/cron/builder/types.d.cts +0 -79
- package/dist/cron/builder/types.d.cts.map +0 -1
- package/dist/cron/builder/types.d.mts +0 -79
- package/dist/cron/builder/types.d.mts.map +0 -1
- package/dist/cron/builder/types.mjs +0 -28
- package/dist/cron/builder/types.mjs.map +0 -1
- package/dist/cron/core/index.cjs +0 -308
- package/dist/cron/core/index.d.cts +0 -39
- package/dist/cron/core/index.d.cts.map +0 -1
- package/dist/cron/core/index.d.mts +0 -39
- package/dist/cron/core/index.d.mts.map +0 -1
- package/dist/cron/core/index.mjs +0 -310
- package/dist/cron/core/index.mjs.map +0 -1
- package/dist/cron/core/scanner.cjs +0 -237
- package/dist/cron/core/scanner.mjs +0 -238
- package/dist/cron/core/scanner.mjs.map +0 -1
- package/dist/cron/core/types.d.cts +0 -11
- package/dist/cron/core/types.d.cts.map +0 -1
- package/dist/cron/core/types.d.mts +0 -11
- package/dist/cron/core/types.d.mts.map +0 -1
- package/dist/errors/types.d.cts +0 -5
- package/dist/errors/types.d.cts.map +0 -1
- package/dist/errors/types.d.mts +0 -5
- package/dist/errors/types.d.mts.map +0 -1
- package/dist/i18n/types.d.cts +0 -13
- package/dist/i18n/types.d.cts.map +0 -1
- package/dist/i18n/types.d.mts +0 -13
- package/dist/i18n/types.d.mts.map +0 -1
- package/dist/lib/cache/index.d.cts.map +0 -1
- package/dist/lib/cache/index.d.mts.map +0 -1
- package/dist/lib/cache/index.mjs.map +0 -1
- package/dist/lib/errors/index.d.cts.map +0 -1
- package/dist/lib/errors/index.d.mts.map +0 -1
- package/dist/lib/errors/index.mjs.map +0 -1
- package/dist/lib/i18n/index.d.cts.map +0 -1
- package/dist/lib/i18n/index.d.mts.map +0 -1
- package/dist/lib/i18n/index.mjs.map +0 -1
- package/dist/lib/orm/index.cjs +0 -20
- package/dist/lib/orm/index.d.cts +0 -7
- package/dist/lib/orm/index.d.mts +0 -7
- package/dist/lib/orm/index.mjs +0 -6
- package/dist/lib/policy/index.d.cts.map +0 -1
- package/dist/lib/policy/index.d.mts.map +0 -1
- package/dist/lib/policy/index.mjs.map +0 -1
- package/dist/lib/prompts/index.d.cts.map +0 -1
- package/dist/lib/prompts/index.d.mts.map +0 -1
- package/dist/lib/prompts/index.mjs.map +0 -1
- package/dist/lib/pubsub/index.d.cts.map +0 -1
- package/dist/lib/pubsub/index.d.mts.map +0 -1
- package/dist/lib/pubsub/index.mjs.map +0 -1
- package/dist/lib/queue/index.d.cts.map +0 -1
- package/dist/lib/queue/index.d.mts.map +0 -1
- package/dist/lib/queue/index.mjs.map +0 -1
- package/dist/lib/workflow/index.d.cts.map +0 -1
- package/dist/lib/workflow/index.d.mts.map +0 -1
- package/dist/lib/workflow/index.mjs.map +0 -1
- package/dist/logging/core/index.cjs +0 -99
- package/dist/logging/core/index.d.cts +0 -26
- package/dist/logging/core/index.d.cts.map +0 -1
- package/dist/logging/core/index.d.mts +0 -26
- package/dist/logging/core/index.d.mts.map +0 -1
- package/dist/logging/core/index.mjs +0 -99
- package/dist/logging/core/index.mjs.map +0 -1
- package/dist/logging/core/types.cjs +0 -10
- package/dist/logging/core/types.d.cts +0 -22
- package/dist/logging/core/types.d.cts.map +0 -1
- package/dist/logging/core/types.d.mts +0 -22
- package/dist/logging/core/types.d.mts.map +0 -1
- package/dist/logging/core/types.mjs +0 -12
- package/dist/logging/core/types.mjs.map +0 -1
- package/dist/logging/formatter/index.cjs +0 -119
- package/dist/logging/formatter/index.d.cts +0 -27
- package/dist/logging/formatter/index.d.cts.map +0 -1
- package/dist/logging/formatter/index.d.mts +0 -27
- package/dist/logging/formatter/index.d.mts.map +0 -1
- package/dist/logging/formatter/index.mjs +0 -115
- package/dist/logging/formatter/index.mjs.map +0 -1
- package/dist/logging/formatter/types.d.cts +0 -5
- package/dist/logging/formatter/types.d.cts.map +0 -1
- package/dist/logging/formatter/types.d.mts +0 -5
- package/dist/logging/formatter/types.d.mts.map +0 -1
- package/dist/logging/provider/index.cjs +0 -165
- package/dist/logging/provider/index.d.cts +0 -28
- package/dist/logging/provider/index.d.cts.map +0 -1
- package/dist/logging/provider/index.d.mts +0 -28
- package/dist/logging/provider/index.d.mts.map +0 -1
- package/dist/logging/provider/index.mjs +0 -165
- package/dist/logging/provider/index.mjs.map +0 -1
- package/dist/logging/provider/types.d.cts +0 -23
- package/dist/logging/provider/types.d.cts.map +0 -1
- package/dist/logging/provider/types.d.mts +0 -23
- package/dist/logging/provider/types.d.mts.map +0 -1
- package/dist/node_modules/@standard-schema/spec/dist/index.d.cts +0 -80
- package/dist/node_modules/@standard-schema/spec/dist/index.d.cts.map +0 -1
- package/dist/node_modules/@standard-schema/spec/dist/index.d.mts +0 -80
- package/dist/node_modules/@standard-schema/spec/dist/index.d.mts.map +0 -1
- package/dist/orm/column.cjs +0 -137
- package/dist/orm/column.d.cts +0 -121
- package/dist/orm/column.d.cts.map +0 -1
- package/dist/orm/column.d.mts +0 -121
- package/dist/orm/column.d.mts.map +0 -1
- package/dist/orm/column.mjs +0 -132
- package/dist/orm/column.mjs.map +0 -1
- package/dist/orm/dialect/index.cjs +0 -14
- package/dist/orm/dialect/index.mjs +0 -16
- package/dist/orm/dialect/index.mjs.map +0 -1
- package/dist/orm/dialect/mysql.cjs +0 -31
- package/dist/orm/dialect/mysql.mjs +0 -33
- package/dist/orm/dialect/mysql.mjs.map +0 -1
- package/dist/orm/dialect/postgres.cjs +0 -23
- package/dist/orm/dialect/postgres.mjs +0 -25
- package/dist/orm/dialect/postgres.mjs.map +0 -1
- package/dist/orm/dialect/sqlite.cjs +0 -31
- package/dist/orm/dialect/sqlite.mjs +0 -33
- package/dist/orm/dialect/sqlite.mjs.map +0 -1
- package/dist/orm/dialect/utils.cjs +0 -8
- package/dist/orm/dialect/utils.mjs +0 -10
- package/dist/orm/dialect/utils.mjs.map +0 -1
- package/dist/orm/internal/table-columns.cjs +0 -31
- package/dist/orm/internal/table-columns.mjs +0 -32
- package/dist/orm/internal/table-columns.mjs.map +0 -1
- package/dist/orm/internal/table-lookup.cjs +0 -35
- package/dist/orm/internal/table-lookup.mjs +0 -35
- package/dist/orm/internal/table-lookup.mjs.map +0 -1
- package/dist/orm/internal/table-relations.cjs +0 -28
- package/dist/orm/internal/table-relations.mjs +0 -29
- package/dist/orm/internal/table-relations.mjs.map +0 -1
- package/dist/orm/migration/config.cjs +0 -7
- package/dist/orm/migration/config.d.cts +0 -7
- package/dist/orm/migration/config.d.cts.map +0 -1
- package/dist/orm/migration/config.d.mts +0 -7
- package/dist/orm/migration/config.d.mts.map +0 -1
- package/dist/orm/migration/config.mjs +0 -8
- package/dist/orm/migration/config.mjs.map +0 -1
- package/dist/orm/migration/types.d.cts +0 -20
- package/dist/orm/migration/types.d.cts.map +0 -1
- package/dist/orm/migration/types.d.mts +0 -20
- package/dist/orm/migration/types.d.mts.map +0 -1
- package/dist/orm/orm.cjs +0 -41
- package/dist/orm/orm.d.cts +0 -18
- package/dist/orm/orm.d.cts.map +0 -1
- package/dist/orm/orm.d.mts +0 -18
- package/dist/orm/orm.d.mts.map +0 -1
- package/dist/orm/orm.mjs +0 -43
- package/dist/orm/orm.mjs.map +0 -1
- package/dist/orm/relation.cjs +0 -18
- package/dist/orm/relation.d.cts +0 -8
- package/dist/orm/relation.d.cts.map +0 -1
- package/dist/orm/relation.d.mts +0 -8
- package/dist/orm/relation.d.mts.map +0 -1
- package/dist/orm/relation.mjs +0 -19
- package/dist/orm/relation.mjs.map +0 -1
- package/dist/orm/runtime/builders/mutations.cjs +0 -29
- package/dist/orm/runtime/builders/mutations.mjs +0 -28
- package/dist/orm/runtime/builders/mutations.mjs.map +0 -1
- package/dist/orm/runtime/builders/select.cjs +0 -18
- package/dist/orm/runtime/builders/select.mjs +0 -19
- package/dist/orm/runtime/builders/select.mjs.map +0 -1
- package/dist/orm/runtime/client.cjs +0 -90
- package/dist/orm/runtime/client.mjs +0 -92
- package/dist/orm/runtime/client.mjs.map +0 -1
- package/dist/orm/runtime/context.cjs +0 -49
- package/dist/orm/runtime/context.mjs +0 -51
- package/dist/orm/runtime/context.mjs.map +0 -1
- package/dist/orm/runtime/dialect/index.cjs +0 -11
- package/dist/orm/runtime/dialect/index.mjs +0 -13
- package/dist/orm/runtime/dialect/index.mjs.map +0 -1
- package/dist/orm/runtime/dialect/mysql.cjs +0 -95
- package/dist/orm/runtime/dialect/mysql.mjs +0 -97
- package/dist/orm/runtime/dialect/mysql.mjs.map +0 -1
- package/dist/orm/runtime/dialect/postgres.cjs +0 -51
- package/dist/orm/runtime/dialect/postgres.mjs +0 -53
- package/dist/orm/runtime/dialect/postgres.mjs.map +0 -1
- package/dist/orm/runtime/dialect/sqlite.cjs +0 -4
- package/dist/orm/runtime/dialect/sqlite.mjs +0 -7
- package/dist/orm/runtime/dialect/sqlite.mjs.map +0 -1
- package/dist/orm/runtime/errors.cjs +0 -19
- package/dist/orm/runtime/errors.mjs +0 -21
- package/dist/orm/runtime/errors.mjs.map +0 -1
- package/dist/orm/runtime/hydrate/many.cjs +0 -46
- package/dist/orm/runtime/hydrate/many.mjs +0 -48
- package/dist/orm/runtime/hydrate/many.mjs.map +0 -1
- package/dist/orm/runtime/hydrate/one.cjs +0 -38
- package/dist/orm/runtime/hydrate/one.mjs +0 -40
- package/dist/orm/runtime/hydrate/one.mjs.map +0 -1
- package/dist/orm/runtime/hydrate.cjs +0 -49
- package/dist/orm/runtime/hydrate.mjs +0 -51
- package/dist/orm/runtime/hydrate.mjs.map +0 -1
- package/dist/orm/runtime/rows.cjs +0 -30
- package/dist/orm/runtime/rows.mjs +0 -31
- package/dist/orm/runtime/rows.mjs.map +0 -1
- package/dist/orm/runtime/utils.cjs +0 -27
- package/dist/orm/runtime/utils.mjs +0 -27
- package/dist/orm/runtime/utils.mjs.map +0 -1
- package/dist/orm/sql/parse-array.cjs +0 -64
- package/dist/orm/sql/parse-array.mjs +0 -66
- package/dist/orm/sql/parse-array.mjs.map +0 -1
- package/dist/orm/sql/plan/select.cjs +0 -36
- package/dist/orm/sql/plan/select.mjs +0 -38
- package/dist/orm/sql/plan/select.mjs.map +0 -1
- package/dist/orm/sql/plan/where/operators.cjs +0 -95
- package/dist/orm/sql/plan/where/operators.mjs +0 -97
- package/dist/orm/sql/plan/where/operators.mjs.map +0 -1
- package/dist/orm/sql/plan/where.cjs +0 -59
- package/dist/orm/sql/plan/where.mjs +0 -61
- package/dist/orm/sql/plan/where.mjs.map +0 -1
- package/dist/orm/sql/serialize/clauses.cjs +0 -36
- package/dist/orm/sql/serialize/clauses.mjs +0 -37
- package/dist/orm/sql/serialize/clauses.mjs.map +0 -1
- package/dist/orm/sql/serialize/joins.cjs +0 -31
- package/dist/orm/sql/serialize/joins.mjs +0 -33
- package/dist/orm/sql/serialize/joins.mjs.map +0 -1
- package/dist/orm/sql/serialize/values.cjs +0 -30
- package/dist/orm/sql/serialize/values.mjs +0 -32
- package/dist/orm/sql/serialize/values.mjs.map +0 -1
- package/dist/orm/sql/serialize/where/predicate.cjs +0 -73
- package/dist/orm/sql/serialize/where/predicate.mjs +0 -75
- package/dist/orm/sql/serialize/where/predicate.mjs.map +0 -1
- package/dist/orm/sql/serialize/where/tree.cjs +0 -26
- package/dist/orm/sql/serialize/where/tree.mjs +0 -28
- package/dist/orm/sql/serialize/where/tree.mjs.map +0 -1
- package/dist/orm/sql/serialize/where.cjs +0 -10
- package/dist/orm/sql/serialize/where.mjs +0 -12
- package/dist/orm/sql/serialize/where.mjs.map +0 -1
- package/dist/orm/sql/serialize.cjs +0 -24
- package/dist/orm/sql/serialize.mjs +0 -25
- package/dist/orm/sql/serialize.mjs.map +0 -1
- package/dist/orm/table.cjs +0 -12
- package/dist/orm/table.d.cts +0 -12
- package/dist/orm/table.d.cts.map +0 -1
- package/dist/orm/table.d.mts +0 -12
- package/dist/orm/table.d.mts.map +0 -1
- package/dist/orm/table.mjs +0 -14
- package/dist/orm/table.mjs.map +0 -1
- package/dist/orm/types.d.cts +0 -183
- package/dist/orm/types.d.cts.map +0 -1
- package/dist/orm/types.d.mts +0 -183
- package/dist/orm/types.d.mts.map +0 -1
- package/dist/policy/helpers.cjs +0 -206
- package/dist/policy/helpers.d.cts +0 -50
- package/dist/policy/helpers.d.cts.map +0 -1
- package/dist/policy/helpers.d.mts +0 -50
- package/dist/policy/helpers.d.mts.map +0 -1
- package/dist/policy/helpers.mjs +0 -190
- package/dist/policy/helpers.mjs.map +0 -1
- package/dist/policy/types.d.cts +0 -16
- package/dist/policy/types.d.cts.map +0 -1
- package/dist/policy/types.d.mts +0 -16
- package/dist/policy/types.d.mts.map +0 -1
- package/dist/prompts/core/keys.cjs +0 -165
- package/dist/prompts/core/keys.mjs +0 -167
- package/dist/prompts/core/keys.mjs.map +0 -1
- package/dist/prompts/core/runtime.cjs +0 -104
- package/dist/prompts/core/runtime.mjs +0 -106
- package/dist/prompts/core/runtime.mjs.map +0 -1
- package/dist/prompts/core/session.cjs +0 -98
- package/dist/prompts/core/session.mjs +0 -100
- package/dist/prompts/core/session.mjs.map +0 -1
- package/dist/prompts/core/types.d.cts +0 -21
- package/dist/prompts/core/types.d.cts.map +0 -1
- package/dist/prompts/core/types.d.mts +0 -21
- package/dist/prompts/core/types.d.mts.map +0 -1
- package/dist/prompts/types.d.cts +0 -52
- package/dist/prompts/types.d.cts.map +0 -1
- package/dist/prompts/types.d.mts +0 -52
- package/dist/prompts/types.d.mts.map +0 -1
- package/dist/pubsub/types.d.cts +0 -10
- package/dist/pubsub/types.d.cts.map +0 -1
- package/dist/pubsub/types.d.mts +0 -10
- package/dist/pubsub/types.d.mts.map +0 -1
- package/dist/queue/types.d.cts +0 -47
- package/dist/queue/types.d.cts.map +0 -1
- package/dist/queue/types.d.mts +0 -47
- package/dist/queue/types.d.mts.map +0 -1
- package/dist/workflow/types.d.cts +0 -83
- package/dist/workflow/types.d.cts.map +0 -1
- package/dist/workflow/types.d.mts +0 -83
- package/dist/workflow/types.d.mts.map +0 -1
|
@@ -1,7 +1,85 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
//#region src/lib/workflow/types.d.ts
|
|
2
|
+
type WorkflowStatus = "pending" | "running" | "completed" | "failed" | "cancelled";
|
|
3
|
+
type WorkflowErrorType = "WorkflowError" | "WorkflowNotFoundError" | "WorkflowStateError" | "WorkflowSerializationError" | "WorkflowLockError" | "WorkflowExecutionError" | "WorkflowCancelledError";
|
|
4
|
+
type WorkflowError = {
|
|
5
|
+
type: WorkflowErrorType;
|
|
6
|
+
message: string;
|
|
7
|
+
};
|
|
8
|
+
type StepSnapshot = {
|
|
9
|
+
name: string;
|
|
10
|
+
completedAt: number;
|
|
11
|
+
};
|
|
12
|
+
type WorkflowExecution<TInput, TResult> = {
|
|
13
|
+
id: string;
|
|
14
|
+
name: string;
|
|
15
|
+
status: WorkflowStatus;
|
|
16
|
+
input: TInput;
|
|
17
|
+
result: TResult | null;
|
|
18
|
+
error: string | null;
|
|
19
|
+
createdAt: number;
|
|
20
|
+
updatedAt: number;
|
|
21
|
+
completedAt: number | null;
|
|
22
|
+
failedAt: number | null;
|
|
23
|
+
cancelledAt: number | null;
|
|
24
|
+
steps: StepSnapshot[];
|
|
25
|
+
};
|
|
26
|
+
type StepHandler<TInput, TStep> = (input: TInput, signal: AbortSignal) => TStep | Promise<TStep>;
|
|
27
|
+
type WorkflowHandlerContext<TInput> = {
|
|
28
|
+
input: TInput;
|
|
29
|
+
executionId: string;
|
|
30
|
+
signal: AbortSignal;
|
|
31
|
+
step: <TStep>(name: string, handler: StepHandler<TInput, TStep>) => Promise<TStep>;
|
|
32
|
+
};
|
|
33
|
+
type SerializeValue<T> = (value: T) => string;
|
|
34
|
+
type DeserializeValue<T> = (raw: string) => T;
|
|
35
|
+
type WorkflowOptions<TInput, TResult> = {
|
|
36
|
+
name: string;
|
|
37
|
+
redis: Bun.RedisClient;
|
|
38
|
+
handler: (context: WorkflowHandlerContext<TInput>) => TResult | Promise<TResult>;
|
|
39
|
+
lockTTL?: number;
|
|
40
|
+
serializeInput?: SerializeValue<TInput>;
|
|
41
|
+
deserializeInput?: DeserializeValue<TInput>;
|
|
42
|
+
serializeResult?: SerializeValue<TResult>;
|
|
43
|
+
deserializeResult?: DeserializeValue<TResult>;
|
|
44
|
+
serializeStepOutput?: SerializeValue<unknown>;
|
|
45
|
+
deserializeStepOutput?: DeserializeValue<unknown>;
|
|
46
|
+
};
|
|
47
|
+
type WorkflowStartOptions = {
|
|
48
|
+
executionId?: string;
|
|
49
|
+
};
|
|
50
|
+
type WorkflowStartResult = {
|
|
51
|
+
executionId: string;
|
|
52
|
+
status: WorkflowStatus;
|
|
53
|
+
};
|
|
54
|
+
type WorkflowCancelResult = {
|
|
55
|
+
status: WorkflowStatus;
|
|
56
|
+
executionId: string;
|
|
57
|
+
updatedAt: number;
|
|
58
|
+
cancelledAt: number;
|
|
59
|
+
createdAt: number;
|
|
60
|
+
};
|
|
61
|
+
type WorkflowMeta = {
|
|
62
|
+
status: string;
|
|
63
|
+
input: string;
|
|
64
|
+
result: string;
|
|
65
|
+
error: string;
|
|
66
|
+
createdAt: string;
|
|
67
|
+
updatedAt: string;
|
|
68
|
+
completedAt: string;
|
|
69
|
+
failedAt: string;
|
|
70
|
+
cancelledAt: string;
|
|
71
|
+
steps: string;
|
|
72
|
+
};
|
|
73
|
+
type WorkflowMetaField = keyof WorkflowMeta;
|
|
74
|
+
type Workflow<TInput, TResult> = {
|
|
75
|
+
start: (input: TInput, options?: WorkflowStartOptions) => Promise<readonly [WorkflowError | null, WorkflowStartResult | null]>;
|
|
76
|
+
run: (input: TInput, options?: WorkflowStartOptions) => Promise<readonly [WorkflowError | null, TResult | null]>;
|
|
77
|
+
resume: (executionId: string) => Promise<readonly [WorkflowError | null, WorkflowStartResult | null]>;
|
|
78
|
+
get: (executionId: string) => Promise<readonly [WorkflowError | null, WorkflowExecution<TInput, TResult> | null]>;
|
|
79
|
+
cancel: (executionId: string) => Promise<readonly [WorkflowError | null, WorkflowCancelResult | null]>;
|
|
80
|
+
};
|
|
81
|
+
//#endregion
|
|
3
82
|
//#region src/lib/workflow/index.d.ts
|
|
4
83
|
declare const defineWorkflow: <TInput, TResult = void>(options: WorkflowOptions<TInput, TResult>) => Workflow<TInput, TResult>;
|
|
5
84
|
//#endregion
|
|
6
|
-
export { type StepHandler, type Workflow, type WorkflowError, type WorkflowExecution, type WorkflowHandlerContext, type WorkflowMeta, type WorkflowMetaField, type WorkflowOptions, type WorkflowStartOptions, type WorkflowStartResult, type WorkflowStatus, defineWorkflow };
|
|
7
|
-
//# sourceMappingURL=index.d.mts.map
|
|
85
|
+
export { type StepHandler, type Workflow, type WorkflowError, type WorkflowExecution, type WorkflowHandlerContext, type WorkflowMeta, type WorkflowMetaField, type WorkflowOptions, type WorkflowStartOptions, type WorkflowStartResult, type WorkflowStatus, defineWorkflow };
|
package/package.json
CHANGED
package/dist/api/core/index.cjs
DELETED
|
@@ -1,206 +0,0 @@
|
|
|
1
|
-
const require_lib_errors_index = require("../../lib/errors/index.cjs");
|
|
2
|
-
const require_index = require("../openapi/index.cjs");
|
|
3
|
-
const require_index$1 = require("../validation/index.cjs");
|
|
4
|
-
//#region src/lib/api/core/index.ts
|
|
5
|
-
const defaultValidated = Object.freeze({
|
|
6
|
-
body: void 0,
|
|
7
|
-
query: void 0,
|
|
8
|
-
headers: void 0,
|
|
9
|
-
cookies: void 0,
|
|
10
|
-
params: void 0
|
|
11
|
-
});
|
|
12
|
-
const responseHelpers = {
|
|
13
|
-
json: (status, data) => Response.json(data, { status }),
|
|
14
|
-
text: (status, text) => new Response(text, { status }),
|
|
15
|
-
html: (status, html) => new Response(html, {
|
|
16
|
-
status,
|
|
17
|
-
headers: { "Content-Type": "text/html" }
|
|
18
|
-
}),
|
|
19
|
-
redirect: (status, url) => Response.redirect(url, status)
|
|
20
|
-
};
|
|
21
|
-
const noopGet = () => void 0;
|
|
22
|
-
const stripTrailingSlash = (path) => {
|
|
23
|
-
if (path !== "/" && path.endsWith("/")) return path.slice(0, -1);
|
|
24
|
-
return path;
|
|
25
|
-
};
|
|
26
|
-
const hasSchemas = (schema) => schema && (schema.body || schema.query || schema.headers || schema.cookies || schema.params);
|
|
27
|
-
const needsBodyCache = (schema) => schema?.body !== void 0;
|
|
28
|
-
const shouldCreateBodyCache = (hasMiddlewares, allMiddlewares, request) => {
|
|
29
|
-
if (needsBodyCache(request)) return true;
|
|
30
|
-
if (!hasMiddlewares) return false;
|
|
31
|
-
return allMiddlewares.some((mw) => needsBodyCache(mw.options.request));
|
|
32
|
-
};
|
|
33
|
-
const resolveValidation = (v) => {
|
|
34
|
-
if (v === void 0 || v === true) return {
|
|
35
|
-
input: true,
|
|
36
|
-
output: true
|
|
37
|
-
};
|
|
38
|
-
if (v === false) return {
|
|
39
|
-
input: false,
|
|
40
|
-
output: false
|
|
41
|
-
};
|
|
42
|
-
return {
|
|
43
|
-
input: v.input !== false,
|
|
44
|
-
output: v.output !== false
|
|
45
|
-
};
|
|
46
|
-
};
|
|
47
|
-
var Api = class {
|
|
48
|
-
options;
|
|
49
|
-
routes = [];
|
|
50
|
-
constructor(options = {}) {
|
|
51
|
-
this.options = options;
|
|
52
|
-
}
|
|
53
|
-
getFullPath(path) {
|
|
54
|
-
const normalizedPath = stripTrailingSlash(path) || "/";
|
|
55
|
-
if (!this.options.prefix) return normalizedPath;
|
|
56
|
-
const normalizedPrefix = stripTrailingSlash(this.options.prefix);
|
|
57
|
-
if (normalizedPrefix === "/") return normalizedPath;
|
|
58
|
-
if (normalizedPath === "/") return normalizedPrefix;
|
|
59
|
-
return normalizedPrefix + normalizedPath;
|
|
60
|
-
}
|
|
61
|
-
async validateRequestSchema(req, schema, bodyCache) {
|
|
62
|
-
if (!schema) return {
|
|
63
|
-
success: true,
|
|
64
|
-
data: {}
|
|
65
|
-
};
|
|
66
|
-
const v = {};
|
|
67
|
-
if (schema.body) {
|
|
68
|
-
const [err, val] = await require_index$1.validateBody(req, schema.body, bodyCache);
|
|
69
|
-
if (err) return {
|
|
70
|
-
success: false,
|
|
71
|
-
error: err
|
|
72
|
-
};
|
|
73
|
-
v.body = val;
|
|
74
|
-
}
|
|
75
|
-
if (schema.query) {
|
|
76
|
-
const [err, val] = await require_index$1.validateQuery(req, schema.query);
|
|
77
|
-
if (err) return {
|
|
78
|
-
success: false,
|
|
79
|
-
error: err
|
|
80
|
-
};
|
|
81
|
-
v.query = val;
|
|
82
|
-
}
|
|
83
|
-
if (schema.headers) {
|
|
84
|
-
const [err, val] = await require_index$1.validateHeaders(req, schema.headers);
|
|
85
|
-
if (err) return {
|
|
86
|
-
success: false,
|
|
87
|
-
error: err
|
|
88
|
-
};
|
|
89
|
-
v.headers = val;
|
|
90
|
-
}
|
|
91
|
-
if (schema.cookies) {
|
|
92
|
-
const [err, val] = await require_index$1.validateCookies(req, schema.cookies);
|
|
93
|
-
if (err) return {
|
|
94
|
-
success: false,
|
|
95
|
-
error: err
|
|
96
|
-
};
|
|
97
|
-
v.cookies = val;
|
|
98
|
-
}
|
|
99
|
-
if (schema.params) {
|
|
100
|
-
const [err, val] = await require_index$1.validateParams(req, schema.params);
|
|
101
|
-
if (err) return {
|
|
102
|
-
success: false,
|
|
103
|
-
error: err
|
|
104
|
-
};
|
|
105
|
-
v.params = val;
|
|
106
|
-
}
|
|
107
|
-
return {
|
|
108
|
-
success: true,
|
|
109
|
-
data: v
|
|
110
|
-
};
|
|
111
|
-
}
|
|
112
|
-
createContext(req, validated, extensions) {
|
|
113
|
-
return {
|
|
114
|
-
raw: req,
|
|
115
|
-
req: validated,
|
|
116
|
-
...responseHelpers,
|
|
117
|
-
get: (key) => extensions[key]
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
async validateResponseBody(response, schema) {
|
|
121
|
-
if (!schema) return response;
|
|
122
|
-
const statusSchema = schema[response.status];
|
|
123
|
-
if (!statusSchema) return response;
|
|
124
|
-
if (!(response.headers.get("content-type") ?? "").includes("application/json")) return response;
|
|
125
|
-
const [parseError, body] = await require_lib_errors_index.mightThrow(response.clone().json());
|
|
126
|
-
if (parseError) return responseHelpers.json(400, { message: "Invalid response body" });
|
|
127
|
-
const [validationError] = await require_index$1.validateSchema(statusSchema, body);
|
|
128
|
-
if (validationError) return responseHelpers.json(400, { message: validationError.message });
|
|
129
|
-
return response;
|
|
130
|
-
}
|
|
131
|
-
buildBunRoutes() {
|
|
132
|
-
const bunRoutes = {};
|
|
133
|
-
const validationConfig = resolveValidation(this.options.validation);
|
|
134
|
-
for (const route of this.routes) {
|
|
135
|
-
const { path, method, handler, request, response, middlewares } = route;
|
|
136
|
-
const fullPath = this.getFullPath(path);
|
|
137
|
-
if (!bunRoutes[fullPath]) bunRoutes[fullPath] = {};
|
|
138
|
-
const allMiddlewares = [...this.options.middlewares ?? [], ...middlewares ?? []];
|
|
139
|
-
const hasMiddlewares = allMiddlewares.length > 0;
|
|
140
|
-
const hasRouteSchemas = hasSchemas(request);
|
|
141
|
-
const effectiveOutputValidation = validationConfig.output && !!response;
|
|
142
|
-
if (!hasMiddlewares && !(validationConfig.input && hasRouteSchemas) && !effectiveOutputValidation) bunRoutes[fullPath][method] = (req) => {
|
|
143
|
-
const context = Object.create(responseHelpers);
|
|
144
|
-
context.raw = req;
|
|
145
|
-
context.req = defaultValidated;
|
|
146
|
-
context.get = noopGet;
|
|
147
|
-
return handler(context);
|
|
148
|
-
};
|
|
149
|
-
else bunRoutes[fullPath][method] = async (req) => {
|
|
150
|
-
const extensions = {};
|
|
151
|
-
const bodyCache = validationConfig.input && shouldCreateBodyCache(hasMiddlewares, allMiddlewares, request) ? {
|
|
152
|
-
parsed: false,
|
|
153
|
-
value: void 0
|
|
154
|
-
} : void 0;
|
|
155
|
-
for (const mw of allMiddlewares) {
|
|
156
|
-
const { request: reqSchema, handler: mwHandler } = mw.options;
|
|
157
|
-
let validated = defaultValidated;
|
|
158
|
-
if (validationConfig.input && hasSchemas(reqSchema)) {
|
|
159
|
-
const result = await this.validateRequestSchema(req, reqSchema, bodyCache);
|
|
160
|
-
if (!result.success) return responseHelpers.json(400, { message: result.error?.message });
|
|
161
|
-
validated = result.data;
|
|
162
|
-
}
|
|
163
|
-
const mwResult = await mwHandler(this.createContext(req, validated, extensions));
|
|
164
|
-
if (mwResult instanceof Response) return mwResult;
|
|
165
|
-
if (mwResult) Object.assign(extensions, mwResult);
|
|
166
|
-
}
|
|
167
|
-
let routeValidated = defaultValidated;
|
|
168
|
-
if (validationConfig.input && hasRouteSchemas) {
|
|
169
|
-
const result = await this.validateRequestSchema(req, request, bodyCache);
|
|
170
|
-
if (!result.success) return responseHelpers.json(400, { message: result.error?.message });
|
|
171
|
-
routeValidated = result.data;
|
|
172
|
-
}
|
|
173
|
-
const handlerResponse = await handler(this.createContext(req, routeValidated, extensions));
|
|
174
|
-
if (effectiveOutputValidation) return this.validateResponseBody(handlerResponse, response);
|
|
175
|
-
return handlerResponse;
|
|
176
|
-
};
|
|
177
|
-
}
|
|
178
|
-
return bunRoutes;
|
|
179
|
-
}
|
|
180
|
-
defineRoute(config) {
|
|
181
|
-
this.routes.push(config);
|
|
182
|
-
}
|
|
183
|
-
getOpenApiSpec() {
|
|
184
|
-
return require_index.generateOpenApiSpec({
|
|
185
|
-
title: this.options.openapi?.title ?? "API",
|
|
186
|
-
description: this.options.openapi?.description,
|
|
187
|
-
version: this.options.openapi?.version ?? "1.0.0",
|
|
188
|
-
prefix: this.options.prefix,
|
|
189
|
-
servers: this.options.openapi?.servers,
|
|
190
|
-
securitySchemes: this.options.openapi?.securitySchemes,
|
|
191
|
-
routes: this.routes,
|
|
192
|
-
globalMiddlewares: this.options.middlewares
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
serve(port, callback) {
|
|
196
|
-
const bunRoutes = this.buildBunRoutes();
|
|
197
|
-
const server = Bun.serve({
|
|
198
|
-
port,
|
|
199
|
-
routes: bunRoutes,
|
|
200
|
-
fetch: () => new Response("Not found", { status: 404 })
|
|
201
|
-
});
|
|
202
|
-
if (callback) callback(server);
|
|
203
|
-
}
|
|
204
|
-
};
|
|
205
|
-
//#endregion
|
|
206
|
-
exports.Api = Api;
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { OpenApiSpec } from "../openapi/types.cjs";
|
|
2
|
-
import { ApiOptions, RequestSchema, ResponseSchema, RouteConfig } from "./types.cjs";
|
|
3
|
-
import { Middleware } from "../middleware/index.cjs";
|
|
4
|
-
|
|
5
|
-
//#region src/lib/api/core/index.d.ts
|
|
6
|
-
declare class Api<TMiddlewares extends readonly Middleware[] = readonly []> {
|
|
7
|
-
private options;
|
|
8
|
-
private routes;
|
|
9
|
-
constructor(options?: ApiOptions<TMiddlewares>);
|
|
10
|
-
private getFullPath;
|
|
11
|
-
private validateRequestSchema;
|
|
12
|
-
private createContext;
|
|
13
|
-
private validateResponseBody;
|
|
14
|
-
private buildBunRoutes;
|
|
15
|
-
defineRoute<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema = ResponseSchema, TRouteMiddlewares extends readonly Middleware[] = readonly []>(config: RouteConfig<TReq, TRes, TMiddlewares, TRouteMiddlewares>): void;
|
|
16
|
-
getOpenApiSpec(): Promise<OpenApiSpec>;
|
|
17
|
-
serve(port: number, callback?: (server: Bun.Server<unknown>) => void): void;
|
|
18
|
-
}
|
|
19
|
-
//#endregion
|
|
20
|
-
export { Api };
|
|
21
|
-
//# sourceMappingURL=index.d.cts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.cts","names":[],"sources":["../../../src/lib/api/core/index.ts"],"mappings":";;;;;cA4Ea,GAAA,+BAAkC,UAAA;EAAA,QACrC,OAAA;EAAA,QACA,MAAA;cAOW,OAAA,GAAS,UAAA,CAAW,YAAA;EAAA,QAI/B,WAAA;EAAA,QAaM,qBAAA;EAAA,QA+EN,aAAA;EAAA,QAaM,oBAAA;EAAA,QA6BN,cAAA;EAuHD,WAAA,cACQ,aAAA,GAAgB,aAAA,eAChB,cAAA,GAAiB,cAAA,qCACK,UAAA,iBAAA,CACnC,MAAA,EAAQ,WAAA,CAAY,IAAA,EAAM,IAAA,EAAM,YAAA,EAAc,iBAAA;EAWzC,cAAA,CAAA,GAAc,OAAA,CAXA,WAAA;EAwBd,KAAA,CAAM,IAAA,UAAc,QAAA,IAAY,MAAA,EAAQ,GAAA,CAAI,MAAA;AAAA"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { OpenApiSpec } from "../openapi/types.mjs";
|
|
2
|
-
import { ApiOptions, RequestSchema, ResponseSchema, RouteConfig } from "./types.mjs";
|
|
3
|
-
import { Middleware } from "../middleware/index.mjs";
|
|
4
|
-
|
|
5
|
-
//#region src/lib/api/core/index.d.ts
|
|
6
|
-
declare class Api<TMiddlewares extends readonly Middleware[] = readonly []> {
|
|
7
|
-
private options;
|
|
8
|
-
private routes;
|
|
9
|
-
constructor(options?: ApiOptions<TMiddlewares>);
|
|
10
|
-
private getFullPath;
|
|
11
|
-
private validateRequestSchema;
|
|
12
|
-
private createContext;
|
|
13
|
-
private validateResponseBody;
|
|
14
|
-
private buildBunRoutes;
|
|
15
|
-
defineRoute<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema = ResponseSchema, TRouteMiddlewares extends readonly Middleware[] = readonly []>(config: RouteConfig<TReq, TRes, TMiddlewares, TRouteMiddlewares>): void;
|
|
16
|
-
getOpenApiSpec(): Promise<OpenApiSpec>;
|
|
17
|
-
serve(port: number, callback?: (server: Bun.Server<unknown>) => void): void;
|
|
18
|
-
}
|
|
19
|
-
//#endregion
|
|
20
|
-
export { Api };
|
|
21
|
-
//# sourceMappingURL=index.d.mts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.mts","names":[],"sources":["../../../src/lib/api/core/index.ts"],"mappings":";;;;;cA4Ea,GAAA,+BAAkC,UAAA;EAAA,QACrC,OAAA;EAAA,QACA,MAAA;cAOW,OAAA,GAAS,UAAA,CAAW,YAAA;EAAA,QAI/B,WAAA;EAAA,QAaM,qBAAA;EAAA,QA+EN,aAAA;EAAA,QAaM,oBAAA;EAAA,QA6BN,cAAA;EAuHD,WAAA,cACQ,aAAA,GAAgB,aAAA,eAChB,cAAA,GAAiB,cAAA,qCACK,UAAA,iBAAA,CACnC,MAAA,EAAQ,WAAA,CAAY,IAAA,EAAM,IAAA,EAAM,YAAA,EAAc,iBAAA;EAWzC,cAAA,CAAA,GAAc,OAAA,CAXA,WAAA;EAwBd,KAAA,CAAM,IAAA,UAAc,QAAA,IAAY,MAAA,EAAQ,GAAA,CAAI,MAAA;AAAA"}
|
package/dist/api/core/index.mjs
DELETED
|
@@ -1,208 +0,0 @@
|
|
|
1
|
-
import { mightThrow } from "../../lib/errors/index.mjs";
|
|
2
|
-
import { generateOpenApiSpec } from "../openapi/index.mjs";
|
|
3
|
-
import { validateBody, validateCookies, validateHeaders, validateParams, validateQuery, validateSchema } from "../validation/index.mjs";
|
|
4
|
-
//#region src/lib/api/core/index.ts
|
|
5
|
-
const defaultValidated = Object.freeze({
|
|
6
|
-
body: void 0,
|
|
7
|
-
query: void 0,
|
|
8
|
-
headers: void 0,
|
|
9
|
-
cookies: void 0,
|
|
10
|
-
params: void 0
|
|
11
|
-
});
|
|
12
|
-
const responseHelpers = {
|
|
13
|
-
json: (status, data) => Response.json(data, { status }),
|
|
14
|
-
text: (status, text) => new Response(text, { status }),
|
|
15
|
-
html: (status, html) => new Response(html, {
|
|
16
|
-
status,
|
|
17
|
-
headers: { "Content-Type": "text/html" }
|
|
18
|
-
}),
|
|
19
|
-
redirect: (status, url) => Response.redirect(url, status)
|
|
20
|
-
};
|
|
21
|
-
const noopGet = () => void 0;
|
|
22
|
-
const stripTrailingSlash = (path) => {
|
|
23
|
-
if (path !== "/" && path.endsWith("/")) return path.slice(0, -1);
|
|
24
|
-
return path;
|
|
25
|
-
};
|
|
26
|
-
const hasSchemas = (schema) => schema && (schema.body || schema.query || schema.headers || schema.cookies || schema.params);
|
|
27
|
-
const needsBodyCache = (schema) => schema?.body !== void 0;
|
|
28
|
-
const shouldCreateBodyCache = (hasMiddlewares, allMiddlewares, request) => {
|
|
29
|
-
if (needsBodyCache(request)) return true;
|
|
30
|
-
if (!hasMiddlewares) return false;
|
|
31
|
-
return allMiddlewares.some((mw) => needsBodyCache(mw.options.request));
|
|
32
|
-
};
|
|
33
|
-
const resolveValidation = (v) => {
|
|
34
|
-
if (v === void 0 || v === true) return {
|
|
35
|
-
input: true,
|
|
36
|
-
output: true
|
|
37
|
-
};
|
|
38
|
-
if (v === false) return {
|
|
39
|
-
input: false,
|
|
40
|
-
output: false
|
|
41
|
-
};
|
|
42
|
-
return {
|
|
43
|
-
input: v.input !== false,
|
|
44
|
-
output: v.output !== false
|
|
45
|
-
};
|
|
46
|
-
};
|
|
47
|
-
var Api = class {
|
|
48
|
-
options;
|
|
49
|
-
routes = [];
|
|
50
|
-
constructor(options = {}) {
|
|
51
|
-
this.options = options;
|
|
52
|
-
}
|
|
53
|
-
getFullPath(path) {
|
|
54
|
-
const normalizedPath = stripTrailingSlash(path) || "/";
|
|
55
|
-
if (!this.options.prefix) return normalizedPath;
|
|
56
|
-
const normalizedPrefix = stripTrailingSlash(this.options.prefix);
|
|
57
|
-
if (normalizedPrefix === "/") return normalizedPath;
|
|
58
|
-
if (normalizedPath === "/") return normalizedPrefix;
|
|
59
|
-
return normalizedPrefix + normalizedPath;
|
|
60
|
-
}
|
|
61
|
-
async validateRequestSchema(req, schema, bodyCache) {
|
|
62
|
-
if (!schema) return {
|
|
63
|
-
success: true,
|
|
64
|
-
data: {}
|
|
65
|
-
};
|
|
66
|
-
const v = {};
|
|
67
|
-
if (schema.body) {
|
|
68
|
-
const [err, val] = await validateBody(req, schema.body, bodyCache);
|
|
69
|
-
if (err) return {
|
|
70
|
-
success: false,
|
|
71
|
-
error: err
|
|
72
|
-
};
|
|
73
|
-
v.body = val;
|
|
74
|
-
}
|
|
75
|
-
if (schema.query) {
|
|
76
|
-
const [err, val] = await validateQuery(req, schema.query);
|
|
77
|
-
if (err) return {
|
|
78
|
-
success: false,
|
|
79
|
-
error: err
|
|
80
|
-
};
|
|
81
|
-
v.query = val;
|
|
82
|
-
}
|
|
83
|
-
if (schema.headers) {
|
|
84
|
-
const [err, val] = await validateHeaders(req, schema.headers);
|
|
85
|
-
if (err) return {
|
|
86
|
-
success: false,
|
|
87
|
-
error: err
|
|
88
|
-
};
|
|
89
|
-
v.headers = val;
|
|
90
|
-
}
|
|
91
|
-
if (schema.cookies) {
|
|
92
|
-
const [err, val] = await validateCookies(req, schema.cookies);
|
|
93
|
-
if (err) return {
|
|
94
|
-
success: false,
|
|
95
|
-
error: err
|
|
96
|
-
};
|
|
97
|
-
v.cookies = val;
|
|
98
|
-
}
|
|
99
|
-
if (schema.params) {
|
|
100
|
-
const [err, val] = await validateParams(req, schema.params);
|
|
101
|
-
if (err) return {
|
|
102
|
-
success: false,
|
|
103
|
-
error: err
|
|
104
|
-
};
|
|
105
|
-
v.params = val;
|
|
106
|
-
}
|
|
107
|
-
return {
|
|
108
|
-
success: true,
|
|
109
|
-
data: v
|
|
110
|
-
};
|
|
111
|
-
}
|
|
112
|
-
createContext(req, validated, extensions) {
|
|
113
|
-
return {
|
|
114
|
-
raw: req,
|
|
115
|
-
req: validated,
|
|
116
|
-
...responseHelpers,
|
|
117
|
-
get: (key) => extensions[key]
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
async validateResponseBody(response, schema) {
|
|
121
|
-
if (!schema) return response;
|
|
122
|
-
const statusSchema = schema[response.status];
|
|
123
|
-
if (!statusSchema) return response;
|
|
124
|
-
if (!(response.headers.get("content-type") ?? "").includes("application/json")) return response;
|
|
125
|
-
const [parseError, body] = await mightThrow(response.clone().json());
|
|
126
|
-
if (parseError) return responseHelpers.json(400, { message: "Invalid response body" });
|
|
127
|
-
const [validationError] = await validateSchema(statusSchema, body);
|
|
128
|
-
if (validationError) return responseHelpers.json(400, { message: validationError.message });
|
|
129
|
-
return response;
|
|
130
|
-
}
|
|
131
|
-
buildBunRoutes() {
|
|
132
|
-
const bunRoutes = {};
|
|
133
|
-
const validationConfig = resolveValidation(this.options.validation);
|
|
134
|
-
for (const route of this.routes) {
|
|
135
|
-
const { path, method, handler, request, response, middlewares } = route;
|
|
136
|
-
const fullPath = this.getFullPath(path);
|
|
137
|
-
if (!bunRoutes[fullPath]) bunRoutes[fullPath] = {};
|
|
138
|
-
const allMiddlewares = [...this.options.middlewares ?? [], ...middlewares ?? []];
|
|
139
|
-
const hasMiddlewares = allMiddlewares.length > 0;
|
|
140
|
-
const hasRouteSchemas = hasSchemas(request);
|
|
141
|
-
const effectiveOutputValidation = validationConfig.output && !!response;
|
|
142
|
-
if (!hasMiddlewares && !(validationConfig.input && hasRouteSchemas) && !effectiveOutputValidation) bunRoutes[fullPath][method] = (req) => {
|
|
143
|
-
const context = Object.create(responseHelpers);
|
|
144
|
-
context.raw = req;
|
|
145
|
-
context.req = defaultValidated;
|
|
146
|
-
context.get = noopGet;
|
|
147
|
-
return handler(context);
|
|
148
|
-
};
|
|
149
|
-
else bunRoutes[fullPath][method] = async (req) => {
|
|
150
|
-
const extensions = {};
|
|
151
|
-
const bodyCache = validationConfig.input && shouldCreateBodyCache(hasMiddlewares, allMiddlewares, request) ? {
|
|
152
|
-
parsed: false,
|
|
153
|
-
value: void 0
|
|
154
|
-
} : void 0;
|
|
155
|
-
for (const mw of allMiddlewares) {
|
|
156
|
-
const { request: reqSchema, handler: mwHandler } = mw.options;
|
|
157
|
-
let validated = defaultValidated;
|
|
158
|
-
if (validationConfig.input && hasSchemas(reqSchema)) {
|
|
159
|
-
const result = await this.validateRequestSchema(req, reqSchema, bodyCache);
|
|
160
|
-
if (!result.success) return responseHelpers.json(400, { message: result.error?.message });
|
|
161
|
-
validated = result.data;
|
|
162
|
-
}
|
|
163
|
-
const mwResult = await mwHandler(this.createContext(req, validated, extensions));
|
|
164
|
-
if (mwResult instanceof Response) return mwResult;
|
|
165
|
-
if (mwResult) Object.assign(extensions, mwResult);
|
|
166
|
-
}
|
|
167
|
-
let routeValidated = defaultValidated;
|
|
168
|
-
if (validationConfig.input && hasRouteSchemas) {
|
|
169
|
-
const result = await this.validateRequestSchema(req, request, bodyCache);
|
|
170
|
-
if (!result.success) return responseHelpers.json(400, { message: result.error?.message });
|
|
171
|
-
routeValidated = result.data;
|
|
172
|
-
}
|
|
173
|
-
const handlerResponse = await handler(this.createContext(req, routeValidated, extensions));
|
|
174
|
-
if (effectiveOutputValidation) return this.validateResponseBody(handlerResponse, response);
|
|
175
|
-
return handlerResponse;
|
|
176
|
-
};
|
|
177
|
-
}
|
|
178
|
-
return bunRoutes;
|
|
179
|
-
}
|
|
180
|
-
defineRoute(config) {
|
|
181
|
-
this.routes.push(config);
|
|
182
|
-
}
|
|
183
|
-
getOpenApiSpec() {
|
|
184
|
-
return generateOpenApiSpec({
|
|
185
|
-
title: this.options.openapi?.title ?? "API",
|
|
186
|
-
description: this.options.openapi?.description,
|
|
187
|
-
version: this.options.openapi?.version ?? "1.0.0",
|
|
188
|
-
prefix: this.options.prefix,
|
|
189
|
-
servers: this.options.openapi?.servers,
|
|
190
|
-
securitySchemes: this.options.openapi?.securitySchemes,
|
|
191
|
-
routes: this.routes,
|
|
192
|
-
globalMiddlewares: this.options.middlewares
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
serve(port, callback) {
|
|
196
|
-
const bunRoutes = this.buildBunRoutes();
|
|
197
|
-
const server = Bun.serve({
|
|
198
|
-
port,
|
|
199
|
-
routes: bunRoutes,
|
|
200
|
-
fetch: () => new Response("Not found", { status: 404 })
|
|
201
|
-
});
|
|
202
|
-
if (callback) callback(server);
|
|
203
|
-
}
|
|
204
|
-
};
|
|
205
|
-
//#endregion
|
|
206
|
-
export { Api };
|
|
207
|
-
|
|
208
|
-
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","names":[],"sources":["../../../src/lib/api/core/index.ts"],"sourcesContent":["import { mightThrow } from \"../../errors/index.js\";\nimport type { Middleware } from \"../middleware/index.js\";\nimport { generateOpenApiSpec } from \"../openapi/index.js\";\nimport {\n type BodyCache,\n validateBody,\n validateCookies,\n validateHeaders,\n validateParams,\n validateQuery,\n validateSchema,\n} from \"../validation/index.js\";\nimport type {\n ApiOptions,\n MethodRoutes,\n RequestSchema,\n ResponseSchema,\n RouteConfig,\n ValidatedRequest,\n ValidationOptions,\n} from \"./types.js\";\n\n// Shared defaults reused across requests to avoid per-request allocations\nconst defaultValidated: ValidatedRequest = Object.freeze({\n body: undefined,\n query: undefined,\n headers: undefined,\n cookies: undefined,\n params: undefined,\n});\n\nconst responseHelpers = {\n json: (status: number, data: unknown) => Response.json(data, { status }),\n text: (status: number, text: string) => new Response(text, { status }),\n html: (status: number, html: string) =>\n new Response(html, { status, headers: { \"Content-Type\": \"text/html\" } }),\n redirect: (status: number, url: string) => Response.redirect(url, status),\n} as const;\n\nconst noopGet = () => undefined;\n\nconst stripTrailingSlash = (path: string) => {\n if (path !== \"/\" && path.endsWith(\"/\")) {\n return path.slice(0, -1);\n }\n\n return path;\n};\n\nconst hasSchemas = (schema?: RequestSchema) =>\n schema &&\n (schema.body ||\n schema.query ||\n schema.headers ||\n schema.cookies ||\n schema.params);\n\nconst needsBodyCache = (schema?: RequestSchema) => schema?.body !== undefined;\n\nconst shouldCreateBodyCache = (\n hasMiddlewares: boolean,\n allMiddlewares: Middleware[],\n request?: RequestSchema,\n) => {\n if (needsBodyCache(request)) return true;\n if (!hasMiddlewares) return false;\n\n return allMiddlewares.some((mw) => needsBodyCache(mw.options.request));\n};\n\nconst resolveValidation = (v?: ValidationOptions) => {\n if (v === undefined || v === true) return { input: true, output: true };\n if (v === false) return { input: false, output: false };\n return { input: v.input !== false, output: v.output !== false };\n};\n\nexport class Api<TMiddlewares extends readonly Middleware[] = readonly []> {\n private options: ApiOptions<TMiddlewares>;\n private routes: RouteConfig<\n RequestSchema,\n ResponseSchema,\n TMiddlewares,\n readonly Middleware[]\n >[] = [];\n\n public constructor(options: ApiOptions<TMiddlewares> = {}) {\n this.options = options;\n }\n\n private getFullPath(path: string) {\n const normalizedPath = stripTrailingSlash(path) || \"/\";\n\n if (!this.options.prefix) return normalizedPath;\n\n const normalizedPrefix = stripTrailingSlash(this.options.prefix);\n\n if (normalizedPrefix === \"/\") return normalizedPath;\n if (normalizedPath === \"/\") return normalizedPrefix;\n\n return normalizedPrefix + normalizedPath;\n }\n\n private async validateRequestSchema(\n req: Bun.BunRequest,\n schema: RequestSchema | undefined,\n bodyCache?: BodyCache,\n ) {\n if (!schema) {\n return { success: true, data: {} };\n }\n\n const v: Record<string, unknown> = {};\n\n if (schema.body) {\n const [err, val] = await validateBody(req, schema.body, bodyCache);\n\n if (err) {\n return {\n success: false,\n error: err,\n };\n }\n\n v.body = val;\n }\n\n if (schema.query) {\n const [err, val] = await validateQuery(req, schema.query);\n\n if (err) {\n return {\n success: false,\n error: err,\n };\n }\n\n v.query = val;\n }\n\n if (schema.headers) {\n const [err, val] = await validateHeaders(req, schema.headers);\n\n if (err) {\n return {\n success: false,\n error: err,\n };\n }\n\n v.headers = val;\n }\n\n if (schema.cookies) {\n const [err, val] = await validateCookies(req, schema.cookies);\n\n if (err) {\n return {\n success: false,\n error: err,\n };\n }\n\n v.cookies = val;\n }\n\n if (schema.params) {\n const [err, val] = await validateParams(req, schema.params);\n\n if (err) {\n return {\n success: false,\n error: err,\n };\n }\n\n v.params = val;\n }\n\n return { success: true, data: v };\n }\n\n private createContext(\n req: Bun.BunRequest,\n validated: ValidatedRequest,\n extensions: Record<string, unknown>,\n ) {\n return {\n raw: req,\n req: validated,\n ...responseHelpers,\n get: (key: string) => extensions[key],\n };\n }\n\n private async validateResponseBody(\n response: Response,\n schema: ResponseSchema | undefined,\n ) {\n if (!schema) return response;\n\n const statusSchema = schema[response.status];\n\n if (!statusSchema) return response;\n\n const contentType = response.headers.get(\"content-type\") ?? \"\";\n\n if (!contentType.includes(\"application/json\")) return response;\n\n const [parseError, body] = await mightThrow(response.clone().json());\n\n if (parseError) {\n return responseHelpers.json(400, { message: \"Invalid response body\" });\n }\n\n const [validationError] = await validateSchema(statusSchema, body);\n\n if (validationError) {\n return responseHelpers.json(400, { message: validationError.message });\n }\n\n return response;\n }\n\n private buildBunRoutes() {\n const bunRoutes: MethodRoutes = {};\n const validationConfig = resolveValidation(this.options.validation);\n\n for (const route of this.routes) {\n const { path, method, handler, request, response, middlewares } = route;\n\n const fullPath = this.getFullPath(path);\n\n if (!bunRoutes[fullPath]) {\n bunRoutes[fullPath] = {};\n }\n\n const allMiddlewares = [\n ...(this.options.middlewares ?? []),\n ...(middlewares ?? []),\n ];\n\n const hasMiddlewares = allMiddlewares.length > 0;\n const hasRouteSchemas = hasSchemas(request);\n const effectiveOutputValidation = validationConfig.output && !!response;\n\n if (\n !hasMiddlewares &&\n !(validationConfig.input && hasRouteSchemas) &&\n !effectiveOutputValidation\n ) {\n // Zero-allocation path for simple routes using prototype chain\n // Avoids object spread overhead by inheriting response helpers via prototype\n bunRoutes[fullPath][method] = (req: Bun.BunRequest) => {\n // Create fresh per-request context to avoid cross-request contamination\n const context = Object.create(responseHelpers);\n context.raw = req;\n context.req = defaultValidated;\n context.get = noopGet;\n\n return handler(context as unknown as Parameters<typeof handler>[0]);\n };\n } else {\n bunRoutes[fullPath][method] = async (req: Bun.BunRequest) => {\n const extensions: Record<string, unknown> = {};\n\n // Only create bodyCache if input validation is enabled and any schema has body validation\n const bodyCache: BodyCache | undefined =\n validationConfig.input &&\n shouldCreateBodyCache(hasMiddlewares, allMiddlewares, request)\n ? { parsed: false, value: undefined }\n : undefined;\n\n for (const mw of allMiddlewares) {\n const { request: reqSchema, handler: mwHandler } = mw.options;\n\n let validated = defaultValidated;\n\n if (validationConfig.input && hasSchemas(reqSchema)) {\n const result = await this.validateRequestSchema(\n req,\n reqSchema,\n bodyCache,\n );\n\n if (!result.success) {\n return responseHelpers.json(400, {\n message: result.error?.message,\n });\n }\n\n validated = result.data as ValidatedRequest;\n }\n\n const context = this.createContext(req, validated, extensions);\n const mwResult = await mwHandler(\n context as Parameters<typeof mwHandler>[0],\n );\n\n if (mwResult instanceof Response) {\n return mwResult;\n }\n\n if (mwResult) {\n Object.assign(extensions, mwResult);\n }\n }\n\n let routeValidated = defaultValidated;\n\n if (validationConfig.input && hasRouteSchemas) {\n const result = await this.validateRequestSchema(\n req,\n request,\n bodyCache,\n );\n\n if (!result.success) {\n return responseHelpers.json(400, {\n message: result.error?.message,\n });\n }\n\n routeValidated = result.data as ValidatedRequest;\n }\n\n const context = this.createContext(req, routeValidated, extensions);\n const handlerResponse = await handler(\n context as Parameters<typeof handler>[0],\n );\n\n if (effectiveOutputValidation) {\n return this.validateResponseBody(handlerResponse, response);\n }\n\n return handlerResponse;\n };\n }\n }\n\n return bunRoutes;\n }\n\n public defineRoute<\n TReq extends RequestSchema = RequestSchema,\n TRes extends ResponseSchema = ResponseSchema,\n TRouteMiddlewares extends readonly Middleware[] = readonly [],\n >(config: RouteConfig<TReq, TRes, TMiddlewares, TRouteMiddlewares>) {\n this.routes.push(\n config as RouteConfig<\n RequestSchema,\n ResponseSchema,\n TMiddlewares,\n readonly Middleware[]\n >,\n );\n }\n\n public getOpenApiSpec() {\n return generateOpenApiSpec({\n title: this.options.openapi?.title ?? \"API\",\n description: this.options.openapi?.description,\n version: this.options.openapi?.version ?? \"1.0.0\",\n prefix: this.options.prefix,\n servers: this.options.openapi?.servers,\n securitySchemes: this.options.openapi?.securitySchemes,\n routes: this.routes,\n globalMiddlewares: this.options.middlewares,\n });\n }\n\n public serve(port: number, callback?: (server: Bun.Server<unknown>) => void) {\n const bunRoutes = this.buildBunRoutes();\n\n const server = Bun.serve({\n port,\n routes: bunRoutes,\n fetch: () => new Response(\"Not found\", { status: 404 }),\n });\n\n if (callback) {\n callback(server);\n }\n }\n}\n"],"mappings":"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"}
|