semola 0.5.2 → 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.
Files changed (160) hide show
  1. package/README.md +88 -13
  2. package/dist/index-BhGNDjPq.d.mts +13 -0
  3. package/dist/index-DxSbeGP-.d.cts +13 -0
  4. package/dist/lib/api/index.cjs +522 -4
  5. package/dist/lib/api/index.d.cts +270 -4
  6. package/dist/lib/api/index.d.mts +270 -4
  7. package/dist/lib/api/index.mjs +520 -2
  8. package/dist/lib/cache/index.d.cts +19 -7
  9. package/dist/lib/cache/index.d.mts +19 -7
  10. package/dist/lib/cache/index.mjs +0 -2
  11. package/dist/lib/cron/index.cjs +470 -11
  12. package/dist/lib/cron/index.d.cts +112 -5
  13. package/dist/lib/cron/index.d.mts +112 -5
  14. package/dist/lib/cron/index.mjs +461 -12
  15. package/dist/lib/errors/index.d.cts +2 -13
  16. package/dist/lib/errors/index.d.mts +2 -13
  17. package/dist/lib/errors/index.mjs +0 -2
  18. package/dist/lib/i18n/index.cjs +6 -1
  19. package/dist/lib/i18n/index.d.cts +12 -4
  20. package/dist/lib/i18n/index.d.mts +12 -4
  21. package/dist/lib/i18n/index.mjs +6 -3
  22. package/dist/lib/logging/index.cjs +387 -0
  23. package/dist/lib/logging/index.d.cts +108 -0
  24. package/dist/lib/logging/index.d.mts +108 -0
  25. package/dist/lib/logging/index.mjs +374 -0
  26. package/dist/lib/policy/index.cjs +206 -20
  27. package/dist/lib/policy/index.d.cts +61 -5
  28. package/dist/lib/policy/index.d.mts +61 -5
  29. package/dist/lib/policy/index.mjs +187 -3
  30. package/dist/lib/prompts/index.cjs +374 -14
  31. package/dist/lib/prompts/index.d.cts +77 -12
  32. package/dist/lib/prompts/index.d.mts +77 -12
  33. package/dist/lib/prompts/index.mjs +362 -4
  34. package/dist/lib/pubsub/index.cjs +82 -13
  35. package/dist/lib/pubsub/index.d.cts +23 -9
  36. package/dist/lib/pubsub/index.d.mts +23 -9
  37. package/dist/lib/pubsub/index.mjs +82 -15
  38. package/dist/lib/queue/index.d.cts +46 -4
  39. package/dist/lib/queue/index.d.mts +46 -4
  40. package/dist/lib/queue/index.mjs +0 -2
  41. package/dist/lib/workflow/index.cjs +534 -0
  42. package/dist/lib/workflow/index.d.cts +85 -0
  43. package/dist/lib/workflow/index.d.mts +85 -0
  44. package/dist/lib/workflow/index.mjs +533 -0
  45. package/package.json +29 -3
  46. package/dist/api/core/index.cjs +0 -206
  47. package/dist/api/core/index.d.cts +0 -21
  48. package/dist/api/core/index.d.cts.map +0 -1
  49. package/dist/api/core/index.d.mts +0 -21
  50. package/dist/api/core/index.d.mts.map +0 -1
  51. package/dist/api/core/index.mjs +0 -208
  52. package/dist/api/core/index.mjs.map +0 -1
  53. package/dist/api/core/types.d.cts +0 -107
  54. package/dist/api/core/types.d.cts.map +0 -1
  55. package/dist/api/core/types.d.mts +0 -107
  56. package/dist/api/core/types.d.mts.map +0 -1
  57. package/dist/api/middleware/index.cjs +0 -8
  58. package/dist/api/middleware/index.d.cts +0 -11
  59. package/dist/api/middleware/index.d.cts.map +0 -1
  60. package/dist/api/middleware/index.d.mts +0 -11
  61. package/dist/api/middleware/index.d.mts.map +0 -1
  62. package/dist/api/middleware/index.mjs +0 -10
  63. package/dist/api/middleware/index.mjs.map +0 -1
  64. package/dist/api/middleware/types.d.cts +0 -16
  65. package/dist/api/middleware/types.d.cts.map +0 -1
  66. package/dist/api/middleware/types.d.mts +0 -16
  67. package/dist/api/middleware/types.d.mts.map +0 -1
  68. package/dist/api/openapi/index.cjs +0 -254
  69. package/dist/api/openapi/index.mjs +0 -256
  70. package/dist/api/openapi/index.mjs.map +0 -1
  71. package/dist/api/openapi/types.d.cts +0 -60
  72. package/dist/api/openapi/types.d.cts.map +0 -1
  73. package/dist/api/openapi/types.d.mts +0 -60
  74. package/dist/api/openapi/types.d.mts.map +0 -1
  75. package/dist/api/validation/index.cjs +0 -64
  76. package/dist/api/validation/index.mjs +0 -61
  77. package/dist/api/validation/index.mjs.map +0 -1
  78. package/dist/cache/types.d.cts +0 -17
  79. package/dist/cache/types.d.cts.map +0 -1
  80. package/dist/cache/types.d.mts +0 -17
  81. package/dist/cache/types.d.mts.map +0 -1
  82. package/dist/cron/scanner.cjs +0 -237
  83. package/dist/cron/scanner.mjs +0 -238
  84. package/dist/cron/scanner.mjs.map +0 -1
  85. package/dist/cron/types.d.cts +0 -11
  86. package/dist/cron/types.d.cts.map +0 -1
  87. package/dist/cron/types.d.mts +0 -11
  88. package/dist/cron/types.d.mts.map +0 -1
  89. package/dist/errors/types.d.cts +0 -5
  90. package/dist/errors/types.d.cts.map +0 -1
  91. package/dist/errors/types.d.mts +0 -5
  92. package/dist/errors/types.d.mts.map +0 -1
  93. package/dist/i18n/types.d.cts +0 -13
  94. package/dist/i18n/types.d.cts.map +0 -1
  95. package/dist/i18n/types.d.mts +0 -13
  96. package/dist/i18n/types.d.mts.map +0 -1
  97. package/dist/lib/cache/index.d.cts.map +0 -1
  98. package/dist/lib/cache/index.d.mts.map +0 -1
  99. package/dist/lib/cache/index.mjs.map +0 -1
  100. package/dist/lib/cron/index.d.cts.map +0 -1
  101. package/dist/lib/cron/index.d.mts.map +0 -1
  102. package/dist/lib/cron/index.mjs.map +0 -1
  103. package/dist/lib/errors/index.d.cts.map +0 -1
  104. package/dist/lib/errors/index.d.mts.map +0 -1
  105. package/dist/lib/errors/index.mjs.map +0 -1
  106. package/dist/lib/i18n/index.d.cts.map +0 -1
  107. package/dist/lib/i18n/index.d.mts.map +0 -1
  108. package/dist/lib/i18n/index.mjs.map +0 -1
  109. package/dist/lib/policy/index.d.cts.map +0 -1
  110. package/dist/lib/policy/index.d.mts.map +0 -1
  111. package/dist/lib/policy/index.mjs.map +0 -1
  112. package/dist/lib/prompts/index.d.cts.map +0 -1
  113. package/dist/lib/prompts/index.d.mts.map +0 -1
  114. package/dist/lib/prompts/index.mjs.map +0 -1
  115. package/dist/lib/pubsub/index.d.cts.map +0 -1
  116. package/dist/lib/pubsub/index.d.mts.map +0 -1
  117. package/dist/lib/pubsub/index.mjs.map +0 -1
  118. package/dist/lib/queue/index.d.cts.map +0 -1
  119. package/dist/lib/queue/index.d.mts.map +0 -1
  120. package/dist/lib/queue/index.mjs.map +0 -1
  121. package/dist/node_modules/@standard-schema/spec/dist/index.d.cts +0 -80
  122. package/dist/node_modules/@standard-schema/spec/dist/index.d.cts.map +0 -1
  123. package/dist/node_modules/@standard-schema/spec/dist/index.d.mts +0 -80
  124. package/dist/node_modules/@standard-schema/spec/dist/index.d.mts.map +0 -1
  125. package/dist/policy/helpers.cjs +0 -206
  126. package/dist/policy/helpers.d.cts +0 -50
  127. package/dist/policy/helpers.d.cts.map +0 -1
  128. package/dist/policy/helpers.d.mts +0 -50
  129. package/dist/policy/helpers.d.mts.map +0 -1
  130. package/dist/policy/helpers.mjs +0 -190
  131. package/dist/policy/helpers.mjs.map +0 -1
  132. package/dist/policy/types.d.cts +0 -16
  133. package/dist/policy/types.d.cts.map +0 -1
  134. package/dist/policy/types.d.mts +0 -16
  135. package/dist/policy/types.d.mts.map +0 -1
  136. package/dist/prompts/core/keys.cjs +0 -165
  137. package/dist/prompts/core/keys.mjs +0 -167
  138. package/dist/prompts/core/keys.mjs.map +0 -1
  139. package/dist/prompts/core/runtime.cjs +0 -104
  140. package/dist/prompts/core/runtime.mjs +0 -106
  141. package/dist/prompts/core/runtime.mjs.map +0 -1
  142. package/dist/prompts/core/session.cjs +0 -98
  143. package/dist/prompts/core/session.mjs +0 -100
  144. package/dist/prompts/core/session.mjs.map +0 -1
  145. package/dist/prompts/core/types.d.cts +0 -21
  146. package/dist/prompts/core/types.d.cts.map +0 -1
  147. package/dist/prompts/core/types.d.mts +0 -21
  148. package/dist/prompts/core/types.d.mts.map +0 -1
  149. package/dist/prompts/types.d.cts +0 -52
  150. package/dist/prompts/types.d.cts.map +0 -1
  151. package/dist/prompts/types.d.mts +0 -52
  152. package/dist/prompts/types.d.mts.map +0 -1
  153. package/dist/pubsub/types.d.cts +0 -10
  154. package/dist/pubsub/types.d.cts.map +0 -1
  155. package/dist/pubsub/types.d.mts +0 -10
  156. package/dist/pubsub/types.d.mts.map +0 -1
  157. package/dist/queue/types.d.cts +0 -47
  158. package/dist/queue/types.d.cts.map +0 -1
  159. package/dist/queue/types.d.mts +0 -47
  160. package/dist/queue/types.d.mts.map +0 -1
