@thinkhive/sdk 4.1.0 → 4.2.1
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/README.md +161 -2
- package/dist/api/documents.d.ts +52 -0
- package/dist/api/documents.js +58 -0
- package/dist/api/drift.d.ts +70 -0
- package/dist/api/drift.js +71 -0
- package/dist/api/eval-runs.d.ts +126 -0
- package/dist/api/eval-runs.js +126 -0
- package/dist/api/llm-costs.d.ts +104 -0
- package/dist/api/llm-costs.js +81 -0
- package/dist/api/notifications.d.ts +103 -0
- package/dist/api/notifications.js +110 -0
- package/dist/api/sessions.d.ts +57 -0
- package/dist/api/sessions.js +49 -0
- package/dist/api/shadow-tests.d.ts +78 -0
- package/dist/api/shadow-tests.js +80 -0
- package/dist/api/signals.d.ts +177 -0
- package/dist/api/signals.js +172 -0
- package/dist/core/client.d.ts +2 -0
- package/dist/core/client.js +10 -4
- package/dist/guardrails.d.ts +70 -0
- package/dist/guardrails.js +34 -0
- package/dist/index.d.ts +105 -2
- package/dist/index.js +50 -4
- package/package.json +1 -1
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK - Sessions API
|
|
4
|
+
*
|
|
5
|
+
* Trace session grouping for multi-turn conversation tracking
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.default = exports.sessions = void 0;
|
|
9
|
+
const client_1 = require("../core/client");
|
|
10
|
+
// ============================================================================
|
|
11
|
+
// SESSIONS API CLIENT
|
|
12
|
+
// ============================================================================
|
|
13
|
+
/**
|
|
14
|
+
* Sessions API client for trace session grouping
|
|
15
|
+
*/
|
|
16
|
+
exports.sessions = {
|
|
17
|
+
/**
|
|
18
|
+
* List sessions for an agent
|
|
19
|
+
*
|
|
20
|
+
* @param agentId - The agent ID
|
|
21
|
+
* @param opts - Pagination options
|
|
22
|
+
* @returns List of sessions
|
|
23
|
+
*/
|
|
24
|
+
async list(agentId, opts) {
|
|
25
|
+
const params = new URLSearchParams({ agentId });
|
|
26
|
+
if (opts?.limit !== undefined)
|
|
27
|
+
params.set('limit', String(opts.limit));
|
|
28
|
+
if (opts?.offset !== undefined)
|
|
29
|
+
params.set('offset', String(opts.offset));
|
|
30
|
+
return (0, client_1.apiRequestWithData)(`/traces/sessions?${params}`, {
|
|
31
|
+
apiVersion: 'none',
|
|
32
|
+
});
|
|
33
|
+
},
|
|
34
|
+
/**
|
|
35
|
+
* Get traces for a specific session
|
|
36
|
+
*
|
|
37
|
+
* @param sessionId - The session ID
|
|
38
|
+
* @param agentId - The agent ID
|
|
39
|
+
* @returns List of traces in the session
|
|
40
|
+
*/
|
|
41
|
+
async getTraces(sessionId, agentId) {
|
|
42
|
+
const params = new URLSearchParams({ agentId, sessionId });
|
|
43
|
+
return (0, client_1.apiRequestWithData)(`/traces?${params}`, {
|
|
44
|
+
apiVersion: 'none',
|
|
45
|
+
});
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
exports.default = exports.sessions;
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Vzc2lvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXBpL3Nlc3Npb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7OztHQUlHOzs7QUFFSCwyQ0FBb0Q7QUFrQ3BELCtFQUErRTtBQUMvRSxzQkFBc0I7QUFDdEIsK0VBQStFO0FBRS9FOztHQUVHO0FBQ1UsUUFBQSxRQUFRLEdBQUc7SUFDdEI7Ozs7OztPQU1HO0lBQ0gsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFlLEVBQUUsSUFBMEI7UUFNcEQsTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFlLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ2hELElBQUksSUFBSSxFQUFFLEtBQUssS0FBSyxTQUFTO1lBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ3ZFLElBQUksSUFBSSxFQUFFLE1BQU0sS0FBSyxTQUFTO1lBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBRTFFLE9BQU8sSUFBQSwyQkFBa0IsRUFBQyxvQkFBb0IsTUFBTSxFQUFFLEVBQUU7WUFDdEQsVUFBVSxFQUFFLE1BQU07U0FDbkIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNILEtBQUssQ0FBQyxTQUFTLENBQUMsU0FBaUIsRUFBRSxPQUFlO1FBQ2hELE1BQU0sTUFBTSxHQUFHLElBQUksZUFBZSxDQUFDLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7UUFDM0QsT0FBTyxJQUFBLDJCQUFrQixFQUFpQixXQUFXLE1BQU0sRUFBRSxFQUFFO1lBQzdELFVBQVUsRUFBRSxNQUFNO1NBQ25CLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRixDQUFDO0FBRW1CLGtCQXRDUixnQkFBUSxDQXNDTyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVGhpbmtIaXZlIFNESyAtIFNlc3Npb25zIEFQSVxuICpcbiAqIFRyYWNlIHNlc3Npb24gZ3JvdXBpbmcgZm9yIG11bHRpLXR1cm4gY29udmVyc2F0aW9uIHRyYWNraW5nXG4gKi9cblxuaW1wb3J0IHsgYXBpUmVxdWVzdFdpdGhEYXRhIH0gZnJvbSAnLi4vY29yZS9jbGllbnQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBUWVBFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogT3B0aW9ucyBmb3IgbGlzdGluZyBzZXNzaW9ucyAqL1xuZXhwb3J0IGludGVyZmFjZSBMaXN0U2Vzc2lvbnNPcHRpb25zIHtcbiAgbGltaXQ/OiBudW1iZXI7XG4gIG9mZnNldD86IG51bWJlcjtcbn1cblxuLyoqIEEgdHJhY2Ugc2Vzc2lvbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTZXNzaW9uIHtcbiAgc2Vzc2lvbklkOiBzdHJpbmc7XG4gIGFnZW50SWQ6IHN0cmluZztcbiAgdHJhY2VDb3VudDogbnVtYmVyO1xuICBmaXJzdFRyYWNlQXQ6IHN0cmluZztcbiAgbGFzdFRyYWNlQXQ6IHN0cmluZztcbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbn1cblxuLyoqIEEgdHJhY2Ugd2l0aGluIGEgc2Vzc2lvbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTZXNzaW9uVHJhY2Uge1xuICBpZDogc3RyaW5nO1xuICBhZ2VudElkOiBzdHJpbmc7XG4gIHNlc3Npb25JZDogc3RyaW5nO1xuICBpbnB1dD86IHVua25vd247XG4gIG91dHB1dD86IHVua25vd247XG4gIHN0YXR1czogc3RyaW5nO1xuICBjcmVhdGVkQXQ6IHN0cmluZztcbiAgW2tleTogc3RyaW5nXTogdW5rbm93bjtcbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gU0VTU0lPTlMgQVBJIENMSUVOVFxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIFNlc3Npb25zIEFQSSBjbGllbnQgZm9yIHRyYWNlIHNlc3Npb24gZ3JvdXBpbmdcbiAqL1xuZXhwb3J0IGNvbnN0IHNlc3Npb25zID0ge1xuICAvKipcbiAgICogTGlzdCBzZXNzaW9ucyBmb3IgYW4gYWdlbnRcbiAgICpcbiAgICogQHBhcmFtIGFnZW50SWQgLSBUaGUgYWdlbnQgSURcbiAgICogQHBhcmFtIG9wdHMgLSBQYWdpbmF0aW9uIG9wdGlvbnNcbiAgICogQHJldHVybnMgTGlzdCBvZiBzZXNzaW9uc1xuICAgKi9cbiAgYXN5bmMgbGlzdChhZ2VudElkOiBzdHJpbmcsIG9wdHM/OiBMaXN0U2Vzc2lvbnNPcHRpb25zKTogUHJvbWlzZTx7XG4gICAgc2Vzc2lvbnM6IFNlc3Npb25bXTtcbiAgICBsaW1pdDogbnVtYmVyO1xuICAgIG9mZnNldDogbnVtYmVyO1xuICAgIGhhc01vcmU6IGJvb2xlYW47XG4gIH0+IHtcbiAgICBjb25zdCBwYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKHsgYWdlbnRJZCB9KTtcbiAgICBpZiAob3B0cz8ubGltaXQgIT09IHVuZGVmaW5lZCkgcGFyYW1zLnNldCgnbGltaXQnLCBTdHJpbmcob3B0cy5saW1pdCkpO1xuICAgIGlmIChvcHRzPy5vZmZzZXQgIT09IHVuZGVmaW5lZCkgcGFyYW1zLnNldCgnb2Zmc2V0JywgU3RyaW5nKG9wdHMub2Zmc2V0KSk7XG5cbiAgICByZXR1cm4gYXBpUmVxdWVzdFdpdGhEYXRhKGAvdHJhY2VzL3Nlc3Npb25zPyR7cGFyYW1zfWAsIHtcbiAgICAgIGFwaVZlcnNpb246ICdub25lJyxcbiAgICB9KTtcbiAgfSxcblxuICAvKipcbiAgICogR2V0IHRyYWNlcyBmb3IgYSBzcGVjaWZpYyBzZXNzaW9uXG4gICAqXG4gICAqIEBwYXJhbSBzZXNzaW9uSWQgLSBUaGUgc2Vzc2lvbiBJRFxuICAgKiBAcGFyYW0gYWdlbnRJZCAtIFRoZSBhZ2VudCBJRFxuICAgKiBAcmV0dXJucyBMaXN0IG9mIHRyYWNlcyBpbiB0aGUgc2Vzc2lvblxuICAgKi9cbiAgYXN5bmMgZ2V0VHJhY2VzKHNlc3Npb25JZDogc3RyaW5nLCBhZ2VudElkOiBzdHJpbmcpOiBQcm9taXNlPFNlc3Npb25UcmFjZVtdPiB7XG4gICAgY29uc3QgcGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcyh7IGFnZW50SWQsIHNlc3Npb25JZCB9KTtcbiAgICByZXR1cm4gYXBpUmVxdWVzdFdpdGhEYXRhPFNlc3Npb25UcmFjZVtdPihgL3RyYWNlcz8ke3BhcmFtc31gLCB7XG4gICAgICBhcGlWZXJzaW9uOiAnbm9uZScsXG4gICAgfSk7XG4gIH0sXG59O1xuXG5leHBvcnQgeyBzZXNzaW9ucyBhcyBkZWZhdWx0IH07XG4iXX0=
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK - Shadow Tests API
|
|
3
|
+
*
|
|
4
|
+
* Shadow test execution for validating proposed fixes
|
|
5
|
+
*/
|
|
6
|
+
/** Data for creating a shadow test */
|
|
7
|
+
export interface CreateShadowTestData {
|
|
8
|
+
fixId: string;
|
|
9
|
+
agentId: string;
|
|
10
|
+
testName: string;
|
|
11
|
+
inputData: unknown;
|
|
12
|
+
expectedOutput: unknown;
|
|
13
|
+
}
|
|
14
|
+
/** Data for updating a shadow test */
|
|
15
|
+
export interface UpdateShadowTestData {
|
|
16
|
+
testName?: string;
|
|
17
|
+
status?: string;
|
|
18
|
+
actualOutput?: unknown;
|
|
19
|
+
passed?: boolean;
|
|
20
|
+
metadata?: Record<string, unknown>;
|
|
21
|
+
}
|
|
22
|
+
/** A shadow test record */
|
|
23
|
+
export interface ShadowTest {
|
|
24
|
+
id: string;
|
|
25
|
+
fixId: string;
|
|
26
|
+
agentId: string;
|
|
27
|
+
testName: string;
|
|
28
|
+
inputData: unknown;
|
|
29
|
+
expectedOutput: unknown;
|
|
30
|
+
actualOutput?: unknown;
|
|
31
|
+
status: string;
|
|
32
|
+
passed?: boolean;
|
|
33
|
+
createdAt: string;
|
|
34
|
+
completedAt?: string;
|
|
35
|
+
metadata?: Record<string, unknown>;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Shadow tests API client for managing shadow test execution
|
|
39
|
+
*/
|
|
40
|
+
export declare const shadowTests: {
|
|
41
|
+
/**
|
|
42
|
+
* List shadow tests for an agent
|
|
43
|
+
*
|
|
44
|
+
* @param agentId - The agent ID
|
|
45
|
+
* @returns List of shadow tests
|
|
46
|
+
*/
|
|
47
|
+
list(agentId: string): Promise<ShadowTest[]>;
|
|
48
|
+
/**
|
|
49
|
+
* Get a shadow test by ID
|
|
50
|
+
*
|
|
51
|
+
* @param id - The shadow test ID
|
|
52
|
+
* @returns The shadow test details
|
|
53
|
+
*/
|
|
54
|
+
get(id: string): Promise<ShadowTest>;
|
|
55
|
+
/**
|
|
56
|
+
* Get shadow tests for a specific fix
|
|
57
|
+
*
|
|
58
|
+
* @param fixId - The fix ID
|
|
59
|
+
* @returns List of shadow tests for the fix
|
|
60
|
+
*/
|
|
61
|
+
getByFix(fixId: string): Promise<ShadowTest[]>;
|
|
62
|
+
/**
|
|
63
|
+
* Create a new shadow test
|
|
64
|
+
*
|
|
65
|
+
* @param data - Shadow test configuration
|
|
66
|
+
* @returns The created shadow test
|
|
67
|
+
*/
|
|
68
|
+
create(data: CreateShadowTestData): Promise<ShadowTest>;
|
|
69
|
+
/**
|
|
70
|
+
* Update a shadow test
|
|
71
|
+
*
|
|
72
|
+
* @param id - The shadow test ID to update
|
|
73
|
+
* @param data - Fields to update
|
|
74
|
+
* @returns The updated shadow test
|
|
75
|
+
*/
|
|
76
|
+
update(id: string, data: UpdateShadowTestData): Promise<ShadowTest>;
|
|
77
|
+
};
|
|
78
|
+
export { shadowTests as default };
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK - Shadow Tests API
|
|
4
|
+
*
|
|
5
|
+
* Shadow test execution for validating proposed fixes
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.default = exports.shadowTests = void 0;
|
|
9
|
+
const client_1 = require("../core/client");
|
|
10
|
+
// ============================================================================
|
|
11
|
+
// SHADOW TESTS API CLIENT
|
|
12
|
+
// ============================================================================
|
|
13
|
+
/**
|
|
14
|
+
* Shadow tests API client for managing shadow test execution
|
|
15
|
+
*/
|
|
16
|
+
exports.shadowTests = {
|
|
17
|
+
/**
|
|
18
|
+
* List shadow tests for an agent
|
|
19
|
+
*
|
|
20
|
+
* @param agentId - The agent ID
|
|
21
|
+
* @returns List of shadow tests
|
|
22
|
+
*/
|
|
23
|
+
async list(agentId) {
|
|
24
|
+
const params = new URLSearchParams({ agentId });
|
|
25
|
+
return (0, client_1.apiRequestWithData)(`/shadow-tests?${params}`, {
|
|
26
|
+
apiVersion: 'none',
|
|
27
|
+
});
|
|
28
|
+
},
|
|
29
|
+
/**
|
|
30
|
+
* Get a shadow test by ID
|
|
31
|
+
*
|
|
32
|
+
* @param id - The shadow test ID
|
|
33
|
+
* @returns The shadow test details
|
|
34
|
+
*/
|
|
35
|
+
async get(id) {
|
|
36
|
+
return (0, client_1.apiRequestWithData)(`/shadow-tests/${id}`, {
|
|
37
|
+
apiVersion: 'none',
|
|
38
|
+
});
|
|
39
|
+
},
|
|
40
|
+
/**
|
|
41
|
+
* Get shadow tests for a specific fix
|
|
42
|
+
*
|
|
43
|
+
* @param fixId - The fix ID
|
|
44
|
+
* @returns List of shadow tests for the fix
|
|
45
|
+
*/
|
|
46
|
+
async getByFix(fixId) {
|
|
47
|
+
return (0, client_1.apiRequestWithData)(`/fixes/${fixId}/shadow-tests`, {
|
|
48
|
+
apiVersion: 'none',
|
|
49
|
+
});
|
|
50
|
+
},
|
|
51
|
+
/**
|
|
52
|
+
* Create a new shadow test
|
|
53
|
+
*
|
|
54
|
+
* @param data - Shadow test configuration
|
|
55
|
+
* @returns The created shadow test
|
|
56
|
+
*/
|
|
57
|
+
async create(data) {
|
|
58
|
+
return (0, client_1.apiRequestWithData)('/shadow-tests', {
|
|
59
|
+
method: 'POST',
|
|
60
|
+
body: data,
|
|
61
|
+
apiVersion: 'none',
|
|
62
|
+
});
|
|
63
|
+
},
|
|
64
|
+
/**
|
|
65
|
+
* Update a shadow test
|
|
66
|
+
*
|
|
67
|
+
* @param id - The shadow test ID to update
|
|
68
|
+
* @param data - Fields to update
|
|
69
|
+
* @returns The updated shadow test
|
|
70
|
+
*/
|
|
71
|
+
async update(id, data) {
|
|
72
|
+
return (0, client_1.apiRequestWithData)(`/shadow-tests/${id}`, {
|
|
73
|
+
method: 'PATCH',
|
|
74
|
+
body: data,
|
|
75
|
+
apiVersion: 'none',
|
|
76
|
+
});
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
exports.default = exports.shadowTests;
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhZG93LXRlc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwaS9zaGFkb3ctdGVzdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7O0dBSUc7OztBQUVILDJDQUFvRDtBQXdDcEQsK0VBQStFO0FBQy9FLDBCQUEwQjtBQUMxQiwrRUFBK0U7QUFFL0U7O0dBRUc7QUFDVSxRQUFBLFdBQVcsR0FBRztJQUN6Qjs7Ozs7T0FLRztJQUNILEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBZTtRQUN4QixNQUFNLE1BQU0sR0FBRyxJQUFJLGVBQWUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7UUFDaEQsT0FBTyxJQUFBLDJCQUFrQixFQUFlLGlCQUFpQixNQUFNLEVBQUUsRUFBRTtZQUNqRSxVQUFVLEVBQUUsTUFBTTtTQUNuQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUMsR0FBRyxDQUFDLEVBQVU7UUFDbEIsT0FBTyxJQUFBLDJCQUFrQixFQUFhLGlCQUFpQixFQUFFLEVBQUUsRUFBRTtZQUMzRCxVQUFVLEVBQUUsTUFBTTtTQUNuQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSCxLQUFLLENBQUMsUUFBUSxDQUFDLEtBQWE7UUFDMUIsT0FBTyxJQUFBLDJCQUFrQixFQUFlLFVBQVUsS0FBSyxlQUFlLEVBQUU7WUFDdEUsVUFBVSxFQUFFLE1BQU07U0FDbkIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUEwQjtRQUNyQyxPQUFPLElBQUEsMkJBQWtCLEVBQWEsZUFBZSxFQUFFO1lBQ3JELE1BQU0sRUFBRSxNQUFNO1lBQ2QsSUFBSSxFQUFFLElBQUk7WUFDVixVQUFVLEVBQUUsTUFBTTtTQUNuQixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsS0FBSyxDQUFDLE1BQU0sQ0FBQyxFQUFVLEVBQUUsSUFBMEI7UUFDakQsT0FBTyxJQUFBLDJCQUFrQixFQUFhLGlCQUFpQixFQUFFLEVBQUUsRUFBRTtZQUMzRCxNQUFNLEVBQUUsT0FBTztZQUNmLElBQUksRUFBRSxJQUFJO1lBQ1YsVUFBVSxFQUFFLE1BQU07U0FDbkIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGLENBQUM7QUFFc0Isa0JBcEVYLG1CQUFXLENBb0VPIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBUaGlua0hpdmUgU0RLIC0gU2hhZG93IFRlc3RzIEFQSVxuICpcbiAqIFNoYWRvdyB0ZXN0IGV4ZWN1dGlvbiBmb3IgdmFsaWRhdGluZyBwcm9wb3NlZCBmaXhlc1xuICovXG5cbmltcG9ydCB7IGFwaVJlcXVlc3RXaXRoRGF0YSB9IGZyb20gJy4uL2NvcmUvY2xpZW50JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gVFlQRVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIERhdGEgZm9yIGNyZWF0aW5nIGEgc2hhZG93IHRlc3QgKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ3JlYXRlU2hhZG93VGVzdERhdGEge1xuICBmaXhJZDogc3RyaW5nO1xuICBhZ2VudElkOiBzdHJpbmc7XG4gIHRlc3ROYW1lOiBzdHJpbmc7XG4gIGlucHV0RGF0YTogdW5rbm93bjtcbiAgZXhwZWN0ZWRPdXRwdXQ6IHVua25vd247XG59XG5cbi8qKiBEYXRhIGZvciB1cGRhdGluZyBhIHNoYWRvdyB0ZXN0ICovXG5leHBvcnQgaW50ZXJmYWNlIFVwZGF0ZVNoYWRvd1Rlc3REYXRhIHtcbiAgdGVzdE5hbWU/OiBzdHJpbmc7XG4gIHN0YXR1cz86IHN0cmluZztcbiAgYWN0dWFsT3V0cHV0PzogdW5rbm93bjtcbiAgcGFzc2VkPzogYm9vbGVhbjtcbiAgbWV0YWRhdGE/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbn1cblxuLyoqIEEgc2hhZG93IHRlc3QgcmVjb3JkICovXG5leHBvcnQgaW50ZXJmYWNlIFNoYWRvd1Rlc3Qge1xuICBpZDogc3RyaW5nO1xuICBmaXhJZDogc3RyaW5nO1xuICBhZ2VudElkOiBzdHJpbmc7XG4gIHRlc3ROYW1lOiBzdHJpbmc7XG4gIGlucHV0RGF0YTogdW5rbm93bjtcbiAgZXhwZWN0ZWRPdXRwdXQ6IHVua25vd247XG4gIGFjdHVhbE91dHB1dD86IHVua25vd247XG4gIHN0YXR1czogc3RyaW5nO1xuICBwYXNzZWQ/OiBib29sZWFuO1xuICBjcmVhdGVkQXQ6IHN0cmluZztcbiAgY29tcGxldGVkQXQ/OiBzdHJpbmc7XG4gIG1ldGFkYXRhPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG59XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNIQURPVyBURVNUUyBBUEkgQ0xJRU5UXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogU2hhZG93IHRlc3RzIEFQSSBjbGllbnQgZm9yIG1hbmFnaW5nIHNoYWRvdyB0ZXN0IGV4ZWN1dGlvblxuICovXG5leHBvcnQgY29uc3Qgc2hhZG93VGVzdHMgPSB7XG4gIC8qKlxuICAgKiBMaXN0IHNoYWRvdyB0ZXN0cyBmb3IgYW4gYWdlbnRcbiAgICpcbiAgICogQHBhcmFtIGFnZW50SWQgLSBUaGUgYWdlbnQgSURcbiAgICogQHJldHVybnMgTGlzdCBvZiBzaGFkb3cgdGVzdHNcbiAgICovXG4gIGFzeW5jIGxpc3QoYWdlbnRJZDogc3RyaW5nKTogUHJvbWlzZTxTaGFkb3dUZXN0W10+IHtcbiAgICBjb25zdCBwYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKHsgYWdlbnRJZCB9KTtcbiAgICByZXR1cm4gYXBpUmVxdWVzdFdpdGhEYXRhPFNoYWRvd1Rlc3RbXT4oYC9zaGFkb3ctdGVzdHM/JHtwYXJhbXN9YCwge1xuICAgICAgYXBpVmVyc2lvbjogJ25vbmUnLFxuICAgIH0pO1xuICB9LFxuXG4gIC8qKlxuICAgKiBHZXQgYSBzaGFkb3cgdGVzdCBieSBJRFxuICAgKlxuICAgKiBAcGFyYW0gaWQgLSBUaGUgc2hhZG93IHRlc3QgSURcbiAgICogQHJldHVybnMgVGhlIHNoYWRvdyB0ZXN0IGRldGFpbHNcbiAgICovXG4gIGFzeW5jIGdldChpZDogc3RyaW5nKTogUHJvbWlzZTxTaGFkb3dUZXN0PiB7XG4gICAgcmV0dXJuIGFwaVJlcXVlc3RXaXRoRGF0YTxTaGFkb3dUZXN0PihgL3NoYWRvdy10ZXN0cy8ke2lkfWAsIHtcbiAgICAgIGFwaVZlcnNpb246ICdub25lJyxcbiAgICB9KTtcbiAgfSxcblxuICAvKipcbiAgICogR2V0IHNoYWRvdyB0ZXN0cyBmb3IgYSBzcGVjaWZpYyBmaXhcbiAgICpcbiAgICogQHBhcmFtIGZpeElkIC0gVGhlIGZpeCBJRFxuICAgKiBAcmV0dXJucyBMaXN0IG9mIHNoYWRvdyB0ZXN0cyBmb3IgdGhlIGZpeFxuICAgKi9cbiAgYXN5bmMgZ2V0QnlGaXgoZml4SWQ6IHN0cmluZyk6IFByb21pc2U8U2hhZG93VGVzdFtdPiB7XG4gICAgcmV0dXJuIGFwaVJlcXVlc3RXaXRoRGF0YTxTaGFkb3dUZXN0W10+KGAvZml4ZXMvJHtmaXhJZH0vc2hhZG93LXRlc3RzYCwge1xuICAgICAgYXBpVmVyc2lvbjogJ25vbmUnLFxuICAgIH0pO1xuICB9LFxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSBuZXcgc2hhZG93IHRlc3RcbiAgICpcbiAgICogQHBhcmFtIGRhdGEgLSBTaGFkb3cgdGVzdCBjb25maWd1cmF0aW9uXG4gICAqIEByZXR1cm5zIFRoZSBjcmVhdGVkIHNoYWRvdyB0ZXN0XG4gICAqL1xuICBhc3luYyBjcmVhdGUoZGF0YTogQ3JlYXRlU2hhZG93VGVzdERhdGEpOiBQcm9taXNlPFNoYWRvd1Rlc3Q+IHtcbiAgICByZXR1cm4gYXBpUmVxdWVzdFdpdGhEYXRhPFNoYWRvd1Rlc3Q+KCcvc2hhZG93LXRlc3RzJywge1xuICAgICAgbWV0aG9kOiAnUE9TVCcsXG4gICAgICBib2R5OiBkYXRhLFxuICAgICAgYXBpVmVyc2lvbjogJ25vbmUnLFxuICAgIH0pO1xuICB9LFxuXG4gIC8qKlxuICAgKiBVcGRhdGUgYSBzaGFkb3cgdGVzdFxuICAgKlxuICAgKiBAcGFyYW0gaWQgLSBUaGUgc2hhZG93IHRlc3QgSUQgdG8gdXBkYXRlXG4gICAqIEBwYXJhbSBkYXRhIC0gRmllbGRzIHRvIHVwZGF0ZVxuICAgKiBAcmV0dXJucyBUaGUgdXBkYXRlZCBzaGFkb3cgdGVzdFxuICAgKi9cbiAgYXN5bmMgdXBkYXRlKGlkOiBzdHJpbmcsIGRhdGE6IFVwZGF0ZVNoYWRvd1Rlc3REYXRhKTogUHJvbWlzZTxTaGFkb3dUZXN0PiB7XG4gICAgcmV0dXJuIGFwaVJlcXVlc3RXaXRoRGF0YTxTaGFkb3dUZXN0PihgL3NoYWRvdy10ZXN0cy8ke2lkfWAsIHtcbiAgICAgIG1ldGhvZDogJ1BBVENIJyxcbiAgICAgIGJvZHk6IGRhdGEsXG4gICAgICBhcGlWZXJzaW9uOiAnbm9uZScsXG4gICAgfSk7XG4gIH0sXG59O1xuXG5leHBvcnQgeyBzaGFkb3dUZXN0cyBhcyBkZWZhdWx0IH07XG4iXX0=
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ThinkHive SDK - Signals API
|
|
3
|
+
*
|
|
4
|
+
* Behavioral signal management for detecting patterns in agent interactions
|
|
5
|
+
*/
|
|
6
|
+
/** Signal detection configuration */
|
|
7
|
+
export interface DetectionConfig {
|
|
8
|
+
type: string;
|
|
9
|
+
threshold?: number;
|
|
10
|
+
pattern?: string;
|
|
11
|
+
[key: string]: unknown;
|
|
12
|
+
}
|
|
13
|
+
/** Options for creating a signal */
|
|
14
|
+
export interface CreateSignalOptions {
|
|
15
|
+
description?: string;
|
|
16
|
+
isEnabled?: boolean;
|
|
17
|
+
severity?: string;
|
|
18
|
+
}
|
|
19
|
+
/** Options for updating a signal */
|
|
20
|
+
export interface UpdateSignalOptions {
|
|
21
|
+
name?: string;
|
|
22
|
+
group?: string;
|
|
23
|
+
description?: string;
|
|
24
|
+
detectionConfig?: DetectionConfig;
|
|
25
|
+
isEnabled?: boolean;
|
|
26
|
+
severity?: string;
|
|
27
|
+
}
|
|
28
|
+
/** Options for listing signals */
|
|
29
|
+
export interface ListSignalsOptions {
|
|
30
|
+
group?: string;
|
|
31
|
+
source?: string;
|
|
32
|
+
isEnabled?: boolean;
|
|
33
|
+
}
|
|
34
|
+
/** Options for getting signal stats */
|
|
35
|
+
export interface SignalStatsOptions {
|
|
36
|
+
startDate?: string;
|
|
37
|
+
endDate?: string;
|
|
38
|
+
agentId?: string;
|
|
39
|
+
}
|
|
40
|
+
/** Options for getting signal trends */
|
|
41
|
+
export interface SignalTrendsOptions {
|
|
42
|
+
startDate?: string;
|
|
43
|
+
endDate?: string;
|
|
44
|
+
agentId?: string;
|
|
45
|
+
granularity?: 'hour' | 'day' | 'week' | 'month';
|
|
46
|
+
}
|
|
47
|
+
/** Options for getting signal traces */
|
|
48
|
+
export interface SignalTracesOptions {
|
|
49
|
+
limit?: number;
|
|
50
|
+
offset?: number;
|
|
51
|
+
startDate?: string;
|
|
52
|
+
endDate?: string;
|
|
53
|
+
agentId?: string;
|
|
54
|
+
}
|
|
55
|
+
/** Options for getting signal events */
|
|
56
|
+
export interface SignalEventsOptions {
|
|
57
|
+
limit?: number;
|
|
58
|
+
offset?: number;
|
|
59
|
+
}
|
|
60
|
+
/** A behavioral signal definition */
|
|
61
|
+
export interface Signal {
|
|
62
|
+
id: string;
|
|
63
|
+
name: string;
|
|
64
|
+
group: string;
|
|
65
|
+
description?: string;
|
|
66
|
+
detectionConfig: DetectionConfig;
|
|
67
|
+
isEnabled: boolean;
|
|
68
|
+
severity?: string;
|
|
69
|
+
source?: string;
|
|
70
|
+
createdAt: string;
|
|
71
|
+
updatedAt: string;
|
|
72
|
+
}
|
|
73
|
+
/** Signal statistics */
|
|
74
|
+
export interface SignalStats {
|
|
75
|
+
signalId: string;
|
|
76
|
+
name: string;
|
|
77
|
+
eventCount: number;
|
|
78
|
+
traceCount: number;
|
|
79
|
+
lastTriggeredAt?: string;
|
|
80
|
+
}
|
|
81
|
+
/** Signal trend data point */
|
|
82
|
+
export interface SignalTrendPoint {
|
|
83
|
+
period: string;
|
|
84
|
+
eventCount: number;
|
|
85
|
+
traceCount: number;
|
|
86
|
+
}
|
|
87
|
+
/** A signal event occurrence */
|
|
88
|
+
export interface SignalEvent {
|
|
89
|
+
id: string;
|
|
90
|
+
signalId: string;
|
|
91
|
+
traceId: string;
|
|
92
|
+
detectedAt: string;
|
|
93
|
+
metadata?: Record<string, unknown>;
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Signals API client for managing behavioral signal detection
|
|
97
|
+
*/
|
|
98
|
+
export declare const signals: {
|
|
99
|
+
/**
|
|
100
|
+
* List all signals with optional filters
|
|
101
|
+
*
|
|
102
|
+
* @param opts - Filter options for group, source, or enabled status
|
|
103
|
+
* @returns List of signals
|
|
104
|
+
*/
|
|
105
|
+
list(opts?: ListSignalsOptions): Promise<Signal[]>;
|
|
106
|
+
/**
|
|
107
|
+
* Create a new behavioral signal
|
|
108
|
+
*
|
|
109
|
+
* @param name - Signal name
|
|
110
|
+
* @param group - Signal group/category
|
|
111
|
+
* @param detectionConfig - Detection configuration
|
|
112
|
+
* @param opts - Additional signal options
|
|
113
|
+
* @returns The created signal
|
|
114
|
+
*/
|
|
115
|
+
create(name: string, group: string, detectionConfig: DetectionConfig, opts?: CreateSignalOptions): Promise<Signal>;
|
|
116
|
+
/**
|
|
117
|
+
* Update an existing signal
|
|
118
|
+
*
|
|
119
|
+
* @param id - Signal ID to update
|
|
120
|
+
* @param opts - Fields to update
|
|
121
|
+
* @returns The updated signal
|
|
122
|
+
*/
|
|
123
|
+
update(id: string, opts: UpdateSignalOptions): Promise<Signal>;
|
|
124
|
+
/**
|
|
125
|
+
* Delete a signal
|
|
126
|
+
*
|
|
127
|
+
* @param id - Signal ID to delete
|
|
128
|
+
*/
|
|
129
|
+
remove(id: string): Promise<void>;
|
|
130
|
+
/**
|
|
131
|
+
* Seed default signal definitions
|
|
132
|
+
*
|
|
133
|
+
* @returns List of seeded signals
|
|
134
|
+
*/
|
|
135
|
+
seedDefaults(): Promise<Signal[]>;
|
|
136
|
+
/**
|
|
137
|
+
* Get signal statistics
|
|
138
|
+
*
|
|
139
|
+
* @param opts - Date range and agent filter options
|
|
140
|
+
* @returns Signal statistics
|
|
141
|
+
*/
|
|
142
|
+
getStats(opts?: SignalStatsOptions): Promise<SignalStats[]>;
|
|
143
|
+
/**
|
|
144
|
+
* Get signal trend data over time
|
|
145
|
+
*
|
|
146
|
+
* @param opts - Date range, agent, and granularity options
|
|
147
|
+
* @returns Signal trend data points
|
|
148
|
+
*/
|
|
149
|
+
getTrends(opts?: SignalTrendsOptions): Promise<SignalTrendPoint[]>;
|
|
150
|
+
/**
|
|
151
|
+
* Get traces that triggered a specific signal
|
|
152
|
+
*
|
|
153
|
+
* @param id - Signal ID
|
|
154
|
+
* @param opts - Pagination and filter options
|
|
155
|
+
* @returns Traces associated with the signal
|
|
156
|
+
*/
|
|
157
|
+
getTraces(id: string, opts?: SignalTracesOptions): Promise<{
|
|
158
|
+
traces: any[];
|
|
159
|
+
limit: number;
|
|
160
|
+
offset: number;
|
|
161
|
+
hasMore: boolean;
|
|
162
|
+
}>;
|
|
163
|
+
/**
|
|
164
|
+
* Get events for a specific signal
|
|
165
|
+
*
|
|
166
|
+
* @param id - Signal ID
|
|
167
|
+
* @param opts - Pagination options
|
|
168
|
+
* @returns Signal events
|
|
169
|
+
*/
|
|
170
|
+
getEvents(id: string, opts?: SignalEventsOptions): Promise<{
|
|
171
|
+
events: SignalEvent[];
|
|
172
|
+
limit: number;
|
|
173
|
+
offset: number;
|
|
174
|
+
hasMore: boolean;
|
|
175
|
+
}>;
|
|
176
|
+
};
|
|
177
|
+
export { signals as default };
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ThinkHive SDK - Signals API
|
|
4
|
+
*
|
|
5
|
+
* Behavioral signal management for detecting patterns in agent interactions
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.default = exports.signals = void 0;
|
|
9
|
+
const client_1 = require("../core/client");
|
|
10
|
+
// ============================================================================
|
|
11
|
+
// SIGNALS API CLIENT
|
|
12
|
+
// ============================================================================
|
|
13
|
+
/**
|
|
14
|
+
* Signals API client for managing behavioral signal detection
|
|
15
|
+
*/
|
|
16
|
+
exports.signals = {
|
|
17
|
+
/**
|
|
18
|
+
* List all signals with optional filters
|
|
19
|
+
*
|
|
20
|
+
* @param opts - Filter options for group, source, or enabled status
|
|
21
|
+
* @returns List of signals
|
|
22
|
+
*/
|
|
23
|
+
async list(opts) {
|
|
24
|
+
const params = new URLSearchParams();
|
|
25
|
+
if (opts?.group)
|
|
26
|
+
params.set('group', opts.group);
|
|
27
|
+
if (opts?.source)
|
|
28
|
+
params.set('source', opts.source);
|
|
29
|
+
if (opts?.isEnabled !== undefined)
|
|
30
|
+
params.set('isEnabled', String(opts.isEnabled));
|
|
31
|
+
const query = params.toString();
|
|
32
|
+
return (0, client_1.apiRequestWithData)(`/signals/${query ? `?${query}` : ''}`, {
|
|
33
|
+
apiVersion: 'v1',
|
|
34
|
+
});
|
|
35
|
+
},
|
|
36
|
+
/**
|
|
37
|
+
* Create a new behavioral signal
|
|
38
|
+
*
|
|
39
|
+
* @param name - Signal name
|
|
40
|
+
* @param group - Signal group/category
|
|
41
|
+
* @param detectionConfig - Detection configuration
|
|
42
|
+
* @param opts - Additional signal options
|
|
43
|
+
* @returns The created signal
|
|
44
|
+
*/
|
|
45
|
+
async create(name, group, detectionConfig, opts) {
|
|
46
|
+
return (0, client_1.apiRequestWithData)('/signals/', {
|
|
47
|
+
method: 'POST',
|
|
48
|
+
body: { name, group, detectionConfig, ...opts },
|
|
49
|
+
apiVersion: 'v1',
|
|
50
|
+
});
|
|
51
|
+
},
|
|
52
|
+
/**
|
|
53
|
+
* Update an existing signal
|
|
54
|
+
*
|
|
55
|
+
* @param id - Signal ID to update
|
|
56
|
+
* @param opts - Fields to update
|
|
57
|
+
* @returns The updated signal
|
|
58
|
+
*/
|
|
59
|
+
async update(id, opts) {
|
|
60
|
+
return (0, client_1.apiRequestWithData)(`/signals/${id}`, {
|
|
61
|
+
method: 'PUT',
|
|
62
|
+
body: opts,
|
|
63
|
+
apiVersion: 'v1',
|
|
64
|
+
});
|
|
65
|
+
},
|
|
66
|
+
/**
|
|
67
|
+
* Delete a signal
|
|
68
|
+
*
|
|
69
|
+
* @param id - Signal ID to delete
|
|
70
|
+
*/
|
|
71
|
+
async remove(id) {
|
|
72
|
+
return (0, client_1.apiRequest)(`/signals/${id}`, {
|
|
73
|
+
method: 'DELETE',
|
|
74
|
+
apiVersion: 'v1',
|
|
75
|
+
});
|
|
76
|
+
},
|
|
77
|
+
/**
|
|
78
|
+
* Seed default signal definitions
|
|
79
|
+
*
|
|
80
|
+
* @returns List of seeded signals
|
|
81
|
+
*/
|
|
82
|
+
async seedDefaults() {
|
|
83
|
+
return (0, client_1.apiRequestWithData)('/signals/seed', {
|
|
84
|
+
method: 'POST',
|
|
85
|
+
apiVersion: 'v1',
|
|
86
|
+
});
|
|
87
|
+
},
|
|
88
|
+
/**
|
|
89
|
+
* Get signal statistics
|
|
90
|
+
*
|
|
91
|
+
* @param opts - Date range and agent filter options
|
|
92
|
+
* @returns Signal statistics
|
|
93
|
+
*/
|
|
94
|
+
async getStats(opts) {
|
|
95
|
+
const params = new URLSearchParams();
|
|
96
|
+
if (opts?.startDate)
|
|
97
|
+
params.set('startDate', opts.startDate);
|
|
98
|
+
if (opts?.endDate)
|
|
99
|
+
params.set('endDate', opts.endDate);
|
|
100
|
+
if (opts?.agentId)
|
|
101
|
+
params.set('agentId', opts.agentId);
|
|
102
|
+
const query = params.toString();
|
|
103
|
+
return (0, client_1.apiRequestWithData)(`/signals/stats${query ? `?${query}` : ''}`, {
|
|
104
|
+
apiVersion: 'v1',
|
|
105
|
+
});
|
|
106
|
+
},
|
|
107
|
+
/**
|
|
108
|
+
* Get signal trend data over time
|
|
109
|
+
*
|
|
110
|
+
* @param opts - Date range, agent, and granularity options
|
|
111
|
+
* @returns Signal trend data points
|
|
112
|
+
*/
|
|
113
|
+
async getTrends(opts) {
|
|
114
|
+
const params = new URLSearchParams();
|
|
115
|
+
if (opts?.startDate)
|
|
116
|
+
params.set('startDate', opts.startDate);
|
|
117
|
+
if (opts?.endDate)
|
|
118
|
+
params.set('endDate', opts.endDate);
|
|
119
|
+
if (opts?.agentId)
|
|
120
|
+
params.set('agentId', opts.agentId);
|
|
121
|
+
if (opts?.granularity)
|
|
122
|
+
params.set('granularity', opts.granularity);
|
|
123
|
+
const query = params.toString();
|
|
124
|
+
return (0, client_1.apiRequestWithData)(`/signals/trends${query ? `?${query}` : ''}`, {
|
|
125
|
+
apiVersion: 'v1',
|
|
126
|
+
});
|
|
127
|
+
},
|
|
128
|
+
/**
|
|
129
|
+
* Get traces that triggered a specific signal
|
|
130
|
+
*
|
|
131
|
+
* @param id - Signal ID
|
|
132
|
+
* @param opts - Pagination and filter options
|
|
133
|
+
* @returns Traces associated with the signal
|
|
134
|
+
*/
|
|
135
|
+
async getTraces(id, opts) {
|
|
136
|
+
const params = new URLSearchParams();
|
|
137
|
+
if (opts?.limit !== undefined)
|
|
138
|
+
params.set('limit', String(opts.limit));
|
|
139
|
+
if (opts?.offset !== undefined)
|
|
140
|
+
params.set('offset', String(opts.offset));
|
|
141
|
+
if (opts?.startDate)
|
|
142
|
+
params.set('startDate', opts.startDate);
|
|
143
|
+
if (opts?.endDate)
|
|
144
|
+
params.set('endDate', opts.endDate);
|
|
145
|
+
if (opts?.agentId)
|
|
146
|
+
params.set('agentId', opts.agentId);
|
|
147
|
+
const query = params.toString();
|
|
148
|
+
return (0, client_1.apiRequestWithData)(`/signals/${id}/traces${query ? `?${query}` : ''}`, {
|
|
149
|
+
apiVersion: 'v1',
|
|
150
|
+
});
|
|
151
|
+
},
|
|
152
|
+
/**
|
|
153
|
+
* Get events for a specific signal
|
|
154
|
+
*
|
|
155
|
+
* @param id - Signal ID
|
|
156
|
+
* @param opts - Pagination options
|
|
157
|
+
* @returns Signal events
|
|
158
|
+
*/
|
|
159
|
+
async getEvents(id, opts) {
|
|
160
|
+
const params = new URLSearchParams();
|
|
161
|
+
if (opts?.limit !== undefined)
|
|
162
|
+
params.set('limit', String(opts.limit));
|
|
163
|
+
if (opts?.offset !== undefined)
|
|
164
|
+
params.set('offset', String(opts.offset));
|
|
165
|
+
const query = params.toString();
|
|
166
|
+
return (0, client_1.apiRequestWithData)(`/signals/${id}/events${query ? `?${query}` : ''}`, {
|
|
167
|
+
apiVersion: 'v1',
|
|
168
|
+
});
|
|
169
|
+
},
|
|
170
|
+
};
|
|
171
|
+
exports.default = exports.signals;
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/api/signals.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * ThinkHive SDK - Signals API\n *\n * Behavioral signal management for detecting patterns in agent interactions\n */\n\nimport { apiRequest, apiRequestWithData } from '../core/client';\n\n// ============================================================================\n// TYPES\n// ============================================================================\n\n/** Signal detection configuration */\nexport interface DetectionConfig {\n  type: string;\n  threshold?: number;\n  pattern?: string;\n  [key: string]: unknown;\n}\n\n/** Options for creating a signal */\nexport interface CreateSignalOptions {\n  description?: string;\n  isEnabled?: boolean;\n  severity?: string;\n}\n\n/** Options for updating a signal */\nexport interface UpdateSignalOptions {\n  name?: string;\n  group?: string;\n  description?: string;\n  detectionConfig?: DetectionConfig;\n  isEnabled?: boolean;\n  severity?: string;\n}\n\n/** Options for listing signals */\nexport interface ListSignalsOptions {\n  group?: string;\n  source?: string;\n  isEnabled?: boolean;\n}\n\n/** Options for getting signal stats */\nexport interface SignalStatsOptions {\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n}\n\n/** Options for getting signal trends */\nexport interface SignalTrendsOptions {\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n  granularity?: 'hour' | 'day' | 'week' | 'month';\n}\n\n/** Options for getting signal traces */\nexport interface SignalTracesOptions {\n  limit?: number;\n  offset?: number;\n  startDate?: string;\n  endDate?: string;\n  agentId?: string;\n}\n\n/** Options for getting signal events */\nexport interface SignalEventsOptions {\n  limit?: number;\n  offset?: number;\n}\n\n/** A behavioral signal definition */\nexport interface Signal {\n  id: string;\n  name: string;\n  group: string;\n  description?: string;\n  detectionConfig: DetectionConfig;\n  isEnabled: boolean;\n  severity?: string;\n  source?: string;\n  createdAt: string;\n  updatedAt: string;\n}\n\n/** Signal statistics */\nexport interface SignalStats {\n  signalId: string;\n  name: string;\n  eventCount: number;\n  traceCount: number;\n  lastTriggeredAt?: string;\n}\n\n/** Signal trend data point */\nexport interface SignalTrendPoint {\n  period: string;\n  eventCount: number;\n  traceCount: number;\n}\n\n/** A signal event occurrence */\nexport interface SignalEvent {\n  id: string;\n  signalId: string;\n  traceId: string;\n  detectedAt: string;\n  metadata?: Record<string, unknown>;\n}\n\n// ============================================================================\n// SIGNALS API CLIENT\n// ============================================================================\n\n/**\n * Signals API client for managing behavioral signal detection\n */\nexport const signals = {\n  /**\n   * List all signals with optional filters\n   *\n   * @param opts - Filter options for group, source, or enabled status\n   * @returns List of signals\n   */\n  async list(opts?: ListSignalsOptions): Promise<Signal[]> {\n    const params = new URLSearchParams();\n    if (opts?.group) params.set('group', opts.group);\n    if (opts?.source) params.set('source', opts.source);\n    if (opts?.isEnabled !== undefined) params.set('isEnabled', String(opts.isEnabled));\n\n    const query = params.toString();\n    return apiRequestWithData<Signal[]>(`/signals/${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Create a new behavioral signal\n   *\n   * @param name - Signal name\n   * @param group - Signal group/category\n   * @param detectionConfig - Detection configuration\n   * @param opts - Additional signal options\n   * @returns The created signal\n   */\n  async create(\n    name: string,\n    group: string,\n    detectionConfig: DetectionConfig,\n    opts?: CreateSignalOptions\n  ): Promise<Signal> {\n    return apiRequestWithData<Signal>('/signals/', {\n      method: 'POST',\n      body: { name, group, detectionConfig, ...opts },\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Update an existing signal\n   *\n   * @param id - Signal ID to update\n   * @param opts - Fields to update\n   * @returns The updated signal\n   */\n  async update(id: string, opts: UpdateSignalOptions): Promise<Signal> {\n    return apiRequestWithData<Signal>(`/signals/${id}`, {\n      method: 'PUT',\n      body: opts,\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Delete a signal\n   *\n   * @param id - Signal ID to delete\n   */\n  async remove(id: string): Promise<void> {\n    return apiRequest<void>(`/signals/${id}`, {\n      method: 'DELETE',\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Seed default signal definitions\n   *\n   * @returns List of seeded signals\n   */\n  async seedDefaults(): Promise<Signal[]> {\n    return apiRequestWithData<Signal[]>('/signals/seed', {\n      method: 'POST',\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get signal statistics\n   *\n   * @param opts - Date range and agent filter options\n   * @returns Signal statistics\n   */\n  async getStats(opts?: SignalStatsOptions): Promise<SignalStats[]> {\n    const params = new URLSearchParams();\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n\n    const query = params.toString();\n    return apiRequestWithData<SignalStats[]>(`/signals/stats${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get signal trend data over time\n   *\n   * @param opts - Date range, agent, and granularity options\n   * @returns Signal trend data points\n   */\n  async getTrends(opts?: SignalTrendsOptions): Promise<SignalTrendPoint[]> {\n    const params = new URLSearchParams();\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n    if (opts?.granularity) params.set('granularity', opts.granularity);\n\n    const query = params.toString();\n    return apiRequestWithData<SignalTrendPoint[]>(`/signals/trends${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get traces that triggered a specific signal\n   *\n   * @param id - Signal ID\n   * @param opts - Pagination and filter options\n   * @returns Traces associated with the signal\n   */\n  async getTraces(id: string, opts?: SignalTracesOptions): Promise<{\n    traces: any[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  }> {\n    const params = new URLSearchParams();\n    if (opts?.limit !== undefined) params.set('limit', String(opts.limit));\n    if (opts?.offset !== undefined) params.set('offset', String(opts.offset));\n    if (opts?.startDate) params.set('startDate', opts.startDate);\n    if (opts?.endDate) params.set('endDate', opts.endDate);\n    if (opts?.agentId) params.set('agentId', opts.agentId);\n\n    const query = params.toString();\n    return apiRequestWithData(`/signals/${id}/traces${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n\n  /**\n   * Get events for a specific signal\n   *\n   * @param id - Signal ID\n   * @param opts - Pagination options\n   * @returns Signal events\n   */\n  async getEvents(id: string, opts?: SignalEventsOptions): Promise<{\n    events: SignalEvent[];\n    limit: number;\n    offset: number;\n    hasMore: boolean;\n  }> {\n    const params = new URLSearchParams();\n    if (opts?.limit !== undefined) params.set('limit', String(opts.limit));\n    if (opts?.offset !== undefined) params.set('offset', String(opts.offset));\n\n    const query = params.toString();\n    return apiRequestWithData(`/signals/${id}/events${query ? `?${query}` : ''}`, {\n      apiVersion: 'v1',\n    });\n  },\n};\n\nexport { signals as default };\n"]}
|
package/dist/core/client.d.ts
CHANGED
|
@@ -13,6 +13,8 @@ export interface RequestOptions {
|
|
|
13
13
|
maxRetries?: number;
|
|
14
14
|
/** Request timeout in milliseconds */
|
|
15
15
|
timeout?: number;
|
|
16
|
+
/** Use path as-is without prepending /api/ prefix (for routes like /v1/guardrails/scan) */
|
|
17
|
+
rawPath?: boolean;
|
|
16
18
|
}
|
|
17
19
|
/**
|
|
18
20
|
* Make an authenticated API request with retry logic
|