@dreamboard-games/cli 0.1.30-alpha.2 → 0.1.30-alpha.20

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 (136) hide show
  1. package/README.md +25 -107
  2. package/dist/agent-verifier/agent-workspace-verifier.mjs +1682 -0
  3. package/dist/agent-verifier/agent-workspace-verifier.mjs.map +1 -0
  4. package/dist/agent-verifier/chunk-4I2WWAPK.mjs +399 -0
  5. package/dist/agent-verifier/chunk-4I2WWAPK.mjs.map +1 -0
  6. package/dist/agent-verifier/chunk-BWBN2TDJ.mjs +2811 -0
  7. package/dist/agent-verifier/chunk-BWBN2TDJ.mjs.map +1 -0
  8. package/dist/agent-verifier/chunk-DQUYBIGQ.mjs +353 -0
  9. package/dist/agent-verifier/chunk-DQUYBIGQ.mjs.map +1 -0
  10. package/dist/agent-verifier/chunk-F2DIOJJZ.mjs +302 -0
  11. package/dist/agent-verifier/chunk-F2DIOJJZ.mjs.map +1 -0
  12. package/dist/agent-verifier/chunk-GCFGAFYC.mjs +720 -0
  13. package/dist/agent-verifier/chunk-GCFGAFYC.mjs.map +1 -0
  14. package/dist/agent-verifier/chunk-GWRZRWCF.mjs +107 -0
  15. package/dist/agent-verifier/chunk-GWRZRWCF.mjs.map +1 -0
  16. package/dist/agent-verifier/chunk-H6XDQJ3N.mjs +11 -0
  17. package/dist/agent-verifier/chunk-HUBV22JQ.mjs +89 -0
  18. package/dist/agent-verifier/chunk-HUBV22JQ.mjs.map +1 -0
  19. package/dist/agent-verifier/chunk-IWB4L2HV.mjs +273 -0
  20. package/dist/agent-verifier/chunk-IWB4L2HV.mjs.map +1 -0
  21. package/dist/agent-verifier/chunk-JZTH3EMV.mjs +14523 -0
  22. package/dist/agent-verifier/chunk-JZTH3EMV.mjs.map +1 -0
  23. package/dist/agent-verifier/chunk-KDAQ4CZY.mjs +192 -0
  24. package/dist/agent-verifier/chunk-KDAQ4CZY.mjs.map +1 -0
  25. package/dist/agent-verifier/chunk-M7UVBANQ.mjs +58 -0
  26. package/dist/agent-verifier/chunk-M7UVBANQ.mjs.map +1 -0
  27. package/dist/agent-verifier/chunk-MYMVXTZT.mjs +766 -0
  28. package/dist/agent-verifier/chunk-MYMVXTZT.mjs.map +1 -0
  29. package/dist/agent-verifier/chunk-OJFZVGEL.mjs +492 -0
  30. package/dist/agent-verifier/chunk-OJFZVGEL.mjs.map +1 -0
  31. package/dist/agent-verifier/chunk-QD4SQNUP.mjs +75 -0
  32. package/dist/agent-verifier/chunk-QD4SQNUP.mjs.map +1 -0
  33. package/dist/agent-verifier/chunk-RDYXWXXC.mjs +47 -0
  34. package/dist/agent-verifier/chunk-RDYXWXXC.mjs.map +1 -0
  35. package/dist/agent-verifier/chunk-TIDX3YLW.mjs +158 -0
  36. package/dist/agent-verifier/chunk-TIDX3YLW.mjs.map +1 -0
  37. package/dist/agent-verifier/chunk-TTB7AIHZ.mjs +214 -0
  38. package/dist/agent-verifier/chunk-TTB7AIHZ.mjs.map +1 -0
  39. package/dist/agent-verifier/chunk-UXGTT25Q.mjs +59 -0
  40. package/dist/agent-verifier/chunk-UXGTT25Q.mjs.map +1 -0
  41. package/dist/agent-verifier/chunk-YE7UAO3T.mjs +129 -0
  42. package/dist/agent-verifier/chunk-YE7UAO3T.mjs.map +1 -0
  43. package/dist/agent-verifier/chunk-ZEELHSY3.mjs +20 -0
  44. package/dist/agent-verifier/chunk-ZEELHSY3.mjs.map +1 -0
  45. package/dist/agent-verifier/global-config-IXZLY4BS.mjs +19 -0
  46. package/dist/agent-verifier/keychain-backend-UF3Z26JM.mjs +140 -0
  47. package/dist/agent-verifier/keychain-backend-UF3Z26JM.mjs.map +1 -0
  48. package/dist/agent-verifier/local-files-OF4QFISU.mjs +45 -0
  49. package/dist/agent-verifier/local-files-OF4QFISU.mjs.map +1 -0
  50. package/dist/agent-verifier/local-typecheck-DHVLM37Z.mjs +150 -0
  51. package/dist/agent-verifier/local-typecheck-DHVLM37Z.mjs.map +1 -0
  52. package/dist/agent-verifier/materialize-workspace-VS5RHSBO.mjs +90 -0
  53. package/dist/agent-verifier/materialize-workspace-VS5RHSBO.mjs.map +1 -0
  54. package/dist/agent-verifier/project-state-XKUSCFSV.mjs +33 -0
  55. package/dist/agent-verifier/project-state-XKUSCFSV.mjs.map +1 -0
  56. package/dist/agent-verifier/prompt-VKHMCQT6.mjs +756 -0
  57. package/dist/agent-verifier/prompt-VKHMCQT6.mjs.map +1 -0
  58. package/dist/agent-verifier/reducer-bundle-preflight-GLUJKTWU.mjs +312 -0
  59. package/dist/agent-verifier/reducer-bundle-preflight-GLUJKTWU.mjs.map +1 -0
  60. package/dist/agent-verifier/reducer-contract-preflight-WVQQPW5F.mjs +46 -0
  61. package/dist/agent-verifier/reducer-contract-preflight-WVQQPW5F.mjs.map +1 -0
  62. package/dist/agent-verifier/reducer-native-test-harness-H6G6RBRY.mjs +3436 -0
  63. package/dist/agent-verifier/reducer-native-test-harness-H6G6RBRY.mjs.map +1 -0
  64. package/dist/agent-verifier/static-scaffold-C36KROJA.mjs +24 -0
  65. package/dist/agent-verifier/static-scaffold-C36KROJA.mjs.map +1 -0
  66. package/dist/agent-verifier/workspace-codegen-SPPVHURX.mjs +10 -0
  67. package/dist/agent-verifier/workspace-codegen-SPPVHURX.mjs.map +1 -0
  68. package/dist/agent-verifier/workspace-dependencies-5HEEKZFP.mjs +17 -0
  69. package/dist/agent-verifier/workspace-dependencies-5HEEKZFP.mjs.map +1 -0
  70. package/dist/authoring-compatibility-internal.js +12 -0
  71. package/dist/authoring-compatibility-internal.js.map +1 -0
  72. package/dist/chunk-2H7UOFLK.js +11 -0
  73. package/dist/chunk-2H7UOFLK.js.map +1 -0
  74. package/dist/chunk-5PJWUB6W.js +4281 -0
  75. package/dist/chunk-5PJWUB6W.js.map +1 -0
  76. package/dist/{chunk-TAQKH67O.js → chunk-EJGB3IR7.js} +2700 -7338
  77. package/dist/chunk-EJGB3IR7.js.map +1 -0
  78. package/dist/chunk-EQNBQVIW.js +204 -0
  79. package/dist/chunk-EQNBQVIW.js.map +1 -0
  80. package/dist/chunk-UI7NWSYA.js +334 -0
  81. package/dist/chunk-UI7NWSYA.js.map +1 -0
  82. package/dist/{global-config-S4ZIPECE.js → global-config-GK2UC2X6.js} +4 -3
  83. package/dist/global-config-GK2UC2X6.js.map +1 -0
  84. package/dist/index.js +3411 -6433
  85. package/dist/index.js.map +1 -1
  86. package/dist/internal.js +15 -9
  87. package/dist/{keychain-backend-HDF4TZDL.js → keychain-backend-GO34KGTG.js} +12 -7
  88. package/dist/keychain-backend-GO34KGTG.js.map +1 -0
  89. package/dist/{prompt-NDV3AE5L.js → prompt-GMZABCJC.js} +2 -2
  90. package/package.json +11 -20
  91. package/release/authoring-release-set.json +38 -0
  92. package/skills/dreamboard/SKILL.md +30 -28
  93. package/skills/dreamboard/references/building-your-first-game.md +15 -15
  94. package/skills/dreamboard/references/cli.md +48 -47
  95. package/skills/dreamboard/references/manifest-authoring.md +11 -3
  96. package/skills/dreamboard/references/quickstart.md +16 -13
  97. package/skills/dreamboard/references/testing.md +10 -10
  98. package/dist/chunk-N7XPNNUI.js +0 -432
  99. package/dist/chunk-N7XPNNUI.js.map +0 -1
  100. package/dist/chunk-SEGVTWSK.js +0 -44
  101. package/dist/chunk-TAQKH67O.js.map +0 -1
  102. package/dist/dev-host/components/drawer.tsx +0 -132
  103. package/dist/dev-host/components/input.tsx +0 -21
  104. package/dist/dev-host/dev-api-proxy-plugin.ts +0 -328
  105. package/dist/dev-host/dev-author-dom-warnings.ts +0 -100
  106. package/dist/dev-host/dev-diagnostics.ts +0 -62
  107. package/dist/dev-host/dev-fallback-stylesheet.ts +0 -53
  108. package/dist/dev-host/dev-hmr-guard-plugin.ts +0 -47
  109. package/dist/dev-host/dev-host-controller.ts +0 -674
  110. package/dist/dev-host/dev-host-player-query.ts +0 -17
  111. package/dist/dev-host/dev-host-session-transport.ts +0 -52
  112. package/dist/dev-host/dev-host-storage.ts +0 -56
  113. package/dist/dev-host/dev-log-relay-plugin.ts +0 -510
  114. package/dist/dev-host/dev-runtime-config.ts +0 -14
  115. package/dist/dev-host/dev-runtime-platform.ts +0 -335
  116. package/dist/dev-host/dev-virtual-modules-plugin.ts +0 -64
  117. package/dist/dev-host/host-main.css +0 -224
  118. package/dist/dev-host/host-main.tsx +0 -948
  119. package/dist/dev-host/index.html +0 -56
  120. package/dist/dev-host/lib/utils.ts +0 -6
  121. package/dist/dev-host/plugin-main.ts +0 -61
  122. package/dist/dev-host/plugin.html +0 -24
  123. package/dist/dev-host/shared-styles.css +0 -144
  124. package/dist/dev-host/start-dev-server.ts +0 -140
  125. package/dist/dev-host/virtual-modules.d.ts +0 -27
  126. package/dist/keychain-backend-HDF4TZDL.js.map +0 -1
  127. package/skills/dreamboard/scripts/events-extract.mjs +0 -218
  128. /package/dist/{chunk-SEGVTWSK.js.map → agent-verifier/chunk-H6XDQJ3N.mjs.map} +0 -0
  129. /package/dist/{global-config-S4ZIPECE.js.map → agent-verifier/global-config-IXZLY4BS.mjs.map} +0 -0
  130. /package/dist/{prompt-NDV3AE5L.js.map → prompt-GMZABCJC.js.map} +0 -0
  131. /package/{dist/scaffold → scaffold}/assets/static/app/tsconfig.framework.json +0 -0
  132. /package/{dist/scaffold → scaffold}/assets/static/app/tsconfig.json +0 -0
  133. /package/{dist/scaffold → scaffold}/assets/static/ui/index.tsx +0 -0
  134. /package/{dist/scaffold → scaffold}/assets/static/ui/style.css +0 -0
  135. /package/{dist/scaffold → scaffold}/assets/static/ui/tsconfig.framework.json +0 -0
  136. /package/{dist/scaffold → scaffold}/assets/static/ui/tsconfig.json +0 -0
