ts-procedures 5.2.0 → 5.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/README.md +150 -0
  2. package/agent_config/bin/postinstall.mjs +105 -0
  3. package/agent_config/bin/setup.mjs +286 -0
  4. package/agent_config/claude-code/.claude-plugin/plugin.json +5 -0
  5. package/agent_config/claude-code/agents/ts-procedures-architect.md +188 -0
  6. package/agent_config/claude-code/skills/guide/SKILL.md +142 -0
  7. package/agent_config/claude-code/skills/guide/anti-patterns.md +608 -0
  8. package/agent_config/claude-code/skills/guide/api-reference.md +696 -0
  9. package/agent_config/claude-code/skills/guide/patterns.md +727 -0
  10. package/agent_config/claude-code/skills/review/SKILL.md +53 -0
  11. package/agent_config/claude-code/skills/review/checklist.md +163 -0
  12. package/agent_config/claude-code/skills/scaffold/SKILL.md +56 -0
  13. package/agent_config/claude-code/skills/scaffold/templates/express-rpc.md +134 -0
  14. package/agent_config/claude-code/skills/scaffold/templates/hono-api.md +169 -0
  15. package/agent_config/claude-code/skills/scaffold/templates/hono-rpc.md +139 -0
  16. package/agent_config/claude-code/skills/scaffold/templates/hono-stream.md +134 -0
  17. package/agent_config/claude-code/skills/scaffold/templates/procedure.md +77 -0
  18. package/agent_config/claude-code/skills/scaffold/templates/stream-procedure.md +113 -0
  19. package/agent_config/copilot/copilot-instructions.md +290 -0
  20. package/agent_config/cursor/cursorrules +290 -0
  21. package/agent_config/lib/install-claude.mjs +109 -0
  22. package/build/implementations/http/hono-api/index.d.ts +102 -0
  23. package/build/implementations/http/hono-api/index.js +339 -0
  24. package/build/implementations/http/hono-api/index.js.map +1 -0
  25. package/build/implementations/http/hono-api/index.test.d.ts +1 -0
  26. package/build/implementations/http/hono-api/index.test.js +983 -0
  27. package/build/implementations/http/hono-api/index.test.js.map +1 -0
  28. package/build/implementations/http/hono-api/types.d.ts +13 -0
  29. package/build/implementations/http/hono-api/types.js +2 -0
  30. package/build/implementations/http/hono-api/types.js.map +1 -0
  31. package/build/implementations/types.d.ts +44 -0
  32. package/build/index.d.ts +28 -6
  33. package/build/index.js +28 -0
  34. package/build/index.js.map +1 -1
  35. package/build/schema/compute-schema.d.ts +5 -0
  36. package/build/schema/compute-schema.js +8 -1
  37. package/build/schema/compute-schema.js.map +1 -1
  38. package/build/schema/parser.d.ts +6 -5
  39. package/build/schema/parser.js +54 -0
  40. package/build/schema/parser.js.map +1 -1
  41. package/package.json +14 -4
  42. package/src/implementations/http/README.md +45 -2
  43. package/src/implementations/http/hono-api/index.test.ts +1328 -0
  44. package/src/implementations/http/hono-api/index.ts +461 -0
  45. package/src/implementations/http/hono-api/types.ts +16 -0
  46. package/src/implementations/types.ts +52 -0
  47. package/src/index.ts +87 -10
  48. package/src/schema/compute-schema.ts +23 -2
  49. package/src/schema/parser.ts +70 -3
