langwatch 0.5.1 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (120) hide show
  1. package/README.md +19 -0
  2. package/dist/{add-4WXEWG5H.js → add-CGTO6GC2.js} +28 -32
  3. package/dist/add-CGTO6GC2.js.map +1 -0
  4. package/dist/{add-D2WVVKIP.mjs → add-XCI65PVN.mjs} +14 -18
  5. package/dist/add-XCI65PVN.mjs.map +1 -0
  6. package/dist/{chunk-P4SQTYGN.js → chunk-2GYC6KEA.js} +32 -32
  7. package/dist/{chunk-P4SQTYGN.js.map → chunk-2GYC6KEA.js.map} +1 -1
  8. package/dist/{chunk-CAZONSXV.js → chunk-36XAYVMC.js} +186 -76
  9. package/dist/chunk-36XAYVMC.js.map +1 -0
  10. package/dist/{chunk-ZIULPOMQ.mjs → chunk-3P4ROGZJ.mjs} +4 -4
  11. package/dist/{chunk-DLJO7AK5.mjs → chunk-AD7QRYIJ.mjs} +2 -2
  12. package/dist/{chunk-DISMHYXC.js → chunk-CKIZDPIJ.js} +24 -22
  13. package/dist/chunk-CKIZDPIJ.js.map +1 -0
  14. package/dist/{chunk-7OZKH5K2.js → chunk-DZH6SY3Z.js} +10 -10
  15. package/dist/{chunk-7OZKH5K2.js.map → chunk-DZH6SY3Z.js.map} +1 -1
  16. package/dist/{chunk-N2V6J3U2.mjs → chunk-FEL5FLHA.mjs} +2 -2
  17. package/dist/{chunk-H5PON53W.mjs → chunk-GAFUPYJ3.mjs} +334 -143
  18. package/dist/chunk-GAFUPYJ3.mjs.map +1 -0
  19. package/dist/{chunk-SVXNUWZI.js → chunk-HVW45GST.js} +345 -154
  20. package/dist/chunk-HVW45GST.js.map +1 -0
  21. package/dist/{chunk-YNQ44U6D.mjs → chunk-I2SOBPAF.mjs} +23 -21
  22. package/dist/chunk-I2SOBPAF.mjs.map +1 -0
  23. package/dist/{chunk-ECOC36EA.js → chunk-J7B7BNDN.js} +11 -11
  24. package/dist/{chunk-ECOC36EA.js.map → chunk-J7B7BNDN.js.map} +1 -1
  25. package/dist/{chunk-QZGTM76F.mjs → chunk-JPWKINZP.mjs} +2 -2
  26. package/dist/{chunk-OXBO24RB.js → chunk-OHM7JUMR.js} +15 -2
  27. package/dist/chunk-OHM7JUMR.js.map +1 -0
  28. package/dist/chunk-PYVDTUA6.mjs +352 -0
  29. package/dist/chunk-PYVDTUA6.mjs.map +1 -0
  30. package/dist/{chunk-YH5TIVK2.js → chunk-SNDTNU3T.js} +2 -2
  31. package/dist/{chunk-YH5TIVK2.js.map → chunk-SNDTNU3T.js.map} +1 -1
  32. package/dist/{chunk-CU3443HD.mjs → chunk-URTD2WOC.mjs} +14 -1
  33. package/dist/{chunk-YKFTFYKK.mjs → chunk-WOBPYIKO.mjs} +2 -2
  34. package/dist/chunk-WOBPYIKO.mjs.map +1 -0
  35. package/dist/{chunk-QCYYSMCU.js → chunk-Z3NTWVVA.js} +2 -2
  36. package/dist/chunk-Z3NTWVVA.js.map +1 -0
  37. package/dist/cli/index.js +8 -8
  38. package/dist/cli/index.mjs +8 -8
  39. package/dist/{create-OQEMO4MU.mjs → create-LXQB4EFB.mjs} +4 -5
  40. package/dist/{create-OQEMO4MU.mjs.map → create-LXQB4EFB.mjs.map} +1 -1
  41. package/dist/{create-4LG4N2A4.js → create-S5RDGF3H.js} +9 -10
  42. package/dist/create-S5RDGF3H.js.map +1 -0
  43. package/dist/{implementation-BIlL6-SW.d.ts → implementation-DsHp9FYU.d.ts} +1 -1
  44. package/dist/{implementation-fAgqv8OM.d.mts → implementation-nE9dgTwc.d.mts} +1 -1
  45. package/dist/{index-DTEZr0Jn.d.mts → index-D7rKIGrO.d.mts} +12 -12
  46. package/dist/{index-DTEZr0Jn.d.ts → index-D7rKIGrO.d.ts} +12 -12
  47. package/dist/index.d.mts +256 -11
  48. package/dist/index.d.ts +256 -11
  49. package/dist/index.js +135 -12
  50. package/dist/index.js.map +1 -1
  51. package/dist/index.mjs +133 -10
  52. package/dist/index.mjs.map +1 -1
  53. package/dist/{init-MQXXHCNT.mjs → init-T4YDPHBA.mjs} +4 -5
  54. package/dist/{init-MQXXHCNT.mjs.map → init-T4YDPHBA.mjs.map} +1 -1
  55. package/dist/init-UADBKUJU.js +15 -0
  56. package/dist/init-UADBKUJU.js.map +1 -0
  57. package/dist/{list-GIAXAAH5.js → list-GRKVAGJS.js} +14 -15
  58. package/dist/list-GRKVAGJS.js.map +1 -0
  59. package/dist/{list-PFWV7IU6.mjs → list-XHXVFN24.mjs} +13 -14
  60. package/dist/list-XHXVFN24.mjs.map +1 -0
  61. package/dist/{login-3STX2FAO.js → login-4GWM5I6F.js} +4 -4
  62. package/dist/{login-3STX2FAO.js.map → login-4GWM5I6F.js.map} +1 -1
  63. package/dist/{login-BYLXS23I.mjs → login-EKE7SFN3.mjs} +3 -3
  64. package/dist/observability-sdk/index.d.mts +4 -3
  65. package/dist/observability-sdk/index.d.ts +4 -3
  66. package/dist/observability-sdk/index.js +7 -7
  67. package/dist/observability-sdk/index.mjs +6 -6
  68. package/dist/observability-sdk/instrumentation/langchain/index.d.mts +2 -1
  69. package/dist/observability-sdk/instrumentation/langchain/index.d.ts +2 -1
  70. package/dist/observability-sdk/instrumentation/langchain/index.js +19 -19
  71. package/dist/observability-sdk/instrumentation/langchain/index.mjs +3 -3
  72. package/dist/observability-sdk/setup/node/index.d.mts +1 -1
  73. package/dist/observability-sdk/setup/node/index.d.ts +1 -1
  74. package/dist/observability-sdk/setup/node/index.js +15 -15
  75. package/dist/observability-sdk/setup/node/index.mjs +4 -4
  76. package/dist/{remove-U3PILQDV.js → remove-7EXB2Z6R.js} +17 -18
  77. package/dist/remove-7EXB2Z6R.js.map +1 -0
  78. package/dist/{remove-FTF3EBYV.mjs → remove-W44FQ5MF.mjs} +9 -10
  79. package/dist/{remove-FTF3EBYV.mjs.map → remove-W44FQ5MF.mjs.map} +1 -1
  80. package/dist/{sync-T3T22GVZ.js → sync-V7WRMNJV.js} +31 -35
  81. package/dist/sync-V7WRMNJV.js.map +1 -0
  82. package/dist/{sync-FOW7DHAH.mjs → sync-XGFABFAW.mjs} +16 -20
  83. package/dist/sync-XGFABFAW.mjs.map +1 -0
  84. package/dist/{types-DyUmlaDx.d.ts → types-B9772cUR.d.ts} +98 -29
  85. package/dist/{types-jrEEZt9d.d.mts → types-DbPAi4US.d.mts} +98 -29
  86. package/package.json +4 -3
  87. package/dist/add-4WXEWG5H.js.map +0 -1
  88. package/dist/add-D2WVVKIP.mjs.map +0 -1
  89. package/dist/chunk-CAZONSXV.js.map +0 -1
  90. package/dist/chunk-CKVDNVFL.mjs +0 -242
  91. package/dist/chunk-CKVDNVFL.mjs.map +0 -1
  92. package/dist/chunk-DISMHYXC.js.map +0 -1
  93. package/dist/chunk-DSIQSULK.js +0 -152
  94. package/dist/chunk-DSIQSULK.js.map +0 -1
  95. package/dist/chunk-H5PON53W.mjs.map +0 -1
  96. package/dist/chunk-OXBO24RB.js.map +0 -1
  97. package/dist/chunk-QCYYSMCU.js.map +0 -1
  98. package/dist/chunk-R6FBJN7K.js +0 -115
  99. package/dist/chunk-R6FBJN7K.js.map +0 -1
  100. package/dist/chunk-SVXNUWZI.js.map +0 -1
  101. package/dist/chunk-V5M3HUBV.mjs +0 -115
  102. package/dist/chunk-V5M3HUBV.mjs.map +0 -1
  103. package/dist/chunk-YEGQXDTE.mjs +0 -152
  104. package/dist/chunk-YEGQXDTE.mjs.map +0 -1
  105. package/dist/chunk-YKFTFYKK.mjs.map +0 -1
  106. package/dist/chunk-YNQ44U6D.mjs.map +0 -1
  107. package/dist/create-4LG4N2A4.js.map +0 -1
  108. package/dist/init-EKNL2SQE.js +0 -16
  109. package/dist/init-EKNL2SQE.js.map +0 -1
  110. package/dist/list-GIAXAAH5.js.map +0 -1
  111. package/dist/list-PFWV7IU6.mjs.map +0 -1
  112. package/dist/remove-U3PILQDV.js.map +0 -1
  113. package/dist/sync-FOW7DHAH.mjs.map +0 -1
  114. package/dist/sync-T3T22GVZ.js.map +0 -1
  115. /package/dist/{chunk-ZIULPOMQ.mjs.map → chunk-3P4ROGZJ.mjs.map} +0 -0
  116. /package/dist/{chunk-DLJO7AK5.mjs.map → chunk-AD7QRYIJ.mjs.map} +0 -0
  117. /package/dist/{chunk-N2V6J3U2.mjs.map → chunk-FEL5FLHA.mjs.map} +0 -0
  118. /package/dist/{chunk-QZGTM76F.mjs.map → chunk-JPWKINZP.mjs.map} +0 -0
  119. /package/dist/{chunk-CU3443HD.mjs.map → chunk-URTD2WOC.mjs.map} +0 -0
  120. /package/dist/{login-BYLXS23I.mjs.map → login-EKE7SFN3.mjs.map} +0 -0