@@ -0,0 +1,59 @@
1
+ #!/usr/bin/env node
2
+ import {
3
+ getCredentialFilePath
4
+ } from "./chunk-IWB4L2HV.mjs";
5
+ import {
6
+ atomicWriteFile
7
+ } from "./chunk-GWRZRWCF.mjs";
8
+ import {
9
+ ensureDir,
10
+ readJsonFile
11
+ } from "./chunk-RDYXWXXC.mjs";
12
+ import {
13
+ PROJECT_DIR_NAME
14
+ } from "./chunk-M7UVBANQ.mjs";
15
+
16
+ // src/config/global-config.ts
17
+ import os from "os";
18
+ import path from "path";
19
+ function normalizeCredentialBackend(value) {
20
+ if (value === "file" || value === "keychain") return value;
21
+ return void 0;
22
+ }
23
+ function getGlobalConfigPath() {
24
+ return path.join(os.homedir(), PROJECT_DIR_NAME, "config.json");
25
+ }
26
+ function getGlobalAuthPath() {
27
+ return getCredentialFilePath();
28
+ }
29
+ async function loadGlobalConfig() {
30
+ const config = await readJsonFile(getGlobalConfigPath()).catch(
31
+ () => ({})
32
+ );
33
+ return {
34
+ environment: config.environment,
35
+ credentialBackend: normalizeCredentialBackend(config.credentialBackend)
36
+ };
37
+ }
38
+ async function saveGlobalConfig(config) {
39
+ const configDir = path.join(os.homedir(), PROJECT_DIR_NAME);
40
+ await ensureDir(configDir);
41
+ const normalized = {
42
+ environment: config.environment,
43
+ credentialBackend: normalizeCredentialBackend(config.credentialBackend)
44
+ };
45
+ await atomicWriteFile(
46
+ getGlobalConfigPath(),
47
+ `${JSON.stringify(normalized, null, 2)}
48
+ `,
49
+ { mode: 384 }
50
+ );
51
+ }
52
+
53
+ export {
54
+ getGlobalConfigPath,
55
+ getGlobalAuthPath,
56
+ loadGlobalConfig,
57
+ saveGlobalConfig
58
+ };
59
+ //# sourceMappingURL=chunk-UXGTT25Q.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/config/global-config.ts"],"sourcesContent":["import os from \"node:os\";\nimport path from \"node:path\";\nimport type { CredentialBackendPreference, GlobalConfig } from \"../types.js\";\nimport { PROJECT_DIR_NAME } from \"../constants.js\";\nimport { ensureDir, readJsonFile } from \"../utils/fs.js\";\nimport { atomicWriteFile } from \"../utils/atomic-file.js\";\nimport { getCredentialFilePath } from \"./credential-store.js\";\n\nfunction normalizeCredentialBackend(\n value: unknown,\n): CredentialBackendPreference | undefined {\n if (value === \"file\" || value === \"keychain\") return value;\n // Tolerate unknown / malformed values rather than refusing to load the\n // whole config - an unrecognised backend name should degrade to \"use\n // the default\" instead of locking the user out of their CLI.\n return undefined;\n}\n\nexport function getGlobalConfigPath(): string {\n return path.join(os.homedir(), PROJECT_DIR_NAME, \"config.json\");\n}\n\n/**\n * Path to the on-disk credential file used by the file backend of\n * `CredentialStore`. Re-exported here to avoid circular / ad-hoc imports\n * in UI surface (`auth status`, `config show`, etc).\n */\nexport function getGlobalAuthPath(): string {\n return getCredentialFilePath();\n}\n\n/**\n * Load non-credential CLI configuration.\n *\n * Note: this function used to also load `authToken` / `refreshToken`\n * from `auth.json` and flatten them onto `GlobalConfig`. That shape\n * enabled the refresh-token-wipe bug: `saveGlobalConfig({ ...config })`\n * without explicit auth fields erased the stored refresh token.\n *\n * Credentials are now owned exclusively by `CredentialStore`. Callers\n * that need them must import `getCredentials()` directly.\n */\nexport async function loadGlobalConfig(): Promise<GlobalConfig> {\n const config = await readJsonFile<GlobalConfig>(getGlobalConfigPath()).catch(\n () => ({}) as GlobalConfig,\n );\n return {\n environment: config.environment,\n credentialBackend: normalizeCredentialBackend(config.credentialBackend),\n };\n}\n\n/**\n * Persist non-credential CLI configuration.\n *\n * This function cannot write credentials, by construction: the\n * `GlobalConfig` type has no credential fields. Credentials must be\n * persisted through `setCredentials` / `clearCredentials` from\n * `credential-store.ts`.\n */\nexport async function saveGlobalConfig(config: GlobalConfig): Promise<void> {\n const configDir = path.join(os.homedir(), PROJECT_DIR_NAME);\n await ensureDir(configDir);\n const normalized: GlobalConfig = {\n environment: config.environment,\n credentialBackend: normalizeCredentialBackend(config.credentialBackend),\n };\n await atomicWriteFile(\n getGlobalConfigPath(),\n `${JSON.stringify(normalized, null, 2)}\\n`,\n { mode: 0o600 },\n );\n}\n"],"mappings":";;;;;;;;;;;;;;;;AAAA,OAAO,QAAQ;AACf,OAAO,UAAU;AAOjB,SAAS,2BACP,OACyC;AACzC,MAAI,UAAU,UAAU,UAAU,WAAY,QAAO;AAIrD,SAAO;AACT;AAEO,SAAS,sBAA8B;AAC5C,SAAO,KAAK,KAAK,GAAG,QAAQ,GAAG,kBAAkB,aAAa;AAChE;AAOO,SAAS,oBAA4B;AAC1C,SAAO,sBAAsB;AAC/B;AAaA,eAAsB,mBAA0C;AAC9D,QAAM,SAAS,MAAM,aAA2B,oBAAoB,CAAC,EAAE;AAAA,IACrE,OAAO,CAAC;AAAA,EACV;AACA,SAAO;AAAA,IACL,aAAa,OAAO;AAAA,IACpB,mBAAmB,2BAA2B,OAAO,iBAAiB;AAAA,EACxE;AACF;AAUA,eAAsB,iBAAiB,QAAqC;AAC1E,QAAM,YAAY,KAAK,KAAK,GAAG,QAAQ,GAAG,gBAAgB;AAC1D,QAAM,UAAU,SAAS;AACzB,QAAM,aAA2B;AAAA,IAC/B,aAAa,OAAO;AAAA,IACpB,mBAAmB,2BAA2B,OAAO,iBAAiB;AAAA,EACxE;AACA,QAAM;AAAA,IACJ,oBAAoB;AAAA,IACpB,GAAG,KAAK,UAAU,YAAY,MAAM,CAAC,CAAC;AAAA;AAAA,IACtC,EAAE,MAAM,IAAM;AAAA,EAChB;AACF;","names":[]}
@@ -0,0 +1,129 @@
1
+ #!/usr/bin/env node
2
+
3
+ // src/services/project/project-state.ts
4
+ var LOCAL_MAINTAINER_SDK_PACKAGE_NAMES = [
5
+ "@dreamboard-games/api-client",
6
+ "@dreamboard-games/sdk"
7
+ ];
8
+ function getProjectAuthoringState(projectConfig) {
9
+ return projectConfig.authoring ?? {};
10
+ }
11
+ function getProjectPendingAuthoringSync(projectConfig) {
12
+ return getProjectAuthoringState(projectConfig).pendingSync;
13
+ }
14
+ function getProjectCompileState(projectConfig) {
15
+ return projectConfig.compile ?? {};
16
+ }
17
+ function getProjectLocalMaintainerRegistry(projectConfig) {
18
+ return projectConfig.localMaintainerRegistry;
19
+ }
20
+ function updateProjectAuthoringState(projectConfig, authoring) {
21
+ return {
22
+ ...projectConfig,
23
+ authoring: {
24
+ ...getProjectAuthoringState(projectConfig),
25
+ ...authoring
26
+ }
27
+ };
28
+ }
29
+ function setProjectPendingAuthoringSync(projectConfig, pendingSync) {
30
+ return updateProjectAuthoringState(projectConfig, {
31
+ pendingSync
32
+ });
33
+ }
34
+ function clearProjectPendingAuthoringSync(projectConfig) {
35
+ const authoring = getProjectAuthoringState(projectConfig);
36
+ if (!authoring.pendingSync) {
37
+ return projectConfig;
38
+ }
39
+ const { pendingSync: _pendingSync, ...rest } = authoring;
40
+ return {
41
+ ...projectConfig,
42
+ authoring: rest
43
+ };
44
+ }
45
+ function finalizeProjectPendingAuthoringSync(projectConfig) {
46
+ const authoring = getProjectAuthoringState(projectConfig);
47
+ const pendingSync = authoring.pendingSync;
48
+ if (!pendingSync) {
49
+ return projectConfig;
50
+ }
51
+ return updateProjectAuthoringState(
52
+ clearProjectPendingAuthoringSync(projectConfig),
53
+ {
54
+ authoringStateId: pendingSync.phase === "authoring_state_created" ? pendingSync.authoringStateId : authoring.authoringStateId,
55
+ revisionDigest: pendingSync.revisionDigest ?? authoring.revisionDigest,
56
+ sourceRevisionId: pendingSync.sourceRevisionId,
57
+ sourceTreeHash: pendingSync.sourceTreeHash,
58
+ manifestId: pendingSync.manifestId,
59
+ manifestContentHash: pendingSync.manifestContentHash,
60
+ localManifestContentHash: pendingSync.localManifestContentHash,
61
+ ruleId: pendingSync.ruleId
62
+ }
63
+ );
64
+ }
65
+ function updateProjectCompileState(projectConfig, compile) {
66
+ return {
67
+ ...projectConfig,
68
+ compile: {
69
+ ...getProjectCompileState(projectConfig),
70
+ ...compile
71
+ }
72
+ };
73
+ }
74
+ function setLatestCompileAttempt(projectConfig, attempt) {
75
+ return updateProjectCompileState(projectConfig, {
76
+ ...getProjectCompileState(projectConfig),
77
+ latestAttempt: attempt,
78
+ latestSuccessful: attempt.status === "successful" && attempt.resultId ? {
79
+ resultId: attempt.resultId,
80
+ authoringStateId: attempt.authoringStateId,
81
+ revisionDigest: attempt.revisionDigest
82
+ } : getProjectCompileState(projectConfig).latestSuccessful
83
+ });
84
+ }
85
+ function clearProjectCompileState(projectConfig) {
86
+ return {
87
+ ...projectConfig,
88
+ compile: {}
89
+ };
90
+ }
91
+ function updateProjectLocalMaintainerRegistry(projectConfig, localMaintainerRegistry) {
92
+ return {
93
+ ...projectConfig,
94
+ localMaintainerRegistry: sanitizeProjectLocalMaintainerRegistry(
95
+ localMaintainerRegistry
96
+ )
97
+ };
98
+ }
99
+ function sanitizeProjectLocalMaintainerRegistry(localMaintainerRegistry) {
100
+ if (!localMaintainerRegistry) return void 0;
101
+ const packages = {};
102
+ for (const packageName of LOCAL_MAINTAINER_SDK_PACKAGE_NAMES) {
103
+ const version = localMaintainerRegistry.packages[packageName];
104
+ if (version) {
105
+ packages[packageName] = version;
106
+ }
107
+ }
108
+ return {
109
+ ...localMaintainerRegistry,
110
+ packages
111
+ };
112
+ }
113
+
114
+ export {
115
+ getProjectAuthoringState,
116
+ getProjectPendingAuthoringSync,
117
+ getProjectCompileState,
118
+ getProjectLocalMaintainerRegistry,
119
+ updateProjectAuthoringState,
120
+ setProjectPendingAuthoringSync,
121
+ clearProjectPendingAuthoringSync,
122
+ finalizeProjectPendingAuthoringSync,
123
+ updateProjectCompileState,
124
+ setLatestCompileAttempt,
125
+ clearProjectCompileState,
126
+ updateProjectLocalMaintainerRegistry,
127
+ sanitizeProjectLocalMaintainerRegistry
128
+ };
129
+ //# sourceMappingURL=chunk-YE7UAO3T.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/services/project/project-state.ts"],"sourcesContent":["import type {\n LocalMaintainerRegistryConfig,\n LocalMaintainerRegistryPackages,\n LocalMaintainerSdkPackageName,\n ProjectAuthoringState,\n ProjectCompileAttempt,\n ProjectCompileState,\n ProjectConfig,\n ProjectPendingAuthoringSync,\n} from \"../../types.js\";\n\nconst LOCAL_MAINTAINER_SDK_PACKAGE_NAMES = [\n \"@dreamboard-games/api-client\",\n \"@dreamboard-games/sdk\",\n] as const satisfies readonly LocalMaintainerSdkPackageName[];\n\nexport function getProjectAuthoringState(\n projectConfig: ProjectConfig,\n): ProjectAuthoringState {\n return projectConfig.authoring ?? {};\n}\n\nexport function getProjectPendingAuthoringSync(\n projectConfig: ProjectConfig,\n): ProjectPendingAuthoringSync | undefined {\n return getProjectAuthoringState(projectConfig).pendingSync;\n}\n\nexport function getProjectCompileState(\n projectConfig: ProjectConfig,\n): ProjectCompileState {\n return projectConfig.compile ?? {};\n}\n\nexport function getProjectLocalMaintainerRegistry(\n projectConfig: ProjectConfig,\n): LocalMaintainerRegistryConfig | undefined {\n return projectConfig.localMaintainerRegistry;\n}\n\nexport function updateProjectAuthoringState(\n projectConfig: ProjectConfig,\n authoring: ProjectAuthoringState,\n): ProjectConfig {\n return {\n ...projectConfig,\n authoring: {\n ...getProjectAuthoringState(projectConfig),\n ...authoring,\n },\n };\n}\n\nexport function setProjectPendingAuthoringSync(\n projectConfig: ProjectConfig,\n pendingSync: ProjectPendingAuthoringSync,\n): ProjectConfig {\n return updateProjectAuthoringState(projectConfig, {\n pendingSync,\n });\n}\n\nexport function clearProjectPendingAuthoringSync(\n projectConfig: ProjectConfig,\n): ProjectConfig {\n const authoring = getProjectAuthoringState(projectConfig);\n if (!authoring.pendingSync) {\n return projectConfig;\n }\n\n const { pendingSync: _pendingSync, ...rest } = authoring;\n return {\n ...projectConfig,\n authoring: rest,\n };\n}\n\nexport function finalizeProjectPendingAuthoringSync(\n projectConfig: ProjectConfig,\n): ProjectConfig {\n const authoring = getProjectAuthoringState(projectConfig);\n const pendingSync = authoring.pendingSync;\n if (!pendingSync) {\n return projectConfig;\n }\n\n return updateProjectAuthoringState(\n clearProjectPendingAuthoringSync(projectConfig),\n {\n authoringStateId:\n pendingSync.phase === \"authoring_state_created\"\n ? pendingSync.authoringStateId\n : authoring.authoringStateId,\n revisionDigest: pendingSync.revisionDigest ?? authoring.revisionDigest,\n sourceRevisionId: pendingSync.sourceRevisionId,\n sourceTreeHash: pendingSync.sourceTreeHash,\n manifestId: pendingSync.manifestId,\n manifestContentHash: pendingSync.manifestContentHash,\n localManifestContentHash: pendingSync.localManifestContentHash,\n ruleId: pendingSync.ruleId,\n },\n );\n}\n\nexport function updateProjectCompileState(\n projectConfig: ProjectConfig,\n compile: ProjectCompileState,\n): ProjectConfig {\n return {\n ...projectConfig,\n compile: {\n ...getProjectCompileState(projectConfig),\n ...compile,\n },\n };\n}\n\nexport function setLatestCompileAttempt(\n projectConfig: ProjectConfig,\n attempt: ProjectCompileAttempt,\n): ProjectConfig {\n return updateProjectCompileState(projectConfig, {\n ...getProjectCompileState(projectConfig),\n latestAttempt: attempt,\n latestSuccessful:\n attempt.status === \"successful\" && attempt.resultId\n ? {\n resultId: attempt.resultId,\n authoringStateId: attempt.authoringStateId,\n revisionDigest: attempt.revisionDigest,\n }\n : getProjectCompileState(projectConfig).latestSuccessful,\n });\n}\n\nexport function clearProjectCompileState(\n projectConfig: ProjectConfig,\n): ProjectConfig {\n return {\n ...projectConfig,\n compile: {},\n };\n}\n\nexport function updateProjectLocalMaintainerRegistry(\n projectConfig: ProjectConfig,\n localMaintainerRegistry: LocalMaintainerRegistryConfig | undefined,\n): ProjectConfig {\n return {\n ...projectConfig,\n localMaintainerRegistry: sanitizeProjectLocalMaintainerRegistry(\n localMaintainerRegistry,\n ),\n };\n}\n\nexport function sanitizeProjectLocalMaintainerRegistry(\n localMaintainerRegistry: LocalMaintainerRegistryConfig | undefined,\n): LocalMaintainerRegistryConfig | undefined {\n if (!localMaintainerRegistry) return undefined;\n\n const packages: Partial<LocalMaintainerRegistryPackages> = {};\n for (const packageName of LOCAL_MAINTAINER_SDK_PACKAGE_NAMES) {\n const version = localMaintainerRegistry.packages[packageName];\n if (version) {\n packages[packageName] = version;\n }\n }\n\n return {\n ...localMaintainerRegistry,\n packages: packages as LocalMaintainerRegistryPackages,\n };\n}\n"],"mappings":";;;AAWA,IAAM,qCAAqC;AAAA,EACzC;AAAA,EACA;AACF;AAEO,SAAS,yBACd,eACuB;AACvB,SAAO,cAAc,aAAa,CAAC;AACrC;AAEO,SAAS,+BACd,eACyC;AACzC,SAAO,yBAAyB,aAAa,EAAE;AACjD;AAEO,SAAS,uBACd,eACqB;AACrB,SAAO,cAAc,WAAW,CAAC;AACnC;AAEO,SAAS,kCACd,eAC2C;AAC3C,SAAO,cAAc;AACvB;AAEO,SAAS,4BACd,eACA,WACe;AACf,SAAO;AAAA,IACL,GAAG;AAAA,IACH,WAAW;AAAA,MACT,GAAG,yBAAyB,aAAa;AAAA,MACzC,GAAG;AAAA,IACL;AAAA,EACF;AACF;AAEO,SAAS,+BACd,eACA,aACe;AACf,SAAO,4BAA4B,eAAe;AAAA,IAChD;AAAA,EACF,CAAC;AACH;AAEO,SAAS,iCACd,eACe;AACf,QAAM,YAAY,yBAAyB,aAAa;AACxD,MAAI,CAAC,UAAU,aAAa;AAC1B,WAAO;AAAA,EACT;AAEA,QAAM,EAAE,aAAa,cAAc,GAAG,KAAK,IAAI;AAC/C,SAAO;AAAA,IACL,GAAG;AAAA,IACH,WAAW;AAAA,EACb;AACF;AAEO,SAAS,oCACd,eACe;AACf,QAAM,YAAY,yBAAyB,aAAa;AACxD,QAAM,cAAc,UAAU;AAC9B,MAAI,CAAC,aAAa;AAChB,WAAO;AAAA,EACT;AAEA,SAAO;AAAA,IACL,iCAAiC,aAAa;AAAA,IAC9C;AAAA,MACE,kBACE,YAAY,UAAU,4BAClB,YAAY,mBACZ,UAAU;AAAA,MAChB,gBAAgB,YAAY,kBAAkB,UAAU;AAAA,MACxD,kBAAkB,YAAY;AAAA,MAC9B,gBAAgB,YAAY;AAAA,MAC5B,YAAY,YAAY;AAAA,MACxB,qBAAqB,YAAY;AAAA,MACjC,0BAA0B,YAAY;AAAA,MACtC,QAAQ,YAAY;AAAA,IACtB;AAAA,EACF;AACF;AAEO,SAAS,0BACd,eACA,SACe;AACf,SAAO;AAAA,IACL,GAAG;AAAA,IACH,SAAS;AAAA,MACP,GAAG,uBAAuB,aAAa;AAAA,MACvC,GAAG;AAAA,IACL;AAAA,EACF;AACF;AAEO,SAAS,wBACd,eACA,SACe;AACf,SAAO,0BAA0B,eAAe;AAAA,IAC9C,GAAG,uBAAuB,aAAa;AAAA,IACvC,eAAe;AAAA,IACf,kBACE,QAAQ,WAAW,gBAAgB,QAAQ,WACvC;AAAA,MACE,UAAU,QAAQ;AAAA,MAClB,kBAAkB,QAAQ;AAAA,MAC1B,gBAAgB,QAAQ;AAAA,IAC1B,IACA,uBAAuB,aAAa,EAAE;AAAA,EAC9C,CAAC;AACH;AAEO,SAAS,yBACd,eACe;AACf,SAAO;AAAA,IACL,GAAG;AAAA,IACH,SAAS,CAAC;AAAA,EACZ;AACF;AAEO,SAAS,qCACd,eACA,yBACe;AACf,SAAO;AAAA,IACL,GAAG;AAAA,IACH,yBAAyB;AAAA,MACvB;AAAA,IACF;AAAA,EACF;AACF;AAEO,SAAS,uCACd,yBAC2C;AAC3C,MAAI,CAAC,wBAAyB,QAAO;AAErC,QAAM,WAAqD,CAAC;AAC5D,aAAW,eAAe,oCAAoC;AAC5D,UAAM,UAAU,wBAAwB,SAAS,WAAW;AAC5D,QAAI,SAAS;AACX,eAAS,WAAW,IAAI;AAAA,IAC1B;AAAA,EACF;AAEA,SAAO;AAAA,IACL,GAAG;AAAA,IACH;AAAA,EACF;AACF;","names":[]}
@@ -0,0 +1,20 @@
1
+ #!/usr/bin/env node
2
+
3
+ // src/services/project/framework-dependencies.ts
4
+ var FRAMEWORK_REACT_VERSION = "19.2.6";
5
+ var FRAMEWORK_ZOD_VERSION = "4.4.3";
6
+ var FRAMEWORK_REACT_DEPENDENCIES = {
7
+ react: FRAMEWORK_REACT_VERSION,
8
+ "react-dom": FRAMEWORK_REACT_VERSION
9
+ };
10
+ var FRAMEWORK_PNPM_OVERRIDES = {
11
+ ...FRAMEWORK_REACT_DEPENDENCIES,
12
+ zod: FRAMEWORK_ZOD_VERSION
13
+ };
14
+
15
+ export {
16
+ FRAMEWORK_ZOD_VERSION,
17
+ FRAMEWORK_REACT_DEPENDENCIES,
18
+ FRAMEWORK_PNPM_OVERRIDES
19
+ };
20
+ //# sourceMappingURL=chunk-ZEELHSY3.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/services/project/framework-dependencies.ts"],"sourcesContent":["export const FRAMEWORK_REACT_VERSION = \"19.2.6\";\nexport const FRAMEWORK_ZOD_VERSION = \"4.4.3\";\n\nexport const FRAMEWORK_REACT_DEPENDENCIES = {\n react: FRAMEWORK_REACT_VERSION,\n \"react-dom\": FRAMEWORK_REACT_VERSION,\n} as const;\n\nexport const FRAMEWORK_PNPM_OVERRIDES = {\n ...FRAMEWORK_REACT_DEPENDENCIES,\n zod: FRAMEWORK_ZOD_VERSION,\n} as const;\n"],"mappings":";;;AAAO,IAAM,0BAA0B;AAChC,IAAM,wBAAwB;AAE9B,IAAM,+BAA+B;AAAA,EAC1C,OAAO;AAAA,EACP,aAAa;AACf;AAEO,IAAM,2BAA2B;AAAA,EACtC,GAAG;AAAA,EACH,KAAK;AACP;","names":[]}
@@ -0,0 +1,19 @@
1
+ #!/usr/bin/env node
2
+ import {
3
+ getGlobalAuthPath,
4
+ getGlobalConfigPath,
5
+ loadGlobalConfig,
6
+ saveGlobalConfig
7
+ } from "./chunk-UXGTT25Q.mjs";
8
+ import "./chunk-IWB4L2HV.mjs";
9
+ import "./chunk-GWRZRWCF.mjs";
10
+ import "./chunk-RDYXWXXC.mjs";
11
+ import "./chunk-M7UVBANQ.mjs";
12
+ import "./chunk-H6XDQJ3N.mjs";
13
+ export {
14
+ getGlobalAuthPath,
15
+ getGlobalConfigPath,
16
+ loadGlobalConfig,
17
+ saveGlobalConfig
18
+ };
19
+ //# sourceMappingURL=global-config-IXZLY4BS.mjs.map
@@ -0,0 +1,140 @@
1
+ #!/usr/bin/env node
2
+ import "./chunk-H6XDQJ3N.mjs";
3
+
4
+ // src/config/keychain-backend.ts
5
+ var KEYCHAIN_SERVICE = "dreamboard-cli";
6
+ var KEYCHAIN_ACCOUNT = "session";
7
+ var cachedModule;
8
+ async function loadKeyringModule() {
9
+ if (cachedModule !== void 0) return cachedModule;
10
+ try {
11
+ const mod = await import("@napi-rs/keyring");
12
+ cachedModule = mod;
13
+ } catch {
14
+ cachedModule = null;
15
+ }
16
+ return cachedModule;
17
+ }
18
+ function keychainProbe(entry) {
19
+ try {
20
+ entry.getPassword();
21
+ return true;
22
+ } catch {
23
+ return false;
24
+ }
25
+ }
26
+ function parsePayload(raw) {
27
+ if (raw === null || raw === void 0) return null;
28
+ const trimmed = raw.trim();
29
+ if (trimmed.length === 0) return null;
30
+ try {
31
+ const parsed = JSON.parse(trimmed);
32
+ const accessToken = parsed.clerkAccessToken ?? parsed.accessToken;
33
+ if (!accessToken && !parsed.refreshToken) return null;
34
+ return {
35
+ accessToken: accessToken || void 0,
36
+ refreshToken: parsed.refreshToken || void 0,
37
+ tokenExpiresAt: parsed.clerkAccessExpiresAt || parsed.tokenExpiresAt || void 0,
38
+ dreamboardApiToken: parsed.dreamboardApiToken || void 0,
39
+ dreamboardApiExpiresAt: parsed.dreamboardApiExpiresAt || void 0,
40
+ clerkOAuthIssuer: parsed.clerkOAuthIssuer || void 0,
41
+ clerkOAuthClientId: parsed.clerkOAuthClientId || void 0,
42
+ clerkOAuthTokenUrl: parsed.clerkOAuthTokenUrl || void 0,
43
+ environment: parsed.environment || void 0
44
+ };
45
+ } catch {
46
+ return null;
47
+ }
48
+ }
49
+ function writeFull(entry, creds) {
50
+ if (!creds.accessToken || !creds.refreshToken) {
51
+ throw new Error(
52
+ "Refusing to persist credentials with an empty accessToken or refreshToken."
53
+ );
54
+ }
55
+ const payload = {
56
+ clerkAccessToken: creds.accessToken,
57
+ refreshToken: creds.refreshToken,
58
+ clerkAccessExpiresAt: creds.tokenExpiresAt,
59
+ dreamboardApiToken: creds.dreamboardApiToken,
60
+ dreamboardApiExpiresAt: creds.dreamboardApiExpiresAt,
61
+ clerkOAuthIssuer: creds.clerkOAuthIssuer,
62
+ clerkOAuthClientId: creds.clerkOAuthClientId,
63
+ clerkOAuthTokenUrl: creds.clerkOAuthTokenUrl,
64
+ environment: creds.environment
65
+ };
66
+ entry.setPassword(JSON.stringify(payload));
67
+ }
68
+ function writeAccessOnly(entry, accessToken) {
69
+ if (!accessToken) {
70
+ throw new Error("Refusing to persist an empty access token.");
71
+ }
72
+ const payload = { accessToken };
73
+ entry.setPassword(JSON.stringify(payload));
74
+ }
75
+ function clear(entry) {
76
+ try {
77
+ entry.deletePassword();
78
+ } catch {
79
+ }
80
+ }
81
+ async function tryKeychainBackend() {
82
+ const mod = await loadKeyringModule();
83
+ if (!mod) {
84
+ return {
85
+ available: false,
86
+ reason: "@napi-rs/keyring is not installed for this platform"
87
+ };
88
+ }
89
+ let entry;
90
+ try {
91
+ entry = new mod.Entry(KEYCHAIN_SERVICE, KEYCHAIN_ACCOUNT);
92
+ } catch (err) {
93
+ return {
94
+ available: false,
95
+ reason: `Failed to construct keyring entry: ${String(err.message ?? err)}`
96
+ };
97
+ }
98
+ if (!keychainProbe(entry)) {
99
+ return {
100
+ available: false,
101
+ reason: "OS keyring is not accessible from this process"
102
+ };
103
+ }
104
+ const backend = {
105
+ name: "keychain",
106
+ async read() {
107
+ try {
108
+ return parsePayload(entry.getPassword());
109
+ } catch (err) {
110
+ const message = String(err.message ?? err);
111
+ if (/no matching entry|not found/i.test(message)) {
112
+ return null;
113
+ }
114
+ throw err;
115
+ }
116
+ },
117
+ async writeFull(creds) {
118
+ writeFull(entry, creds);
119
+ },
120
+ async writeAccessOnly(accessToken) {
121
+ writeAccessOnly(entry, accessToken);
122
+ },
123
+ async clear() {
124
+ clear(entry);
125
+ }
126
+ };
127
+ return { available: true, backend };
128
+ }
129
+ function _setKeyringModuleForTests(mod) {
130
+ cachedModule = mod;
131
+ }
132
+ function _resetKeyringModuleForTests() {
133
+ cachedModule = void 0;
134
+ }
135
+ export {
136
+ _resetKeyringModuleForTests,
137
+ _setKeyringModuleForTests,
138
+ tryKeychainBackend
139
+ };
140
+ //# sourceMappingURL=keychain-backend-UF3Z26JM.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/config/keychain-backend.ts"],"sourcesContent":["/**\n * OS keychain-backed `CredentialBackend` built on top of `@napi-rs/keyring`.\n *\n * Keychain is an optional storage backend. Users can opt in with\n * `credentialBackend: \"keychain\"` in `~/.dreamboard/config.json`\n * (see `credential-store.ts` for the resolver).\n * When enabled, it gives us:\n * - A refresh token encrypted at rest by the OS (Keychain on macOS,\n * Credential Vault on Windows, Secret Service on Linux).\n * - Protection against other processes running as the same user tailing\n * `~/.dreamboard/auth.json` to scrape the token.\n *\n * This module is loaded optionally: `@napi-rs/keyring` is declared as an\n * `optionalDependencies` entry. If the native binary or OS keyring is\n * unavailable, the resolver falls back to the file backend.\n *\n * One-time migration: when the active backend is keychain and `auth.json` still\n * has tokens, `credential-store.ts` copies them into the keychain, verifies the\n * keychain read, and deletes the file. This is the only path that intentionally\n * mutates both backends.\n */\n\nimport type {\n CredentialBackend,\n Credentials,\n StoredSessionSnapshot,\n} from \"./credential-store.js\";\n\n/** Keychain service id. Shared across all Dreamboard CLI builds. */\nconst KEYCHAIN_SERVICE = \"dreamboard-cli\";\n/**\n * Keychain account id. The `user@host` shape is conventional but we keep\n * it fixed for now because the CLI only cares about \"the session for this\n * OS user\", not per-process sessions.\n */\nconst KEYCHAIN_ACCOUNT = \"session\";\n\ntype EntryInstance = {\n setPassword(value: string): void;\n getPassword(): string | null | undefined;\n deletePassword(): boolean;\n};\n\ntype KeyringModule = {\n Entry: new (service: string, account: string) => EntryInstance;\n};\n\nlet cachedModule: KeyringModule | null | undefined;\n\nasync function loadKeyringModule(): Promise<KeyringModule | null> {\n if (cachedModule !== undefined) return cachedModule;\n try {\n // `@napi-rs/keyring` is an optional dependency. If the native binary is\n // missing on this platform the dynamic import throws; resolver policy in\n // credential-store decides whether that is fatal.\n const mod = (await import(\"@napi-rs/keyring\")) as unknown as KeyringModule;\n cachedModule = mod;\n } catch {\n cachedModule = null;\n }\n return cachedModule;\n}\n\nfunction keychainProbe(entry: EntryInstance): boolean {\n // Some platforms have the module installed but no accessible keyring\n // (e.g. headless Linux without DBus). Touch getPassword to verify we\n // can talk to the service without side effects.\n try {\n entry.getPassword();\n return true;\n } catch {\n return false;\n }\n}\n\ntype KeychainPayload = {\n clerkAccessToken?: string;\n accessToken?: string;\n refreshToken?: string;\n clerkAccessExpiresAt?: string;\n tokenExpiresAt?: string;\n dreamboardApiToken?: string;\n dreamboardApiExpiresAt?: string;\n clerkOAuthIssuer?: string;\n clerkOAuthClientId?: string;\n clerkOAuthTokenUrl?: string;\n environment?: string;\n};\n\nfunction parsePayload(\n raw: string | null | undefined,\n): StoredSessionSnapshot | null {\n if (raw === null || raw === undefined) return null;\n const trimmed = raw.trim();\n if (trimmed.length === 0) return null;\n try {\n const parsed = JSON.parse(trimmed) as KeychainPayload;\n const accessToken = parsed.clerkAccessToken ?? parsed.accessToken;\n if (!accessToken && !parsed.refreshToken) return null;\n return {\n accessToken: accessToken || undefined,\n refreshToken: parsed.refreshToken || undefined,\n tokenExpiresAt:\n parsed.clerkAccessExpiresAt || parsed.tokenExpiresAt || undefined,\n dreamboardApiToken: parsed.dreamboardApiToken || undefined,\n dreamboardApiExpiresAt: parsed.dreamboardApiExpiresAt || undefined,\n clerkOAuthIssuer: parsed.clerkOAuthIssuer || undefined,\n clerkOAuthClientId: parsed.clerkOAuthClientId || undefined,\n clerkOAuthTokenUrl: parsed.clerkOAuthTokenUrl || undefined,\n environment: parsed.environment || undefined,\n };\n } catch {\n return null;\n }\n}\n\nfunction writeFull(entry: EntryInstance, creds: Credentials): void {\n if (!creds.accessToken || !creds.refreshToken) {\n throw new Error(\n \"Refusing to persist credentials with an empty accessToken or refreshToken.\",\n );\n }\n const payload: KeychainPayload = {\n clerkAccessToken: creds.accessToken,\n refreshToken: creds.refreshToken,\n clerkAccessExpiresAt: creds.tokenExpiresAt,\n dreamboardApiToken: creds.dreamboardApiToken,\n dreamboardApiExpiresAt: creds.dreamboardApiExpiresAt,\n clerkOAuthIssuer: creds.clerkOAuthIssuer,\n clerkOAuthClientId: creds.clerkOAuthClientId,\n clerkOAuthTokenUrl: creds.clerkOAuthTokenUrl,\n environment: creds.environment,\n };\n entry.setPassword(JSON.stringify(payload));\n}\n\nfunction writeAccessOnly(entry: EntryInstance, accessToken: string): void {\n if (!accessToken) {\n throw new Error(\"Refusing to persist an empty access token.\");\n }\n const payload: KeychainPayload = { accessToken };\n entry.setPassword(JSON.stringify(payload));\n}\n\nfunction clear(entry: EntryInstance): void {\n try {\n entry.deletePassword();\n } catch {\n // keyring-rs throws when the entry does not exist. That is fine -\n // `clearCredentials` contracts as idempotent.\n }\n}\n\nexport type KeychainAvailability =\n | { available: true; backend: CredentialBackend }\n | { available: false; reason: string };\n\n/**\n * Attempt to construct a keychain-backed `CredentialBackend`. Returns an\n * `available: false` result (with a reason) if the native module, the\n * OS keyring, or the probe fails.\n */\nexport async function tryKeychainBackend(): Promise<KeychainAvailability> {\n const mod = await loadKeyringModule();\n if (!mod) {\n return {\n available: false,\n reason: \"@napi-rs/keyring is not installed for this platform\",\n };\n }\n\n let entry: EntryInstance;\n try {\n entry = new mod.Entry(KEYCHAIN_SERVICE, KEYCHAIN_ACCOUNT);\n } catch (err) {\n return {\n available: false,\n reason: `Failed to construct keyring entry: ${String((err as Error).message ?? err)}`,\n };\n }\n\n if (!keychainProbe(entry)) {\n return {\n available: false,\n reason: \"OS keyring is not accessible from this process\",\n };\n }\n\n const backend: CredentialBackend = {\n name: \"keychain\",\n async read() {\n try {\n return parsePayload(entry.getPassword());\n } catch (err) {\n const message = String((err as Error).message ?? err);\n // Transient keychain access errors (e.g. Touch ID prompt\n // cancelled) should not surface as \"session wiped\". Treat the\n // unreadable state as \"no session\" so the caller can fall back\n // to prompting for login.\n if (/no matching entry|not found/i.test(message)) {\n return null;\n }\n throw err;\n }\n },\n async writeFull(creds) {\n writeFull(entry, creds);\n },\n async writeAccessOnly(accessToken) {\n writeAccessOnly(entry, accessToken);\n },\n async clear() {\n clear(entry);\n },\n };\n return { available: true, backend };\n}\n\n/**\n * Test-only escape hatch so unit tests can install a fake keyring module\n * without going through the dynamic import cache.\n */\nexport function _setKeyringModuleForTests(mod: KeyringModule | null): void {\n cachedModule = mod;\n}\n\nexport function _resetKeyringModuleForTests(): void {\n cachedModule = undefined;\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,45 @@
1
+ #!/usr/bin/env node
2
+ import {
3
+ collectLocalFiles,
4
+ getLocalDiff,
5
+ isAllowedGamePath,
6
+ isLibraryPath,
7
+ loadManifest,
8
+ loadRule,
9
+ removeExtraneousFiles,
10
+ walkDir,
11
+ writeManifest,
12
+ writeRule,
13
+ writeScaffoldFiles,
14
+ writeSnapshot,
15
+ writeSnapshotFromFiles,
16
+ writeSourceFiles
17
+ } from "./chunk-KDAQ4CZY.mjs";
18
+ import "./chunk-GWRZRWCF.mjs";
19
+ import {
20
+ computeManifestHash
21
+ } from "./chunk-BWBN2TDJ.mjs";
22
+ import "./chunk-JZTH3EMV.mjs";
23
+ import "./chunk-TTB7AIHZ.mjs";
24
+ import "./chunk-MYMVXTZT.mjs";
25
+ import "./chunk-OJFZVGEL.mjs";
26
+ import "./chunk-M7UVBANQ.mjs";
27
+ import "./chunk-H6XDQJ3N.mjs";
28
+ export {
29
+ collectLocalFiles,
30
+ computeManifestHash,
31
+ getLocalDiff,
32
+ isAllowedGamePath,
33
+ isLibraryPath,
34
+ loadManifest,
35
+ loadRule,
36
+ removeExtraneousFiles,
37
+ walkDir,
38
+ writeManifest,
39
+ writeRule,
40
+ writeScaffoldFiles,
41
+ writeSnapshot,
42
+ writeSnapshotFromFiles,
43
+ writeSourceFiles
44
+ };
45
+ //# sourceMappingURL=local-files-OF4QFISU.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,150 @@
1
+ #!/usr/bin/env node
2
+ import {
3
+ MANIFEST_TYPECHECK_CONFIG_FILE
4
+ } from "./chunk-M7UVBANQ.mjs";
5
+ import "./chunk-H6XDQJ3N.mjs";
6
+
7
+ // src/services/project/local-typecheck.ts
8
+ import { spawn } from "child_process";
9
+ import { lstat } from "fs/promises";
10
+ import { createRequire } from "module";
11
+ import path from "path";
12
+ var TYPESCRIPT_BIN_PATH_SEGMENTS = [
13
+ "node_modules",
14
+ "typescript",
15
+ "bin",
16
+ "tsc"
17
+ ];
18
+ var CLI_PACKAGE_TYPESCRIPT_CLI = resolveCliPackageTypescriptCli();
19
+ function resolveCliPackageTypescriptCli() {
20
+ try {
21
+ const require2 = createRequire(import.meta.url);
22
+ return require2.resolve("typescript/bin/tsc");
23
+ } catch {
24
+ return null;
25
+ }
26
+ }
27
+ function getProjectNodeModules(projectRoot) {
28
+ return path.join(projectRoot, "node_modules");
29
+ }
30
+ function getProjectTypescriptCli(projectRoot) {
31
+ return path.join(projectRoot, ...TYPESCRIPT_BIN_PATH_SEGMENTS);
32
+ }
33
+ async function pathExists(targetPath) {
34
+ try {
35
+ await lstat(targetPath);
36
+ return true;
37
+ } catch {
38
+ return false;
39
+ }
40
+ }
41
+ async function ensureTypecheckDependencies(projectRoot) {
42
+ if (await pathExists(getProjectNodeModules(projectRoot))) {
43
+ return null;
44
+ }
45
+ return `Skipping local typecheck: workspace dependencies are not installed at ${getProjectNodeModules(projectRoot)}. Run \`pnpm install --frozen-lockfile\` or recreate the workspace with \`dreamboard project create\` / \`dreamboard project clone\` first.`;
46
+ }
47
+ async function resolveTypecheckRunner(projectRoot) {
48
+ const localTypescriptCli = getProjectTypescriptCli(projectRoot);
49
+ if (await pathExists(localTypescriptCli)) {
50
+ return {
51
+ command: process.execPath,
52
+ argsPrefix: [localTypescriptCli]
53
+ };
54
+ }
55
+ if (CLI_PACKAGE_TYPESCRIPT_CLI && await pathExists(CLI_PACKAGE_TYPESCRIPT_CLI)) {
56
+ return {
57
+ command: process.execPath,
58
+ argsPrefix: [CLI_PACKAGE_TYPESCRIPT_CLI]
59
+ };
60
+ }
61
+ const globalTscAvailable = await new Promise((resolve) => {
62
+ const child = spawn("tsc", ["--version"], {
63
+ env: process.env,
64
+ stdio: "ignore"
65
+ });
66
+ child.on("error", () => {
67
+ resolve(false);
68
+ });
69
+ child.on("close", (code) => {
70
+ resolve(code === 0);
71
+ });
72
+ });
73
+ if (!globalTscAvailable) {
74
+ return null;
75
+ }
76
+ return {
77
+ command: "tsc",
78
+ argsPrefix: []
79
+ };
80
+ }
81
+ async function runTypecheckProject(runner, projectRoot, projectPath) {
82
+ return new Promise((resolve, reject) => {
83
+ const child = spawn(
84
+ runner.command,
85
+ [...runner.argsPrefix, "--noEmit", "-p", projectPath],
86
+ {
87
+ cwd: projectRoot,
88
+ env: process.env,
89
+ stdio: ["ignore", "pipe", "pipe"]
90
+ }
91
+ );
92
+ let stdout = "";
93
+ let stderr = "";
94
+ child.stdout.on("data", (chunk) => {
95
+ stdout += chunk.toString();
96
+ });
97
+ child.stderr.on("data", (chunk) => {
98
+ stderr += chunk.toString();
99
+ });
100
+ child.on("error", (error) => {
101
+ reject(new Error(`Failed to start local typecheck. ${error.message}`));
102
+ });
103
+ child.on("close", (code) => {
104
+ const output = [stdout, stderr].filter(Boolean).join("\n").trim();
105
+ resolve({
106
+ success: code === 0,
107
+ output
108
+ });
109
+ });
110
+ });
111
+ }
112
+ async function runLocalTypecheck(projectRoot) {
113
+ const dependencySkipReason = await ensureTypecheckDependencies(projectRoot);
114
+ if (dependencySkipReason) {
115
+ return {
116
+ success: true,
117
+ skipped: true,
118
+ output: dependencySkipReason
119
+ };
120
+ }
121
+ const runner = await resolveTypecheckRunner(projectRoot);
122
+ if (!runner) {
123
+ return {
124
+ success: true,
125
+ skipped: true,
126
+ output: "Skipping local typecheck: TypeScript CLI was not found in workspace dependencies or on PATH."
127
+ };
128
+ }
129
+ const results = await Promise.all(
130
+ [
131
+ MANIFEST_TYPECHECK_CONFIG_FILE,
132
+ "app/tsconfig.json",
133
+ "ui/tsconfig.json"
134
+ ].map(
135
+ (projectPath) => runTypecheckProject(runner, projectRoot, projectPath)
136
+ )
137
+ );
138
+ const firstFailure = results.find((result) => !result.success);
139
+ if (firstFailure) {
140
+ return firstFailure;
141
+ }
142
+ return {
143
+ success: true,
144
+ output: ""
145
+ };
146
+ }
147
+ export {
148
+ runLocalTypecheck
149
+ };
150
+ //# sourceMappingURL=local-typecheck-DHVLM37Z.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/services/project/local-typecheck.ts"],"sourcesContent":["import { MANIFEST_TYPECHECK_CONFIG_FILE } from \"../../constants.js\";\nimport { spawn } from \"node:child_process\";\nimport { lstat } from \"node:fs/promises\";\nimport { createRequire } from \"node:module\";\nimport path from \"node:path\";\n\nexport type LocalTypecheckResult = {\n success: boolean;\n output: string;\n skipped?: boolean;\n};\n\ntype TypecheckRunner = {\n command: string;\n argsPrefix: string[];\n};\n\nconst TYPESCRIPT_BIN_PATH_SEGMENTS = [\n \"node_modules\",\n \"typescript\",\n \"bin\",\n \"tsc\",\n];\n\n// TypeScript shipped with the CLI package itself; used as a fallback when the\n// user's workspace does not provide its own `typescript` install.\nconst CLI_PACKAGE_TYPESCRIPT_CLI = resolveCliPackageTypescriptCli();\n\nfunction resolveCliPackageTypescriptCli(): string | null {\n try {\n const require = createRequire(import.meta.url);\n return require.resolve(\"typescript/bin/tsc\");\n } catch {\n return null;\n }\n}\n\nfunction getProjectNodeModules(projectRoot: string): string {\n return path.join(projectRoot, \"node_modules\");\n}\n\nfunction getProjectTypescriptCli(projectRoot: string): string {\n return path.join(projectRoot, ...TYPESCRIPT_BIN_PATH_SEGMENTS);\n}\n\nasync function pathExists(targetPath: string): Promise<boolean> {\n try {\n await lstat(targetPath);\n return true;\n } catch {\n return false;\n }\n}\n\nasync function ensureTypecheckDependencies(\n projectRoot: string,\n): Promise<string | null> {\n if (await pathExists(getProjectNodeModules(projectRoot))) {\n return null;\n }\n\n return `Skipping local typecheck: workspace dependencies are not installed at ${getProjectNodeModules(projectRoot)}. Run \\`pnpm install --frozen-lockfile\\` or recreate the workspace with \\`dreamboard project create\\` / \\`dreamboard project clone\\` first.`;\n}\n\nasync function resolveTypecheckRunner(\n projectRoot: string,\n): Promise<TypecheckRunner | null> {\n const localTypescriptCli = getProjectTypescriptCli(projectRoot);\n if (await pathExists(localTypescriptCli)) {\n return {\n command: process.execPath,\n argsPrefix: [localTypescriptCli],\n };\n }\n\n if (\n CLI_PACKAGE_TYPESCRIPT_CLI &&\n (await pathExists(CLI_PACKAGE_TYPESCRIPT_CLI))\n ) {\n return {\n command: process.execPath,\n argsPrefix: [CLI_PACKAGE_TYPESCRIPT_CLI],\n };\n }\n\n const globalTscAvailable = await new Promise<boolean>((resolve) => {\n const child = spawn(\"tsc\", [\"--version\"], {\n env: process.env,\n stdio: \"ignore\",\n });\n\n child.on(\"error\", () => {\n resolve(false);\n });\n child.on(\"close\", (code) => {\n resolve(code === 0);\n });\n });\n\n if (!globalTscAvailable) {\n return null;\n }\n\n return {\n command: \"tsc\",\n argsPrefix: [],\n };\n}\n\nasync function runTypecheckProject(\n runner: TypecheckRunner,\n projectRoot: string,\n projectPath: string,\n): Promise<LocalTypecheckResult> {\n return new Promise((resolve, reject) => {\n const child = spawn(\n runner.command,\n [...runner.argsPrefix, \"--noEmit\", \"-p\", projectPath],\n {\n cwd: projectRoot,\n env: process.env,\n stdio: [\"ignore\", \"pipe\", \"pipe\"],\n },\n );\n\n let stdout = \"\";\n let stderr = \"\";\n\n child.stdout.on(\"data\", (chunk) => {\n stdout += chunk.toString();\n });\n child.stderr.on(\"data\", (chunk) => {\n stderr += chunk.toString();\n });\n child.on(\"error\", (error) => {\n reject(new Error(`Failed to start local typecheck. ${error.message}`));\n });\n child.on(\"close\", (code) => {\n const output = [stdout, stderr].filter(Boolean).join(\"\\n\").trim();\n resolve({\n success: code === 0,\n output,\n });\n });\n });\n}\n\nexport async function runLocalTypecheck(\n projectRoot: string,\n): Promise<LocalTypecheckResult> {\n const dependencySkipReason = await ensureTypecheckDependencies(projectRoot);\n if (dependencySkipReason) {\n return {\n success: true,\n skipped: true,\n output: dependencySkipReason,\n };\n }\n\n const runner = await resolveTypecheckRunner(projectRoot);\n if (!runner) {\n return {\n success: true,\n skipped: true,\n output:\n \"Skipping local typecheck: TypeScript CLI was not found in workspace dependencies or on PATH.\",\n };\n }\n\n // The three projects are independent (no cross-project references), so\n // checking them in parallel roughly halves wall-clock time without changing\n // correctness. The slowest project (typically `ui/tsconfig.json`) bounds the\n // total cost.\n const results = await Promise.all(\n [\n MANIFEST_TYPECHECK_CONFIG_FILE,\n \"app/tsconfig.json\",\n \"ui/tsconfig.json\",\n ].map((projectPath) =>\n runTypecheckProject(runner, projectRoot, projectPath),\n ),\n );\n\n const firstFailure = results.find((result) => !result.success);\n if (firstFailure) {\n return firstFailure;\n }\n\n return {\n success: true,\n output: \"\",\n };\n}\n"],"mappings":"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","names":["require"]}