@@ -1,5 +1,271 @@
1
- import { InferMiddlewareExtension, MergeMiddlewareExtensions, MiddlewareHandler, MiddlewareOptions } from "../../api/middleware/types.cjs";
2
- import { ApiOptions, Context, ExtractStatusCodes, InferInput, InferOutput, OpenApiOptions, RequestSchema, ResponseSchema, RouteConfig, RouteHandler, SecurityScheme, SecuritySchemeApiKey, SecuritySchemeHttp, SecuritySchemeOAuth2, SecuritySchemeOAuth2Flow, SecuritySchemeOpenIdConnect } from "../../api/core/types.cjs";
3
- import { Middleware } from "../../api/middleware/index.cjs";
4
- import { Api } from "../../api/core/index.cjs";
1
+ //#region src/lib/api/openapi/types.d.ts
2
+ type OpenApiSpec = {
3
+ openapi: string;
4
+ info: {
5
+ title: string;
6
+ description?: string;
7
+ version: string;
8
+ };
9
+ servers?: Array<{
10
+ url: string;
11
+ description?: string;
12
+ }>;
13
+ paths: Record<string, OpenApiPath>;
14
+ components?: {
15
+ schemas?: Record<string, unknown>;
16
+ responses?: Record<string, unknown>;
17
+ parameters?: Record<string, unknown>;
18
+ requestBodies?: Record<string, unknown>;
19
+ securitySchemes?: Record<string, unknown>;
20
+ };
21
+ };
22
+ type OpenApiPath = {
23
+ [method: string]: OpenApiOperation;
24
+ };
25
+ type OpenApiOperation = {
26
+ summary?: string;
27
+ description?: string;
28
+ operationId?: string;
29
+ tags?: string[];
30
+ parameters?: OpenApiParameter[];
31
+ requestBody?: OpenApiRequestBody;
32
+ responses: Record<string, OpenApiResponse>;
33
+ security?: Array<Record<string, string[]>>;
34
+ };
35
+ type OpenApiParameter = {
36
+ name: string;
37
+ in: "path" | "query" | "header" | "cookie";
38
+ required?: boolean;
39
+ schema: unknown;
40
+ description?: string;
41
+ };
42
+ type OpenApiRequestBody = {
43
+ required?: boolean;
44
+ content: {
45
+ [mediaType: string]: {
46
+ schema: unknown;
47
+ };
48
+ };
49
+ };
50
+ type OpenApiResponse = {
51
+ description: string;
52
+ content?: {
53
+ [mediaType: string]: {
54
+ schema: unknown;
55
+ };
56
+ };
57
+ };
58
+ //#endregion
59
+ //#region node_modules/@standard-schema/spec/dist/index.d.ts
60
+ /** The Standard Typed interface. This is a base type extended by other specs. */
61
+ interface StandardTypedV1<Input = unknown, Output = Input> {
62
+ /** The Standard properties. */
63
+ readonly "~standard": StandardTypedV1.Props<Input, Output>;
64
+ }
65
+ declare namespace StandardTypedV1 {
66
+ /** The Standard Typed properties interface. */
67
+ interface Props<Input = unknown, Output = Input> {
68
+ /** The version number of the standard. */
69
+ readonly version: 1;
70
+ /** The vendor name of the schema library. */
71
+ readonly vendor: string;
72
+ /** Inferred types associated with the schema. */
73
+ readonly types?: Types<Input, Output> | undefined;
74
+ }
75
+ /** The Standard Typed types interface. */
76
+ interface Types<Input = unknown, Output = Input> {
77
+ /** The input type of the schema. */
78
+ readonly input: Input;
79
+ /** The output type of the schema. */
80
+ readonly output: Output;
81
+ }
82
+ /** Infers the input type of a Standard Typed. */
83
+ type InferInput<Schema extends StandardTypedV1> = NonNullable<Schema["~standard"]["types"]>["input"];
84
+ /** Infers the output type of a Standard Typed. */
85
+ type InferOutput<Schema extends StandardTypedV1> = NonNullable<Schema["~standard"]["types"]>["output"];
86
+ }
87
+ /** The Standard Schema interface. */
88
+ interface StandardSchemaV1<Input = unknown, Output = Input> {
89
+ /** The Standard Schema properties. */
90
+ readonly "~standard": StandardSchemaV1.Props<Input, Output>;
91
+ }
92
+ declare namespace StandardSchemaV1 {
93
+ /** The Standard Schema properties interface. */
94
+ interface Props<Input = unknown, Output = Input> extends StandardTypedV1.Props<Input, Output> {
95
+ /** Validates unknown input values. */
96
+ readonly validate: (value: unknown, options?: StandardSchemaV1.Options | undefined) => Result<Output> | Promise<Result<Output>>;
97
+ }
98
+ /** The result interface of the validate function. */
99
+ type Result<Output> = SuccessResult<Output> | FailureResult;
100
+ /** The result interface if validation succeeds. */
101
+ interface SuccessResult<Output> {
102
+ /** The typed output value. */
103
+ readonly value: Output;
104
+ /** A falsy value for `issues` indicates success. */
105
+ readonly issues?: undefined;
106
+ }
107
+ interface Options {
108
+ /** Explicit support for additional vendor-specific parameters, if needed. */
109
+ readonly libraryOptions?: Record<string, unknown> | undefined;
110
+ }
111
+ /** The result interface if validation fails. */
112
+ interface FailureResult {
113
+ /** The issues of failed validation. */
114
+ readonly issues: ReadonlyArray<Issue>;
115
+ }
116
+ /** The issue interface of the failure output. */
117
+ interface Issue {
118
+ /** The error message of the issue. */
119
+ readonly message: string;
120
+ /** The path of the issue, if any. */
121
+ readonly path?: ReadonlyArray<PropertyKey | PathSegment> | undefined;
122
+ }
123
+ /** The path segment interface of the issue. */
124
+ interface PathSegment {
125
+ /** The key representing a path segment. */
126
+ readonly key: PropertyKey;
127
+ }
128
+ /** The Standard types interface. */
129
+ interface Types<Input = unknown, Output = Input> extends StandardTypedV1.Types<Input, Output> {}
130
+ /** Infers the input type of a Standard. */
131
+ type InferInput<Schema extends StandardTypedV1> = StandardTypedV1.InferInput<Schema>;
132
+ /** Infers the output type of a Standard. */
133
+ type InferOutput<Schema extends StandardTypedV1> = StandardTypedV1.InferOutput<Schema>;
134
+ }
135
+ /** The Standard JSON Schema interface. */
136
+ //#endregion
137
+ //#region src/lib/api/middleware/types.d.ts
138
+ type MiddlewareHandler<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<never, never>> = (c: Context<TReq, TRes>) => Response | TExt | undefined | Promise<Response | TExt | undefined> | Promise<void> | void;
139
+ type MiddlewareOptions<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<string, unknown>> = {
140
+ request?: TReq;
141
+ response?: TRes;
142
+ handler: MiddlewareHandler<TReq, TRes, TExt>;
143
+ };
144
+ type InferMiddlewareExtension<T> = T extends {
145
+ options: MiddlewareOptions<infer _TReq, infer _TRes, infer E>;
146
+ } ? E : never;
147
+ type MergeMiddlewareExtensions<T extends readonly unknown[]> = T extends readonly [infer First, ...infer Rest] ? InferMiddlewareExtension<First> & MergeMiddlewareExtensions<Rest> : {};
148
+ //#endregion
149
+ //#region src/lib/api/core/types.d.ts
150
+ type ResponseSchema = {
151
+ [status: number]: StandardSchemaV1;
152
+ };
153
+ type RequestSchema = {
154
+ params?: StandardSchemaV1;
155
+ body?: StandardSchemaV1;
156
+ query?: StandardSchemaV1;
157
+ headers?: StandardSchemaV1;
158
+ cookies?: StandardSchemaV1;
159
+ };
160
+ type SafeTypeAccess<T, K extends "input" | "output"> = T extends StandardSchemaV1 ? T["~standard"] extends {
161
+ types?: infer U;
162
+ } ? U extends Record<K, infer V> ? V : never : never : undefined;
163
+ type InferOutput<T extends StandardSchemaV1 | undefined> = SafeTypeAccess<T, "output">;
164
+ type InferInput<T extends StandardSchemaV1 | undefined> = SafeTypeAccess<T, "input">;
165
+ type ExtractStatusCodes<T extends ResponseSchema> = keyof T & number;
166
+ type ExtractStatusCodesOrAny<T extends ResponseSchema | undefined> = T extends ResponseSchema ? ExtractStatusCodes<T> : number;
167
+ type ValidationOptions = boolean | {
168
+ input?: boolean;
169
+ output?: boolean;
170
+ };
171
+ type ApiOptions<TMiddlewares extends readonly Middleware[] = readonly []> = {
172
+ prefix?: string;
173
+ openapi?: OpenApiOptions;
174
+ middlewares?: TMiddlewares;
175
+ validation?: ValidationOptions;
176
+ };
177
+ type SecuritySchemeApiKey = {
178
+ type: "apiKey";
179
+ name: string;
180
+ in: "query" | "header" | "cookie";
181
+ description?: string;
182
+ };
183
+ type SecuritySchemeHttp = {
184
+ type: "http";
185
+ scheme: string;
186
+ bearerFormat?: string;
187
+ description?: string;
188
+ };
189
+ type SecuritySchemeOAuth2Flow = {
190
+ authorizationUrl?: string;
191
+ tokenUrl?: string;
192
+ refreshUrl?: string;
193
+ scopes: Record<string, string>;
194
+ };
195
+ type SecuritySchemeOAuth2 = {
196
+ type: "oauth2";
197
+ flows: {
198
+ implicit?: SecuritySchemeOAuth2Flow;
199
+ password?: SecuritySchemeOAuth2Flow;
200
+ clientCredentials?: SecuritySchemeOAuth2Flow;
201
+ authorizationCode?: SecuritySchemeOAuth2Flow;
202
+ };
203
+ description?: string;
204
+ };
205
+ type SecuritySchemeOpenIdConnect = {
206
+ type: "openIdConnect";
207
+ openIdConnectUrl: string;
208
+ description?: string;
209
+ };
210
+ type SecurityScheme = SecuritySchemeApiKey | SecuritySchemeHttp | SecuritySchemeOAuth2 | SecuritySchemeOpenIdConnect;
211
+ type OpenApiOptions = {
212
+ version: string;
213
+ title: string;
214
+ description?: string;
215
+ servers?: Array<{
216
+ url: string;
217
+ description?: string;
218
+ }>;
219
+ securitySchemes?: Record<string, SecurityScheme>;
220
+ };
221
+ type Context<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<string, unknown>> = {
222
+ raw: Request;
223
+ req: {
224
+ body: InferOutput<TReq["body"]>;
225
+ query: InferOutput<TReq["query"]>;
226
+ headers: InferOutput<TReq["headers"]>;
227
+ cookies: InferOutput<TReq["cookies"]>;
228
+ params: InferOutput<TReq["params"]>;
229
+ };
230
+ json: <S extends ExtractStatusCodesOrAny<TRes>>(status: S, data: TRes extends ResponseSchema ? InferOutput<TRes[S]> : unknown) => Response;
231
+ text: (status: number, text: string) => Response;
232
+ html: (status: number, html: string) => Response;
233
+ redirect: (status: number, url: string) => Response;
234
+ get: <K extends keyof TExt>(key: K) => TExt[K];
235
+ };
236
+ type RouteHandler<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<string, unknown>> = (c: Context<TReq, TRes, TExt>) => Response | Promise<Response>;
237
+ type RouteConfig<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TGlobalMiddlewares extends readonly Middleware[] = readonly [], TRouteMiddlewares extends readonly Middleware[] = readonly []> = {
238
+ path: string;
239
+ method: Bun.Serve.HTTPMethod;
240
+ request?: TReq;
241
+ response?: TRes;
242
+ middlewares?: TRouteMiddlewares;
243
+ handler: RouteHandler<TReq, TRes, MergeMiddlewareExtensions<TGlobalMiddlewares> & MergeMiddlewareExtensions<TRouteMiddlewares>>;
244
+ summary?: string;
245
+ description?: string;
246
+ operationId?: string;
247
+ tags?: string[];
248
+ };
249
+ //#endregion
250
+ //#region src/lib/api/middleware/index.d.ts
251
+ declare class Middleware<TRequest extends RequestSchema = RequestSchema, TResponse extends ResponseSchema = ResponseSchema, TExtension extends Record<string, unknown> = Record<string, unknown>> {
252
+ options: MiddlewareOptions<TRequest, TResponse, TExtension>;
253
+ constructor(options: MiddlewareOptions<TRequest, TResponse, TExtension>);
254
+ }
255
+ //#endregion
256
+ //#region src/lib/api/core/index.d.ts
257
+ declare class Api<TMiddlewares extends readonly Middleware[] = readonly []> {
258
+ private options;
259
+ private routes;
260
+ constructor(options?: ApiOptions<TMiddlewares>);
261
+ private getFullPath;
262
+ private validateRequestSchema;
263
+ private createContext;
264
+ private validateResponseBody;
265
+ private buildBunRoutes;
266
+ defineRoute<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema = ResponseSchema, TRouteMiddlewares extends readonly Middleware[] = readonly []>(config: RouteConfig<TReq, TRes, TMiddlewares, TRouteMiddlewares>): void;
267
+ getOpenApiSpec(): Promise<OpenApiSpec>;
268
+ serve(port: number, callback?: (server: Bun.Server<unknown>) => void): void;
269
+ }
270
+ //#endregion
5
271
  export { Api, type ApiOptions, type Context, type ExtractStatusCodes, type InferInput, type InferMiddlewareExtension, type InferOutput, type MergeMiddlewareExtensions, Middleware, type MiddlewareHandler, type MiddlewareOptions, type OpenApiOptions, type RequestSchema, type ResponseSchema, type RouteConfig, type RouteHandler, type SecurityScheme, type SecuritySchemeApiKey, type SecuritySchemeHttp, type SecuritySchemeOAuth2, type SecuritySchemeOAuth2Flow, type SecuritySchemeOpenIdConnect };
