bytekit 0.1.12

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 (200) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +2241 -0
  3. package/bin/sutils.js +9 -0
  4. package/dist/api-client.d.ts +2 -0
  5. package/dist/api-client.d.ts.map +1 -0
  6. package/dist/api-client.js +2 -0
  7. package/dist/api-client.js.map +1 -0
  8. package/dist/cli/index.d.ts +2 -0
  9. package/dist/cli/index.d.ts.map +1 -0
  10. package/dist/cli/index.js +401 -0
  11. package/dist/cli/index.js.map +1 -0
  12. package/dist/cli/type-generator.d.ts +12 -0
  13. package/dist/cli/type-generator.d.ts.map +1 -0
  14. package/dist/cli/type-generator.js +152 -0
  15. package/dist/cli/type-generator.js.map +1 -0
  16. package/dist/date-utils.d.ts +2 -0
  17. package/dist/date-utils.d.ts.map +1 -0
  18. package/dist/date-utils.js +2 -0
  19. package/dist/date-utils.js.map +1 -0
  20. package/dist/debug.d.ts +2 -0
  21. package/dist/debug.d.ts.map +1 -0
  22. package/dist/debug.js +2 -0
  23. package/dist/debug.js.map +1 -0
  24. package/dist/env-manager.d.ts +2 -0
  25. package/dist/env-manager.d.ts.map +1 -0
  26. package/dist/env-manager.js +2 -0
  27. package/dist/env-manager.js.map +1 -0
  28. package/dist/file-upload.d.ts +2 -0
  29. package/dist/file-upload.d.ts.map +1 -0
  30. package/dist/file-upload.js +2 -0
  31. package/dist/file-upload.js.map +1 -0
  32. package/dist/index.d.ts +2 -0
  33. package/dist/index.d.ts.map +1 -0
  34. package/dist/index.js +2 -0
  35. package/dist/index.js.map +1 -0
  36. package/dist/logger.d.ts +2 -0
  37. package/dist/logger.d.ts.map +1 -0
  38. package/dist/logger.js +2 -0
  39. package/dist/logger.js.map +1 -0
  40. package/dist/profiler.d.ts +2 -0
  41. package/dist/profiler.d.ts.map +1 -0
  42. package/dist/profiler.js +2 -0
  43. package/dist/profiler.js.map +1 -0
  44. package/dist/response-validator.d.ts +2 -0
  45. package/dist/response-validator.d.ts.map +1 -0
  46. package/dist/response-validator.js +2 -0
  47. package/dist/response-validator.js.map +1 -0
  48. package/dist/retry-policy.d.ts +2 -0
  49. package/dist/retry-policy.d.ts.map +1 -0
  50. package/dist/retry-policy.js +2 -0
  51. package/dist/retry-policy.js.map +1 -0
  52. package/dist/storage-utils.d.ts +2 -0
  53. package/dist/storage-utils.d.ts.map +1 -0
  54. package/dist/storage-utils.js +2 -0
  55. package/dist/storage-utils.js.map +1 -0
  56. package/dist/streaming.d.ts +2 -0
  57. package/dist/streaming.d.ts.map +1 -0
  58. package/dist/streaming.js +2 -0
  59. package/dist/streaming.js.map +1 -0
  60. package/dist/string-utils.d.ts +2 -0
  61. package/dist/string-utils.d.ts.map +1 -0
  62. package/dist/string-utils.js +2 -0
  63. package/dist/string-utils.js.map +1 -0
  64. package/dist/utils/core/ApiClient.d.ts +94 -0
  65. package/dist/utils/core/ApiClient.d.ts.map +1 -0
  66. package/dist/utils/core/ApiClient.js +291 -0
  67. package/dist/utils/core/ApiClient.js.map +1 -0
  68. package/dist/utils/core/ErrorBoundary.d.ts +141 -0
  69. package/dist/utils/core/ErrorBoundary.d.ts.map +1 -0
  70. package/dist/utils/core/ErrorBoundary.js +322 -0
  71. package/dist/utils/core/ErrorBoundary.js.map +1 -0
  72. package/dist/utils/core/Logger.d.ts +39 -0
  73. package/dist/utils/core/Logger.d.ts.map +1 -0
  74. package/dist/utils/core/Logger.js +154 -0
  75. package/dist/utils/core/Logger.js.map +1 -0
  76. package/dist/utils/core/Profiler.d.ts +8 -0
  77. package/dist/utils/core/Profiler.d.ts.map +1 -0
  78. package/dist/utils/core/Profiler.js +18 -0
  79. package/dist/utils/core/Profiler.js.map +1 -0
  80. package/dist/utils/core/RateLimiter.d.ts +74 -0
  81. package/dist/utils/core/RateLimiter.d.ts.map +1 -0
  82. package/dist/utils/core/RateLimiter.js +170 -0
  83. package/dist/utils/core/RateLimiter.js.map +1 -0
  84. package/dist/utils/core/RequestCache.d.ts +64 -0
  85. package/dist/utils/core/RequestCache.d.ts.map +1 -0
  86. package/dist/utils/core/RequestCache.js +139 -0
  87. package/dist/utils/core/RequestCache.js.map +1 -0
  88. package/dist/utils/core/RequestDeduplicator.d.ts +41 -0
  89. package/dist/utils/core/RequestDeduplicator.d.ts.map +1 -0
  90. package/dist/utils/core/RequestDeduplicator.js +83 -0
  91. package/dist/utils/core/RequestDeduplicator.js.map +1 -0
  92. package/dist/utils/core/ResponseValidator.d.ts +26 -0
  93. package/dist/utils/core/ResponseValidator.d.ts.map +1 -0
  94. package/dist/utils/core/ResponseValidator.js +140 -0
  95. package/dist/utils/core/ResponseValidator.js.map +1 -0
  96. package/dist/utils/core/RetryPolicy.d.ts +43 -0
  97. package/dist/utils/core/RetryPolicy.d.ts.map +1 -0
  98. package/dist/utils/core/RetryPolicy.js +119 -0
  99. package/dist/utils/core/RetryPolicy.js.map +1 -0
  100. package/dist/utils/core/debug.d.ts +46 -0
  101. package/dist/utils/core/debug.d.ts.map +1 -0
  102. package/dist/utils/core/debug.js +83 -0
  103. package/dist/utils/core/debug.js.map +1 -0
  104. package/dist/utils/core/index.d.ts +11 -0
  105. package/dist/utils/core/index.d.ts.map +1 -0
  106. package/dist/utils/core/index.js +11 -0
  107. package/dist/utils/core/index.js.map +1 -0
  108. package/dist/utils/helpers/ArrayUtils.d.ts +134 -0
  109. package/dist/utils/helpers/ArrayUtils.d.ts.map +1 -0
  110. package/dist/utils/helpers/ArrayUtils.js +301 -0
  111. package/dist/utils/helpers/ArrayUtils.js.map +1 -0
  112. package/dist/utils/helpers/CacheManager.d.ts +67 -0
  113. package/dist/utils/helpers/CacheManager.d.ts.map +1 -0
  114. package/dist/utils/helpers/CacheManager.js +222 -0
  115. package/dist/utils/helpers/CacheManager.js.map +1 -0
  116. package/dist/utils/helpers/CompressionUtils.d.ts +80 -0
  117. package/dist/utils/helpers/CompressionUtils.d.ts.map +1 -0
  118. package/dist/utils/helpers/CompressionUtils.js +224 -0
  119. package/dist/utils/helpers/CompressionUtils.js.map +1 -0
  120. package/dist/utils/helpers/CryptoUtils.d.ts +70 -0
  121. package/dist/utils/helpers/CryptoUtils.d.ts.map +1 -0
  122. package/dist/utils/helpers/CryptoUtils.js +215 -0
  123. package/dist/utils/helpers/CryptoUtils.js.map +1 -0
  124. package/dist/utils/helpers/DateUtils.d.ts +31 -0
  125. package/dist/utils/helpers/DateUtils.d.ts.map +1 -0
  126. package/dist/utils/helpers/DateUtils.js +104 -0
  127. package/dist/utils/helpers/DateUtils.js.map +1 -0
  128. package/dist/utils/helpers/DiffUtils.d.ts +61 -0
  129. package/dist/utils/helpers/DiffUtils.d.ts.map +1 -0
  130. package/dist/utils/helpers/DiffUtils.js +249 -0
  131. package/dist/utils/helpers/DiffUtils.js.map +1 -0
  132. package/dist/utils/helpers/EnvManager.d.ts +7 -0
  133. package/dist/utils/helpers/EnvManager.d.ts.map +1 -0
  134. package/dist/utils/helpers/EnvManager.js +19 -0
  135. package/dist/utils/helpers/EnvManager.js.map +1 -0
  136. package/dist/utils/helpers/EventEmitter.d.ts +78 -0
  137. package/dist/utils/helpers/EventEmitter.d.ts.map +1 -0
  138. package/dist/utils/helpers/EventEmitter.js +208 -0
  139. package/dist/utils/helpers/EventEmitter.js.map +1 -0
  140. package/dist/utils/helpers/FileUploadHelper.d.ts +44 -0
  141. package/dist/utils/helpers/FileUploadHelper.d.ts.map +1 -0
  142. package/dist/utils/helpers/FileUploadHelper.js +127 -0
  143. package/dist/utils/helpers/FileUploadHelper.js.map +1 -0
  144. package/dist/utils/helpers/FormUtils.d.ts +162 -0
  145. package/dist/utils/helpers/FormUtils.d.ts.map +1 -0
  146. package/dist/utils/helpers/FormUtils.js +378 -0
  147. package/dist/utils/helpers/FormUtils.js.map +1 -0
  148. package/dist/utils/helpers/ObjectUtils.d.ts +102 -0
  149. package/dist/utils/helpers/ObjectUtils.d.ts.map +1 -0
  150. package/dist/utils/helpers/ObjectUtils.js +297 -0
  151. package/dist/utils/helpers/ObjectUtils.js.map +1 -0
  152. package/dist/utils/helpers/PaginationHelper.d.ts +127 -0
  153. package/dist/utils/helpers/PaginationHelper.d.ts.map +1 -0
  154. package/dist/utils/helpers/PaginationHelper.js +259 -0
  155. package/dist/utils/helpers/PaginationHelper.js.map +1 -0
  156. package/dist/utils/helpers/PollingHelper.d.ts +64 -0
  157. package/dist/utils/helpers/PollingHelper.d.ts.map +1 -0
  158. package/dist/utils/helpers/PollingHelper.js +131 -0
  159. package/dist/utils/helpers/PollingHelper.js.map +1 -0
  160. package/dist/utils/helpers/StorageUtils.d.ts +9 -0
  161. package/dist/utils/helpers/StorageUtils.d.ts.map +1 -0
  162. package/dist/utils/helpers/StorageUtils.js +33 -0
  163. package/dist/utils/helpers/StorageUtils.js.map +1 -0
  164. package/dist/utils/helpers/StreamingHelper.d.ts +35 -0
  165. package/dist/utils/helpers/StreamingHelper.d.ts.map +1 -0
  166. package/dist/utils/helpers/StreamingHelper.js +167 -0
  167. package/dist/utils/helpers/StreamingHelper.js.map +1 -0
  168. package/dist/utils/helpers/StringUtils.d.ts +42 -0
  169. package/dist/utils/helpers/StringUtils.d.ts.map +1 -0
  170. package/dist/utils/helpers/StringUtils.js +173 -0
  171. package/dist/utils/helpers/StringUtils.js.map +1 -0
  172. package/dist/utils/helpers/TimeUtils.d.ts +87 -0
  173. package/dist/utils/helpers/TimeUtils.d.ts.map +1 -0
  174. package/dist/utils/helpers/TimeUtils.js +234 -0
  175. package/dist/utils/helpers/TimeUtils.js.map +1 -0
  176. package/dist/utils/helpers/Validator.d.ts +31 -0
  177. package/dist/utils/helpers/Validator.d.ts.map +1 -0
  178. package/dist/utils/helpers/Validator.js +156 -0
  179. package/dist/utils/helpers/Validator.js.map +1 -0
  180. package/dist/utils/helpers/WebSocketHelper.d.ts +63 -0
  181. package/dist/utils/helpers/WebSocketHelper.d.ts.map +1 -0
  182. package/dist/utils/helpers/WebSocketHelper.js +200 -0
  183. package/dist/utils/helpers/WebSocketHelper.js.map +1 -0
  184. package/dist/utils/helpers/index.d.ts +20 -0
  185. package/dist/utils/helpers/index.d.ts.map +1 -0
  186. package/dist/utils/helpers/index.js +20 -0
  187. package/dist/utils/helpers/index.js.map +1 -0
  188. package/dist/utils/index.d.ts +21 -0
  189. package/dist/utils/index.d.ts.map +1 -0
  190. package/dist/utils/index.js +21 -0
  191. package/dist/utils/index.js.map +1 -0
  192. package/dist/validator.d.ts +2 -0
  193. package/dist/validator.d.ts.map +1 -0
  194. package/dist/validator.js +2 -0
  195. package/dist/validator.js.map +1 -0
  196. package/dist/websocket.d.ts +2 -0
  197. package/dist/websocket.d.ts.map +1 -0
  198. package/dist/websocket.js +2 -0
  199. package/dist/websocket.js.map +1 -0
  200. package/package.json +189 -0
