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
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import {
|
|
2
|
+
createLangWatchApiClient
|
|
3
|
+
} from "./chunk-SAR52TH6.mjs";
|
|
4
|
+
|
|
5
|
+
// src/client-sdk/services/analytics/analytics-api.service.ts
|
|
6
|
+
var AnalyticsApiError = class extends Error {
|
|
7
|
+
constructor(message, operation, originalError) {
|
|
8
|
+
super(message);
|
|
9
|
+
this.operation = operation;
|
|
10
|
+
this.originalError = originalError;
|
|
11
|
+
this.name = "AnalyticsApiError";
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
var AnalyticsApiService = class {
|
|
15
|
+
constructor(config) {
|
|
16
|
+
var _a;
|
|
17
|
+
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a : createLangWatchApiClient();
|
|
18
|
+
}
|
|
19
|
+
handleApiError(operation, error) {
|
|
20
|
+
var _a;
|
|
21
|
+
const errorMessage = typeof error === "string" ? error : error != null && typeof error === "object" && "error" in error && error.error != null ? typeof error.error === "string" ? error.error : (_a = error.error.message) != null ? _a : JSON.stringify(error.error) : error instanceof Error ? error.message : "Unknown error occurred";
|
|
22
|
+
throw new AnalyticsApiError(
|
|
23
|
+
`Failed to ${operation}: ${errorMessage}`,
|
|
24
|
+
operation,
|
|
25
|
+
error
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
async timeseries(params) {
|
|
29
|
+
const { data, error } = await this.apiClient.POST(
|
|
30
|
+
"/api/analytics/timeseries",
|
|
31
|
+
{ body: params }
|
|
32
|
+
);
|
|
33
|
+
if (error) this.handleApiError("query analytics", error);
|
|
34
|
+
return data;
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
export {
|
|
39
|
+
AnalyticsApiError,
|
|
40
|
+
AnalyticsApiService
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=chunk-XIHOAUIU.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/client-sdk/services/analytics/analytics-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 AnalyticsTimeseriesBody = NonNullable<\n paths[\"/api/analytics/timeseries\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type AnalyticsTimeseriesResponse =\n paths[\"/api/analytics/timeseries\"][\"post\"][\"responses\"][\"200\"][\"content\"][\"application/json\"];\n\nexport class AnalyticsApiError extends Error {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"AnalyticsApiError\";\n }\n}\n\nexport class AnalyticsApiService {\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 AnalyticsApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n async timeseries(params: AnalyticsTimeseriesBody): Promise<AnalyticsTimeseriesResponse> {\n const { data, error } = await this.apiClient.POST(\n \"/api/analytics/timeseries\",\n { body: params },\n );\n if (error) this.handleApiError(\"query analytics\", error);\n return data;\n }\n}\n"],"mappings":";;;;;AAcO,IAAM,oBAAN,cAAgC,MAAM;AAAA,EAC3C,YACE,SACgB,WACA,eAChB;AACA,UAAM,OAAO;AAHG;AACA;AAGhB,SAAK,OAAO;AAAA,EACd;AACF;AAEO,IAAM,sBAAN,MAA0B;AAAA,EAG/B,YAAY,QAAqD;AA5BnE;AA6BI,SAAK,aAAY,sCAAQ,uBAAR,YAA8B,yBAAyB;AAAA,EAC1E;AAAA,EAEQ,eAAe,WAAmB,OAAuB;AAhCnE;AAiCI,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,WAAW,QAAuE;AACtF,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU;AAAA,MAC3C;AAAA,MACA,EAAE,MAAM,OAAO;AAAA,IACjB;AACA,QAAI,MAAO,MAAK,eAAe,mBAAmB,KAAK;AACvD,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/annotations/annotations-api.service.ts
|
|
6
6
|
var AnnotationsApiError = class extends Error {
|
|
@@ -77,4 +77,4 @@ export {
|
|
|
77
77
|
AnnotationsApiError,
|
|
78
78
|
AnnotationsApiService
|
|
79
79
|
};
|
|
80
|
-
//# sourceMappingURL=chunk-
|
|
80
|
+
//# sourceMappingURL=chunk-Y5PPNQXM.mjs.map
|
|
@@ -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/model-providers/model-providers-api.service.ts
|
|
6
6
|
var ModelProvidersApiError = class extends Error {
|
|
@@ -48,4 +48,4 @@ export {
|
|
|
48
48
|
ModelProvidersApiError,
|
|
49
49
|
ModelProvidersApiService
|
|
50
50
|
};
|
|
51
|
-
//# sourceMappingURL=chunk-
|
|
51
|
+
//# sourceMappingURL=chunk-YD7SA3ZL.mjs.map
|
|
@@ -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/dashboards/dashboards-api.service.ts
|
|
6
6
|
var DashboardsApiError = class extends Error {
|
|
@@ -65,4 +65,4 @@ export {
|
|
|
65
65
|
DashboardsApiError,
|
|
66
66
|
DashboardsApiService
|
|
67
67
|
};
|
|
68
|
-
//# sourceMappingURL=chunk-
|
|
68
|
+
//# sourceMappingURL=chunk-YDRETRB6.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/client-sdk/services/dashboards/dashboards-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 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"],"mappings":";;;;;AA0BO,IAAM,qBAAN,cAAiC,MAAM;AAAA,EAC5C,YACE,SACgB,WACA,eAChB;AACA,UAAM,OAAO;AAHG;AACA;AAGhB,SAAK,OAAO;AAAA,EACd;AACF;AAEO,IAAM,uBAAN,MAA2B;AAAA,EAGhC,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,OAA8C;AAClD,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,IAAI,iBAAiB;AAClE,QAAI,MAAO,MAAK,eAAe,mBAAmB,KAAK;AACvD,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,IAAI,IAAsC;AAC9C,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,IAAI,wBAAwB;AAAA,MACvE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE;AAAA,IACzB,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,kBAAkB,EAAE,KAAK,KAAK;AAC7D,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO,QAAoD;AAC/D,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,KAAK,mBAAmB;AAAA,MACnE,MAAM;AAAA,IACR,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,oBAAoB,KAAK;AACxD,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO,IAAY,QAAoD;AAC3E,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,MAAM,wBAAwB;AAAA,MACzE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE;AAAA,MACvB,MAAM;AAAA,IACR,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,qBAAqB,EAAE,KAAK,KAAK;AAChE,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAO,IAAmD;AAC9D,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,KAAK,UAAU,OAAO,wBAAwB;AAAA,MAC1E,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE;AAAA,IACzB,CAAC;AACD,QAAI,MAAO,MAAK,eAAe,qBAAqB,EAAE,KAAK,KAAK;AAChE,WAAO;AAAA,EACT;AACF;","names":[]}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
var _chunkCKYNUZLAjs = require('./chunk-CKYNUZLA.js');
|
|
4
|
+
|
|
5
|
+
// src/client-sdk/services/analytics/analytics-api.service.ts
|
|
6
|
+
var AnalyticsApiError = class extends Error {
|
|
7
|
+
constructor(message, operation, originalError) {
|
|
8
|
+
super(message);
|
|
9
|
+
this.operation = operation;
|
|
10
|
+
this.originalError = originalError;
|
|
11
|
+
this.name = "AnalyticsApiError";
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
var AnalyticsApiService = class {
|
|
15
|
+
constructor(config) {
|
|
16
|
+
var _a;
|
|
17
|
+
this.apiClient = (_a = config == null ? void 0 : config.langwatchApiClient) != null ? _a : _chunkCKYNUZLAjs.createLangWatchApiClient.call(void 0, );
|
|
18
|
+
}
|
|
19
|
+
handleApiError(operation, error) {
|
|
20
|
+
var _a;
|
|
21
|
+
const errorMessage = typeof error === "string" ? error : error != null && typeof error === "object" && "error" in error && error.error != null ? typeof error.error === "string" ? error.error : (_a = error.error.message) != null ? _a : JSON.stringify(error.error) : error instanceof Error ? error.message : "Unknown error occurred";
|
|
22
|
+
throw new AnalyticsApiError(
|
|
23
|
+
`Failed to ${operation}: ${errorMessage}`,
|
|
24
|
+
operation,
|
|
25
|
+
error
|
|
26
|
+
);
|
|
27
|
+
}
|
|
28
|
+
async timeseries(params) {
|
|
29
|
+
const { data, error } = await this.apiClient.POST(
|
|
30
|
+
"/api/analytics/timeseries",
|
|
31
|
+
{ body: params }
|
|
32
|
+
);
|
|
33
|
+
if (error) this.handleApiError("query analytics", error);
|
|
34
|
+
return data;
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
exports.AnalyticsApiError = AnalyticsApiError; exports.AnalyticsApiService = AnalyticsApiService;
|
|
42
|
+
//# sourceMappingURL=chunk-YEDCQTZY.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-YEDCQTZY.js","../src/client-sdk/services/analytics/analytics-api.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;ACUO,IAAM,kBAAA,EAAN,MAAA,QAAgC,MAAM;AAAA,EAC3C,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,mBAAA;AAAA,EACd;AACF,CAAA;AAEO,IAAM,oBAAA,EAAN,MAA0B;AAAA,EAG/B,WAAA,CAAY,MAAA,EAAqD;AA5BnE,IAAA,IAAA,EAAA;AA6BI,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;AAhCnE,IAAA,IAAA,EAAA;AAiCI,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,iBAAA;AAAA,MACR,CAAA,UAAA,EAAa,SAAS,CAAA,EAAA,EAAK,YAAY,CAAA,CAAA;AACvC,MAAA;AACA,MAAA;AACF,IAAA;AACF,EAAA;AAEwF,EAAA;AACnD,IAAA;AACjC,MAAA;AACe,MAAA;AACjB,IAAA;AAC+B,IAAA;AACxB,IAAA;AACT,EAAA;AACF;AD3B8C;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-YEDCQTZY.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 AnalyticsTimeseriesBody = NonNullable<\n paths[\"/api/analytics/timeseries\"][\"post\"][\"requestBody\"]\n>[\"content\"][\"application/json\"];\n\nexport type AnalyticsTimeseriesResponse =\n paths[\"/api/analytics/timeseries\"][\"post\"][\"responses\"][\"200\"][\"content\"][\"application/json\"];\n\nexport class AnalyticsApiError extends Error {\n constructor(\n message: string,\n public readonly operation: string,\n public readonly originalError?: unknown,\n ) {\n super(message);\n this.name = \"AnalyticsApiError\";\n }\n}\n\nexport class AnalyticsApiService {\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 AnalyticsApiError(\n `Failed to ${operation}: ${errorMessage}`,\n operation,\n error,\n );\n }\n\n async timeseries(params: AnalyticsTimeseriesBody): Promise<AnalyticsTimeseriesResponse> {\n const { data, error } = await this.apiClient.POST(\n \"/api/analytics/timeseries\",\n { body: params },\n );\n if (error) this.handleApiError(\"query analytics\", error);\n return data;\n }\n}\n"]}
|
|
@@ -2,14 +2,14 @@
|
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
|
-
var
|
|
5
|
+
var _chunk2VWQGGRZjs = require('./chunk-2VWQGGRZ.js');
|
|
6
6
|
|
|
7
7
|
|
|
8
8
|
|
|
9
9
|
|
|
10
10
|
|
|
11
11
|
|
|
12
|
-
var
|
|
12
|
+
var _chunkBLCVVN6Pjs = require('./chunk-BLCVVN6P.js');
|
|
13
13
|
|
|
14
14
|
|
|
15
15
|
var _chunkOAAMDWSKjs = require('./chunk-OAAMDWSK.js');
|
|
@@ -35,12 +35,12 @@ var _resources = require('@opentelemetry/resources');
|
|
|
35
35
|
var _incubating = require('@opentelemetry/semantic-conventions/incubating'); var semconv = _interopRequireWildcard(_incubating);
|
|
36
36
|
function createMergedResource(attributes, serviceName, givenResource) {
|
|
37
37
|
const langwatchResource = _resources.resourceFromAttributes.call(void 0, {
|
|
38
|
-
[_chunkDB6OJGP4js.ATTR_LANGWATCH_SDK_NAME]:
|
|
39
|
-
[_chunkDB6OJGP4js.ATTR_LANGWATCH_SDK_LANGUAGE]:
|
|
40
|
-
[_chunkDB6OJGP4js.ATTR_LANGWATCH_SDK_VERSION]:
|
|
38
|
+
[_chunkDB6OJGP4js.ATTR_LANGWATCH_SDK_NAME]: _chunkBLCVVN6Pjs.LANGWATCH_SDK_NAME_OBSERVABILITY,
|
|
39
|
+
[_chunkDB6OJGP4js.ATTR_LANGWATCH_SDK_LANGUAGE]: _chunkBLCVVN6Pjs.LANGWATCH_SDK_LANGUAGE,
|
|
40
|
+
[_chunkDB6OJGP4js.ATTR_LANGWATCH_SDK_VERSION]: _chunkBLCVVN6Pjs.LANGWATCH_SDK_VERSION
|
|
41
41
|
});
|
|
42
42
|
const userResource = _resources.resourceFromAttributes.call(void 0, _chunkOHM7JUMRjs.__spreadValues.call(void 0, {
|
|
43
|
-
[semconv.ATTR_SERVICE_NAME]: serviceName != null ? serviceName :
|
|
43
|
+
[semconv.ATTR_SERVICE_NAME]: serviceName != null ? serviceName : _chunkBLCVVN6Pjs.DEFAULT_SERVICE_NAME
|
|
44
44
|
}, attributes != null ? attributes : {}));
|
|
45
45
|
return (givenResource != null ? givenResource : _resources.defaultResource.call(void 0, )).merge(langwatchResource).merge(userResource);
|
|
46
46
|
}
|
|
@@ -96,7 +96,7 @@ var getLangWatchConfig = (options) => {
|
|
|
96
96
|
return {
|
|
97
97
|
disabled: isDisabled,
|
|
98
98
|
apiKey: isDisabled ? void 0 : (_a = config.apiKey) != null ? _a : process.env.LANGWATCH_API_KEY,
|
|
99
|
-
endpoint: isDisabled ? void 0 : (_c = (_b = config.endpoint) != null ? _b : process.env.LANGWATCH_ENDPOINT) != null ? _c :
|
|
99
|
+
endpoint: isDisabled ? void 0 : (_c = (_b = config.endpoint) != null ? _b : process.env.LANGWATCH_ENDPOINT) != null ? _c : _chunkBLCVVN6Pjs.DEFAULT_ENDPOINT,
|
|
100
100
|
processorType: (_d = config.processorType) != null ? _d : "batch"
|
|
101
101
|
};
|
|
102
102
|
};
|
|
@@ -203,11 +203,11 @@ function createAndStartNodeSdk(options, logger, resource) {
|
|
|
203
203
|
logger.debug("Console recording of logs enabled; adding console log record processor");
|
|
204
204
|
}
|
|
205
205
|
if (!langwatch.disabled) {
|
|
206
|
-
const traceExporter = new (0,
|
|
206
|
+
const traceExporter = new (0, _chunk2VWQGGRZjs.LangWatchTraceExporter)({
|
|
207
207
|
apiKey: langwatch.apiKey,
|
|
208
208
|
endpoint: langwatch.endpoint
|
|
209
209
|
});
|
|
210
|
-
const logExporter = new (0,
|
|
210
|
+
const logExporter = new (0, _chunk2VWQGGRZjs.LangWatchLogsExporter)({
|
|
211
211
|
apiKey: langwatch.apiKey,
|
|
212
212
|
endpoint: langwatch.endpoint
|
|
213
213
|
});
|
|
@@ -277,7 +277,7 @@ function createAndStartNodeSdk(options, logger, resource) {
|
|
|
277
277
|
});
|
|
278
278
|
}
|
|
279
279
|
if (loggerProvider) {
|
|
280
|
-
|
|
280
|
+
_chunk2VWQGGRZjs.setLangWatchLoggerProvider.call(void 0, loggerProvider);
|
|
281
281
|
logger.debug("Set LangWatch logger provider");
|
|
282
282
|
}
|
|
283
283
|
if (!((_e = options.advanced) == null ? void 0 : _e.disableAutoShutdown)) {
|
|
@@ -331,4 +331,4 @@ var ensureSetup = () => {
|
|
|
331
331
|
|
|
332
332
|
|
|
333
333
|
exports.setupObservability = setupObservability; exports.ensureSetup = ensureSetup;
|
|
334
|
-
//# sourceMappingURL=chunk-
|
|
334
|
+
//# sourceMappingURL=chunk-YNIDOE6Q.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-JWF5KHWM.js","../src/observability-sdk/setup/node/setup.ts","../src/observability-sdk/setup/utils.ts"],"names":[],"mappings":"AAAA;AACE;AACA;AACA;AACF,sDAA4B;AAC5B;AACE;AACA;AACA;AACA;AACA;AACF,sDAA4B;AAC5B;AACE;AACF,sDAA4B;AAC5B;AACE;AACA;AACA;AACA;AACF,sDAA4B;AAC5B;AACE;AACF,sDAA4B;AAC5B;AACA;ACzBA,kDAAwB;AACxB,kDAAqI;AD2BrI;AACA;AE7BA;AACE;AAEA;AAAA,qDACK;AAEP,gIAAyB;AAgBlB,SAAS,oBAAA,CACd,UAAA,EACA,WAAA,EACA,aAAA,EACU;AACV,EAAA,MAAM,kBAAA,EAAoB,+CAAA;AAAuB,IAC/C,CAAC,wCAAuB,CAAA,EAAG,iDAAA;AAAA,IAC3B,CAAC,4CAA2B,CAAA,EAAG,uCAAA;AAAA,IAC/B,CAAC,2CAA0B,CAAA,EAAG;AAAA,EAChC,CAAC,CAAA;AAED,EAAA,MAAM,aAAA,EAAe,+CAAA,6CAAuB;AAAA,IAC1C,CAAS,OAAA,CAAA,iBAAiB,CAAA,EAAG,YAAA,GAAA,KAAA,EAAA,YAAA,EAAe;AAAA,EAAA,CAAA,EACxC,WAAA,GAAA,KAAA,EAAA,WAAA,EAAc,CAAC,CAAA,CACpB,CAAA;AAED,EAAA,OAAA,CAAQ,cAAA,GAAA,KAAA,EAAA,cAAA,EAAiB,wCAAA,CAAgB,CAAA,CACtC,KAAA,CAAM,iBAAiB,CAAA,CACvB,KAAA,CAAM,YAAY,CAAA;AACvB;AAMO,SAAS,mBAAA,CAAoB,QAAA,EAA4B;AA/ChE,EAAA,IAAA,EAAA,EAAA,EAAA;AAgDE,EAAA,GAAA,CAAI,CAAC,SAAA,GAAY,OAAO,SAAA,IAAa,QAAA,EAAU,OAAO,KAAA,CAAA;AAGtD,EAAA,MAAM,gBAAA,EAAA,CAAmB,GAAA,EAAA,QAAA,CAAiB,WAAA,EAAA,GAAjB,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAA8B,IAAA;AACvD,EAAA,GAAA,CAAI,CAAC,oBAAA,EAAsB,qBAAqB,CAAA,CAAE,QAAA,CAAS,eAAe,CAAA,EAAG;AAC3E,IAAA,OAAO,QAAA;AAAA,EACT;AACA,EAAA,GAAA,CAAI,OAAQ,QAAA,CAAiB,iBAAA,IAAqB,UAAA,EAAY;AAC5D,IAAA,OAAO,QAAA;AAAA,EACT;AAGA,EAAA,IAAI,QAAA;AACJ,EAAA,GAAA,CAAI,OAAQ,QAAA,CAAiB,YAAA,IAAgB,UAAA,EAAY;AACvD,IAAA,SAAA,EAAY,QAAA,CAAiB,WAAA,CAAY,CAAA;AAAA,EAC3C,EAAA,KAAA,GAAA,CAAY,QAAA,CAAiB,QAAA,EAAU;AACrC,IAAA,SAAA,EAAY,QAAA,CAAiB,QAAA;AAAA,EAC/B,EAAA,KAAA,GAAA,CAAY,QAAA,CAAiB,SAAA,EAAW;AAGtC,IAAA,SAAA,EAAY,QAAA,CAAiB,SAAA;AAAA,EAC/B;AAEA,EAAA,GAAA,CAAI,SAAA,GAAY,OAAO,SAAA,IAAa,QAAA,EAAU;AAC5C,IAAA,MAAM,wBAAA,EAAA,CAA0B,GAAA,EAAA,QAAA,CAAS,WAAA,EAAA,GAAT,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAsB,IAAA;AACtD,IAAA,GAAA,CAAI,CAAC,oBAAA,EAAsB,qBAAqB,CAAA,CAAE,QAAA,CAAS,uBAAuB,CAAA,EAAG;AACnF,MAAA,OAAO,QAAA;AAAA,IACT;AACA,IAAA,GAAA,CAAI,OAAO,QAAA,CAAS,iBAAA,IAAqB,UAAA,EAAY;AACnD,MAAA,OAAO,QAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,KAAA,CAAA;AACT;AAKO,SAAS,kBAAA,CAAmB,QAAA,EAA4B;AAC7D,EAAA,OAAO,CAAC,CAAC,mBAAA,CAAoB,QAAQ,CAAA;AACvC;AFXA;AACA;AC3EA,yCAAsB;AACtB;AACE;AACA;AACA;AAAA,6DAEK;AASP,IAAM,iBAAA,EAAmB,CAAC,MAAA,EAAA,GAAA,CAAyC;AAAA,EACjE,QAAA,EAAU,MAAA,CAAA,EAAA,GAAY;AACpB,IAAA,MAAA,CAAO,KAAA,CAAM,+DAA+D,CAAA;AAAA,EAC9E;AACF,CAAA,CAAA;AAEA,IAAM,mBAAA,EAAqB,CAAC,OAAA,EAAA,GAAuC;AAzBnE,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AA0BE,EAAA,MAAM,WAAA,EAAa,OAAA,CAAQ,UAAA,IAAc,UAAA;AACzC,EAAA,MAAM,OAAA,EAAS,OAAO,OAAA,CAAQ,UAAA,IAAc,SAAA,EAAW,OAAA,CAAQ,UAAA,EAAY,CAAC,CAAA;AAE5E,EAAA,OAAO;AAAA,IACL,QAAA,EAAU,UAAA;AAAA,IACV,MAAA,EAAQ,WAAA,EAAa,KAAA,EAAA,EAAA,CAAU,GAAA,EAAA,MAAA,CAAO,MAAA,EAAA,GAAP,KAAA,EAAA,GAAA,EAAiB,OAAA,CAAQ,GAAA,CAAI,iBAAA;AAAA,IAC5D,QAAA,EAAU,WAAA,EAAa,KAAA,EAAA,EAAA,CAAU,GAAA,EAAA,CAAA,GAAA,EAAA,MAAA,CAAO,QAAA,EAAA,GAAP,KAAA,EAAA,GAAA,EAAmB,OAAA,CAAQ,GAAA,CAAI,kBAAA,EAAA,GAA/B,KAAA,EAAA,GAAA,EAAqD,iCAAA;AAAA,IACtF,aAAA,EAAA,CAAe,GAAA,EAAA,MAAA,CAAO,aAAA,EAAA,GAAP,KAAA,EAAA,GAAA,EAAwB;AAAA,EACzC,CAAA;AACF,CAAA;AAEA,IAAM,kBAAA,EAAoB,CAAC,OAAA,EAAoC,MAAA,EAAA,GAA+C;AArC9G,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AAsCE,EAAA,GAAA,CAAA,CAAI,GAAA,EAAA,OAAA,CAAQ,QAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAkB,QAAA,EAAU;AAC9B,IAAA,MAAA,CAAO,KAAA,CAAM,8CAA8C,CAAA;AAC3D,IAAA,OAAO,gBAAA,CAAiB,MAAM,CAAA;AAAA,EAChC;AAEA,EAAA,GAAA,CAAA,CAAI,GAAA,EAAA,OAAA,CAAQ,QAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAkB,sBAAA,EAAwB;AAC5C,IAAA,MAAA,CAAO,KAAA,CAAM,8BAA8B,CAAA;AAC3C,IAAA,OAAO,gBAAA,CAAiB,MAAM,CAAA;AAAA,EAChC;AAEA,EAAA,MAAM,eAAA,EAAiB,UAAA,CAAM,iBAAA,CAAkB,CAAA;AAC/C,EAAA,MAAM,aAAA,EAAe,kBAAA,CAAmB,cAAc,CAAA;AAEtD,EAAA,GAAA,CAAI,aAAA,GAAgB,CAAA,CAAA,CAAC,GAAA,EAAA,OAAA,CAAQ,QAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAkB,yCAAA,CAAA,EAA2C;AAChF,IAAA,MAAA,CAAO,KAAA;AAAA,MACL,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wEAAA;AAAA,IAQF,CAAA;AACA,IAAA,OAAO,gBAAA,CAAiB,MAAM,CAAA;AAAA,EAChC;AAEA,EAAA,GAAA,CAAI,YAAA,EAAc;AAChB,IAAA,MAAA,CAAO,IAAA;AAAA,MACL;AAAA,IAEF,CAAA;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT,CAAA;AAEA,IAAM,oBAAA,EAAsB,CAAC,OAAA,EAAoC,SAAA,EAAkD,MAAA,EAAA,GAAmB;AA3EtI,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AA+EE,EAAA,GAAA,CAAI,SAAA,CAAU,QAAA,EAAU;AACtB,IAAA,MAAM,qBAAA,EAAA,CACJ,GAAA,EAAA,CAAA,GAAA,EAAA,CAAA,GAAA,EAAA,CAAA,GAAA,EAAA,CAAA,GAAA,EAAA,OAAA,CAAQ,cAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAwB,MAAA,EAAA,GAAxB,KAAA,EAAA,GAAA,EAAA,CACA,GAAA,EAAA,OAAA,CAAQ,mBAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAA6B,MAAA,EAAA,GAD7B,KAAA,EAAA,GAAA,EAAA,CAEA,GAAA,EAAA,OAAA,CAAQ,KAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAe,cAAA,EAAA,GAFf,KAAA,EAAA,GAAA,EAAA,CAGA,GAAA,EAAA,OAAA,CAAQ,KAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAe,cAAA,EAAA,GAHf,KAAA,EAAA,GAAA,EAIA,OAAA,CAAQ,aAAA;AAEV,IAAA,GAAA,CAAI,CAAC,oBAAA,EAAsB;AACzB,MAAA,MAAM,aAAA,EACJ,4iBAAA;AASF,MAAA,GAAA,CAAA,CAAI,GAAA,EAAA,OAAA,CAAQ,QAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAkB,iBAAA,EAAmB;AACvC,QAAA,MAAM,IAAI,KAAA,CAAM,YAAY,CAAA;AAAA,MAC9B,EAAA,KAAO;AACL,QAAA,MAAA,CAAO,KAAA,CAAM,YAAY,CAAA;AAAA,MAC3B;AAAA,IACF;AAAA,EACF;AACF,CAAA;AAEO,SAAS,kBAAA,CAAmB,QAAA,EAAqC,CAAC,CAAA,EAAwB;AA3GjG,EAAA,IAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA,EAAA;AA4GE,EAAA,MAAM,OAAA,EAAA,CAAS,GAAA,EAAA,CAAA,GAAA,EAAA,OAAA,CAAQ,KAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAe,MAAA,EAAA,GAAf,KAAA,EAAA,GAAA,EAAyB,IAAI,mCAAA,CAAc;AAAA,IACxD,KAAA,EAAA,CAAO,GAAA,EAAA,CAAA,GAAA,EAAA,OAAA,CAAQ,KAAA,EAAA,GAAR,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAe,QAAA,EAAA,GAAf,KAAA,EAAA,GAAA,EAA2B,MAAA;AAAA,IAClC,MAAA,EAAQ;AAAA,EACV,CAAC,CAAA;AAED,EAAA,+DAAA;AAAiC,IAC/B,MAAA;AAAA,IACA,WAAA,EAAa,OAAA,CAAQ;AAAA,EACvB,CAAC,CAAA;AAED,EAAA,MAAM,UAAA,EAAY,iBAAA,CAAkB,OAAA,EAAS,MAAM,CAAA;AACnD,EAAA,GAAA,CAAI,SAAA,EAAW,OAAO,SAAA;AAEtB,EAAA,IAAI;AACF,IAAA,MAAM,IAAA,EAAM,qBAAA,CAAsB,OAAA,EAAS,MAAA,EAAQ,oBAAA;AAAA,MACjD,OAAA,CAAQ,UAAA;AAAA,MACR,OAAA,CAAQ,WAAA;AAAA,MACR,OAAA,CAAQ;AAAA,IACV,CAAC,CAAA;AAED,IAAA,MAAA,CAAO,IAAA,CAAK,0DAA0D,CAAA;AAEtE,IAAA,OAAO;AAAA,MACL,QAAA,EAAU,MAAA,CAAA,EAAA,GAAY;AACpB,QAAA,MAAA,CAAO,KAAA,CAAM,uBAAuB,CAAA;AACpC,QAAA,MAAA,CAAM,IAAA,GAAA,KAAA,EAAA,KAAA,EAAA,EAAA,GAAA,CAAK,QAAA,CAAA,CAAA,CAAA;AACX,QAAA,MAAA,CAAO,IAAA,CAAK,2BAA2B,CAAA;AAAA,MACzC;AAAA,IACF,CAAA;AAAA,EACF,EAAA,MAAA,CAAS,GAAA,EAAK;AACZ,IAAA,MAAM,aAAA,EAAe,IAAA,WAAe,MAAA,EAAQ,GAAA,CAAI,QAAA,EAAU,MAAA,CAAO,GAAG,CAAA;AACpE,IAAA,MAAA,CAAO,KAAA,CAAM,CAAA,8BAAA,EAAiC,YAAY,CAAA,CAAA;AAEnB,IAAA;AACG,MAAA;AAC1C,IAAA;AAEsB,IAAA;AACQ,IAAA;AAChC,EAAA;AACF;AAMW;AA1JX,EAAA;AA2J8C,EAAA;AAEpB,EAAA;AACV,IAAA;AACP,EAAA;AACiD,IAAA;AACxD,EAAA;AAEyC,EAAA;AACI,EAAA;AAG1B,EAAA;AAC+B,IAAA;AACnC,IAAA;AACf,EAAA;AACmB,EAAA;AACmC,IAAA;AACvC,IAAA;AACf,EAAA;AAEyB,EAAA;AAC0B,IAAA;AAC7B,MAAA;AACE,MAAA;AACrB,IAAA;AAC6C,IAAA;AAC1B,MAAA;AACE,MAAA;AACrB,IAAA;AAEwC,IAAA;AACkB,MAAA;AACV,MAAA;AACQ,MAAA;AAClD,IAAA;AACoD,MAAA;AACT,MAAA;AACO,MAAA;AACzD,IAAA;AACF,EAAA;AAE2B,EAAA;AAC2B,IAAA;AACG,IAAA;AACzD,EAAA;AAE4B,EAAA;AACmB,IAAA;AACc,IAAA;AAC7D,EAAA;AACiC,EAAA;AACkB,IAAA;AACL,IAAA;AAC9C,EAAA;AAE8C,EAAA;AAGI,EAAA;AAChD,IAAA;AACY,IAAA;AACT,EAAA;AAEe,EAAA;AAC8B,IAAA;AAClD,EAAA;AAEwB,EAAA;AACtB,IAAA;AACqB,IAAA;AACQ,IAAA;AACL,IAAA;AACG,IAAA;AACL,IAAA;AACP,IAAA;AACY,IAAA;AACV,IAAA;AACjB,IAAA;AACqB,IAAA;AACD,IAAA;AACC,IAAA;AACK,IAAA;AAC3B,EAAA;AAES,EAAA;AACgC,EAAA;AAIC,EAAA;AAEtB,IAAA;AAC8B,MAAA;AAGP,MAAA;AAC1B,QAAA;AAGiC,QAAA;AAE3B,QAAA;AAE0B,UAAA;AAC9B,UAAA;AACP,QAAA;AACQ,UAAA;AACf,QAAA;AACK,MAAA;AAC0C,QAAA;AACjD,MAAA;AACD,IAAA;AACH,EAAA;AAEoB,EAAA;AACuB,IAAA;AACG,IAAA;AAC9C,EAAA;AAEuB,EAAA;AACA,IAAA;AAE6E,IAAA;AAC5E,MAAA;AACH,MAAA;AAEuC,MAAA;AACpD,MAAA;AACiB,QAAA;AAC2B,QAAA;AAClC,MAAA;AACyC,QAAA;AACrD,MAAA;AACe,QAAA;AACC,UAAA;AAChB,QAAA;AACF,MAAA;AACF,IAAA;AAG+B,IAAA;AAC4B,MAAA;AAC1D,IAAA;AAG0B,IAAA;AAC4B,MAAA;AACtD,IAAA;AAG2B,IAAA;AAC4B,MAAA;AACvD,IAAA;AACH,EAAA;AAEO,EAAA;AACT;AAwBsD;AACL,EAAA;AACO,EAAA;AAGpC,EAAA;AACT,IAAA;AACiB,MAAA;AAEtB,MAAA;AACF,IAAA;AACF,EAAA;AAGoC,EAAA;AAC3B,IAAA;AACiB,MAAA;AAEtB,MAAA;AACF,IAAA;AACF,EAAA;AAG0B,EAAA;AAC5B;ADhC+D;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-JWF5KHWM.js","sourcesContent":[null,"import { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport { SimpleLogRecordProcessor, BatchLogRecordProcessor, type LogRecordProcessor, ConsoleLogRecordExporter, LoggerProvider } from \"@opentelemetry/sdk-logs\";\nimport { createMergedResource, isConcreteProvider } from \"../utils\";\nimport { type SetupObservabilityOptions, type ObservabilityHandle } from \"./types\";\nimport { trace } from \"@opentelemetry/api\";\nimport {\n ConsoleSpanExporter,\n SimpleSpanProcessor,\n BatchSpanProcessor,\n type SpanProcessor,\n} from \"@opentelemetry/sdk-trace-base\";\nimport { type Resource } from \"@opentelemetry/resources\";\nimport { LangWatchLogsExporter, LangWatchTraceExporter } from \"../../exporters\";\nimport { ConsoleLogger, type Logger } from \"../../../logger\";\nimport { initializeObservabilitySdkConfig } from \"../../config\";\nimport { setLangWatchLoggerProvider } from \"../../logger\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\n// Helper functions\nconst createNoOpHandle = (logger: Logger): ObservabilityHandle => ({\n shutdown: async () => {\n logger.debug(\"Shutdown called for LangWatch no-op. Nothing will be shutdown\");\n },\n});\n\nconst getLangWatchConfig = (options: SetupObservabilityOptions) => {\n const isDisabled = options.langwatch === 'disabled';\n const config = typeof options.langwatch === 'object' ? options.langwatch : {};\n\n return {\n disabled: isDisabled,\n apiKey: isDisabled ? void 0 : (config.apiKey ?? process.env.LANGWATCH_API_KEY),\n endpoint: isDisabled ? void 0 : (config.endpoint ?? process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT),\n processorType: config.processorType ?? 'batch'\n };\n};\n\nconst checkForEarlyExit = (options: SetupObservabilityOptions, logger: Logger): ObservabilityHandle | null => {\n if (options.advanced?.disabled) {\n logger.debug(\"Observability disabled via advanced.disabled\");\n return createNoOpHandle(logger);\n }\n\n if (options.advanced?.skipOpenTelemetrySetup) {\n logger.debug(\"Skipping OpenTelemetry setup\");\n return createNoOpHandle(logger);\n }\n\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n\n if (alreadySetup && !options.advanced?.UNSAFE_forceOpenTelemetryReinitialization) {\n logger.error(\n `OpenTelemetry is already set up in this process.\\n` +\n `Spans will NOT be sent to LangWatch unless you add the LangWatch span processor or exporter to your existing OpenTelemetry setup.\\n` +\n `You must either:\\n` +\n ` 1. Remove your existing OpenTelemetry setup and only use LangWatch,\\n` +\n ` 2. Add the LangWatch span processor to your existing setup, or replace the existing exporter with the LangWatch exporter.\\n` +\n `\\nFor step-by-step instructions, see the LangWatch docs and check out the integration guide for your framework:\\n` +\n ` https://docs.langwatch.ai/integration/typescript/guide\\n` +\n `\\nSee also: https://github.com/open-telemetry/opentelemetry-js/issues/5299`,\n );\n return createNoOpHandle(logger);\n }\n\n if (alreadySetup) {\n logger.warn(\n \"OpenTelemetry is already set up, but UNSAFE_forceOpenTelemetryReinitialization=true. \" +\n \"Proceeding with reinitialization. This may cause conflicts.\"\n );\n }\n\n return null;\n};\n\nconst warnIfMisconfigured = (options: SetupObservabilityOptions, langwatch: ReturnType<typeof getLangWatchConfig>, logger: Logger) => {\n // Check if LangWatch is disabled but no alternative export mechanisms are provided\n // Note: If we reach this function, we know advanced.disabled and advanced.skipOpenTelemetrySetup are false\n // because those are handled as early exits in setupObservability()\n if (langwatch.disabled) {\n const hasAlternativeExport =\n options.spanProcessors?.length ??\n options.logRecordProcessors?.length ??\n options.debug?.consoleTracing ??\n options.debug?.consoleLogging ??\n options.traceExporter;\n\n if (!hasAlternativeExport) {\n const errorMessage =\n \"LangWatch integration is disabled but no custom span processors, trace exporters, or console tracing is configured. \" +\n \"OpenTelemetry will be set up but traces will not be exported anywhere. \" +\n \"Either:\\n\" +\n \" 1. Enable LangWatch integration (remove langwatch: 'disabled')\\n\" +\n \" 2. Provide custom spanProcessors, logRecordProcessors, or traceExporter\\n\" +\n \" 3. Enable debug.consoleTracing or debug.consoleLogging for development\\n\" +\n \" 4. Use advanced.disabled to completely disable observability\\n\" +\n \" 5. Use advanced.skipOpenTelemetrySetup to handle OpenTelemetry setup yourself\";\n\n if (options.advanced?.throwOnSetupError) {\n throw new Error(errorMessage);\n } else {\n logger.error(errorMessage);\n }\n }\n }\n};\n\nexport function setupObservability(options: SetupObservabilityOptions = {}): ObservabilityHandle {\n const logger = options.debug?.logger ?? new ConsoleLogger({\n level: options.debug?.logLevel ?? 'warn',\n prefix: \"LangWatch Observability SDK\",\n });\n\n initializeObservabilitySdkConfig({\n logger,\n dataCapture: options.dataCapture,\n });\n\n const earlyExit = checkForEarlyExit(options, logger);\n if (earlyExit) return earlyExit;\n\n try {\n const sdk = createAndStartNodeSdk(options, logger, createMergedResource(\n options.attributes,\n options.serviceName,\n options.resource,\n ));\n\n logger.info(\"LangWatch Observability SDK setup completed successfully\");\n\n return {\n shutdown: async () => {\n logger.debug(\"Shutting down NodeSDK\");\n await sdk?.shutdown();\n logger.info(\"NodeSDK shutdown complete\");\n },\n };\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : String(err);\n logger.error(`Failed to initialize NodeSDK: ${errorMessage}`);\n\n if (err instanceof Error && err.stack) {\n logger.debug(`Stack trace: ${err.stack}`);\n }\n\n if (options.advanced?.throwOnSetupError) throw err;\n return createNoOpHandle(logger);\n }\n}\n\nexport function createAndStartNodeSdk(\n options: SetupObservabilityOptions,\n logger: Logger,\n resource: Resource,\n): NodeSDK {\n const langwatch = getLangWatchConfig(options);\n\n if (langwatch.disabled) {\n logger.warn(\"LangWatch integration disabled, using user-provided SpanProcessors and LogRecordProcessors\");\n } else {\n logger.info(`Using LangWatch ${langwatch.processorType} processors for tracing and logging`);\n }\n\n const spanProcessors: SpanProcessor[] = [];\n const logProcessors: LogRecordProcessor[] = [];\n\n // Console processors\n if (options.debug?.consoleTracing) {\n spanProcessors.push(new SimpleSpanProcessor(new ConsoleSpanExporter()));\n logger.debug(\"Console tracing enabled; adding console span exporter\");\n }\n if (options.debug?.consoleLogging) {\n logProcessors.push(new SimpleLogRecordProcessor(new ConsoleLogRecordExporter()));\n logger.debug(\"Console recording of logs enabled; adding console log record processor\");\n }\n\n if (!langwatch.disabled) {\n const traceExporter = new LangWatchTraceExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n const logExporter = new LangWatchLogsExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n\n if (langwatch.processorType === 'batch') {\n spanProcessors.push(new BatchSpanProcessor(traceExporter));\n logProcessors.push(new BatchLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n } else {\n spanProcessors.push(new SimpleSpanProcessor(traceExporter));\n logProcessors.push(new SimpleLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n }\n }\n\n if (options.traceExporter) {\n spanProcessors.push(new SimpleSpanProcessor(options.traceExporter));\n logger.debug(`Added user-provided SpanProcessor to SDK`);\n }\n\n if (options.spanProcessors?.length) {\n spanProcessors.push(...options.spanProcessors);\n logger.debug(`Added user-provided ${options.spanProcessors.length} SpanProcessors to SDK`);\n }\n if (options.logRecordProcessors?.length) {\n logProcessors.push(...options.logRecordProcessors);\n logger.debug(`Added user-provided ${options.logRecordProcessors.length} LogRecordProcessors to SDK`);\n }\n\n warnIfMisconfigured(options, langwatch, logger);\n\n // Create logger provider\n const loggerProvider = logProcessors.length ? new LoggerProvider({\n resource,\n processors: logProcessors,\n }) : void 0;\n\n if (loggerProvider) {\n logger.debug(\"Created LangWatch logger provider\");\n }\n\n const sdk = new NodeSDK({\n resource,\n serviceName: options.serviceName,\n autoDetectResources: options.autoDetectResources,\n contextManager: options.contextManager,\n textMapPropagator: options.textMapPropagator,\n metricReader: options.metricReader,\n views: options.views,\n resourceDetectors: options.resourceDetectors,\n sampler: options.sampler,\n spanProcessors,\n logRecordProcessors: logProcessors,\n spanLimits: options.spanLimits,\n idGenerator: options.idGenerator,\n instrumentations: options.instrumentations,\n });\n\n sdk.start();\n logger.info(\"NodeSDK started successfully\");\n\n // Fix for Next.js 15: Explicitly verify and register provider if still proxy\n // See: https://github.com/langwatch/langwatch/issues/753\n if (process.env.NEXT_RUNTIME === 'nodejs') {\n // Wait a tick to ensure SDK initialization completes\n setImmediate(() => {\n const globalProvider = trace.getTracerProvider();\n\n // Check if provider is still a proxy (Next.js 15 issue)\n if (globalProvider.constructor.name === 'ProxyTracerProvider') {\n logger.warn('Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround');\n\n // Access the real provider from the delegate\n const realProvider = (globalProvider as any)._delegate;\n\n if (realProvider?.constructor.name === 'NodeTracerProvider') {\n // Explicitly register the real provider globally\n trace.setGlobalTracerProvider(realProvider);\n logger.info('Successfully registered NodeTracerProvider globally for Next.js 15');\n } else {\n logger.error('Could not find NodeTracerProvider in proxy delegate - spans may not be exported');\n }\n } else {\n logger.debug(`Provider registered correctly: ${globalProvider.constructor.name}`);\n }\n });\n }\n\n if (loggerProvider) {\n setLangWatchLoggerProvider(loggerProvider);\n logger.debug(\"Set LangWatch logger provider\");\n }\n\n if (!options.advanced?.disableAutoShutdown) {\n let isShuttingDown = false;\n\n const gracefulShutdown = async ({ signal, exitAfter }: { signal: string; exitAfter: boolean }) => {\n if (isShuttingDown) return;\n isShuttingDown = true;\n\n logger.debug(`${signal}: shutting down OpenTelemetry...`);\n try {\n await sdk.shutdown();\n logger.debug('OpenTelemetry shutdown complete');\n } catch (err) {\n logger.error('Error shutting down OpenTelemetry', err);\n } finally {\n if (exitAfter) {\n process.exit(0);\n }\n }\n };\n\n // Normal process exit when event loop drains (e.g. CLI scripts, one-shot programs)\n process.on('beforeExit', () => {\n void gracefulShutdown({ signal: 'beforeExit', exitAfter: false });\n });\n\n // Ctrl+C\n process.on('SIGINT', () => {\n void gracefulShutdown({ signal: 'SIGINT', exitAfter: true });\n });\n\n // External kill / Docker stop / k8s pod termination\n process.on('SIGTERM', () => {\n void gracefulShutdown({ signal: 'SIGTERM', exitAfter: true });\n });\n }\n\n return sdk;\n}\n\n/**\n * Ensure observability is set up, but only if not already configured.\n * \n * This is an idempotent function that:\n * - Does nothing if OpenTelemetry is already configured (by you or another library)\n * - Sets up LangWatch observability if no tracer provider exists\n * - Does nothing if LANGWATCH_API_KEY is not set\n * \n * This is useful for libraries/SDKs that want to ensure tracing is available\n * without conflicting with user's existing observability setup.\n * \n * @example\n * ```typescript\n * import { ensureSetup } from \"langwatch/observability/node\";\n * \n * // Safe to call - won't conflict with existing setup\n * ensureSetup();\n * \n * // Now you can use tracing\n * const tracer = trace.getTracer(\"my-app\");\n * ```\n */\nexport const ensureSetup = (): ObservabilityHandle => {\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n \n // If already set up, return no-op handle (don't log error, just silently skip)\n if (alreadySetup) {\n return {\n shutdown: async () => {\n // No-op - we didn't set up anything\n },\n };\n }\n \n // If no API key, return no-op handle (can't set up without it)\n if (!process.env.LANGWATCH_API_KEY) {\n return {\n shutdown: async () => {\n // No-op - no API key available\n },\n };\n }\n \n // Set up observability with defaults\n return setupObservability();\n};\n","import {\n defaultResource,\n type Resource,\n resourceFromAttributes,\n} from \"@opentelemetry/resources\";\nimport { type Attributes } from \"@opentelemetry/api\";\nimport * as semconv from \"@opentelemetry/semantic-conventions/incubating\";\nimport {\n LANGWATCH_SDK_LANGUAGE,\n LANGWATCH_SDK_VERSION,\n DEFAULT_SERVICE_NAME,\n LANGWATCH_SDK_NAME_OBSERVABILITY,\n} from \"../../internal/constants\";\nimport {\n ATTR_LANGWATCH_SDK_NAME,\n ATTR_LANGWATCH_SDK_VERSION,\n ATTR_LANGWATCH_SDK_LANGUAGE,\n} from \"../semconv/attributes\";\n\n/**\n * Creates a merged resource from the given attributes, service name, and given resource.\n */\nexport function createMergedResource(\n attributes: Attributes | undefined,\n serviceName: string | undefined,\n givenResource: Resource | undefined,\n): Resource {\n const langwatchResource = resourceFromAttributes({\n [ATTR_LANGWATCH_SDK_NAME]: LANGWATCH_SDK_NAME_OBSERVABILITY,\n [ATTR_LANGWATCH_SDK_LANGUAGE]: LANGWATCH_SDK_LANGUAGE,\n [ATTR_LANGWATCH_SDK_VERSION]: LANGWATCH_SDK_VERSION,\n });\n\n const userResource = resourceFromAttributes({\n [semconv.ATTR_SERVICE_NAME]: serviceName ?? DEFAULT_SERVICE_NAME,\n ...(attributes ?? {}),\n });\n\n return (givenResource ?? defaultResource())\n .merge(langwatchResource)\n .merge(userResource);\n}\n\n/**\n * Returns the concrete OpenTelemetry provider (NodeTracerProvider or BasicTracerProvider),\n * either from the given provider or its delegate, or undefined if not found.\n */\nexport function getConcreteProvider(provider: unknown): unknown {\n if (!provider || typeof provider !== \"object\") return undefined;\n\n // Check provider itself\n const constructorName = (provider as any).constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(constructorName)) {\n return provider;\n }\n if (typeof (provider as any).addSpanProcessor === \"function\") {\n return provider;\n }\n\n // Check one level of delegate (ProxyTracerProvider pattern)\n let delegate;\n if (typeof (provider as any).getDelegate === \"function\") {\n delegate = (provider as any).getDelegate();\n } else if ((provider as any).delegate) {\n delegate = (provider as any).delegate;\n } else if ((provider as any)._delegate) {\n // Also check for _delegate (OpenTelemetry's actual property name)\n // See: https://github.com/langwatch/langwatch/issues/753\n delegate = (provider as any)._delegate;\n }\n\n if (delegate && typeof delegate === \"object\") {\n const delegateConstructorName = delegate.constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(delegateConstructorName)) {\n return delegate;\n }\n if (typeof delegate.addSpanProcessor === \"function\") {\n return delegate;\n }\n }\n\n return void 0;\n}\n\n/**\n * Returns true if the given provider (or its delegate) is a concrete OpenTelemetry provider.\n */\nexport function isConcreteProvider(provider: unknown): boolean {\n return !!getConcreteProvider(provider);\n}\n\n"]}
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-YNIDOE6Q.js","../src/observability-sdk/setup/node/setup.ts","../src/observability-sdk/setup/utils.ts"],"names":[],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-YNIDOE6Q.js","sourcesContent":[null,"import { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport { SimpleLogRecordProcessor, BatchLogRecordProcessor, type LogRecordProcessor, ConsoleLogRecordExporter, LoggerProvider } from \"@opentelemetry/sdk-logs\";\nimport { createMergedResource, isConcreteProvider } from \"../utils\";\nimport { type SetupObservabilityOptions, type ObservabilityHandle } from \"./types\";\nimport { trace } from \"@opentelemetry/api\";\nimport {\n ConsoleSpanExporter,\n SimpleSpanProcessor,\n BatchSpanProcessor,\n type SpanProcessor,\n} from \"@opentelemetry/sdk-trace-base\";\nimport { type Resource } from \"@opentelemetry/resources\";\nimport { LangWatchLogsExporter, LangWatchTraceExporter } from \"../../exporters\";\nimport { ConsoleLogger, type Logger } from \"../../../logger\";\nimport { initializeObservabilitySdkConfig } from \"../../config\";\nimport { setLangWatchLoggerProvider } from \"../../logger\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\n// Helper functions\nconst createNoOpHandle = (logger: Logger): ObservabilityHandle => ({\n shutdown: async () => {\n logger.debug(\"Shutdown called for LangWatch no-op. Nothing will be shutdown\");\n },\n});\n\nconst getLangWatchConfig = (options: SetupObservabilityOptions) => {\n const isDisabled = options.langwatch === 'disabled';\n const config = typeof options.langwatch === 'object' ? options.langwatch : {};\n\n return {\n disabled: isDisabled,\n apiKey: isDisabled ? void 0 : (config.apiKey ?? process.env.LANGWATCH_API_KEY),\n endpoint: isDisabled ? void 0 : (config.endpoint ?? process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT),\n processorType: config.processorType ?? 'batch'\n };\n};\n\nconst checkForEarlyExit = (options: SetupObservabilityOptions, logger: Logger): ObservabilityHandle | null => {\n if (options.advanced?.disabled) {\n logger.debug(\"Observability disabled via advanced.disabled\");\n return createNoOpHandle(logger);\n }\n\n if (options.advanced?.skipOpenTelemetrySetup) {\n logger.debug(\"Skipping OpenTelemetry setup\");\n return createNoOpHandle(logger);\n }\n\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n\n if (alreadySetup && !options.advanced?.UNSAFE_forceOpenTelemetryReinitialization) {\n logger.error(\n `OpenTelemetry is already set up in this process.\\n` +\n `Spans will NOT be sent to LangWatch unless you add the LangWatch span processor or exporter to your existing OpenTelemetry setup.\\n` +\n `You must either:\\n` +\n ` 1. Remove your existing OpenTelemetry setup and only use LangWatch,\\n` +\n ` 2. Add the LangWatch span processor to your existing setup, or replace the existing exporter with the LangWatch exporter.\\n` +\n `\\nFor step-by-step instructions, see the LangWatch docs and check out the integration guide for your framework:\\n` +\n ` https://docs.langwatch.ai/integration/typescript/guide\\n` +\n `\\nSee also: https://github.com/open-telemetry/opentelemetry-js/issues/5299`,\n );\n return createNoOpHandle(logger);\n }\n\n if (alreadySetup) {\n logger.warn(\n \"OpenTelemetry is already set up, but UNSAFE_forceOpenTelemetryReinitialization=true. \" +\n \"Proceeding with reinitialization. This may cause conflicts.\"\n );\n }\n\n return null;\n};\n\nconst warnIfMisconfigured = (options: SetupObservabilityOptions, langwatch: ReturnType<typeof getLangWatchConfig>, logger: Logger) => {\n // Check if LangWatch is disabled but no alternative export mechanisms are provided\n // Note: If we reach this function, we know advanced.disabled and advanced.skipOpenTelemetrySetup are false\n // because those are handled as early exits in setupObservability()\n if (langwatch.disabled) {\n const hasAlternativeExport =\n options.spanProcessors?.length ??\n options.logRecordProcessors?.length ??\n options.debug?.consoleTracing ??\n options.debug?.consoleLogging ??\n options.traceExporter;\n\n if (!hasAlternativeExport) {\n const errorMessage =\n \"LangWatch integration is disabled but no custom span processors, trace exporters, or console tracing is configured. \" +\n \"OpenTelemetry will be set up but traces will not be exported anywhere. \" +\n \"Either:\\n\" +\n \" 1. Enable LangWatch integration (remove langwatch: 'disabled')\\n\" +\n \" 2. Provide custom spanProcessors, logRecordProcessors, or traceExporter\\n\" +\n \" 3. Enable debug.consoleTracing or debug.consoleLogging for development\\n\" +\n \" 4. Use advanced.disabled to completely disable observability\\n\" +\n \" 5. Use advanced.skipOpenTelemetrySetup to handle OpenTelemetry setup yourself\";\n\n if (options.advanced?.throwOnSetupError) {\n throw new Error(errorMessage);\n } else {\n logger.error(errorMessage);\n }\n }\n }\n};\n\nexport function setupObservability(options: SetupObservabilityOptions = {}): ObservabilityHandle {\n const logger = options.debug?.logger ?? new ConsoleLogger({\n level: options.debug?.logLevel ?? 'warn',\n prefix: \"LangWatch Observability SDK\",\n });\n\n initializeObservabilitySdkConfig({\n logger,\n dataCapture: options.dataCapture,\n });\n\n const earlyExit = checkForEarlyExit(options, logger);\n if (earlyExit) return earlyExit;\n\n try {\n const sdk = createAndStartNodeSdk(options, logger, createMergedResource(\n options.attributes,\n options.serviceName,\n options.resource,\n ));\n\n logger.info(\"LangWatch Observability SDK setup completed successfully\");\n\n return {\n shutdown: async () => {\n logger.debug(\"Shutting down NodeSDK\");\n await sdk?.shutdown();\n logger.info(\"NodeSDK shutdown complete\");\n },\n };\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : String(err);\n logger.error(`Failed to initialize NodeSDK: ${errorMessage}`);\n\n if (err instanceof Error && err.stack) {\n logger.debug(`Stack trace: ${err.stack}`);\n }\n\n if (options.advanced?.throwOnSetupError) throw err;\n return createNoOpHandle(logger);\n }\n}\n\nexport function createAndStartNodeSdk(\n options: SetupObservabilityOptions,\n logger: Logger,\n resource: Resource,\n): NodeSDK {\n const langwatch = getLangWatchConfig(options);\n\n if (langwatch.disabled) {\n logger.warn(\"LangWatch integration disabled, using user-provided SpanProcessors and LogRecordProcessors\");\n } else {\n logger.info(`Using LangWatch ${langwatch.processorType} processors for tracing and logging`);\n }\n\n const spanProcessors: SpanProcessor[] = [];\n const logProcessors: LogRecordProcessor[] = [];\n\n // Console processors\n if (options.debug?.consoleTracing) {\n spanProcessors.push(new SimpleSpanProcessor(new ConsoleSpanExporter()));\n logger.debug(\"Console tracing enabled; adding console span exporter\");\n }\n if (options.debug?.consoleLogging) {\n logProcessors.push(new SimpleLogRecordProcessor(new ConsoleLogRecordExporter()));\n logger.debug(\"Console recording of logs enabled; adding console log record processor\");\n }\n\n if (!langwatch.disabled) {\n const traceExporter = new LangWatchTraceExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n const logExporter = new LangWatchLogsExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n\n if (langwatch.processorType === 'batch') {\n spanProcessors.push(new BatchSpanProcessor(traceExporter));\n logProcessors.push(new BatchLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n } else {\n spanProcessors.push(new SimpleSpanProcessor(traceExporter));\n logProcessors.push(new SimpleLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n }\n }\n\n if (options.traceExporter) {\n spanProcessors.push(new SimpleSpanProcessor(options.traceExporter));\n logger.debug(`Added user-provided SpanProcessor to SDK`);\n }\n\n if (options.spanProcessors?.length) {\n spanProcessors.push(...options.spanProcessors);\n logger.debug(`Added user-provided ${options.spanProcessors.length} SpanProcessors to SDK`);\n }\n if (options.logRecordProcessors?.length) {\n logProcessors.push(...options.logRecordProcessors);\n logger.debug(`Added user-provided ${options.logRecordProcessors.length} LogRecordProcessors to SDK`);\n }\n\n warnIfMisconfigured(options, langwatch, logger);\n\n // Create logger provider\n const loggerProvider = logProcessors.length ? new LoggerProvider({\n resource,\n processors: logProcessors,\n }) : void 0;\n\n if (loggerProvider) {\n logger.debug(\"Created LangWatch logger provider\");\n }\n\n const sdk = new NodeSDK({\n resource,\n serviceName: options.serviceName,\n autoDetectResources: options.autoDetectResources,\n contextManager: options.contextManager,\n textMapPropagator: options.textMapPropagator,\n metricReader: options.metricReader,\n views: options.views,\n resourceDetectors: options.resourceDetectors,\n sampler: options.sampler,\n spanProcessors,\n logRecordProcessors: logProcessors,\n spanLimits: options.spanLimits,\n idGenerator: options.idGenerator,\n instrumentations: options.instrumentations,\n });\n\n sdk.start();\n logger.info(\"NodeSDK started successfully\");\n\n // Fix for Next.js 15: Explicitly verify and register provider if still proxy\n // See: https://github.com/langwatch/langwatch/issues/753\n if (process.env.NEXT_RUNTIME === 'nodejs') {\n // Wait a tick to ensure SDK initialization completes\n setImmediate(() => {\n const globalProvider = trace.getTracerProvider();\n\n // Check if provider is still a proxy (Next.js 15 issue)\n if (globalProvider.constructor.name === 'ProxyTracerProvider') {\n logger.warn('Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround');\n\n // Access the real provider from the delegate\n const realProvider = (globalProvider as any)._delegate;\n\n if (realProvider?.constructor.name === 'NodeTracerProvider') {\n // Explicitly register the real provider globally\n trace.setGlobalTracerProvider(realProvider);\n logger.info('Successfully registered NodeTracerProvider globally for Next.js 15');\n } else {\n logger.error('Could not find NodeTracerProvider in proxy delegate - spans may not be exported');\n }\n } else {\n logger.debug(`Provider registered correctly: ${globalProvider.constructor.name}`);\n }\n });\n }\n\n if (loggerProvider) {\n setLangWatchLoggerProvider(loggerProvider);\n logger.debug(\"Set LangWatch logger provider\");\n }\n\n if (!options.advanced?.disableAutoShutdown) {\n let isShuttingDown = false;\n\n const gracefulShutdown = async ({ signal, exitAfter }: { signal: string; exitAfter: boolean }) => {\n if (isShuttingDown) return;\n isShuttingDown = true;\n\n logger.debug(`${signal}: shutting down OpenTelemetry...`);\n try {\n await sdk.shutdown();\n logger.debug('OpenTelemetry shutdown complete');\n } catch (err) {\n logger.error('Error shutting down OpenTelemetry', err);\n } finally {\n if (exitAfter) {\n process.exit(0);\n }\n }\n };\n\n // Normal process exit when event loop drains (e.g. CLI scripts, one-shot programs)\n process.on('beforeExit', () => {\n void gracefulShutdown({ signal: 'beforeExit', exitAfter: false });\n });\n\n // Ctrl+C\n process.on('SIGINT', () => {\n void gracefulShutdown({ signal: 'SIGINT', exitAfter: true });\n });\n\n // External kill / Docker stop / k8s pod termination\n process.on('SIGTERM', () => {\n void gracefulShutdown({ signal: 'SIGTERM', exitAfter: true });\n });\n }\n\n return sdk;\n}\n\n/**\n * Ensure observability is set up, but only if not already configured.\n * \n * This is an idempotent function that:\n * - Does nothing if OpenTelemetry is already configured (by you or another library)\n * - Sets up LangWatch observability if no tracer provider exists\n * - Does nothing if LANGWATCH_API_KEY is not set\n * \n * This is useful for libraries/SDKs that want to ensure tracing is available\n * without conflicting with user's existing observability setup.\n * \n * @example\n * ```typescript\n * import { ensureSetup } from \"langwatch/observability/node\";\n * \n * // Safe to call - won't conflict with existing setup\n * ensureSetup();\n * \n * // Now you can use tracing\n * const tracer = trace.getTracer(\"my-app\");\n * ```\n */\nexport const ensureSetup = (): ObservabilityHandle => {\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n \n // If already set up, return no-op handle (don't log error, just silently skip)\n if (alreadySetup) {\n return {\n shutdown: async () => {\n // No-op - we didn't set up anything\n },\n };\n }\n \n // If no API key, return no-op handle (can't set up without it)\n if (!process.env.LANGWATCH_API_KEY) {\n return {\n shutdown: async () => {\n // No-op - no API key available\n },\n };\n }\n \n // Set up observability with defaults\n return setupObservability();\n};\n","import {\n defaultResource,\n type Resource,\n resourceFromAttributes,\n} from \"@opentelemetry/resources\";\nimport { type Attributes } from \"@opentelemetry/api\";\nimport * as semconv from \"@opentelemetry/semantic-conventions/incubating\";\nimport {\n LANGWATCH_SDK_LANGUAGE,\n LANGWATCH_SDK_VERSION,\n DEFAULT_SERVICE_NAME,\n LANGWATCH_SDK_NAME_OBSERVABILITY,\n} from \"../../internal/constants\";\nimport {\n ATTR_LANGWATCH_SDK_NAME,\n ATTR_LANGWATCH_SDK_VERSION,\n ATTR_LANGWATCH_SDK_LANGUAGE,\n} from \"../semconv/attributes\";\n\n/**\n * Creates a merged resource from the given attributes, service name, and given resource.\n */\nexport function createMergedResource(\n attributes: Attributes | undefined,\n serviceName: string | undefined,\n givenResource: Resource | undefined,\n): Resource {\n const langwatchResource = resourceFromAttributes({\n [ATTR_LANGWATCH_SDK_NAME]: LANGWATCH_SDK_NAME_OBSERVABILITY,\n [ATTR_LANGWATCH_SDK_LANGUAGE]: LANGWATCH_SDK_LANGUAGE,\n [ATTR_LANGWATCH_SDK_VERSION]: LANGWATCH_SDK_VERSION,\n });\n\n const userResource = resourceFromAttributes({\n [semconv.ATTR_SERVICE_NAME]: serviceName ?? DEFAULT_SERVICE_NAME,\n ...(attributes ?? {}),\n });\n\n return (givenResource ?? defaultResource())\n .merge(langwatchResource)\n .merge(userResource);\n}\n\n/**\n * Returns the concrete OpenTelemetry provider (NodeTracerProvider or BasicTracerProvider),\n * either from the given provider or its delegate, or undefined if not found.\n */\nexport function getConcreteProvider(provider: unknown): unknown {\n if (!provider || typeof provider !== \"object\") return undefined;\n\n // Check provider itself\n const constructorName = (provider as any).constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(constructorName)) {\n return provider;\n }\n if (typeof (provider as any).addSpanProcessor === \"function\") {\n return provider;\n }\n\n // Check one level of delegate (ProxyTracerProvider pattern)\n let delegate;\n if (typeof (provider as any).getDelegate === \"function\") {\n delegate = (provider as any).getDelegate();\n } else if ((provider as any).delegate) {\n delegate = (provider as any).delegate;\n } else if ((provider as any)._delegate) {\n // Also check for _delegate (OpenTelemetry's actual property name)\n // See: https://github.com/langwatch/langwatch/issues/753\n delegate = (provider as any)._delegate;\n }\n\n if (delegate && typeof delegate === \"object\") {\n const delegateConstructorName = delegate.constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(delegateConstructorName)) {\n return delegate;\n }\n if (typeof delegate.addSpanProcessor === \"function\") {\n return delegate;\n }\n }\n\n return void 0;\n}\n\n/**\n * Returns true if the given provider (or its delegate) is a concrete OpenTelemetry provider.\n */\nexport function isConcreteProvider(provider: unknown): boolean {\n return !!getConcreteProvider(provider);\n}\n\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
2
2
|
|
|
3
3
|
|
|
4
|
-
var
|
|
4
|
+
var _chunkBBCZ4LXGjs = require('./chunk-BBCZ4LXG.js');
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
var _chunkF6E4XQQUjs = require('./chunk-F6E4XQQU.js');
|
|
@@ -34,7 +34,7 @@ var createCommand = async (name, options) => {
|
|
|
34
34
|
process.exit(1);
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
|
-
const service =
|
|
37
|
+
const service = _chunkBBCZ4LXGjs.createDatasetService.call(void 0, );
|
|
38
38
|
const spinner = _ora2.default.call(void 0, `Creating dataset "${name}"...`).start();
|
|
39
39
|
try {
|
|
40
40
|
const dataset = await service.createDataset({ name, columnTypes });
|
|
@@ -50,9 +50,13 @@ var createCommand = async (name, options) => {
|
|
|
50
50
|
const colStr = dataset.columnTypes.map((c) => `${c.name}:${c.type}`).join(", ");
|
|
51
51
|
console.log(` ${_chalk2.default.bold("Columns:")} ${colStr}`);
|
|
52
52
|
}
|
|
53
|
+
const viewUrl = dataset.platformUrl;
|
|
54
|
+
if (viewUrl) {
|
|
55
|
+
console.log(` ${_chalk2.default.bold("View:")} ${_chalk2.default.underline(viewUrl)}`);
|
|
56
|
+
}
|
|
53
57
|
} catch (error) {
|
|
54
58
|
spinner.fail("Failed to create dataset");
|
|
55
|
-
|
|
59
|
+
_chunkBBCZ4LXGjs.handleDatasetCommandError.call(void 0, error, "creating dataset");
|
|
56
60
|
}
|
|
57
61
|
};
|
|
58
62
|
|
|
@@ -60,4 +64,4 @@ var createCommand = async (name, options) => {
|
|
|
60
64
|
|
|
61
65
|
|
|
62
66
|
exports.parseColumns = parseColumns; exports.createCommand = createCommand;
|
|
63
|
-
//# sourceMappingURL=chunk-
|
|
67
|
+
//# sourceMappingURL=chunk-Z76KL7SX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-Z76KL7SX.js","../src/cli/commands/dataset/create.ts"],"names":[],"mappings":"AAAA;AACE;AACA;AACF,sDAA4B;AAC5B;AACE;AACF,sDAA4B;AAC5B;AACA;ACRA,4EAAkB;AAClB,oEAAgB;AAaT,IAAM,aAAA,EAAe,CAAC,UAAA,EAAA,GAA4C;AACvE,EAAA,OAAO,UAAA,CAAW,KAAA,CAAM,GAAG,CAAA,CAAE,GAAA,CAAI,CAAC,IAAA,EAAA,GAAS;AAf7C,IAAA,IAAA,EAAA,EAAA,EAAA;AAgBI,IAAA,MAAM,MAAA,EAAQ,IAAA,CAAK,IAAA,CAAK,CAAA,CAAE,KAAA,CAAM,GAAG,CAAA;AACnC,IAAA,GAAA,CAAI,KAAA,CAAM,OAAA,IAAW,EAAA,GAAK,CAAA,CAAA,CAAC,GAAA,EAAA,KAAA,CAAM,CAAC,CAAA,EAAA,GAAP,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAU,IAAA,CAAA,CAAA,EAAA,GAAU,CAAA,CAAA,CAAC,GAAA,EAAA,KAAA,CAAM,CAAC,CAAA,EAAA,GAAP,KAAA,EAAA,KAAA,EAAA,EAAA,EAAA,CAAU,IAAA,CAAA,CAAA,CAAA,EAAQ;AAChE,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,wBAAA,EAA2B,IAAA,CAAK,IAAA,CAAK,CAAC,CAAA,6CAAA;AAAA,MACxC,CAAA;AAAA,IACF;AACA,IAAA,OAAO,EAAE,IAAA,EAAM,KAAA,CAAM,CAAC,CAAA,CAAE,IAAA,CAAK,CAAA,EAAG,IAAA,EAAM,KAAA,CAAM,CAAC,CAAA,CAAE,IAAA,CAAK,EAAE,CAAA;AAAA,EACxD,CAAC,CAAA;AACH,CAAA;AAKO,IAAM,cAAA,EAAgB,MAAA,CAC3B,IAAA,EACA,OAAA,EAAA,GACkB;AAClB,EAAA,0CAAA,CAAY;AAEZ,EAAA,IAAI,YAAA,EAAmC,CAAC,CAAA;AACxC,EAAA,GAAA,CAAI,OAAA,CAAQ,OAAA,EAAS;AACnB,IAAA,IAAI;AACF,MAAA,YAAA,EAAc,YAAA,CAAa,OAAA,CAAQ,OAAO,CAAA;AAAA,IAC5C,EAAA,MAAA,CAAS,KAAA,EAAO;AACd,MAAA,OAAA,CAAQ,KAAA;AAAA,QACN,eAAA,CAAM,GAAA,CAAI,MAAA,WAAiB,MAAA,EAAQ,KAAA,CAAM,QAAA,EAAU,wBAAwB;AAAA,MAC7E,CAAA;AACA,MAAA,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA;AAAA,IAChB;AAAA,EACF;AAEA,EAAA,MAAM,QAAA,EAAU,mDAAA,CAAqB;AACrC,EAAA,MAAM,QAAA,EAAU,2BAAA,CAAI,kBAAA,EAAqB,IAAI,CAAA,IAAA,CAAM,CAAA,CAAE,KAAA,CAAM,CAAA;AAE3D,EAAA,IAAI;AACF,IAAA,MAAM,QAAA,EAAU,MAAM,OAAA,CAAQ,aAAA,CAAc,EAAE,IAAA,EAAM,YAAY,CAAC,CAAA;AAEjE,IAAA,OAAA,CAAQ,OAAA,CAAQ,CAAA,iBAAA,EAAoB,eAAA,CAAM,IAAA,CAAK,OAAA,CAAQ,IAAI,CAAC,CAAA,CAAA;AAE7B,IAAA;AACe,MAAA;AAC5C,MAAA;AACF,IAAA;AAEY,IAAA;AACyC,IAAA;AACE,IAAA;AACnB,IAAA;AAEP,MAAA;AAEwB,MAAA;AACrD,IAAA;AACwB,IAAA;AACX,IAAA;AAC8C,MAAA;AAC3D,IAAA;AACc,EAAA;AACyB,IAAA;AACY,IAAA;AACrD,EAAA;AACF;ADhBiE;AACA;AACA;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-Z76KL7SX.js","sourcesContent":[null,"import chalk from \"chalk\";\nimport ora from \"ora\";\nimport type { DatasetColumnType } from \"@/client-sdk/services/datasets/types\";\nimport { checkApiKey } from \"../../utils/apiKey\";\nimport { createDatasetService } from \"./service-factory\";\nimport { handleDatasetCommandError } from \"./error-handler\";\n\n/**\n * Parses a comma-separated column spec string into DatasetColumnType[].\n *\n * @param columnsStr - Format: \"name:type,name:type\" (e.g. \"input:string,output:string\")\n * @returns Parsed column type definitions\n * @throws Error if the format is invalid\n */\nexport const parseColumns = (columnsStr: string): DatasetColumnType[] => {\n return columnsStr.split(\",\").map((pair) => {\n const parts = pair.trim().split(\":\");\n if (parts.length !== 2 || !parts[0]?.trim() || !parts[1]?.trim()) {\n throw new Error(\n `Invalid column format: \"${pair.trim()}\". Expected \"name:type\" (e.g. \"input:string\")`,\n );\n }\n return { name: parts[0].trim(), type: parts[1].trim() };\n });\n};\n\n/**\n * Creates a new dataset with the given name and optional column types.\n */\nexport const createCommand = async (\n name: string,\n options: { columns?: string; format?: string },\n): Promise<void> => {\n checkApiKey();\n\n let columnTypes: DatasetColumnType[] = [];\n if (options.columns) {\n try {\n columnTypes = parseColumns(options.columns);\n } catch (error) {\n console.error(\n chalk.red(error instanceof Error ? error.message : \"Invalid columns format\"),\n );\n process.exit(1);\n }\n }\n\n const service = createDatasetService();\n const spinner = ora(`Creating dataset \"${name}\"...`).start();\n\n try {\n const dataset = await service.createDataset({ name, columnTypes });\n\n spinner.succeed(`Dataset created: ${chalk.cyan(dataset.slug)}`);\n\n if (options.format === \"json\") {\n console.log(JSON.stringify(dataset, null, 2));\n return;\n }\n\n console.log();\n console.log(` ${chalk.bold(\"ID:\")} ${dataset.id}`);\n console.log(` ${chalk.bold(\"Slug:\")} ${dataset.slug}`);\n if (dataset.columnTypes.length > 0) {\n const colStr = dataset.columnTypes\n .map((c) => `${c.name}:${c.type}`)\n .join(\", \");\n console.log(` ${chalk.bold(\"Columns:\")} ${colStr}`);\n }\n const viewUrl = dataset.platformUrl;\n if (viewUrl) {\n console.log(` ${chalk.bold(\"View:\")} ${chalk.underline(viewUrl)}`);\n }\n } catch (error) {\n spinner.fail(\"Failed to create dataset\");\n handleDatasetCommandError(error, \"creating dataset\");\n }\n};\n"]}
|