@@ -1,5 +1,271 @@
1
- import { InferMiddlewareExtension, MergeMiddlewareExtensions, MiddlewareHandler, MiddlewareOptions } from "../../api/middleware/types.mjs";
2
- import { ApiOptions, Context, ExtractStatusCodes, InferInput, InferOutput, OpenApiOptions, RequestSchema, ResponseSchema, RouteConfig, RouteHandler, SecurityScheme, SecuritySchemeApiKey, SecuritySchemeHttp, SecuritySchemeOAuth2, SecuritySchemeOAuth2Flow, SecuritySchemeOpenIdConnect } from "../../api/core/types.mjs";
3
- import { Middleware } from "../../api/middleware/index.mjs";
4
- import { Api } from "../../api/core/index.mjs";
1
+ //#region src/lib/api/openapi/types.d.ts
2
+ type OpenApiSpec = {
3
+ openapi: string;
4
+ info: {
5
+ title: string;
6
+ description?: string;
7
+ version: string;
8
+ };
9
+ servers?: Array<{
10
+ url: string;
11
+ description?: string;
12
+ }>;
13
+ paths: Record<string, OpenApiPath>;
14
+ components?: {
15
+ schemas?: Record<string, unknown>;
16
+ responses?: Record<string, unknown>;
17
+ parameters?: Record<string, unknown>;
18
+ requestBodies?: Record<string, unknown>;
19
+ securitySchemes?: Record<string, unknown>;
20
+ };
21
+ };
22
+ type OpenApiPath = {
23
+ [method: string]: OpenApiOperation;
24
+ };
25
+ type OpenApiOperation = {
26
+ summary?: string;
27
+ description?: string;
28
+ operationId?: string;
29
+ tags?: string[];
30
+ parameters?: OpenApiParameter[];
31
+ requestBody?: OpenApiRequestBody;
32
+ responses: Record<string, OpenApiResponse>;
33
+ security?: Array<Record<string, string[]>>;
34
+ };
35
+ type OpenApiParameter = {
36
+ name: string;
37
+ in: "path" | "query" | "header" | "cookie";
38
+ required?: boolean;
39
+ schema: unknown;
40
+ description?: string;
41
+ };
42
+ type OpenApiRequestBody = {
43
+ required?: boolean;
44
+ content: {
45
+ [mediaType: string]: {
46
+ schema: unknown;
47
+ };
48
+ };
49
+ };
50
+ type OpenApiResponse = {
51
+ description: string;
52
+ content?: {
53
+ [mediaType: string]: {
54
+ schema: unknown;
55
+ };
56
+ };
57
+ };
58
+ //#endregion
59
+ //#region node_modules/@standard-schema/spec/dist/index.d.ts
60
+ /** The Standard Typed interface. This is a base type extended by other specs. */
61
+ interface StandardTypedV1<Input = unknown, Output = Input> {
62
+ /** The Standard properties. */
63
+ readonly "~standard": StandardTypedV1.Props<Input, Output>;
64
+ }
65
+ declare namespace StandardTypedV1 {
66
+ /** The Standard Typed properties interface. */
67
+ interface Props<Input = unknown, Output = Input> {
68
+ /** The version number of the standard. */
69
+ readonly version: 1;
70
+ /** The vendor name of the schema library. */
71
+ readonly vendor: string;
72
+ /** Inferred types associated with the schema. */
73
+ readonly types?: Types<Input, Output> | undefined;
74
+ }
75
+ /** The Standard Typed types interface. */
76
+ interface Types<Input = unknown, Output = Input> {
77
+ /** The input type of the schema. */
78
+ readonly input: Input;
79
+ /** The output type of the schema. */
80
+ readonly output: Output;
81
+ }
82
+ /** Infers the input type of a Standard Typed. */
83
+ type InferInput<Schema extends StandardTypedV1> = NonNullable<Schema["~standard"]["types"]>["input"];
84
+ /** Infers the output type of a Standard Typed. */
85
+ type InferOutput<Schema extends StandardTypedV1> = NonNullable<Schema["~standard"]["types"]>["output"];
86
+ }
87
+ /** The Standard Schema interface. */
88
+ interface StandardSchemaV1<Input = unknown, Output = Input> {
89
+ /** The Standard Schema properties. */
90
+ readonly "~standard": StandardSchemaV1.Props<Input, Output>;
91
+ }
92
+ declare namespace StandardSchemaV1 {
93
+ /** The Standard Schema properties interface. */
94
+ interface Props<Input = unknown, Output = Input> extends StandardTypedV1.Props<Input, Output> {
95
+ /** Validates unknown input values. */
96
+ readonly validate: (value: unknown, options?: StandardSchemaV1.Options | undefined) => Result<Output> | Promise<Result<Output>>;
97
+ }
98
+ /** The result interface of the validate function. */
99
+ type Result<Output> = SuccessResult<Output> | FailureResult;
100
+ /** The result interface if validation succeeds. */
101
+ interface SuccessResult<Output> {
102
+ /** The typed output value. */
103
+ readonly value: Output;
104
+ /** A falsy value for `issues` indicates success. */
105
+ readonly issues?: undefined;
106
+ }
107
+ interface Options {
108
+ /** Explicit support for additional vendor-specific parameters, if needed. */
109
+ readonly libraryOptions?: Record<string, unknown> | undefined;
110
+ }
111
+ /** The result interface if validation fails. */
112
+ interface FailureResult {
113
+ /** The issues of failed validation. */
114
+ readonly issues: ReadonlyArray<Issue>;
115
+ }
116
+ /** The issue interface of the failure output. */
117
+ interface Issue {
118
+ /** The error message of the issue. */
119
+ readonly message: string;
120
+ /** The path of the issue, if any. */
121
+ readonly path?: ReadonlyArray<PropertyKey | PathSegment> | undefined;
122
+ }
123
+ /** The path segment interface of the issue. */
124
+ interface PathSegment {
125
+ /** The key representing a path segment. */
126
+ readonly key: PropertyKey;
127
+ }
128
+ /** The Standard types interface. */
129
+ interface Types<Input = unknown, Output = Input> extends StandardTypedV1.Types<Input, Output> {}
130
+ /** Infers the input type of a Standard. */
131
+ type InferInput<Schema extends StandardTypedV1> = StandardTypedV1.InferInput<Schema>;
132
+ /** Infers the output type of a Standard. */
133
+ type InferOutput<Schema extends StandardTypedV1> = StandardTypedV1.InferOutput<Schema>;
134
+ }
135
+ /** The Standard JSON Schema interface. */
136
+ //#endregion
137
+ //#region src/lib/api/middleware/types.d.ts
138
+ type MiddlewareHandler<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<never, never>> = (c: Context<TReq, TRes>) => Response | TExt | undefined | Promise<Response | TExt | undefined> | Promise<void> | void;
139
+ type MiddlewareOptions<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<string, unknown>> = {
140
+ request?: TReq;
141
+ response?: TRes;
142
+ handler: MiddlewareHandler<TReq, TRes, TExt>;
143
+ };
144
+ type InferMiddlewareExtension<T> = T extends {
145
+ options: MiddlewareOptions<infer _TReq, infer _TRes, infer E>;
146
+ } ? E : never;
147
+ type MergeMiddlewareExtensions<T extends readonly unknown[]> = T extends readonly [infer First, ...infer Rest] ? InferMiddlewareExtension<First> & MergeMiddlewareExtensions<Rest> : {};
148
+ //#endregion
149
+ //#region src/lib/api/core/types.d.ts
150
+ type ResponseSchema = {
151
+ [status: number]: StandardSchemaV1;
152
+ };
153
+ type RequestSchema = {
154
+ params?: StandardSchemaV1;
155
+ body?: StandardSchemaV1;
156
+ query?: StandardSchemaV1;
157
+ headers?: StandardSchemaV1;
158
+ cookies?: StandardSchemaV1;
159
+ };
160
+ type SafeTypeAccess<T, K extends "input" | "output"> = T extends StandardSchemaV1 ? T["~standard"] extends {
161
+ types?: infer U;
162
+ } ? U extends Record<K, infer V> ? V : never : never : undefined;
163
+ type InferOutput<T extends StandardSchemaV1 | undefined> = SafeTypeAccess<T, "output">;
164
+ type InferInput<T extends StandardSchemaV1 | undefined> = SafeTypeAccess<T, "input">;
165
+ type ExtractStatusCodes<T extends ResponseSchema> = keyof T & number;
166
+ type ExtractStatusCodesOrAny<T extends ResponseSchema | undefined> = T extends ResponseSchema ? ExtractStatusCodes<T> : number;
167
+ type ValidationOptions = boolean | {
168
+ input?: boolean;
169
+ output?: boolean;
170
+ };
171
+ type ApiOptions<TMiddlewares extends readonly Middleware[] = readonly []> = {
172
+ prefix?: string;
173
+ openapi?: OpenApiOptions;
174
+ middlewares?: TMiddlewares;
175
+ validation?: ValidationOptions;
176
+ };
177
+ type SecuritySchemeApiKey = {
178
+ type: "apiKey";
179
+ name: string;
180
+ in: "query" | "header" | "cookie";
181
+ description?: string;
182
+ };
183
+ type SecuritySchemeHttp = {
184
+ type: "http";
185
+ scheme: string;
186
+ bearerFormat?: string;
187
+ description?: string;
188
+ };
189
+ type SecuritySchemeOAuth2Flow = {
190
+ authorizationUrl?: string;
191
+ tokenUrl?: string;
192
+ refreshUrl?: string;
193
+ scopes: Record<string, string>;
194
+ };
195
+ type SecuritySchemeOAuth2 = {
196
+ type: "oauth2";
197
+ flows: {
198
+ implicit?: SecuritySchemeOAuth2Flow;
199
+ password?: SecuritySchemeOAuth2Flow;
200
+ clientCredentials?: SecuritySchemeOAuth2Flow;
201
+ authorizationCode?: SecuritySchemeOAuth2Flow;
202
+ };
203
+ description?: string;
204
+ };
205
+ type SecuritySchemeOpenIdConnect = {
206
+ type: "openIdConnect";
207
+ openIdConnectUrl: string;
208
+ description?: string;
209
+ };
210
+ type SecurityScheme = SecuritySchemeApiKey | SecuritySchemeHttp | SecuritySchemeOAuth2 | SecuritySchemeOpenIdConnect;
211
+ type OpenApiOptions = {
212
+ version: string;
213
+ title: string;
214
+ description?: string;
215
+ servers?: Array<{
216
+ url: string;
217
+ description?: string;
218
+ }>;
219
+ securitySchemes?: Record<string, SecurityScheme>;
220
+ };
221
+ type Context<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<string, unknown>> = {
222
+ raw: Request;
223
+ req: {
224
+ body: InferOutput<TReq["body"]>;
225
+ query: InferOutput<TReq["query"]>;
226
+ headers: InferOutput<TReq["headers"]>;
227
+ cookies: InferOutput<TReq["cookies"]>;
228
+ params: InferOutput<TReq["params"]>;
229
+ };
230
+ json: <S extends ExtractStatusCodesOrAny<TRes>>(status: S, data: TRes extends ResponseSchema ? InferOutput<TRes[S]> : unknown) => Response;
231
+ text: (status: number, text: string) => Response;
232
+ html: (status: number, html: string) => Response;
233
+ redirect: (status: number, url: string) => Response;
234
+ get: <K extends keyof TExt>(key: K) => TExt[K];
235
+ };
236
+ type RouteHandler<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TExt extends Record<string, unknown> = Record<string, unknown>> = (c: Context<TReq, TRes, TExt>) => Response | Promise<Response>;
237
+ type RouteConfig<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema | undefined = undefined, TGlobalMiddlewares extends readonly Middleware[] = readonly [], TRouteMiddlewares extends readonly Middleware[] = readonly []> = {
238
+ path: string;
239
+ method: Bun.Serve.HTTPMethod;
240
+ request?: TReq;
241
+ response?: TRes;
242
+ middlewares?: TRouteMiddlewares;
243
+ handler: RouteHandler<TReq, TRes, MergeMiddlewareExtensions<TGlobalMiddlewares> & MergeMiddlewareExtensions<TRouteMiddlewares>>;
244
+ summary?: string;
245
+ description?: string;
246
+ operationId?: string;
247
+ tags?: string[];
248
+ };
249
+ //#endregion
250
+ //#region src/lib/api/middleware/index.d.ts
251
+ declare class Middleware<TRequest extends RequestSchema = RequestSchema, TResponse extends ResponseSchema = ResponseSchema, TExtension extends Record<string, unknown> = Record<string, unknown>> {
252
+ options: MiddlewareOptions<TRequest, TResponse, TExtension>;
253
+ constructor(options: MiddlewareOptions<TRequest, TResponse, TExtension>);
254
+ }
255
+ //#endregion
256
+ //#region src/lib/api/core/index.d.ts
257
+ declare class Api<TMiddlewares extends readonly Middleware[] = readonly []> {
258
+ private options;
259
+ private routes;
260
+ constructor(options?: ApiOptions<TMiddlewares>);
261
+ private getFullPath;
262
+ private validateRequestSchema;
263
+ private createContext;
264
+ private validateResponseBody;
265
+ private buildBunRoutes;
266
+ defineRoute<TReq extends RequestSchema = RequestSchema, TRes extends ResponseSchema = ResponseSchema, TRouteMiddlewares extends readonly Middleware[] = readonly []>(config: RouteConfig<TReq, TRes, TMiddlewares, TRouteMiddlewares>): void;
267
+ getOpenApiSpec(): Promise<OpenApiSpec>;
268
+ serve(port: number, callback?: (server: Bun.Server<unknown>) => void): void;
269
+ }
270
+ //#endregion
5
271
  export { Api, type ApiOptions, type Context, type ExtractStatusCodes, type InferInput, type InferMiddlewareExtension, type InferOutput, type MergeMiddlewareExtensions, Middleware, type MiddlewareHandler, type MiddlewareOptions, type OpenApiOptions, type RequestSchema, type ResponseSchema, type RouteConfig, type RouteHandler, type SecurityScheme, type SecuritySchemeApiKey, type SecuritySchemeHttp, type SecuritySchemeOAuth2, type SecuritySchemeOAuth2Flow, type SecuritySchemeOpenIdConnect };