@allstak/wizard 0.1.4 → 0.1.5

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 (281) hide show
  1. package/CHANGELOG.md +42 -3
  2. package/LICENSE +191 -0
  3. package/README.md +35 -32
  4. package/dist/api/http.d.ts +2 -0
  5. package/dist/api/http.d.ts.map +1 -1
  6. package/dist/api/http.js +6 -0
  7. package/dist/api/http.js.map +1 -1
  8. package/dist/api/index.d.ts +1 -0
  9. package/dist/api/index.d.ts.map +1 -1
  10. package/dist/api/index.js +1 -0
  11. package/dist/api/index.js.map +1 -1
  12. package/dist/certification/fixtures.d.ts +4 -0
  13. package/dist/certification/fixtures.d.ts.map +1 -0
  14. package/dist/certification/fixtures.js +109 -0
  15. package/dist/certification/fixtures.js.map +1 -0
  16. package/dist/certification/gates.d.ts +10 -0
  17. package/dist/certification/gates.d.ts.map +1 -0
  18. package/dist/certification/gates.js +20 -0
  19. package/dist/certification/gates.js.map +1 -0
  20. package/dist/certification/index.d.ts +6 -0
  21. package/dist/certification/index.d.ts.map +1 -0
  22. package/dist/certification/index.js +5 -0
  23. package/dist/certification/index.js.map +1 -0
  24. package/dist/certification/live-backend.d.ts +50 -0
  25. package/dist/certification/live-backend.d.ts.map +1 -0
  26. package/dist/certification/live-backend.js +422 -0
  27. package/dist/certification/live-backend.js.map +1 -0
  28. package/dist/certification/packages.d.ts +3 -0
  29. package/dist/certification/packages.d.ts.map +1 -0
  30. package/dist/certification/packages.js +49 -0
  31. package/dist/certification/packages.js.map +1 -0
  32. package/dist/certification/process.d.ts +8 -0
  33. package/dist/certification/process.d.ts.map +1 -0
  34. package/dist/certification/process.js +77 -0
  35. package/dist/certification/process.js.map +1 -0
  36. package/dist/certification/report.d.ts +3 -0
  37. package/dist/certification/report.d.ts.map +1 -0
  38. package/dist/certification/report.js +38 -0
  39. package/dist/certification/report.js.map +1 -0
  40. package/dist/certification/runner.d.ts +3 -0
  41. package/dist/certification/runner.d.ts.map +1 -0
  42. package/dist/certification/runner.js +299 -0
  43. package/dist/certification/runner.js.map +1 -0
  44. package/dist/certification/runtime.d.ts +11 -0
  45. package/dist/certification/runtime.d.ts.map +1 -0
  46. package/dist/certification/runtime.js +60 -0
  47. package/dist/certification/runtime.js.map +1 -0
  48. package/dist/certification/types.d.ts +73 -0
  49. package/dist/certification/types.d.ts.map +1 -0
  50. package/dist/certification/types.js +2 -0
  51. package/dist/certification/types.js.map +1 -0
  52. package/dist/cli.js +70 -3
  53. package/dist/cli.js.map +1 -1
  54. package/dist/commands/certify.d.ts +18 -0
  55. package/dist/commands/certify.d.ts.map +1 -0
  56. package/dist/commands/certify.js +27 -0
  57. package/dist/commands/certify.js.map +1 -0
  58. package/dist/commands/init.d.ts.map +1 -1
  59. package/dist/commands/init.js +13 -0
  60. package/dist/commands/init.js.map +1 -1
  61. package/dist/commands/list.d.ts +5 -1
  62. package/dist/commands/list.d.ts.map +1 -1
  63. package/dist/commands/list.js +9 -3
  64. package/dist/commands/list.js.map +1 -1
  65. package/dist/commands/security-snapshot.d.ts +24 -0
  66. package/dist/commands/security-snapshot.d.ts.map +1 -0
  67. package/dist/commands/security-snapshot.js +113 -0
  68. package/dist/commands/security-snapshot.js.map +1 -0
  69. package/dist/index.d.ts +3 -1
  70. package/dist/index.d.ts.map +1 -1
  71. package/dist/index.js +3 -1
  72. package/dist/index.js.map +1 -1
  73. package/dist/integrations/_scaffold.d.ts +2 -1
  74. package/dist/integrations/_scaffold.d.ts.map +1 -1
  75. package/dist/integrations/_scaffold.js +36 -13
  76. package/dist/integrations/_scaffold.js.map +1 -1
  77. package/dist/integrations/_simple-scaffold.d.ts +5 -2
  78. package/dist/integrations/_simple-scaffold.d.ts.map +1 -1
  79. package/dist/integrations/_simple-scaffold.js +3 -0
  80. package/dist/integrations/_simple-scaffold.js.map +1 -1
  81. package/dist/integrations/dotnet.d.ts.map +1 -1
  82. package/dist/integrations/dotnet.js +3 -0
  83. package/dist/integrations/dotnet.js.map +1 -1
  84. package/dist/integrations/expo/detect.d.ts +13 -0
  85. package/dist/integrations/expo/detect.d.ts.map +1 -0
  86. package/dist/integrations/expo/detect.js +38 -0
  87. package/dist/integrations/expo/detect.js.map +1 -0
  88. package/dist/integrations/expo/doctor.d.ts +6 -0
  89. package/dist/integrations/expo/doctor.d.ts.map +1 -0
  90. package/dist/integrations/expo/doctor.js +136 -0
  91. package/dist/integrations/expo/doctor.js.map +1 -0
  92. package/dist/integrations/expo/files.d.ts +15 -0
  93. package/dist/integrations/expo/files.d.ts.map +1 -0
  94. package/dist/integrations/expo/files.js +62 -0
  95. package/dist/integrations/expo/files.js.map +1 -0
  96. package/dist/integrations/expo/index.d.ts +24 -0
  97. package/dist/integrations/expo/index.d.ts.map +1 -0
  98. package/dist/integrations/expo/index.js +68 -0
  99. package/dist/integrations/expo/index.js.map +1 -0
  100. package/dist/integrations/expo/manifest.d.ts +3 -0
  101. package/dist/integrations/expo/manifest.d.ts.map +1 -0
  102. package/dist/integrations/expo/manifest.js +39 -0
  103. package/dist/integrations/expo/manifest.js.map +1 -0
  104. package/dist/integrations/expo/patch.d.ts +13 -0
  105. package/dist/integrations/expo/patch.d.ts.map +1 -0
  106. package/dist/integrations/expo/patch.js +215 -0
  107. package/dist/integrations/expo/patch.js.map +1 -0
  108. package/dist/integrations/expo/uninstall.d.ts +4 -0
  109. package/dist/integrations/expo/uninstall.d.ts.map +1 -0
  110. package/dist/integrations/expo/uninstall.js +77 -0
  111. package/dist/integrations/expo/uninstall.js.map +1 -0
  112. package/dist/integrations/expo.d.ts +8 -1
  113. package/dist/integrations/expo.d.ts.map +1 -1
  114. package/dist/integrations/expo.js +8 -11
  115. package/dist/integrations/expo.js.map +1 -1
  116. package/dist/integrations/fastify/detect.d.ts +3 -0
  117. package/dist/integrations/fastify/detect.d.ts.map +1 -0
  118. package/dist/integrations/fastify/detect.js +12 -0
  119. package/dist/integrations/fastify/detect.js.map +1 -0
  120. package/dist/integrations/fastify/doctor.d.ts +3 -0
  121. package/dist/integrations/fastify/doctor.d.ts.map +1 -0
  122. package/dist/integrations/fastify/doctor.js +81 -0
  123. package/dist/integrations/fastify/doctor.js.map +1 -0
  124. package/dist/integrations/fastify/files.d.ts +17 -0
  125. package/dist/integrations/fastify/files.d.ts.map +1 -0
  126. package/dist/integrations/fastify/files.js +51 -0
  127. package/dist/integrations/fastify/files.js.map +1 -0
  128. package/dist/integrations/fastify/index.d.ts +3 -0
  129. package/dist/integrations/fastify/index.d.ts.map +1 -0
  130. package/dist/integrations/fastify/index.js +47 -0
  131. package/dist/integrations/fastify/index.js.map +1 -0
  132. package/dist/integrations/fastify/manifest.d.ts +3 -0
  133. package/dist/integrations/fastify/manifest.d.ts.map +1 -0
  134. package/dist/integrations/fastify/manifest.js +34 -0
  135. package/dist/integrations/fastify/manifest.js.map +1 -0
  136. package/dist/integrations/fastify/patch.d.ts +27 -0
  137. package/dist/integrations/fastify/patch.d.ts.map +1 -0
  138. package/dist/integrations/fastify/patch.js +91 -0
  139. package/dist/integrations/fastify/patch.js.map +1 -0
  140. package/dist/integrations/fastify/uninstall.d.ts +4 -0
  141. package/dist/integrations/fastify/uninstall.d.ts.map +1 -0
  142. package/dist/integrations/fastify/uninstall.js +18 -0
  143. package/dist/integrations/fastify/uninstall.js.map +1 -0
  144. package/dist/integrations/fastify.d.ts +5 -1
  145. package/dist/integrations/fastify.d.ts.map +1 -1
  146. package/dist/integrations/fastify.js +5 -9
  147. package/dist/integrations/fastify.js.map +1 -1
  148. package/dist/integrations/flutter.d.ts.map +1 -1
  149. package/dist/integrations/flutter.js +3 -0
  150. package/dist/integrations/flutter.js.map +1 -1
  151. package/dist/integrations/go/index.d.ts +3 -0
  152. package/dist/integrations/go/index.d.ts.map +1 -0
  153. package/dist/integrations/go/index.js +199 -0
  154. package/dist/integrations/go/index.js.map +1 -0
  155. package/dist/integrations/go.d.ts.map +1 -1
  156. package/dist/integrations/go.js +5 -2
  157. package/dist/integrations/go.js.map +1 -1
  158. package/dist/integrations/java/index.d.ts +3 -0
  159. package/dist/integrations/java/index.d.ts.map +1 -0
  160. package/dist/integrations/java/index.js +472 -0
  161. package/dist/integrations/java/index.js.map +1 -0
  162. package/dist/integrations/java.d.ts.map +1 -1
  163. package/dist/integrations/java.js +5 -2
  164. package/dist/integrations/java.js.map +1 -1
  165. package/dist/integrations/js/manifest.d.ts.map +1 -1
  166. package/dist/integrations/js/manifest.js +3 -0
  167. package/dist/integrations/js/manifest.js.map +1 -1
  168. package/dist/integrations/nestjs/detect.d.ts +3 -0
  169. package/dist/integrations/nestjs/detect.d.ts.map +1 -0
  170. package/dist/integrations/nestjs/detect.js +12 -0
  171. package/dist/integrations/nestjs/detect.js.map +1 -0
  172. package/dist/integrations/nestjs/doctor.d.ts +3 -0
  173. package/dist/integrations/nestjs/doctor.d.ts.map +1 -0
  174. package/dist/integrations/nestjs/doctor.js +76 -0
  175. package/dist/integrations/nestjs/doctor.js.map +1 -0
  176. package/dist/integrations/nestjs/files.d.ts +18 -0
  177. package/dist/integrations/nestjs/files.d.ts.map +1 -0
  178. package/dist/integrations/nestjs/files.js +39 -0
  179. package/dist/integrations/nestjs/files.js.map +1 -0
  180. package/dist/integrations/nestjs/index.d.ts +3 -0
  181. package/dist/integrations/nestjs/index.d.ts.map +1 -0
  182. package/dist/integrations/nestjs/index.js +43 -0
  183. package/dist/integrations/nestjs/index.js.map +1 -0
  184. package/dist/integrations/nestjs/manifest.d.ts +3 -0
  185. package/dist/integrations/nestjs/manifest.d.ts.map +1 -0
  186. package/dist/integrations/nestjs/manifest.js +32 -0
  187. package/dist/integrations/nestjs/manifest.js.map +1 -0
  188. package/dist/integrations/nestjs/patch.d.ts +25 -0
  189. package/dist/integrations/nestjs/patch.d.ts.map +1 -0
  190. package/dist/integrations/nestjs/patch.js +66 -0
  191. package/dist/integrations/nestjs/patch.js.map +1 -0
  192. package/dist/integrations/nestjs/uninstall.d.ts +4 -0
  193. package/dist/integrations/nestjs/uninstall.d.ts.map +1 -0
  194. package/dist/integrations/nestjs/uninstall.js +18 -0
  195. package/dist/integrations/nestjs/uninstall.js.map +1 -0
  196. package/dist/integrations/nestjs.d.ts +5 -1
  197. package/dist/integrations/nestjs.d.ts.map +1 -1
  198. package/dist/integrations/nestjs.js +5 -9
  199. package/dist/integrations/nestjs.js.map +1 -1
  200. package/dist/integrations/next/index.js +2 -2
  201. package/dist/integrations/next/index.js.map +1 -1
  202. package/dist/integrations/next/manifest.d.ts.map +1 -1
  203. package/dist/integrations/next/manifest.js +4 -1
  204. package/dist/integrations/next/manifest.js.map +1 -1
  205. package/dist/integrations/next/patch.js +8 -3
  206. package/dist/integrations/next/patch.js.map +1 -1
  207. package/dist/integrations/next/uninstall.d.ts.map +1 -1
  208. package/dist/integrations/next/uninstall.js +10 -1
  209. package/dist/integrations/next/uninstall.js.map +1 -1
  210. package/dist/integrations/otel.d.ts.map +1 -1
  211. package/dist/integrations/otel.js +4 -1
  212. package/dist/integrations/otel.js.map +1 -1
  213. package/dist/integrations/php.d.ts.map +1 -1
  214. package/dist/integrations/php.js +16 -3
  215. package/dist/integrations/php.js.map +1 -1
  216. package/dist/integrations/python/index.d.ts +3 -0
  217. package/dist/integrations/python/index.d.ts.map +1 -0
  218. package/dist/integrations/python/index.js +222 -0
  219. package/dist/integrations/python/index.js.map +1 -0
  220. package/dist/integrations/python.d.ts.map +1 -1
  221. package/dist/integrations/python.js +5 -2
  222. package/dist/integrations/python.js.map +1 -1
  223. package/dist/integrations/react/doctor.d.ts.map +1 -1
  224. package/dist/integrations/react/doctor.js +41 -8
  225. package/dist/integrations/react/doctor.js.map +1 -1
  226. package/dist/integrations/react/index.d.ts.map +1 -1
  227. package/dist/integrations/react/index.js +1 -4
  228. package/dist/integrations/react/index.js.map +1 -1
  229. package/dist/integrations/react/manifest.d.ts.map +1 -1
  230. package/dist/integrations/react/manifest.js +4 -1
  231. package/dist/integrations/react/manifest.js.map +1 -1
  232. package/dist/integrations/react/patch.d.ts.map +1 -1
  233. package/dist/integrations/react/patch.js +120 -8
  234. package/dist/integrations/react/patch.js.map +1 -1
  235. package/dist/integrations/react/uninstall.d.ts.map +1 -1
  236. package/dist/integrations/react/uninstall.js +20 -1
  237. package/dist/integrations/react/uninstall.js.map +1 -1
  238. package/dist/integrations/react-native.d.ts.map +1 -1
  239. package/dist/integrations/react-native.js +3 -0
  240. package/dist/integrations/react-native.js.map +1 -1
  241. package/dist/integrations/ruby.d.ts.map +1 -1
  242. package/dist/integrations/ruby.js +3 -0
  243. package/dist/integrations/ruby.js.map +1 -1
  244. package/dist/output/human.d.ts.map +1 -1
  245. package/dist/output/human.js +38 -7
  246. package/dist/output/human.js.map +1 -1
  247. package/dist/registry/index.d.ts.map +1 -1
  248. package/dist/registry/index.js +9 -23
  249. package/dist/registry/index.js.map +1 -1
  250. package/dist/registry/manifest.d.ts +8 -0
  251. package/dist/registry/manifest.d.ts.map +1 -1
  252. package/dist/security-snapshot/builder.d.ts +3 -0
  253. package/dist/security-snapshot/builder.d.ts.map +1 -0
  254. package/dist/security-snapshot/builder.js +343 -0
  255. package/dist/security-snapshot/builder.js.map +1 -0
  256. package/dist/security-snapshot/client.d.ts +3 -0
  257. package/dist/security-snapshot/client.d.ts.map +1 -0
  258. package/dist/security-snapshot/client.js +38 -0
  259. package/dist/security-snapshot/client.js.map +1 -0
  260. package/dist/security-snapshot/index.d.ts +4 -0
  261. package/dist/security-snapshot/index.d.ts.map +1 -0
  262. package/dist/security-snapshot/index.js +3 -0
  263. package/dist/security-snapshot/index.js.map +1 -0
  264. package/dist/security-snapshot/types.d.ts +57 -0
  265. package/dist/security-snapshot/types.d.ts.map +1 -0
  266. package/dist/security-snapshot/types.js +2 -0
  267. package/dist/security-snapshot/types.js.map +1 -0
  268. package/dist/sourcemaps/next.js +3 -3
  269. package/dist/sourcemaps/next.js.map +1 -1
  270. package/dist/sourcemaps/vite.d.ts.map +1 -1
  271. package/dist/sourcemaps/vite.js +92 -9
  272. package/dist/sourcemaps/vite.js.map +1 -1
  273. package/docs/architecture/v02-sourcemaps-e2e-spec.md +1 -1
  274. package/docs/beta/expo.md +69 -0
  275. package/docs/beta/fastify.md +62 -0
  276. package/docs/beta/known-limitations.md +14 -14
  277. package/docs/beta/nestjs.md +69 -0
  278. package/docs/beta/next.md +7 -8
  279. package/docs/beta/react.md +23 -15
  280. package/docs/beta/reliability.md +33 -0
  281. package/package.json +11 -3
