@launchdarkly/server-sdk-ai 0.8.1 → 0.9.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/CHANGELOG.md +14 -0
- package/README.md +2 -3
- package/__tests__/LDAIConfigTrackerImpl.test.ts +141 -44
- package/dist/LDAIClientImpl.d.ts.map +1 -1
- package/dist/LDAIClientImpl.js +5 -3
- package/dist/LDAIClientImpl.js.map +1 -1
- package/dist/LDAIConfigTrackerImpl.d.ts +2 -1
- package/dist/LDAIConfigTrackerImpl.d.ts.map +1 -1
- package/dist/LDAIConfigTrackerImpl.js +3 -1
- package/dist/LDAIConfigTrackerImpl.js.map +1 -1
- package/docs/enums/LDFeedbackKind.html +6 -6
- package/docs/functions/createBedrockTokenUsage.html +4 -4
- package/docs/functions/initAi.html +4 -4
- package/docs/index.html +4 -4
- package/docs/interfaces/LDAIClient.html +5 -5
- package/docs/interfaces/LDAIConfig.html +9 -9
- package/docs/interfaces/LDAIConfigTracker.html +14 -14
- package/docs/interfaces/LDMessage.html +6 -6
- package/docs/interfaces/LDModelConfig.html +7 -7
- package/docs/interfaces/LDProviderConfig.html +5 -5
- package/docs/interfaces/LDTokenUsage.html +7 -7
- package/docs/types/LDAIDefaults.html +4 -4
- package/package.json +1 -1
- package/src/LDAIClientImpl.ts +3 -0
- package/src/LDAIConfigTrackerImpl.ts +3 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,19 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [0.9.0](https://github.com/launchdarkly/js-core/compare/server-sdk-ai-v0.8.2...server-sdk-ai-v0.9.0) (2025-02-06)
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
### Features
|
|
7
|
+
|
|
8
|
+
* add support for versioned metrics for AI Configs ([#773](https://github.com/launchdarkly/js-core/issues/773)) ([a3f756f](https://github.com/launchdarkly/js-core/commit/a3f756f3c3207a068115b147d5c7439e204b7ae4))
|
|
9
|
+
|
|
10
|
+
## [0.8.2](https://github.com/launchdarkly/js-core/compare/server-sdk-ai-v0.8.1...server-sdk-ai-v0.8.2) (2025-01-27)
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
### Bug Fixes
|
|
14
|
+
|
|
15
|
+
* **docs:** Node.js AI SDK: modelConfig --> config in readme ([#765](https://github.com/launchdarkly/js-core/issues/765)) ([4d46117](https://github.com/launchdarkly/js-core/commit/4d4611700e7eebd9a7d6f8fd596a7a4ff3310802))
|
|
16
|
+
|
|
3
17
|
## [0.8.1](https://github.com/launchdarkly/js-core/compare/server-sdk-ai-v0.8.0...server-sdk-ai-v0.8.1) (2025-01-24)
|
|
4
18
|
|
|
5
19
|
|
package/README.md
CHANGED
|
@@ -21,8 +21,7 @@
|
|
|
21
21
|
|
|
22
22
|
## Quick Setup
|
|
23
23
|
|
|
24
|
-
This assumes that you have already installed the LaunchDarkly Node.js SDK, or a compatible edge
|
|
25
|
-
SDK.
|
|
24
|
+
This assumes that you have already installed the LaunchDarkly Node.js (server-side) SDK, or a compatible edge SDK.
|
|
26
25
|
|
|
27
26
|
1. Install this package with `npm` or `yarn`:
|
|
28
27
|
|
|
@@ -40,7 +39,7 @@ const aiClient = initAi(ldClient);
|
|
|
40
39
|
3. Evaluate a model configuration:
|
|
41
40
|
|
|
42
41
|
```typescript
|
|
43
|
-
const config = await aiClient.
|
|
42
|
+
const config = await aiClient.config(
|
|
44
43
|
aiConfigKey!,
|
|
45
44
|
context,
|
|
46
45
|
{ enabled: false },
|
|
@@ -14,25 +14,38 @@ const mockLdClient: LDClientMin = {
|
|
|
14
14
|
const testContext: LDContext = { kind: 'user', key: 'test-user' };
|
|
15
15
|
const configKey = 'test-config';
|
|
16
16
|
const variationKey = 'v1';
|
|
17
|
+
const version = 1;
|
|
17
18
|
|
|
18
19
|
beforeEach(() => {
|
|
19
20
|
jest.clearAllMocks();
|
|
20
21
|
});
|
|
21
22
|
|
|
22
23
|
it('tracks duration', () => {
|
|
23
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
24
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
25
|
+
mockLdClient,
|
|
26
|
+
configKey,
|
|
27
|
+
variationKey,
|
|
28
|
+
version,
|
|
29
|
+
testContext,
|
|
30
|
+
);
|
|
24
31
|
tracker.trackDuration(1000);
|
|
25
32
|
|
|
26
33
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
27
34
|
'$ld:ai:duration:total',
|
|
28
35
|
testContext,
|
|
29
|
-
{ configKey, variationKey },
|
|
36
|
+
{ configKey, variationKey, version },
|
|
30
37
|
1000,
|
|
31
38
|
);
|
|
32
39
|
});
|
|
33
40
|
|
|
34
41
|
it('tracks duration of async function', async () => {
|
|
35
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
42
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
43
|
+
mockLdClient,
|
|
44
|
+
configKey,
|
|
45
|
+
variationKey,
|
|
46
|
+
version,
|
|
47
|
+
testContext,
|
|
48
|
+
);
|
|
36
49
|
jest.spyOn(global.Date, 'now').mockReturnValueOnce(1000).mockReturnValueOnce(2000);
|
|
37
50
|
|
|
38
51
|
const result = await tracker.trackDurationOf(async () => 'test-result');
|
|
@@ -41,61 +54,91 @@ it('tracks duration of async function', async () => {
|
|
|
41
54
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
42
55
|
'$ld:ai:duration:total',
|
|
43
56
|
testContext,
|
|
44
|
-
{ configKey, variationKey },
|
|
57
|
+
{ configKey, variationKey, version },
|
|
45
58
|
1000,
|
|
46
59
|
);
|
|
47
60
|
});
|
|
48
61
|
|
|
49
62
|
it('tracks time to first token', () => {
|
|
50
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
63
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
64
|
+
mockLdClient,
|
|
65
|
+
configKey,
|
|
66
|
+
variationKey,
|
|
67
|
+
version,
|
|
68
|
+
testContext,
|
|
69
|
+
);
|
|
51
70
|
tracker.trackTimeToFirstToken(1000);
|
|
52
71
|
|
|
53
72
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
54
73
|
'$ld:ai:tokens:ttf',
|
|
55
74
|
testContext,
|
|
56
|
-
{ configKey, variationKey },
|
|
75
|
+
{ configKey, variationKey, version },
|
|
57
76
|
1000,
|
|
58
77
|
);
|
|
59
78
|
});
|
|
60
79
|
|
|
61
80
|
it('tracks positive feedback', () => {
|
|
62
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
81
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
82
|
+
mockLdClient,
|
|
83
|
+
configKey,
|
|
84
|
+
variationKey,
|
|
85
|
+
version,
|
|
86
|
+
testContext,
|
|
87
|
+
);
|
|
63
88
|
tracker.trackFeedback({ kind: LDFeedbackKind.Positive });
|
|
64
89
|
|
|
65
90
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
66
91
|
'$ld:ai:feedback:user:positive',
|
|
67
92
|
testContext,
|
|
68
|
-
{ configKey, variationKey },
|
|
93
|
+
{ configKey, variationKey, version },
|
|
69
94
|
1,
|
|
70
95
|
);
|
|
71
96
|
});
|
|
72
97
|
|
|
73
98
|
it('tracks negative feedback', () => {
|
|
74
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
99
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
100
|
+
mockLdClient,
|
|
101
|
+
configKey,
|
|
102
|
+
variationKey,
|
|
103
|
+
version,
|
|
104
|
+
testContext,
|
|
105
|
+
);
|
|
75
106
|
tracker.trackFeedback({ kind: LDFeedbackKind.Negative });
|
|
76
107
|
|
|
77
108
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
78
109
|
'$ld:ai:feedback:user:negative',
|
|
79
110
|
testContext,
|
|
80
|
-
{ configKey, variationKey },
|
|
111
|
+
{ configKey, variationKey, version },
|
|
81
112
|
1,
|
|
82
113
|
);
|
|
83
114
|
});
|
|
84
115
|
|
|
85
116
|
it('tracks success', () => {
|
|
86
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
117
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
118
|
+
mockLdClient,
|
|
119
|
+
configKey,
|
|
120
|
+
variationKey,
|
|
121
|
+
version,
|
|
122
|
+
testContext,
|
|
123
|
+
);
|
|
87
124
|
tracker.trackSuccess();
|
|
88
125
|
|
|
89
126
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
90
127
|
'$ld:ai:generation',
|
|
91
128
|
testContext,
|
|
92
|
-
{ configKey, variationKey },
|
|
129
|
+
{ configKey, variationKey, version },
|
|
93
130
|
1,
|
|
94
131
|
);
|
|
95
132
|
});
|
|
96
133
|
|
|
97
134
|
it('tracks OpenAI usage', async () => {
|
|
98
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
135
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
136
|
+
mockLdClient,
|
|
137
|
+
configKey,
|
|
138
|
+
variationKey,
|
|
139
|
+
version,
|
|
140
|
+
testContext,
|
|
141
|
+
);
|
|
99
142
|
jest.spyOn(global.Date, 'now').mockReturnValueOnce(1000).mockReturnValueOnce(2000);
|
|
100
143
|
|
|
101
144
|
const TOTAL_TOKENS = 100;
|
|
@@ -113,41 +156,47 @@ it('tracks OpenAI usage', async () => {
|
|
|
113
156
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
114
157
|
'$ld:ai:duration:total',
|
|
115
158
|
testContext,
|
|
116
|
-
{ configKey, variationKey },
|
|
159
|
+
{ configKey, variationKey, version },
|
|
117
160
|
1000,
|
|
118
161
|
);
|
|
119
162
|
|
|
120
163
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
121
164
|
'$ld:ai:generation',
|
|
122
165
|
testContext,
|
|
123
|
-
{ configKey, variationKey },
|
|
166
|
+
{ configKey, variationKey, version },
|
|
124
167
|
1,
|
|
125
168
|
);
|
|
126
169
|
|
|
127
170
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
128
171
|
'$ld:ai:tokens:total',
|
|
129
172
|
testContext,
|
|
130
|
-
{ configKey, variationKey },
|
|
173
|
+
{ configKey, variationKey, version },
|
|
131
174
|
TOTAL_TOKENS,
|
|
132
175
|
);
|
|
133
176
|
|
|
134
177
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
135
178
|
'$ld:ai:tokens:input',
|
|
136
179
|
testContext,
|
|
137
|
-
{ configKey, variationKey },
|
|
180
|
+
{ configKey, variationKey, version },
|
|
138
181
|
PROMPT_TOKENS,
|
|
139
182
|
);
|
|
140
183
|
|
|
141
184
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
142
185
|
'$ld:ai:tokens:output',
|
|
143
186
|
testContext,
|
|
144
|
-
{ configKey, variationKey },
|
|
187
|
+
{ configKey, variationKey, version },
|
|
145
188
|
COMPLETION_TOKENS,
|
|
146
189
|
);
|
|
147
190
|
});
|
|
148
191
|
|
|
149
192
|
it('tracks error when OpenAI metrics function throws', async () => {
|
|
150
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
193
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
194
|
+
mockLdClient,
|
|
195
|
+
configKey,
|
|
196
|
+
variationKey,
|
|
197
|
+
version,
|
|
198
|
+
testContext,
|
|
199
|
+
);
|
|
151
200
|
jest.spyOn(global.Date, 'now').mockReturnValueOnce(1000).mockReturnValueOnce(2000);
|
|
152
201
|
|
|
153
202
|
const error = new Error('OpenAI API error');
|
|
@@ -160,27 +209,33 @@ it('tracks error when OpenAI metrics function throws', async () => {
|
|
|
160
209
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
161
210
|
'$ld:ai:duration:total',
|
|
162
211
|
testContext,
|
|
163
|
-
{ configKey, variationKey },
|
|
212
|
+
{ configKey, variationKey, version },
|
|
164
213
|
1000,
|
|
165
214
|
);
|
|
166
215
|
|
|
167
216
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
168
217
|
'$ld:ai:generation',
|
|
169
218
|
testContext,
|
|
170
|
-
{ configKey, variationKey },
|
|
219
|
+
{ configKey, variationKey, version },
|
|
171
220
|
1,
|
|
172
221
|
);
|
|
173
222
|
|
|
174
223
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
175
224
|
'$ld:ai:generation:error',
|
|
176
225
|
testContext,
|
|
177
|
-
{ configKey, variationKey },
|
|
226
|
+
{ configKey, variationKey, version },
|
|
178
227
|
1,
|
|
179
228
|
);
|
|
180
229
|
});
|
|
181
230
|
|
|
182
231
|
it('tracks Bedrock conversation with successful response', () => {
|
|
183
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
232
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
233
|
+
mockLdClient,
|
|
234
|
+
configKey,
|
|
235
|
+
variationKey,
|
|
236
|
+
version,
|
|
237
|
+
testContext,
|
|
238
|
+
);
|
|
184
239
|
|
|
185
240
|
const TOTAL_TOKENS = 100;
|
|
186
241
|
const PROMPT_TOKENS = 49;
|
|
@@ -201,41 +256,47 @@ it('tracks Bedrock conversation with successful response', () => {
|
|
|
201
256
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
202
257
|
'$ld:ai:generation',
|
|
203
258
|
testContext,
|
|
204
|
-
{ configKey, variationKey },
|
|
259
|
+
{ configKey, variationKey, version },
|
|
205
260
|
1,
|
|
206
261
|
);
|
|
207
262
|
|
|
208
263
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
209
264
|
'$ld:ai:duration:total',
|
|
210
265
|
testContext,
|
|
211
|
-
{ configKey, variationKey },
|
|
266
|
+
{ configKey, variationKey, version },
|
|
212
267
|
500,
|
|
213
268
|
);
|
|
214
269
|
|
|
215
270
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
216
271
|
'$ld:ai:tokens:total',
|
|
217
272
|
testContext,
|
|
218
|
-
{ configKey, variationKey },
|
|
273
|
+
{ configKey, variationKey, version },
|
|
219
274
|
TOTAL_TOKENS,
|
|
220
275
|
);
|
|
221
276
|
|
|
222
277
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
223
278
|
'$ld:ai:tokens:input',
|
|
224
279
|
testContext,
|
|
225
|
-
{ configKey, variationKey },
|
|
280
|
+
{ configKey, variationKey, version },
|
|
226
281
|
PROMPT_TOKENS,
|
|
227
282
|
);
|
|
228
283
|
|
|
229
284
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
230
285
|
'$ld:ai:tokens:output',
|
|
231
286
|
testContext,
|
|
232
|
-
{ configKey, variationKey },
|
|
287
|
+
{ configKey, variationKey, version },
|
|
233
288
|
COMPLETION_TOKENS,
|
|
234
289
|
);
|
|
235
290
|
});
|
|
236
291
|
|
|
237
292
|
it('tracks Bedrock conversation with error response', () => {
|
|
238
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
293
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
294
|
+
mockLdClient,
|
|
295
|
+
configKey,
|
|
296
|
+
variationKey,
|
|
297
|
+
version,
|
|
298
|
+
testContext,
|
|
299
|
+
);
|
|
239
300
|
|
|
240
301
|
const response = {
|
|
241
302
|
$metadata: { httpStatusCode: 400 },
|
|
@@ -247,20 +308,26 @@ it('tracks Bedrock conversation with error response', () => {
|
|
|
247
308
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
248
309
|
'$ld:ai:generation',
|
|
249
310
|
testContext,
|
|
250
|
-
{ configKey, variationKey },
|
|
311
|
+
{ configKey, variationKey, version },
|
|
251
312
|
1,
|
|
252
313
|
);
|
|
253
314
|
|
|
254
315
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
255
316
|
'$ld:ai:generation:error',
|
|
256
317
|
testContext,
|
|
257
|
-
{ configKey, variationKey },
|
|
318
|
+
{ configKey, variationKey, version },
|
|
258
319
|
1,
|
|
259
320
|
);
|
|
260
321
|
});
|
|
261
322
|
|
|
262
323
|
it('tracks tokens', () => {
|
|
263
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
324
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
325
|
+
mockLdClient,
|
|
326
|
+
configKey,
|
|
327
|
+
variationKey,
|
|
328
|
+
version,
|
|
329
|
+
testContext,
|
|
330
|
+
);
|
|
264
331
|
|
|
265
332
|
const TOTAL_TOKENS = 100;
|
|
266
333
|
const PROMPT_TOKENS = 49;
|
|
@@ -275,27 +342,33 @@ it('tracks tokens', () => {
|
|
|
275
342
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
276
343
|
'$ld:ai:tokens:total',
|
|
277
344
|
testContext,
|
|
278
|
-
{ configKey, variationKey },
|
|
345
|
+
{ configKey, variationKey, version },
|
|
279
346
|
TOTAL_TOKENS,
|
|
280
347
|
);
|
|
281
348
|
|
|
282
349
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
283
350
|
'$ld:ai:tokens:input',
|
|
284
351
|
testContext,
|
|
285
|
-
{ configKey, variationKey },
|
|
352
|
+
{ configKey, variationKey, version },
|
|
286
353
|
PROMPT_TOKENS,
|
|
287
354
|
);
|
|
288
355
|
|
|
289
356
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
290
357
|
'$ld:ai:tokens:output',
|
|
291
358
|
testContext,
|
|
292
|
-
{ configKey, variationKey },
|
|
359
|
+
{ configKey, variationKey, version },
|
|
293
360
|
COMPLETION_TOKENS,
|
|
294
361
|
);
|
|
295
362
|
});
|
|
296
363
|
|
|
297
364
|
it('only tracks non-zero token counts', () => {
|
|
298
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
365
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
366
|
+
mockLdClient,
|
|
367
|
+
configKey,
|
|
368
|
+
variationKey,
|
|
369
|
+
version,
|
|
370
|
+
testContext,
|
|
371
|
+
);
|
|
299
372
|
|
|
300
373
|
tracker.trackTokens({
|
|
301
374
|
total: 0,
|
|
@@ -313,7 +386,7 @@ it('only tracks non-zero token counts', () => {
|
|
|
313
386
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
314
387
|
'$ld:ai:tokens:input',
|
|
315
388
|
testContext,
|
|
316
|
-
{ configKey, variationKey },
|
|
389
|
+
{ configKey, variationKey, version },
|
|
317
390
|
50,
|
|
318
391
|
);
|
|
319
392
|
|
|
@@ -326,7 +399,13 @@ it('only tracks non-zero token counts', () => {
|
|
|
326
399
|
});
|
|
327
400
|
|
|
328
401
|
it('returns empty summary when no metrics tracked', () => {
|
|
329
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
402
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
403
|
+
mockLdClient,
|
|
404
|
+
configKey,
|
|
405
|
+
variationKey,
|
|
406
|
+
version,
|
|
407
|
+
testContext,
|
|
408
|
+
);
|
|
330
409
|
|
|
331
410
|
const summary = tracker.getSummary();
|
|
332
411
|
|
|
@@ -334,7 +413,13 @@ it('returns empty summary when no metrics tracked', () => {
|
|
|
334
413
|
});
|
|
335
414
|
|
|
336
415
|
it('summarizes tracked metrics', () => {
|
|
337
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
416
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
417
|
+
mockLdClient,
|
|
418
|
+
configKey,
|
|
419
|
+
variationKey,
|
|
420
|
+
version,
|
|
421
|
+
testContext,
|
|
422
|
+
);
|
|
338
423
|
|
|
339
424
|
tracker.trackDuration(1000);
|
|
340
425
|
tracker.trackTokens({
|
|
@@ -362,7 +447,13 @@ it('summarizes tracked metrics', () => {
|
|
|
362
447
|
});
|
|
363
448
|
|
|
364
449
|
it('tracks duration when async function throws', async () => {
|
|
365
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
450
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
451
|
+
mockLdClient,
|
|
452
|
+
configKey,
|
|
453
|
+
variationKey,
|
|
454
|
+
version,
|
|
455
|
+
testContext,
|
|
456
|
+
);
|
|
366
457
|
jest.spyOn(global.Date, 'now').mockReturnValueOnce(1000).mockReturnValueOnce(2000);
|
|
367
458
|
|
|
368
459
|
const error = new Error('test error');
|
|
@@ -375,26 +466,32 @@ it('tracks duration when async function throws', async () => {
|
|
|
375
466
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
376
467
|
'$ld:ai:duration:total',
|
|
377
468
|
testContext,
|
|
378
|
-
{ configKey, variationKey },
|
|
469
|
+
{ configKey, variationKey, version },
|
|
379
470
|
1000,
|
|
380
471
|
);
|
|
381
472
|
});
|
|
382
473
|
|
|
383
474
|
it('tracks error', () => {
|
|
384
|
-
const tracker = new LDAIConfigTrackerImpl(
|
|
475
|
+
const tracker = new LDAIConfigTrackerImpl(
|
|
476
|
+
mockLdClient,
|
|
477
|
+
configKey,
|
|
478
|
+
variationKey,
|
|
479
|
+
version,
|
|
480
|
+
testContext,
|
|
481
|
+
);
|
|
385
482
|
tracker.trackError();
|
|
386
483
|
|
|
387
484
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
388
485
|
'$ld:ai:generation',
|
|
389
486
|
testContext,
|
|
390
|
-
{ configKey, variationKey },
|
|
487
|
+
{ configKey, variationKey, version },
|
|
391
488
|
1,
|
|
392
489
|
);
|
|
393
490
|
|
|
394
491
|
expect(mockTrack).toHaveBeenCalledWith(
|
|
395
492
|
'$ld:ai:generation:error',
|
|
396
493
|
testContext,
|
|
397
|
-
{ configKey, variationKey },
|
|
494
|
+
{ configKey, variationKey, version },
|
|
398
495
|
1,
|
|
399
496
|
);
|
|
400
497
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LDAIClientImpl.d.ts","sourceRoot":"","sources":["../src/LDAIClientImpl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAE/D,OAAO,EAAE,UAAU,EAAE,YAAY,EAA8C,MAAM,cAAc,CAAC;AACpG,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"LDAIClientImpl.d.ts","sourceRoot":"","sources":["../src/LDAIClientImpl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAE/D,OAAO,EAAE,UAAU,EAAE,YAAY,EAA8C,MAAM,cAAc,CAAC;AACpG,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAE9C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAsB5C,qBAAa,cAAe,YAAW,UAAU;IACnC,OAAO,CAAC,SAAS;gBAAT,SAAS,EAAE,WAAW;IAE1C,OAAO,CAAC,oBAAoB;IAItB,MAAM,CACV,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,SAAS,EAClB,YAAY,EAAE,YAAY,EAC1B,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAClC,OAAO,CAAC,UAAU,CAAC;CAoCvB"}
|
package/dist/LDAIClientImpl.js
CHANGED
|
@@ -11,13 +11,15 @@ class LDAIClientImpl {
|
|
|
11
11
|
return Mustache.render(template, variables, undefined, { escape: (item) => item });
|
|
12
12
|
}
|
|
13
13
|
async config(key, context, defaultValue, variables) {
|
|
14
|
-
var _a, _b, _c;
|
|
14
|
+
var _a, _b, _c, _d, _e;
|
|
15
15
|
const value = await this._ldClient.variation(key, context, defaultValue);
|
|
16
16
|
const tracker = new LDAIConfigTrackerImpl_1.LDAIConfigTrackerImpl(this._ldClient, key,
|
|
17
17
|
// eslint-disable-next-line no-underscore-dangle
|
|
18
|
-
(_b = (_a = value._ldMeta) === null || _a === void 0 ? void 0 : _a.variationKey) !== null && _b !== void 0 ? _b : '',
|
|
18
|
+
(_b = (_a = value._ldMeta) === null || _a === void 0 ? void 0 : _a.variationKey) !== null && _b !== void 0 ? _b : '',
|
|
19
19
|
// eslint-disable-next-line no-underscore-dangle
|
|
20
|
-
|
|
20
|
+
(_d = (_c = value._ldMeta) === null || _c === void 0 ? void 0 : _c.version) !== null && _d !== void 0 ? _d : 1, context);
|
|
21
|
+
// eslint-disable-next-line no-underscore-dangle
|
|
22
|
+
const enabled = !!((_e = value._ldMeta) === null || _e === void 0 ? void 0 : _e.enabled);
|
|
21
23
|
const config = {
|
|
22
24
|
tracker,
|
|
23
25
|
enabled,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LDAIClientImpl.js","sourceRoot":"","sources":["../src/LDAIClientImpl.ts"],"names":[],"mappings":";;;AAAA,qCAAqC;AAMrC,mEAAgE;
|
|
1
|
+
{"version":3,"file":"LDAIClientImpl.js","sourceRoot":"","sources":["../src/LDAIClientImpl.ts"],"names":[],"mappings":";;;AAAA,qCAAqC;AAMrC,mEAAgE;AAuBhE,MAAa,cAAc;IACzB,YAAoB,SAAsB;QAAtB,cAAS,GAAT,SAAS,CAAa;IAAG,CAAC;IAEtC,oBAAoB,CAAC,QAAgB,EAAE,SAAkC;QAC/E,OAAO,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,MAAM,EAAE,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1F,CAAC;IAED,KAAK,CAAC,MAAM,CACV,GAAW,EACX,OAAkB,EAClB,YAA0B,EAC1B,SAAmC;;QAEnC,MAAM,KAAK,GAAqB,MAAM,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;QAC3F,MAAM,OAAO,GAAG,IAAI,6CAAqB,CACvC,IAAI,CAAC,SAAS,EACd,GAAG;QACH,gDAAgD;QAChD,MAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,YAAY,mCAAI,EAAE;QACjC,gDAAgD;QAChD,MAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,OAAO,mCAAI,CAAC,EAC3B,OAAO,CACR,CAAC;QACF,gDAAgD;QAChD,MAAM,OAAO,GAAG,CAAC,CAAC,CAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,OAAO,CAAA,CAAC;QACzC,MAAM,MAAM,GAAe;YACzB,OAAO;YACP,OAAO;SACR,CAAC;QACF,gFAAgF;QAChF,+FAA+F;QAC/F,IAAI,KAAK,CAAC,KAAK,EAAE;YACf,MAAM,CAAC,KAAK,qBAAQ,KAAK,CAAC,KAAK,CAAE,CAAC;SACnC;QACD,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,MAAM,CAAC,QAAQ,qBAAQ,KAAK,CAAC,QAAQ,CAAE,CAAC;SACzC;QACD,MAAM,YAAY,mCAAQ,SAAS,KAAE,KAAK,EAAE,OAAO,GAAE,CAAC;QAEtD,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,iCAChD,KAAK,KACR,OAAO,EAAE,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,OAAO,EAAE,YAAY,CAAC,IAC/D,CAAC,CAAC;SACL;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AAhDD,wCAgDC"}
|
|
@@ -7,9 +7,10 @@ export declare class LDAIConfigTrackerImpl implements LDAIConfigTracker {
|
|
|
7
7
|
private _ldClient;
|
|
8
8
|
private _configKey;
|
|
9
9
|
private _variationKey;
|
|
10
|
+
private _version;
|
|
10
11
|
private _context;
|
|
11
12
|
private _trackedMetrics;
|
|
12
|
-
constructor(_ldClient: LDClientMin, _configKey: string, _variationKey: string, _context: LDContext);
|
|
13
|
+
constructor(_ldClient: LDClientMin, _configKey: string, _variationKey: string, _version: number, _context: LDContext);
|
|
13
14
|
private _getTrackData;
|
|
14
15
|
trackDuration(duration: number): void;
|
|
15
16
|
trackDurationOf<TRes>(func: () => Promise<TRes>): Promise<TRes>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LDAIConfigTrackerImpl.d.ts","sourceRoot":"","sources":["../src/LDAIConfigTrackerImpl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAE/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAA2B,cAAc,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAEtF,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,qBAAa,qBAAsB,YAAW,iBAAiB;IAI3D,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,QAAQ;
|
|
1
|
+
{"version":3,"file":"LDAIConfigTrackerImpl.d.ts","sourceRoot":"","sources":["../src/LDAIConfigTrackerImpl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAE/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAA2B,cAAc,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAEtF,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,qBAAa,qBAAsB,YAAW,iBAAiB;IAI3D,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,QAAQ;IAPlB,OAAO,CAAC,eAAe,CAAyB;gBAGtC,SAAS,EAAE,WAAW,EACtB,UAAU,EAAE,MAAM,EAClB,aAAa,EAAE,MAAM,EACrB,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,SAAS;IAG7B,OAAO,CAAC,aAAa;IAQrB,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAK/B,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAarE,qBAAqB,CAAC,kBAAkB,EAAE,MAAM;IAUhD,aAAa,CAAC,QAAQ,EAAE;QAAE,IAAI,EAAE,cAAc,CAAA;KAAE,GAAG,IAAI;IASvD,YAAY,IAAI,IAAI;IAMpB,UAAU,IAAI,IAAI;IAMZ,kBAAkB,CACtB,IAAI,SAAS;QACX,KAAK,CAAC,EAAE;YACN,YAAY,CAAC,EAAE,MAAM,CAAC;YACtB,aAAa,CAAC,EAAE,MAAM,CAAC;YACvB,iBAAiB,CAAC,EAAE,MAAM,CAAC;SAC5B,CAAC;KACH,EACD,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAc3C,2BAA2B,CACzB,IAAI,SAAS;QACX,SAAS,EAAE;YAAE,cAAc,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;QACvC,OAAO,CAAC,EAAE;YAAE,SAAS,CAAC,EAAE,MAAM,CAAA;SAAE,CAAC;QACjC,KAAK,CAAC,EAAE;YACN,WAAW,CAAC,EAAE,MAAM,CAAC;YACrB,YAAY,CAAC,EAAE,MAAM,CAAC;YACtB,WAAW,CAAC,EAAE,MAAM,CAAC;SACtB,CAAC;KACH,EACD,GAAG,EAAE,IAAI,GAAG,IAAI;IAelB,WAAW,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI;IAcvC;;OAEG;IACH,UAAU,IAAI,iBAAiB;CAGhC"}
|
|
@@ -4,10 +4,11 @@ exports.LDAIConfigTrackerImpl = void 0;
|
|
|
4
4
|
const metrics_1 = require("./api/metrics");
|
|
5
5
|
const OpenAiUsage_1 = require("./api/metrics/OpenAiUsage");
|
|
6
6
|
class LDAIConfigTrackerImpl {
|
|
7
|
-
constructor(_ldClient, _configKey, _variationKey, _context) {
|
|
7
|
+
constructor(_ldClient, _configKey, _variationKey, _version, _context) {
|
|
8
8
|
this._ldClient = _ldClient;
|
|
9
9
|
this._configKey = _configKey;
|
|
10
10
|
this._variationKey = _variationKey;
|
|
11
|
+
this._version = _version;
|
|
11
12
|
this._context = _context;
|
|
12
13
|
this._trackedMetrics = {};
|
|
13
14
|
}
|
|
@@ -15,6 +16,7 @@ class LDAIConfigTrackerImpl {
|
|
|
15
16
|
return {
|
|
16
17
|
variationKey: this._variationKey,
|
|
17
18
|
configKey: this._configKey,
|
|
19
|
+
version: this._version,
|
|
18
20
|
};
|
|
19
21
|
}
|
|
20
22
|
trackDuration(duration) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LDAIConfigTrackerImpl.js","sourceRoot":"","sources":["../src/LDAIConfigTrackerImpl.ts"],"names":[],"mappings":";;;AAIA,2CAAsF;AACtF,2DAA8D;AAG9D,MAAa,qBAAqB;IAGhC,YACU,SAAsB,EACtB,UAAkB,EAClB,aAAqB,EACrB,QAAmB;
|
|
1
|
+
{"version":3,"file":"LDAIConfigTrackerImpl.js","sourceRoot":"","sources":["../src/LDAIConfigTrackerImpl.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
<!DOCTYPE html><html class="default" lang="en"><head><meta charSet="utf-8"/><meta http-equiv="x-ua-compatible" content="IE=edge"/><title>LDFeedbackKind | @launchdarkly/server-sdk-ai - v0.
|
|
1
|
+
<!DOCTYPE html><html class="default" lang="en"><head><meta charSet="utf-8"/><meta http-equiv="x-ua-compatible" content="IE=edge"/><title>LDFeedbackKind | @launchdarkly/server-sdk-ai - v0.9.0</title><meta name="description" content="Documentation for @launchdarkly/server-sdk-ai"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="stylesheet" href="../assets/style.css"/><link rel="stylesheet" href="../assets/highlight.css"/><script defer src="../assets/main.js"></script><script async src="../assets/search.js" id="tsd-search-script"></script></head><body><script>document.documentElement.dataset.theme = localStorage.getItem("tsd-theme") || "os"</script><header class="tsd-page-toolbar">
|
|
2
2
|
<div class="tsd-toolbar-contents container">
|
|
3
3
|
<div class="table-cell" id="tsd-search" data-base="..">
|
|
4
4
|
<div class="field"><label for="tsd-search-field" class="tsd-widget tsd-toolbar-icon search no-caption"><svg width="16" height="16" viewBox="0 0 16 16" fill="none"><path d="M15.7824 13.833L12.6666 10.7177C12.5259 10.5771 12.3353 10.499 12.1353 10.499H11.6259C12.4884 9.39596 13.001 8.00859 13.001 6.49937C13.001 2.90909 10.0914 0 6.50048 0C2.90959 0 0 2.90909 0 6.49937C0 10.0896 2.90959 12.9987 6.50048 12.9987C8.00996 12.9987 9.39756 12.4863 10.5008 11.6239V12.1332C10.5008 12.3332 10.5789 12.5238 10.7195 12.6644L13.8354 15.7797C14.1292 16.0734 14.6042 16.0734 14.8948 15.7797L15.7793 14.8954C16.0731 14.6017 16.0731 14.1267 15.7824 13.833ZM6.50048 10.499C4.29094 10.499 2.50018 8.71165 2.50018 6.49937C2.50018 4.29021 4.28781 2.49976 6.50048 2.49976C8.71001 2.49976 10.5008 4.28708 10.5008 6.49937C10.5008 8.70852 8.71314 10.499 6.50048 10.499Z" fill="var(--color-text)"></path></svg></label><input type="text" id="tsd-search-field" aria-label="Search"/></div>
|
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
<div id="tsd-toolbar-links"></div></div>
|
|
7
7
|
<ul class="results">
|
|
8
8
|
<li class="state loading">Preparing search index...</li>
|
|
9
|
-
<li class="state failure">The search index is not available</li></ul><a href="../index.html" class="title">@launchdarkly/server-sdk-ai - v0.
|
|
9
|
+
<li class="state failure">The search index is not available</li></ul><a href="../index.html" class="title">@launchdarkly/server-sdk-ai - v0.9.0</a></div>
|
|
10
10
|
<div class="table-cell" id="tsd-widgets"><a href="#" class="tsd-widget tsd-toolbar-icon menu no-caption" data-toggle="menu" aria-label="Menu"><svg width="16" height="16" viewBox="0 0 16 16" fill="none"><rect x="1" y="3" width="14" height="2" fill="var(--color-text)"></rect><rect x="1" y="7" width="14" height="2" fill="var(--color-text)"></rect><rect x="1" y="11" width="14" height="2" fill="var(--color-text)"></rect></svg></a></div></div></header>
|
|
11
11
|
<div class="container container-main">
|
|
12
12
|
<div class="col-content">
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
</div>
|
|
21
21
|
<div class="tsd-comment tsd-typography"></div></section><aside class="tsd-sources">
|
|
22
22
|
<ul>
|
|
23
|
-
<li>Defined in <a href="https://github.com/launchdarkly/js-core/blob/
|
|
23
|
+
<li>Defined in <a href="https://github.com/launchdarkly/js-core/blob/1926b49/packages/sdk/server-ai/src/api/metrics/LDFeedbackKind.ts#L4">api/metrics/LDFeedbackKind.ts:4</a></li></ul></aside>
|
|
24
24
|
<section class="tsd-panel-group tsd-index-group">
|
|
25
25
|
<section class="tsd-panel tsd-index-panel">
|
|
26
26
|
<details class="tsd-index-content tsd-index-accordion" open><summary class="tsd-accordion-summary tsd-index-summary">
|
|
@@ -40,7 +40,7 @@
|
|
|
40
40
|
</div>
|
|
41
41
|
<div class="tsd-comment tsd-typography"></div><aside class="tsd-sources">
|
|
42
42
|
<ul>
|
|
43
|
-
<li>Defined in <a href="https://github.com/launchdarkly/js-core/blob/
|
|
43
|
+
<li>Defined in <a href="https://github.com/launchdarkly/js-core/blob/1926b49/packages/sdk/server-ai/src/api/metrics/LDFeedbackKind.ts#L12">api/metrics/LDFeedbackKind.ts:12</a></li></ul></aside></section>
|
|
44
44
|
<section class="tsd-panel tsd-member"><a id="Positive" class="tsd-anchor"></a>
|
|
45
45
|
<h3 class="tsd-anchor-link"><span>Positive</span><a href="#Positive" aria-label="Permalink" class="tsd-anchor-icon"><svg viewBox="0 0 24 24"><use href="#icon-anchor"></use></svg></a></h3>
|
|
46
46
|
<div class="tsd-signature"><span class="tsd-kind-enum-member">Positive</span><span class="tsd-signature-symbol">:</span> <span class="tsd-signature-type">"positive"</span></div>
|
|
@@ -48,7 +48,7 @@
|
|
|
48
48
|
</div>
|
|
49
49
|
<div class="tsd-comment tsd-typography"></div><aside class="tsd-sources">
|
|
50
50
|
<ul>
|
|
51
|
-
<li>Defined in <a href="https://github.com/launchdarkly/js-core/blob/
|
|
51
|
+
<li>Defined in <a href="https://github.com/launchdarkly/js-core/blob/1926b49/packages/sdk/server-ai/src/api/metrics/LDFeedbackKind.ts#L8">api/metrics/LDFeedbackKind.ts:8</a></li></ul></aside></section></section></div>
|
|
52
52
|
<div class="col-sidebar">
|
|
53
53
|
<div class="page-menu">
|
|
54
54
|
<div class="tsd-navigation settings">
|
|
@@ -71,7 +71,7 @@
|
|
|
71
71
|
<li><a href="#Negative" class=""><svg class="tsd-kind-icon" viewBox="0 0 24 24"><use href="#icon-1024"></use></svg><span>Negative</span></a></li>
|
|
72
72
|
<li><a href="#Positive" class=""><svg class="tsd-kind-icon" viewBox="0 0 24 24"><use href="#icon-1024"></use></svg><span>Positive</span></a></li></ul></div></details></div>
|
|
73
73
|
<div class="site-menu">
|
|
74
|
-
<nav class="tsd-navigation"><a href="../index.html"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><g id="icon-4"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-namespace)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.33 16V7.24H10.77L13.446 14.74C13.43 14.54 13.41 14.296 13.386 14.008C13.37 13.712 13.354 13.404 13.338 13.084C13.33 12.756 13.326 12.448 13.326 12.16V7.24H14.37V16H12.93L10.266 8.5C10.282 8.692 10.298 8.936 10.314 9.232C10.33 9.52 10.342 9.828 10.35 10.156C10.366 10.476 10.374 10.784 10.374 11.08V16H9.33Z" fill="var(--color-text)"></path></g></svg><span>@launchdarkly/server-<wbr/>sdk-<wbr/>ai -<wbr/> v0.
|
|
74
|
+
<nav class="tsd-navigation"><a href="../index.html"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><g id="icon-4"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-namespace)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.33 16V7.24H10.77L13.446 14.74C13.43 14.54 13.41 14.296 13.386 14.008C13.37 13.712 13.354 13.404 13.338 13.084C13.33 12.756 13.326 12.448 13.326 12.16V7.24H14.37V16H12.93L10.266 8.5C10.282 8.692 10.298 8.936 10.314 9.232C10.33 9.52 10.342 9.828 10.35 10.156C10.366 10.476 10.374 10.784 10.374 11.08V16H9.33Z" fill="var(--color-text)"></path></g></svg><span>@launchdarkly/server-<wbr/>sdk-<wbr/>ai -<wbr/> v0.9.0</span></a>
|
|
75
75
|
<ul class="tsd-small-nested-navigation">
|
|
76
76
|
<li><a href="LDFeedbackKind.html" class="current"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><g id="icon-8"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-enum)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.45 16V7.24H14.49V8.224H10.518V10.936H14.07V11.908H10.518V15.016H14.49V16H9.45Z" fill="var(--color-text)"></path></g></svg><span>LDFeedback<wbr/>Kind</span></a></li>
|
|
77
77
|
<li><a href="../interfaces/LDAIClient.html"><svg class="tsd-kind-icon" viewBox="0 0 24 24"><g id="icon-256"><rect fill="var(--color-icon-background)" stroke="var(--color-ts-interface)" stroke-width="1.5" x="1" y="1" width="22" height="22" rx="6"></rect><path d="M9.51 16V15.016H11.298V8.224H9.51V7.24H14.19V8.224H12.402V15.016H14.19V16H9.51Z" fill="var(--color-text)"></path></g></svg><span>LDAIClient</span></a></li>
|