package/bin/sutils.js ADDED
@@ -0,0 +1,9 @@
1
+ #!/usr/bin/env node
2
+ import { runCli } from "../dist/cli/index.js";
3
+
4
+ try {
5
+ await runCli(process.argv.slice(2));
6
+ } catch (error) {
7
+ console.error(error);
8
+ process.exit(1);
9
+ }
@@ -0,0 +1,2 @@
1
+ export * from "./utils/core/ApiClient.js";
2
+ //# sourceMappingURL=api-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-client.d.ts","sourceRoot":"","sources":["../src/api-client.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from "./utils/core/ApiClient.js";
2
+ //# sourceMappingURL=api-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-client.js","sourceRoot":"","sources":["../src/api-client.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function runCli(argv: string[]): Promise<void>;
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"AAuBA,wBAAsB,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAiB1D"}
@@ -0,0 +1,401 @@
1
+ import fs from "node:fs/promises";
2
+ import path from "node:path";
3
+ import { fileURLToPath } from "node:url";
4
+ import { generateTypesFromEndpoint } from "./type-generator.js";
5
+ const DEFAULT_API_DIR = "api";
6
+ const DEFAULT_HOOKS_DIR = "hooks";
7
+ export async function runCli(argv) {
8
+ if (argv.length === 0 || argv[0] === "--help" || argv[0] === "-h") {
9
+ printHelp();
10
+ return;
11
+ }
12
+ const [command, target, ...rest] = argv;
13
+ if (command === "create") {
14
+ await handleCreate(target, rest);
15
+ }
16
+ else if (command === "types") {
17
+ await handleTypes(target, rest);
18
+ }
19
+ else {
20
+ console.error(`\u001b[31mUnknown command:\u001b[0m ${command}`);
21
+ printHelp();
22
+ process.exit(1);
23
+ }
24
+ }
25
+ async function handleCreate(resource, args) {
26
+ if (!resource || resource.startsWith("--")) {
27
+ console.error("\u001b[31mMissing resource name.\u001b[0m");
28
+ printCreateHelp();
29
+ process.exit(1);
30
+ }
31
+ const flags = parseCreateFlags(args);
32
+ const resourceSegments = resource.split("/").filter(Boolean);
33
+ if (resourceSegments.length === 0) {
34
+ console.error("\u001b[31mResource name cannot be empty.\u001b[0m");
35
+ process.exit(1);
36
+ }
37
+ const config = {
38
+ apiDir: flags.apiDir ?? DEFAULT_API_DIR,
39
+ hooksDir: flags.hooksDir ?? DEFAULT_HOOKS_DIR,
40
+ force: Boolean(flags.force),
41
+ route: flags.route ?? `/${resourceSegments.join("/")}`,
42
+ resourceSegments,
43
+ };
44
+ await createResourceFiles(config);
45
+ }
46
+ async function handleTypes(endpoint, args) {
47
+ if (!endpoint) {
48
+ console.error("\u001b[31mMissing endpoint URL.\u001b[0m");
49
+ printTypesHelp();
50
+ process.exit(1);
51
+ }
52
+ const flags = parseTypesFlags(args);
53
+ await generateTypesFromEndpoint({
54
+ endpoint,
55
+ method: (flags.method ?? "GET"),
56
+ output: flags.output,
57
+ name: flags.name,
58
+ headers: flags.headers,
59
+ });
60
+ }
61
+ function parseCreateFlags(args) {
62
+ const flags = {};
63
+ for (const arg of args) {
64
+ if (!arg.startsWith("--")) {
65
+ console.warn(`Ignoring unexpected argument "${arg}".`);
66
+ continue;
67
+ }
68
+ const withoutDashes = arg.slice(2);
69
+ const [rawKey, rawValue] = withoutDashes.split("=", 2);
70
+ const key = rawKey.trim();
71
+ if (key === "force") {
72
+ flags.force = rawValue === undefined ? true : rawValue === "true";
73
+ continue;
74
+ }
75
+ if (rawValue === undefined) {
76
+ console.warn(`Flag "--${key}" requires a value; ignoring.`);
77
+ continue;
78
+ }
79
+ switch (key) {
80
+ case "apiDir":
81
+ flags.apiDir = rawValue;
82
+ break;
83
+ case "hooksDir":
84
+ flags.hooksDir = rawValue;
85
+ break;
86
+ case "route":
87
+ flags.route = rawValue;
88
+ break;
89
+ default:
90
+ console.warn(`Unrecognized flag "--${key}"; ignoring.`);
91
+ }
92
+ }
93
+ return flags;
94
+ }
95
+ function parseTypesFlags(args) {
96
+ const flags = { headers: {} };
97
+ for (const arg of args) {
98
+ if (!arg.startsWith("--")) {
99
+ console.warn(`Ignoring unexpected argument "${arg}".`);
100
+ continue;
101
+ }
102
+ const withoutDashes = arg.slice(2);
103
+ const [rawKey, rawValue] = withoutDashes.split("=", 2);
104
+ const key = rawKey.trim();
105
+ if (rawValue === undefined) {
106
+ console.warn(`Flag "--${key}" requires a value; ignoring.`);
107
+ continue;
108
+ }
109
+ switch (key) {
110
+ case "method":
111
+ flags.method = rawValue.toUpperCase();
112
+ break;
113
+ case "output":
114
+ flags.output = rawValue;
115
+ break;
116
+ case "name":
117
+ flags.name = rawValue;
118
+ break;
119
+ case "header":
120
+ const [headerKey, headerValue] = rawValue.split(":", 2);
121
+ if (headerKey && headerValue) {
122
+ flags.headers[headerKey.trim()] = headerValue.trim();
123
+ }
124
+ break;
125
+ default:
126
+ console.warn(`Unrecognized flag "--${key}"; ignoring.`);
127
+ }
128
+ }
129
+ return flags;
130
+ }
131
+ async function createResourceFiles(config) {
132
+ const { apiDir, hooksDir, force, resourceSegments, route } = config;
133
+ const lastSegment = resourceSegments[resourceSegments.length - 1];
134
+ const pascalPlural = toPascalCase(lastSegment);
135
+ const singularSegment = toSingular(lastSegment);
136
+ const pascalSingular = toPascalCase(singularSegment);
137
+ const resolvedRoute = route.startsWith("/") ? route : `/${route}`;
138
+ const resourceKey = resourceSegments.join("/");
139
+ const apiResourceDir = path.join(process.cwd(), apiDir, ...resourceSegments);
140
+ const hooksResourceDir = path.join(process.cwd(), hooksDir, ...resourceSegments);
141
+ await fs.mkdir(apiResourceDir, { recursive: true });
142
+ await fs.mkdir(hooksResourceDir, { recursive: true });
143
+ const apiFilePath = path.join(apiResourceDir, "index.ts");
144
+ const hooksFilePath = path.join(hooksResourceDir, `use${pascalPlural}.ts`);
145
+ const hooksIndexPath = path.join(hooksResourceDir, "index.ts");
146
+ const apiImportPath = buildImportPath(hooksResourceDir, apiResourceDir);
147
+ await writeFileIfAllowed(apiFilePath, buildApiTemplate({
148
+ pluralPascal: pascalPlural,
149
+ singularPascal: pascalSingular,
150
+ route: resolvedRoute,
151
+ }), force);
152
+ await writeFileIfAllowed(hooksFilePath, buildHooksTemplate({
153
+ pascalPlural,
154
+ pascalSingular,
155
+ resourceKey,
156
+ apiImportPath,
157
+ }), force);
158
+ await writeFileIfAllowed(hooksIndexPath, `export * from "./use${pascalPlural}";\n`, force);
159
+ console.log(`Scaffolded "${resourceKey}" under "${apiDir}" and "${hooksDir}".`);
160
+ }
161
+ function buildImportPath(fromDir, toDir) {
162
+ const relativePath = path.relative(fromDir, toDir).replace(/\\/g, "/");
163
+ if (!relativePath.startsWith(".")) {
164
+ return `./${relativePath}`;
165
+ }
166
+ return relativePath;
167
+ }
168
+ async function writeFileIfAllowed(filePath, content, force) {
169
+ try {
170
+ await fs.access(filePath);
171
+ if (!force) {
172
+ console.warn(`Skipping existing file: ${filePath}`);
173
+ return;
174
+ }
175
+ }
176
+ catch {
177
+ // file does not exist
178
+ }
179
+ await fs.writeFile(filePath, content, "utf8");
180
+ console.log(`Generated ${filePath}`);
181
+ }
182
+ function buildApiTemplate(options) {
183
+ const { pluralPascal, singularPascal, route } = options;
184
+ return `import type { ApiClient } from "bytekit";
185
+
186
+ const RESOURCE_PATH = "${route}";
187
+
188
+ export interface ${singularPascal}Dto {
189
+ id: string;
190
+ /** Extend with the fields returned by the API. */
191
+ }
192
+
193
+ export type Create${singularPascal}Dto = Omit<${singularPascal}Dto, "id">;
194
+ export type Update${singularPascal}Dto = Partial<Omit<${singularPascal}Dto, "id">>;
195
+
196
+ export type ${singularPascal}Filters = Record<string, string | number | boolean | undefined>;
197
+
198
+ export const list${pluralPascal} = (
199
+ client: ApiClient,
200
+ filters?: ${singularPascal}Filters
201
+ ) => client.get<${singularPascal}Dto[]>(RESOURCE_PATH, { searchParams: filters });
202
+
203
+ export const get${singularPascal} = (client: ApiClient, id: string) =>
204
+ client.get<${singularPascal}Dto>(RESOURCE_PATH + "/" + id);
205
+
206
+ export const create${singularPascal} = (client: ApiClient, payload: Create${singularPascal}Dto) =>
207
+ client.post<${singularPascal}Dto>(RESOURCE_PATH, { body: payload });
208
+
209
+ export const update${singularPascal} = (
210
+ client: ApiClient,
211
+ id: string,
212
+ payload: Update${singularPascal}Dto
213
+ ) => client.patch<${singularPascal}Dto>(RESOURCE_PATH + "/" + id, { body: payload });
214
+
215
+ export const delete${singularPascal} = (client: ApiClient, id: string) =>
216
+ client.delete<void>(RESOURCE_PATH + "/" + id);
217
+
218
+ `;
219
+ }
220
+ function buildHooksTemplate(options) {
221
+ const { pascalPlural, pascalSingular, resourceKey, apiImportPath } = options;
222
+ return `import {
223
+ useMutation,
224
+ useQuery,
225
+ useQueryClient,
226
+ type UseMutationOptions,
227
+ type UseQueryOptions,
228
+ } from "@tanstack/react-query";
229
+ import type { ApiClient } from "bytekit";
230
+ import {
231
+ list${pascalPlural},
232
+ get${pascalSingular},
233
+ create${pascalSingular},
234
+ update${pascalSingular},
235
+ delete${pascalSingular},
236
+ type ${pascalSingular}Dto,
237
+ type Create${pascalSingular}Dto,
238
+ type Update${pascalSingular}Dto,
239
+ type ${pascalSingular}Filters,
240
+ } from "${apiImportPath}";
241
+
242
+ const resourceKey = ["${resourceKey}"] as const;
243
+
244
+ export const ${pascalSingular.toLowerCase()}Keys = {
245
+ all: resourceKey,
246
+ detail: (id: string) => [...resourceKey, id] as const,
247
+ };
248
+
249
+ export const use${pascalPlural} = (
250
+ client: ApiClient,
251
+ filters?: ${pascalSingular}Filters,
252
+ options?: UseQueryOptions<${pascalSingular}Dto[], Error>
253
+ ) =>
254
+ useQuery({
255
+ queryKey: filters ? [...resourceKey, filters] : resourceKey,
256
+ queryFn: () => list${pascalPlural}(client, filters),
257
+ ...options,
258
+ });
259
+
260
+ export const use${pascalSingular} = (
261
+ client: ApiClient,
262
+ id?: string,
263
+ options?: UseQueryOptions<${pascalSingular}Dto, Error>
264
+ ) =>
265
+ useQuery({
266
+ queryKey: id ? [...resourceKey, id] : [...resourceKey, "detail"],
267
+ queryFn: () => {
268
+ if (!id) {
269
+ throw new Error("${pascalSingular} id is required");
270
+ }
271
+
272
+ return get${pascalSingular}(client, id);
273
+ },
274
+ enabled: Boolean(id),
275
+ ...options,
276
+ });
277
+
278
+ type CreateMutationVars = Create${pascalSingular}Dto;
279
+ type UpdateMutationVars = {
280
+ id: string;
281
+ payload: Update${pascalSingular}Dto;
282
+ };
283
+ type DeleteMutationVars = {
284
+ id: string;
285
+ };
286
+
287
+ export const useCreate${pascalSingular} = (
288
+ client: ApiClient,
289
+ options?: UseMutationOptions<${pascalSingular}Dto, unknown, CreateMutationVars>
290
+ ) => {
291
+ const queryClient = useQueryClient();
292
+
293
+ return useMutation({
294
+ mutationFn: (payload) => create${pascalSingular}(client, payload),
295
+ ...options,
296
+ onSuccess(data, variables, context) {
297
+ queryClient.invalidateQueries(resourceKey);
298
+ options?.onSuccess?.(data, variables, context);
299
+ },
300
+ });
301
+ };
302
+
303
+ export const useUpdate${pascalSingular} = (
304
+ client: ApiClient,
305
+ options?: UseMutationOptions<${pascalSingular}Dto, unknown, UpdateMutationVars>
306
+ ) => {
307
+ const queryClient = useQueryClient();
308
+
309
+ return useMutation({
310
+ mutationFn: ({ id, payload }) => update${pascalSingular}(client, id, payload),
311
+ ...options,
312
+ onSuccess(data, variables, context) {
313
+ queryClient.invalidateQueries(resourceKey);
314
+ if (variables?.id) {
315
+ queryClient.invalidateQueries(${pascalSingular.toLowerCase()}Keys.detail(variables.id));
316
+ }
317
+ options?.onSuccess?.(data, variables, context);
318
+ },
319
+ });
320
+ };
321
+
322
+ export const useDelete${pascalSingular} = (
323
+ client: ApiClient,
324
+ options?: UseMutationOptions<void, unknown, DeleteMutationVars>
325
+ ) => {
326
+ const queryClient = useQueryClient();
327
+
328
+ return useMutation({
329
+ mutationFn: ({ id }) => delete${pascalSingular}(client, id),
330
+ ...options,
331
+ onSuccess(data, variables, context) {
332
+ queryClient.invalidateQueries(resourceKey);
333
+ if (variables?.id) {
334
+ queryClient.invalidateQueries(${pascalSingular.toLowerCase()}Keys.detail(variables.id));
335
+ }
336
+ options?.onSuccess?.(data, variables, context);
337
+ },
338
+ });
339
+ };
340
+
341
+ `;
342
+ }
343
+ function toPascalCase(value) {
344
+ return value
345
+ .split(/[^a-zA-Z0-9]/)
346
+ .filter(Boolean)
347
+ .map((segment) => segment[0].toUpperCase() + segment.slice(1).toLowerCase())
348
+ .join("");
349
+ }
350
+ function toSingular(value) {
351
+ const lower = value.toLowerCase();
352
+ if (lower.endsWith("ies")) {
353
+ return `${value.slice(0, -3)}y`;
354
+ }
355
+ if (lower.endsWith("s")) {
356
+ return value.slice(0, -1);
357
+ }
358
+ return value;
359
+ }
360
+ function printHelp() {
361
+ console.log(`sutils <command> [args]
362
+
363
+ Commands
364
+ create <resource> Scaffold API + hooks for a resource.
365
+ types <endpoint> Generate TypeScript types from API response.
366
+
367
+ Run \`sutils create --help\` or \`sutils types --help\` for details.
368
+ `);
369
+ }
370
+ function printCreateHelp() {
371
+ console.log(`sutils create <resource> [options]
372
+
373
+ Options
374
+ --apiDir=<dir> Base directory for API files (default: api).
375
+ --hooksDir=<dir> Base directory for hooks (default: hooks).
376
+ --route=</path> API route path (default: derived from resource).
377
+ --force Overwrite existing files.
378
+ `);
379
+ }
380
+ function printTypesHelp() {
381
+ console.log(`sutils types <endpoint> [options]
382
+
383
+ Options
384
+ --method=<METHOD> HTTP method (default: GET).
385
+ --output=<file> Output file path (default: types.ts).
386
+ --name=<name> Type name (default: ApiResponse).
387
+ --header=<key:value> Custom header (can be used multiple times).
388
+
389
+ Examples
390
+ sutils types https://api.example.com/users
391
+ sutils types https://api.example.com/users --output=user-types.ts --name=User
392
+ sutils types https://api.example.com/users --method=POST --header=Authorization:Bearer\ token
393
+ `);
394
+ }
395
+ if (process.argv[1] === fileURLToPath(import.meta.url)) {
396
+ runCli(process.argv.slice(2)).catch((error) => {
397
+ console.error(error);
398
+ process.exit(1);
399
+ });
400
+ }
401
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ export interface TypeGeneratorOptions {
2
+ endpoint: string;
3
+ method?: "GET" | "POST" | "PUT" | "PATCH" | "DELETE";
4
+ output?: string;
5
+ name?: string;
6
+ headers?: Record<string, string>;
7
+ }
8
+ /**
9
+ * Generate TypeScript types from API response
10
+ */
11
+ export declare function generateTypesFromEndpoint(options: TypeGeneratorOptions): Promise<void>;
12
+ //# sourceMappingURL=type-generator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"type-generator.d.ts","sourceRoot":"","sources":["../../src/cli/type-generator.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,oBAAoB;IACjC,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,GAAG,QAAQ,CAAC;IACrD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACpC;AAED;;GAEG;AACH,wBAAsB,yBAAyB,CAC3C,OAAO,EAAE,oBAAoB,GAC9B,OAAO,CAAC,IAAI,CAAC,CAyCf"}
@@ -0,0 +1,152 @@
1
+ import fs from "node:fs/promises";
2
+ import path from "node:path";
3
+ /**
4
+ * Generate TypeScript types from API response
5
+ */
6
+ export async function generateTypesFromEndpoint(options) {
7
+ const { endpoint, method = "GET", output = "types.ts", name = "ApiResponse", headers = {}, } = options;
8
+ console.log(`\n📡 Fetching ${method} ${endpoint}...`);
9
+ try {
10
+ const response = await fetch(endpoint, {
11
+ method,
12
+ headers: {
13
+ "Content-Type": "application/json",
14
+ ...headers,
15
+ },
16
+ });
17
+ if (!response.ok) {
18
+ throw new Error(`HTTP ${response.status}: ${response.statusText}`);
19
+ }
20
+ const data = await response.json();
21
+ const typeDefinition = generateTypeFromData(data, name);
22
+ const outputPath = path.join(process.cwd(), output);
23
+ await fs.writeFile(outputPath, typeDefinition, "utf8");
24
+ console.log(`✅ Types generated successfully!`);
25
+ console.log(`📝 Output: ${outputPath}\n`);
26
+ console.log("Generated types:");
27
+ console.log("─".repeat(50));
28
+ console.log(typeDefinition);
29
+ console.log("─".repeat(50));
30
+ }
31
+ catch (error) {
32
+ const message = error instanceof Error ? error.message : String(error);
33
+ console.error(`❌ Error: ${message}`);
34
+ process.exit(1);
35
+ }
36
+ }
37
+ /**
38
+ * Generate TypeScript type definition from data
39
+ */
40
+ function generateTypeFromData(data, typeName) {
41
+ const typeDefinition = inferType(data, typeName);
42
+ return `// Auto-generated types from API response\n// Generated at ${new Date().toISOString()}\n\n${typeDefinition}\n`;
43
+ }
44
+ /**
45
+ * Infer TypeScript type from data
46
+ */
47
+ function inferType(data, name, depth = 0) {
48
+ const indent = " ".repeat(depth);
49
+ if (data === null) {
50
+ return `type ${name} = null;`;
51
+ }
52
+ if (data === undefined) {
53
+ return `type ${name} = undefined;`;
54
+ }
55
+ const type = typeof data;
56
+ if (type === "boolean") {
57
+ return `type ${name} = boolean;`;
58
+ }
59
+ if (type === "number") {
60
+ return `type ${name} = number;`;
61
+ }
62
+ if (type === "string") {
63
+ return `type ${name} = string;`;
64
+ }
65
+ if (Array.isArray(data)) {
66
+ if (data.length === 0) {
67
+ return `type ${name} = unknown[];`;
68
+ }
69
+ // Infer from first element
70
+ const firstElement = data[0];
71
+ const elementType = inferElementType(firstElement);
72
+ return `type ${name} = ${elementType}[];`;
73
+ }
74
+ if (type === "object") {
75
+ return generateObjectType(data, name, depth);
76
+ }
77
+ return `type ${name} = unknown;`;
78
+ }
79
+ /**
80
+ * Generate object type definition
81
+ */
82
+ function generateObjectType(obj, name, depth) {
83
+ const indent = " ".repeat(depth);
84
+ const innerIndent = " ".repeat(depth + 1);
85
+ const properties = Object.entries(obj)
86
+ .map(([key, value]) => {
87
+ const fieldType = inferFieldType(value);
88
+ const isOptional = value === null || value === undefined ? "?" : "";
89
+ return `${innerIndent}${key}${isOptional}: ${fieldType};`;
90
+ })
91
+ .join("\n");
92
+ return `export interface ${name} {\n${properties}\n${indent}}`;
93
+ }
94
+ /**
95
+ * Infer field type from value
96
+ */
97
+ function inferFieldType(value) {
98
+ if (value === null) {
99
+ return "null";
100
+ }
101
+ if (value === undefined) {
102
+ return "undefined";
103
+ }
104
+ const type = typeof value;
105
+ if (type === "boolean") {
106
+ return "boolean";
107
+ }
108
+ if (type === "number") {
109
+ return "number";
110
+ }
111
+ if (type === "string") {
112
+ return "string";
113
+ }
114
+ if (Array.isArray(value)) {
115
+ if (value.length === 0) {
116
+ return "unknown[]";
117
+ }
118
+ const elementType = inferElementType(value[0]);
119
+ return `${elementType}[]`;
120
+ }
121
+ if (type === "object") {
122
+ // For inline objects, use Record
123
+ return "Record<string, unknown>";
124
+ }
125
+ return "unknown";
126
+ }
127
+ /**
128
+ * Infer element type from array element
129
+ */
130
+ function inferElementType(element) {
131
+ if (element === null || element === undefined) {
132
+ return "unknown";
133
+ }
134
+ const type = typeof element;
135
+ if (type === "boolean") {
136
+ return "boolean";
137
+ }
138
+ if (type === "number") {
139
+ return "number";
140
+ }
141
+ if (type === "string") {
142
+ return "string";
143
+ }
144
+ if (Array.isArray(element)) {
145
+ return "unknown[]";
146
+ }
147
+ if (type === "object") {
148
+ return "Record<string, unknown>";
149
+ }
150
+ return "unknown";
151
+ }
152
+ //# sourceMappingURL=type-generator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"type-generator.js","sourceRoot":"","sources":["../../src/cli/type-generator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from "./utils/helpers/DateUtils.js";
2
+ //# sourceMappingURL=date-utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"date-utils.d.ts","sourceRoot":"","sources":["../src/date-utils.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from "./utils/helpers/DateUtils.js";
2
+ //# sourceMappingURL=date-utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"date-utils.js","sourceRoot":"","sources":["../src/date-utils.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from "./utils/core/debug.js";
2
+ //# sourceMappingURL=debug.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug.d.ts","sourceRoot":"","sources":["../src/debug.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
package/dist/debug.js ADDED
@@ -0,0 +1,2 @@
1
+ export * from "./utils/core/debug.js";
2
+ //# sourceMappingURL=debug.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug.js","sourceRoot":"","sources":["../src/debug.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from "./utils/helpers/EnvManager.js";
2
+ //# sourceMappingURL=env-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"env-manager.d.ts","sourceRoot":"","sources":["../src/env-manager.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from "./utils/helpers/EnvManager.js";
2
+ //# sourceMappingURL=env-manager.js.map