@@ -1,16 +1,124 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
2
 
3
- var _chunkR6FBJN7Kjs = require('./chunk-R6FBJN7K.js');
4
-
5
-
6
3
  var _chunkAZHZ4NB4js = require('./chunk-AZHZ4NB4.js');
7
4
 
5
+ // src/cli/utils/promptConverter.ts
6
+ var PromptConverter = class {
7
+ /**
8
+ * Converts a Prompt instance from the API service to the MaterializedPrompt format
9
+ * used for saving to the .materialized directory.
10
+ */
11
+ static fromApiToMaterialized(prompt) {
12
+ return {
13
+ id: prompt.id,
14
+ name: prompt.name,
15
+ version: prompt.version,
16
+ versionId: prompt.versionId,
17
+ model: prompt.model,
18
+ messages: prompt.messages,
19
+ prompt: prompt.prompt,
20
+ temperature: prompt.temperature,
21
+ maxTokens: prompt.maxTokens,
22
+ inputs: prompt.inputs,
23
+ outputs: prompt.outputs,
24
+ updatedAt: prompt.updatedAt
25
+ };
26
+ }
27
+ /**
28
+ * Converts a MaterializedPrompt to the YAML content structure
29
+ * for saving to .prompt.yaml files.
30
+ */
31
+ static fromMaterializedToYaml(prompt) {
32
+ const result = {
33
+ model: prompt.model,
34
+ messages: prompt.messages
35
+ };
36
+ if (prompt.temperature !== void 0 || prompt.maxTokens !== void 0) {
37
+ result.modelParameters = {};
38
+ if (prompt.temperature !== void 0) {
39
+ result.modelParameters.temperature = prompt.temperature;
40
+ }
41
+ if (prompt.maxTokens !== void 0) {
42
+ result.modelParameters.maxTokens = prompt.maxTokens;
43
+ }
44
+ }
45
+ return result;
46
+ }
47
+ /**
48
+ * Converts a LocalPromptConfig (loaded from YAML) to the format
49
+ * expected by the API service for upserting.
50
+ */
51
+ static fromLocalToApiFormat(config) {
52
+ return {
53
+ model: config.model,
54
+ modelParameters: config.modelParameters,
55
+ messages: config.messages
56
+ };
57
+ }
58
+ /**
59
+ * Extracts the system prompt from messages array.
60
+ * Used when converting to API format that separates system prompt from messages.
61
+ */
62
+ static extractSystemPrompt(messages) {
63
+ var _a, _b;
64
+ return (_b = (_a = messages.find((m) => m.role === "system")) == null ? void 0 : _a.content) != null ? _b : "";
65
+ }
66
+ /**
67
+ * Filters out system messages from the messages array.
68
+ * Used when converting to API format that handles system prompt separately.
69
+ */
70
+ static filterNonSystemMessages(messages) {
71
+ return messages.filter((m) => m.role !== "system");
72
+ }
73
+ /**
74
+ * Converts version specification strings to actual version constraints.
75
+ * Handles npm-style version specs like "latest", "5", "^5", etc.
76
+ */
77
+ static parseVersionSpec(versionSpec) {
78
+ if (versionSpec === "latest") {
79
+ return { type: "latest", value: "latest" };
80
+ }
81
+ if (/^\d+$/.test(versionSpec)) {
82
+ return { type: "exact", value: versionSpec };
83
+ }
84
+ return { type: "tag", value: versionSpec };
85
+ }
86
+ /**
87
+ * Validates that a YAML config can be safely converted to API format.
88
+ * Returns validation errors if any, or null if valid.
89
+ */
90
+ static validateForApiConversion(config) {
91
+ var _a;
92
+ const errors = [];
93
+ if (!((_a = config.model) == null ? void 0 : _a.trim())) {
94
+ errors.push("Model is required and cannot be empty");
95
+ }
96
+ if (!config.messages || config.messages.length === 0) {
97
+ errors.push("At least one message is required");
98
+ }
99
+ if (config.messages) {
100
+ config.messages.forEach((message, index) => {
101
+ var _a2;
102
+ if (!["system", "user", "assistant"].includes(message.role)) {
103
+ errors.push(
104
+ `Message ${index}: role must be 'system', 'user', or 'assistant'`
105
+ );
106
+ }
107
+ if (!((_a2 = message.content) == null ? void 0 : _a2.trim())) {
108
+ errors.push(`Message ${index}: content cannot be empty`);
109
+ }
110
+ });
111
+ }
112
+ return errors;
113
+ }
114
+ };
115
+
8
116
  // src/cli/utils/fileManager.ts
9
117
  var _fs = require('fs'); var fs = _interopRequireWildcard(_fs);
10
118
  var _path = require('path'); var path = _interopRequireWildcard(_path);
11
119
  var _jsyaml = require('js-yaml'); var yaml = _interopRequireWildcard(_jsyaml);
12
120
  var _chalk = require('chalk'); var _chalk2 = _interopRequireDefault(_chalk);
13
- var FileManager = class {
121
+ var _FileManager = class _FileManager {
14
122
  static getPromptsConfigPath() {
15
123
  return path.join(process.cwd(), this.PROMPTS_CONFIG_FILE);
16
124
  }
@@ -59,21 +167,6 @@ var FileManager = class {
59
167
  }
60
168
  return { created: false, path: configPath };
61
169
  }
62
- static loadPromptsLock() {
63
- const lockPath = this.getPromptsLockPath();
64
- if (!fs.existsSync(lockPath)) {
65
- return {
66
- lockfileVersion: 1,
67
- prompts: {}
68
- };
69
- }
70
- try {
71
- const content = fs.readFileSync(lockPath, "utf-8");
72
- return JSON.parse(content);
73
- } catch (error) {
74
- throw new Error(`Failed to parse prompts-lock.json: ${error instanceof Error ? error.message : "Unknown error"}`);
75
- }
76
- }
77
170
  static savePromptsLock(lock) {
78
171
  const lockPath = this.getPromptsLockPath();
79
172
  fs.writeFileSync(lockPath, JSON.stringify(lock, null, 2) + "\n");
@@ -91,31 +184,6 @@ var FileManager = class {
91
184
  }
92
185
  return { created: false, path: lockPath };
93
186
  }
94
- static loadLocalPrompt(filePath) {
95
- const fullPath = path.resolve(filePath);
96
- if (!fs.existsSync(fullPath)) {
97
- throw new Error(`Local prompt file not found: ${filePath}`);
98
- }
99
- try {
100
- const content = fs.readFileSync(fullPath, "utf-8");
101
- const rawData = yaml.load(content);
102
- const result = _chunkAZHZ4NB4js.localPromptConfigSchema.safeParse(rawData);
103
- if (!result.success) {
104
- const prettyError = result.error.issues.map((issue) => `\u2716 ${issue.message}${issue.path.length > 0 ? `
105
- \u2192 at ${issue.path.join(".")}` : ""}`).join("\n");
106
- throw new Error(
107
- `Invalid prompt configuration in ${_chalk2.default.yellow(filePath)}:
108
- ${prettyError}`
109
- );
110
- }
111
- return result.data;
112
- } catch (error) {
113
- if (error instanceof Error && error.message.includes("Invalid prompt configuration")) {
114
- throw error;
115
- }
116
- throw new Error(`Failed to parse local prompt file ${filePath}: ${error instanceof Error ? error.message : "Unknown error"}`);
117
- }
118
- }
119
187
  static saveMaterializedPrompt(name, prompt) {
120
188
  const materializedDir = this.getMaterializedDir();
121
189
  const parts = name.split("/");
@@ -127,7 +195,7 @@ ${prettyError}`
127
195
  }
128
196
  }
129
197
  const filePath = path.join(materializedDir, ...parts.slice(0, -1), fileName);
130
- const yamlContent = _chunkR6FBJN7Kjs.PromptConverter.fromMaterializedToYaml(prompt);
198
+ const yamlContent = PromptConverter.fromMaterializedToYaml(prompt);
131
199
  const yamlString = yaml.dump(yamlContent, {
132
200
  lineWidth: -1,
133
201
  noRefs: true,
@@ -136,31 +204,6 @@ ${prettyError}`
136
204
  fs.writeFileSync(filePath, yamlString);
137
205
  return filePath;
138
206
  }
139
- static getLocalPromptFiles() {
140
- const promptsDir = this.getPromptsDir();
141
- const materializedDir = this.getMaterializedDir();
142
- if (!fs.existsSync(promptsDir)) {
143
- return [];
144
- }
145
- const files = [];
146
- const walkDir = (dir, relativePath = "") => {
147
- const entries = fs.readdirSync(dir, { withFileTypes: true });
148
- for (const entry of entries) {
149
- const fullPath = path.join(dir, entry.name);
150
- const relativeFilePath = path.join(relativePath, entry.name);
151
- if (entry.isDirectory()) {
152
- if (fullPath === materializedDir) {
153
- continue;
154
- }
155
- walkDir(fullPath, relativeFilePath);
156
- } else if (entry.isFile() && entry.name.endsWith(".prompt.yaml")) {
157
- files.push(path.join(promptsDir, relativeFilePath));
158
- }
159
- }
160
- };
161
- walkDir(promptsDir);
162
- return files;
163
- }
164
207
  static promptNameFromPath(filePath) {
165
208
  const promptsDir = this.getPromptsDir();
166
209
  const relativePath = path.relative(promptsDir, filePath);
@@ -231,12 +274,79 @@ ${entry}
231
274
  return { added: true, existed: false };
232
275
  }
233
276
  };
