langwatch 0.4.1 → 0.4.2

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 (99) hide show
  1. package/dist/{add-WLUMK5VQ.mjs → add-SMYALCQG.mjs} +10 -10
  2. package/dist/{add-RGWB3264.js → add-SV662KZU.js} +27 -27
  3. package/dist/{add-RGWB3264.js.map → add-SV662KZU.js.map} +1 -1
  4. package/dist/{chunk-IZ2U3ABC.mjs → chunk-5ZKAT4KI.mjs} +70 -113
  5. package/dist/chunk-5ZKAT4KI.mjs.map +1 -0
  6. package/dist/{chunk-HUI45ULC.mjs → chunk-7ZRAJ52N.mjs} +3 -3
  7. package/dist/{chunk-FQSWUK5N.mjs → chunk-CAVBDSBT.mjs} +2 -2
  8. package/dist/chunk-CAVBDSBT.mjs.map +1 -0
  9. package/dist/{chunk-ZJZ3MIWE.mjs → chunk-ENSRDEDA.mjs} +2 -2
  10. package/dist/{chunk-HA3LI5IK.js → chunk-I5NDMIK5.js} +1 -1
  11. package/dist/{chunk-HA3LI5IK.js.map → chunk-I5NDMIK5.js.map} +1 -1
  12. package/dist/{chunk-M4VUHTT2.js → chunk-ILTCLEIF.js} +5 -5
  13. package/dist/{chunk-M4VUHTT2.js.map → chunk-ILTCLEIF.js.map} +1 -1
  14. package/dist/{chunk-ECUXLXFT.mjs → chunk-K4ICRI7W.mjs} +53 -13
  15. package/dist/chunk-K4ICRI7W.mjs.map +1 -0
  16. package/dist/{chunk-SYMZPWZE.mjs → chunk-LXVDGQA4.mjs} +5 -4
  17. package/dist/chunk-LXVDGQA4.mjs.map +1 -0
  18. package/dist/{chunk-5N5BUR2Z.js → chunk-NFM6RB4R.js} +71 -114
  19. package/dist/chunk-NFM6RB4R.js.map +1 -0
  20. package/dist/{chunk-4TF2O2TH.js → chunk-NVKMXXNP.js} +14 -14
  21. package/dist/{chunk-4TF2O2TH.js.map → chunk-NVKMXXNP.js.map} +1 -1
  22. package/dist/{chunk-D2CSG4SJ.js → chunk-P5F63PAW.js} +5 -5
  23. package/dist/{chunk-D2CSG4SJ.js.map → chunk-P5F63PAW.js.map} +1 -1
  24. package/dist/{chunk-SGNJDRCT.js → chunk-PUHM465C.js} +5 -4
  25. package/dist/chunk-PUHM465C.js.map +1 -0
  26. package/dist/{chunk-4ILMGMAP.mjs → chunk-RBZNMZTF.mjs} +4 -4
  27. package/dist/{chunk-AZELEDOV.js → chunk-T7FQHOLK.js} +14 -14
  28. package/dist/{chunk-AZELEDOV.js.map → chunk-T7FQHOLK.js.map} +1 -1
  29. package/dist/{chunk-DEVJ7BPE.js → chunk-VI5NJ53L.js} +2 -2
  30. package/dist/chunk-VI5NJ53L.js.map +1 -0
  31. package/dist/{chunk-EJWJXTPU.mjs → chunk-VILW5FYO.mjs} +2 -2
  32. package/dist/chunk-VILW5FYO.mjs.map +1 -0
  33. package/dist/{chunk-4NRLVT2U.mjs → chunk-YQVVPMKH.mjs} +1 -1
  34. package/dist/chunk-YQVVPMKH.mjs.map +1 -0
  35. package/dist/{chunk-K64Y6YUG.js → chunk-ZZLIF3DE.js} +59 -19
  36. package/dist/chunk-ZZLIF3DE.js.map +1 -0
  37. package/dist/cli/index.js +9 -9
  38. package/dist/cli/index.mjs +8 -8
  39. package/dist/{create-MK7NEGCM.mjs → create-BHWZP6YD.mjs} +5 -5
  40. package/dist/{create-7K2CC4KQ.js → create-GUY3HZM2.js} +10 -10
  41. package/dist/{create-7K2CC4KQ.js.map → create-GUY3HZM2.js.map} +1 -1
  42. package/dist/{implementation-CzemP9jY.d.ts → implementation--7B7PUww.d.ts} +1 -1
  43. package/dist/{implementation-C4lvooSg.d.mts → implementation-D7LzdQop.d.mts} +1 -1
  44. package/dist/index.d.mts +2 -2
  45. package/dist/index.d.ts +2 -2
  46. package/dist/index.js +7 -7
  47. package/dist/index.mjs +6 -6
  48. package/dist/init-OO2BUJ6V.js +16 -0
  49. package/dist/{init-GDKJICSS.js.map → init-OO2BUJ6V.js.map} +1 -1
  50. package/dist/{init-RINSTP4L.mjs → init-RDW2F4G3.mjs} +5 -5
  51. package/dist/{list-ZOMRKOBV.mjs → list-32BRZ6RS.mjs} +7 -7
  52. package/dist/list-32BRZ6RS.mjs.map +1 -0
  53. package/dist/{list-DBUK47MA.js → list-GZGLSJ52.js} +10 -10
  54. package/dist/{list-DBUK47MA.js.map → list-GZGLSJ52.js.map} +1 -1
  55. package/dist/{login-A7LEPNBR.js → login-IAP4RFUM.js} +3 -3
  56. package/dist/{login-A7LEPNBR.js.map → login-IAP4RFUM.js.map} +1 -1
  57. package/dist/{login-ULPHWIAX.mjs → login-VXLW2OXR.mjs} +2 -2
  58. package/dist/observability-sdk/index.d.mts +3 -3
  59. package/dist/observability-sdk/index.d.ts +3 -3
  60. package/dist/observability-sdk/index.js +4 -4
  61. package/dist/observability-sdk/index.mjs +3 -3
  62. package/dist/observability-sdk/instrumentation/langchain/index.d.mts +1 -1
  63. package/dist/observability-sdk/instrumentation/langchain/index.d.ts +1 -1
  64. package/dist/observability-sdk/instrumentation/langchain/index.js +3 -3
  65. package/dist/observability-sdk/instrumentation/langchain/index.mjs +1 -1
  66. package/dist/observability-sdk/setup/node/index.js +10 -10
  67. package/dist/observability-sdk/setup/node/index.mjs +2 -2
  68. package/dist/{remove-RAJBGHQQ.mjs → remove-JUVM6M7G.mjs} +8 -8
  69. package/dist/{remove-ODTJLFWR.js → remove-N3324KHS.js} +16 -16
  70. package/dist/{remove-ODTJLFWR.js.map → remove-N3324KHS.js.map} +1 -1
  71. package/dist/{sync-2IXPWN64.mjs → sync-B4YK6QYX.mjs} +14 -11
  72. package/dist/sync-B4YK6QYX.mjs.map +1 -0
  73. package/dist/{sync-PBOL5ODF.js → sync-E32H3H52.js} +32 -29
  74. package/dist/sync-E32H3H52.js.map +1 -0
  75. package/dist/{types-1q5wIYP5.d.mts → types-D61S7yPU.d.mts} +917 -527
  76. package/dist/{types-C9k5gGhU.d.ts → types-D6Cs1385.d.ts} +917 -527
  77. package/package.json +11 -10
  78. package/dist/chunk-4NRLVT2U.mjs.map +0 -1
  79. package/dist/chunk-5N5BUR2Z.js.map +0 -1
  80. package/dist/chunk-DEVJ7BPE.js.map +0 -1
  81. package/dist/chunk-ECUXLXFT.mjs.map +0 -1
  82. package/dist/chunk-EJWJXTPU.mjs.map +0 -1
  83. package/dist/chunk-FQSWUK5N.mjs.map +0 -1
  84. package/dist/chunk-IZ2U3ABC.mjs.map +0 -1
  85. package/dist/chunk-K64Y6YUG.js.map +0 -1
  86. package/dist/chunk-SGNJDRCT.js.map +0 -1
  87. package/dist/chunk-SYMZPWZE.mjs.map +0 -1
  88. package/dist/init-GDKJICSS.js +0 -16
  89. package/dist/list-ZOMRKOBV.mjs.map +0 -1
  90. package/dist/sync-2IXPWN64.mjs.map +0 -1
  91. package/dist/sync-PBOL5ODF.js.map +0 -1
  92. /package/dist/{add-WLUMK5VQ.mjs.map → add-SMYALCQG.mjs.map} +0 -0
  93. /package/dist/{chunk-HUI45ULC.mjs.map → chunk-7ZRAJ52N.mjs.map} +0 -0
  94. /package/dist/{chunk-ZJZ3MIWE.mjs.map → chunk-ENSRDEDA.mjs.map} +0 -0
  95. /package/dist/{chunk-4ILMGMAP.mjs.map → chunk-RBZNMZTF.mjs.map} +0 -0
  96. /package/dist/{create-MK7NEGCM.mjs.map → create-BHWZP6YD.mjs.map} +0 -0
  97. /package/dist/{init-RINSTP4L.mjs.map → init-RDW2F4G3.mjs.map} +0 -0
  98. /package/dist/{login-ULPHWIAX.mjs.map → login-VXLW2OXR.mjs.map} +0 -0
  99. /package/dist/{remove-RAJBGHQQ.mjs.map → remove-JUVM6M7G.mjs.map} +0 -0