@@ -0,0 +1,102 @@
1
+ import { Hono, Context } from 'hono';
2
+ import { TProcedureRegistration } from '../../../index.js';
3
+ import { ExtractConfig, ExtractContext, ProceduresFactory, APIConfig, APIHttpRouteDoc, APIInput, HttpMethod } from '../../types.js';
4
+ export type { APIConfig, APIHttpRouteDoc, APIInput, HttpMethod };
5
+ export type QueryParser = (queryString: string) => Record<string, unknown>;
6
+ export type HonoAPIAppBuilderConfig = {
7
+ /**
8
+ * An existing Hono application instance to use.
9
+ * If not provided, a new instance will be created.
10
+ */
11
+ app?: Hono;
12
+ /** Optional path prefix for all API routes. */
13
+ pathPrefix?: string;
14
+ /**
15
+ * Custom query string parser. Receives the raw query string (without '?').
16
+ * Default: uses `qs` (optional peer dependency) if available, otherwise native URLSearchParams.
17
+ */
18
+ queryParser?: QueryParser;
19
+ onRequestStart?: (c: Context) => void;
20
+ onRequestEnd?: (c: Context) => void;
21
+ onSuccess?: (procedure: TProcedureRegistration, c: Context) => void;
22
+ /**
23
+ * Error handler called when a procedure throws an error.
24
+ */
25
+ onError?: (procedure: TProcedureRegistration, c: Context, error: Error) => Response | Promise<Response>;
26
+ };
27
+ /**
28
+ * Builder class for creating a Hono application with REST-style API routes.
29
+ *
30
+ * Uses `schema.input` for per-channel type safety:
31
+ * - `input.pathParams` → validated path parameters
32
+ * - `input.query` → validated query string parameters
33
+ * - `input.body` → validated request body
34
+ * - `input.headers` → validated request headers
35
+ *
36
+ * Usage:
37
+ * const API = Procedures<MyContext, APIConfig>()
38
+ *
39
+ * API.Create('GetUser', {
40
+ * path: '/users/:id',
41
+ * method: 'get',
42
+ * schema: {
43
+ * input: {
44
+ * pathParams: Type.Object({ id: Type.String() }),
45
+ * query: Type.Object({ include: Type.Optional(Type.String()) }),
46
+ * },
47
+ * returnType: Type.Object({ id: Type.String(), name: Type.String() }),
48
+ * }
49
+ * }, async (ctx, { pathParams, query }) => {
50
+ * return { id: pathParams.id, name: 'John' }
51
+ * })
52
+ *
53
+ * const apiApp = new HonoAPIAppBuilder()
54
+ * .register(API, (c) => ({ ... }))
55
+ * .build()
56
+ */
57
+ export declare class HonoAPIAppBuilder {
58
+ readonly config?: HonoAPIAppBuilderConfig | undefined;
59
+ constructor(config?: HonoAPIAppBuilderConfig | undefined);
60
+ private factories;
61
+ private _app;
62
+ private _docs;
63
+ get app(): Hono;
64
+ get docs(): APIHttpRouteDoc[];
65
+ /**
66
+ * Registers a procedure factory with its context.
67
+ * @param factory - The procedure factory created by Procedures<Context, APIConfig>()
68
+ * @param factoryContext - Context for handlers. Direct value, sync function, or async function.
69
+ * @param extendProcedureDoc - Custom function to extend the generated route documentation.
70
+ */
71
+ register<TFactory extends ProceduresFactory>(factory: TFactory, factoryContext: ExtractContext<TFactory> | ((c: Context) => ExtractContext<TFactory> | Promise<ExtractContext<TFactory>>), extendProcedureDoc?: (params: {
72
+ base: APIHttpRouteDoc;
73
+ procedure: TProcedureRegistration<any, ExtractConfig<TFactory>>;
74
+ }) => Record<string, any>): this;
75
+ /**
76
+ * Resolves the full path for a route, combining pathPrefix and the procedure's path.
77
+ */
78
+ private resolveFullPath;
79
+ /**
80
+ * Builds and returns the Hono application with registered API routes.
81
+ * Async because it resolves the query parser (qs optional peer dep) once at build time.
82
+ */
83
+ build(): Promise<Hono>;
84
+ /**
85
+ * Validates that path parameter names in the path template match the schema.input.pathParams declaration.
86
+ */
87
+ private validatePathParamConsistency;
88
+ /**
89
+ * Creates the async route handler for a procedure.
90
+ */
91
+ private createRouteHandler;
92
+ /**
93
+ * Extracts and assembles structured input params from HTTP request sources.
94
+ * Each channel (pathParams, query, body, headers) is extracted from its HTTP source.
95
+ * The core validates each channel independently via schema.input validators.
96
+ */
97
+ private extractInputParams;
98
+ /**
99
+ * Generates the API HTTP route documentation for the given procedure.
100
+ */
101
+ private buildApiHttpRouteDoc;
102
+ }
@@ -0,0 +1,339 @@
1
+ import { Hono } from 'hono';
2
+ /** Lazy-loaded qs module (optional peer dependency) */
3
+ let _qsModule;
4
+ async function loadQs() {
5
+ if (_qsModule === undefined) {
6
+ try {
7
+ const mod = await import('qs');
8
+ _qsModule = mod.default ?? mod;
9
+ }
10
+ catch {
11
+ _qsModule = false;
12
+ }
13
+ }
14
+ return _qsModule || undefined;
15
+ }
16
+ /** Fallback query parser using native URLSearchParams */
17
+ function parseQueryNative(queryString) {
18
+ const searchParams = new URLSearchParams(queryString);
19
+ const result = {};
20
+ for (const key of new Set(searchParams.keys())) {
21
+ const values = searchParams.getAll(key);
22
+ result[key] = values.length > 1 ? values : values[0];
23
+ }
24
+ return result;
25
+ }
26
+ /**
27
+ * Resolves the query parser once. Called during build() so handlers use a sync parser.
28
+ * Priority: custom queryParser > qs (optional peer dep) > native URLSearchParams
29
+ */
30
+ async function resolveQueryParser(custom) {
31
+ if (custom)
32
+ return custom;
33
+ const qs = await loadQs();
34
+ if (qs) {
35
+ return (raw) => qs.parse(raw);
36
+ }
37
+ return parseQueryNative;
38
+ }
39
+ /** Extract path parameter names from a route pattern (e.g., '/users/:id' → ['id']) */
40
+ function extractPathParamNames(path) {
41
+ const matches = path.match(/:([a-zA-Z_][a-zA-Z0-9_]*)/g);
42
+ return matches ? matches.map((m) => m.slice(1)) : [];
43
+ }
44
+ /** Default success status codes by HTTP method */
45
+ function defaultSuccessStatus(method) {
46
+ switch (method) {
47
+ case 'post':
48
+ return 201;
49
+ case 'delete':
50
+ return 204;
51
+ default:
52
+ return 200;
53
+ }
54
+ }
55
+ /** HTTP methods that typically carry a request body */
56
+ const BODY_METHODS = ['post', 'put', 'patch'];
57
+ /** Extracts the raw query string from a URL and runs it through the resolved parser. */
58
+ function extractQuery(url, queryParser) {
59
+ const questionMark = url.indexOf('?');
60
+ if (questionMark === -1)
61
+ return {};
62
+ const rawQuery = url.slice(questionMark + 1);
63
+ if (!rawQuery)
64
+ return {};
65
+ return queryParser(rawQuery);
66
+ }
67
+ /**
68
+ * Builder class for creating a Hono application with REST-style API routes.
69
+ *
70
+ * Uses `schema.input` for per-channel type safety:
71
+ * - `input.pathParams` → validated path parameters
72
+ * - `input.query` → validated query string parameters
73
+ * - `input.body` → validated request body
74
+ * - `input.headers` → validated request headers
75
+ *
76
+ * Usage:
77
+ * const API = Procedures<MyContext, APIConfig>()
78
+ *
79
+ * API.Create('GetUser', {
80
+ * path: '/users/:id',
81
+ * method: 'get',
82
+ * schema: {
83
+ * input: {
84
+ * pathParams: Type.Object({ id: Type.String() }),
85
+ * query: Type.Object({ include: Type.Optional(Type.String()) }),
86
+ * },
87
+ * returnType: Type.Object({ id: Type.String(), name: Type.String() }),
88
+ * }
89
+ * }, async (ctx, { pathParams, query }) => {
90
+ * return { id: pathParams.id, name: 'John' }
91
+ * })
92
+ *
93
+ * const apiApp = new HonoAPIAppBuilder()
94
+ * .register(API, (c) => ({ ... }))
95
+ * .build()
96
+ */
97
+ export class HonoAPIAppBuilder {
98
+ config;
99
+ constructor(config) {
100
+ this.config = config;
101
+ if (config?.app) {
102
+ this._app = config.app;
103
+ }
104
+ if (config?.onRequestStart) {
105
+ this._app.use('*', async (c, next) => {
106
+ config.onRequestStart(c);
107
+ await next();
108
+ });
109
+ }
110
+ if (config?.onRequestEnd) {
111
+ this._app.use('*', async (c, next) => {
112
+ await next();
113
+ config.onRequestEnd(c);
114
+ });
115
+ }
116
+ }
117
+ factories = [];
118
+ _app = new Hono();
119
+ _docs = [];
120
+ get app() {
121
+ return this._app;
122
+ }
123
+ get docs() {
124
+ return this._docs;
125
+ }
126
+ /**
127
+ * Registers a procedure factory with its context.
128
+ * @param factory - The procedure factory created by Procedures<Context, APIConfig>()
129
+ * @param factoryContext - Context for handlers. Direct value, sync function, or async function.
130
+ * @param extendProcedureDoc - Custom function to extend the generated route documentation.
131
+ */
132
+ register(factory, factoryContext, extendProcedureDoc) {
133
+ this.factories.push({ factory, factoryContext, extendProcedureDoc });
134
+ return this;
135
+ }
136
+ /**
137
+ * Resolves the full path for a route, combining pathPrefix and the procedure's path.
138
+ */
139
+ resolveFullPath(procedurePath) {
140
+ const prefix = this.config?.pathPrefix;
141
+ const normalizedPrefix = prefix ? (prefix.startsWith('/') ? prefix : `/${prefix}`) : '';
142
+ const normalizedPath = procedurePath.startsWith('/') ? procedurePath : `/${procedurePath}`;
143
+ return `${normalizedPrefix}${normalizedPath}`;
144
+ }
145
+ /**
146
+ * Builds and returns the Hono application with registered API routes.
147
+ * Async because it resolves the query parser (qs optional peer dep) once at build time.
148
+ */
149
+ async build() {
150
+ // Resolve query parser once so handlers use it synchronously
151
+ const queryParser = await resolveQueryParser(this.config?.queryParser);
152
+ this.factories.forEach(({ factory, factoryContext, extendProcedureDoc }) => {
153
+ factory.getProcedures().map((procedure) => {
154
+ const { config } = procedure;
155
+ const fullPath = this.resolveFullPath(config.path);
156
+ const inputSchema = procedure.config.schema?.input;
157
+ // Validate consistency: path params in path template must match schema.input.pathParams
158
+ this.validatePathParamConsistency(procedure.name, config.path, inputSchema);
159
+ const route = this.buildApiHttpRouteDoc(procedure, fullPath, extendProcedureDoc);
160
+ this._docs.push(route);
161
+ const method = config.method;
162
+ const handler = this.createRouteHandler(procedure, factoryContext, config, inputSchema, queryParser);
163
+ this._app.on(method.toUpperCase(), fullPath, handler);
164
+ });
165
+ });
166
+ return this._app;
167
+ }
168
+ /**
169
+ * Validates that path parameter names in the path template match the schema.input.pathParams declaration.
170
+ */
171
+ validatePathParamConsistency(procedureName, path, inputSchema) {
172
+ // Only validate when schema.input is used; schema.params (flat mode) skips this check
173
+ if (!inputSchema)
174
+ return;
175
+ const pathParamNames = extractPathParamNames(path);
176
+ if (pathParamNames.length > 0 && !inputSchema.pathParams) {
177
+ throw new Error(`Path "${path}" has path parameters [${pathParamNames.join(', ')}] but schema.input.pathParams is not defined for procedure "${procedureName}". ` +
178
+ `Define schema.input.pathParams to validate path parameters.`);
179
+ }
180
+ if (inputSchema.pathParams && pathParamNames.length === 0) {
181
+ throw new Error(`schema.input.pathParams is defined for procedure "${procedureName}" but path "${path}" has no path parameters. ` +
182
+ `Remove schema.input.pathParams or add path parameters to the path.`);
183
+ }
184
+ // Deep validation: verify schema property names match the :param names in the path
185
+ if (inputSchema.pathParams && pathParamNames.length > 0) {
186
+ const pathParamsJsonSchema = inputSchema.pathParams;
187
+ const schemaProperties = pathParamsJsonSchema.properties;
188
+ if (schemaProperties) {
189
+ const schemaKeys = Object.keys(schemaProperties);
190
+ const missingInSchema = pathParamNames.filter((p) => !schemaKeys.includes(p));
191
+ const extraInSchema = schemaKeys.filter((k) => !pathParamNames.includes(k));
192
+ if (missingInSchema.length > 0 || extraInSchema.length > 0) {
193
+ const parts = [];
194
+ if (missingInSchema.length > 0) {
195
+ parts.push(`path has [${missingInSchema.join(', ')}] but they are missing from schema`);
196
+ }
197
+ if (extraInSchema.length > 0) {
198
+ parts.push(`schema has [${extraInSchema.join(', ')}] but they are not in the path`);
199
+ }
200
+ throw new Error(`Path param mismatch for procedure "${procedureName}": ${parts.join('; ')}. ` +
201
+ `Path "${path}" expects [${pathParamNames.join(', ')}], schema defines [${schemaKeys.join(', ')}].`);
202
+ }
203
+ }
204
+ }
205
+ }
206
+ /**
207
+ * Creates the async route handler for a procedure.
208
+ */
209
+ createRouteHandler(procedure, factoryContext, config, inputSchema, queryParser) {
210
+ const successStatus = config.successStatus ?? defaultSuccessStatus(config.method);
211
+ return async (c) => {
212
+ try {
213
+ const context = typeof factoryContext === 'function'
214
+ ? await factoryContext(c)
215
+ : factoryContext;
216
+ let params;
217
+ if (inputSchema) {
218
+ // schema.input mode: build structured params from HTTP sources
219
+ params = await this.extractInputParams(c, config.method, inputSchema, queryParser);
220
+ }
221
+ else if (procedure.config.schema?.params) {
222
+ // schema.params mode: extract from body or query based on method
223
+ if (BODY_METHODS.includes(config.method)) {
224
+ params = await c.req.json().catch(() => ({}));
225
+ }
226
+ else {
227
+ params = extractQuery(c.req.url, queryParser);
228
+ }
229
+ }
230
+ else {
231
+ params = await c.req.json().catch(() => undefined);
232
+ }
233
+ const result = await procedure.handler({ ...context, signal: c.req.raw.signal }, params);
234
+ if (this.config?.onSuccess) {
235
+ this.config.onSuccess(procedure, c);
236
+ }
237
+ // 204 No Content returns no body
238
+ if (successStatus === 204) {
239
+ return c.body(null, 204);
240
+ }
241
+ return c.json(result, successStatus);
242
+ }
243
+ catch (error) {
244
+ if (this.config?.onError) {
245
+ return this.config.onError(procedure, c, error);
246
+ }
247
+ return c.json({ error: error.message }, 500);
248
+ }
249
+ };
250
+ }
251
+ /**
252
+ * Extracts and assembles structured input params from HTTP request sources.
253
+ * Each channel (pathParams, query, body, headers) is extracted from its HTTP source.
254
+ * The core validates each channel independently via schema.input validators.
255
+ */
256
+ async extractInputParams(c, method, inputSchema, queryParser) {
257
+ const params = {};
258
+ const channelNames = Object.keys(inputSchema);
259
+ for (const channel of channelNames) {
260
+ switch (channel) {
261
+ case 'pathParams':
262
+ params.pathParams = c.req.param();
263
+ break;
264
+ case 'query':
265
+ params.query = extractQuery(c.req.url, queryParser);
266
+ break;
267
+ case 'body':
268
+ if (BODY_METHODS.includes(method)) {
269
+ params.body = await c.req.json().catch(() => ({}));
270
+ }
271
+ break;
272
+ case 'headers': {
273
+ // Pass all request headers; AJV's removeAdditional strips non-declared keys
274
+ const headersObj = {};
275
+ c.req.raw.headers.forEach((value, key) => {
276
+ headersObj[key] = value;
277
+ });
278
+ params.headers = headersObj;
279
+ break;
280
+ }
281
+ default:
282
+ // Unknown channel — pass through empty. Core validation will catch mismatches.
283
+ params[channel] = undefined;
284
+ break;
285
+ }
286
+ }
287
+ return params;
288
+ }
289
+ /**
290
+ * Generates the API HTTP route documentation for the given procedure.
291
+ */
292
+ buildApiHttpRouteDoc(procedure, fullPath, extendProcedureDoc) {
293
+ const { config } = procedure;
294
+ const inputSchema = config.schema?.input;
295
+ const jsonSchema = {};
296
+ // Populate per-channel JSON schemas from schema.input
297
+ if (inputSchema) {
298
+ if (inputSchema.pathParams)
299
+ jsonSchema.pathParams = inputSchema.pathParams;
300
+ if (inputSchema.query)
301
+ jsonSchema.query = inputSchema.query;
302
+ if (inputSchema.body)
303
+ jsonSchema.body = inputSchema.body;
304
+ if (inputSchema.headers)
305
+ jsonSchema.headers = inputSchema.headers;
306
+ }
307
+ else if (config.schema?.params) {
308
+ // Fallback: schema.params treated as body/query depending on method
309
+ if (BODY_METHODS.includes(config.method)) {
310
+ jsonSchema.body = config.schema.params;
311
+ }
312
+ else {
313
+ jsonSchema.query = config.schema.params;
314
+ }
315
+ }
316
+ if (config.schema?.returnType) {
317
+ jsonSchema.response = config.schema.returnType;
318
+ }
319
+ const base = {
320
+ name: procedure.name,
321
+ path: config.path,
322
+ method: config.method,
323
+ fullPath,
324
+ jsonSchema,
325
+ };
326
+ if (config.successStatus) {
327
+ base.successStatus = config.successStatus;
328
+ }
329
+ let extendedDoc = {};
330
+ if (extendProcedureDoc) {
331
+ extendedDoc = extendProcedureDoc({ base, procedure });
332
+ }
333
+ return {
334
+ ...extendedDoc,
335
+ ...base,
336
+ };
337
+ }
338
+ }
339
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/implementations/http/hono-api/index.ts"],"names":[],"mappings":"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"}