234
- FileManager.PROMPTS_CONFIG_FILE = "prompts.json";
235
- FileManager.PROMPTS_LOCK_FILE = "prompts-lock.json";
236
- FileManager.PROMPTS_DIR = "prompts";
237
- FileManager.MATERIALIZED_DIR = ".materialized";
277
+ _FileManager.PROMPTS_CONFIG_FILE = "prompts.json";
278
+ _FileManager.PROMPTS_LOCK_FILE = "prompts-lock.json";
279
+ _FileManager.PROMPTS_DIR = "prompts";
280
+ _FileManager.MATERIALIZED_DIR = ".materialized";
281
+ _FileManager.loadPromptsLock = () => {
282
+ const lockPath = _FileManager.getPromptsLockPath();
283
+ if (!fs.existsSync(lockPath)) {
284
+ return {
285
+ lockfileVersion: 1,
286
+ prompts: {}
287
+ };
288
+ }
289
+ try {
290
+ const content = fs.readFileSync(lockPath, "utf-8");
291
+ return JSON.parse(content);
292
+ } catch (error) {
293
+ throw new Error(`Failed to parse prompts-lock.json: ${error instanceof Error ? error.message : "Unknown error"}`);
294
+ }
295
+ };
296
+ _FileManager.loadLocalPrompt = (filePath) => {
297
+ const fullPath = path.resolve(filePath);
298
+ if (!fs.existsSync(fullPath)) {
299
+ throw new Error(`Local prompt file not found: ${filePath}`);
300
+ }
301
+ try {
302
+ const content = fs.readFileSync(fullPath, "utf-8");
303
+ const rawData = yaml.load(content);
304
+ const result = _chunkAZHZ4NB4js.localPromptConfigSchema.safeParse(rawData);
305
+ if (!result.success) {
306
+ const prettyError = result.error.issues.map((issue) => `\u2716 ${issue.message}${issue.path.length > 0 ? `
307
+ \u2192 at ${issue.path.join(".")}` : ""}`).join("\n");
308
+ throw new Error(
309
+ `Invalid prompt configuration in ${_chalk2.default.yellow(filePath)}:
310
+ ${prettyError}`
311
+ );
312
+ }
313
+ return result.data;
314
+ } catch (error) {
315
+ if (error instanceof Error && error.message.includes("Invalid prompt configuration")) {
316
+ throw error;
317
+ }
318
+ throw new Error(`Failed to parse local prompt file ${filePath}: ${error instanceof Error ? error.message : "Unknown error"}`);
319
+ }
320
+ };
321
+ _FileManager.getLocalPromptFiles = () => {
322
+ const promptsDir = _FileManager.getPromptsDir();
323
+ const materializedDir = _FileManager.getMaterializedDir();
324
+ if (!fs.existsSync(promptsDir)) {
325
+ return [];
326
+ }
327
+ const files = [];
328
+ const walkDir = (dir, relativePath = "") => {
329
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
330
+ for (const entry of entries) {
331
+ const fullPath = path.join(dir, entry.name);
332
+ const relativeFilePath = path.join(relativePath, entry.name);
333
+ if (entry.isDirectory()) {
334
+ if (fullPath === materializedDir) {
335
+ continue;
336
+ }
337
+ walkDir(fullPath, relativeFilePath);
338
+ } else if (entry.isFile() && entry.name.endsWith(".prompt.yaml")) {
339
+ files.push(path.join(promptsDir, relativeFilePath));
340
+ }
341
+ }
342
+ };
343
+ walkDir(promptsDir);
344
+ return files;
345
+ };
346
+ var FileManager = _FileManager;
347
+
238
348
 
239
349
 
240
350
 