@@ -3,25 +3,25 @@
3
3
  var _chunkF6E4XQQUjs = require('./chunk-F6E4XQQU.js');
4
4
 
5
5
 
6
- var _chunkAZELEDOVjs = require('./chunk-AZELEDOV.js');
6
+ var _chunkT7FQHOLKjs = require('./chunk-T7FQHOLK.js');
7
7
 
8
8
 
9
- var _chunk5N5BUR2Zjs = require('./chunk-5N5BUR2Z.js');
9
+ var _chunkNFM6RB4Rjs = require('./chunk-NFM6RB4R.js');
10
10
  require('./chunk-YH5TIVK2.js');
11
- require('./chunk-M4VUHTT2.js');
12
- require('./chunk-4TF2O2TH.js');
13
- require('./chunk-DEVJ7BPE.js');
11
+ require('./chunk-ILTCLEIF.js');
12
+ require('./chunk-NVKMXXNP.js');
13
+ require('./chunk-VI5NJ53L.js');
14
14
  require('./chunk-DISMHYXC.js');
15
15
 
16
16
 
17
- var _chunkK64Y6YUGjs = require('./chunk-K64Y6YUG.js');
17
+ var _chunkZZLIF3DEjs = require('./chunk-ZZLIF3DE.js');
18
18
 