@@ -0,0 +1,343 @@
1
+ import { existsSync, readdirSync, readFileSync } from 'node:fs';
2
+ import { basename, dirname, relative, resolve } from 'node:path';
3
+ import { detectFramework, detectMonorepo, detectPackageManager } from '../detect/index.js';
4
+ const PARSER_VERSION = '2026-05-08';
5
+ const DEFAULT_MAX_DEPENDENCIES = 10_000;
6
+ export function buildDependencySnapshot(opts = {}) {
7
+ const cwd = resolve(opts.cwd ?? process.cwd());
8
+ const projectRoot = findSnapshotRoot(cwd);
9
+ const detected = detectFramework(projectRoot);
10
+ const pm = detectPackageManager(projectRoot).pm;
11
+ const monorepo = detectMonorepo(cwd);
12
+ const packageDirs = discoverPackageDirs(projectRoot, cwd);
13
+ const dependencies = new Map();
14
+ const manifests = new Set();
15
+ const lockfiles = new Set();
16
+ let truncated = false;
17
+ for (const packageDir of packageDirs) {
18
+ const pkgPath = resolve(packageDir, 'package.json');
19
+ const pkg = readPackageJson(pkgPath);
20
+ if (pkg) {
21
+ manifests.add(rel(projectRoot, pkgPath));
22
+ addPackageJsonDependencies(dependencies, pkg, rel(projectRoot, pkgPath), rel(projectRoot, packageDir), pm);
23
+ }
24
+ }
25
+ const packageLock = resolve(projectRoot, 'package-lock.json');
26
+ if (existsSync(packageLock)) {
27
+ lockfiles.add('package-lock.json');
28
+ parsePackageLock(dependencies, packageLock, projectRoot, pm);
29
+ }
30
+ const pnpmLock = resolve(projectRoot, 'pnpm-lock.yaml');
31
+ if (existsSync(pnpmLock)) {
32
+ lockfiles.add('pnpm-lock.yaml');
33
+ parsePnpmLock(dependencies, pnpmLock, projectRoot, pm);
34
+ }
35
+ const yarnLock = resolve(projectRoot, 'yarn.lock');
36
+ if (existsSync(yarnLock)) {
37
+ lockfiles.add('yarn.lock');
38
+ parseYarnLock(dependencies, yarnLock, projectRoot, pm);
39
+ }
40
+ const pomFiles = discoverPomFiles(projectRoot, cwd);
41
+ for (const pomPath of pomFiles) {
42
+ manifests.add(rel(projectRoot, pomPath));
43
+ parsePomXml(dependencies, pomPath, projectRoot);
44
+ }
45
+ const max = opts.maxDependencies ?? DEFAULT_MAX_DEPENDENCIES;
46
+ let items = Array.from(dependencies.values())
47
+ .filter((dep) => dep.name && dep.version && !dep.version.includes('${'))
48
+ .sort((a, b) => `${a.ecosystem}:${a.name}:${a.version}`.localeCompare(`${b.ecosystem}:${b.name}:${b.version}`));
49
+ if (items.length > max) {
50
+ items = items.slice(0, max);
51
+ truncated = true;
52
+ }
53
+ return {
54
+ sourceType: opts.sourceType ?? 'wizard',
55
+ sourceRef: opts.sourceRef ?? workspaceName(packageDirs[0] ?? cwd) ?? undefined,
56
+ sourceCommitSha: opts.sourceCommitSha,
57
+ sourceBranch: opts.sourceBranch,
58
+ environment: opts.environment,
59
+ manifestCount: manifests.size,
60
+ dependencies: items,
61
+ metadata: {
62
+ framework: opts.framework ?? detected.candidates[0],
63
+ runtime: detected.candidates.includes('java') ? 'java' : detected.packageJson ? 'node' : undefined,
64
+ environment: opts.environment,
65
+ packageManager: pm,
66
+ nodeVersion: process.versions.node,
67
+ javaVersion: process.env.JAVA_VERSION,
68
+ monorepoTool: monorepo.tool,
69
+ workspaceName: workspaceName(packageDirs[0] ?? cwd),
70
+ lockfiles: Array.from(lockfiles),
71
+ manifests: Array.from(manifests).sort(),
72
+ parserVersion: PARSER_VERSION,
73
+ truncated,
74
+ },
75
+ };
76
+ }
77
+ function findSnapshotRoot(cwd) {
78
+ const monorepo = detectMonorepo(cwd);
79
+ if (monorepo.rootDir)
80
+ return monorepo.rootDir;
81
+ let dir = cwd;
82
+ while (true) {
83
+ if (existsSync(resolve(dir, 'package-lock.json')) || existsSync(resolve(dir, 'pnpm-lock.yaml')) || existsSync(resolve(dir, 'yarn.lock'))) {
84
+ return dir;
85
+ }
86
+ if (existsSync(resolve(dir, 'package.json')) || existsSync(resolve(dir, 'pom.xml')))
87
+ return dir;
88
+ const parent = dirname(dir);
89
+ if (parent === dir)
90
+ return cwd;
91
+ dir = parent;
92
+ }
93
+ }
94
+ function discoverPackageDirs(root, cwd) {
95
+ const dirs = new Set();
96
+ const rootPkg = readPackageJson(resolve(root, 'package.json'));
97
+ if (rootPkg)
98
+ dirs.add(root);
99
+ const patterns = workspacePatterns(rootPkg);
100
+ for (const pattern of patterns) {
101
+ for (const dir of expandWorkspacePattern(root, pattern))
102
+ dirs.add(dir);
103
+ }
104
+ const cwdPkg = readPackageJson(resolve(cwd, 'package.json'));
105
+ if (cwdPkg)
106
+ dirs.add(cwd);
107
+ return Array.from(dirs).sort();
108
+ }
109
+ function discoverPomFiles(root, cwd) {
110
+ const found = new Set();
111
+ for (const dir of [root, cwd]) {
112
+ const pom = resolve(dir, 'pom.xml');
113
+ if (existsSync(pom))
114
+ found.add(pom);
115
+ }
116
+ const modules = readPomModules(resolve(root, 'pom.xml'));
117
+ for (const mod of modules) {
118
+ const pom = resolve(root, mod, 'pom.xml');
119
+ if (existsSync(pom))
120
+ found.add(pom);
121
+ }
122
+ return Array.from(found).sort();
123
+ }
124
+ function readPackageJson(path) {
125
+ if (!existsSync(path))
126
+ return null;
127
+ try {
128
+ return JSON.parse(readFileSync(path, 'utf8'));
129
+ }
130
+ catch {
131
+ return null;
132
+ }
133
+ }
134
+ function addPackageJsonDependencies(out, pkg, sourceFile, packageDir, manager) {
135
+ const groups = [
136
+ ['production', pkg.dependencies],
137
+ ['development', pkg.devDependencies],
138
+ ['optional', pkg.optionalDependencies],
139
+ ['peer', pkg.peerDependencies],
140
+ ];
141
+ for (const [scope, deps] of groups) {
142
+ for (const [name, version] of Object.entries(deps ?? {})) {
143
+ add(out, {
144
+ ecosystem: 'npm',
145
+ name,
146
+ version: normalizeVersion(version),
147
+ scope,
148
+ direct: true,
149
+ sourceFile,
150
+ manager,
151
+ path: packageDir && packageDir !== '.' ? [packageDir] : undefined,
152
+ });
153
+ }
154
+ }
155
+ }
156
+ function parsePackageLock(out, lockPath, root, manager) {
157
+ try {
158
+ const lock = JSON.parse(readFileSync(lockPath, 'utf8'));
159
+ const rootPackage = lock.packages?.[''];
160
+ const directNames = new Set([
161
+ ...Object.keys(rootPackage?.dependencies ?? {}),
162
+ ...Object.keys(rootPackage?.devDependencies ?? {}),
163
+ ...Object.keys(rootPackage?.optionalDependencies ?? {}),
164
+ ...Object.keys(rootPackage?.peerDependencies ?? {}),
165
+ ]);
166
+ for (const [path, meta] of Object.entries(lock.packages ?? {})) {
167
+ if (!path.startsWith('node_modules/') || !meta.version)
168
+ continue;
169
+ const name = packageNameFromNodeModules(path);
170
+ if (!name)
171
+ continue;
172
+ add(out, {
173
+ ecosystem: 'npm',
174
+ name,
175
+ version: normalizeVersion(meta.version),
176
+ scope: meta.optional ? 'optional' : meta.peer ? 'peer' : meta.dev ? 'development' : 'production',
177
+ direct: directNames.has(name),
178
+ sourceFile: rel(root, lockPath),
179
+ manager,
180
+ });
181
+ }
182
+ for (const [name, meta] of Object.entries(lock.dependencies ?? {})) {
183
+ if (!meta.version)
184
+ continue;
185
+ add(out, {
186
+ ecosystem: 'npm',
187
+ name,
188
+ version: normalizeVersion(meta.version),
189
+ scope: meta.optional ? 'optional' : meta.dev ? 'development' : 'production',
190
+ direct: false,
191
+ sourceFile: rel(root, lockPath),
192
+ manager,
193
+ });
194
+ }
195
+ }
196
+ catch {
197
+ // Ignore malformed lockfiles; package.json fallback remains useful.
198
+ }
199
+ }
200
+ function parsePnpmLock(out, lockPath, root, manager) {
201
+ const text = readFileSync(lockPath, 'utf8');
202
+ const seen = new Set();
203
+ for (const line of text.split(/\r?\n/)) {
204
+ const match = line.match(/^\s{2}['"]?(?:\/)?((?:@[^/\s'"]+\/)?[^@\s'":]+)@([^'":\s(]+)(?:\([^'"]+\))?['"]?:\s*$/);
205
+ if (!match)
206
+ continue;
207
+ const [, name, version] = match;
208
+ if (!name || !version || name === 'lockfileVersion' || seen.has(`${name}@${version}`))
209
+ continue;
210
+ seen.add(`${name}@${version}`);
211
+ add(out, {
212
+ ecosystem: 'npm',
213
+ name,
214
+ version: normalizeVersion(version),
215
+ scope: 'unknown',
216
+ direct: false,
217
+ sourceFile: rel(root, lockPath),
218
+ manager,
219
+ });
220
+ }
221
+ }
222
+ function parseYarnLock(out, lockPath, root, manager) {
223
+ const lines = readFileSync(lockPath, 'utf8').split(/\r?\n/);
224
+ for (let i = 0; i < lines.length; i += 1) {
225
+ const header = lines[i] ?? '';
226
+ if (/^\s/.test(header) || !header.includes('@') || header.startsWith('#'))
227
+ continue;
228
+ const versionLine = lines.slice(i + 1, i + 8).find((line) => /^\s+version\s+/.test(line));
229
+ if (!versionLine)
230
+ continue;
231
+ const version = versionLine.replace(/^\s+version\s+/, '').replace(/"/g, '').trim();
232
+ for (const name of packageNamesFromYarnHeader(header)) {
233
+ add(out, {
234
+ ecosystem: 'npm',
235
+ name,
236
+ version: normalizeVersion(version),
237
+ scope: 'unknown',
238
+ direct: false,
239
+ sourceFile: rel(root, lockPath),
240
+ manager,
241
+ });
242
+ }
243
+ }
244
+ }
245
+ function parsePomXml(out, pomPath, root) {
246
+ const text = readFileSync(pomPath, 'utf8');
247
+ const dependencyBlocks = text.match(/<dependency>[\s\S]*?<\/dependency>/g) ?? [];
248
+ for (const block of dependencyBlocks) {
249
+ const groupId = xmlTag(block, 'groupId');
250
+ const artifactId = xmlTag(block, 'artifactId');
251
+ const version = xmlTag(block, 'version');
252
+ if (!groupId || !artifactId || !version)
253
+ continue;
254
+ const scope = xmlTag(block, 'scope');
255
+ add(out, {
256
+ ecosystem: 'maven',
257
+ name: `${groupId}:${artifactId}`,
258
+ version: normalizeVersion(version),
259
+ scope: scope === 'test' ? 'development' : scope === 'provided' ? 'peer' : 'production',
260
+ direct: true,
261
+ sourceFile: rel(root, pomPath),
262
+ manager: 'maven',
263
+ });
264
+ }
265
+ }
266
+ function readPomModules(pomPath) {
267
+ if (!existsSync(pomPath))
268
+ return [];
269
+ const text = readFileSync(pomPath, 'utf8');
270
+ return Array.from(text.matchAll(/<module>([^<]+)<\/module>/g)).map((match) => match[1].trim()).filter(Boolean);
271
+ }
272
+ function xmlTag(text, tag) {
273
+ const match = text.match(new RegExp(`<${tag}>\\s*([^<]+?)\\s*</${tag}>`));
274
+ return match?.[1]?.trim() ?? null;
275
+ }
276
+ function packageNameFromNodeModules(path) {
277
+ const parts = path.split('node_modules/').filter(Boolean);
278
+ const last = parts[parts.length - 1];
279
+ if (!last)
280
+ return null;
281
+ const segs = last.split('/');
282
+ return segs[0]?.startsWith('@') ? `${segs[0]}/${segs[1]}` : segs[0] ?? null;
283
+ }
284
+ function packageNamesFromYarnHeader(header) {
285
+ return header
286
+ .replace(/:$/, '')
287
+ .split(/,\s*/)
288
+ .map((entry) => entry.trim().replace(/^"|"$/g, ''))
289
+ .map((entry) => {
290
+ if (entry.startsWith('@')) {
291
+ const at = entry.indexOf('@', 1);
292
+ return at > 0 ? entry.slice(0, at) : entry;
293
+ }
294
+ const at = entry.indexOf('@');
295
+ return at > 0 ? entry.slice(0, at) : entry;
296
+ })
297
+ .filter(Boolean);
298
+ }
299
+ function add(out, dep) {
300
+ if (!dep.name || !dep.version || dep.version === '*' || dep.version.startsWith('file:') || dep.version.startsWith('workspace:'))
301
+ return;
302
+ const key = `${dep.ecosystem}:${dep.name}:${dep.version}`;
303
+ const existing = out.get(key);
304
+ if (!existing) {
305
+ out.set(key, dep);
306
+ return;
307
+ }
308
+ if (!existing.direct && dep.direct)
309
+ existing.direct = true;
310
+ if (existing.scope === 'unknown' && dep.scope !== 'unknown')
311
+ existing.scope = dep.scope;
312
+ if (!existing.sourceFile && dep.sourceFile)
313
+ existing.sourceFile = dep.sourceFile;
314
+ }
315
+ function normalizeVersion(version) {
316
+ return version.trim().replace(/^[~^=<> ]+/, '').replace(/^v/, '');
317
+ }
318
+ function workspacePatterns(pkg) {
319
+ if (!pkg?.workspaces)
320
+ return [];
321
+ if (Array.isArray(pkg.workspaces))
322
+ return pkg.workspaces;
323
+ return pkg.workspaces.packages ?? [];
324
+ }
325
+ function expandWorkspacePattern(root, pattern) {
326
+ if (!pattern.endsWith('/*'))
327
+ return [];
328
+ const base = resolve(root, pattern.slice(0, -2));
329
+ if (!existsSync(base))
330
+ return [];
331
+ return readdirSync(base, { withFileTypes: true })
332
+ .filter((entry) => entry.isDirectory())
333
+ .map((entry) => resolve(base, entry.name))
334
+ .filter((dir) => existsSync(resolve(dir, 'package.json')));
335
+ }
336
+ function workspaceName(dir) {
337
+ const pkg = readPackageJson(resolve(dir, 'package.json'));
338
+ return pkg?.name ?? basename(dir) ?? null;
339
+ }
340
+ function rel(root, path) {
341
+ return relative(root, path) || basename(path);
342
+ }
343
+ //# sourceMappingURL=builder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"builder.js","sourceRoot":"","sources":["../../src/security-snapshot/builder.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { BuiltDependencySnapshot, SecuritySnapshotUploadResult } from './types.js';
2
+ export declare function uploadSecuritySnapshot(host: string, accessToken: string, projectId: string, snapshot: BuiltDependencySnapshot): Promise<SecuritySnapshotUploadResult>;
3
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/security-snapshot/client.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,uBAAuB,EAAE,4BAA4B,EAAiC,MAAM,YAAY,CAAC;AAiBvH,wBAAsB,sBAAsB,CAC1C,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,uBAAuB,GAChC,OAAO,CAAC,4BAA4B,CAAC,CA+BvC"}
@@ -0,0 +1,38 @@
1
+ import { apiRequest } from '../api/http.js';
2
+ export async function uploadSecuritySnapshot(host, accessToken, projectId, snapshot) {
3
+ const payload = { projectId, ...snapshot };
4
+ const res = await apiRequest(host, {
5
+ method: 'POST',
6
+ path: '/api/v1/security/dependency-snapshots',
7
+ body: payload,
8
+ auth: { kind: 'bearer', token: accessToken },
9
+ timeoutMs: 12_000,
10
+ });
11
+ const uploaded = unwrap(res.data);
12
+ let vulnerabilityCount = null;
13
+ try {
14
+ const summary = await apiRequest(host, {
15
+ method: 'GET',
16
+ path: '/api/v1/security/risk-summary',
17
+ query: { projectId },
18
+ auth: { kind: 'bearer', token: accessToken },
19
+ timeoutMs: 8_000,
20
+ });
21
+ vulnerabilityCount = unwrap(summary.data).open ?? null;
22
+ }
23
+ catch {
24
+ vulnerabilityCount = null;
25
+ }
26
+ return {
27
+ snapshotId: uploaded.id,
28
+ dependencyCount: uploaded.dependencyCount ?? snapshot.dependencies.length,
29
+ vulnerabilityCount,
30
+ processingStatus: uploaded.processingStatus,
31
+ };
32
+ }
33
+ function unwrap(body) {
34
+ if (body && typeof body === 'object' && 'data' in body)
35
+ return body.data;
36
+ return body;
37
+ }
38
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/security-snapshot/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAkB5C,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,IAAY,EACZ,WAAmB,EACnB,SAAiB,EACjB,QAAiC;IAEjC,MAAM,OAAO,GAAkC,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,CAAC;IAC1E,MAAM,GAAG,GAAG,MAAM,UAAU,CAAmD,IAAI,EAAE;QACnF,MAAM,EAAE,MAAM;QACd,IAAI,EAAE,uCAAuC;QAC7C,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE;QAC5C,SAAS,EAAE,MAAM;KAClB,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClC,IAAI,kBAAkB,GAAkB,IAAI,CAAC;IAC7C,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,UAAU,CAAyD,IAAI,EAAE;YAC7F,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,+BAA+B;YACrC,KAAK,EAAE,EAAE,SAAS,EAAE;YACpB,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,WAAW,EAAE;YAC5C,SAAS,EAAE,KAAK;SACjB,CAAC,CAAC;QACH,kBAAkB,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC;IACzD,CAAC;IAAC,MAAM,CAAC;QACP,kBAAkB,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED,OAAO;QACL,UAAU,EAAE,QAAQ,CAAC,EAAE;QACvB,eAAe,EAAE,QAAQ,CAAC,eAAe,IAAI,QAAQ,CAAC,YAAY,CAAC,MAAM;QACzE,kBAAkB;QAClB,gBAAgB,EAAE,QAAQ,CAAC,gBAAgB;KAC5C,CAAC;AACJ,CAAC;AAED,SAAS,MAAM,CAAI,IAAwB;IACzC,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,MAAM,IAAI,IAAI;QAAE,OAAQ,IAAuB,CAAC,IAAS,CAAC;IAClG,OAAO,IAAS,CAAC;AACnB,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { buildDependencySnapshot } from './builder.js';
2
+ export { uploadSecuritySnapshot } from './client.js';
3
+ export type { BuildSnapshotOptions, BuiltDependencySnapshot, DependencyScope, SecuritySnapshotUploadResult, SnapshotDependency, SnapshotEcosystem, SnapshotRuntimeMetadata, UploadSecuritySnapshotRequest, } from './types.js';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/security-snapshot/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC;AACrD,YAAY,EACV,oBAAoB,EACpB,uBAAuB,EACvB,eAAe,EACf,4BAA4B,EAC5B,kBAAkB,EAClB,iBAAiB,EACjB,uBAAuB,EACvB,6BAA6B,GAC9B,MAAM,YAAY,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { buildDependencySnapshot } from './builder.js';
2
+ export { uploadSecuritySnapshot } from './client.js';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/security-snapshot/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,57 @@
1
+ export type DependencyScope = 'production' | 'development' | 'optional' | 'peer' | 'unknown';
2
+ export type SnapshotEcosystem = 'npm' | 'maven';
3
+ export interface SnapshotDependency {
4
+ ecosystem: SnapshotEcosystem;
5
+ name: string;
6
+ version: string;
7
+ scope: DependencyScope;
8
+ direct: boolean;
9
+ sourceFile: string;
10
+ manager?: string;
11
+ path?: string[];
12
+ }
13
+ export interface SnapshotRuntimeMetadata {
14
+ framework?: string;
15
+ runtime?: string;
16
+ environment?: string;
17
+ packageManager?: string;
18
+ nodeVersion?: string;
19
+ javaVersion?: string;
20
+ monorepoTool?: string | null;
21
+ workspaceName?: string | null;
22
+ }
23
+ export interface BuiltDependencySnapshot {
24
+ sourceType: 'wizard' | 'ci';
25
+ sourceRef?: string;
26
+ sourceCommitSha?: string;
27
+ sourceBranch?: string;
28
+ environment?: string;
29
+ manifestCount: number;
30
+ dependencies: SnapshotDependency[];
31
+ metadata: SnapshotRuntimeMetadata & {
32
+ lockfiles: string[];
33
+ manifests: string[];
34
+ parserVersion: string;
35
+ truncated: boolean;
36
+ };
37
+ }
38
+ export interface BuildSnapshotOptions {
39
+ cwd?: string;
40
+ sourceType?: 'wizard' | 'ci';
41
+ environment?: string;
42
+ sourceRef?: string;
43
+ sourceCommitSha?: string;
44
+ sourceBranch?: string;
45
+ framework?: string;
46
+ maxDependencies?: number;
47
+ }
48
+ export interface UploadSecuritySnapshotRequest extends BuiltDependencySnapshot {
49
+ projectId: string;
50
+ }
51
+ export interface SecuritySnapshotUploadResult {
52
+ snapshotId?: string;
53
+ dependencyCount: number;
54
+ vulnerabilityCount: number | null;
55
+ processingStatus?: string;
56
+ }
57
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/security-snapshot/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,eAAe,GAAG,YAAY,GAAG,aAAa,GAAG,UAAU,GAAG,MAAM,GAAG,SAAS,CAAC;AAC7F,MAAM,MAAM,iBAAiB,GAAG,KAAK,GAAG,OAAO,CAAC;AAEhD,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,iBAAiB,CAAC;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,eAAe,CAAC;IACvB,MAAM,EAAE,OAAO,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,MAAM,WAAW,uBAAuB;IACtC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC/B;AAED,MAAM,WAAW,uBAAuB;IACtC,UAAU,EAAE,QAAQ,GAAG,IAAI,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,kBAAkB,EAAE,CAAC;IACnC,QAAQ,EAAE,uBAAuB,GAAG;QAClC,SAAS,EAAE,MAAM,EAAE,CAAC;QACpB,SAAS,EAAE,MAAM,EAAE,CAAC;QACpB,aAAa,EAAE,MAAM,CAAC;QACtB,SAAS,EAAE,OAAO,CAAC;KACpB,CAAC;CACH;AAED,MAAM,WAAW,oBAAoB;IACnC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,QAAQ,GAAG,IAAI,CAAC;IAC7B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,6BAA8B,SAAQ,uBAAuB;IAC5E,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,4BAA4B;IAC3C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,EAAE,MAAM,CAAC;IACxB,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/security-snapshot/types.ts"],"names":[],"mappings":""}
@@ -1,7 +1,7 @@
1
1
  import { existsSync, readFileSync } from 'node:fs';
2
2
  import { resolve } from 'node:path';
3
3
  import { appendManagedBlock, removeManagedSourceBlock } from '../patchers/source-block.js';
4
- const PKG = '@allstak/js/next';
4
+ const PKG = '@allstak/next';
5
5
  function locate(projectRoot) {
6
6
  for (const c of ['next.config.ts', 'next.config.mjs', 'next.config.js']) {
7
7
  const full = resolve(projectRoot, c);
@@ -23,8 +23,8 @@ export const nextSourceMapProvider = {
23
23
  return;
24
24
  await appendManagedBlock(tx, cfg, [
25
25
  `// allstak-wizard: enable browser source maps to unblock symbolication.`,
26
- `// const { withAllStak } = require('${PKG}');`,
27
- `// module.exports = withAllStak({ ...nextConfig, productionBrowserSourceMaps: true });`,
26
+ `// Install ${PKG} and initialize it from instrumentation.ts.`,
27
+ `// Keep productionBrowserSourceMaps: true in your Next config if browser symbolication is needed.`,
28
28
  ].join('\n'), { style: 'slash', validateJs: true });
29
29
  },
30
30
  async unwire(_ctx, tx) {
@@ -1 +1 @@
1
- {"version":3,"file":"next.js","sourceRoot":"","sources":["../../src/sourcemaps/next.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,MAAM,6BAA6B,CAAC;AAE3F,MAAM,GAAG,GAAG,kBAAkB,CAAC;AAE/B,SAAS,MAAM,CAAC,WAAmB;IACjC,KAAK,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,iBAAiB,EAAE,gBAAgB,CAAC,EAAE,CAAC;QACxE,MAAM,IAAI,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACrC,IAAI,UAAU,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;IACpC,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAsB;IACtD,EAAE,EAAE,MAAM;IACV,KAAK,EAAE,2BAA2B;IAClC,aAAa,EAAE,GAAG;IAElB,KAAK,CAAC,MAAM,CAAC,GAAG;QACd,OAAO,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE;QACjB,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,MAAM,kBAAkB,CACtB,EAAE,EACF,GAAG,EACH;YACE,yEAAyE;YACzE,yCAAyC,GAAG,KAAK;YACjD,0FAA0F;SAC3F,CAAC,IAAI,CAAC,IAAI,CAAC,EACZ,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,CACrC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE;QACnB,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,MAAM,wBAAwB,CAAC,EAAE,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,GAAG;QACd,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,GAAG;YAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;QAC1E,MAAM,GAAG,GAAG,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACtC,OAAO,GAAG,CAAC,QAAQ,CAAC,gBAAgB,CAAC;YACnC,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE;YACvD,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC;IAC9D,CAAC;CACF,CAAC"}
1
+ {"version":3,"file":"next.js","sourceRoot":"","sources":["../../src/sourcemaps/next.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,MAAM,6BAA6B,CAAC;AAE3F,MAAM,GAAG,GAAG,eAAe,CAAC;AAE5B,SAAS,MAAM,CAAC,WAAmB;IACjC,KAAK,MAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,iBAAiB,EAAE,gBAAgB,CAAC,EAAE,CAAC;QACxE,MAAM,IAAI,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACrC,IAAI,UAAU,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;IACpC,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,MAAM,qBAAqB,GAAsB;IACtD,EAAE,EAAE,MAAM;IACV,KAAK,EAAE,2BAA2B;IAClC,aAAa,EAAE,GAAG;IAElB,KAAK,CAAC,MAAM,CAAC,GAAG;QACd,OAAO,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE;QACjB,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,MAAM,kBAAkB,CACtB,EAAE,EACF,GAAG,EACH;YACE,yEAAyE;YACzE,gBAAgB,GAAG,6CAA6C;YAChE,qGAAqG;SACtG,CAAC,IAAI,CAAC,IAAI,CAAC,EACZ,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,CACrC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE;QACnB,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,MAAM,wBAAwB,CAAC,EAAE,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;IACnD,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,GAAG;QACd,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,GAAG;YAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;QAC1E,MAAM,GAAG,GAAG,YAAY,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QACtC,OAAO,GAAG,CAAC,QAAQ,CAAC,gBAAgB,CAAC;YACnC,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE;YACvD,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC;IAC9D,CAAC;CACF,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"vite.d.ts","sourceRoot":"","sources":["../../src/sourcemaps/vite.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAmB,MAAM,eAAe,CAAC;AAexE,eAAO,MAAM,qBAAqB,EAAE,iBAiDnC,CAAC"}
1
+ {"version":3,"file":"vite.d.ts","sourceRoot":"","sources":["../../src/sourcemaps/vite.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAmB,MAAM,eAAe,CAAC;AAgBxE,eAAO,MAAM,qBAAqB,EAAE,iBA8DnC,CAAC"}