241
- exports.FileManager = FileManager;
242
- //# sourceMappingURL=chunk-CAZONSXV.js.map
351
+ exports.PromptConverter = PromptConverter; exports.FileManager = FileManager;
352
+ //# sourceMappingURL=chunk-36XAYVMC.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-36XAYVMC.js","../src/cli/utils/promptConverter.ts","../src/cli/utils/fileManager.ts"],"names":["_a"],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-36XAYVMC.js","sourcesContent":[null,"import type { LocalPromptConfig, MaterializedPrompt } from \"../types\";\nimport { type PromptResponse } from \"@/client-sdk/services/prompts/types\";\n\n/**\n * Converter utility for transforming between YAML prompt format and API service format.\n *\n * The YAML format follows the GitHub .prompt.yaml file format standard,\n * while the API format is our internal prompt service schema tied to the database.\n *\n * This separation allows us to maintain and evolve both formats independently\n * while keeping the conversion logic centralized and well-tested.\n */\nexport class PromptConverter {\n /**\n * Converts a Prompt instance from the API service to the MaterializedPrompt format\n * used for saving to the .materialized directory.\n */\n static fromApiToMaterialized(prompt: PromptResponse): MaterializedPrompt {\n return {\n id: prompt.id,\n name: prompt.name,\n version: prompt.version,\n versionId: prompt.versionId,\n model: prompt.model,\n messages: prompt.messages,\n prompt: prompt.prompt,\n temperature: prompt.temperature,\n maxTokens: prompt.maxTokens,\n inputs: prompt.inputs,\n outputs: prompt.outputs,\n updatedAt: prompt.updatedAt,\n };\n }\n\n /**\n * Converts a MaterializedPrompt to the YAML content structure\n * for saving to .prompt.yaml files.\n */\n static fromMaterializedToYaml(prompt: MaterializedPrompt): {\n model: string;\n modelParameters?: {\n temperature?: number;\n maxTokens?: number;\n };\n messages: Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>;\n } {\n const result: any = {\n model: prompt.model,\n messages: prompt.messages,\n };\n\n // Add modelParameters if temperature or maxTokens exist\n if (prompt.temperature !== undefined || prompt.maxTokens !== undefined) {\n result.modelParameters = {};\n if (prompt.temperature !== undefined) {\n result.modelParameters.temperature = prompt.temperature;\n }\n if (prompt.maxTokens !== undefined) {\n result.modelParameters.maxTokens = prompt.maxTokens;\n }\n }\n\n return result;\n }\n\n /**\n * Converts a LocalPromptConfig (loaded from YAML) to the format\n * expected by the API service for upserting.\n */\n static fromLocalToApiFormat(config: LocalPromptConfig): {\n model: string;\n modelParameters?: {\n temperature?: number;\n max_tokens?: number;\n };\n messages: Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>;\n } {\n return {\n model: config.model,\n modelParameters: config.modelParameters,\n messages: config.messages,\n };\n }\n\n /**\n * Extracts the system prompt from messages array.\n * Used when converting to API format that separates system prompt from messages.\n */\n static extractSystemPrompt(\n messages: Array<{ role: string; content: string }>,\n ): string {\n return messages.find((m) => m.role === \"system\")?.content ?? \"\";\n }\n\n /**\n * Filters out system messages from the messages array.\n * Used when converting to API format that handles system prompt separately.\n */\n static filterNonSystemMessages(\n messages: Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>,\n ): Array<{ role: \"user\" | \"assistant\"; content: string }> {\n return messages.filter((m) => m.role !== \"system\") as Array<{\n role: \"user\" | \"assistant\";\n content: string;\n }>;\n }\n\n /**\n * Converts version specification strings to actual version constraints.\n * Handles npm-style version specs like \"latest\", \"5\", \"^5\", etc.\n */\n static parseVersionSpec(versionSpec: string): {\n type: \"latest\" | \"exact\" | \"tag\";\n value: string;\n } {\n if (versionSpec === \"latest\") {\n return { type: \"latest\", value: \"latest\" };\n }\n\n // For now, treat everything else as tags until we implement proper semver\n if (/^\\d+$/.test(versionSpec)) {\n return { type: \"exact\", value: versionSpec };\n }\n\n // Handle prefixes like ^, ~, etc. as tags for now\n return { type: \"tag\", value: versionSpec };\n }\n\n /**\n * Validates that a YAML config can be safely converted to API format.\n * Returns validation errors if any, or null if valid.\n */\n static validateForApiConversion(config: LocalPromptConfig): string[] {\n const errors: string[] = [];\n\n if (!config.model?.trim()) {\n errors.push(\"Model is required and cannot be empty\");\n }\n\n if (!config.messages || config.messages.length === 0) {\n errors.push(\"At least one message is required\");\n }\n\n if (config.messages) {\n config.messages.forEach((message, index) => {\n if (![\"system\", \"user\", \"assistant\"].includes(message.role)) {\n errors.push(\n `Message ${index}: role must be 'system', 'user', or 'assistant'`,\n );\n }\n if (!message.content?.trim()) {\n errors.push(`Message ${index}: content cannot be empty`);\n }\n });\n }\n\n return errors;\n }\n}\n","import * as fs from \"fs\";\nimport * as path from \"path\";\nimport * as yaml from \"js-yaml\";\nimport chalk from \"chalk\";\nimport type { PromptsConfig, LocalPromptConfig, MaterializedPrompt, PromptsLock } from \"../types\";\nimport { localPromptConfigSchema } from \"../types\";\nimport { PromptConverter } from \"@/cli/utils/promptConverter\";\n\nexport class FileManager {\n private static readonly PROMPTS_CONFIG_FILE = \"prompts.json\";\n private static readonly PROMPTS_LOCK_FILE = \"prompts-lock.json\";\n private static readonly PROMPTS_DIR = \"prompts\";\n private static readonly MATERIALIZED_DIR = \".materialized\";\n\n static getPromptsConfigPath(): string {\n return path.join(process.cwd(), this.PROMPTS_CONFIG_FILE);\n }\n\n static getPromptsLockPath(): string {\n return path.join(process.cwd(), this.PROMPTS_LOCK_FILE);\n }\n\n static getPromptsDir(): string {\n return path.join(process.cwd(), this.PROMPTS_DIR);\n }\n\n static getMaterializedDir(): string {\n return path.join(this.getPromptsDir(), this.MATERIALIZED_DIR);\n }\n\n static ensureDirectories(): void {\n const promptsDir = this.getPromptsDir();\n const materializedDir = this.getMaterializedDir();\n\n if (!fs.existsSync(promptsDir)) {\n fs.mkdirSync(promptsDir, { recursive: true });\n }\n\n if (!fs.existsSync(materializedDir)) {\n fs.mkdirSync(materializedDir, { recursive: true });\n }\n }\n\n static loadPromptsConfig(): PromptsConfig {\n const configPath = this.getPromptsConfigPath();\n\n if (!fs.existsSync(configPath)) {\n return { prompts: {} };\n }\n\n try {\n const content = fs.readFileSync(configPath, \"utf-8\");\n return JSON.parse(content) as PromptsConfig;\n } catch (error) {\n throw new Error(`Failed to parse prompts.json: ${error instanceof Error ? error.message : \"Unknown error\"}`);\n }\n }\n\n static savePromptsConfig(config: PromptsConfig): void {\n const configPath = this.getPromptsConfigPath();\n fs.writeFileSync(configPath, JSON.stringify(config, null, 2) + \"\\n\");\n }\n\n static initializePromptsConfig(): { created: boolean; path: string } {\n const configPath = this.getPromptsConfigPath();\n const existed = fs.existsSync(configPath);\n\n if (!existed) {\n const emptyConfig: PromptsConfig = { prompts: {} };\n this.savePromptsConfig(emptyConfig);\n return { created: true, path: configPath };\n }\n\n return { created: false, path: configPath };\n }\n\n static loadPromptsLock = (): PromptsLock => {\n const lockPath = this.getPromptsLockPath();\n\n if (!fs.existsSync(lockPath)) {\n return {\n lockfileVersion: 1,\n prompts: {}\n };\n }\n\n try {\n const content = fs.readFileSync(lockPath, \"utf-8\");\n return JSON.parse(content) as PromptsLock;\n } catch (error) {\n throw new Error(`Failed to parse prompts-lock.json: ${error instanceof Error ? error.message : \"Unknown error\"}`);\n }\n }\n\n static savePromptsLock(lock: PromptsLock): void {\n const lockPath = this.getPromptsLockPath();\n fs.writeFileSync(lockPath, JSON.stringify(lock, null, 2) + \"\\n\");\n }\n\n static initializePromptsLock(): { created: boolean; path: string } {\n const lockPath = this.getPromptsLockPath();\n const existed = fs.existsSync(lockPath);\n\n if (!existed) {\n const emptyLock: PromptsLock = {\n lockfileVersion: 1,\n prompts: {}\n };\n this.savePromptsLock(emptyLock);\n return { created: true, path: lockPath };\n }\n\n return { created: false, path: lockPath };\n }\n\n static loadLocalPrompt = (filePath: string): LocalPromptConfig => {\n const fullPath = path.resolve(filePath);\n\n if (!fs.existsSync(fullPath)) {\n throw new Error(`Local prompt file not found: ${filePath}`);\n }\n\n try {\n const content = fs.readFileSync(fullPath, \"utf-8\");\n const rawData = yaml.load(content);\n\n // Validate with zod and provide nice error messages\n const result = localPromptConfigSchema.safeParse(rawData);\n\n if (!result.success) {\n // Format zod errors nicely (manually since z.prettifyError might not be available)\n const prettyError = result.error.issues\n .map(issue => `✖ ${issue.message}${issue.path.length > 0 ? `\\n → at ${issue.path.join('.')}` : ''}`)\n .join('\\n');\n\n throw new Error(\n `Invalid prompt configuration in ${chalk.yellow(filePath)}:\\n${prettyError}`\n );\n }\n\n return result.data;\n } catch (error) {\n if (error instanceof Error && error.message.includes(\"Invalid prompt configuration\")) {\n throw error; // Re-throw zod validation errors as-is\n }\n throw new Error(`Failed to parse local prompt file ${filePath}: ${error instanceof Error ? error.message : \"Unknown error\"}`);\n }\n }\n\n static saveMaterializedPrompt(name: string, prompt: MaterializedPrompt): string {\n const materializedDir = this.getMaterializedDir();\n const parts = name.split(\"/\");\n const fileName = `${parts[parts.length - 1]}.prompt.yaml`;\n\n // Create nested directories if needed\n if (parts.length > 1) {\n const subDir = path.join(materializedDir, ...parts.slice(0, -1));\n if (!fs.existsSync(subDir)) {\n fs.mkdirSync(subDir, { recursive: true });\n }\n }\n\n const filePath = path.join(materializedDir, ...parts.slice(0, -1), fileName);\n\n // Convert to YAML format using the converter\n const yamlContent = PromptConverter.fromMaterializedToYaml(prompt);\n\n const yamlString = yaml.dump(yamlContent, {\n lineWidth: -1,\n noRefs: true,\n sortKeys: false\n });\n\n fs.writeFileSync(filePath, yamlString);\n return filePath;\n }\n\n static getLocalPromptFiles = (): string[] => {\n const promptsDir = this.getPromptsDir();\n const materializedDir = this.getMaterializedDir();\n\n if (!fs.existsSync(promptsDir)) {\n return [];\n }\n\n const files: string[] = [];\n\n const walkDir = (dir: string, relativePath = \"\"): void => {\n const entries = fs.readdirSync(dir, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n const relativeFilePath = path.join(relativePath, entry.name);\n\n if (entry.isDirectory()) {\n // Skip the .materialized directory\n if (fullPath === materializedDir) {\n continue;\n }\n walkDir(fullPath, relativeFilePath);\n } else if (entry.isFile() && entry.name.endsWith(\".prompt.yaml\")) {\n files.push(path.join(promptsDir, relativeFilePath));\n }\n }\n };\n\n walkDir(promptsDir);\n return files;\n }\n\n static promptNameFromPath(filePath: string): string {\n const promptsDir = this.getPromptsDir();\n const relativePath = path.relative(promptsDir, filePath);\n return relativePath.replace(/\\.prompt\\.yaml$/, \"\");\n }\n\n static cleanupOrphanedMaterializedFiles(currentDependencies: Set<string>): string[] {\n const materializedDir = this.getMaterializedDir();\n\n if (!fs.existsSync(materializedDir)) {\n return [];\n }\n\n const cleaned: string[] = [];\n\n const cleanupDir = (dir: string, relativePath = \"\"): void => {\n const entries = fs.readdirSync(dir, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n const relativeFilePath = path.join(relativePath, entry.name);\n\n if (entry.isDirectory()) {\n cleanupDir(fullPath, relativeFilePath);\n\n // Remove empty directories\n try {\n const dirEntries = fs.readdirSync(fullPath);\n if (dirEntries.length === 0) {\n fs.rmdirSync(fullPath);\n }\n } catch {\n // Directory not empty or other error, ignore\n }\n } else if (entry.isFile() && entry.name.endsWith(\".prompt.yaml\")) {\n // Extract prompt name from materialized file path\n const promptName = relativeFilePath.replace(/\\.prompt\\.yaml$/, \"\");\n\n if (!currentDependencies.has(promptName)) {\n fs.unlinkSync(fullPath);\n cleaned.push(promptName);\n }\n }\n }\n };\n\n cleanupDir(materializedDir);\n return cleaned;\n }\n\n static updateLockEntry(lock: PromptsLock, name: string, prompt: MaterializedPrompt, materializedPath: string): void {\n const relativePath = path.relative(process.cwd(), materializedPath);\n\n lock.prompts[name] = {\n version: prompt.version,\n versionId: prompt.versionId,\n materialized: relativePath,\n };\n }\n\n static removeFromLock(lock: PromptsLock, names: string[]): void {\n for (const name of names) {\n delete lock.prompts[name];\n }\n }\n\n static addToGitignore(entry: string): { added: boolean; existed: boolean } {\n const gitignorePath = path.join(process.cwd(), \".gitignore\");\n\n // Check if .gitignore exists\n if (!fs.existsSync(gitignorePath)) {\n // Create new .gitignore with the entry\n fs.writeFileSync(gitignorePath, `${entry}\\n`);\n return { added: true, existed: false };\n }\n\n // Read existing .gitignore\n const content = fs.readFileSync(gitignorePath, \"utf-8\");\n const lines = content.split(\"\\n\").map(line => line.trim());\n\n // Check if entry already exists\n if (lines.includes(entry)) {\n return { added: false, existed: true };\n }\n\n // Add entry to .gitignore\n const newContent = content.endsWith(\"\\n\") ? `${content}${entry}\\n` : `${content}\\n${entry}\\n`;\n fs.writeFileSync(gitignorePath, newContent);\n\n return { added: true, existed: false };\n }\n}\n"]}
@@ -6,14 +6,14 @@ import {
6
6
  LANGWATCH_SDK_VERSION,
7
7
  LOGS_PATH,
8
8
  TRACES_PATH
9
- } from "./chunk-YKFTFYKK.mjs";
9
+ } from "./chunk-WOBPYIKO.mjs";
10
10
  import {
11
11
  shouldCaptureOutput
12
- } from "./chunk-YNQ44U6D.mjs";
12
+ } from "./chunk-I2SOBPAF.mjs";
13
13
  import {
14
14
  __spreadProps,
15
15
  __spreadValues
16
- } from "./chunk-CU3443HD.mjs";
16
+ } from "./chunk-URTD2WOC.mjs";
17
17
 
18
18
  // src/observability-sdk/exporters/langwatch-trace-exporter.ts
19
19
  import { OTLPTraceExporter } from "@opentelemetry/exporter-trace-otlp-http";
@@ -204,4 +204,4 @@ export {
204
204
  getLangWatchLogger,
205
205
  getLangWatchLoggerFromProvider
206
206
  };
207
- //# sourceMappingURL=chunk-ZIULPOMQ.mjs.map
207
+ //# sourceMappingURL=chunk-3P4ROGZJ.mjs.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  FileManager
3
- } from "./chunk-CKVDNVFL.mjs";
3
+ } from "./chunk-PYVDTUA6.mjs";
4
4
 
5
5
  // src/cli/utils/init.ts
6
6
  import * as readline from "readline";
@@ -130,4 +130,4 @@ export {
130
130
  initializeProject,
131
131
  ensureProjectInitialized
132
132
  };
133
- //# sourceMappingURL=chunk-DLJO7AK5.mjs.map
133
+ //# sourceMappingURL=chunk-AD7QRYIJ.mjs.map
@@ -1,6 +1,6 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkOXBO24RBjs = require('./chunk-OXBO24RB.js');
3
+ var _chunkOHM7JUMRjs = require('./chunk-OHM7JUMR.js');
4
4
 
5
5
  // src/logger/index.ts