19
19
 
20
- var _chunkD2CSG4SJjs = require('./chunk-D2CSG4SJ.js');
20
+ var _chunkP5F63PAWjs = require('./chunk-P5F63PAW.js');
21
21
 
22
22
 
23
- var _chunkSGNJDRCTjs = require('./chunk-SGNJDRCT.js');
24
- require('./chunk-HA3LI5IK.js');
23
+ var _chunkPUHM465Cjs = require('./chunk-PUHM465C.js');
24
+ require('./chunk-I5NDMIK5.js');
25
25
  require('./chunk-OXBO24RB.js');
26
26
 
27
27
  // src/cli/commands/sync.ts
@@ -73,13 +73,14 @@ var handleConflict = async (promptName, conflictInfo) => {
73
73
  };
74
74
  var syncCommand = async () => {
75
75
  var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q;
76
+ console.log("\u{1F504} Starting sync...");
76
77
  const startTime = Date.now();
77
78
  try {
78
79
  _chunkF6E4XQQUjs.checkApiKey.call(void 0, );
79
- const langwatch = new (0, _chunkAZELEDOVjs.LangWatch)();
80
- await _chunkK64Y6YUGjs.ensureProjectInitialized.call(void 0, false);
81
- const config = _chunkD2CSG4SJjs.FileManager.loadPromptsConfig();
82
- const lock = _chunkD2CSG4SJjs.FileManager.loadPromptsLock();
80
+ const langwatch = new (0, _chunkT7FQHOLKjs.LangWatch)();
81
+ await _chunkZZLIF3DEjs.ensureProjectInitialized.call(void 0, false);
82
+ const config = _chunkP5F63PAWjs.FileManager.loadPromptsConfig();
83
+ const lock = _chunkP5F63PAWjs.FileManager.loadPromptsLock();
83
84
  const result = {
84
85
  fetched: [],
85
86
  pushed: [],
@@ -110,8 +111,8 @@ var syncCommand = async () => {
110
111
  if (prompt) {
111
112
  const needsUpdate = !lockEntry || lockEntry.version !== prompt.version || !lockEntry.materialized || !fs.existsSync(path.resolve(lockEntry.materialized));
112
113
  if (needsUpdate) {
113
- const materializedPrompt = _chunkSGNJDRCTjs.PromptConverter.fromApiToMaterialized(prompt);
114
- const savedPath = _chunkD2CSG4SJjs.FileManager.saveMaterializedPrompt(
114
+ const materializedPrompt = _chunkPUHM465Cjs.PromptConverter.fromApiToMaterialized(prompt);
115
+ const savedPath = _chunkP5F63PAWjs.FileManager.saveMaterializedPrompt(
115
116
  name,
116
117
  materializedPrompt
117
118
  );
@@ -121,7 +122,7 @@ var syncCommand = async () => {
121
122
  version: prompt.version,
122
123
  versionSpec
123
124
  });
124
- _chunkD2CSG4SJjs.FileManager.updateLockEntry(
125
+ _chunkP5F63PAWjs.FileManager.updateLockEntry(
125
126
  lock,
126
127
  name,
127
128
  materializedPrompt,
@@ -157,12 +158,12 @@ var syncCommand = async () => {
157
158
  for (const [promptName, dependency] of localFileRefs) {
158
159
  try {
159
160
  const filePath = dependency.slice(5);
160
- const localConfig = _chunkD2CSG4SJjs.FileManager.loadLocalPrompt(filePath);
161
+ const localConfig = _chunkP5F63PAWjs.FileManager.loadLocalPrompt(filePath);
161
162
  const currentVersion = (_b = lock.prompts[promptName]) == null ? void 0 : _b.version;
162
163
  const configData = {
163
164
  model: localConfig.model,
164
- prompt: _chunkSGNJDRCTjs.PromptConverter.extractSystemPrompt(localConfig.messages),
165
- messages: _chunkSGNJDRCTjs.PromptConverter.filterNonSystemMessages(
165
+ prompt: _chunkPUHM465Cjs.PromptConverter.extractSystemPrompt(localConfig.messages),
166
+ messages: _chunkPUHM465Cjs.PromptConverter.filterNonSystemMessages(
166
167
  localConfig.messages
167
168
  ),
168
169
  temperature: (_c = localConfig.modelParameters) == null ? void 0 : _c.temperature,
@@ -285,12 +286,12 @@ var syncCommand = async () => {
285
286
  result.errors.push({ name: promptName, error: errorMessage });
286
287
  }
287
288
  }
288
- _chunkD2CSG4SJjs.FileManager.savePromptsLock(lock);
289
+ _chunkP5F63PAWjs.FileManager.savePromptsLock(lock);
289
290
  pushSpinner.stop();
290
291
  }
291
- const discoveredLocalFiles = _chunkD2CSG4SJjs.FileManager.getLocalPromptFiles();
292
+ const discoveredLocalFiles = _chunkP5F63PAWjs.FileManager.getLocalPromptFiles();
292
293
  const orphanFiles = discoveredLocalFiles.filter((filePath) => {
293
- const promptName = _chunkD2CSG4SJjs.FileManager.promptNameFromPath(filePath);
294
+ const promptName = _chunkP5F63PAWjs.FileManager.promptNameFromPath(filePath);
294
295
  return !config.prompts[promptName];
295
296
  });
296
297
  if (orphanFiles.length > 0) {
@@ -301,7 +302,7 @@ var syncCommand = async () => {
301
302
  )
302
303
  );
303
304
  for (const filePath of orphanFiles) {
304
- const promptName = _chunkD2CSG4SJjs.FileManager.promptNameFromPath(filePath);
305
+ const promptName = _chunkP5F63PAWjs.FileManager.promptNameFromPath(filePath);
305
306
  const relativePath = path.relative(process.cwd(), filePath);
306
307
  console.log(_chalk2.default.yellow(` ${relativePath}`));
307
308
  console.log(
@@ -329,12 +330,12 @@ Tip: Add these to prompts.json to include them in sync operations.`
329
330
  return true;
330
331
  })
331
332
  );
332
- const cleanedFiles = _chunkD2CSG4SJjs.FileManager.cleanupOrphanedMaterializedFiles(currentDependencies);
333
+ const cleanedFiles = _chunkP5F63PAWjs.FileManager.cleanupOrphanedMaterializedFiles(currentDependencies);
333
334
  if (cleanedFiles.length > 0) {
334
335
  result.cleaned = cleanedFiles;
335
- _chunkD2CSG4SJjs.FileManager.removeFromLock(lock, cleanedFiles);
336
+ _chunkP5F63PAWjs.FileManager.removeFromLock(lock, cleanedFiles);
336
337
  }
337
- _chunkD2CSG4SJjs.FileManager.savePromptsLock(lock);
338
+ _chunkP5F63PAWjs.FileManager.savePromptsLock(lock);
338
339
  if (result.fetched.length > 0) {
339
340
  for (const { name, version, versionSpec } of result.fetched) {
340
341
  const lockEntry = lock.prompts[name];
@@ -353,7 +354,9 @@ Tip: Add these to prompts.json to include them in sync operations.`
353
354
  const localPath = `./prompts/${name}.prompt.yaml`;
354
355
  console.log(
355
356
  _chalk2.default.green(
356
- `\u2713 Pushed ${_chalk2.default.cyan(name)} ${_chalk2.default.gray(`(version ${version})`)} from ${_chalk2.default.gray(localPath)}`
357
+ `\u2713 Pushed ${_chalk2.default.cyan(name)} ${_chalk2.default.gray(
358
+ `(version ${version})`
359
+ )} from ${_chalk2.default.gray(localPath)}`
357
360
  )
358
361
  );
359
362
  }
@@ -392,7 +395,7 @@ Tip: Add these to prompts.json to include them in sync operations.`
392
395
  process.exit(1);
393
396
  }
394
397
  } catch (error) {
395
- if (error instanceof _chunk5N5BUR2Zjs.PromptsError) {
398
+ if (error instanceof _chunkNFM6RB4Rjs.PromptsError) {
396
399
  console.error(_chalk2.default.red(`Error: ${error.message}`));
397
400
  } else {
398
401
  console.error(
@@ -407,4 +410,4 @@ Tip: Add these to prompts.json to include them in sync operations.`
407
410
 
408
411
 
409
412
  exports.syncCommand = syncCommand;
410
- //# sourceMappingURL=sync-PBOL5ODF.js.map
413
+ //# sourceMappingURL=sync-E32H3H52.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/sync-E32H3H52.js","../src/cli/commands/sync.ts"],"names":[],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/sync-E32H3H52.js","sourcesContent":[null,"import * as fs from \"fs\";\nimport * as path from \"path\";\nimport chalk from \"chalk\";\nimport ora from \"ora\";\nimport * as yaml from \"js-yaml\";\nimport { PromptConverter } from \"@/cli/utils/promptConverter\";\nimport {\n type ConfigData,\n PromptsError,\n type SyncAction,\n} from \"@/client-sdk/services/prompts\";\nimport { LangWatch } from \"@/client-sdk\";\nimport type { SyncResult } from \"../types\";\nimport { FileManager } from \"../utils/fileManager\";\nimport { ensureProjectInitialized } from \"../utils/init\";\nimport { checkApiKey } from \"../utils/apiKey\";\nimport readline from \"node:readline\";\n\n// Handle conflict resolution - show diff and ask user to choose\nconst handleConflict = async (\n promptName: string,\n conflictInfo: {\n localVersion: number;\n remoteVersion: number;\n differences: string[];\n remoteConfigData: any;\n },\n): Promise<\"local\" | \"remote\" | \"abort\"> => {\n console.log(\n chalk.yellow(\n `\\n⚠ Conflict detected for prompt: ${chalk.cyan(promptName)}`,\n ),\n );\n console.log(\n chalk.gray(\n `Local version: ${conflictInfo.localVersion}, Remote version: ${conflictInfo.remoteVersion}`,\n ),\n );\n\n if (conflictInfo.differences.length > 0) {\n console.log(chalk.yellow(\"\\nDifferences:\"));\n conflictInfo.differences.forEach((diff) => {\n console.log(chalk.gray(` • ${diff}`));\n });\n }\n\n console.log(chalk.yellow(\"\\nOptions:\"));\n console.log(\" [l] Use local version (overwrite remote)\");\n console.log(\" [r] Use remote version (overwrite local)\");\n console.log(\" [a] Abort sync for this prompt\");\n\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n return new Promise((resolve) => {\n rl.question(\"Choose resolution (l/r/a): \", (answer: string) => {\n rl.close();\n const choice = answer.toLowerCase();\n if (choice === \"l\" || choice === \"local\") {\n resolve(\"local\");\n } else if (choice === \"r\" || choice === \"remote\") {\n resolve(\"remote\");\n } else {\n resolve(\"abort\");\n }\n });\n });\n};\n\nexport const syncCommand = async (): Promise<void> => {\n console.log(\"🔄 Starting sync...\");\n\n const startTime = Date.now();\n\n try {\n // Check API key before doing anything else\n checkApiKey();\n\n // Get LangWatch client\n const langwatch = new LangWatch();\n\n // Ensure project is initialized (prompts.json, lock file, directories)\n await ensureProjectInitialized(false); // Don't prompt for .gitignore in sync\n\n // Load prompts config and lock\n const config = FileManager.loadPromptsConfig();\n const lock = FileManager.loadPromptsLock();\n\n const result: SyncResult = {\n fetched: [],\n pushed: [],\n unchanged: [],\n cleaned: [],\n errors: [],\n };\n\n // Process remote prompts (fetch and materialize)\n const remoteDeps = Object.entries(config.prompts).filter(\n ([, dependency]) => {\n // Skip local file dependencies (both object format and string format)\n if (typeof dependency === \"object\" && dependency.file) {\n return false;\n }\n if (typeof dependency === \"string\" && dependency.startsWith(\"file:\")) {\n return false;\n }\n return true;\n },\n );\n\n if (remoteDeps.length > 0) {\n const fetchSpinner = ora(\n `Checking ${remoteDeps.length} remote prompts...`,\n ).start();\n\n for (const [name, dependency] of remoteDeps) {\n try {\n const versionSpec =\n typeof dependency === \"string\"\n ? dependency\n : dependency.version ?? \"latest\";\n\n // Check if we already have this prompt with the same version\n const lockEntry = lock.prompts[name];\n\n // Fetch the prompt from the API to check current version\n const prompt = await langwatch.prompts.get(name);\n\n if (prompt) {\n // Check if we need to update (new version or not materialized)\n const needsUpdate =\n !lockEntry ||\n lockEntry.version !== prompt.version ||\n !lockEntry.materialized ||\n !fs.existsSync(path.resolve(lockEntry.materialized));\n\n if (needsUpdate) {\n // Convert to MaterializedPrompt format using the converter\n const materializedPrompt =\n PromptConverter.fromApiToMaterialized(prompt);\n\n const savedPath = FileManager.saveMaterializedPrompt(\n name,\n materializedPrompt,\n );\n const relativePath = path.relative(process.cwd(), savedPath);\n result.fetched.push({\n name,\n version: prompt.version,\n versionSpec,\n });\n\n // Update lock file entry\n FileManager.updateLockEntry(\n lock,\n name,\n materializedPrompt,\n savedPath,\n );\n\n fetchSpinner.text = `Fetched ${chalk.cyan(\n `${name}@${versionSpec}`,\n )} ${chalk.gray(`(version ${prompt.version})`)} → ${chalk.gray(\n relativePath,\n )}`;\n } else {\n // No change needed, track as unchanged\n result.unchanged.push(name);\n }\n } else {\n result.errors.push({ name, error: \"Prompt not found\" });\n }\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : \"Unknown error\";\n result.errors.push({ name, error: errorMessage });\n }\n }\n\n fetchSpinner.stop();\n }\n\n // Process local prompts (push to API) - only those explicitly declared in prompts.json\n const localFileRefs = Object.entries(config.prompts).filter(\n ([, dependency]) => {\n return typeof dependency === \"string\" && dependency.startsWith(\"file:\");\n },\n );\n\n if (localFileRefs.length > 0) {\n const pushSpinner = ora(\n `Pushing ${localFileRefs.length} local prompts...`,\n ).start();\n\n // Use the existing lock file instead of reloading it\n // const lock = FileManager.loadPromptsLock(); // Don't reload - use existing lock\n\n for (const [promptName, dependency] of localFileRefs) {\n try {\n const filePath = (dependency as string).slice(5); // Remove \"file:\" prefix\n\n // Load local prompt config\n const localConfig = FileManager.loadLocalPrompt(filePath);\n\n // Get current version from lock file\n const currentVersion = lock.prompts[promptName]?.version;\n\n // Convert local config to API configData format\n const configData: ConfigData = {\n model: localConfig.model,\n prompt: PromptConverter.extractSystemPrompt(localConfig.messages),\n messages: PromptConverter.filterNonSystemMessages(\n localConfig.messages,\n ) as Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>,\n temperature: localConfig.modelParameters?.temperature,\n max_tokens: localConfig.modelParameters?.max_tokens,\n inputs: [{ identifier: \"input\", type: \"str\" }],\n outputs: [{ identifier: \"output\", type: \"str\" }],\n };\n\n // Use new sync API with conflict detection\n const syncResult = await langwatch.prompts.sync({\n name: promptName,\n configData,\n localVersion: currentVersion,\n commitMessage: `Synced from local file: ${path.basename(filePath)}`,\n });\n\n const relativePath = path.relative(process.cwd(), filePath);\n\n let conflictResolution: \"local\" | \"remote\" | \"abort\" | null = null;\n if (syncResult.action === \"conflict\") {\n // Handle conflict - prompt user for resolution\n pushSpinner.stop();\n conflictResolution = await handleConflict(\n promptName,\n syncResult.conflictInfo!,\n );\n if (conflictResolution === \"abort\") {\n result.errors.push({\n name: promptName,\n error: \"Sync aborted due to conflict\",\n });\n continue;\n }\n\n // If user chose remote, we should pull the remote version to local file\n if (conflictResolution === \"remote\" && syncResult.conflictInfo) {\n // Update local file with remote content\n const remoteConfig = {\n model: syncResult.conflictInfo.remoteConfigData.model,\n modelParameters: {\n temperature:\n syncResult.conflictInfo.remoteConfigData.temperature,\n max_tokens:\n syncResult.conflictInfo.remoteConfigData.max_tokens,\n },\n messages: [\n {\n role: \"system\" as const,\n content: syncResult.conflictInfo.remoteConfigData.prompt,\n },\n ...(syncResult.conflictInfo.remoteConfigData.messages ?? []),\n ],\n };\n\n const yamlContent = yaml.dump(remoteConfig, {\n lineWidth: -1,\n noRefs: true,\n sortKeys: false,\n });\n\n fs.writeFileSync(filePath, yamlContent);\n }\n\n // If user chose to proceed, we continue with the sync\n pushSpinner.start();\n }\n\n // Update lock file with new version info\n if (syncResult.prompt) {\n lock.prompts[promptName] = {\n version: syncResult.prompt.version,\n versionId: syncResult.prompt.versionId,\n materialized: filePath,\n };\n } else if (syncResult.action === \"conflict\") {\n const remoteVersion = syncResult.conflictInfo?.remoteVersion ?? 0;\n if (conflictResolution === \"remote\") {\n // User chose remote - use remote version\n lock.prompts[promptName] = {\n version: remoteVersion,\n versionId: \"remote_version\", // We don't have the actual versionId from conflict info\n materialized: filePath,\n };\n } else {\n // User chose local - create new version (remote + 1)\n lock.prompts[promptName] = {\n version: remoteVersion + 1,\n versionId: \"conflict_resolved\", // Temporary until we get actual versionId\n materialized: filePath,\n };\n }\n }\n\n // Determine the action text based on sync result and conflict resolution\n let actionText: string;\n if (syncResult.action === \"conflict\") {\n if (conflictResolution === \"remote\") {\n actionText = \"Pulled\"; // User chose to use remote version\n result.fetched.push({\n name: promptName,\n version: syncResult.conflictInfo?.remoteVersion ?? 0,\n versionSpec: \"latest\", // Default for conflict resolution\n });\n } else {\n actionText = \"Pushed\"; // User chose to use local version (or forced push)\n result.pushed.push({\n name: promptName,\n version: (syncResult.conflictInfo?.remoteVersion ?? 0) + 1, // New version after push\n });\n }\n } else if (syncResult.action === \"up_to_date\") {\n // For up-to-date prompts, add to unchanged instead of pushed\n actionText = \"Up-to-date\";\n result.unchanged.push(promptName);\n } else {\n const actionMap: Record<SyncAction, string> = {\n created: \"Created\",\n updated: \"Updated\",\n conflict: \"Conflict resolved\",\n up_to_date: \"Up to date\",\n };\n actionText = actionMap[syncResult.action as SyncAction] || \"Pushed\";\n result.pushed.push({\n name: promptName,\n version: syncResult.prompt?.version ?? 0,\n });\n }\n\n pushSpinner.text = `${actionText} ${chalk.cyan(\n promptName,\n )} ${chalk.gray(\n `(version ${\n syncResult.prompt?.version ??\n syncResult.conflictInfo?.remoteVersion ??\n \"unknown\"\n })`,\n )} ${conflictResolution === \"remote\" ? \"to\" : \"from\"} ${chalk.gray(\n relativePath,\n )}`;\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : \"Unknown error\";\n result.errors.push({ name: promptName, error: errorMessage });\n }\n }\n\n // Save lock file with all updates\n FileManager.savePromptsLock(lock);\n\n pushSpinner.stop();\n }\n\n // Check for orphan local prompt files and show helpful warnings\n const discoveredLocalFiles = FileManager.getLocalPromptFiles();\n const orphanFiles = discoveredLocalFiles.filter((filePath) => {\n const promptName = FileManager.promptNameFromPath(filePath);\n return !config.prompts[promptName]; // Not declared in prompts.json\n });\n\n if (orphanFiles.length > 0) {\n console.log(\n chalk.yellow(\n `\\n⚠ Found ${orphanFiles.length} orphan prompt file${\n orphanFiles.length > 1 ? \"s\" : \"\"\n }:`,\n ),\n );\n\n for (const filePath of orphanFiles) {\n const promptName = FileManager.promptNameFromPath(filePath);\n const relativePath = path.relative(process.cwd(), filePath);\n\n console.log(chalk.yellow(` ${relativePath}`));\n console.log(\n chalk.gray(\n ` Add to prompts.json: \"${promptName}\": \"file:${relativePath}\"`,\n ),\n );\n }\n\n console.log(\n chalk.gray(\n `\\nTip: Add these to prompts.json to include them in sync operations.`,\n ),\n );\n }\n\n // Cleanup orphaned materialized files\n const currentDependencies = new Set(\n Object.keys(config.prompts).filter((name) => {\n const dependency = config.prompts[name];\n // Only include remote dependencies (not local file: dependencies)\n if (typeof dependency === \"object\" && dependency.file) {\n return false;\n }\n if (typeof dependency === \"string\" && dependency.startsWith(\"file:\")) {\n return false;\n }\n return true;\n }),\n );\n\n const cleanedFiles =\n FileManager.cleanupOrphanedMaterializedFiles(currentDependencies);\n if (cleanedFiles.length > 0) {\n result.cleaned = cleanedFiles;\n FileManager.removeFromLock(lock, cleanedFiles);\n }\n\n // Save the updated lock file\n FileManager.savePromptsLock(lock);\n\n // Print individual results if there were actions\n if (result.fetched.length > 0) {\n for (const { name, version, versionSpec } of result.fetched) {\n // Get the actual saved path from lock file for display consistency\n const lockEntry = lock.prompts[name];\n const displayPath = lockEntry?.materialized\n ? `./${lockEntry.materialized}`\n : `./prompts/.materialized/${name}.prompt.yaml`;\n\n console.log(\n chalk.green(\n `✓ Pulled ${chalk.cyan(`${name}@${versionSpec}`)} ${chalk.gray(\n `(version ${version})`,\n )} → ${chalk.gray(displayPath)}`,\n ),\n );\n }\n }\n\n if (result.pushed.length > 0) {\n for (const { name, version } of result.pushed) {\n const localPath = `./prompts/${name}.prompt.yaml`;\n console.log(\n chalk.green(\n `✓ Pushed ${chalk.cyan(name)} ${chalk.gray(\n `(version ${version})`,\n )} from ${chalk.gray(localPath)}`,\n ),\n );\n }\n }\n\n // Print cleaned up files\n if (result.cleaned.length > 0) {\n for (const name of result.cleaned) {\n console.log(\n chalk.yellow(\n `✓ Cleaned ${chalk.cyan(name)} (no longer in dependencies)`,\n ),\n );\n }\n }\n\n // Print errors\n if (result.errors.length > 0) {\n for (const { name, error } of result.errors) {\n console.log(chalk.red(`✗ Failed ${chalk.cyan(name)}: ${error}`));\n }\n }\n\n // Print summary\n const duration = ((Date.now() - startTime) / 1000).toFixed(1);\n const totalActions =\n result.fetched.length + result.pushed.length + result.cleaned.length;\n\n if (totalActions === 0 && result.errors.length === 0) {\n console.log(chalk.gray(`Synced in ${duration}s, no changes`));\n } else {\n const summary = [];\n if (result.fetched.length > 0)\n summary.push(`${result.fetched.length} fetched`);\n if (result.pushed.length > 0)\n summary.push(`${result.pushed.length} pushed`);\n if (result.cleaned.length > 0)\n summary.push(`${result.cleaned.length} cleaned`);\n if (result.errors.length > 0)\n summary.push(`${result.errors.length} errors`);\n\n console.log(chalk.gray(`Synced ${summary.join(\", \")} in ${duration}s`));\n }\n\n if (result.errors.length > 0) {\n process.exit(1);\n }\n } catch (error) {\n if (error instanceof PromptsError) {\n console.error(chalk.red(`Error: ${error.message}`));\n } else {\n console.error(\n chalk.red(\n `Unexpected error: ${\n error instanceof Error ? error.message : \"Unknown error\"\n }`,\n ),\n );\n }\n process.exit(1);\n }\n};\n"]}