langwatch 0.22.0 → 0.23.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.
- package/dist/{add-EJSXUSD6.js → add-DVFVWTYU.js} +8 -8
- package/dist/{add-EJSXUSD6.js.map → add-DVFVWTYU.js.map} +1 -1
- package/dist/{add-7QFHK67E.mjs → add-TCJZAPWG.mjs} +5 -5
- package/dist/{assign-JCCQ5D7I.mjs → assign-VH54CNRX.mjs} +5 -5
- package/dist/{assign-5UEB6AJU.js → assign-WY4UY33D.js} +6 -6
- package/dist/{assign-5UEB6AJU.js.map → assign-WY4UY33D.js.map} +1 -1
- package/dist/{chunk-7FD7BEJP.mjs → chunk-2KPA2FK7.mjs} +6 -2
- package/dist/{chunk-7FD7BEJP.mjs.map → chunk-2KPA2FK7.mjs.map} +1 -1
- package/dist/{chunk-DUG35J5N.js → chunk-2VWQGGRZ.js} +14 -14
- package/dist/{chunk-DUG35J5N.js.map → chunk-2VWQGGRZ.js.map} +1 -1
- package/dist/{chunk-ILLEMTW3.mjs → chunk-3CRFCUOQ.mjs} +2 -2
- package/dist/{chunk-ESGWN42J.mjs → chunk-4K2OMMLS.mjs} +2 -2
- package/dist/{chunk-I2LDJPTG.mjs → chunk-7FCVMMAW.mjs} +2 -2
- package/dist/{chunk-KJSFJ5Z3.js → chunk-7U52CTSJ.js} +3 -3
- package/dist/{chunk-KJSFJ5Z3.js.map → chunk-7U52CTSJ.js.map} +1 -1
- package/dist/{chunk-X7QBE6AA.js → chunk-BBCZ4LXG.js} +9 -9
- package/dist/{chunk-X7QBE6AA.js.map → chunk-BBCZ4LXG.js.map} +1 -1
- package/dist/{chunk-D2FHOR76.js → chunk-BLCVVN6P.js} +2 -2
- package/dist/{chunk-D2FHOR76.js.map → chunk-BLCVVN6P.js.map} +1 -1
- package/dist/{chunk-WLMXMXHE.js → chunk-BOL5DI7B.js} +3 -3
- package/dist/chunk-BOL5DI7B.js.map +1 -0
- package/dist/{chunk-2BJPLPLU.js → chunk-CKYNUZLA.js} +8 -8
- package/dist/{chunk-2BJPLPLU.js.map → chunk-CKYNUZLA.js.map} +1 -1
- package/dist/{chunk-Z6MQQXMS.js → chunk-DBUA35L3.js} +4 -4
- package/dist/{chunk-Z6MQQXMS.js.map → chunk-DBUA35L3.js.map} +1 -1
- package/dist/{chunk-HPQFHP6K.js → chunk-EAVYXXJX.js} +4 -4
- package/dist/{chunk-HPQFHP6K.js.map → chunk-EAVYXXJX.js.map} +1 -1
- package/dist/{chunk-AK4YCKWK.js → chunk-EDEAR2QX.js} +5 -5
- package/dist/{chunk-AK4YCKWK.js.map → chunk-EDEAR2QX.js.map} +1 -1
- package/dist/{chunk-AMPLL3EP.js → chunk-FXCSXFDY.js} +3 -3
- package/dist/chunk-FXCSXFDY.js.map +1 -0
- package/dist/{chunk-L3IOXWDG.mjs → chunk-GSZ4QKFH.mjs} +3 -3
- package/dist/{chunk-VMDYRBQ7.js → chunk-GXRQEJ6D.js} +3 -3
- package/dist/chunk-GXRQEJ6D.js.map +1 -0
- package/dist/{chunk-TQYUM3WH.mjs → chunk-HJARRXXA.mjs} +2 -2
- package/dist/chunk-HJARRXXA.mjs.map +1 -0
- package/dist/{chunk-NIW2SFZZ.mjs → chunk-IFCABR3D.mjs} +2 -2
- package/dist/chunk-IFCABR3D.mjs.map +1 -0
- package/dist/{chunk-CYRJSLKD.js → chunk-JIIQDBF2.js} +3 -3
- package/dist/chunk-JIIQDBF2.js.map +1 -0
- package/dist/{chunk-TV6ZXLE5.mjs → chunk-LIUQYWHM.mjs} +2 -2
- package/dist/{chunk-LN33ZL4Z.mjs → chunk-LUBBPBV3.mjs} +2 -2
- package/dist/{chunk-LN33ZL4Z.mjs.map → chunk-LUBBPBV3.mjs.map} +1 -1
- package/dist/{chunk-47F7UDHN.js → chunk-MAI4B2ZR.js} +3 -3
- package/dist/{chunk-47F7UDHN.js.map → chunk-MAI4B2ZR.js.map} +1 -1
- package/dist/{chunk-COKOLKOR.mjs → chunk-N6O7634G.mjs} +3 -3
- package/dist/{chunk-DWHR6QJK.mjs → chunk-NZLR6K3R.mjs} +4 -4
- package/dist/{chunk-WE2PHCFS.js → chunk-PFDDSWCH.js} +3 -3
- package/dist/{chunk-WE2PHCFS.js.map → chunk-PFDDSWCH.js.map} +1 -1
- package/dist/{chunk-LULJYN3P.mjs → chunk-PWBHSOGK.mjs} +2 -2
- package/dist/{chunk-TCO73AV5.mjs → chunk-QJQMCRLL.mjs} +2 -2
- package/dist/{chunk-QH3WUSKF.mjs → chunk-SAR52TH6.mjs} +2 -2
- package/dist/{chunk-CGFG5FCC.js → chunk-SB3SAGAO.js} +3 -3
- package/dist/{chunk-CGFG5FCC.js.map → chunk-SB3SAGAO.js.map} +1 -1
- package/dist/{chunk-5PMWRY5J.js → chunk-SJTBEIRG.js} +3 -3
- package/dist/{chunk-5PMWRY5J.js.map → chunk-SJTBEIRG.js.map} +1 -1
- package/dist/{chunk-HHRXMHVH.js → chunk-V6PD6N4K.js} +3 -3
- package/dist/{chunk-HHRXMHVH.js.map → chunk-V6PD6N4K.js.map} +1 -1
- package/dist/{chunk-YTR56IZO.mjs → chunk-VTLTVATI.mjs} +2 -2
- package/dist/{chunk-JYR4TXSB.mjs → chunk-VUVLYTWK.mjs} +2 -2
- package/dist/{chunk-KH64V3CL.mjs → chunk-WF54BYWA.mjs} +2 -2
- package/dist/chunk-WF54BYWA.mjs.map +1 -0
- package/dist/{chunk-GLCAOVJA.js → chunk-WTRZLGRP.js} +3 -3
- package/dist/{chunk-GLCAOVJA.js.map → chunk-WTRZLGRP.js.map} +1 -1
- package/dist/chunk-XIHOAUIU.mjs +42 -0
- package/dist/chunk-XIHOAUIU.mjs.map +1 -0
- package/dist/{chunk-PO6XRHYW.mjs → chunk-Y5PPNQXM.mjs} +2 -2
- package/dist/{chunk-2OHGLTXZ.mjs → chunk-YD7SA3ZL.mjs} +2 -2
- package/dist/{chunk-NMACMKQN.mjs → chunk-YDRETRB6.mjs} +2 -2
- package/dist/chunk-YDRETRB6.mjs.map +1 -0
- package/dist/chunk-YEDCQTZY.js +42 -0
- package/dist/chunk-YEDCQTZY.js.map +1 -0
- package/dist/{chunk-JWF5KHWM.js → chunk-YNIDOE6Q.js} +11 -11
- package/dist/{chunk-JWF5KHWM.js.map → chunk-YNIDOE6Q.js.map} +1 -1
- package/dist/{chunk-FKIH4XCX.js → chunk-Z76KL7SX.js} +8 -4
- package/dist/chunk-Z76KL7SX.js.map +1 -0
- package/dist/cli/index.js +72 -72
- package/dist/cli/index.mjs +72 -72
- package/dist/{create-RPHO5TZX.js → create-22AV5FP2.js} +8 -6
- package/dist/create-22AV5FP2.js.map +1 -0
- package/dist/{create-4OA73B7I.mjs → create-7FIIBI4T.mjs} +6 -4
- package/dist/create-7FIIBI4T.mjs.map +1 -0
- package/dist/{create-KAPF2AOL.js → create-7LFWJ235.js} +8 -6
- package/dist/create-7LFWJ235.js.map +1 -0
- package/dist/{create-CQ7W2OAA.js → create-AZ3PHE5K.js} +4 -1
- package/dist/create-AZ3PHE5K.js.map +1 -0
- package/dist/{create-XGD3GULQ.js → create-BEG4EIHW.js} +8 -6
- package/dist/create-BEG4EIHW.js.map +1 -0
- package/dist/{create-NFYHBFF5.mjs → create-GPP6BM66.mjs} +6 -4
- package/dist/create-GPP6BM66.mjs.map +1 -0
- package/dist/{create-LWG7ZHEW.mjs → create-IKDIMLMS.mjs} +4 -1
- package/dist/create-IKDIMLMS.mjs.map +1 -0
- package/dist/{create-XZXVGMKU.js → create-O4UEDGLZ.js} +6 -6
- package/dist/{create-XZXVGMKU.js.map → create-O4UEDGLZ.js.map} +1 -1
- package/dist/{create-45FMHT6B.mjs → create-OZ7Z2AES.mjs} +4 -1
- package/dist/create-OZ7Z2AES.mjs.map +1 -0
- package/dist/{create-4U5BPFCT.mjs → create-PS2NZEMT.mjs} +6 -4
- package/dist/create-PS2NZEMT.mjs.map +1 -0
- package/dist/{create-RRI5ZTMI.mjs → create-PWWOD5ET.mjs} +6 -4
- package/dist/create-PWWOD5ET.mjs.map +1 -0
- package/dist/{create-MXYMAFMF.js → create-Q2VNDJVM.js} +4 -1
- package/dist/create-Q2VNDJVM.js.map +1 -0
- package/dist/create-QEKYWQHD.js +18 -0
- package/dist/{create-Z2XFL2HX.js.map → create-QEKYWQHD.js.map} +1 -1
- package/dist/{create-UZ5NDYPV.js → create-SSYLJSGF.js} +9 -6
- package/dist/create-SSYLJSGF.js.map +1 -0
- package/dist/{create-ZU4L3XOF.mjs → create-TVQPOM22.mjs} +7 -4
- package/dist/create-TVQPOM22.mjs.map +1 -0
- package/dist/{create-Z7DUMMQ4.mjs → create-UJNSUW4A.mjs} +5 -5
- package/dist/{create-ARJEJDYU.mjs → create-VBHJZCM5.mjs} +6 -6
- package/dist/{create-FYLUSZTP.js → create-WF3XYRRQ.js} +6 -6
- package/dist/{create-FYLUSZTP.js.map → create-WF3XYRRQ.js.map} +1 -1
- package/dist/{create-OSAXTSUC.js → create-WIMFK6DS.js} +8 -6
- package/dist/create-WIMFK6DS.js.map +1 -0
- package/dist/{create-GGYYU5KM.mjs → create-XPIBPXZI.mjs} +4 -4
- package/dist/{delete-5NINT2KV.mjs → delete-2R62572G.mjs} +4 -4
- package/dist/{delete-QVE52G3Q.mjs → delete-5ENFR4LN.mjs} +4 -4
- package/dist/{delete-2S67GS6A.mjs → delete-5K4CLCFU.mjs} +5 -5
- package/dist/{delete-L3SU34X6.mjs → delete-5QY2NINK.mjs} +4 -4
- package/dist/{delete-CTE3RNKB.mjs → delete-63PUL37J.mjs} +4 -4
- package/dist/{delete-XKF7KO4Y.js → delete-7JQTLLAD.js} +7 -7
- package/dist/{delete-XKF7KO4Y.js.map → delete-7JQTLLAD.js.map} +1 -1
- package/dist/{delete-22LDMLNG.mjs → delete-ALUMMULI.mjs} +4 -4
- package/dist/{delete-I36NLS2V.mjs → delete-BSWXG6TJ.mjs} +4 -4
- package/dist/{delete-ZY2UCN3W.js → delete-FVCS3V2N.js} +6 -6
- package/dist/{delete-ZY2UCN3W.js.map → delete-FVCS3V2N.js.map} +1 -1
- package/dist/{delete-PXGB35PF.js → delete-HUHP4UXY.js} +7 -7
- package/dist/{delete-PXGB35PF.js.map → delete-HUHP4UXY.js.map} +1 -1
- package/dist/{delete-555RUBQA.js → delete-I522RDQH.js} +6 -6
- package/dist/{delete-555RUBQA.js.map → delete-I522RDQH.js.map} +1 -1
- package/dist/{delete-N6OZW65U.js → delete-ML353B46.js} +6 -6
- package/dist/{delete-N6OZW65U.js.map → delete-ML353B46.js.map} +1 -1
- package/dist/{delete-BLTSYYZQ.js → delete-MMN2V7S7.js} +7 -7
- package/dist/{delete-BLTSYYZQ.js.map → delete-MMN2V7S7.js.map} +1 -1
- package/dist/{delete-6ZD3ARMB.js → delete-PMQGPBO7.js} +7 -7
- package/dist/{delete-6ZD3ARMB.js.map → delete-PMQGPBO7.js.map} +1 -1
- package/dist/{delete-PPEXA2V4.js → delete-QSDZF66A.js} +6 -6
- package/dist/{delete-PPEXA2V4.js.map → delete-QSDZF66A.js.map} +1 -1
- package/dist/{delete-J2P2Y2BW.mjs → delete-QT27YCTA.mjs} +4 -4
- package/dist/{delete-R5TSAZOU.js → delete-RFNKZHBB.js} +6 -6
- package/dist/{delete-R5TSAZOU.js.map → delete-RFNKZHBB.js.map} +1 -1
- package/dist/{delete-RIHVCQ6G.mjs → delete-TCTLTE3Q.mjs} +5 -5
- package/dist/{download-7RBJ3GZM.mjs → download-67ZES3AB.mjs} +5 -5
- package/dist/{download-2Q5T4WW2.js → download-MHKH6RCM.js} +7 -7
- package/dist/{download-2Q5T4WW2.js.map → download-MHKH6RCM.js.map} +1 -1
- package/dist/{duplicate-7N6B5PJD.mjs → duplicate-2KHC6FOH.mjs} +4 -4
- package/dist/{duplicate-HZGUFROD.js → duplicate-X3XQ53D2.js} +6 -6
- package/dist/{duplicate-HZGUFROD.js.map → duplicate-X3XQ53D2.js.map} +1 -1
- package/dist/{get-PM5HD5BJ.js → get-73GUKSK3.js} +4 -1
- package/dist/get-73GUKSK3.js.map +1 -0
- package/dist/{get-SBMD2X2P.js → get-CF34ZSPN.js} +9 -6
- package/dist/get-CF34ZSPN.js.map +1 -0
- package/dist/{get-7V7OBWY5.js → get-FOFTVMFV.js} +11 -7
- package/dist/get-FOFTVMFV.js.map +1 -0
- package/dist/{get-6UQYEENU.mjs → get-FSTX64UH.mjs} +4 -4
- package/dist/{get-MHGIJVZ5.js → get-IB6M6ATH.js} +10 -6
- package/dist/get-IB6M6ATH.js.map +1 -0
- package/dist/{get-S7MFACWM.js → get-K32PRLNO.js} +10 -6
- package/dist/get-K32PRLNO.js.map +1 -0
- package/dist/{get-PYWLY7QQ.mjs → get-KQSOHGJQ.mjs} +4 -4
- package/dist/{get-E2RIDN65.mjs → get-KUG6O53D.mjs} +8 -4
- package/dist/get-KUG6O53D.mjs.map +1 -0
- package/dist/{get-NIA7XUS2.mjs → get-LHDIDP3V.mjs} +7 -4
- package/dist/{get-NIA7XUS2.mjs.map → get-LHDIDP3V.mjs.map} +1 -1
- package/dist/{get-JAWJ5RIB.mjs → get-M3H4S5DC.mjs} +7 -4
- package/dist/{get-JAWJ5RIB.mjs.map → get-M3H4S5DC.mjs.map} +1 -1
- package/dist/{get-GQTPK2MW.mjs → get-N7C2SLH7.mjs} +7 -4
- package/dist/get-N7C2SLH7.mjs.map +1 -0
- package/dist/{get-7JYKMJXV.mjs → get-OE5YA7ZA.mjs} +7 -4
- package/dist/get-OE5YA7ZA.mjs.map +1 -0
- package/dist/{get-IDYGZX5O.mjs → get-P74XQGCD.mjs} +8 -4
- package/dist/get-P74XQGCD.mjs.map +1 -0
- package/dist/{get-T754IOEI.js → get-Q2LPBIMN.js} +9 -6
- package/dist/get-Q2LPBIMN.js.map +1 -0
- package/dist/{get-ZEUJA3KA.js → get-R7ZFJVYU.js} +9 -6
- package/dist/get-R7ZFJVYU.js.map +1 -0
- package/dist/{get-PR65PTQ5.mjs → get-RY2GI2C2.mjs} +9 -5
- package/dist/get-RY2GI2C2.mjs.map +1 -0
- package/dist/{get-73K7EOMU.mjs → get-SXE4EFVR.mjs} +4 -1
- package/dist/get-SXE4EFVR.mjs.map +1 -0
- package/dist/{get-EN3CQXA7.js → get-TY2Z4NUQ.js} +9 -6
- package/dist/get-TY2Z4NUQ.js.map +1 -0
- package/dist/{get-Y22XVMEO.js → get-URZC7GB6.js} +6 -6
- package/dist/{get-Y22XVMEO.js.map → get-URZC7GB6.js.map} +1 -1
- package/dist/{get-CBNUMPUN.mjs → get-V6EGHO7N.mjs} +4 -1
- package/dist/get-V6EGHO7N.mjs.map +1 -0
- package/dist/{get-TOXTYIN5.js → get-XEIEWQX5.js} +6 -6
- package/dist/{get-TOXTYIN5.js.map → get-XEIEWQX5.js.map} +1 -1
- package/dist/{get-JYN765FP.js → get-XHTTHKOB.js} +4 -1
- package/dist/get-XHTTHKOB.js.map +1 -0
- package/dist/{implementation-BbuGM8_W.d.mts → implementation-DXEHmcUG.d.mts} +1 -1
- package/dist/{implementation-7POf4yX4.d.ts → implementation-pWh-26jw.d.ts} +1 -1
- package/dist/index.d.mts +369 -46
- package/dist/index.d.ts +369 -46
- package/dist/index.js +354 -19
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +345 -10
- package/dist/index.mjs.map +1 -1
- package/dist/{list-GN3SAZG2.js → list-5VHGKL4O.js} +7 -7
- package/dist/{list-GN3SAZG2.js.map → list-5VHGKL4O.js.map} +1 -1
- package/dist/{list-6JTFDJAI.mjs → list-76OFVBVA.mjs} +7 -7
- package/dist/{list-ARBOOOYN.mjs → list-7GUEO2RV.mjs} +7 -7
- package/dist/{list-EPB36Y7W.mjs → list-7I6DVHQM.mjs} +5 -5
- package/dist/{list-N7WIOJ5A.mjs → list-AGD6VB73.mjs} +5 -5
- package/dist/{list-6BRQWVVV.js → list-CJMCFRTB.js} +7 -7
- package/dist/{list-6BRQWVVV.js.map → list-CJMCFRTB.js.map} +1 -1
- package/dist/{list-FLTPMAHR.js → list-EV2SFI5Z.js} +7 -7
- package/dist/{list-FLTPMAHR.js.map → list-EV2SFI5Z.js.map} +1 -1
- package/dist/{list-E7YPBCAF.mjs → list-H72AM4ED.mjs} +4 -4
- package/dist/{list-AEX4S72W.mjs → list-HDAXVYSZ.mjs} +5 -5
- package/dist/{list-UOTJUE2P.js → list-JLRDBUIK.js} +7 -7
- package/dist/{list-UOTJUE2P.js.map → list-JLRDBUIK.js.map} +1 -1
- package/dist/{list-RS4QL7NE.mjs → list-KHKK6QLG.mjs} +7 -7
- package/dist/{list-BAKCZVTL.mjs → list-LJRNMYC7.mjs} +7 -7
- package/dist/{list-ZB53NL6Z.mjs → list-MG2J6OSE.mjs} +7 -7
- package/dist/{list-FPIWJ65T.mjs → list-MRT5ZJFV.mjs} +7 -7
- package/dist/{list-Z5EEMYRQ.js → list-NMMNVYV2.js} +7 -7
- package/dist/{list-Z5EEMYRQ.js.map → list-NMMNVYV2.js.map} +1 -1
- package/dist/{list-WYYGGV5V.mjs → list-OXFS5MS3.mjs} +7 -7
- package/dist/{list-SDMJ2GJE.js → list-P5LOEVF2.js} +7 -7
- package/dist/{list-SDMJ2GJE.js.map → list-P5LOEVF2.js.map} +1 -1
- package/dist/{list-7LV6GOZO.js → list-SCDBHVZ3.js} +6 -6
- package/dist/{list-7LV6GOZO.js.map → list-SCDBHVZ3.js.map} +1 -1
- package/dist/{list-JRWFJU5H.js → list-TMXD7HKD.js} +7 -7
- package/dist/{list-JRWFJU5H.js.map → list-TMXD7HKD.js.map} +1 -1
- package/dist/{list-C6DPYHQ2.js → list-V2M62TJB.js} +8 -8
- package/dist/{list-C6DPYHQ2.js.map → list-V2M62TJB.js.map} +1 -1
- package/dist/{list-UKGJOVJE.js → list-X6XMFWC4.js} +6 -6
- package/dist/{list-UKGJOVJE.js.map → list-X6XMFWC4.js.map} +1 -1
- package/dist/{list-XTOWXYB2.js → list-XROB5YXS.js} +7 -7
- package/dist/{list-XTOWXYB2.js.map → list-XROB5YXS.js.map} +1 -1
- package/dist/{login-4AX6AOKI.mjs → login-33KFSUDT.mjs} +2 -2
- package/dist/{login-H3SQDBT7.js → login-P6NS5HQ3.js} +3 -3
- package/dist/{login-H3SQDBT7.js.map → login-P6NS5HQ3.js.map} +1 -1
- package/dist/observability-sdk/index.d.mts +3 -3
- package/dist/observability-sdk/index.d.ts +3 -3
- package/dist/observability-sdk/index.js +3 -3
- package/dist/observability-sdk/index.mjs +2 -2
- package/dist/observability-sdk/instrumentation/langchain/index.d.mts +1 -1
- package/dist/observability-sdk/instrumentation/langchain/index.d.ts +1 -1
- package/dist/observability-sdk/setup/node/index.js +4 -4
- package/dist/observability-sdk/setup/node/index.mjs +3 -3
- package/dist/{pull-64HVVOBC.mjs → pull-SC2QC7KA.mjs} +6 -6
- package/dist/{push-I3BJSL6N.js → pull-X5JE4Z3G.js} +7 -7
- package/dist/{pull-QIANBELG.js.map → pull-X5JE4Z3G.js.map} +1 -1
- package/dist/{push-GXLGORLM.mjs → push-732VUFS5.mjs} +6 -6
- package/dist/{pull-QIANBELG.js → push-HC5IC3BV.js} +7 -7
- package/dist/{push-I3BJSL6N.js.map → push-HC5IC3BV.js.map} +1 -1
- package/dist/{query-UF2LDBR4.js → query-3WIPNLUZ.js} +8 -41
- package/dist/query-3WIPNLUZ.js.map +1 -0
- package/dist/{query-ZI7HJSIY.mjs → query-U4YAOT4T.mjs} +7 -40
- package/dist/query-U4YAOT4T.mjs.map +1 -0
- package/dist/{records-add-WTIGBJV4.js → records-add-CQDMYR7E.js} +7 -7
- package/dist/{records-add-WTIGBJV4.js.map → records-add-CQDMYR7E.js.map} +1 -1
- package/dist/{records-add-4LX4JHLO.mjs → records-add-LVMGWT2E.mjs} +5 -5
- package/dist/{records-delete-IY37NWPN.mjs → records-delete-DTFPYDNS.mjs} +5 -5
- package/dist/{records-delete-MLOG4DM4.js → records-delete-FEGZXSF6.js} +7 -7
- package/dist/{records-delete-MLOG4DM4.js.map → records-delete-FEGZXSF6.js.map} +1 -1
- package/dist/{records-list-RIDOAE2V.mjs → records-list-7ZUIOAUK.mjs} +5 -5
- package/dist/{records-list-EP6OCFH5.js → records-list-TZ63FXGK.js} +7 -7
- package/dist/{records-list-EP6OCFH5.js.map → records-list-TZ63FXGK.js.map} +1 -1
- package/dist/{records-update-5QZBDYUJ.js → records-update-AQQ3XV4Y.js} +7 -7
- package/dist/{records-update-5QZBDYUJ.js.map → records-update-AQQ3XV4Y.js.map} +1 -1
- package/dist/{records-update-JINO26IA.mjs → records-update-FFPA33GL.mjs} +5 -5
- package/dist/{remove-HLVK7VUB.mjs → remove-GRPHB3UQ.mjs} +5 -5
- package/dist/{remove-LDX2BSUH.js → remove-SQ4HATMB.js} +7 -7
- package/dist/{remove-LDX2BSUH.js.map → remove-SQ4HATMB.js.map} +1 -1
- package/dist/{rename-PUSZYLZ7.js → rename-NR4UOXSM.js} +6 -6
- package/dist/{rename-PUSZYLZ7.js.map → rename-NR4UOXSM.js.map} +1 -1
- package/dist/{rename-FP7X3GJJ.mjs → rename-WDO4KRS4.mjs} +5 -5
- package/dist/{run-QW2HL4EK.mjs → run-25RB32H2.mjs} +4 -4
- package/dist/{run-UZVJBWGG.js → run-GIDKJP6G.js} +6 -6
- package/dist/{run-UZVJBWGG.js.map → run-GIDKJP6G.js.map} +1 -1
- package/dist/{run-GUSPWLCC.mjs → run-IHQ73OJ7.mjs} +4 -4
- package/dist/{run-FJDOSV5E.js → run-MI2CU2VM.js} +6 -6
- package/dist/{run-FJDOSV5E.js.map → run-MI2CU2VM.js.map} +1 -1
- package/dist/{run-KNCB7OEA.js → run-PJIUCPMU.js} +6 -6
- package/dist/{run-KNCB7OEA.js.map → run-PJIUCPMU.js.map} +1 -1
- package/dist/{run-AIGCDUDF.mjs → run-SGJRPI4Z.mjs} +4 -4
- package/dist/{run-WZ4CSMTP.mjs → run-SQEOVBHK.mjs} +4 -4
- package/dist/{run-CKZ6VNKK.js → run-UC6OFJZZ.js} +6 -6
- package/dist/{run-CKZ6VNKK.js.map → run-UC6OFJZZ.js.map} +1 -1
- package/dist/{search-J5GDX5JK.js → search-FIUSFX36.js} +7 -7
- package/dist/{search-J5GDX5JK.js.map → search-FIUSFX36.js.map} +1 -1
- package/dist/{search-5B32YGSP.mjs → search-ZFATW43M.mjs} +7 -7
- package/dist/{set-S5L5QSYZ.js → set-JQJABXPR.js} +6 -6
- package/dist/{set-S5L5QSYZ.js.map → set-JQJABXPR.js.map} +1 -1
- package/dist/{set-2DYJNVS5.mjs → set-Z34CUN2N.mjs} +4 -4
- package/dist/{status-QRK56VLF.js → status-AK5C6GIB.js} +6 -6
- package/dist/{status-QRK56VLF.js.map → status-AK5C6GIB.js.map} +1 -1
- package/dist/{status-T7NOWM4X.js → status-KF5WI6U5.js} +4 -4
- package/dist/{status-T7NOWM4X.js.map → status-KF5WI6U5.js.map} +1 -1
- package/dist/{status-Q2PEMYJT.mjs → status-QLEH2TD4.mjs} +4 -4
- package/dist/{status-OIXOYFH4.mjs → status-ZG374FIY.mjs} +3 -3
- package/dist/{sync-IDSAYUGO.js → sync-2RTTXX5T.js} +11 -11
- package/dist/{sync-IDSAYUGO.js.map → sync-2RTTXX5T.js.map} +1 -1
- package/dist/{sync-LA27E4UB.mjs → sync-A73OUY3S.mjs} +7 -7
- package/dist/{types-CWY5yQki.d.mts → types-7LPyG10b.d.mts} +1 -1
- package/dist/{types-B4TSe7JR.d.ts → types-CyB5AQ9u.d.ts} +1 -1
- package/dist/{update-4FC4YPW7.mjs → update-5ZUMCEDT.mjs} +4 -4
- package/dist/{update-VLY6LJVM.js → update-6UVK6NCS.js} +6 -6
- package/dist/{update-VLY6LJVM.js.map → update-6UVK6NCS.js.map} +1 -1
- package/dist/{update-EG6BZOLC.mjs → update-7CDKATAQ.mjs} +4 -4
- package/dist/{update-4YMVL4UT.mjs → update-BWB4XG3Y.mjs} +4 -4
- package/dist/{update-YMWBN55I.js → update-GAXW53JM.js} +7 -7
- package/dist/{update-YMWBN55I.js.map → update-GAXW53JM.js.map} +1 -1
- package/dist/{update-DLFJBCI2.js → update-IUSPDA2P.js} +12 -9
- package/dist/update-IUSPDA2P.js.map +1 -0
- package/dist/{update-PSY46JJD.mjs → update-J6SLRCFT.mjs} +9 -6
- package/dist/{update-PSY46JJD.mjs.map → update-J6SLRCFT.mjs.map} +1 -1
- package/dist/{update-MFZOMTRJ.mjs → update-JHGDZHGT.mjs} +4 -4
- package/dist/{update-RCZ47II5.js → update-OPASDCEJ.js} +6 -6
- package/dist/{update-RCZ47II5.js.map → update-OPASDCEJ.js.map} +1 -1
- package/dist/{update-7ZEJO5SB.js → update-RDD7CKDE.js} +6 -6
- package/dist/{update-7ZEJO5SB.js.map → update-RDD7CKDE.js.map} +1 -1
- package/dist/{update-RPD2OXXQ.js → update-VDDM7HDM.js} +6 -6
- package/dist/{update-RPD2OXXQ.js.map → update-VDDM7HDM.js.map} +1 -1
- package/dist/{update-WQK5Q34V.mjs → update-WKI762BB.mjs} +4 -4
- package/dist/{upload-QWAITH5R.mjs → upload-2V2F6QYK.mjs} +8 -5
- package/dist/{upload-QWAITH5R.mjs.map → upload-2V2F6QYK.mjs.map} +1 -1
- package/dist/{upload-6LF5GVLP.js → upload-AZIWHQFL.js} +10 -7
- package/dist/upload-AZIWHQFL.js.map +1 -0
- package/package.json +1 -1
- package/dist/chunk-AMPLL3EP.js.map +0 -1
- package/dist/chunk-CYRJSLKD.js.map +0 -1
- package/dist/chunk-FKIH4XCX.js.map +0 -1
- package/dist/chunk-KH64V3CL.mjs.map +0 -1
- package/dist/chunk-NIW2SFZZ.mjs.map +0 -1
- package/dist/chunk-NMACMKQN.mjs.map +0 -1
- package/dist/chunk-TQYUM3WH.mjs.map +0 -1
- package/dist/chunk-VMDYRBQ7.js.map +0 -1
- package/dist/chunk-WLMXMXHE.js.map +0 -1
- package/dist/create-45FMHT6B.mjs.map +0 -1
- package/dist/create-4OA73B7I.mjs.map +0 -1
- package/dist/create-4U5BPFCT.mjs.map +0 -1
- package/dist/create-CQ7W2OAA.js.map +0 -1
- package/dist/create-KAPF2AOL.js.map +0 -1
- package/dist/create-LWG7ZHEW.mjs.map +0 -1
- package/dist/create-MXYMAFMF.js.map +0 -1
- package/dist/create-NFYHBFF5.mjs.map +0 -1
- package/dist/create-OSAXTSUC.js.map +0 -1
- package/dist/create-RPHO5TZX.js.map +0 -1
- package/dist/create-RRI5ZTMI.mjs.map +0 -1
- package/dist/create-UZ5NDYPV.js.map +0 -1
- package/dist/create-XGD3GULQ.js.map +0 -1
- package/dist/create-Z2XFL2HX.js +0 -18
- package/dist/create-ZU4L3XOF.mjs.map +0 -1
- package/dist/get-73K7EOMU.mjs.map +0 -1
- package/dist/get-7JYKMJXV.mjs.map +0 -1
- package/dist/get-7V7OBWY5.js.map +0 -1
- package/dist/get-CBNUMPUN.mjs.map +0 -1
- package/dist/get-E2RIDN65.mjs.map +0 -1
- package/dist/get-EN3CQXA7.js.map +0 -1
- package/dist/get-GQTPK2MW.mjs.map +0 -1
- package/dist/get-IDYGZX5O.mjs.map +0 -1
- package/dist/get-JYN765FP.js.map +0 -1
- package/dist/get-MHGIJVZ5.js.map +0 -1
- package/dist/get-PM5HD5BJ.js.map +0 -1
- package/dist/get-PR65PTQ5.mjs.map +0 -1
- package/dist/get-S7MFACWM.js.map +0 -1
- package/dist/get-SBMD2X2P.js.map +0 -1
- package/dist/get-T754IOEI.js.map +0 -1
- package/dist/get-ZEUJA3KA.js.map +0 -1
- package/dist/query-UF2LDBR4.js.map +0 -1
- package/dist/query-ZI7HJSIY.mjs.map +0 -1
- package/dist/update-DLFJBCI2.js.map +0 -1
- package/dist/upload-6LF5GVLP.js.map +0 -1
- /package/dist/{add-7QFHK67E.mjs.map → add-TCJZAPWG.mjs.map} +0 -0
- /package/dist/{assign-JCCQ5D7I.mjs.map → assign-VH54CNRX.mjs.map} +0 -0
- /package/dist/{chunk-ILLEMTW3.mjs.map → chunk-3CRFCUOQ.mjs.map} +0 -0
- /package/dist/{chunk-ESGWN42J.mjs.map → chunk-4K2OMMLS.mjs.map} +0 -0
- /package/dist/{chunk-I2LDJPTG.mjs.map → chunk-7FCVMMAW.mjs.map} +0 -0
- /package/dist/{chunk-L3IOXWDG.mjs.map → chunk-GSZ4QKFH.mjs.map} +0 -0
- /package/dist/{chunk-TV6ZXLE5.mjs.map → chunk-LIUQYWHM.mjs.map} +0 -0
- /package/dist/{chunk-COKOLKOR.mjs.map → chunk-N6O7634G.mjs.map} +0 -0
- /package/dist/{chunk-DWHR6QJK.mjs.map → chunk-NZLR6K3R.mjs.map} +0 -0
- /package/dist/{chunk-LULJYN3P.mjs.map → chunk-PWBHSOGK.mjs.map} +0 -0
- /package/dist/{chunk-TCO73AV5.mjs.map → chunk-QJQMCRLL.mjs.map} +0 -0
- /package/dist/{chunk-QH3WUSKF.mjs.map → chunk-SAR52TH6.mjs.map} +0 -0
- /package/dist/{chunk-YTR56IZO.mjs.map → chunk-VTLTVATI.mjs.map} +0 -0
- /package/dist/{chunk-JYR4TXSB.mjs.map → chunk-VUVLYTWK.mjs.map} +0 -0
- /package/dist/{chunk-PO6XRHYW.mjs.map → chunk-Y5PPNQXM.mjs.map} +0 -0
- /package/dist/{chunk-2OHGLTXZ.mjs.map → chunk-YD7SA3ZL.mjs.map} +0 -0
- /package/dist/{create-Z7DUMMQ4.mjs.map → create-UJNSUW4A.mjs.map} +0 -0
- /package/dist/{create-ARJEJDYU.mjs.map → create-VBHJZCM5.mjs.map} +0 -0
- /package/dist/{create-GGYYU5KM.mjs.map → create-XPIBPXZI.mjs.map} +0 -0
- /package/dist/{delete-5NINT2KV.mjs.map → delete-2R62572G.mjs.map} +0 -0
- /package/dist/{delete-QVE52G3Q.mjs.map → delete-5ENFR4LN.mjs.map} +0 -0
- /package/dist/{delete-2S67GS6A.mjs.map → delete-5K4CLCFU.mjs.map} +0 -0
- /package/dist/{delete-L3SU34X6.mjs.map → delete-5QY2NINK.mjs.map} +0 -0
- /package/dist/{delete-CTE3RNKB.mjs.map → delete-63PUL37J.mjs.map} +0 -0
- /package/dist/{delete-22LDMLNG.mjs.map → delete-ALUMMULI.mjs.map} +0 -0
- /package/dist/{delete-I36NLS2V.mjs.map → delete-BSWXG6TJ.mjs.map} +0 -0
- /package/dist/{delete-J2P2Y2BW.mjs.map → delete-QT27YCTA.mjs.map} +0 -0
- /package/dist/{delete-RIHVCQ6G.mjs.map → delete-TCTLTE3Q.mjs.map} +0 -0
- /package/dist/{download-7RBJ3GZM.mjs.map → download-67ZES3AB.mjs.map} +0 -0
- /package/dist/{duplicate-7N6B5PJD.mjs.map → duplicate-2KHC6FOH.mjs.map} +0 -0
- /package/dist/{get-6UQYEENU.mjs.map → get-FSTX64UH.mjs.map} +0 -0
- /package/dist/{get-PYWLY7QQ.mjs.map → get-KQSOHGJQ.mjs.map} +0 -0
- /package/dist/{list-6JTFDJAI.mjs.map → list-76OFVBVA.mjs.map} +0 -0
- /package/dist/{list-ARBOOOYN.mjs.map → list-7GUEO2RV.mjs.map} +0 -0
- /package/dist/{list-EPB36Y7W.mjs.map → list-7I6DVHQM.mjs.map} +0 -0
- /package/dist/{list-N7WIOJ5A.mjs.map → list-AGD6VB73.mjs.map} +0 -0
- /package/dist/{list-E7YPBCAF.mjs.map → list-H72AM4ED.mjs.map} +0 -0
- /package/dist/{list-AEX4S72W.mjs.map → list-HDAXVYSZ.mjs.map} +0 -0
- /package/dist/{list-RS4QL7NE.mjs.map → list-KHKK6QLG.mjs.map} +0 -0
- /package/dist/{list-BAKCZVTL.mjs.map → list-LJRNMYC7.mjs.map} +0 -0
- /package/dist/{list-ZB53NL6Z.mjs.map → list-MG2J6OSE.mjs.map} +0 -0
- /package/dist/{list-FPIWJ65T.mjs.map → list-MRT5ZJFV.mjs.map} +0 -0
- /package/dist/{list-WYYGGV5V.mjs.map → list-OXFS5MS3.mjs.map} +0 -0
- /package/dist/{login-4AX6AOKI.mjs.map → login-33KFSUDT.mjs.map} +0 -0
- /package/dist/{pull-64HVVOBC.mjs.map → pull-SC2QC7KA.mjs.map} +0 -0
- /package/dist/{push-GXLGORLM.mjs.map → push-732VUFS5.mjs.map} +0 -0
- /package/dist/{records-add-4LX4JHLO.mjs.map → records-add-LVMGWT2E.mjs.map} +0 -0
- /package/dist/{records-delete-IY37NWPN.mjs.map → records-delete-DTFPYDNS.mjs.map} +0 -0
- /package/dist/{records-list-RIDOAE2V.mjs.map → records-list-7ZUIOAUK.mjs.map} +0 -0
- /package/dist/{records-update-JINO26IA.mjs.map → records-update-FFPA33GL.mjs.map} +0 -0
- /package/dist/{remove-HLVK7VUB.mjs.map → remove-GRPHB3UQ.mjs.map} +0 -0
- /package/dist/{rename-FP7X3GJJ.mjs.map → rename-WDO4KRS4.mjs.map} +0 -0
- /package/dist/{run-QW2HL4EK.mjs.map → run-25RB32H2.mjs.map} +0 -0
- /package/dist/{run-GUSPWLCC.mjs.map → run-IHQ73OJ7.mjs.map} +0 -0
- /package/dist/{run-AIGCDUDF.mjs.map → run-SGJRPI4Z.mjs.map} +0 -0
- /package/dist/{run-WZ4CSMTP.mjs.map → run-SQEOVBHK.mjs.map} +0 -0
- /package/dist/{search-5B32YGSP.mjs.map → search-ZFATW43M.mjs.map} +0 -0
- /package/dist/{set-2DYJNVS5.mjs.map → set-Z34CUN2N.mjs.map} +0 -0
- /package/dist/{status-Q2PEMYJT.mjs.map → status-QLEH2TD4.mjs.map} +0 -0
- /package/dist/{status-OIXOYFH4.mjs.map → status-ZG374FIY.mjs.map} +0 -0
- /package/dist/{sync-LA27E4UB.mjs.map → sync-A73OUY3S.mjs.map} +0 -0
- /package/dist/{update-4FC4YPW7.mjs.map → update-5ZUMCEDT.mjs.map} +0 -0
- /package/dist/{update-EG6BZOLC.mjs.map → update-7CDKATAQ.mjs.map} +0 -0
- /package/dist/{update-4YMVL4UT.mjs.map → update-BWB4XG3Y.mjs.map} +0 -0
- /package/dist/{update-MFZOMTRJ.mjs.map → update-JHGDZHGT.mjs.map} +0 -0
- /package/dist/{update-WQK5Q34V.mjs.map → update-WKI762BB.mjs.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-AK4YCKWK.js","../src/client-sdk/services/prompts/errors/prompts.error.ts","../src/client-sdk/services/prompts/errors/prompt-compilation.error.ts","../src/client-sdk/services/prompts/errors/prompt-validation.error.ts","../src/client-sdk/services/prompts/errors/prompts-api.error.ts","../src/client-sdk/services/prompts/tracing/prompt-tracing.decorator.ts","../src/client-sdk/services/prompts/tracing/prompt-service-tracing.decorator.ts","../src/client-sdk/services/prompts/tracing/tracer.ts","../src/client-sdk/services/prompts/prompts-api.service.ts","../src/client-sdk/services/prompts/types.ts","../src/client-sdk/services/prompts/prompt.ts","../src/client-sdk/services/prompts/schema/prompt.schema.ts","../src/client-sdk/services/prompts/constants.ts","../src/client-sdk/services/prompts/local-prompts.service.ts","../src/client-sdk/services/prompts/prompts.facade.ts"],"names":["FetchPolicy"],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-AK4YCKWK.js","sourcesContent":[null,"/**\n * Base error class for the Prompts domain.\n * All prompt-related errors should extend this class.\n */\nexport class PromptsError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"PromptsError\";\n }\n}\n","/**\n * Error class for template compilation issues\n */\nexport class PromptCompilationError extends Error {\n constructor(\n message: string,\n public readonly template: string,\n public readonly originalError?: any,\n ) {\n super(message);\n this.name = \"PromptCompilationError\";\n }\n}\n","import { type z } from \"zod\";\n\n/**\n * Error class for prompt validation issues\n */\nexport class PromptValidationError extends Error {\n constructor(message: string, public readonly validationErrors: z.ZodError) {\n super(message);\n this.name = \"PromptValidationError\";\n }\n}\n","import { PromptsError } from \"./prompts.error\";\n\n/**\n * Error class for Prompts API operations.\n * Provides context about the failed operation and the original error.\n */\nexport class PromptsApiError extends PromptsError {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"PromptsApiError\";\n }\n}\n","import { type Prompt, type TemplateVariables, type CompiledPrompt } from \"../prompt\";\nimport { shouldCaptureInput, shouldCaptureOutput } from \"@/observability-sdk\";\nimport type { LangWatchSpan } from \"@/observability-sdk\";\n\n/**\n * Class that decorates the target prompt,\n * adding tracing to specific methods.\n */\nexport class PromptTracingDecorator {\n constructor(private readonly target: Prompt) {}\n\n private traceCompilation(\n span: LangWatchSpan,\n variables: TemplateVariables,\n compileFn: () => CompiledPrompt\n ): CompiledPrompt {\n span.setType(\"prompt\");\n\n if (shouldCaptureInput()) {\n span.setInput(this.target);\n\n if (variables) {\n span.setAttribute(\n 'langwatch.prompt.variables',\n JSON.stringify({\n type: \"json\",\n value: variables,\n }),\n );\n }\n }\n\n const result = compileFn();\n\n // Only emit combined handle:version format when both are available\n if (result.handle != null && result.version != null) {\n span.setAttribute(\n 'langwatch.prompt.id',\n `${result.handle}:${result.version}`,\n );\n }\n\n if (shouldCaptureOutput()) {\n span.setOutput({\n ...result,\n raw: void 0, // TODO(afr): Figure out a better way to do this.\n });\n }\n\n return result;\n }\n\n compile(span: LangWatchSpan, variables: TemplateVariables = {}): CompiledPrompt {\n return this.traceCompilation(\n span,\n variables,\n () => this.target.compile(variables),\n );\n }\n\n compileStrict(span: LangWatchSpan, variables: TemplateVariables): CompiledPrompt {\n return this.traceCompilation(\n span,\n variables,\n () => this.target.compileStrict(variables),\n );\n }\n}\n","import { type PromptsApiService } from \"../prompts-api.service\";\nimport type { LangWatchSpan } from \"@/observability-sdk\";\nimport { shouldCaptureInput, shouldCaptureOutput } from \"@/observability-sdk\";\nimport type { CreatePromptBody, UpdatePromptBody, PromptResponse } from \"../types\";\n\n/**\n * Class that decorates the target prompt service,\n * adding tracing to key methods.\n */\nexport class PromptServiceTracingDecorator {\n constructor(private readonly target: PromptsApiService) {}\n\n async get(\n span: LangWatchSpan,\n id: string,\n options?: { version?: string }\n ): Promise<PromptResponse> {\n span.setType(\"prompt\");\n\n const result = await this.target.get(id, options);\n\n if (result) {\n // Only emit combined format when both handle and version are available\n if (result.handle != null && result.version != null) {\n span.setAttribute(\n 'langwatch.prompt.id',\n `${result.handle}:${result.version}`,\n );\n }\n }\n\n if (result && shouldCaptureOutput()) {\n span.setOutput(\"json\", result);\n }\n\n return result;\n }\n\n async create(\n span: LangWatchSpan,\n params: CreatePromptBody\n ): Promise<PromptResponse> {\n span.setType(\"prompt\");\n\n if (shouldCaptureInput()) {\n span.setInput(params);\n }\n\n const result = await this.target.create(params);\n\n span.setAttributes({\n 'langwatch.prompt.id': result.id,\n 'langwatch.prompt.handle': result.handle ?? undefined,\n 'langwatch.prompt.scope': result.scope,\n 'langwatch.prompt.version.id': result.versionId,\n 'langwatch.prompt.version.number': result.version,\n });\n\n return result;\n }\n\n async update(\n span: LangWatchSpan,\n id: string,\n params: UpdatePromptBody\n ): Promise<PromptResponse> {\n\n if (shouldCaptureInput()) {\n span.setInput(params);\n }\n\n const result = await this.target.update(id, params);\n\n span.setType(\"prompt\");\n span.setAttributes({\n 'langwatch.prompt.id': id,\n 'langwatch.prompt.handle': result.handle ?? undefined,\n 'langwatch.prompt.scope': result.scope,\n 'langwatch.prompt.version.id': result.versionId,\n 'langwatch.prompt.version.number': result.version,\n });\n\n return result;\n }\n\n async delete(\n span: LangWatchSpan,\n id: string\n ): Promise<{ success: boolean }> {\n const result = await this.target.delete(id);\n\n span.setType(\"prompt\");\n span.setAttribute('langwatch.prompt.id', id);\n span.setAttribute('langwatch.prompt.deleted', 'true');\n\n return result;\n }\n\n async upsert(\n span: LangWatchSpan,\n handle: string,\n config: any\n ): Promise<{ created: boolean; prompt: PromptResponse }> {\n if (shouldCaptureInput()) {\n span.setInput(config);\n }\n\n const result = await this.target.upsert(handle, config);\n\n span.setType(\"prompt\");\n span.setAttributes({\n 'langwatch.prompt.handle': handle,\n 'langwatch.prompt.created': result.created.toString(),\n 'langwatch.prompt.id': result.prompt.id,\n 'langwatch.prompt.version.id': result.prompt.versionId,\n 'langwatch.prompt.version.number': result.prompt.version,\n });\n\n return result;\n }\n\n async sync(\n span: LangWatchSpan,\n params: any\n ): Promise<any> {\n if (shouldCaptureInput()) {\n span.setInput(params);\n }\n\n const result = await this.target.sync(params);\n\n span.setType(\"prompt\");\n span.setAttribute('langwatch.prompt.name', params.name);\n span.setAttribute('langwatch.prompt.sync.action', result.action);\n\n if (result.conflictInfo) {\n span.setAttributes({\n 'langwatch.prompt.sync.has_conflict': 'true',\n 'langwatch.prompt.sync.local_version': result.conflictInfo.localVersion.toString(),\n 'langwatch.prompt.sync.remote_version': result.conflictInfo.remoteVersion.toString(),\n });\n }\n\n return result;\n }\n}\n","import { getLangWatchTracer } from \"@/observability-sdk/tracer\";\nimport { LANGWATCH_SDK_NAME_CLIENT, LANGWATCH_SDK_VERSION } from \"@/internal/constants\";\n\nexport const tracer = getLangWatchTracer(`${LANGWATCH_SDK_NAME_CLIENT}.prompts`, LANGWATCH_SDK_VERSION);\n","import type { paths, operations } from \"@/internal/generated/openapi/api-client\";\nimport { type PromptResponse, type TagDefinition, type CreatedTag } from \"./types\";\nimport { PromptConverter } from \"@/cli/utils/promptConverter\";\nimport { PromptServiceTracingDecorator, tracer } from \"./tracing\";\nimport { createTracingProxy } from \"@/client-sdk/tracing/create-tracing-proxy\";\nimport { type InternalConfig } from \"@/client-sdk/types\";\nimport { type CreatePromptBody, type UpdatePromptBody } from \"./types\";\nimport { createLangWatchApiClient, type LangwatchApiClient } from \"@/internal/api/client\";\nimport { PromptsApiError } from \"./errors\";\n\nexport type SyncAction = \"created\" | \"updated\" | \"conflict\" | \"up_to_date\";\n\nexport type AssignTagResult = NonNullable<\n operations[\"putApiPromptsByIdTagsByTag\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>;\n\nexport type ConfigData = NonNullable<\n paths[\"/api/prompts/{id}/sync\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"][\"configData\"];\n\nexport interface SyncResult {\n action: SyncAction;\n prompt?: PromptResponse;\n conflictInfo?: {\n localVersion: number;\n remoteVersion: number;\n differences: string[];\n remoteConfigData: ConfigData;\n };\n}\n\n/**\n * Service for managing prompt resources via the Langwatch API.\n * Constructor creates a proxy that wraps the service and traces all methods.\n *\n * Responsibilities:\n * - CRUD operations for prompts\n * - Creating prompt versions\n * - Error handling with contextual information\n *\n * All methods return raw PromptResponse data from the API.\n */\nexport class PromptsApiService {\n private readonly apiClient: LangwatchApiClient;\n\n constructor(config?: Pick<InternalConfig, \"langwatchApiClient\">) {\n this.apiClient = config?.langwatchApiClient ?? createLangWatchApiClient();\n\n /**\n * Wraps the service in a tracing proxy via the decorator.\n */\n return createTracingProxy(\n this as PromptsApiService,\n tracer,\n PromptServiceTracingDecorator,\n );\n }\n\n /**\n * Handles API errors by throwing a PromptsApiError with operation context.\n * @param operation Description of the operation being performed.\n * @param error The error object returned from the API client.\n * @throws {PromptsApiError}\n */\n private handleApiError(operation: string, error: any): never {\n const errorMessage =\n typeof error === \"string\"\n ? error\n : error?.error != null\n ? typeof error.error === \"string\"\n ? error.error\n : error.error.message ??\n JSON.stringify(error.error, Object.getOwnPropertyNames(error.error))\n : error?.message ?? \"Unknown error occurred\";\n\n throw new PromptsApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n /**\n * Fetches all prompts from the API.\n * @returns Array of raw PromptResponse data.\n * @throws {PromptsApiError} If the API call fails.\n */\n async getAll(): Promise<PromptResponse[]> {\n const { data, error } =\n await this.apiClient.GET(\"/api/prompts\");\n if (error) this.handleApiError(\"fetch all prompts\", error);\n return data;\n }\n\n /**\n * Fetches a single prompt by its ID.\n * @param id The prompt's unique identifier.\n * @param options Optional parameters for the request.\n * @param options.version Specific version to fetch (numeric string or \"latest\").\n * @param options.tag Tag to fetch (e.g., \"production\", \"staging\", or a custom tag).\n * @returns Raw PromptResponse data.\n * @throws {PromptsApiError} If the API call fails.\n */\n get = async (id: string, options?: { version?: string; tag?: string }): Promise<PromptResponse> => {\n // Parse version to number, skip for \"latest\" or invalid values\n const versionNumber = options?.version && options.version !== \"latest\"\n ? parseInt(options.version, 10)\n : undefined;\n\n const { data, error } = await this.apiClient.GET(\n \"/api/prompts/{id}\",\n {\n params: {\n path: { id },\n query: {\n version: Number.isNaN(versionNumber) ? undefined : versionNumber,\n tag: options?.tag,\n },\n },\n },\n );\n\n if (error) {\n this.handleApiError(`fetch prompt with ID \"${id}\"`, error);\n }\n\n return data;\n }\n\n /**\n * Validates if a prompt exists.\n * @param id The prompt's unique identifier.\n * @returns True if prompt exists, false otherwise.\n * @throws {PromptsApiError} If the API call fails (not 404).\n */\n async exists(id: string): Promise<boolean> {\n try {\n await this.get(id);\n return true;\n } catch (error) {\n const originalError = error instanceof PromptsApiError ? error.originalError : null;\n const statusCode = originalError != null && typeof originalError === \"object\" && \"statusCode\" in originalError\n ? (originalError as { statusCode: unknown }).statusCode\n : null;\n\n if (statusCode === 404) {\n return false;\n }\n\n throw error;\n }\n }\n\n /**\n * Creates a new prompt.\n * @param params The prompt creation payload, matching the OpenAPI schema.\n * @returns Raw PromptResponse data of the created prompt.\n * @throws {PromptsApiError} If the API call fails.\n */\n async create(params: CreatePromptBody): Promise<PromptResponse> {\n const { data, error } = await this.apiClient.POST(\n \"/api/prompts\",\n {\n body: params,\n },\n );\n if (error) this.handleApiError(\"create prompt\", error);\n return data;\n }\n\n /**\n * Updates an existing prompt.\n * @param id The prompt's unique identifier.\n * @param params The update payload, matching the OpenAPI schema.\n * @returns Raw PromptResponse data of the updated prompt.\n * @throws {PromptsApiError} If the API call fails.\n */\n async update(id: string, params: UpdatePromptBody): Promise<PromptResponse> {\n const { error, data: updatedPrompt } =\n await this.apiClient.PUT(\"/api/prompts/{id}\", {\n params: { path: { id } },\n body: params,\n });\n if (error) this.handleApiError(`update prompt with ID \"${id}\"`, error);\n return updatedPrompt;\n }\n\n /**\n * Lists all prompt tags (built-in and custom) for the organization.\n * @returns Array of tag definitions.\n * @throws {PromptsApiError} If the API call fails.\n */\n async listTags(): Promise<TagDefinition[]> {\n const { data, error } = await this.apiClient.GET(\"/api/prompts/tags\");\n if (error) this.handleApiError(\"list tags\", error);\n return data;\n }\n\n /**\n * Creates a custom prompt tag for the organization.\n * @param params.name The tag name (must match /^[a-z][a-z0-9_-]*$/).\n * @returns The created tag.\n * @throws {PromptsApiError} If the API call fails.\n */\n async createTag({ name }: { name: string }): Promise<CreatedTag> {\n const { data, error } = await this.apiClient.POST(\"/api/prompts/tags\", {\n body: { name },\n });\n if (error) this.handleApiError(\"create tag\", error);\n return data;\n }\n\n /**\n * Deletes a custom prompt tag by name.\n * @param tagName The tag name to delete.\n * @throws {PromptsApiError} If the API call fails.\n */\n async deleteTag(tagName: string): Promise<void> {\n const { error } = await this.apiClient.DELETE(\n \"/api/prompts/tags/{tag}\" as any,\n { params: { path: { tag: tagName } } } as any,\n );\n if (error) this.handleApiError(`delete tag \"${tagName}\"`, error);\n }\n\n /**\n * Renames an existing prompt tag.\n * @param tag The current tag name.\n * @param name The new tag name.\n * @throws {PromptsApiError} If the API call fails.\n */\n async renameTag({ tag, name }: { tag: string; name: string }): Promise<void> {\n const { error } = await this.apiClient.PUT(\n \"/api/prompts/tags/{tag}\",\n { params: { path: { tag } }, body: { name } },\n );\n if (error) this.handleApiError(`rename tag \"${tag}\"`, error);\n }\n\n async assignTag({\n id,\n tag,\n versionId,\n }: {\n id: string;\n tag: string;\n versionId: string;\n }): Promise<AssignTagResult> {\n const { data, error } = await this.apiClient.PUT(\n \"/api/prompts/{id}/tags/{tag}\",\n {\n params: { path: { id, tag } },\n body: { versionId },\n },\n );\n if (error) this.handleApiError(`assign tag \"${tag}\" to prompt \"${id}\"`, error);\n return data;\n }\n\n /**\n * Deletes a prompt by its ID.\n * @param id The prompt's unique identifier.\n * @throws {PromptsApiError} If the API call fails.\n */\n async delete(id: string): Promise<{ success: boolean }> {\n const { data, error } = await this.apiClient.DELETE(\n \"/api/prompts/{id}\",\n {\n params: { path: { id } },\n },\n );\n if (error) this.handleApiError(`delete prompt with ID \"${id}\"`, error);\n\n return data;\n }\n\n /**\n * Fetches all versions for a given prompt.\n * @param id The prompt's unique identifier.\n * @returns Array of raw PromptResponse data for each version.\n * @throws {PromptsApiError} If the API call fails.\n */\n async getVersions(id: string): Promise<PromptResponse[]> {\n const { data, error } = await this.apiClient.GET(\n \"/api/prompts/{id}/versions\",\n {\n params: { path: { id } },\n },\n );\n if (error)\n this.handleApiError(`fetch versions for prompt with ID \"${id}\"`, error);\n\n return data;\n }\n\n /**\n * Upserts a prompt with local configuration - creates if doesn't exist, updates version if exists.\n * @param handle The prompt's handle/identifier.\n * @param config Local prompt configuration.\n * @returns Object with created flag and raw PromptResponse data.\n * @throws {PromptsApiError} If the API call fails.\n */\n async upsert(\n handle: string,\n config: {\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 ): Promise<{ created: boolean; prompt: PromptResponse }> {\n const payload = {\n handle,\n model: config.model,\n prompt: PromptConverter.extractSystemPrompt(config.messages),\n messages: PromptConverter.filterNonSystemMessages(config.messages),\n temperature: config.modelParameters?.temperature,\n maxTokens: config.modelParameters?.max_tokens,\n inputs: [{ identifier: \"input\", type: \"str\" as const }],\n outputs: [{ identifier: \"output\", type: \"str\" as const }],\n commitMessage: `Updated via CLI sync`,\n schemaVersion: \"1.0\" as const,\n };\n\n // Creating a prompt with the same handle will fail, so we try to update instead\n try {\n const prompt = await this.create(payload);\n return {\n created: true,\n prompt,\n };\n } catch {\n const prompt = await this.update(handle, payload);\n\n return {\n created: false,\n prompt,\n };\n }\n }\n\n /**\n * Sync a prompt with local content, handling conflicts and version management\n * You probably don't need to use this method directly.\n */\n async sync(params: {\n name: string;\n configData: ConfigData;\n localVersion?: number;\n commitMessage?: string;\n }): Promise<SyncResult> {\n try {\n const response = await this.apiClient.POST(\n \"/api/prompts/{id}/sync\",\n {\n params: { path: { id: params.name } },\n body: {\n configData: params.configData,\n localVersion: params.localVersion,\n commitMessage: params.commitMessage,\n },\n },\n );\n\n if (response.error) {\n const errorMessage =\n response.error?.error ?? JSON.stringify(response.error);\n throw new Error(`Failed to sync prompt: ${errorMessage}`);\n }\n\n return {\n action: response.data.action as SyncAction,\n prompt: response.data.prompt,\n conflictInfo: response.data.conflictInfo,\n };\n } catch (error) {\n const message =\n error instanceof Error ? error.message : \"Unknown error occurred\";\n throw new PromptsApiError(message, \"sync\", error);\n }\n }\n}\n","import { type z } from \"zod\";\nimport type { paths } from \"@/internal/generated/openapi/api-client\";\nimport {\n type corePromptDataSchema,\n type promptMetadataSchema,\n type promptDataSchema\n} from \"./schema\";\n\n/**\n * Type for template variables - supporting common data types\n */\nexport type TemplateVariables = Record<\n string,\n string | number | boolean | object | null\n>;\n\n/**\n * Core data needed for prompt functionality\n */\nexport type CorePromptData = z.infer<typeof corePromptDataSchema>;\n\n/**\n * Optional metadata for identification and tracing\n */\nexport type PromptMetadata = z.infer<typeof promptMetadataSchema>;\n\n/**\n * Combined type for creating prompts\n */\nexport type PromptData = z.infer<typeof promptDataSchema>;\n\n// Extract API types from OpenAPI schema for backwards compatibility\nexport type CreatePromptBody = NonNullable<\n paths[\"/api/prompts\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type UpdatePromptBody = NonNullable<\n paths[\"/api/prompts/{id}\"][\"put\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type PromptResponse = NonNullable<\n paths[\"/api/prompts/{id}\"][\"get\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>;\n\n// Extract the PromptScope type from the API client\nexport type PromptScope = paths[\"/api/prompts\"][\"post\"][\"responses\"][\"200\"][\"content\"][\"application/json\"][\"scope\"];\n\n// Extract tag definition types from the OpenAPI schema\nexport type TagDefinition = NonNullable<\n paths[\"/api/prompts/tags\"][\"get\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>[number];\n\nexport type CreatedTag = NonNullable<\n paths[\"/api/prompts/tags\"][\"post\"][\"responses\"][\"201\"][\"content\"][\"application/json\"]\n>;\n\n/**\n * Fetch policy for prompt retrieval.\n * Controls how prompts are fetched and cached.\n */\nexport enum FetchPolicy {\n /** Use local file if available, otherwise fetch from API (default) */\n MATERIALIZED_FIRST = \"MATERIALIZED_FIRST\",\n /** Always try API first, fall back to materialized */\n ALWAYS_FETCH = \"ALWAYS_FETCH\",\n /** Fetch every X minutes, use materialized between fetches */\n CACHE_TTL = \"CACHE_TTL\",\n /** Never fetch, use materialized files only */\n MATERIALIZED_ONLY = \"MATERIALIZED_ONLY\",\n}\n\n","import { Liquid } from \"liquidjs\";\nimport { PromptTracingDecorator, tracer } from \"./tracing\";\nimport { createTracingProxy } from \"@/client-sdk/tracing/create-tracing-proxy\";\nimport { promptDataSchema } from \"./schema\";\nimport { type TemplateVariables, type PromptData, type CorePromptData, type PromptScope } from \"./types\";\nimport { PromptCompilationError, PromptValidationError } from \"./errors\";\n\n// Re-export types and errors for convenience\nexport type { TemplateVariables, PromptData, CorePromptData, PromptMetadata } from \"./types\";\nexport { PromptCompilationError, PromptValidationError } from \"./errors\";\n\n// Global Liquid instance - shared across all prompts for efficiency\nconst liquid = new Liquid({\n strictFilters: true,\n});\n\n/**\n * The Prompt class provides a standardized interface for working with prompt objects\n * within the SDK, focusing on core functionality needed for template compilation and execution.\n * Keeps only essential fields while maintaining compatibility with tracing and observability.\n */\nexport class Prompt {\n // === Core functionality (required) ===\n public readonly model!: string;\n public readonly messages!: Array<{\n role: \"user\" | \"assistant\" | \"system\";\n content: string;\n }>;\n\n // === Optional core fields ===\n public readonly prompt?: string;\n public readonly temperature?: number;\n public readonly maxTokens?: number;\n public readonly responseFormat?: CorePromptData[\"responseFormat\"];\n\n // === Optional identification (for tracing) ===\n public readonly id?: string;\n public readonly handle?: string | null;\n public readonly version?: number;\n public readonly versionId?: string;\n public readonly scope?: PromptScope;\n\n constructor(data: PromptData) {\n // Validate input using Zod\n const validationResult = promptDataSchema.strip().safeParse(data);\n\n if (!validationResult.success) {\n throw new PromptValidationError(\n \"Invalid prompt data provided\",\n validationResult.error\n );\n }\n\n // Assign validated data\n Object.assign(this, validationResult.data);\n\n // Set default for prompt if not provided\n this.prompt ??= this.extractSystemPrompt();\n\n // Return a proxy that wraps specific methods for tracing\n return createTracingProxy(this as Prompt, tracer, PromptTracingDecorator);\n }\n\n private extractSystemPrompt(): string {\n return this.messages.find(m => m.role === \"system\")?.content ?? \"\";\n }\n\n /**\n * Compile the prompt template with provided variables (lenient - missing variables become empty)\n * @param variables - Object containing variable values for template compilation\n * @returns CompiledPrompt instance with compiled content\n */\n private _compile(\n variables: TemplateVariables,\n strict: boolean,\n ): CompiledPrompt {\n try {\n // Compile main prompt\n const compiledPrompt = this.prompt\n ? liquid.parseAndRenderSync(this.prompt, variables, {\n strictVariables: strict,\n })\n : \"\";\n\n // Compile messages\n const compiledMessages = (this.messages || []).map((message) => ({\n ...message,\n content: message.content\n ? liquid.parseAndRenderSync(message.content, variables, {\n strictVariables: strict,\n })\n : message.content,\n }));\n\n // Create new prompt data with compiled content\n const compiledData: PromptData = {\n ...this,\n prompt: compiledPrompt,\n messages: compiledMessages,\n };\n\n return new CompiledPrompt(compiledData, this);\n } catch (error) {\n const templateStr = this.prompt ?? JSON.stringify(this.messages);\n throw new PromptCompilationError(\n `Failed to compile prompt template: ${\n error instanceof Error ? error.message : \"Unknown error\"\n }`,\n templateStr,\n error,\n );\n }\n }\n\n compile(variables: TemplateVariables = {}): CompiledPrompt {\n return this._compile(variables, false);\n }\n\n /**\n * Compile with validation - throws error if required variables are missing\n * @param variables - Template variables\n * @returns CompiledPrompt instance with compiled content\n */\n compileStrict(variables: TemplateVariables): CompiledPrompt {\n return this._compile(variables, true);\n }\n}\n\n\n/**\n * Represents a compiled prompt that extends Prompt with reference to the original template\n */\nexport class CompiledPrompt extends Prompt {\n constructor(\n compiledData: PromptData,\n public readonly original: Prompt,\n ) {\n super(compiledData);\n }\n}\n","// TODO: Move these to their own files\nimport { z } from \"zod\";\nimport { PromptScope } from \"../constants\";\n\n/**\n * Zod schema for message objects in prompts\n */\nexport const messageSchema = z.object({\n role: z.enum([\"user\", \"assistant\", \"system\"]),\n content: z.string(),\n});\n\n/**\n * Zod schema for response format configuration\n */\nexport const responseFormatSchema = z.object({\n type: z.literal(\"json_schema\"),\n json_schema: z.object({\n name: z.string(),\n schema: z.record(z.string(), z.unknown()),\n }).nullable(),\n}).optional();\n\n/**\n * Zod schema for core prompt data - the essential fields needed for functionality\n */\nexport const corePromptDataSchema = z.object({\n model: z.string().min(1, \"Model cannot be empty\"),\n messages: z.array(messageSchema).min(1, \"At least one message is required\"),\n prompt: z.string().optional(),\n temperature: z.number().min(0).max(2).optional(),\n maxTokens: z.number().positive().optional(),\n responseFormat: responseFormatSchema,\n});\n\n/**\n * Zod schema for prompt metadata - optional fields for identification and tracing\n */\nexport const promptMetadataSchema = z.object({\n id: z.string().optional(),\n handle: z.string().nullable().optional(),\n version: z.number().min(0).optional(),\n versionId: z.string().optional(),\n scope: z.enum(PromptScope).optional(),\n});\n\n/**\n * Combined schema for complete prompt data\n */\nexport const promptDataSchema = z.object({\n ...corePromptDataSchema.shape,\n ...promptMetadataSchema.shape,\n});\n","import { type PromptScope as PromptScopeType } from \"./types\";\n\nexport const PromptScope = {\n ORGANIZATION: \"ORGANIZATION\" as const,\n PROJECT: \"PROJECT\" as const,\n} satisfies Record<string, PromptScopeType>;\n","import type { LocalPromptConfig, PromptDependency } from \"@/cli/types\";\nimport { FileManager } from \"@/cli/utils/fileManager\";\nimport { type Logger, NoOpLogger } from \"@/logger\";\nimport { type PromptData } from \"./types\";\nimport { PromptFileNotFoundError } from \"@/cli/utils/errors/prompt-not-found.error\";\n\nexport interface LocalPromptsServiceConfig {\n fileManager?: typeof FileManager;\n logger?: Logger;\n}\n\n/**\n * Service for retrieving prompts from local filesystem sources.\n *\n * Searches for prompts in the following priority order:\n * 1. Explicit file mapping in prompts.json config\n * 2. Materialized path from prompts-lock.json\n * 3. Direct file scanning in prompts directory\n */\nexport class LocalPromptsService {\n private readonly fileManager: typeof FileManager;\n private readonly logger: Logger;\n\n constructor(config?: LocalPromptsServiceConfig) {\n this.fileManager = config?.fileManager ?? FileManager;\n this.logger = config?.logger ?? new NoOpLogger();\n }\n\n /**\n * Retrieves a prompt using the configured search strategy.\n * Tries each source in priority order until found or all sources exhausted.\n */\n async get(handleOrId: string): Promise<PromptData | null> {\n try {\n const dependency = await this.getDependencyFromConfig(handleOrId);\n\n // If no dependency is found, it means it's not a local prompt\n if (!dependency) {\n return null;\n }\n\n // Try each source in priority order until found or all sources exhausted\n // We catch errors and return null if any of the sources fail so we\n // can continue to the next source and return null if all sources fail\n const localPromptConfig = (\n (await this.getFromConfig(dependency).catch((e) => {\n if (e instanceof PromptFileNotFoundError) return null;\n throw e;\n })) ??\n (await this.getFromLockFile(handleOrId).catch((e) => {\n if (e instanceof PromptFileNotFoundError) return null;\n throw e;\n })) ??\n (await this.getFromLocalFiles(handleOrId).catch((e) => {\n if (e instanceof PromptFileNotFoundError) return null;\n throw e;\n }))\n );\n\n return localPromptConfig ? this.convertToPromptData({\n ...localPromptConfig,\n handle: handleOrId,\n }) : null;\n } catch (error) {\n this.logger.warn(`Failed to get prompt \"${handleOrId}\": ${error instanceof Error ? error.message : String(error)}`);\n return null;\n }\n }\n\n\n /**\n * Searches for prompt using explicit file mapping in prompts.json.\n * Looks for dependencies with a 'file' property pointing to a specific path.\n */\n private async getFromConfig(dependency: PromptDependency): Promise<LocalPromptConfig | null> {\n if (typeof dependency === 'string' && dependency.startsWith('file:')) {\n return this.fileManager.loadLocalPrompt(dependency.slice(5));\n }\n\n return null;\n }\n\n /**\n * Searches for prompt using materialized path from lock file.\n * Lock file contains resolved paths for prompts that have been synced/materialized.\n */\n private async getFromLockFile(handleOrId: string): Promise<LocalPromptConfig | null> {\n const lock = this.fileManager.loadPromptsLock();\n const lockEntry = lock.prompts[handleOrId];\n\n if (lockEntry?.materialized) {\n return this.fileManager.loadLocalPrompt(lockEntry.materialized);\n }\n\n return null;\n }\n\n /**\n * Searches for prompt by scanning all .prompt.yaml files in prompts directory.\n * Extracts prompt name from file path and matches against the requested handle.\n * This is the fallback method when explicit mappings don't exist.\n */\n private async getFromLocalFiles(handleOrId: string): Promise<LocalPromptConfig | null> {\n const localFiles = this.fileManager.getLocalPromptFiles();\n\n for (const filePath of localFiles) {\n const promptName = this.fileManager.promptNameFromPath(filePath);\n if (promptName === handleOrId) {\n return this.fileManager.loadLocalPrompt(filePath);\n }\n }\n\n return null;\n }\n\n /**\n * Get dependency from config\n */\n private async getDependencyFromConfig(handleOrId: string): Promise<PromptDependency | null> {\n const config = this.fileManager.loadPromptsConfig();\n const dependency = config.prompts[handleOrId];\n\n return dependency ?? null;\n }\n\n /**\n * Converts LocalPromptConfig to PromptData format\n */\n private convertToPromptData(config: LocalPromptConfig & { handle: string; }): PromptData {\n const { modelParameters, ...rest } = config;\n return {\n maxTokens: modelParameters?.max_tokens,\n temperature: modelParameters?.temperature,\n ...rest,\n };\n }\n}\n","import { PromptsApiService, type AssignTagResult } from \"./prompts-api.service\";\nimport { Prompt } from \"./prompt\";\nimport type { CreatePromptBody, UpdatePromptBody, PromptData, TagDefinition, CreatedTag } from \"./types\";\nimport { FetchPolicy } from \"./types\";\nimport { type InternalConfig } from \"@/client-sdk/types\";\nimport { LocalPromptsService } from \"./local-prompts.service\";\nimport { PromptsError } from \"./errors\";\n\n/**\n * Options for fetching a prompt.\n */\nexport interface GetPromptOptions {\n /** Specific version to fetch */\n version?: string;\n /** Tag to fetch (e.g., \"production\", \"staging\", or a custom tag) */\n tag?: string;\n /** Fetch policy to use */\n fetchPolicy?: FetchPolicy;\n /** Cache TTL in minutes (only used with CACHE_TTL policy) */\n cacheTtlMinutes?: number;\n}\n\ninterface CacheEntry {\n data: PromptData;\n timestamp: number;\n}\n\ninterface PromptsFacadeDependencies {\n promptsApiService: PromptsApiService;\n localPromptsService: LocalPromptsService;\n}\n\n/**\n * Facade for prompt operations in the LangWatch SDK.\n * Provides a simplified interface for common prompt management tasks.\n */\nexport class PromptsFacade implements Pick<PromptsApiService, \"sync\" | \"delete\">{\n private readonly promptsApiService: PromptsApiService;\n private readonly localPromptsService: LocalPromptsService;\n private readonly cache = new Map<string, CacheEntry>();\n readonly tags: {\n assign(id: string, params: { tag: string; versionId: string }): Promise<AssignTagResult>;\n list(): Promise<TagDefinition[]>;\n create(params: { name: string }): Promise<CreatedTag>;\n delete(tagName: string): Promise<void>;\n rename(oldName: string, newName: string): Promise<void>;\n };\n\n constructor(config: InternalConfig & PromptsFacadeDependencies) {\n this.promptsApiService = config.promptsApiService ?? new PromptsApiService(config);\n this.localPromptsService = config.localPromptsService ?? new LocalPromptsService();\n this.tags = {\n assign: (id, { tag, versionId }) =>\n this.promptsApiService.assignTag({ id, tag, versionId }),\n list: () => this.promptsApiService.listTags(),\n create: ({ name }) => this.promptsApiService.createTag({ name }),\n delete: (tagName) => this.promptsApiService.deleteTag(tagName),\n rename: (oldName, newName) =>\n this.promptsApiService.renameTag({ tag: oldName, name: newName }),\n };\n }\n\n /**\n * Creates a new prompt.\n * @param data The prompt creation payload.\n * @returns The created Prompt instance.\n * @throws {PromptsError} If the API call fails.\n */\n async create(data: CreatePromptBody): Promise<Prompt> {\n const serverPrompt = await this.promptsApiService.create(data);\n return new Prompt(serverPrompt);\n }\n\n /**\n * Retrieves a prompt by handle or ID.\n *\n * Supports shorthand `handle:tag` syntax — e.g. `get(\"pizza-prompt:production\")`.\n * Shorthand is parsed server-side; the SDK passes the string through as-is.\n *\n * @param handleOrId The prompt's handle, unique identifier, or `handle:tag` shorthand.\n * @param options Optional parameters for the request.\n * @returns The Prompt instance.\n * @throws {PromptsError} If the prompt is not found or the API call fails.\n */\n async get(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n const fetchPolicy = options?.fetchPolicy ?? FetchPolicy.MATERIALIZED_FIRST;\n\n switch (fetchPolicy) {\n case FetchPolicy.MATERIALIZED_ONLY:\n return this.getMaterializedOnly(handleOrId);\n\n case FetchPolicy.ALWAYS_FETCH:\n return this.getAlwaysFetch(handleOrId, options);\n\n case FetchPolicy.CACHE_TTL:\n return this.getCacheTtl(handleOrId, options);\n\n case FetchPolicy.MATERIALIZED_FIRST:\n default:\n return this.getMaterializedFirst(handleOrId, options);\n }\n }\n\n private async getMaterializedFirst(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n const serverPrompt = await this.promptsApiService.get(handleOrId, options);\n return new Prompt(serverPrompt);\n }\n\n private async getAlwaysFetch(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n try {\n const serverPrompt = await this.promptsApiService.get(handleOrId, options);\n return new Prompt(serverPrompt);\n } catch {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n throw new PromptsError(`Prompt \"${handleOrId}\" not found locally or on server`);\n }\n }\n\n private async getMaterializedOnly(handleOrId: string): Promise<Prompt> {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n throw new PromptsError(`Prompt \"${handleOrId}\" not found in materialized files`);\n }\n\n private buildCacheKey(handleOrId: string, options?: GetPromptOptions): string {\n const tagSegment = options?.tag != null ? `::tag:${options.tag}` : '';\n return `${handleOrId}::version:${options?.version ?? ''}${tagSegment}`;\n }\n\n private async getCacheTtl(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n const cacheKey = this.buildCacheKey(handleOrId, options);\n const ttlMs = (options?.cacheTtlMinutes ?? 5) * 60 * 1000;\n const cached = this.cache.get(cacheKey);\n const now = Date.now();\n\n if (cached && now - cached.timestamp < ttlMs) {\n return new Prompt(cached.data);\n }\n\n try {\n const serverPrompt = await this.promptsApiService.get(handleOrId, options);\n this.cache.set(cacheKey, { data: serverPrompt, timestamp: now });\n return new Prompt(serverPrompt);\n } catch {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n throw new PromptsError(`Prompt \"${handleOrId}\" not found locally or on server`);\n }\n }\n\n /**\n * Retrieves all prompts.\n * @returns Array of Prompt instances.\n * @throws {PromptsError} If the API call fails.\n */\n async getAll(): Promise<Prompt[]> {\n const serverPrompts = await this.promptsApiService.getAll();\n return serverPrompts.map((prompt) => new Prompt(prompt));\n }\n\n /**\n * Updates an existing prompt.\n * @param handleOrId The prompt's handle or unique identifier.\n * @param newData The update payload.\n * @returns The updated Prompt instance.\n * @throws {PromptsError} If the API call fails.\n */\n async update(handleOrId: string, newData: UpdatePromptBody): Promise<Prompt> {\n const serverPrompt = await this.promptsApiService.update(handleOrId, newData);\n return new Prompt(serverPrompt);\n }\n\n get delete() {\n return this.promptsApiService.delete.bind(this.promptsApiService);\n }\n\n /**\n * Delegated method to the prompts API service.\n */\n get sync() {\n return this.promptsApiService.sync.bind(this.promptsApiService);\n }\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-EDEAR2QX.js","../src/client-sdk/services/prompts/errors/prompts.error.ts","../src/client-sdk/services/prompts/errors/prompt-compilation.error.ts","../src/client-sdk/services/prompts/errors/prompt-validation.error.ts","../src/client-sdk/services/prompts/errors/prompts-api.error.ts","../src/client-sdk/services/prompts/tracing/prompt-tracing.decorator.ts","../src/client-sdk/services/prompts/tracing/prompt-service-tracing.decorator.ts","../src/client-sdk/services/prompts/tracing/tracer.ts","../src/client-sdk/services/prompts/prompts-api.service.ts","../src/client-sdk/services/prompts/types.ts","../src/client-sdk/services/prompts/prompt.ts","../src/client-sdk/services/prompts/schema/prompt.schema.ts","../src/client-sdk/services/prompts/constants.ts","../src/client-sdk/services/prompts/local-prompts.service.ts","../src/client-sdk/services/prompts/prompts.facade.ts"],"names":["FetchPolicy"],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-EDEAR2QX.js","sourcesContent":[null,"/**\n * Base error class for the Prompts domain.\n * All prompt-related errors should extend this class.\n */\nexport class PromptsError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"PromptsError\";\n }\n}\n","/**\n * Error class for template compilation issues\n */\nexport class PromptCompilationError extends Error {\n constructor(\n message: string,\n public readonly template: string,\n public readonly originalError?: any,\n ) {\n super(message);\n this.name = \"PromptCompilationError\";\n }\n}\n","import { type z } from \"zod\";\n\n/**\n * Error class for prompt validation issues\n */\nexport class PromptValidationError extends Error {\n constructor(message: string, public readonly validationErrors: z.ZodError) {\n super(message);\n this.name = \"PromptValidationError\";\n }\n}\n","import { PromptsError } from \"./prompts.error\";\n\n/**\n * Error class for Prompts API operations.\n * Provides context about the failed operation and the original error.\n */\nexport class PromptsApiError extends PromptsError {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"PromptsApiError\";\n }\n}\n","import { type Prompt, type TemplateVariables, type CompiledPrompt } from \"../prompt\";\nimport { shouldCaptureInput, shouldCaptureOutput } from \"@/observability-sdk\";\nimport type { LangWatchSpan } from \"@/observability-sdk\";\n\n/**\n * Class that decorates the target prompt,\n * adding tracing to specific methods.\n */\nexport class PromptTracingDecorator {\n constructor(private readonly target: Prompt) {}\n\n private traceCompilation(\n span: LangWatchSpan,\n variables: TemplateVariables,\n compileFn: () => CompiledPrompt\n ): CompiledPrompt {\n span.setType(\"prompt\");\n\n if (shouldCaptureInput()) {\n span.setInput(this.target);\n\n if (variables) {\n span.setAttribute(\n 'langwatch.prompt.variables',\n JSON.stringify({\n type: \"json\",\n value: variables,\n }),\n );\n }\n }\n\n const result = compileFn();\n\n // Only emit combined handle:version format when both are available\n if (result.handle != null && result.version != null) {\n span.setAttribute(\n 'langwatch.prompt.id',\n `${result.handle}:${result.version}`,\n );\n }\n\n if (shouldCaptureOutput()) {\n span.setOutput({\n ...result,\n raw: void 0, // TODO(afr): Figure out a better way to do this.\n });\n }\n\n return result;\n }\n\n compile(span: LangWatchSpan, variables: TemplateVariables = {}): CompiledPrompt {\n return this.traceCompilation(\n span,\n variables,\n () => this.target.compile(variables),\n );\n }\n\n compileStrict(span: LangWatchSpan, variables: TemplateVariables): CompiledPrompt {\n return this.traceCompilation(\n span,\n variables,\n () => this.target.compileStrict(variables),\n );\n }\n}\n","import { type PromptsApiService } from \"../prompts-api.service\";\nimport type { LangWatchSpan } from \"@/observability-sdk\";\nimport { shouldCaptureInput, shouldCaptureOutput } from \"@/observability-sdk\";\nimport type { CreatePromptBody, UpdatePromptBody, PromptResponse } from \"../types\";\n\n/**\n * Class that decorates the target prompt service,\n * adding tracing to key methods.\n */\nexport class PromptServiceTracingDecorator {\n constructor(private readonly target: PromptsApiService) {}\n\n async get(\n span: LangWatchSpan,\n id: string,\n options?: { version?: string }\n ): Promise<PromptResponse> {\n span.setType(\"prompt\");\n\n const result = await this.target.get(id, options);\n\n if (result) {\n // Only emit combined format when both handle and version are available\n if (result.handle != null && result.version != null) {\n span.setAttribute(\n 'langwatch.prompt.id',\n `${result.handle}:${result.version}`,\n );\n }\n }\n\n if (result && shouldCaptureOutput()) {\n span.setOutput(\"json\", result);\n }\n\n return result;\n }\n\n async create(\n span: LangWatchSpan,\n params: CreatePromptBody\n ): Promise<PromptResponse> {\n span.setType(\"prompt\");\n\n if (shouldCaptureInput()) {\n span.setInput(params);\n }\n\n const result = await this.target.create(params);\n\n span.setAttributes({\n 'langwatch.prompt.id': result.id,\n 'langwatch.prompt.handle': result.handle ?? undefined,\n 'langwatch.prompt.scope': result.scope,\n 'langwatch.prompt.version.id': result.versionId,\n 'langwatch.prompt.version.number': result.version,\n });\n\n return result;\n }\n\n async update(\n span: LangWatchSpan,\n id: string,\n params: UpdatePromptBody\n ): Promise<PromptResponse> {\n\n if (shouldCaptureInput()) {\n span.setInput(params);\n }\n\n const result = await this.target.update(id, params);\n\n span.setType(\"prompt\");\n span.setAttributes({\n 'langwatch.prompt.id': id,\n 'langwatch.prompt.handle': result.handle ?? undefined,\n 'langwatch.prompt.scope': result.scope,\n 'langwatch.prompt.version.id': result.versionId,\n 'langwatch.prompt.version.number': result.version,\n });\n\n return result;\n }\n\n async delete(\n span: LangWatchSpan,\n id: string\n ): Promise<{ success: boolean }> {\n const result = await this.target.delete(id);\n\n span.setType(\"prompt\");\n span.setAttribute('langwatch.prompt.id', id);\n span.setAttribute('langwatch.prompt.deleted', 'true');\n\n return result;\n }\n\n async upsert(\n span: LangWatchSpan,\n handle: string,\n config: any\n ): Promise<{ created: boolean; prompt: PromptResponse }> {\n if (shouldCaptureInput()) {\n span.setInput(config);\n }\n\n const result = await this.target.upsert(handle, config);\n\n span.setType(\"prompt\");\n span.setAttributes({\n 'langwatch.prompt.handle': handle,\n 'langwatch.prompt.created': result.created.toString(),\n 'langwatch.prompt.id': result.prompt.id,\n 'langwatch.prompt.version.id': result.prompt.versionId,\n 'langwatch.prompt.version.number': result.prompt.version,\n });\n\n return result;\n }\n\n async sync(\n span: LangWatchSpan,\n params: any\n ): Promise<any> {\n if (shouldCaptureInput()) {\n span.setInput(params);\n }\n\n const result = await this.target.sync(params);\n\n span.setType(\"prompt\");\n span.setAttribute('langwatch.prompt.name', params.name);\n span.setAttribute('langwatch.prompt.sync.action', result.action);\n\n if (result.conflictInfo) {\n span.setAttributes({\n 'langwatch.prompt.sync.has_conflict': 'true',\n 'langwatch.prompt.sync.local_version': result.conflictInfo.localVersion.toString(),\n 'langwatch.prompt.sync.remote_version': result.conflictInfo.remoteVersion.toString(),\n });\n }\n\n return result;\n }\n}\n","import { getLangWatchTracer } from \"@/observability-sdk/tracer\";\nimport { LANGWATCH_SDK_NAME_CLIENT, LANGWATCH_SDK_VERSION } from \"@/internal/constants\";\n\nexport const tracer = getLangWatchTracer(`${LANGWATCH_SDK_NAME_CLIENT}.prompts`, LANGWATCH_SDK_VERSION);\n","import type { paths, operations } from \"@/internal/generated/openapi/api-client\";\nimport { type PromptResponse, type TagDefinition, type CreatedTag } from \"./types\";\nimport { PromptConverter } from \"@/cli/utils/promptConverter\";\nimport { PromptServiceTracingDecorator, tracer } from \"./tracing\";\nimport { createTracingProxy } from \"@/client-sdk/tracing/create-tracing-proxy\";\nimport { type InternalConfig } from \"@/client-sdk/types\";\nimport { type CreatePromptBody, type UpdatePromptBody } from \"./types\";\nimport { createLangWatchApiClient, type LangwatchApiClient } from \"@/internal/api/client\";\nimport { PromptsApiError } from \"./errors\";\n\nexport type SyncAction = \"created\" | \"updated\" | \"conflict\" | \"up_to_date\";\n\nexport type AssignTagResult = NonNullable<\n operations[\"putApiPromptsByIdTagsByTag\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>;\n\nexport type ConfigData = NonNullable<\n paths[\"/api/prompts/{id}/sync\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"][\"configData\"];\n\nexport interface SyncResult {\n action: SyncAction;\n prompt?: PromptResponse;\n conflictInfo?: {\n localVersion: number;\n remoteVersion: number;\n differences: string[];\n remoteConfigData: ConfigData;\n };\n}\n\n/**\n * Service for managing prompt resources via the Langwatch API.\n * Constructor creates a proxy that wraps the service and traces all methods.\n *\n * Responsibilities:\n * - CRUD operations for prompts\n * - Creating prompt versions\n * - Error handling with contextual information\n *\n * All methods return raw PromptResponse data from the API.\n */\nexport class PromptsApiService {\n private readonly apiClient: LangwatchApiClient;\n\n constructor(config?: Pick<InternalConfig, \"langwatchApiClient\">) {\n this.apiClient = config?.langwatchApiClient ?? createLangWatchApiClient();\n\n /**\n * Wraps the service in a tracing proxy via the decorator.\n */\n return createTracingProxy(\n this as PromptsApiService,\n tracer,\n PromptServiceTracingDecorator,\n );\n }\n\n /**\n * Handles API errors by throwing a PromptsApiError with operation context.\n * @param operation Description of the operation being performed.\n * @param error The error object returned from the API client.\n * @throws {PromptsApiError}\n */\n private handleApiError(operation: string, error: any): never {\n const errorMessage =\n typeof error === \"string\"\n ? error\n : error?.error != null\n ? typeof error.error === \"string\"\n ? error.error\n : error.error.message ??\n JSON.stringify(error.error, Object.getOwnPropertyNames(error.error))\n : error?.message ?? \"Unknown error occurred\";\n\n throw new PromptsApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n /**\n * Fetches all prompts from the API.\n * @returns Array of raw PromptResponse data.\n * @throws {PromptsApiError} If the API call fails.\n */\n async getAll(): Promise<PromptResponse[]> {\n const { data, error } =\n await this.apiClient.GET(\"/api/prompts\");\n if (error) this.handleApiError(\"fetch all prompts\", error);\n return data;\n }\n\n /**\n * Fetches a single prompt by its ID.\n * @param id The prompt's unique identifier.\n * @param options Optional parameters for the request.\n * @param options.version Specific version to fetch (numeric string or \"latest\").\n * @param options.tag Tag to fetch (e.g., \"production\", \"staging\", or a custom tag).\n * @returns Raw PromptResponse data.\n * @throws {PromptsApiError} If the API call fails.\n */\n get = async (id: string, options?: { version?: string; tag?: string }): Promise<PromptResponse> => {\n // Parse version to number, skip for \"latest\" or invalid values\n const versionNumber = options?.version && options.version !== \"latest\"\n ? parseInt(options.version, 10)\n : undefined;\n\n const { data, error } = await this.apiClient.GET(\n \"/api/prompts/{id}\",\n {\n params: {\n path: { id },\n query: {\n version: Number.isNaN(versionNumber) ? undefined : versionNumber,\n tag: options?.tag,\n },\n },\n },\n );\n\n if (error) {\n this.handleApiError(`fetch prompt with ID \"${id}\"`, error);\n }\n\n return data;\n }\n\n /**\n * Validates if a prompt exists.\n * @param id The prompt's unique identifier.\n * @returns True if prompt exists, false otherwise.\n * @throws {PromptsApiError} If the API call fails (not 404).\n */\n async exists(id: string): Promise<boolean> {\n try {\n await this.get(id);\n return true;\n } catch (error) {\n const originalError = error instanceof PromptsApiError ? error.originalError : null;\n const statusCode = originalError != null && typeof originalError === \"object\" && \"statusCode\" in originalError\n ? (originalError as { statusCode: unknown }).statusCode\n : null;\n\n if (statusCode === 404) {\n return false;\n }\n\n throw error;\n }\n }\n\n /**\n * Creates a new prompt.\n * @param params The prompt creation payload, matching the OpenAPI schema.\n * @returns Raw PromptResponse data of the created prompt.\n * @throws {PromptsApiError} If the API call fails.\n */\n async create(params: CreatePromptBody): Promise<PromptResponse> {\n const { data, error } = await this.apiClient.POST(\n \"/api/prompts\",\n {\n body: params,\n },\n );\n if (error) this.handleApiError(\"create prompt\", error);\n return data;\n }\n\n /**\n * Updates an existing prompt.\n * @param id The prompt's unique identifier.\n * @param params The update payload, matching the OpenAPI schema.\n * @returns Raw PromptResponse data of the updated prompt.\n * @throws {PromptsApiError} If the API call fails.\n */\n async update(id: string, params: UpdatePromptBody): Promise<PromptResponse> {\n const { error, data: updatedPrompt } =\n await this.apiClient.PUT(\"/api/prompts/{id}\", {\n params: { path: { id } },\n body: params,\n });\n if (error) this.handleApiError(`update prompt with ID \"${id}\"`, error);\n return updatedPrompt;\n }\n\n /**\n * Lists all prompt tags (built-in and custom) for the organization.\n * @returns Array of tag definitions.\n * @throws {PromptsApiError} If the API call fails.\n */\n async listTags(): Promise<TagDefinition[]> {\n const { data, error } = await this.apiClient.GET(\"/api/prompts/tags\");\n if (error) this.handleApiError(\"list tags\", error);\n return data;\n }\n\n /**\n * Creates a custom prompt tag for the organization.\n * @param params.name The tag name (must match /^[a-z][a-z0-9_-]*$/).\n * @returns The created tag.\n * @throws {PromptsApiError} If the API call fails.\n */\n async createTag({ name }: { name: string }): Promise<CreatedTag> {\n const { data, error } = await this.apiClient.POST(\"/api/prompts/tags\", {\n body: { name },\n });\n if (error) this.handleApiError(\"create tag\", error);\n return data;\n }\n\n /**\n * Deletes a custom prompt tag by name.\n * @param tagName The tag name to delete.\n * @throws {PromptsApiError} If the API call fails.\n */\n async deleteTag(tagName: string): Promise<void> {\n const { error } = await this.apiClient.DELETE(\n \"/api/prompts/tags/{tag}\" as any,\n { params: { path: { tag: tagName } } } as any,\n );\n if (error) this.handleApiError(`delete tag \"${tagName}\"`, error);\n }\n\n /**\n * Renames an existing prompt tag.\n * @param tag The current tag name.\n * @param name The new tag name.\n * @throws {PromptsApiError} If the API call fails.\n */\n async renameTag({ tag, name }: { tag: string; name: string }): Promise<void> {\n const { error } = await this.apiClient.PUT(\n \"/api/prompts/tags/{tag}\",\n { params: { path: { tag } }, body: { name } },\n );\n if (error) this.handleApiError(`rename tag \"${tag}\"`, error);\n }\n\n async assignTag({\n id,\n tag,\n versionId,\n }: {\n id: string;\n tag: string;\n versionId: string;\n }): Promise<AssignTagResult> {\n const { data, error } = await this.apiClient.PUT(\n \"/api/prompts/{id}/tags/{tag}\",\n {\n params: { path: { id, tag } },\n body: { versionId },\n },\n );\n if (error) this.handleApiError(`assign tag \"${tag}\" to prompt \"${id}\"`, error);\n return data;\n }\n\n /**\n * Deletes a prompt by its ID.\n * @param id The prompt's unique identifier.\n * @throws {PromptsApiError} If the API call fails.\n */\n async delete(id: string): Promise<{ success: boolean }> {\n const { data, error } = await this.apiClient.DELETE(\n \"/api/prompts/{id}\",\n {\n params: { path: { id } },\n },\n );\n if (error) this.handleApiError(`delete prompt with ID \"${id}\"`, error);\n\n return data;\n }\n\n /**\n * Fetches all versions for a given prompt.\n * @param id The prompt's unique identifier.\n * @returns Array of raw PromptResponse data for each version.\n * @throws {PromptsApiError} If the API call fails.\n */\n async getVersions(id: string): Promise<PromptResponse[]> {\n const { data, error } = await this.apiClient.GET(\n \"/api/prompts/{id}/versions\",\n {\n params: { path: { id } },\n },\n );\n if (error)\n this.handleApiError(`fetch versions for prompt with ID \"${id}\"`, error);\n\n return data;\n }\n\n /**\n * Upserts a prompt with local configuration - creates if doesn't exist, updates version if exists.\n * @param handle The prompt's handle/identifier.\n * @param config Local prompt configuration.\n * @returns Object with created flag and raw PromptResponse data.\n * @throws {PromptsApiError} If the API call fails.\n */\n async upsert(\n handle: string,\n config: {\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 ): Promise<{ created: boolean; prompt: PromptResponse }> {\n const payload = {\n handle,\n model: config.model,\n prompt: PromptConverter.extractSystemPrompt(config.messages),\n messages: PromptConverter.filterNonSystemMessages(config.messages),\n temperature: config.modelParameters?.temperature,\n maxTokens: config.modelParameters?.max_tokens,\n inputs: [{ identifier: \"input\", type: \"str\" as const }],\n outputs: [{ identifier: \"output\", type: \"str\" as const }],\n commitMessage: `Updated via CLI sync`,\n schemaVersion: \"1.0\" as const,\n };\n\n // Creating a prompt with the same handle will fail, so we try to update instead\n try {\n const prompt = await this.create(payload);\n return {\n created: true,\n prompt,\n };\n } catch {\n const prompt = await this.update(handle, payload);\n\n return {\n created: false,\n prompt,\n };\n }\n }\n\n /**\n * Sync a prompt with local content, handling conflicts and version management\n * You probably don't need to use this method directly.\n */\n async sync(params: {\n name: string;\n configData: ConfigData;\n localVersion?: number;\n commitMessage?: string;\n }): Promise<SyncResult> {\n try {\n const response = await this.apiClient.POST(\n \"/api/prompts/{id}/sync\",\n {\n params: { path: { id: params.name } },\n body: {\n configData: params.configData,\n localVersion: params.localVersion,\n commitMessage: params.commitMessage,\n },\n },\n );\n\n if (response.error) {\n const errorMessage =\n response.error?.error ?? JSON.stringify(response.error);\n throw new Error(`Failed to sync prompt: ${errorMessage}`);\n }\n\n return {\n action: response.data.action as SyncAction,\n prompt: response.data.prompt,\n conflictInfo: response.data.conflictInfo,\n };\n } catch (error) {\n const message =\n error instanceof Error ? error.message : \"Unknown error occurred\";\n throw new PromptsApiError(message, \"sync\", error);\n }\n }\n}\n","import { type z } from \"zod\";\nimport type { paths } from \"@/internal/generated/openapi/api-client\";\nimport {\n type corePromptDataSchema,\n type promptMetadataSchema,\n type promptDataSchema\n} from \"./schema\";\n\n/**\n * Type for template variables - supporting common data types\n */\nexport type TemplateVariables = Record<\n string,\n string | number | boolean | object | null\n>;\n\n/**\n * Core data needed for prompt functionality\n */\nexport type CorePromptData = z.infer<typeof corePromptDataSchema>;\n\n/**\n * Optional metadata for identification and tracing\n */\nexport type PromptMetadata = z.infer<typeof promptMetadataSchema>;\n\n/**\n * Combined type for creating prompts\n */\nexport type PromptData = z.infer<typeof promptDataSchema>;\n\n// Extract API types from OpenAPI schema for backwards compatibility\nexport type CreatePromptBody = NonNullable<\n paths[\"/api/prompts\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type UpdatePromptBody = NonNullable<\n paths[\"/api/prompts/{id}\"][\"put\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type PromptResponse = NonNullable<\n paths[\"/api/prompts/{id}\"][\"get\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>;\n\n// Extract the PromptScope type from the API client\nexport type PromptScope = paths[\"/api/prompts\"][\"post\"][\"responses\"][\"200\"][\"content\"][\"application/json\"][\"scope\"];\n\n// Extract tag definition types from the OpenAPI schema\nexport type TagDefinition = NonNullable<\n paths[\"/api/prompts/tags\"][\"get\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>[number];\n\nexport type CreatedTag = NonNullable<\n paths[\"/api/prompts/tags\"][\"post\"][\"responses\"][\"201\"][\"content\"][\"application/json\"]\n>;\n\n/**\n * Fetch policy for prompt retrieval.\n * Controls how prompts are fetched and cached.\n */\nexport enum FetchPolicy {\n /** Use local file if available, otherwise fetch from API (default) */\n MATERIALIZED_FIRST = \"MATERIALIZED_FIRST\",\n /** Always try API first, fall back to materialized */\n ALWAYS_FETCH = \"ALWAYS_FETCH\",\n /** Fetch every X minutes, use materialized between fetches */\n CACHE_TTL = \"CACHE_TTL\",\n /** Never fetch, use materialized files only */\n MATERIALIZED_ONLY = \"MATERIALIZED_ONLY\",\n}\n\n","import { Liquid } from \"liquidjs\";\nimport { PromptTracingDecorator, tracer } from \"./tracing\";\nimport { createTracingProxy } from \"@/client-sdk/tracing/create-tracing-proxy\";\nimport { promptDataSchema } from \"./schema\";\nimport { type TemplateVariables, type PromptData, type CorePromptData, type PromptScope } from \"./types\";\nimport { PromptCompilationError, PromptValidationError } from \"./errors\";\n\n// Re-export types and errors for convenience\nexport type { TemplateVariables, PromptData, CorePromptData, PromptMetadata } from \"./types\";\nexport { PromptCompilationError, PromptValidationError } from \"./errors\";\n\n// Global Liquid instance - shared across all prompts for efficiency\nconst liquid = new Liquid({\n strictFilters: true,\n});\n\n/**\n * The Prompt class provides a standardized interface for working with prompt objects\n * within the SDK, focusing on core functionality needed for template compilation and execution.\n * Keeps only essential fields while maintaining compatibility with tracing and observability.\n */\nexport class Prompt {\n // === Core functionality (required) ===\n public readonly model!: string;\n public readonly messages!: Array<{\n role: \"user\" | \"assistant\" | \"system\";\n content: string;\n }>;\n\n // === Optional core fields ===\n public readonly prompt?: string;\n public readonly temperature?: number;\n public readonly maxTokens?: number;\n public readonly responseFormat?: CorePromptData[\"responseFormat\"];\n\n // === Optional identification (for tracing) ===\n public readonly id?: string;\n public readonly handle?: string | null;\n public readonly version?: number;\n public readonly versionId?: string;\n public readonly scope?: PromptScope;\n\n constructor(data: PromptData) {\n // Validate input using Zod\n const validationResult = promptDataSchema.strip().safeParse(data);\n\n if (!validationResult.success) {\n throw new PromptValidationError(\n \"Invalid prompt data provided\",\n validationResult.error\n );\n }\n\n // Assign validated data\n Object.assign(this, validationResult.data);\n\n // Set default for prompt if not provided\n this.prompt ??= this.extractSystemPrompt();\n\n // Return a proxy that wraps specific methods for tracing\n return createTracingProxy(this as Prompt, tracer, PromptTracingDecorator);\n }\n\n private extractSystemPrompt(): string {\n return this.messages.find(m => m.role === \"system\")?.content ?? \"\";\n }\n\n /**\n * Compile the prompt template with provided variables (lenient - missing variables become empty)\n * @param variables - Object containing variable values for template compilation\n * @returns CompiledPrompt instance with compiled content\n */\n private _compile(\n variables: TemplateVariables,\n strict: boolean,\n ): CompiledPrompt {\n try {\n // Compile main prompt\n const compiledPrompt = this.prompt\n ? liquid.parseAndRenderSync(this.prompt, variables, {\n strictVariables: strict,\n })\n : \"\";\n\n // Compile messages\n const compiledMessages = (this.messages || []).map((message) => ({\n ...message,\n content: message.content\n ? liquid.parseAndRenderSync(message.content, variables, {\n strictVariables: strict,\n })\n : message.content,\n }));\n\n // Create new prompt data with compiled content\n const compiledData: PromptData = {\n ...this,\n prompt: compiledPrompt,\n messages: compiledMessages,\n };\n\n return new CompiledPrompt(compiledData, this);\n } catch (error) {\n const templateStr = this.prompt ?? JSON.stringify(this.messages);\n throw new PromptCompilationError(\n `Failed to compile prompt template: ${\n error instanceof Error ? error.message : \"Unknown error\"\n }`,\n templateStr,\n error,\n );\n }\n }\n\n compile(variables: TemplateVariables = {}): CompiledPrompt {\n return this._compile(variables, false);\n }\n\n /**\n * Compile with validation - throws error if required variables are missing\n * @param variables - Template variables\n * @returns CompiledPrompt instance with compiled content\n */\n compileStrict(variables: TemplateVariables): CompiledPrompt {\n return this._compile(variables, true);\n }\n}\n\n\n/**\n * Represents a compiled prompt that extends Prompt with reference to the original template\n */\nexport class CompiledPrompt extends Prompt {\n constructor(\n compiledData: PromptData,\n public readonly original: Prompt,\n ) {\n super(compiledData);\n }\n}\n","// TODO: Move these to their own files\nimport { z } from \"zod\";\nimport { PromptScope } from \"../constants\";\n\n/**\n * Zod schema for message objects in prompts\n */\nexport const messageSchema = z.object({\n role: z.enum([\"user\", \"assistant\", \"system\"]),\n content: z.string(),\n});\n\n/**\n * Zod schema for response format configuration\n */\nexport const responseFormatSchema = z.object({\n type: z.literal(\"json_schema\"),\n json_schema: z.object({\n name: z.string(),\n schema: z.record(z.string(), z.unknown()),\n }).nullable(),\n}).optional();\n\n/**\n * Zod schema for core prompt data - the essential fields needed for functionality\n */\nexport const corePromptDataSchema = z.object({\n model: z.string().min(1, \"Model cannot be empty\"),\n messages: z.array(messageSchema).min(1, \"At least one message is required\"),\n prompt: z.string().optional(),\n temperature: z.number().min(0).max(2).optional(),\n maxTokens: z.number().positive().optional(),\n responseFormat: responseFormatSchema,\n});\n\n/**\n * Zod schema for prompt metadata - optional fields for identification and tracing\n */\nexport const promptMetadataSchema = z.object({\n id: z.string().optional(),\n handle: z.string().nullable().optional(),\n version: z.number().min(0).optional(),\n versionId: z.string().optional(),\n scope: z.enum(PromptScope).optional(),\n});\n\n/**\n * Combined schema for complete prompt data\n */\nexport const promptDataSchema = z.object({\n ...corePromptDataSchema.shape,\n ...promptMetadataSchema.shape,\n});\n","import { type PromptScope as PromptScopeType } from \"./types\";\n\nexport const PromptScope = {\n ORGANIZATION: \"ORGANIZATION\" as const,\n PROJECT: \"PROJECT\" as const,\n} satisfies Record<string, PromptScopeType>;\n","import type { LocalPromptConfig, PromptDependency } from \"@/cli/types\";\nimport { FileManager } from \"@/cli/utils/fileManager\";\nimport { type Logger, NoOpLogger } from \"@/logger\";\nimport { type PromptData } from \"./types\";\nimport { PromptFileNotFoundError } from \"@/cli/utils/errors/prompt-not-found.error\";\n\nexport interface LocalPromptsServiceConfig {\n fileManager?: typeof FileManager;\n logger?: Logger;\n}\n\n/**\n * Service for retrieving prompts from local filesystem sources.\n *\n * Searches for prompts in the following priority order:\n * 1. Explicit file mapping in prompts.json config\n * 2. Materialized path from prompts-lock.json\n * 3. Direct file scanning in prompts directory\n */\nexport class LocalPromptsService {\n private readonly fileManager: typeof FileManager;\n private readonly logger: Logger;\n\n constructor(config?: LocalPromptsServiceConfig) {\n this.fileManager = config?.fileManager ?? FileManager;\n this.logger = config?.logger ?? new NoOpLogger();\n }\n\n /**\n * Retrieves a prompt using the configured search strategy.\n * Tries each source in priority order until found or all sources exhausted.\n */\n async get(handleOrId: string): Promise<PromptData | null> {\n try {\n const dependency = await this.getDependencyFromConfig(handleOrId);\n\n // If no dependency is found, it means it's not a local prompt\n if (!dependency) {\n return null;\n }\n\n // Try each source in priority order until found or all sources exhausted\n // We catch errors and return null if any of the sources fail so we\n // can continue to the next source and return null if all sources fail\n const localPromptConfig = (\n (await this.getFromConfig(dependency).catch((e) => {\n if (e instanceof PromptFileNotFoundError) return null;\n throw e;\n })) ??\n (await this.getFromLockFile(handleOrId).catch((e) => {\n if (e instanceof PromptFileNotFoundError) return null;\n throw e;\n })) ??\n (await this.getFromLocalFiles(handleOrId).catch((e) => {\n if (e instanceof PromptFileNotFoundError) return null;\n throw e;\n }))\n );\n\n return localPromptConfig ? this.convertToPromptData({\n ...localPromptConfig,\n handle: handleOrId,\n }) : null;\n } catch (error) {\n this.logger.warn(`Failed to get prompt \"${handleOrId}\": ${error instanceof Error ? error.message : String(error)}`);\n return null;\n }\n }\n\n\n /**\n * Searches for prompt using explicit file mapping in prompts.json.\n * Looks for dependencies with a 'file' property pointing to a specific path.\n */\n private async getFromConfig(dependency: PromptDependency): Promise<LocalPromptConfig | null> {\n if (typeof dependency === 'string' && dependency.startsWith('file:')) {\n return this.fileManager.loadLocalPrompt(dependency.slice(5));\n }\n\n return null;\n }\n\n /**\n * Searches for prompt using materialized path from lock file.\n * Lock file contains resolved paths for prompts that have been synced/materialized.\n */\n private async getFromLockFile(handleOrId: string): Promise<LocalPromptConfig | null> {\n const lock = this.fileManager.loadPromptsLock();\n const lockEntry = lock.prompts[handleOrId];\n\n if (lockEntry?.materialized) {\n return this.fileManager.loadLocalPrompt(lockEntry.materialized);\n }\n\n return null;\n }\n\n /**\n * Searches for prompt by scanning all .prompt.yaml files in prompts directory.\n * Extracts prompt name from file path and matches against the requested handle.\n * This is the fallback method when explicit mappings don't exist.\n */\n private async getFromLocalFiles(handleOrId: string): Promise<LocalPromptConfig | null> {\n const localFiles = this.fileManager.getLocalPromptFiles();\n\n for (const filePath of localFiles) {\n const promptName = this.fileManager.promptNameFromPath(filePath);\n if (promptName === handleOrId) {\n return this.fileManager.loadLocalPrompt(filePath);\n }\n }\n\n return null;\n }\n\n /**\n * Get dependency from config\n */\n private async getDependencyFromConfig(handleOrId: string): Promise<PromptDependency | null> {\n const config = this.fileManager.loadPromptsConfig();\n const dependency = config.prompts[handleOrId];\n\n return dependency ?? null;\n }\n\n /**\n * Converts LocalPromptConfig to PromptData format\n */\n private convertToPromptData(config: LocalPromptConfig & { handle: string; }): PromptData {\n const { modelParameters, ...rest } = config;\n return {\n maxTokens: modelParameters?.max_tokens,\n temperature: modelParameters?.temperature,\n ...rest,\n };\n }\n}\n","import { PromptsApiService, type AssignTagResult } from \"./prompts-api.service\";\nimport { Prompt } from \"./prompt\";\nimport type { CreatePromptBody, UpdatePromptBody, PromptData, TagDefinition, CreatedTag } from \"./types\";\nimport { FetchPolicy } from \"./types\";\nimport { type InternalConfig } from \"@/client-sdk/types\";\nimport { LocalPromptsService } from \"./local-prompts.service\";\nimport { PromptsError } from \"./errors\";\n\n/**\n * Options for fetching a prompt.\n */\nexport interface GetPromptOptions {\n /** Specific version to fetch */\n version?: string;\n /** Tag to fetch (e.g., \"production\", \"staging\", or a custom tag) */\n tag?: string;\n /** Fetch policy to use */\n fetchPolicy?: FetchPolicy;\n /** Cache TTL in minutes (only used with CACHE_TTL policy) */\n cacheTtlMinutes?: number;\n}\n\ninterface CacheEntry {\n data: PromptData;\n timestamp: number;\n}\n\ninterface PromptsFacadeDependencies {\n promptsApiService: PromptsApiService;\n localPromptsService: LocalPromptsService;\n}\n\n/**\n * Facade for prompt operations in the LangWatch SDK.\n * Provides a simplified interface for common prompt management tasks.\n */\nexport class PromptsFacade implements Pick<PromptsApiService, \"sync\" | \"delete\">{\n private readonly promptsApiService: PromptsApiService;\n private readonly localPromptsService: LocalPromptsService;\n private readonly cache = new Map<string, CacheEntry>();\n readonly tags: {\n assign(id: string, params: { tag: string; versionId: string }): Promise<AssignTagResult>;\n list(): Promise<TagDefinition[]>;\n create(params: { name: string }): Promise<CreatedTag>;\n delete(tagName: string): Promise<void>;\n rename(oldName: string, newName: string): Promise<void>;\n };\n\n constructor(config: InternalConfig & PromptsFacadeDependencies) {\n this.promptsApiService = config.promptsApiService ?? new PromptsApiService(config);\n this.localPromptsService = config.localPromptsService ?? new LocalPromptsService();\n this.tags = {\n assign: (id, { tag, versionId }) =>\n this.promptsApiService.assignTag({ id, tag, versionId }),\n list: () => this.promptsApiService.listTags(),\n create: ({ name }) => this.promptsApiService.createTag({ name }),\n delete: (tagName) => this.promptsApiService.deleteTag(tagName),\n rename: (oldName, newName) =>\n this.promptsApiService.renameTag({ tag: oldName, name: newName }),\n };\n }\n\n /**\n * Creates a new prompt.\n * @param data The prompt creation payload.\n * @returns The created Prompt instance.\n * @throws {PromptsError} If the API call fails.\n */\n async create(data: CreatePromptBody): Promise<Prompt> {\n const serverPrompt = await this.promptsApiService.create(data);\n return new Prompt(serverPrompt);\n }\n\n /**\n * Retrieves a prompt by handle or ID.\n *\n * Supports shorthand `handle:tag` syntax — e.g. `get(\"pizza-prompt:production\")`.\n * Shorthand is parsed server-side; the SDK passes the string through as-is.\n *\n * @param handleOrId The prompt's handle, unique identifier, or `handle:tag` shorthand.\n * @param options Optional parameters for the request.\n * @returns The Prompt instance.\n * @throws {PromptsError} If the prompt is not found or the API call fails.\n */\n async get(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n const fetchPolicy = options?.fetchPolicy ?? FetchPolicy.MATERIALIZED_FIRST;\n\n switch (fetchPolicy) {\n case FetchPolicy.MATERIALIZED_ONLY:\n return this.getMaterializedOnly(handleOrId);\n\n case FetchPolicy.ALWAYS_FETCH:\n return this.getAlwaysFetch(handleOrId, options);\n\n case FetchPolicy.CACHE_TTL:\n return this.getCacheTtl(handleOrId, options);\n\n case FetchPolicy.MATERIALIZED_FIRST:\n default:\n return this.getMaterializedFirst(handleOrId, options);\n }\n }\n\n private async getMaterializedFirst(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n const serverPrompt = await this.promptsApiService.get(handleOrId, options);\n return new Prompt(serverPrompt);\n }\n\n private async getAlwaysFetch(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n try {\n const serverPrompt = await this.promptsApiService.get(handleOrId, options);\n return new Prompt(serverPrompt);\n } catch {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n throw new PromptsError(`Prompt \"${handleOrId}\" not found locally or on server`);\n }\n }\n\n private async getMaterializedOnly(handleOrId: string): Promise<Prompt> {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n throw new PromptsError(`Prompt \"${handleOrId}\" not found in materialized files`);\n }\n\n private buildCacheKey(handleOrId: string, options?: GetPromptOptions): string {\n const tagSegment = options?.tag != null ? `::tag:${options.tag}` : '';\n return `${handleOrId}::version:${options?.version ?? ''}${tagSegment}`;\n }\n\n private async getCacheTtl(\n handleOrId: string,\n options?: GetPromptOptions,\n ): Promise<Prompt> {\n const cacheKey = this.buildCacheKey(handleOrId, options);\n const ttlMs = (options?.cacheTtlMinutes ?? 5) * 60 * 1000;\n const cached = this.cache.get(cacheKey);\n const now = Date.now();\n\n if (cached && now - cached.timestamp < ttlMs) {\n return new Prompt(cached.data);\n }\n\n try {\n const serverPrompt = await this.promptsApiService.get(handleOrId, options);\n this.cache.set(cacheKey, { data: serverPrompt, timestamp: now });\n return new Prompt(serverPrompt);\n } catch {\n const localPrompt = await this.localPromptsService.get(handleOrId);\n if (localPrompt) {\n return new Prompt(localPrompt);\n }\n throw new PromptsError(`Prompt \"${handleOrId}\" not found locally or on server`);\n }\n }\n\n /**\n * Retrieves all prompts.\n * @returns Array of Prompt instances.\n * @throws {PromptsError} If the API call fails.\n */\n async getAll(): Promise<Prompt[]> {\n const serverPrompts = await this.promptsApiService.getAll();\n return serverPrompts.map((prompt) => new Prompt(prompt));\n }\n\n /**\n * Updates an existing prompt.\n * @param handleOrId The prompt's handle or unique identifier.\n * @param newData The update payload.\n * @returns The updated Prompt instance.\n * @throws {PromptsError} If the API call fails.\n */\n async update(handleOrId: string, newData: UpdatePromptBody): Promise<Prompt> {\n const serverPrompt = await this.promptsApiService.update(handleOrId, newData);\n return new Prompt(serverPrompt);\n }\n\n get delete() {\n return this.promptsApiService.delete.bind(this.promptsApiService);\n }\n\n /**\n * Delegated method to the prompts API service.\n */\n get sync() {\n return this.promptsApiService.sync.bind(this.promptsApiService);\n }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkCKYNUZLAjs = require('./chunk-CKYNUZLA.js');
|
|
4
4
|
|
|
5
5
|
// src/client-sdk/services/agents/agents-api.service.ts
|
|
6
6
|
var AgentsApiError = class extends Error {
|
|
@@ -14,7 +14,7 @@ var AgentsApiError = class extends Error {
|
|
|
14
14
|
var AgentsApiService = class {
|
|
15
15
|
constructor(config) {
|
|
16
16
|
var _a;
|
|
17
|
-
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a :
|
|
17
|
+
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a : _chunkCKYNUZLAjs.createLangWatchApiClient.call(void 0, );
|
|
18
18
|
}
|
|
19
19
|
handleApiError(operation, error) {
|
|
20
20
|
var _a;
|
|
@@ -67,4 +67,4 @@ var AgentsApiService = class {
|
|
|
67
67
|
|
|
68
68
|
|
|
69
69
|
exports.AgentsApiError = AgentsApiError; exports.AgentsApiService = AgentsApiService;
|
|
70
|
-
//# sourceMappingURL=chunk-
|
|
70
|
+
//# sourceMappingURL=chunk-FXCSXFDY.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-FXCSXFDY.js","../src/client-sdk/services/agents/agents-api.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;ACsBO,IAAM,eAAA,EAAN,MAAA,QAA6B,MAAM;AAAA,EACxC,WAAA,CACE,OAAA,EACgB,SAAA,EACA,aAAA,EAChB;AACA,IAAA,KAAA,CAAM,OAAO,CAAA;AAHG,IAAA,IAAA,CAAA,UAAA,EAAA,SAAA;AACA,IAAA,IAAA,CAAA,cAAA,EAAA,aAAA;AAGhB,IAAA,IAAA,CAAK,KAAA,EAAO,gBAAA;AAAA,EACd;AACF,CAAA;AAEO,IAAM,iBAAA,EAAN,MAAuB;AAAA,EAG5B,WAAA,CAAY,MAAA,EAAqD;AAxCnE,IAAA,IAAA,EAAA;AAyCI,IAAA,IAAA,CAAK,UAAA,EAAA,CAAY,GAAA,EAAA,OAAA,GAAA,KAAA,EAAA,KAAA,EAAA,EAAA,MAAA,CAAQ,kBAAA,EAAA,GAAR,KAAA,EAAA,GAAA,EAA8B,uDAAA,CAAyB;AAAA,EAC1E;AAAA,EAEQ,cAAA,CAAe,SAAA,EAAmB,KAAA,EAAuB;AA5CnE,IAAA,IAAA,EAAA;AA6CI,IAAA,MAAM,aAAA,EACJ,OAAO,MAAA,IAAU,SAAA,EACb,MAAA,EACA,MAAA,GAAS,KAAA,GACP,OAAO,MAAA,IAAU,SAAA,GACjB,QAAA,GAAW,MAAA,GACX,KAAA,CAAM,MAAA,GAAS,KAAA,EACf,OAAO,KAAA,CAAM,MAAA,IAAU,SAAA,EACrB,KAAA,CAAM,MAAA,EAAA,CACL,GAAA,EAAA,KAAA,CAAM,KAAA,CAA+B,OAAA,EAAA,GAArC,KAAA,EAAA,GAAA,EACD,IAAA,CAAK,SAAA,CAAU,KAAA,CAAM,KAAK,EAAA,EAC5B,MAAA,WAAiB,MAAA,EACf,KAAA,CAAM,QAAA,EACN,wBAAA;AAEV,IAAA,MAAM,IAAI,cAAA;AAAA,MACR,CAAA,UAAA,EAAa,SAAS,CAAA,EAAA,EAAK,YAAY,CAAA,CAAA;AACvC,MAAA;AACA,MAAA;AACF,IAAA;AACF,EAAA;AAEmF,EAAA;AAC9C,IAAA;AACT,MAAA;AACzB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAE8C,EAAA;AACT,IAAA;AACV,MAAA;AACxB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAO2B,EAAA;AACU,IAAA;AAC3B,MAAA;AACP,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAM2B,EAAA;AACU,IAAA;AACV,MAAA;AACjB,MAAA;AACP,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAEgE,EAAA;AAC3B,IAAA;AACV,MAAA;AACxB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AACF;ADpD8C;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-FXCSXFDY.js","sourcesContent":[null,"import {\n createLangWatchApiClient,\n type LangwatchApiClient,\n} from \"@/internal/api/client\";\nimport { type InternalConfig } from \"@/client-sdk/types\";\n\nexport interface AgentResponse {\n id: string;\n name: string;\n type: string;\n config: Record<string, unknown> | null;\n createdAt: string;\n updatedAt: string;\n platformUrl?: string;\n}\n\nexport interface AgentListResponse {\n data: AgentResponse[];\n pagination: {\n page: number;\n limit: number;\n total: number;\n totalPages: number;\n };\n}\n\nexport class AgentsApiError extends Error {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"AgentsApiError\";\n }\n}\n\nexport class AgentsApiService {\n private readonly apiClient: LangwatchApiClient;\n\n constructor(config?: Pick<InternalConfig, \"langwatchApiClient\">) {\n this.apiClient = config?.langwatchApiClient ?? createLangWatchApiClient();\n }\n\n private handleApiError(operation: string, error: unknown): never {\n const errorMessage =\n typeof error === \"string\"\n ? error\n : error != null &&\n typeof error === \"object\" &&\n \"error\" in error &&\n error.error != null\n ? typeof error.error === \"string\"\n ? error.error\n : (error.error as { message?: string }).message ??\n JSON.stringify(error.error)\n : error instanceof Error\n ? error.message\n : \"Unknown error occurred\";\n\n throw new AgentsApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n async list(params?: { page?: number; limit?: number }): Promise<AgentListResponse> {\n const { data, error } = await this.apiClient.GET(\"/api/agents\", {\n params: { query: params },\n });\n if (error) this.handleApiError(\"list agents\", error);\n return data as unknown as AgentListResponse;\n }\n\n async get(id: string): Promise<AgentResponse> {\n const { data, error } = await this.apiClient.GET(\"/api/agents/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`get agent \"${id}\"`, error);\n return data as unknown as AgentResponse;\n }\n\n async create(params: {\n name: string;\n type: string;\n config: Record<string, unknown>;\n workflowId?: string;\n }): Promise<AgentResponse> {\n const { data, error } = await this.apiClient.POST(\"/api/agents\", {\n body: params as never,\n });\n if (error) this.handleApiError(\"create agent\", error);\n return data as unknown as AgentResponse;\n }\n\n async update(id: string, params: {\n name?: string;\n type?: string;\n config?: Record<string, unknown>;\n }): Promise<AgentResponse> {\n const { data, error } = await this.apiClient.PATCH(\"/api/agents/{id}\", {\n params: { path: { id } },\n body: params as never,\n });\n if (error) this.handleApiError(`update agent \"${id}\"`, error);\n return data as unknown as AgentResponse;\n }\n\n async delete(id: string): Promise<{ id: string; name: string }> {\n const { data, error } = await this.apiClient.DELETE(\"/api/agents/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`delete agent \"${id}\"`, error);\n return data as unknown as { id: string; name: string };\n }\n}\n"]}
|
|
@@ -3,14 +3,14 @@ import {
|
|
|
3
3
|
} from "./chunk-FG3JQBJB.mjs";
|
|
4
4
|
import {
|
|
5
5
|
createLangWatchApiClient
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-SAR52TH6.mjs";
|
|
7
7
|
import {
|
|
8
8
|
getLangWatchTracer
|
|
9
9
|
} from "./chunk-43STSE3B.mjs";
|
|
10
10
|
import {
|
|
11
11
|
LANGWATCH_SDK_NAME_CLIENT,
|
|
12
12
|
LANGWATCH_SDK_VERSION
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-LUBBPBV3.mjs";
|
|
14
14
|
import {
|
|
15
15
|
shouldCaptureInput,
|
|
16
16
|
shouldCaptureOutput
|
|
@@ -847,4 +847,4 @@ export {
|
|
|
847
847
|
LocalPromptsService,
|
|
848
848
|
PromptsFacade
|
|
849
849
|
};
|
|
850
|
-
//# sourceMappingURL=chunk-
|
|
850
|
+
//# sourceMappingURL=chunk-GSZ4QKFH.mjs.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkCKYNUZLAjs = require('./chunk-CKYNUZLA.js');
|
|
4
4
|
|
|
5
5
|
// src/client-sdk/services/suites/suites-api.service.ts
|
|
6
6
|
var SuitesApiError = class extends Error {
|
|
@@ -14,7 +14,7 @@ var SuitesApiError = class extends Error {
|
|
|
14
14
|
var SuitesApiService = class {
|
|
15
15
|
constructor(config) {
|
|
16
16
|
var _a;
|
|
17
|
-
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a :
|
|
17
|
+
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a : _chunkCKYNUZLAjs.createLangWatchApiClient.call(void 0, );
|
|
18
18
|
}
|
|
19
19
|
handleApiError(operation, error) {
|
|
20
20
|
var _a;
|
|
@@ -82,4 +82,4 @@ var SuitesApiService = class {
|
|
|
82
82
|
|
|
83
83
|
|
|
84
84
|
exports.SuitesApiError = SuitesApiError; exports.SuitesApiService = SuitesApiService;
|
|
85
|
-
//# sourceMappingURL=chunk-
|
|
85
|
+
//# sourceMappingURL=chunk-GXRQEJ6D.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-GXRQEJ6D.js","../src/client-sdk/services/suites/suites-api.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;AC0BO,IAAM,eAAA,EAAN,MAAA,QAA6B,MAAM;AAAA,EACxC,WAAA,CACE,OAAA,EACgB,SAAA,EACA,aAAA,EAChB;AACA,IAAA,KAAA,CAAM,OAAO,CAAA;AAHG,IAAA,IAAA,CAAA,UAAA,EAAA,SAAA;AACA,IAAA,IAAA,CAAA,cAAA,EAAA,aAAA;AAGhB,IAAA,IAAA,CAAK,KAAA,EAAO,gBAAA;AAAA,EACd;AACF,CAAA;AAEO,IAAM,iBAAA,EAAN,MAAuB;AAAA,EAG5B,WAAA,CAAY,MAAA,EAAqD;AA5CnE,IAAA,IAAA,EAAA;AA6CI,IAAA,IAAA,CAAK,UAAA,EAAA,CAAY,GAAA,EAAA,OAAA,GAAA,KAAA,EAAA,KAAA,EAAA,EAAA,MAAA,CAAQ,kBAAA,EAAA,GAAR,KAAA,EAAA,GAAA,EAA8B,uDAAA,CAAyB;AAAA,EAC1E;AAAA,EAEQ,cAAA,CAAe,SAAA,EAAmB,KAAA,EAAuB;AAhDnE,IAAA,IAAA,EAAA;AAiDI,IAAA,MAAM,aAAA,EACJ,OAAO,MAAA,IAAU,SAAA,EACb,MAAA,EACA,MAAA,GAAS,KAAA,GACP,OAAO,MAAA,IAAU,SAAA,GACjB,QAAA,GAAW,MAAA,GACX,KAAA,CAAM,MAAA,GAAS,KAAA,EACf,OAAO,KAAA,CAAM,MAAA,IAAU,SAAA,EACrB,KAAA,CAAM,MAAA,EAAA,CACL,GAAA,EAAA,KAAA,CAAM,KAAA,CAA+B,OAAA,EAAA,GAArC,KAAA,EAAA,GAAA,EACD,IAAA,CAAK,SAAA,CAAU,KAAA,CAAM,KAAK,EAAA,EAC5B,MAAA,WAAiB,MAAA,EACf,KAAA,CAAM,QAAA,EACN,wBAAA;AAEV,IAAA,MAAM,IAAI,cAAA;AAAA,MACR,CAAA,UAAA,EAAa,SAAS,CAAA,EAAA,EAAK,YAAY,CAAA,CAAA;AACvC,MAAA;AACA,MAAA;AACF,IAAA;AACF,EAAA;AAEyC,EAAA;AACJ,IAAA;AACJ,IAAA;AACxB,IAAA;AACT,EAAA;AAE8C,EAAA;AACT,IAAA;AACV,MAAA;AACxB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAE8D,EAAA;AACzB,IAAA;AAC3B,MAAA;AACP,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAE0E,EAAA;AACrC,IAAA;AACV,MAAA;AACjB,MAAA;AACP,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAEoD,EAAA;AACf,IAAA;AACV,MAAA;AACxB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAEwE,EAAA;AACnC,IAAA;AACV,MAAA;AACjB,MAAA;AACY,QAAA;AAClB,MAAA;AACD,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAEqE,EAAA;AAChC,IAAA;AACV,MAAA;AACxB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AACF;ADjD8C;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-GXRQEJ6D.js","sourcesContent":[null,"import type { paths } from \"@/internal/generated/openapi/api-client\";\nimport {\n createLangWatchApiClient,\n type LangwatchApiClient,\n} from \"@/internal/api/client\";\nimport type { InternalConfig } from \"@/client-sdk/types\";\n\nexport type SuiteResponse = NonNullable<\n paths[\"/api/suites\"][\"get\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>[number] & {\n /** URL to view this suite on the LangWatch platform */\n platformUrl?: string;\n};\n\nexport type CreateSuiteBody = NonNullable<\n paths[\"/api/suites\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type UpdateSuiteBody = NonNullable<\n paths[\"/api/suites/{id}\"][\"patch\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type SuiteRunResult =\n paths[\"/api/suites/{id}/run\"][\"post\"][\"responses\"][\"200\"][\"content\"][\"application/json\"];\n\nexport interface SuiteTarget {\n type: \"prompt\" | \"http\" | \"code\" | \"workflow\";\n referenceId: string;\n}\n\nexport class SuitesApiError extends Error {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"SuitesApiError\";\n }\n}\n\nexport class SuitesApiService {\n private readonly apiClient: LangwatchApiClient;\n\n constructor(config?: Pick<InternalConfig, \"langwatchApiClient\">) {\n this.apiClient = config?.langwatchApiClient ?? createLangWatchApiClient();\n }\n\n private handleApiError(operation: string, error: unknown): never {\n const errorMessage =\n typeof error === \"string\"\n ? error\n : error != null &&\n typeof error === \"object\" &&\n \"error\" in error &&\n error.error != null\n ? typeof error.error === \"string\"\n ? error.error\n : (error.error as { message?: string }).message ??\n JSON.stringify(error.error)\n : error instanceof Error\n ? error.message\n : \"Unknown error occurred\";\n\n throw new SuitesApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n async getAll(): Promise<SuiteResponse[]> {\n const { data, error } = await this.apiClient.GET(\"/api/suites\");\n if (error) this.handleApiError(\"list suites\", error);\n return data;\n }\n\n async get(id: string): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.GET(\"/api/suites/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`get suite \"${id}\"`, error);\n return data;\n }\n\n async create(params: CreateSuiteBody): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.POST(\"/api/suites\", {\n body: params,\n });\n if (error) this.handleApiError(\"create suite\", error);\n return data;\n }\n\n async update(id: string, params: UpdateSuiteBody): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.PATCH(\"/api/suites/{id}\", {\n params: { path: { id } },\n body: params,\n });\n if (error) this.handleApiError(`update suite \"${id}\"`, error);\n return data;\n }\n\n async duplicate(id: string): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.POST(\"/api/suites/{id}/duplicate\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`duplicate suite \"${id}\"`, error);\n return data;\n }\n\n async run(id: string, idempotencyKey?: string): Promise<SuiteRunResult> {\n const { data, error } = await this.apiClient.POST(\"/api/suites/{id}/run\", {\n params: { path: { id } },\n body: {\n idempotencyKey: idempotencyKey ?? `cli-${Date.now()}-${Math.random().toString(36).slice(2)}`,\n },\n });\n if (error) this.handleApiError(`run suite \"${id}\"`, error);\n return data;\n }\n\n async delete(id: string): Promise<{ id: string; archived: boolean }> {\n const { data, error } = await this.apiClient.DELETE(\"/api/suites/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`delete suite \"${id}\"`, error);\n return data as unknown as { id: string; archived: boolean };\n }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
createLangWatchApiClient
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-SAR52TH6.mjs";
|
|
4
4
|
|
|
5
5
|
// src/client-sdk/services/agents/agents-api.service.ts
|
|
6
6
|
var AgentsApiError = class extends Error {
|
|
@@ -67,4 +67,4 @@ export {
|
|
|
67
67
|
AgentsApiError,
|
|
68
68
|
AgentsApiService
|
|
69
69
|
};
|
|
70
|
-
//# sourceMappingURL=chunk-
|
|
70
|
+
//# sourceMappingURL=chunk-HJARRXXA.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/client-sdk/services/agents/agents-api.service.ts"],"sourcesContent":["import {\n createLangWatchApiClient,\n type LangwatchApiClient,\n} from \"@/internal/api/client\";\nimport { type InternalConfig } from \"@/client-sdk/types\";\n\nexport interface AgentResponse {\n id: string;\n name: string;\n type: string;\n config: Record<string, unknown> | null;\n createdAt: string;\n updatedAt: string;\n platformUrl?: string;\n}\n\nexport interface AgentListResponse {\n data: AgentResponse[];\n pagination: {\n page: number;\n limit: number;\n total: number;\n totalPages: number;\n };\n}\n\nexport class AgentsApiError extends Error {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"AgentsApiError\";\n }\n}\n\nexport class AgentsApiService {\n private readonly apiClient: LangwatchApiClient;\n\n constructor(config?: Pick<InternalConfig, \"langwatchApiClient\">) {\n this.apiClient = config?.langwatchApiClient ?? createLangWatchApiClient();\n }\n\n private handleApiError(operation: string, error: unknown): never {\n const errorMessage =\n typeof error === \"string\"\n ? error\n : error != null &&\n typeof error === \"object\" &&\n \"error\" in error &&\n error.error != null\n ? typeof error.error === \"string\"\n ? error.error\n : (error.error as { message?: string }).message ??\n JSON.stringify(error.error)\n : error instanceof Error\n ? error.message\n : \"Unknown error occurred\";\n\n throw new AgentsApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n async list(params?: { page?: number; limit?: number }): Promise<AgentListResponse> {\n const { data, error } = await this.apiClient.GET(\"/api/agents\", {\n params: { query: params },\n });\n if (error) this.handleApiError(\"list agents\", error);\n return data as unknown as AgentListResponse;\n }\n\n async get(id: string): Promise<AgentResponse> {\n const { data, error } = await this.apiClient.GET(\"/api/agents/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`get agent \"${id}\"`, error);\n return data as unknown as AgentResponse;\n }\n\n async create(params: {\n name: string;\n type: string;\n config: Record<string, unknown>;\n workflowId?: string;\n }): Promise<AgentResponse> {\n const { data, error } = await this.apiClient.POST(\"/api/agents\", {\n body: params as never,\n });\n if (error) this.handleApiError(\"create agent\", error);\n return data as unknown as AgentResponse;\n }\n\n async update(id: string, params: {\n name?: string;\n type?: string;\n config?: Record<string, unknown>;\n }): Promise<AgentResponse> {\n const { data, error } = await this.apiClient.PATCH(\"/api/agents/{id}\", {\n params: { path: { id } },\n body: params as never,\n });\n if (error) this.handleApiError(`update agent \"${id}\"`, error);\n return data as unknown as AgentResponse;\n }\n\n async delete(id: string): Promise<{ id: string; name: string }> {\n const { data, error } = await this.apiClient.DELETE(\"/api/agents/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`delete agent \"${id}\"`, error);\n return data as unknown as { id: string; name: string };\n }\n}\n"],"mappings":";;;;;AA0BO,IAAM,iBAAN,cAA6B,MAAM;AAAA,EACxC,YACE,SACgB,WACA,eAChB;AACA,UAAM,OAAO;AAHG;AACA;AAGhB,SAAK,OAAO;AAAA,EACd;AACF;AAEO,IAAM,mBAAN,MAAuB;AAAA,EAG5B,YAAY,QAAqD;AAxCnE;AAyCI,SAAK,aAAY,sCAAQ,uBAAR,YAA8B,yBAAyB;AAAA,EAC1E;AAAA,EAEQ,eAAe,WAAmB,OAAuB;AA5CnE;AA6CI,UAAM,eACJ,OAAO,UAAU,WACb,QACA,SAAS,QACP,OAAO,UAAU,YACjB,WAAW,SACX,MAAM,SAAS,OACf,OAAO,MAAM,UAAU,WACrB,MAAM,SACL,WAAM,MAA+B,YAArC,YACD,KAAK,UAAU,MAAM,KAAK,IAC5B,iBAAiB,QACf,MAAM,UACN;AAEV,UAAM,IAAI;AAAA,MACR,aAAa,SAAS,KAAK,YAAY;AAAA,MACvC;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAAA,EAEA,MAAM,KAAK,QAAwE;AACjF,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,IAAI,eAAe;AAAA,MAC9D,QAAQ,EAAE,OAAO,OAAO;AAAA,IAC1B,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,eAAe,KAAK;AACnD,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,IAAI,IAAoC;AAC5C,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,IAAI,oBAAoB;AAAA,MACnE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE;AAAA,IACzB,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,cAAc,EAAE,KAAK,KAAK;AACzD,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO,QAKc;AACzB,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,KAAK,eAAe;AAAA,MAC/D,MAAM;AAAA,IACR,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,gBAAgB,KAAK;AACpD,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO,IAAY,QAIE;AACzB,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,MAAM,oBAAoB;AAAA,MACrE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE;AAAA,MACvB,MAAM;AAAA,IACR,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,iBAAiB,EAAE,KAAK,KAAK;AAC5D,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO,IAAmD;AAC9D,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,OAAO,oBAAoB;AAAA,MACtE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE;AAAA,IACzB,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,iBAAiB,EAAE,KAAK,KAAK;AAC5D,WAAO;AAAA,EACT;AACF;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
createLangWatchApiClient
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-SAR52TH6.mjs";
|
|
4
4
|
|
|
5
5
|
// src/client-sdk/services/suites/suites-api.service.ts
|
|
6
6
|
var SuitesApiError = class extends Error {
|
|
@@ -82,4 +82,4 @@ export {
|
|
|
82
82
|
SuitesApiError,
|
|
83
83
|
SuitesApiService
|
|
84
84
|
};
|
|
85
|
-
//# sourceMappingURL=chunk-
|
|
85
|
+
//# sourceMappingURL=chunk-IFCABR3D.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/client-sdk/services/suites/suites-api.service.ts"],"sourcesContent":["import type { paths } from \"@/internal/generated/openapi/api-client\";\nimport {\n createLangWatchApiClient,\n type LangwatchApiClient,\n} from \"@/internal/api/client\";\nimport type { InternalConfig } from \"@/client-sdk/types\";\n\nexport type SuiteResponse = NonNullable<\n paths[\"/api/suites\"][\"get\"][\"responses\"][\"200\"][\"content\"][\"application/json\"]\n>[number] & {\n /** URL to view this suite on the LangWatch platform */\n platformUrl?: string;\n};\n\nexport type CreateSuiteBody = NonNullable<\n paths[\"/api/suites\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type UpdateSuiteBody = NonNullable<\n paths[\"/api/suites/{id}\"][\"patch\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type SuiteRunResult =\n paths[\"/api/suites/{id}/run\"][\"post\"][\"responses\"][\"200\"][\"content\"][\"application/json\"];\n\nexport interface SuiteTarget {\n type: \"prompt\" | \"http\" | \"code\" | \"workflow\";\n referenceId: string;\n}\n\nexport class SuitesApiError extends Error {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"SuitesApiError\";\n }\n}\n\nexport class SuitesApiService {\n private readonly apiClient: LangwatchApiClient;\n\n constructor(config?: Pick<InternalConfig, \"langwatchApiClient\">) {\n this.apiClient = config?.langwatchApiClient ?? createLangWatchApiClient();\n }\n\n private handleApiError(operation: string, error: unknown): never {\n const errorMessage =\n typeof error === \"string\"\n ? error\n : error != null &&\n typeof error === \"object\" &&\n \"error\" in error &&\n error.error != null\n ? typeof error.error === \"string\"\n ? error.error\n : (error.error as { message?: string }).message ??\n JSON.stringify(error.error)\n : error instanceof Error\n ? error.message\n : \"Unknown error occurred\";\n\n throw new SuitesApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n async getAll(): Promise<SuiteResponse[]> {\n const { data, error } = await this.apiClient.GET(\"/api/suites\");\n if (error) this.handleApiError(\"list suites\", error);\n return data;\n }\n\n async get(id: string): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.GET(\"/api/suites/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`get suite \"${id}\"`, error);\n return data;\n }\n\n async create(params: CreateSuiteBody): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.POST(\"/api/suites\", {\n body: params,\n });\n if (error) this.handleApiError(\"create suite\", error);\n return data;\n }\n\n async update(id: string, params: UpdateSuiteBody): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.PATCH(\"/api/suites/{id}\", {\n params: { path: { id } },\n body: params,\n });\n if (error) this.handleApiError(`update suite \"${id}\"`, error);\n return data;\n }\n\n async duplicate(id: string): Promise<SuiteResponse> {\n const { data, error } = await this.apiClient.POST(\"/api/suites/{id}/duplicate\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`duplicate suite \"${id}\"`, error);\n return data;\n }\n\n async run(id: string, idempotencyKey?: string): Promise<SuiteRunResult> {\n const { data, error } = await this.apiClient.POST(\"/api/suites/{id}/run\", {\n params: { path: { id } },\n body: {\n idempotencyKey: idempotencyKey ?? `cli-${Date.now()}-${Math.random().toString(36).slice(2)}`,\n },\n });\n if (error) this.handleApiError(`run suite \"${id}\"`, error);\n return data;\n }\n\n async delete(id: string): Promise<{ id: string; archived: boolean }> {\n const { data, error } = await this.apiClient.DELETE(\"/api/suites/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`delete suite \"${id}\"`, error);\n return data as unknown as { id: string; archived: boolean };\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkCKYNUZLAjs = require('./chunk-CKYNUZLA.js');
|
|
4
4
|
|
|
5
5
|
// src/client-sdk/services/dashboards/dashboards-api.service.ts
|
|
6
6
|
var DashboardsApiError = class extends Error {
|
|
@@ -14,7 +14,7 @@ var DashboardsApiError = class extends Error {
|
|
|
14
14
|
var DashboardsApiService = class {
|
|
15
15
|
constructor(config) {
|
|
16
16
|
var _a;
|
|
17
|
-
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a :
|
|
17
|
+
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a : _chunkCKYNUZLAjs.createLangWatchApiClient.call(void 0, );
|
|
18
18
|
}
|
|
19
19
|
handleApiError(operation, error) {
|
|
20
20
|
var _a;
|
|
@@ -65,4 +65,4 @@ var DashboardsApiService = class {
|
|
|
65
65
|
|
|
66
66
|
|
|
67
67
|
exports.DashboardsApiError = DashboardsApiError; exports.DashboardsApiService = DashboardsApiService;
|
|
68
|
-
//# sourceMappingURL=chunk-
|
|
68
|
+
//# sourceMappingURL=chunk-JIIQDBF2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-JIIQDBF2.js","../src/client-sdk/services/dashboards/dashboards-api.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;ACsBO,IAAM,mBAAA,EAAN,MAAA,QAAiC,MAAM;AAAA,EAC5C,WAAA,CACE,OAAA,EACgB,SAAA,EACA,aAAA,EAChB;AACA,IAAA,KAAA,CAAM,OAAO,CAAA;AAHG,IAAA,IAAA,CAAA,UAAA,EAAA,SAAA;AACA,IAAA,IAAA,CAAA,cAAA,EAAA,aAAA;AAGhB,IAAA,IAAA,CAAK,KAAA,EAAO,oBAAA;AAAA,EACd;AACF,CAAA;AAEO,IAAM,qBAAA,EAAN,MAA2B;AAAA,EAGhC,WAAA,CAAY,MAAA,EAAqD;AAxCnE,IAAA,IAAA,EAAA;AAyCI,IAAA,IAAA,CAAK,UAAA,EAAA,CAAY,GAAA,EAAA,OAAA,GAAA,KAAA,EAAA,KAAA,EAAA,EAAA,MAAA,CAAQ,kBAAA,EAAA,GAAR,KAAA,EAAA,GAAA,EAA8B,uDAAA,CAAyB;AAAA,EAC1E;AAAA,EAEQ,cAAA,CAAe,SAAA,EAAmB,KAAA,EAAuB;AA5CnE,IAAA,IAAA,EAAA;AA6CI,IAAA,MAAM,aAAA,EACJ,OAAO,MAAA,IAAU,SAAA,EACb,MAAA,EACA,MAAA,GAAS,KAAA,GACP,OAAO,MAAA,IAAU,SAAA,GACjB,QAAA,GAAW,MAAA,GACX,KAAA,CAAM,MAAA,GAAS,KAAA,EACf,OAAO,KAAA,CAAM,MAAA,IAAU,SAAA,EACrB,KAAA,CAAM,MAAA,EAAA,CACL,GAAA,EAAA,KAAA,CAAM,KAAA,CAA+B,OAAA,EAAA,GAArC,KAAA,EAAA,GAAA,EACD,IAAA,CAAK,SAAA,CAAU,KAAA,CAAM,KAAK,EAAA,EAC5B,MAAA,WAAiB,MAAA,EACf,KAAA,CAAM,QAAA,EACN,wBAAA;AAEV,IAAA,MAAM,IAAI,kBAAA;AAAA,MACR,CAAA,UAAA,EAAa,SAAS,CAAA,EAAA,EAAK,YAAY,CAAA,CAAA;AACvC,MAAA;AACA,MAAA;AACF,IAAA;AACF,EAAA;AAEoD,EAAA;AACf,IAAA;AACJ,IAAA;AACxB,IAAA;AACT,EAAA;AAEgD,EAAA;AACX,IAAA;AACV,MAAA;AACxB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAEiE,EAAA;AAC5B,IAAA;AAC3B,MAAA;AACP,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAE6E,EAAA;AACxC,IAAA;AACV,MAAA;AACjB,MAAA;AACP,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AAEgE,EAAA;AAC3B,IAAA;AACV,MAAA;AACxB,IAAA;AAC8B,IAAA;AACxB,IAAA;AACT,EAAA;AACF;AD3C8C;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-JIIQDBF2.js","sourcesContent":[null,"import {\n createLangWatchApiClient,\n type LangwatchApiClient,\n} from \"@/internal/api/client\";\nimport { type InternalConfig } from \"@/client-sdk/types\";\n\nexport interface DashboardSummary {\n id: string;\n name: string;\n order: number;\n graphCount: number;\n createdAt: string;\n updatedAt: string;\n platformUrl?: string;\n}\n\nexport interface DashboardDetail {\n id: string;\n name: string;\n order: number;\n graphs: unknown[];\n createdAt: string;\n updatedAt: string;\n platformUrl?: string;\n}\n\nexport class DashboardsApiError extends Error {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"DashboardsApiError\";\n }\n}\n\nexport class DashboardsApiService {\n private readonly apiClient: LangwatchApiClient;\n\n constructor(config?: Pick<InternalConfig, \"langwatchApiClient\">) {\n this.apiClient = config?.langwatchApiClient ?? createLangWatchApiClient();\n }\n\n private handleApiError(operation: string, error: unknown): never {\n const errorMessage =\n typeof error === \"string\"\n ? error\n : error != null &&\n typeof error === \"object\" &&\n \"error\" in error &&\n error.error != null\n ? typeof error.error === \"string\"\n ? error.error\n : (error.error as { message?: string }).message ??\n JSON.stringify(error.error)\n : error instanceof Error\n ? error.message\n : \"Unknown error occurred\";\n\n throw new DashboardsApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n async list(): Promise<{ data: DashboardSummary[] }> {\n const { data, error } = await this.apiClient.GET(\"/api/dashboards\");\n if (error) this.handleApiError(\"list dashboards\", error);\n return data as unknown as { data: DashboardSummary[] };\n }\n\n async get(id: string): Promise<DashboardDetail> {\n const { data, error } = await this.apiClient.GET(\"/api/dashboards/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`get dashboard \"${id}\"`, error);\n return data as unknown as DashboardDetail;\n }\n\n async create(params: { name: string }): Promise<DashboardDetail> {\n const { data, error } = await this.apiClient.POST(\"/api/dashboards\", {\n body: params,\n });\n if (error) this.handleApiError(\"create dashboard\", error);\n return data as unknown as DashboardDetail;\n }\n\n async rename(id: string, params: { name: string }): Promise<DashboardDetail> {\n const { data, error } = await this.apiClient.PATCH(\"/api/dashboards/{id}\", {\n params: { path: { id } },\n body: params,\n });\n if (error) this.handleApiError(`rename dashboard \"${id}\"`, error);\n return data as unknown as DashboardDetail;\n }\n\n async delete(id: string): Promise<{ id: string; name: string }> {\n const { data, error } = await this.apiClient.DELETE(\"/api/dashboards/{id}\", {\n params: { path: { id } },\n });\n if (error) this.handleApiError(`delete dashboard \"${id}\"`, error);\n return data as unknown as { id: string; name: string };\n }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
createLangWatchApiClient
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-SAR52TH6.mjs";
|
|
4
4
|
|
|
5
5
|
// src/client-sdk/services/scenarios/errors.ts
|
|
6
6
|
var ScenariosApiError = class extends Error {
|
|
@@ -73,4 +73,4 @@ export {
|
|
|
73
73
|
ScenariosApiError,
|
|
74
74
|
ScenariosApiService
|
|
75
75
|
};
|
|
76
|
-
//# sourceMappingURL=chunk-
|
|
76
|
+
//# sourceMappingURL=chunk-LIUQYWHM.mjs.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
// package.json
|
|
2
|
-
var version = "0.
|
|
2
|
+
var version = "0.23.0";
|
|
3
3
|
|
|
4
4
|
// src/internal/runtime.ts
|
|
5
5
|
var _runtime;
|
|
@@ -60,4 +60,4 @@ export {
|
|
|
60
60
|
TRACES_PATH,
|
|
61
61
|
LOGS_PATH
|
|
62
62
|
};
|
|
63
|
-
//# sourceMappingURL=chunk-
|
|
63
|
+
//# sourceMappingURL=chunk-LUBBPBV3.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../package.json","../src/internal/runtime.ts","../src/internal/constants.ts"],"sourcesContent":["{\n \"name\": \"langwatch\",\n \"version\": \"0.22.0\",\n \"description\": \"LangWatch TypeScript/JavaScript SDK. Interact with the full LangWatch API and use the LangWatch OpenTelemetry SDK to instrument your application. For more information, see https://docs.langwatch.ai/integration/typescript/guide\",\n \"main\": \"dist/index.js\",\n \"module\": \"dist/index.mjs\",\n \"types\": \"dist/index.d.ts\",\n \"author\": \"LangWatch\",\n \"license\": \"MIT\",\n \"engines\": {\n \"node\": \">=20\",\n \"pnpm\": \">=8\"\n },\n \"files\": [\n \"dist\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"bin\": {\n \"langwatch\": \"./dist/cli/index.js\"\n },\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.mjs\",\n \"require\": \"./dist/index.js\"\n },\n \"./observability\": {\n \"types\": \"./dist/observability-sdk/index.d.ts\",\n \"require\": \"./dist/observability-sdk/index.js\",\n \"import\": \"./dist/observability-sdk/index.mjs\"\n },\n \"./observability/node\": {\n \"types\": \"./dist/observability-sdk/setup/node/index.d.ts\",\n \"require\": \"./dist/observability-sdk/setup/node/index.js\",\n \"import\": \"./dist/observability-sdk/setup/node/index.mjs\"\n },\n \"./observability/instrumentation/langchain\": {\n \"types\": \"./dist/observability-sdk/instrumentation/langchain/index.d.ts\",\n \"require\": \"./dist/observability-sdk/instrumentation/langchain/index.js\",\n \"import\": \"./dist/observability-sdk/instrumentation/langchain/index.mjs\"\n }\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/langwatch/langwatch.git\",\n \"directory\": \"typescript-sdk\"\n },\n \"scripts\": {\n \"prepare\": \"pnpm run generate:server-types && pnpm run generate:openapi-types\",\n \"cli\": \"node dist/cli/index.js\",\n \"lint\": \"eslint .\",\n \"test\": \"vitest\",\n \"test:unit\": \"vitest run --exclude '**/*.integration.test.ts'\",\n \"test:e2e\": \"dotenv -- vitest run -c ./vitest.e2e.config.mts\",\n \"test:seed\": \"dotenv -e .env.test -- bash -c 'cd ../langwatch && pnpm prisma:seed'\",\n \"prebuild\": \"pnpm run prepare\",\n \"build\": \"tsc --noEmit && tsup\",\n \"tarball\": \"pnpm build && pnpm pack\",\n \"typecheck\": \"tsc --noEmit\",\n \"prepublish\": \"pnpm run build\",\n \"generate:openapi-types\": \"pnpx openapi-typescript ../langwatch/src/app/api/openapiLangWatch.json -o ./src/internal/generated/openapi/api-client.ts\",\n \"generate:server-types\": \"./copy-types.sh\"\n },\n \"devDependencies\": {\n \"@eslint/js\": \"^9.32.0\",\n \"@langchain/core\": \">=0.3.68 <0.4.0\",\n \"@langchain/langgraph\": \">=0.4.0 <1.0.0\",\n \"@langchain/openai\": \">=0.6.0 <1.0.0\",\n \"@opentelemetry/sdk-node\": \"0.205.0\",\n \"@opentelemetry/sdk-trace-node\": \"^2.0.1\",\n \"@opentelemetry/sdk-trace-web\": \">=2.0.1\",\n \"@types/debug\": \"^4.1.12\",\n \"@types/js-yaml\": \"^4.0.9\",\n \"@types/node\": \"^24.1.0\",\n \"@typescript/native-preview\": \"7.0.0-dev.20250804.1\",\n \"@vercel/otel\": \"^1.13.0\",\n \"@vitest/coverage-v8\": \"3.2.4\",\n \"dotenv-cli\": \"^11.0.0\",\n \"esbuild\": \"^0.27.3\",\n \"eslint\": \"^9.32.0\",\n \"fets\": \"^0.8.5\",\n \"fishery\": \"^2.3.1\",\n \"langchain\": \">=0.3.0 <2.0.0\",\n \"msw\": \"^2.10.4\",\n \"nock\": \"^14.0.8\",\n \"openapi-msw\": \"^1.2.0\",\n \"ts-to-zod\": \"4.0.1\",\n \"tsup\": \"^8.5.0\",\n \"typescript\": \"^5.9.2\",\n \"typescript-eslint\": \"^8.38.0\",\n \"vitest\": \"^3.2.4\",\n \"vitest-mock-extended\": \"^3.1.0\",\n \"yaml\": \"^2.8.1\",\n \"@opentelemetry/api\": \"^1.9.0\"\n },\n \"dependencies\": {\n \"@opentelemetry/api-logs\": \"0.205.0\",\n \"@opentelemetry/core\": \"^2.0.1\",\n \"@opentelemetry/exporter-logs-otlp-http\": \"0.205.0\",\n \"@opentelemetry/exporter-trace-otlp-http\": \"0.205.0\",\n \"@opentelemetry/instrumentation\": \"0.212.0\",\n \"@opentelemetry/resources\": \"^2.0.1\",\n \"@opentelemetry/sdk-logs\": \"0.205.0\",\n \"@opentelemetry/sdk-metrics\": \"^2.0.1\",\n \"@opentelemetry/sdk-trace-base\": \"^2.0.1\",\n \"@opentelemetry/semantic-conventions\": \"^1.36.0\",\n \"@types/prompts\": \"^2.4.9\",\n \"chalk\": \"^4.1.2\",\n \"commander\": \"^12.0.0\",\n \"dotenv\": \"^17.3.1\",\n \"js-yaml\": \"^4.1.0\",\n \"liquidjs\": \"^10.21.1\",\n \"open\": \"^11.0.0\",\n \"openapi-fetch\": \"^0.16.0\",\n \"ora\": \"^9.3.0\",\n \"prompts\": \"^2.4.2\",\n \"xksuid\": \"^0.0.4\",\n \"zod\": \"^4.0.14\"\n },\n \"peerDependencies\": {\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@ai-sdk/openai\": \">=2.0.0 <4.0.0\",\n \"@langchain/core\": \">=0.3.0 <2.0.0\",\n \"@langchain/langgraph\": \">=0.4.0 <2.0.0\",\n \"@langchain/openai\": \">=0.6.0 <2.0.0\",\n \"@opentelemetry/context-async-hooks\": \"^2.1.0\",\n \"@opentelemetry/context-zone\": \">=1.19.0 <3.0.0\",\n \"@opentelemetry/sdk-node\": \">=0.200.0 <1.0.0\",\n \"@opentelemetry/sdk-trace-web\": \">=1.19.0 <3.0.0\",\n \"langchain\": \">=0.3.0 <2.0.0\"\n },\n \"peerDependenciesMeta\": {\n \"@ai-sdk/openai\": {\n \"optional\": true\n },\n \"@langchain/core\": {\n \"optional\": true\n },\n \"@langchain/langgraph\": {\n \"optional\": true\n },\n \"@langchain/openai\": {\n \"optional\": true\n },\n \"@opentelemetry/context-async-hooks\": {\n \"optional\": true\n },\n \"@opentelemetry/context-zone\": {\n \"optional\": true\n },\n \"@opentelemetry/sdk-node\": {\n \"optional\": true\n },\n \"@opentelemetry/sdk-trace-web\": {\n \"optional\": true\n },\n \"langchain\": {\n \"optional\": true\n }\n },\n \"pnpm\": {\n \"overrides\": {\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@opentelemetry/core\": \"^2.0.1\",\n \"@opentelemetry/resources\": \"^2.0.1\",\n \"@opentelemetry/sdk-trace-base\": \"^2.0.1\",\n \"@opentelemetry/instrumentation\": \"0.212.0\",\n \"@opentelemetry/sdk-node\": \"0.205.0\",\n \"@opentelemetry/context-async-hooks\": \"^2.1.0\",\n \"@opentelemetry/api-logs\": \"0.205.0\",\n \"@opentelemetry/sdk-logs\": \"0.205.0\",\n \"@opentelemetry/exporter-logs-otlp-http\": \"0.205.0\",\n \"@opentelemetry/exporter-trace-otlp-http\": \"0.205.0\",\n \"zod\": \"^4.0.14\",\n \"langchain@<0.3.37\": \"0.3.37\",\n \"@langchain/core@<0.3.80\": \"0.3.80\"\n }\n }\n}\n","export type JsRuntime = \"node\" | \"deno\" | \"bun\" | \"web\" | \"unknown\";\n\nlet _runtime: JsRuntime | undefined;\n\n/**\n * Gets the cached JavaScript runtime environment.\n * @returns The detected runtime environment\n */\nexport const getRuntime = (): JsRuntime => {\n _runtime ??= detectRuntime();\n return _runtime;\n};\n\n/**\n * Resets the cached runtime. Only used for testing.\n * @internal\n */\nexport const resetRuntimeCache = (): void => {\n _runtime = undefined;\n};\n\n/**\n * Detects the JavaScript runtime environment.\n * @param globals - (Test only) Optionally override the global object for environment simulation. Only used if NODE_ENV === 'test'.\n */\nexport function detectRuntime(globals?: any): JsRuntime {\n let g = globalThis;\n if (globals) {\n if (process.env.NODE_ENV === \"test\") {\n g = globals;\n } else {\n console.warn(\"[LangWatch Observability] overriding detectRuntime is only supported when running in NODE_ENV=test\");\n }\n }\n\n try {\n if (\n \"Deno\" in g &&\n typeof g.Deno === \"object\" &&\n g.Deno &&\n 'version' in g.Deno &&\n typeof g.Deno.version === \"object\"\n ) {\n return \"deno\";\n }\n if (\n \"Bun\" in g &&\n typeof g.Bun === \"object\" &&\n g.Bun &&\n 'version' in g.Bun &&\n typeof g.Bun.version === \"string\"\n ) {\n return \"bun\";\n }\n if (\n \"process\" in g &&\n typeof g.process === \"object\" &&\n g.process &&\n typeof g.process.versions === \"object\" &&\n typeof g.process.versions.node === \"string\"\n ) {\n return \"node\";\n }\n if (\n typeof g.window?.document !== \"undefined\" &&\n g === g.window\n ) {\n return \"web\";\n }\n return \"unknown\";\n } catch (error) {\n console.warn(\"[LangWatch Observability] Failed to detect runtime\", error);\n return \"unknown\";\n }\n}\n","import { version } from \"../../package.json\";\nimport { getRuntime } from \"./runtime\";\n\nexport const LANGWATCH_SDK_RUNTIME = getRuntime;\n\nexport const LANGWATCH_SDK_NAME_OBSERVABILITY = \"langwatch-observability-sdk\";\nexport const LANGWATCH_SDK_NAME_CLIENT = \"langwatch-client-sdk\";\nexport const LANGWATCH_SDK_LANGUAGE = \"typescript\";\nexport const LANGWATCH_SDK_VERSION = version;\n\nexport const DEFAULT_ENDPOINT = \"https://app.langwatch.ai/\";\nexport const DEFAULT_SERVICE_NAME = \"unknown-service.langwatch\";\n\nexport const TRACES_PATH = \"/api/otel/v1/traces\";\nexport const LOGS_PATH = \"/api/otel/v1/logs\";\nexport const METRICS_PATH = \"/api/otel/v1/metrics\";\n"],"mappings":";AAEI,cAAW;;;ACAf,IAAI;AAMG,IAAM,aAAa,MAAiB;AACzC,2CAAa,cAAc;AAC3B,SAAO;AACT;AAcO,SAAS,cAAc,SAA0B;AAzBxD;AA0BE,MAAI,IAAI;AACR,MAAI,SAAS;AACX,QAAI,QAAQ,IAAI,aAAa,QAAQ;AACnC,UAAI;AAAA,IACN,OAAO;AACL,cAAQ,KAAK,oGAAoG;AAAA,IACnH;AAAA,EACF;AAEA,MAAI;AACF,QACE,UAAU,KACV,OAAO,EAAE,SAAS,YAClB,EAAE,QACF,aAAa,EAAE,QACf,OAAO,EAAE,KAAK,YAAY,UAC1B;AACA,aAAO;AAAA,IACT;AACA,QACE,SAAS,KACT,OAAO,EAAE,QAAQ,YACjB,EAAE,OACF,aAAa,EAAE,OACf,OAAO,EAAE,IAAI,YAAY,UACzB;AACA,aAAO;AAAA,IACT;AACA,QACE,aAAa,KACb,OAAO,EAAE,YAAY,YACrB,EAAE,WACF,OAAO,EAAE,QAAQ,aAAa,YAC9B,OAAO,EAAE,QAAQ,SAAS,SAAS,UACnC;AACA,aAAO;AAAA,IACT;AACA,QACE,SAAO,OAAE,WAAF,mBAAU,cAAa,eAC9B,MAAM,EAAE,QACR;AACA,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT,SAAS,OAAO;AACd,YAAQ,KAAK,sDAAsD,KAAK;AACxE,WAAO;AAAA,EACT;AACF;;;ACvEO,IAAM,wBAAwB;AAE9B,IAAM,mCAAmC;AACzC,IAAM,4BAA4B;AAClC,IAAM,yBAAyB;AAC/B,IAAM,wBAAwB;AAE9B,IAAM,mBAAmB;AACzB,IAAM,uBAAuB;AAE7B,IAAM,cAAc;AACpB,IAAM,YAAY;","names":[]}
|
|
1
|
+
{"version":3,"sources":["../package.json","../src/internal/runtime.ts","../src/internal/constants.ts"],"sourcesContent":["{\n \"name\": \"langwatch\",\n \"version\": \"0.23.0\",\n \"description\": \"LangWatch TypeScript/JavaScript SDK. Interact with the full LangWatch API and use the LangWatch OpenTelemetry SDK to instrument your application. For more information, see https://docs.langwatch.ai/integration/typescript/guide\",\n \"main\": \"dist/index.js\",\n \"module\": \"dist/index.mjs\",\n \"types\": \"dist/index.d.ts\",\n \"author\": \"LangWatch\",\n \"license\": \"MIT\",\n \"engines\": {\n \"node\": \">=20\",\n \"pnpm\": \">=8\"\n },\n \"files\": [\n \"dist\",\n \"README.md\",\n \"LICENSE\"\n ],\n \"bin\": {\n \"langwatch\": \"./dist/cli/index.js\"\n },\n \"exports\": {\n \".\": {\n \"types\": \"./dist/index.d.ts\",\n \"import\": \"./dist/index.mjs\",\n \"require\": \"./dist/index.js\"\n },\n \"./observability\": {\n \"types\": \"./dist/observability-sdk/index.d.ts\",\n \"require\": \"./dist/observability-sdk/index.js\",\n \"import\": \"./dist/observability-sdk/index.mjs\"\n },\n \"./observability/node\": {\n \"types\": \"./dist/observability-sdk/setup/node/index.d.ts\",\n \"require\": \"./dist/observability-sdk/setup/node/index.js\",\n \"import\": \"./dist/observability-sdk/setup/node/index.mjs\"\n },\n \"./observability/instrumentation/langchain\": {\n \"types\": \"./dist/observability-sdk/instrumentation/langchain/index.d.ts\",\n \"require\": \"./dist/observability-sdk/instrumentation/langchain/index.js\",\n \"import\": \"./dist/observability-sdk/instrumentation/langchain/index.mjs\"\n }\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/langwatch/langwatch.git\",\n \"directory\": \"typescript-sdk\"\n },\n \"scripts\": {\n \"prepare\": \"pnpm run generate:server-types && pnpm run generate:openapi-types\",\n \"cli\": \"node dist/cli/index.js\",\n \"lint\": \"eslint .\",\n \"test\": \"vitest\",\n \"test:unit\": \"vitest run --exclude '**/*.integration.test.ts'\",\n \"test:e2e\": \"dotenv -- vitest run -c ./vitest.e2e.config.mts\",\n \"test:seed\": \"dotenv -e .env.test -- bash -c 'cd ../langwatch && pnpm prisma:seed'\",\n \"prebuild\": \"pnpm run prepare\",\n \"build\": \"tsc --noEmit && tsup\",\n \"tarball\": \"pnpm build && pnpm pack\",\n \"typecheck\": \"tsc --noEmit\",\n \"prepublish\": \"pnpm run build\",\n \"generate:openapi-types\": \"pnpx openapi-typescript ../langwatch/src/app/api/openapiLangWatch.json -o ./src/internal/generated/openapi/api-client.ts\",\n \"generate:server-types\": \"./copy-types.sh\"\n },\n \"devDependencies\": {\n \"@eslint/js\": \"^9.32.0\",\n \"@langchain/core\": \">=0.3.68 <0.4.0\",\n \"@langchain/langgraph\": \">=0.4.0 <1.0.0\",\n \"@langchain/openai\": \">=0.6.0 <1.0.0\",\n \"@opentelemetry/sdk-node\": \"0.205.0\",\n \"@opentelemetry/sdk-trace-node\": \"^2.0.1\",\n \"@opentelemetry/sdk-trace-web\": \">=2.0.1\",\n \"@types/debug\": \"^4.1.12\",\n \"@types/js-yaml\": \"^4.0.9\",\n \"@types/node\": \"^24.1.0\",\n \"@typescript/native-preview\": \"7.0.0-dev.20250804.1\",\n \"@vercel/otel\": \"^1.13.0\",\n \"@vitest/coverage-v8\": \"3.2.4\",\n \"dotenv-cli\": \"^11.0.0\",\n \"esbuild\": \"^0.27.3\",\n \"eslint\": \"^9.32.0\",\n \"fets\": \"^0.8.5\",\n \"fishery\": \"^2.3.1\",\n \"langchain\": \">=0.3.0 <2.0.0\",\n \"msw\": \"^2.10.4\",\n \"nock\": \"^14.0.8\",\n \"openapi-msw\": \"^1.2.0\",\n \"ts-to-zod\": \"4.0.1\",\n \"tsup\": \"^8.5.0\",\n \"typescript\": \"^5.9.2\",\n \"typescript-eslint\": \"^8.38.0\",\n \"vitest\": \"^3.2.4\",\n \"vitest-mock-extended\": \"^3.1.0\",\n \"yaml\": \"^2.8.1\",\n \"@opentelemetry/api\": \"^1.9.0\"\n },\n \"dependencies\": {\n \"@opentelemetry/api-logs\": \"0.205.0\",\n \"@opentelemetry/core\": \"^2.0.1\",\n \"@opentelemetry/exporter-logs-otlp-http\": \"0.205.0\",\n \"@opentelemetry/exporter-trace-otlp-http\": \"0.205.0\",\n \"@opentelemetry/instrumentation\": \"0.212.0\",\n \"@opentelemetry/resources\": \"^2.0.1\",\n \"@opentelemetry/sdk-logs\": \"0.205.0\",\n \"@opentelemetry/sdk-metrics\": \"^2.0.1\",\n \"@opentelemetry/sdk-trace-base\": \"^2.0.1\",\n \"@opentelemetry/semantic-conventions\": \"^1.36.0\",\n \"@types/prompts\": \"^2.4.9\",\n \"chalk\": \"^4.1.2\",\n \"commander\": \"^12.0.0\",\n \"dotenv\": \"^17.3.1\",\n \"js-yaml\": \"^4.1.0\",\n \"liquidjs\": \"^10.21.1\",\n \"open\": \"^11.0.0\",\n \"openapi-fetch\": \"^0.16.0\",\n \"ora\": \"^9.3.0\",\n \"prompts\": \"^2.4.2\",\n \"xksuid\": \"^0.0.4\",\n \"zod\": \"^4.0.14\"\n },\n \"peerDependencies\": {\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@ai-sdk/openai\": \">=2.0.0 <4.0.0\",\n \"@langchain/core\": \">=0.3.0 <2.0.0\",\n \"@langchain/langgraph\": \">=0.4.0 <2.0.0\",\n \"@langchain/openai\": \">=0.6.0 <2.0.0\",\n \"@opentelemetry/context-async-hooks\": \"^2.1.0\",\n \"@opentelemetry/context-zone\": \">=1.19.0 <3.0.0\",\n \"@opentelemetry/sdk-node\": \">=0.200.0 <1.0.0\",\n \"@opentelemetry/sdk-trace-web\": \">=1.19.0 <3.0.0\",\n \"langchain\": \">=0.3.0 <2.0.0\"\n },\n \"peerDependenciesMeta\": {\n \"@ai-sdk/openai\": {\n \"optional\": true\n },\n \"@langchain/core\": {\n \"optional\": true\n },\n \"@langchain/langgraph\": {\n \"optional\": true\n },\n \"@langchain/openai\": {\n \"optional\": true\n },\n \"@opentelemetry/context-async-hooks\": {\n \"optional\": true\n },\n \"@opentelemetry/context-zone\": {\n \"optional\": true\n },\n \"@opentelemetry/sdk-node\": {\n \"optional\": true\n },\n \"@opentelemetry/sdk-trace-web\": {\n \"optional\": true\n },\n \"langchain\": {\n \"optional\": true\n }\n },\n \"pnpm\": {\n \"overrides\": {\n \"@opentelemetry/api\": \"^1.9.0\",\n \"@opentelemetry/core\": \"^2.0.1\",\n \"@opentelemetry/resources\": \"^2.0.1\",\n \"@opentelemetry/sdk-trace-base\": \"^2.0.1\",\n \"@opentelemetry/instrumentation\": \"0.212.0\",\n \"@opentelemetry/sdk-node\": \"0.205.0\",\n \"@opentelemetry/context-async-hooks\": \"^2.1.0\",\n \"@opentelemetry/api-logs\": \"0.205.0\",\n \"@opentelemetry/sdk-logs\": \"0.205.0\",\n \"@opentelemetry/exporter-logs-otlp-http\": \"0.205.0\",\n \"@opentelemetry/exporter-trace-otlp-http\": \"0.205.0\",\n \"zod\": \"^4.0.14\",\n \"langchain@<0.3.37\": \"0.3.37\",\n \"@langchain/core@<0.3.80\": \"0.3.80\"\n }\n }\n}\n","export type JsRuntime = \"node\" | \"deno\" | \"bun\" | \"web\" | \"unknown\";\n\nlet _runtime: JsRuntime | undefined;\n\n/**\n * Gets the cached JavaScript runtime environment.\n * @returns The detected runtime environment\n */\nexport const getRuntime = (): JsRuntime => {\n _runtime ??= detectRuntime();\n return _runtime;\n};\n\n/**\n * Resets the cached runtime. Only used for testing.\n * @internal\n */\nexport const resetRuntimeCache = (): void => {\n _runtime = undefined;\n};\n\n/**\n * Detects the JavaScript runtime environment.\n * @param globals - (Test only) Optionally override the global object for environment simulation. Only used if NODE_ENV === 'test'.\n */\nexport function detectRuntime(globals?: any): JsRuntime {\n let g = globalThis;\n if (globals) {\n if (process.env.NODE_ENV === \"test\") {\n g = globals;\n } else {\n console.warn(\"[LangWatch Observability] overriding detectRuntime is only supported when running in NODE_ENV=test\");\n }\n }\n\n try {\n if (\n \"Deno\" in g &&\n typeof g.Deno === \"object\" &&\n g.Deno &&\n 'version' in g.Deno &&\n typeof g.Deno.version === \"object\"\n ) {\n return \"deno\";\n }\n if (\n \"Bun\" in g &&\n typeof g.Bun === \"object\" &&\n g.Bun &&\n 'version' in g.Bun &&\n typeof g.Bun.version === \"string\"\n ) {\n return \"bun\";\n }\n if (\n \"process\" in g &&\n typeof g.process === \"object\" &&\n g.process &&\n typeof g.process.versions === \"object\" &&\n typeof g.process.versions.node === \"string\"\n ) {\n return \"node\";\n }\n if (\n typeof g.window?.document !== \"undefined\" &&\n g === g.window\n ) {\n return \"web\";\n }\n return \"unknown\";\n } catch (error) {\n console.warn(\"[LangWatch Observability] Failed to detect runtime\", error);\n return \"unknown\";\n }\n}\n","import { version } from \"../../package.json\";\nimport { getRuntime } from \"./runtime\";\n\nexport const LANGWATCH_SDK_RUNTIME = getRuntime;\n\nexport const LANGWATCH_SDK_NAME_OBSERVABILITY = \"langwatch-observability-sdk\";\nexport const LANGWATCH_SDK_NAME_CLIENT = \"langwatch-client-sdk\";\nexport const LANGWATCH_SDK_LANGUAGE = \"typescript\";\nexport const LANGWATCH_SDK_VERSION = version;\n\nexport const DEFAULT_ENDPOINT = \"https://app.langwatch.ai/\";\nexport const DEFAULT_SERVICE_NAME = \"unknown-service.langwatch\";\n\nexport const TRACES_PATH = \"/api/otel/v1/traces\";\nexport const LOGS_PATH = \"/api/otel/v1/logs\";\nexport const METRICS_PATH = \"/api/otel/v1/metrics\";\n"],"mappings":";AAEI,cAAW;;;ACAf,IAAI;AAMG,IAAM,aAAa,MAAiB;AACzC,2CAAa,cAAc;AAC3B,SAAO;AACT;AAcO,SAAS,cAAc,SAA0B;AAzBxD;AA0BE,MAAI,IAAI;AACR,MAAI,SAAS;AACX,QAAI,QAAQ,IAAI,aAAa,QAAQ;AACnC,UAAI;AAAA,IACN,OAAO;AACL,cAAQ,KAAK,oGAAoG;AAAA,IACnH;AAAA,EACF;AAEA,MAAI;AACF,QACE,UAAU,KACV,OAAO,EAAE,SAAS,YAClB,EAAE,QACF,aAAa,EAAE,QACf,OAAO,EAAE,KAAK,YAAY,UAC1B;AACA,aAAO;AAAA,IACT;AACA,QACE,SAAS,KACT,OAAO,EAAE,QAAQ,YACjB,EAAE,OACF,aAAa,EAAE,OACf,OAAO,EAAE,IAAI,YAAY,UACzB;AACA,aAAO;AAAA,IACT;AACA,QACE,aAAa,KACb,OAAO,EAAE,YAAY,YACrB,EAAE,WACF,OAAO,EAAE,QAAQ,aAAa,YAC9B,OAAO,EAAE,QAAQ,SAAS,SAAS,UACnC;AACA,aAAO;AAAA,IACT;AACA,QACE,SAAO,OAAE,WAAF,mBAAU,cAAa,eAC9B,MAAM,EAAE,QACR;AACA,aAAO;AAAA,IACT;AACA,WAAO;AAAA,EACT,SAAS,OAAO;AACd,YAAQ,KAAK,sDAAsD,KAAK;AACxE,WAAO;AAAA,EACT;AACF;;;ACvEO,IAAM,wBAAwB;AAE9B,IAAM,mCAAmC;AACzC,IAAM,4BAA4B;AAClC,IAAM,yBAAyB;AAC/B,IAAM,wBAAwB;AAE9B,IAAM,mBAAmB;AACzB,IAAM,uBAAuB;AAE7B,IAAM,cAAc;AACpB,IAAM,YAAY;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkCKYNUZLAjs = require('./chunk-CKYNUZLA.js');
|
|
4
4
|
|
|
5
5
|
// src/client-sdk/services/scenarios/errors.ts
|
|
6
6
|
var ScenariosApiError = class extends Error {
|
|
@@ -16,7 +16,7 @@ var ScenariosApiError = class extends Error {
|
|
|
16
16
|
var ScenariosApiService = class {
|
|
17
17
|
constructor(config) {
|
|
18
18
|
var _a;
|
|
19
|
-
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a :
|
|
19
|
+
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a : _chunkCKYNUZLAjs.createLangWatchApiClient.call(void 0, );
|
|
20
20
|
}
|
|
21
21
|
handleApiError(operation, error) {
|
|
22
22
|
var _a;
|
|
@@ -73,4 +73,4 @@ var ScenariosApiService = class {
|
|
|
73
73
|
|
|
74
74
|
|
|
75
75
|
exports.ScenariosApiError = ScenariosApiError; exports.ScenariosApiService = ScenariosApiService;
|
|
76
|
-
//# sourceMappingURL=chunk-
|
|
76
|
+
//# sourceMappingURL=chunk-MAI4B2ZR.js.map
|