6
6
  var logLevelOrder = {
@@ -10,17 +10,31 @@ var logLevelOrder = {
10
10
  error: 3
11
11
  };
12
12
  var NoOpLogger = class {
13
- debug() {
14
- }
15
- info() {
16
- }
17
- warn() {
18
- }
19
- error() {
13
+ constructor() {
14
+ this.debug = () => {
15
+ };
16
+ this.info = () => {
17
+ };
18
+ this.warn = () => {
19
+ };
20
+ this.error = () => {
21
+ };
20
22
  }
21
23
  };
22
24
  var ConsoleLogger = class {
23
25
  constructor(options = { level: "warn" }) {
26
+ this.debug = (message, ...args) => {
27
+ if (this.shouldLog("debug")) console.debug(this.format(message), ...args);
28
+ };
29
+ this.info = (message, ...args) => {
30
+ if (this.shouldLog("info")) console.info(this.format(message), ...args);
31
+ };
32
+ this.warn = (message, ...args) => {
33
+ if (this.shouldLog("warn")) console.warn(this.format(message), ...args);
34
+ };
35
+ this.error = (message, ...args) => {
36
+ if (this.shouldLog("error")) console.error(this.format(message), ...args);
37
+ };
24
38
  this.level = options.level;
25
39
  this.prefix = options.prefix;
26
40
  }
@@ -30,23 +44,11 @@ var ConsoleLogger = class {
30
44
  format(message) {
31
45
  return this.prefix ? `[${this.prefix}] ${message}` : message;
32
46
  }
33
- debug(message, ...args) {
34
- if (this.shouldLog("debug")) console.debug(this.format(message), ...args);
35
- }
36
- info(message, ...args) {
37
- if (this.shouldLog("info")) console.info(this.format(message), ...args);
38
- }
39
- warn(message, ...args) {
40
- if (this.shouldLog("warn")) console.warn(this.format(message), ...args);
41
- }
42
- error(message, ...args) {
43
- if (this.shouldLog("error")) console.error(this.format(message), ...args);
44
- }
45
47
  };
46
48
 
47
49
  // src/observability-sdk/semconv/attributes.ts
48
50
  var attributes_exports = {};
49
- _chunkOXBO24RBjs.__export.call(void 0, attributes_exports, {
51
+ _chunkOHM7JUMRjs.__export.call(void 0, attributes_exports, {
50
52
  ATTR_LANGWATCH_CUSTOMER_ID: () => ATTR_LANGWATCH_CUSTOMER_ID,
51
53
  ATTR_LANGWATCH_EVALUATION_CUSTOM: () => ATTR_LANGWATCH_EVALUATION_CUSTOM,
52
54
  ATTR_LANGWATCH_INPUT: () => ATTR_LANGWATCH_INPUT,
@@ -181,4 +183,4 @@ function shouldCaptureOutput() {
181
183
 
182
184
 
183
185
  exports.NoOpLogger = NoOpLogger; exports.ConsoleLogger = ConsoleLogger; exports.ATTR_LANGWATCH_INPUT = ATTR_LANGWATCH_INPUT; exports.ATTR_LANGWATCH_OUTPUT = ATTR_LANGWATCH_OUTPUT; exports.ATTR_LANGWATCH_SPAN_TYPE = ATTR_LANGWATCH_SPAN_TYPE; exports.ATTR_LANGWATCH_RAG_CONTEXTS = ATTR_LANGWATCH_RAG_CONTEXTS; exports.ATTR_LANGWATCH_METRICS = ATTR_LANGWATCH_METRICS; exports.ATTR_LANGWATCH_PROMPT_ID = ATTR_LANGWATCH_PROMPT_ID; exports.ATTR_LANGWATCH_PROMPT_VERSION_ID = ATTR_LANGWATCH_PROMPT_VERSION_ID; exports.ATTR_LANGWATCH_PROMPT_SELECTED_ID = ATTR_LANGWATCH_PROMPT_SELECTED_ID; exports.ATTR_LANGWATCH_PROMPT_VERSION_NUMBER = ATTR_LANGWATCH_PROMPT_VERSION_NUMBER; exports.attributes_exports = attributes_exports; exports.initializeObservabilitySdkConfig = initializeObservabilitySdkConfig; exports.getDataCaptureMode = getDataCaptureMode; exports.shouldCaptureInput = shouldCaptureInput; exports.shouldCaptureOutput = shouldCaptureOutput;
184
- //# sourceMappingURL=chunk-DISMHYXC.js.map
186
+ //# sourceMappingURL=chunk-CKIZDPIJ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-CKIZDPIJ.js","../src/logger/index.ts","../src/observability-sdk/semconv/attributes.ts","../src/observability-sdk/features/data-capture/utils.ts","../src/observability-sdk/config.ts"],"names":[],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-CKIZDPIJ.js","sourcesContent":[null,"// Logger utility for SDKs\n//\n// Usage:\n// - If you pass your own Logger implementation, the SDK will use it as-is (no log level filtering or prefixing applied).\n// - If you use ConsoleLogger, you can specify log level and prefix options.\n// - NoOpLogger disables all logging.\n//\n// Example:\n// const logger = new ConsoleLogger({ level: \"warn\", prefix: \"SDK\" });\n// logger.info(\"This will not show\");\n// logger.warn(\"This will show with prefix\");\n//\n// // If you pass your own logger, SDK will not filter logs:\n// const customLogger: Logger = { ... };\n// // SDK uses customLogger as-is\n\nexport type LogLevel = \"debug\" | \"info\" | \"warn\" | \"error\";\n\nconst logLevelOrder: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3,\n} as const;\n\nexport interface Logger {\n debug: (message: string, ...args: unknown[]) => void;\n info: (message: string, ...args: unknown[]) => void;\n warn: (message: string, ...args: unknown[]) => void;\n error: (message: string, ...args: unknown[]) => void;\n}\n\nexport class NoOpLogger implements Logger {\n debug: () => void = () => { /* noop */ }\n info: () => void = () => { /* noop */ }\n warn: () => void = () => { /* noop */ }\n error: () => void = () => { /* noop */ }\n}\n\ninterface ConsoleLoggerOptions {\n level: LogLevel;\n prefix?: string;\n}\n\n/**\n * ConsoleLogger applies log level filtering and optional prefixing.\n * If you pass your own Logger, the SDK will not apply log level filtering or prefixing.\n */\nexport class ConsoleLogger implements Logger {\n private level: LogLevel;\n private prefix?: string;\n\n constructor(options: ConsoleLoggerOptions = { level: \"warn\" }) {\n this.level = options.level;\n this.prefix = options.prefix;\n }\n\n private shouldLog(level: LogLevel): boolean {\n return logLevelOrder[level] >= logLevelOrder[this.level];\n }\n\n private format(message: string): string {\n return this.prefix ? `[${this.prefix}] ${message}` : message;\n }\n\n debug: (message: string, ...args: unknown[]) => void = (message: string, ...args: unknown[]): void => {\n if (this.shouldLog(\"debug\")) console.debug(this.format(message), ...args);\n };\n info: (message: string, ...args: unknown[]) => void = (message: string, ...args: unknown[]): void => {\n if (this.shouldLog(\"info\")) console.info(this.format(message), ...args);\n };\n warn: (message: string, ...args: unknown[]) => void = (message: string, ...args: unknown[]): void => {\n if (this.shouldLog(\"warn\")) console.warn(this.format(message), ...args);\n }\n error: (message: string, ...args: unknown[]) => void = (message: string, ...args: unknown[]): void => {\n if (this.shouldLog(\"error\")) console.error(this.format(message), ...args);\n }\n}\n","/*\n This file contains the semantic conventions for attributes either owned by LangWatch, or\n which are no yet part of the OpenTelemetry semantic conventions for Gen AI.\n\n Any that are not yet part of the OpenTelemetry semantic conventions for Gen AI are\n marked with an UNSTABLE_ prefix.\n*/\n\n/**\n * LangWatch input data attribute key\n * Used to store the input data for a span or event\n */\nexport const ATTR_LANGWATCH_INPUT = \"langwatch.input\";\n\n/**\n * LangWatch output data attribute key\n * Used to store the output data for a span or event\n */\nexport const ATTR_LANGWATCH_OUTPUT = \"langwatch.output\";\n\n/**\n * LangWatch span type attribute key\n * Used to identify the type of span being traced\n */\nexport const ATTR_LANGWATCH_SPAN_TYPE = \"langwatch.span.type\";\n\n/**\n * LangWatch RAG contexts attribute key\n * Used to store retrieval-augmented generation contexts\n */\nexport const ATTR_LANGWATCH_RAG_CONTEXTS = \"langwatch.contexts\";\n\n/**\n * LangWatch metrics attribute key\n * Used to store custom metrics data\n */\nexport const ATTR_LANGWATCH_METRICS = \"langwatch.metrics\";\n\n/**\n * LangWatch SDK version attribute key\n * Used to track the version of the LangWatch SDK being used\n */\nexport const ATTR_LANGWATCH_SDK_VERSION = \"langwatch.sdk.version\";\n\n/**\n * LangWatch SDK name attribute key\n * Used to identify the LangWatch SDK implementation\n */\nexport const ATTR_LANGWATCH_SDK_NAME = \"langwatch.sdk.name\";\n\n/**\n * LangWatch SDK language attribute key\n * Used to identify the programming language of the SDK\n */\nexport const ATTR_LANGWATCH_SDK_LANGUAGE = \"langwatch.sdk.language\";\n\n/**\n * LangWatch timestamps attribute key\n * Used to store timing information for events\n */\nexport const ATTR_LANGWATCH_TIMESTAMPS = \"langwatch.timestamps\";\n\n/**\n * LangWatch custom evaluation attribute key\n * Used to store custom evaluation data\n */\nexport const ATTR_LANGWATCH_EVALUATION_CUSTOM = \"langwatch.evaluation.custom\";\n\n/**\n * LangWatch parameters attribute key\n * Used to store parameter data for operations\n */\nexport const ATTR_LANGWATCH_PARAMS = \"langwatch.params\";\n\n/**\n * LangWatch customer ID attribute key\n * Used to identify the customer associated with the trace\n */\nexport const ATTR_LANGWATCH_CUSTOMER_ID = \"langwatch.customer.id\";\n\n/**\n * LangWatch thread ID attribute key\n * Used to group related operations within a conversation thread\n */\nexport const ATTR_LANGWATCH_THREAD_ID = \"langwatch.thread.id\";\n\n/**\n * LangWatch user ID attribute key\n * Used to store the user ID for a span or event\n */\nexport const ATTR_LANGWATCH_USER_ID = \"langwatch.user.id\";\n\n/**\n * LangWatch tags attribute key\n * Used to store tags for a span or event\n */\nexport const ATTR_LANGWATCH_TAGS = \"langwatch.tags\";\n\n/**\n * LangWatch streaming attribute key\n * Used to indicate if the operation involves streaming\n */\nexport const ATTR_LANGWATCH_STREAMING = \"langwatch.gen_ai.streaming\";\n\n/**\n * LangWatch prompt ID attribute key\n * Used to identify the specific prompt being used\n */\nexport const ATTR_LANGWATCH_PROMPT_ID = \"langwatch.prompt.id\";\n\n/**\n * LangWatch prompt ID attribute key\n * Used to identify the specific prompt being used\n */\nexport const ATTR_LANGWATCH_PROMPT_HANDLE = \"langwatch.prompt.handle\";\n\n/**\n * LangWatch prompt version ID attribute key\n * Used to identify the specific version of a prompt\n */\nexport const ATTR_LANGWATCH_PROMPT_VERSION_ID = \"langwatch.prompt.version.id\";\n\n/**\n * LangWatch prompt variables attribute key\n * Used to store variables used in prompt templates\n */\nexport const ATTR_LANGWATCH_PROMPT_VARIABLES = \"langwatch.prompt.variables\";\n\n/**\n * LangWatch prompt selected ID attribute key\n * Used to identify which prompt was selected from a set\n */\nexport const ATTR_LANGWATCH_PROMPT_SELECTED_ID = \"langwatch.prompt.selected.id\";\n\n/**\n * LangWatch prompt version number attribute key\n * Used to track the version number of a prompt\n */\nexport const ATTR_LANGWATCH_PROMPT_VERSION_NUMBER =\n \"langwatch.prompt.version.number\";\n\n/**\n * LangWatch LangChain tags attribute key\n * Used to store tags associated with LangChain operations\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_TAGS = \"langwatch.langchain.tags\";\n\n/**\n * LangWatch LangChain event name attribute key\n * Used to identify the specific LangChain event type\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_EVENT_NAME = \"langwatch.langchain.event_name\";\n\n/**\n * LangWatch LangChain run ID attribute key\n * Used to identify a specific LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_ID = \"langwatch.langchain.run.id\";\n\n/**\n * LangWatch LangChain run tags attribute key\n * Used to store tags associated with a LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_TAGS = \"langwatch.langchain.run.tags\";\n\n/**\n * LangWatch LangChain run type attribute key\n * Used to identify the type of LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_TYPE = \"langwatch.langchain.run.type\";\n\n/**\n * LangWatch LangChain run metadata attribute key\n * Used to store metadata associated with a LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_METADATA = \"langwatch.langchain.run.metadata\";\n\n/**\n * LangWatch LangChain run extra parameters attribute key\n * Used to store additional parameters for a LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_EXTRA_PARAMS = \"langwatch.langchain.run.extra_params\";\n\n/**\n * LangWatch LangChain run parent ID attribute key\n * Used to identify the parent run in a hierarchical structure\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_PARENT_ID =\n \"langwatch.langchain.run.parent.id\";\n","import { type DataCaptureMode } from \"./types\";\n\n/**\n * Validates a data capture mode.\n */\nexport function validateDataCaptureMode(mode: DataCaptureMode): boolean {\n return [\"none\", \"input\", \"output\", \"all\"].includes(mode);\n}\n","import { type Logger, NoOpLogger } from \"../logger/index.js\";\nimport {\n type DataCaptureMode,\n type DataCaptureContext,\n type DataCaptureOptions,\n} from \"./features/data-capture/types.js\";\nimport { validateDataCaptureMode } from \"./features/data-capture/utils.js\";\n\n/**\n * @module observability/config\n * @description\n * Provides configuration management for the LangWatch Observability SDK, including logger and data capture settings.\n *\n * @remarks\n * This module allows you to initialize, retrieve, and reset the global observability configuration. It also provides utilities for determining data capture behavior based on context and configuration.\n *\n * @see {@link ObservabilityConfig}\n * @see {@link initializeObservabilitySdkConfig}\n * @see {@link getObservabilitySdkConfig}\n * @see {@link resetObservabilitySdkConfig}\n * @see {@link getDataCaptureMode}\n * @see {@link shouldCaptureInput}\n * @see {@link shouldCaptureOutput}\n */\n/**\n * Configuration options for the LangWatch Observability SDK.\n *\n * @property logger - The logger instance to use for SDK logging.\n * @property dataCapture - Configuration for automatic data capture. Can be a string, function, or object.\n *\n * @example\n * ```ts\n * import { ObservabilityConfig, initializeObservabilitySdkConfig } from \"@langwatch/observability\";\n *\n * const config: ObservabilityConfig = {\n * logger: new ConsoleLogger(),\n * dataCapture: \"all\",\n * };\n *\n * initializeObservabilitySdkConfig(config);\n * ```\n */\nexport interface ObservabilityConfig {\n /**\n * The logger to use for the observability SDK.\n *\n * @default NoOpLogger\n */\n logger: Logger;\n\n /**\n * Configuration for automatic data capture.\n *\n * @default \"all\"\n */\n dataCapture?: DataCaptureOptions;\n}\n\n/**\n * The observability SDK config.\n */\nlet observabilitySdkConfig: ObservabilityConfig | null = null;\n\n/**\n * Initializes the global observability SDK configuration.\n *\n * @param config - The configuration object to use.\n *\n * @remarks\n * This function should be called once at application startup, before using any observability features.\n *\n * @warning\n * Calling this function will intentionally overwrite any existing configuration. This is by design to allow re-initialization in dynamic or testing environments. If you call this function multiple times, the most recent configuration will take effect.\n *\n * @example\n * ```ts\n * initializeObservabilitySdkConfig({ logger: new ConsoleLogger() });\n * ```\n */\nexport function initializeObservabilitySdkConfig(config: ObservabilityConfig) {\n observabilitySdkConfig = config;\n}\n\n/**\n * Resets the global observability SDK configuration to its initial state (`null`).\n *\n * @remarks\n * Useful for testing or re-initializing the SDK in dynamic environments.\n *\n * @example\n * ```ts\n * resetObservabilitySdkConfig();\n * ```\n */\nexport function resetObservabilitySdkConfig() {\n observabilitySdkConfig = null;\n}\n\n/**\n * Retrieves the current observability SDK configuration.\n *\n * @param options - Optional settings.\n * @param options.throwOnUninitialized - If true, throws an error if the config is not initialized. Defaults to `false` unless `NODE_ENV` is `development`.\n * @returns The current {@link ObservabilityConfig}.\n *\n * @throws {Error} If the config is uninitialized and `throwOnUninitialized` is true or in development mode.\n *\n * @example\n * ```ts\n * const config = getObservabilitySdkConfig();\n * ```\n */\nexport function getObservabilitySdkConfig(options?: {\n throwOnUninitialized?: boolean;\n}): ObservabilityConfig {\n if (!observabilitySdkConfig) {\n const message =\n \"[LangWatch Observability SDK] Please call setupObservability() before using the Observability SDK\";\n\n if (\n options?.throwOnUninitialized ||\n process.env.NODE_ENV === \"development\"\n ) {\n throw new Error(message);\n }\n\n // Use a default logger that can be configured\n return {\n logger: new NoOpLogger(),\n };\n }\n return observabilitySdkConfig;\n}\n\n/**\n * Gets the logger instance from the current observability SDK configuration.\n *\n * @returns The configured {@link Logger} instance.\n *\n * @example\n * ```ts\n * const logger = getObservabilitySdkLogger();\n * logger.info(\"Observability initialized\");\n * ```\n */\nexport function getObservabilitySdkLogger(): Logger {\n return getObservabilitySdkConfig().logger;\n}\n\n/**\n * Determines the effective data capture mode.\n *\n * @returns The resolved {@link DataCaptureMode} (\"all\", \"input\", or \"output\").\n *\n * @remarks\n * The mode is determined by the configuration, which can be a string, function, or object. Defaults to \"all\" if not specified.\n *\n * @example\n * ```ts\n * const mode = getDataCaptureMode();\n * ```\n */\nexport function getDataCaptureMode(): DataCaptureMode {\n const config = getObservabilitySdkConfig();\n\n if (!config.dataCapture) {\n return \"all\"; // Default: capture both input and output\n }\n\n // Handle different config formats\n if (typeof config.dataCapture === \"string\") {\n const validModes: DataCaptureMode[] = [\"none\", \"input\", \"output\", \"all\"];\n if (validModes.includes(config.dataCapture)) {\n return config.dataCapture;\n }\n\n\n getObservabilitySdkLogger().warn(\n `Invalid data capture mode: ${config.dataCapture}. Using default: \"all\"`,\n );\n\n return \"all\";\n }\n\n if (typeof config.dataCapture === \"object\" && config.dataCapture.mode &&validateDataCaptureMode(config.dataCapture.mode)) {\n return config.dataCapture.mode;\n }\n\n return \"all\"; // Default fallback\n}\n\n/**\n * Determines if input data should be captured.\n *\n * @returns `true` if input should be captured, otherwise `false`.\n *\n * @example\n * ```ts\n * if (shouldCaptureInput()) {\n * // Capture input\n * }\n * ```\n */\nexport function shouldCaptureInput(): boolean {\n const mode = getDataCaptureMode();\n return mode === \"input\" || mode === \"all\";\n}\n\n/**\n * Determines if output data should be captured.\n *\n * @returns `true` if output should be captured, otherwise `false`.\n *\n * @example\n * ```ts\n * if (shouldCaptureOutput()) {\n * // Capture output\n * }\n * ```\n */\nexport function shouldCaptureOutput(): boolean {\n const mode = getDataCaptureMode();\n return mode === \"output\" || mode === \"all\";\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
2
 
3
- var _chunkCAZONSXVjs = require('./chunk-CAZONSXV.js');
3
+ var _chunk36XAYVMCjs = require('./chunk-36XAYVMC.js');
4
4
 
5
5
  // src/cli/utils/init.ts
6
6
  var _readline = require('readline'); var readline = _interopRequireWildcard(_readline);
@@ -19,14 +19,14 @@ var promptUser = (question) => {
19
19
  };
20
20
  var initializeProject = async () => {
21
21
  console.log(_chalk2.default.blue("Initializing LangWatch prompts project..."));
22
- const configResult = _chunkCAZONSXVjs.FileManager.initializePromptsConfig();
22
+ const configResult = _chunk36XAYVMCjs.FileManager.initializePromptsConfig();
23
23
  if (configResult.created) {
24
24
  console.log(_chalk2.default.green(`\u2713 Created ${_chalk2.default.gray("./prompts.json")}`));
25
25
  const shouldAddGitignore = await promptUser(
26
26
  _chalk2.default.yellow("Add 'prompts/.materialized' to .gitignore? [Y/n]: ")
27
27
  );
28
28
  if (shouldAddGitignore === "" || shouldAddGitignore === "y" || shouldAddGitignore === "yes") {
29
- const gitignoreResult = _chunkCAZONSXVjs.FileManager.addToGitignore(
29
+ const gitignoreResult = _chunk36XAYVMCjs.FileManager.addToGitignore(
30
30
  "prompts/.materialized"
31
31
  );
32
32
  if (gitignoreResult.added) {
@@ -58,13 +58,13 @@ var initializeProject = async () => {
58
58
  } else {
59
59
  console.log(_chalk2.default.gray(`\u2022 prompts.json already exists`));
60
60
  }
61
- const lockResult = _chunkCAZONSXVjs.FileManager.initializePromptsLock();
61
+ const lockResult = _chunk36XAYVMCjs.FileManager.initializePromptsLock();
62
62
  if (lockResult.created) {
63
63
  console.log(_chalk2.default.green(`\u2713 Created ${_chalk2.default.gray("./prompts-lock.json")}`));
64
64
  } else {
65
65
  console.log(_chalk2.default.gray(`\u2022 prompts-lock.json already exists`));
66
66
  }
67
- _chunkCAZONSXVjs.FileManager.ensureDirectories();
67
+ _chunk36XAYVMCjs.FileManager.ensureDirectories();
68
68
  console.log(
69
69
  _chalk2.default.green(`\u2713 Created ${_chalk2.default.gray("./prompts/")} directory structure`)
70
70
  );
@@ -74,7 +74,7 @@ var initializeProject = async () => {
74
74
  console.log(_chalk2.default.gray(" langwatch prompt add <name>"));
75
75
  };
76
76
  var ensureProjectInitialized = async (shouldPromptForGitignore = true) => {
77
- const configResult = _chunkCAZONSXVjs.FileManager.initializePromptsConfig();
77
+ const configResult = _chunk36XAYVMCjs.FileManager.initializePromptsConfig();
78
78
  let askedAboutGitignore = false;
79
79
  if (configResult.created) {
80
80
  console.log(_chalk2.default.green(`\u2713 Created ${_chalk2.default.gray("./prompts.json")}`));
@@ -84,7 +84,7 @@ var ensureProjectInitialized = async (shouldPromptForGitignore = true) => {
84
84
  _chalk2.default.yellow("Add 'prompts/.materialized' to .gitignore? [Y/n]: ")
85
85
  );
86
86
  if (shouldAddGitignore === "" || shouldAddGitignore === "y" || shouldAddGitignore === "yes") {
87
- const gitignoreResult = _chunkCAZONSXVjs.FileManager.addToGitignore(
87
+ const gitignoreResult = _chunk36XAYVMCjs.FileManager.addToGitignore(
88
88
  "prompts/.materialized"
89
89
  );
90
90
  if (gitignoreResult.added) {
@@ -115,11 +115,11 @@ var ensureProjectInitialized = async (shouldPromptForGitignore = true) => {
115
115
  }
116
116
  }
117
117
  }
118
- const lockResult = _chunkCAZONSXVjs.FileManager.initializePromptsLock();
118
+ const lockResult = _chunk36XAYVMCjs.FileManager.initializePromptsLock();
119
119
  if (lockResult.created) {
120
120
  console.log(_chalk2.default.green(`\u2713 Created ${_chalk2.default.gray("./prompts-lock.json")}`));
121
121
  }
122
- _chunkCAZONSXVjs.FileManager.ensureDirectories();
122
+ _chunk36XAYVMCjs.FileManager.ensureDirectories();
123
123
  return {
124
124
  configCreated: configResult.created,
125
125
  lockCreated: lockResult.created
@@ -130,4 +130,4 @@ var ensureProjectInitialized = async (shouldPromptForGitignore = true) => {
130
130
 
131
131
 
132
132
  exports.initializeProject = initializeProject; exports.ensureProjectInitialized = ensureProjectInitialized;
133
- //# sourceMappingURL=chunk-7OZKH5K2.js.map
133
+ //# sourceMappingURL=chunk-DZH6SY3Z.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-7OZKH5K2.js","../src/cli/utils/init.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;ACJA,uFAA0B;AAC1B,4EAAkB;AAGlB,IAAM,WAAA,EAAa,CAAC,QAAA,EAAA,GAAsC;AACxD,EAAA,MAAM,GAAA,EAAc,QAAA,CAAA,eAAA,CAAgB;AAAA,IAClC,KAAA,EAAO,OAAA,CAAQ,KAAA;AAAA,IACf,MAAA,EAAQ,OAAA,CAAQ;AAAA,EAClB,CAAC,CAAA;AAED,EAAA,OAAO,IAAI,OAAA,CAAQ,CAAC,OAAA,EAAA,GAAY;AAC9B,IAAA,EAAA,CAAG,QAAA,CAAS,QAAA,EAAU,CAAC,MAAA,EAAA,GAAW;AAChC,MAAA,EAAA,CAAG,KAAA,CAAM,CAAA;AACT,MAAA,OAAA,CAAQ,MAAA,CAAO,IAAA,CAAK,CAAA,CAAE,WAAA,CAAY,CAAC,CAAA;AAAA,IACrC,CAAC,CAAA;AAAA,EACH,CAAC,CAAA;AACH,CAAA;AAEO,IAAM,kBAAA,EAAoB,MAAA,CAAA,EAAA,GAA2B;AAC1D,EAAA,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAM,IAAA,CAAK,2CAA2C,CAAC,CAAA;AAGnE,EAAA,MAAM,aAAA,EAAe,4BAAA,CAAY,uBAAA,CAAwB,CAAA;AACzD,EAAA,GAAA,CAAI,YAAA,CAAa,OAAA,EAAS;AACxB,IAAA,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAM,KAAA,CAAM,CAAA,eAAA,EAAa,eAAA,CAAM,IAAA,CAAK,gBAAgB,CAAC,CAAA,CAAA;AAGhC,IAAA;AACkC,MAAA;AACnE,IAAA;AAKE,IAAA;AAEoC,MAAA;AAClC,QAAA;AACF,MAAA;AAC2B,MAAA;AACI,QAAA;AACnB,UAAA;AACA,YAAA;AACa,cAAA;AACf,gBAAA;AACD,cAAA;AACH,YAAA;AACF,UAAA;AACK,QAAA;AACG,UAAA;AACA,YAAA;AAC+B,cAAA;AACjC,gBAAA;AACD,cAAA;AACH,YAAA;AACF,UAAA;AACF,QAAA;AACK,MAAA;AACG,QAAA;AACA,UAAA;AACoC,YAAA;AAC1C,UAAA;AACF,QAAA;AACF,MAAA;AACF,IAAA;AACK,EAAA;AACkD,IAAA;AACzD,EAAA;AAGqD,EAAA;AAC7B,EAAA;AAC0B,IAAA;AAC3C,EAAA;AACuD,IAAA;AAC9D,EAAA;AAG8B,EAAA;AACtB,EAAA;AAC2C,IAAA;AACnD,EAAA;AAEQ,EAAA;AACM,IAAA;AACd,EAAA;AACuD,EAAA;AACzD;AAIgE;AAEL,EAAA;AAC/B,EAAA;AAEA,EAAA;AACyC,IAAA;AAGX,IAAA;AAC9B,MAAA;AACW,MAAA;AACkC,QAAA;AACnE,MAAA;AAKE,MAAA;AAEoC,QAAA;AAClC,UAAA;AACF,QAAA;AAC2B,QAAA;AACI,UAAA;AACnB,YAAA;AACA,cAAA;AACa,gBAAA;AACf,kBAAA;AACD,gBAAA;AACH,cAAA;AACF,YAAA;AACK,UAAA;AACG,YAAA;AACA,cAAA;AAC+B,gBAAA;AACjC,kBAAA;AACD,gBAAA;AACH,cAAA;AACF,YAAA;AACF,UAAA;AACK,QAAA;AACG,UAAA;AACA,YAAA;AACoC,cAAA;AAC1C,YAAA;AACF,UAAA;AACF,QAAA;AACF,MAAA;AACF,IAAA;AACF,EAAA;AAGqD,EAAA;AAC7B,EAAA;AAC0B,IAAA;AAClD,EAAA;AAG8B,EAAA;AAEvB,EAAA;AACuB,IAAA;AACJ,IAAA;AAC1B,EAAA;AACF;AD7B2E;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-7OZKH5K2.js","sourcesContent":[null,"import * as readline from \"readline\";\nimport chalk from \"chalk\";\nimport { FileManager } from \"./fileManager\";\n\nconst promptUser = (question: string): Promise<string> => {\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n return new Promise((resolve) => {\n rl.question(question, (answer) => {\n rl.close();\n resolve(answer.trim().toLowerCase());\n });\n });\n};\n\nexport const initializeProject = async (): Promise<void> => {\n console.log(chalk.blue(\"Initializing LangWatch prompts project...\"));\n\n // Initialize prompts.json\n const configResult = FileManager.initializePromptsConfig();\n if (configResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts.json\")}`));\n\n // Ask about .gitignore\n const shouldAddGitignore = await promptUser(\n chalk.yellow(\"Add 'prompts/.materialized' to .gitignore? [Y/n]: \"),\n );\n\n if (\n shouldAddGitignore === \"\" ||\n shouldAddGitignore === \"y\" ||\n shouldAddGitignore === \"yes\"\n ) {\n const gitignoreResult = FileManager.addToGitignore(\n \"prompts/.materialized\",\n );\n if (gitignoreResult.added) {\n if (gitignoreResult.existed) {\n console.log(\n chalk.green(\n `✓ Added ${chalk.gray(\n \"prompts/.materialized\",\n )} to existing .gitignore`,\n ),\n );\n } else {\n console.log(\n chalk.green(\n `✓ Created .gitignore with ${chalk.gray(\n \"prompts/.materialized\",\n )}`,\n ),\n );\n }\n } else {\n console.log(\n chalk.gray(\n `• ${chalk.gray(\"prompts/.materialized\")} already in .gitignore`,\n ),\n );\n }\n }\n } else {\n console.log(chalk.gray(`• prompts.json already exists`));\n }\n\n // Initialize lock file\n const lockResult = FileManager.initializePromptsLock();\n if (lockResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts-lock.json\")}`));\n } else {\n console.log(chalk.gray(`• prompts-lock.json already exists`));\n }\n\n // Ensure directories exist\n FileManager.ensureDirectories();\n console.log(\n chalk.green(`✓ Created ${chalk.gray(\"./prompts/\")} directory structure`),\n );\n\n console.log(\n chalk.green(\"\\n✨ Project initialized! You can now add prompts with:\"),\n );\n console.log(chalk.gray(\" langwatch prompt add <name>\"));\n};\n\nexport const ensureProjectInitialized = async (\n shouldPromptForGitignore = true,\n): Promise<{ configCreated: boolean; lockCreated: boolean }> => {\n // Initialize prompts.json\n const configResult = FileManager.initializePromptsConfig();\n let askedAboutGitignore = false;\n\n if (configResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts.json\")}`));\n\n // Ask about .gitignore only if we should prompt and haven't asked yet\n if (shouldPromptForGitignore && !askedAboutGitignore) {\n askedAboutGitignore = true;\n const shouldAddGitignore = await promptUser(\n chalk.yellow(\"Add 'prompts/.materialized' to .gitignore? [Y/n]: \"),\n );\n\n if (\n shouldAddGitignore === \"\" ||\n shouldAddGitignore === \"y\" ||\n shouldAddGitignore === \"yes\"\n ) {\n const gitignoreResult = FileManager.addToGitignore(\n \"prompts/.materialized\",\n );\n if (gitignoreResult.added) {\n if (gitignoreResult.existed) {\n console.log(\n chalk.green(\n `✓ Added ${chalk.gray(\n \"prompts/.materialized\",\n )} to existing .gitignore`,\n ),\n );\n } else {\n console.log(\n chalk.green(\n `✓ Created .gitignore with ${chalk.gray(\n \"prompts/.materialized\",\n )}`,\n ),\n );\n }\n } else {\n console.log(\n chalk.gray(\n `• ${chalk.gray(\"prompts/.materialized\")} already in .gitignore`,\n ),\n );\n }\n }\n }\n }\n\n // Initialize lock file\n const lockResult = FileManager.initializePromptsLock();\n if (lockResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts-lock.json\")}`));\n }\n\n // Ensure directories exist\n FileManager.ensureDirectories();\n\n return {\n configCreated: configResult.created,\n lockCreated: lockResult.created,\n };\n};\n"]}
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-DZH6SY3Z.js","../src/cli/utils/init.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;ACJA,uFAA0B;AAC1B,4EAAkB;AAGlB,IAAM,WAAA,EAAa,CAAC,QAAA,EAAA,GAAsC;AACxD,EAAA,MAAM,GAAA,EAAc,QAAA,CAAA,eAAA,CAAgB;AAAA,IAClC,KAAA,EAAO,OAAA,CAAQ,KAAA;AAAA,IACf,MAAA,EAAQ,OAAA,CAAQ;AAAA,EAClB,CAAC,CAAA;AAED,EAAA,OAAO,IAAI,OAAA,CAAQ,CAAC,OAAA,EAAA,GAAY;AAC9B,IAAA,EAAA,CAAG,QAAA,CAAS,QAAA,EAAU,CAAC,MAAA,EAAA,GAAW;AAChC,MAAA,EAAA,CAAG,KAAA,CAAM,CAAA;AACT,MAAA,OAAA,CAAQ,MAAA,CAAO,IAAA,CAAK,CAAA,CAAE,WAAA,CAAY,CAAC,CAAA;AAAA,IACrC,CAAC,CAAA;AAAA,EACH,CAAC,CAAA;AACH,CAAA;AAEO,IAAM,kBAAA,EAAoB,MAAA,CAAA,EAAA,GAA2B;AAC1D,EAAA,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAM,IAAA,CAAK,2CAA2C,CAAC,CAAA;AAGnE,EAAA,MAAM,aAAA,EAAe,4BAAA,CAAY,uBAAA,CAAwB,CAAA;AACzD,EAAA,GAAA,CAAI,YAAA,CAAa,OAAA,EAAS;AACxB,IAAA,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAM,KAAA,CAAM,CAAA,eAAA,EAAa,eAAA,CAAM,IAAA,CAAK,gBAAgB,CAAC,CAAA,CAAA;AAGhC,IAAA;AACkC,MAAA;AACnE,IAAA;AAKE,IAAA;AAEoC,MAAA;AAClC,QAAA;AACF,MAAA;AAC2B,MAAA;AACI,QAAA;AACnB,UAAA;AACA,YAAA;AACa,cAAA;AACf,gBAAA;AACD,cAAA;AACH,YAAA;AACF,UAAA;AACK,QAAA;AACG,UAAA;AACA,YAAA;AAC+B,cAAA;AACjC,gBAAA;AACD,cAAA;AACH,YAAA;AACF,UAAA;AACF,QAAA;AACK,MAAA;AACG,QAAA;AACA,UAAA;AACoC,YAAA;AAC1C,UAAA;AACF,QAAA;AACF,MAAA;AACF,IAAA;AACK,EAAA;AACkD,IAAA;AACzD,EAAA;AAGqD,EAAA;AAC7B,EAAA;AAC0B,IAAA;AAC3C,EAAA;AACuD,IAAA;AAC9D,EAAA;AAG8B,EAAA;AACtB,EAAA;AAC2C,IAAA;AACnD,EAAA;AAEQ,EAAA;AACM,IAAA;AACd,EAAA;AACuD,EAAA;AACzD;AAIgE;AAEL,EAAA;AAC/B,EAAA;AAEA,EAAA;AACyC,IAAA;AAGX,IAAA;AAC9B,MAAA;AACW,MAAA;AACkC,QAAA;AACnE,MAAA;AAKE,MAAA;AAEoC,QAAA;AAClC,UAAA;AACF,QAAA;AAC2B,QAAA;AACI,UAAA;AACnB,YAAA;AACA,cAAA;AACa,gBAAA;AACf,kBAAA;AACD,gBAAA;AACH,cAAA;AACF,YAAA;AACK,UAAA;AACG,YAAA;AACA,cAAA;AAC+B,gBAAA;AACjC,kBAAA;AACD,gBAAA;AACH,cAAA;AACF,YAAA;AACF,UAAA;AACK,QAAA;AACG,UAAA;AACA,YAAA;AACoC,cAAA;AAC1C,YAAA;AACF,UAAA;AACF,QAAA;AACF,MAAA;AACF,IAAA;AACF,EAAA;AAGqD,EAAA;AAC7B,EAAA;AAC0B,IAAA;AAClD,EAAA;AAG8B,EAAA;AAEvB,EAAA;AACuB,IAAA;AACJ,IAAA;AAC1B,EAAA;AACF;AD7B2E;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-DZH6SY3Z.js","sourcesContent":[null,"import * as readline from \"readline\";\nimport chalk from \"chalk\";\nimport { FileManager } from \"./fileManager\";\n\nconst promptUser = (question: string): Promise<string> => {\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n return new Promise((resolve) => {\n rl.question(question, (answer) => {\n rl.close();\n resolve(answer.trim().toLowerCase());\n });\n });\n};\n\nexport const initializeProject = async (): Promise<void> => {\n console.log(chalk.blue(\"Initializing LangWatch prompts project...\"));\n\n // Initialize prompts.json\n const configResult = FileManager.initializePromptsConfig();\n if (configResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts.json\")}`));\n\n // Ask about .gitignore\n const shouldAddGitignore = await promptUser(\n chalk.yellow(\"Add 'prompts/.materialized' to .gitignore? [Y/n]: \"),\n );\n\n if (\n shouldAddGitignore === \"\" ||\n shouldAddGitignore === \"y\" ||\n shouldAddGitignore === \"yes\"\n ) {\n const gitignoreResult = FileManager.addToGitignore(\n \"prompts/.materialized\",\n );\n if (gitignoreResult.added) {\n if (gitignoreResult.existed) {\n console.log(\n chalk.green(\n `✓ Added ${chalk.gray(\n \"prompts/.materialized\",\n )} to existing .gitignore`,\n ),\n );\n } else {\n console.log(\n chalk.green(\n `✓ Created .gitignore with ${chalk.gray(\n \"prompts/.materialized\",\n )}`,\n ),\n );\n }\n } else {\n console.log(\n chalk.gray(\n `• ${chalk.gray(\"prompts/.materialized\")} already in .gitignore`,\n ),\n );\n }\n }\n } else {\n console.log(chalk.gray(`• prompts.json already exists`));\n }\n\n // Initialize lock file\n const lockResult = FileManager.initializePromptsLock();\n if (lockResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts-lock.json\")}`));\n } else {\n console.log(chalk.gray(`• prompts-lock.json already exists`));\n }\n\n // Ensure directories exist\n FileManager.ensureDirectories();\n console.log(\n chalk.green(`✓ Created ${chalk.gray(\"./prompts/\")} directory structure`),\n );\n\n console.log(\n chalk.green(\"\\n✨ Project initialized! You can now add prompts with:\"),\n );\n console.log(chalk.gray(\" langwatch prompt add <name>\"));\n};\n\nexport const ensureProjectInitialized = async (\n shouldPromptForGitignore = true,\n): Promise<{ configCreated: boolean; lockCreated: boolean }> => {\n // Initialize prompts.json\n const configResult = FileManager.initializePromptsConfig();\n let askedAboutGitignore = false;\n\n if (configResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts.json\")}`));\n\n // Ask about .gitignore only if we should prompt and haven't asked yet\n if (shouldPromptForGitignore && !askedAboutGitignore) {\n askedAboutGitignore = true;\n const shouldAddGitignore = await promptUser(\n chalk.yellow(\"Add 'prompts/.materialized' to .gitignore? [Y/n]: \"),\n );\n\n if (\n shouldAddGitignore === \"\" ||\n shouldAddGitignore === \"y\" ||\n shouldAddGitignore === \"yes\"\n ) {\n const gitignoreResult = FileManager.addToGitignore(\n \"prompts/.materialized\",\n );\n if (gitignoreResult.added) {\n if (gitignoreResult.existed) {\n console.log(\n chalk.green(\n `✓ Added ${chalk.gray(\n \"prompts/.materialized\",\n )} to existing .gitignore`,\n ),\n );\n } else {\n console.log(\n chalk.green(\n `✓ Created .gitignore with ${chalk.gray(\n \"prompts/.materialized\",\n )}`,\n ),\n );\n }\n } else {\n console.log(\n chalk.gray(\n `• ${chalk.gray(\"prompts/.materialized\")} already in .gitignore`,\n ),\n );\n }\n }\n }\n }\n\n // Initialize lock file\n const lockResult = FileManager.initializePromptsLock();\n if (lockResult.created) {\n console.log(chalk.green(`✓ Created ${chalk.gray(\"./prompts-lock.json\")}`));\n }\n\n // Ensure directories exist\n FileManager.ensureDirectories();\n\n return {\n configCreated: configResult.created,\n lockCreated: lockResult.created,\n };\n};\n"]}
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  attributes_exports
3
- } from "./chunk-YNQ44U6D.mjs";
3
+ } from "./chunk-I2SOBPAF.mjs";
4
4
 
5
5
  // src/observability-sdk/processors/filterable-batch-span-processor.ts
6
6
  import {
@@ -72,4 +72,4 @@ export {
72
72
  FilterableBatchSpanProcessor,
73
73
  DataCapturePresets
74
74
  };
75
- //# sourceMappingURL=chunk-N2V6J3U2.mjs.map
75
+ //# sourceMappingURL=chunk-FEL5FLHA.mjs.map