webdaemon 21.1.0 → 24.0.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/index.js +17 -3
- package/dist/index.js.map +4 -4
- package/dist/types/index.d.ts +20 -18
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/js/BrowserApp.d.ts +1 -1
- package/dist/types/js/GenerativeChatBrowser.d.ts +192 -0
- package/dist/types/js/GenerativeChatBrowser.d.ts.map +1 -0
- package/dist/types/js/Token.d.ts +9 -9
- package/dist/types/js/Token.d.ts.map +1 -1
- package/dist/types/ts/GenerativeChatAgent.d.ts +45 -0
- package/dist/types/ts/GenerativeChatAgent.d.ts.map +1 -0
- package/dist/types/ts/McpServer.d.ts +1 -1
- package/dist/types/ts/McpServer.d.ts.map +1 -1
- package/dist/types/ts/McpToolAuthorization.d.ts +17 -2
- package/dist/types/ts/McpToolAuthorization.d.ts.map +1 -1
- package/dist/types/ts/YamlContent.d.ts +15 -1
- package/dist/types/ts/YamlContent.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/types/index.d.ts
CHANGED
|
@@ -1,22 +1,24 @@
|
|
|
1
1
|
/** Common libs */
|
|
2
|
-
export * from
|
|
3
|
-
export * from
|
|
4
|
-
export * from
|
|
2
|
+
export * from "./js/Digest.js";
|
|
3
|
+
export * from "./js/GenerativeChatBrowser.js";
|
|
4
|
+
export * from "./js/KeyPair.js";
|
|
5
|
+
export * from "./js/Token.js";
|
|
5
6
|
/** Browser libs */
|
|
6
|
-
export * from
|
|
7
|
-
export * from
|
|
8
|
-
export * from
|
|
9
|
-
export * from
|
|
10
|
-
export * from
|
|
7
|
+
export * from "./js/Alert.js";
|
|
8
|
+
export * from "./js/BrowserApp.js";
|
|
9
|
+
export * from "./js/ParentHelper.js";
|
|
10
|
+
export * from "./js/QrCode.js";
|
|
11
|
+
export * from "./js/Storage.js";
|
|
11
12
|
/** Backend libs */
|
|
12
|
-
export * from
|
|
13
|
-
export * from
|
|
14
|
-
export * from
|
|
15
|
-
export * from
|
|
16
|
-
export * from
|
|
17
|
-
export * from
|
|
18
|
-
export * from
|
|
19
|
-
export * from
|
|
20
|
-
export * from
|
|
21
|
-
export * from
|
|
13
|
+
export * from "./ts/Assertions.ts";
|
|
14
|
+
export * from "./ts/GenerativeChatAgent.ts";
|
|
15
|
+
export * from "./ts/HtmlContent.ts";
|
|
16
|
+
export * from "./ts/Lifecycle.ts";
|
|
17
|
+
export * from "./ts/McpAgentTools.ts";
|
|
18
|
+
export * from "./ts/McpClient.ts";
|
|
19
|
+
export * from "./ts/McpServer.ts";
|
|
20
|
+
export * from "./ts/McpToolAuthorization.ts";
|
|
21
|
+
export * from "./ts/Requests.ts";
|
|
22
|
+
export * from "./ts/Responses.ts";
|
|
23
|
+
export * from "./ts/YamlContent.ts";
|
|
22
24
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../index.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,cAAc,gBAAgB,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../index.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,cAAc,gBAAgB,CAAC;AAC/B,cAAc,+BAA+B,CAAC;AAC9C,cAAc,iBAAiB,CAAC;AAChC,cAAc,eAAe,CAAC;AAE9B,mBAAmB;AACnB,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAEhC,mBAAmB;AACnB,cAAc,oBAAoB,CAAC;AACnC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,qBAAqB,CAAC;AACpC,cAAc,mBAAmB,CAAC;AAClC,cAAc,uBAAuB,CAAC;AACtC,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export class BrowserApp {
|
|
2
2
|
/** @type {BrowserApp | null} */
|
|
3
|
-
static "__#
|
|
3
|
+
static "__#3@#instance": BrowserApp | null;
|
|
4
4
|
/**
|
|
5
5
|
* Gets the singleton instance of BrowserApp. On invocations
|
|
6
6
|
* after the first, the app name must be omitted or match
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @param {BrowserChatApp=} app
|
|
3
|
+
* @return {ClientToolRegistry}
|
|
4
|
+
*/
|
|
5
|
+
export function createDefaultBrowserChatTools(app?: BrowserChatApp | undefined): ClientToolRegistry;
|
|
6
|
+
/**
|
|
7
|
+
* @typedef {{
|
|
8
|
+
* isOrphan: Function,
|
|
9
|
+
* getAgentUrl: Function,
|
|
10
|
+
* getTokenBase64: Function,
|
|
11
|
+
* getParty: Function,
|
|
12
|
+
* getToken: Function,
|
|
13
|
+
* }} BrowserChatApp
|
|
14
|
+
*/
|
|
15
|
+
/**
|
|
16
|
+
* @typedef {{
|
|
17
|
+
* events?: object[],
|
|
18
|
+
* clientToolCalls?: Array<{ id: string, name: string, input?: object }>,
|
|
19
|
+
* }} ConversationRound
|
|
20
|
+
*/
|
|
21
|
+
export class ClientToolRegistry {
|
|
22
|
+
/**
|
|
23
|
+
* @param {string} name
|
|
24
|
+
* @param {object} descriptor
|
|
25
|
+
* @param {Function} execute
|
|
26
|
+
* @return {ClientToolRegistry}
|
|
27
|
+
*/
|
|
28
|
+
register(name: string, descriptor: object, execute: Function): ClientToolRegistry;
|
|
29
|
+
/**
|
|
30
|
+
* @return {object[]}
|
|
31
|
+
*/
|
|
32
|
+
descriptors(): object[];
|
|
33
|
+
/**
|
|
34
|
+
* @param {Array<{ id: string, name: string, input?: object }>} toolCalls
|
|
35
|
+
* @param {object=} context
|
|
36
|
+
* @return {Promise<Array<object>>}
|
|
37
|
+
*/
|
|
38
|
+
executeToolCalls(toolCalls: Array<{
|
|
39
|
+
id: string;
|
|
40
|
+
name: string;
|
|
41
|
+
input?: object;
|
|
42
|
+
}>, context?: object | undefined): Promise<Array<object>>;
|
|
43
|
+
#private;
|
|
44
|
+
}
|
|
45
|
+
export class GenerativeChatClient {
|
|
46
|
+
/**
|
|
47
|
+
* @param {{
|
|
48
|
+
* app?: BrowserChatApp,
|
|
49
|
+
* appName?: string,
|
|
50
|
+
* agentTab?: string,
|
|
51
|
+
* clientTools?: ClientToolRegistry,
|
|
52
|
+
* }=} options
|
|
53
|
+
*/
|
|
54
|
+
constructor(options?: {
|
|
55
|
+
app?: BrowserChatApp;
|
|
56
|
+
appName?: string;
|
|
57
|
+
agentTab?: string;
|
|
58
|
+
clientTools?: ClientToolRegistry;
|
|
59
|
+
} | undefined);
|
|
60
|
+
/**
|
|
61
|
+
* @return {BrowserChatApp | null}
|
|
62
|
+
*/
|
|
63
|
+
get app(): BrowserChatApp | null;
|
|
64
|
+
/**
|
|
65
|
+
* @return {string | null}
|
|
66
|
+
*/
|
|
67
|
+
get agentUrl(): string | null;
|
|
68
|
+
/**
|
|
69
|
+
* @return {ClientToolRegistry}
|
|
70
|
+
*/
|
|
71
|
+
get clientTools(): ClientToolRegistry;
|
|
72
|
+
/**
|
|
73
|
+
* @return {Promise<GenerativeChatClient>}
|
|
74
|
+
*/
|
|
75
|
+
init(): Promise<GenerativeChatClient>;
|
|
76
|
+
/**
|
|
77
|
+
* @return {boolean}
|
|
78
|
+
*/
|
|
79
|
+
isOrphan(): boolean;
|
|
80
|
+
/**
|
|
81
|
+
* @return {string}
|
|
82
|
+
*/
|
|
83
|
+
getParty(): string;
|
|
84
|
+
/**
|
|
85
|
+
* @param {{ targetParty: string }} options
|
|
86
|
+
* @return {Promise<object>}
|
|
87
|
+
*/
|
|
88
|
+
listChats({ targetParty }: {
|
|
89
|
+
targetParty: string;
|
|
90
|
+
}): Promise<object>;
|
|
91
|
+
/**
|
|
92
|
+
* @param {{
|
|
93
|
+
* targetParty: string,
|
|
94
|
+
* chatId?: string | null,
|
|
95
|
+
* systemPrompt?: string,
|
|
96
|
+
* temperature?: number,
|
|
97
|
+
* }} options
|
|
98
|
+
* @return {Promise<object>}
|
|
99
|
+
*/
|
|
100
|
+
createSession(options: {
|
|
101
|
+
targetParty: string;
|
|
102
|
+
chatId?: string | null;
|
|
103
|
+
systemPrompt?: string;
|
|
104
|
+
temperature?: number;
|
|
105
|
+
}): Promise<object>;
|
|
106
|
+
/**
|
|
107
|
+
* @param {{
|
|
108
|
+
* targetParty: string,
|
|
109
|
+
* chatId: string,
|
|
110
|
+
* message: string,
|
|
111
|
+
* temperature?: number,
|
|
112
|
+
* toolsEnabled?: boolean,
|
|
113
|
+
* toolDetails?: boolean,
|
|
114
|
+
* onConversationResult?: Function,
|
|
115
|
+
* onClientToolCalls?: Function,
|
|
116
|
+
* }} options
|
|
117
|
+
* @return {Promise<object>}
|
|
118
|
+
*/
|
|
119
|
+
sendMessage(options: {
|
|
120
|
+
targetParty: string;
|
|
121
|
+
chatId: string;
|
|
122
|
+
message: string;
|
|
123
|
+
temperature?: number;
|
|
124
|
+
toolsEnabled?: boolean;
|
|
125
|
+
toolDetails?: boolean;
|
|
126
|
+
onConversationResult?: Function;
|
|
127
|
+
onClientToolCalls?: Function;
|
|
128
|
+
}): Promise<object>;
|
|
129
|
+
/**
|
|
130
|
+
* @param {{
|
|
131
|
+
* targetParty: string,
|
|
132
|
+
* chatId: string,
|
|
133
|
+
* toolResults: Array<object>,
|
|
134
|
+
* temperature?: number,
|
|
135
|
+
* toolsEnabled?: boolean,
|
|
136
|
+
* toolDetails?: boolean,
|
|
137
|
+
* }} options
|
|
138
|
+
* @return {Promise<object>}
|
|
139
|
+
*/
|
|
140
|
+
sendClientToolResults(options: {
|
|
141
|
+
targetParty: string;
|
|
142
|
+
chatId: string;
|
|
143
|
+
toolResults: Array<object>;
|
|
144
|
+
temperature?: number;
|
|
145
|
+
toolsEnabled?: boolean;
|
|
146
|
+
toolDetails?: boolean;
|
|
147
|
+
}): Promise<object>;
|
|
148
|
+
/**
|
|
149
|
+
* @param {{ targetParty: string, chatId: string }} options
|
|
150
|
+
* @return {Promise<object>}
|
|
151
|
+
*/
|
|
152
|
+
closeChat({ targetParty, chatId }: {
|
|
153
|
+
targetParty: string;
|
|
154
|
+
chatId: string;
|
|
155
|
+
}): Promise<object>;
|
|
156
|
+
/**
|
|
157
|
+
* @param {{ targetParty: string, chatId: string }} options
|
|
158
|
+
* @return {Promise<object>}
|
|
159
|
+
*/
|
|
160
|
+
deleteChat({ targetParty, chatId }: {
|
|
161
|
+
targetParty: string;
|
|
162
|
+
chatId: string;
|
|
163
|
+
}): Promise<object>;
|
|
164
|
+
/**
|
|
165
|
+
* @param {string} path
|
|
166
|
+
* @param {object} body
|
|
167
|
+
* @return {Promise<object>}
|
|
168
|
+
*/
|
|
169
|
+
postAgent(path: string, body: object): Promise<object>;
|
|
170
|
+
/**
|
|
171
|
+
* @param {unknown} value
|
|
172
|
+
* @return {string}
|
|
173
|
+
*/
|
|
174
|
+
normalizeTargetParty(value: unknown): string;
|
|
175
|
+
#private;
|
|
176
|
+
}
|
|
177
|
+
export type BrowserChatApp = {
|
|
178
|
+
isOrphan: Function;
|
|
179
|
+
getAgentUrl: Function;
|
|
180
|
+
getTokenBase64: Function;
|
|
181
|
+
getParty: Function;
|
|
182
|
+
getToken: Function;
|
|
183
|
+
};
|
|
184
|
+
export type ConversationRound = {
|
|
185
|
+
events?: object[];
|
|
186
|
+
clientToolCalls?: Array<{
|
|
187
|
+
id: string;
|
|
188
|
+
name: string;
|
|
189
|
+
input?: object;
|
|
190
|
+
}>;
|
|
191
|
+
};
|
|
192
|
+
//# sourceMappingURL=GenerativeChatBrowser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GenerativeChatBrowser.d.ts","sourceRoot":"","sources":["../../../js/GenerativeChatBrowser.js"],"names":[],"mappings":"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"}
|
package/dist/types/js/Token.d.ts
CHANGED
|
@@ -29,33 +29,33 @@ export class Token {
|
|
|
29
29
|
static DEFAULT_EXPIRY_MILLIS: number;
|
|
30
30
|
static TOKEN_HEADER: string;
|
|
31
31
|
static SCOPE_SEPARATOR: RegExp;
|
|
32
|
-
static "__#
|
|
33
|
-
static "__#
|
|
32
|
+
static "__#1@#SIGNATORY_CACHE_TTL_MILLIS": number;
|
|
33
|
+
static "__#1@#SIGNATORY_CACHE_MAX_ENTRIES": number;
|
|
34
34
|
/** @type{Map<string, SignatoryCacheEntry>} */
|
|
35
|
-
static "__#
|
|
35
|
+
static "__#1@#signatoryCache": Map<string, SignatoryCacheEntry>;
|
|
36
36
|
/** @type{Map<string, Promise<SignatoryCacheEntry>>} */
|
|
37
|
-
static "__#
|
|
37
|
+
static "__#1@#signatoryCacheInFlight": Map<string, Promise<SignatoryCacheEntry>>;
|
|
38
38
|
/**
|
|
39
39
|
* Returns a signatory cache entry from cache or network.
|
|
40
40
|
*
|
|
41
41
|
* @param {string} issuer issuer URL.
|
|
42
42
|
* @returns {Promise<SignatoryCacheEntry>}
|
|
43
43
|
*/
|
|
44
|
-
static "__#
|
|
44
|
+
static "__#1@#getCachedSignatory"(issuer: string): Promise<SignatoryCacheEntry>;
|
|
45
45
|
/**
|
|
46
46
|
* Returns a currently valid cached entry if present.
|
|
47
47
|
*
|
|
48
48
|
* @param {string} issuer issuer URL.
|
|
49
49
|
* @returns {SignatoryCacheEntry | null}
|
|
50
50
|
*/
|
|
51
|
-
static "__#
|
|
51
|
+
static "__#1@#getFreshCachedSignatory"(issuer: string): SignatoryCacheEntry | null;
|
|
52
52
|
/**
|
|
53
53
|
* Adds/replaces a cache entry and enforces bounded size.
|
|
54
54
|
*
|
|
55
55
|
* @param {string} issuer issuer URL.
|
|
56
56
|
* @param {SignatoryCacheEntry} entry signatory cache entry.
|
|
57
57
|
*/
|
|
58
|
-
static "__#
|
|
58
|
+
static "__#1@#putCachedSignatory"(issuer: string, entry: SignatoryCacheEntry): void;
|
|
59
59
|
/**
|
|
60
60
|
* Fetches signatory details for the supplied issuer.
|
|
61
61
|
*
|
|
@@ -63,7 +63,7 @@ export class Token {
|
|
|
63
63
|
* @returns {Promise<Signatory>}
|
|
64
64
|
* @throws {string} if issuer cannot be read.
|
|
65
65
|
*/
|
|
66
|
-
static "__#
|
|
66
|
+
static "__#1@#fetchSignatoryForIssuer"(issuer: string): Promise<Signatory>;
|
|
67
67
|
/**
|
|
68
68
|
* Imports and validates a JWK for signature verification.
|
|
69
69
|
*
|
|
@@ -72,7 +72,7 @@ export class Token {
|
|
|
72
72
|
* @returns {Promise<CryptoKey>}
|
|
73
73
|
* @throws {string} if key is missing or invalid.
|
|
74
74
|
*/
|
|
75
|
-
static "__#
|
|
75
|
+
static "__#1@#importPublicKey"(publicJwk: JsonWebKey, issuer: string): Promise<CryptoKey>;
|
|
76
76
|
/**
|
|
77
77
|
* Returns a base64 JSON string corresponding to the provided byte array.
|
|
78
78
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Token.d.ts","sourceRoot":"","sources":["../../../js/Token.js"],"names":[],"mappings":"AA6FA;
|
|
1
|
+
{"version":3,"file":"Token.d.ts","sourceRoot":"","sources":["../../../js/Token.js"],"names":[],"mappings":"AA6FA;IAEE;;MAEC;IAGD;;MAEC;IAGD;;;;;;;;;;;;;;;;;;;;MAoBC;IAED,qCAAkD;IAClD,4BAAyC;IACzC,+BAAoC;IACpC,kDAA8C;IAC9C,mDAA0C;IAE1C,8CAA8C;IAC9C,+BADU,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC,CACR;IAElC,uDAAuD;IACvD,uCADU,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,mBAAmB,CAAC,CAAC,CACT;IAsP1C;;;;;OAKG;IACH,0CAHW,MAAM,GACJ,OAAO,CAAC,mBAAmB,CAAC,CA+BxC;IAED;;;;;OAKG;IACH,+CAHW,MAAM,GACJ,mBAAmB,GAAG,IAAI,CAiBtC;IAED;;;;;OAKG;IACH,0CAHW,MAAM,SACN,mBAAmB,QAoB7B;IAED;;;;;;OAMG;IACH,+CAJW,MAAM,GACJ,OAAO,CAAC,SAAS,CAAC,CAgC9B;IAED;;;;;;;OAOG;IACH,0CALW,UAAU,UACV,MAAM,GACJ,OAAO,CAAC,SAAS,CAAC,CAc9B;IAoMD;;;;;OAKG;IACH,4BAHW,UAAU,GACR,MAAM,CAKlB;IAED;;;;;OAKG;IACH,6BAHW,MAAM,GACJ,UAAU,CAKtB;IAED;;;;;;;OAOG;IACH,qBAJW,OAAO,GACN,KAAK,GAAG,IAAI,CAUvB;IAED;;;;;;;;;;;OAWG;IACH,gCAHW,QAAQ,GACN,MAAM,CAUlB;IAhnBD;;;;;;;OAOG;IACH,oBAFW,MAAM,GAAG,MAAM,EAuDzB;IAED;;;;;;OAMG;IACH,4BAHW,OAAO,CAAC,UAAU,CAAC,GAClB,OAAO,CAAC,MAAM,CAAC,CA0B1B;IAED;;;;;OAKG;IACH,iCASC;IAED;;;;;;;;OAQG;IACH,gCAIC;IAED;;;;;;OAMG;IACH,iCAHW,OAAO,CAAC,UAAU,CAAC,iBAc7B;IAiOD;;;;OAIG;IACH,oBAFY,YAAY,CAWvB;IAED;;;;OAIG;IACH,cAFY,YAAY,CAOvB;IAED;;;;OAIG;IACH,UAFY,MAAM,CAIjB;IAED;;;;OAIG;IACH,YAFY,MAAM,CAIjB;IAED;;;;OAIG;IACH,UAFY,MAAM,CAIjB;IAED;;;;OAIG;IACH,UAFY,MAAM,CAIjB;IAED;;;;;OAKG;IACH,mBAFY,MAAM,CAIjB;IAED;;;;;;OAMG;IACH,mBAFa,MAAM,CAQlB;IAED;;;;OAIG;IACH,gBAFY,GAAG,CAId;IAED;;;;;OAKG;IACH,aAFY,GAAG,CAId;IAED;;;;OAIG;IACH,cAFY,MAAM,EAAE,CAYnB;IAED;;;;;;;;OAQG;IACH,wBAHW,MAAM,GACL,MAAM,EAAE,CAanB;IAED;;;;;;;OAOG;IACH,sBAJW,MAAM,cACN,MAAM,GACL,OAAO,CAIlB;IAED;;;;;OAKG;IACH,oBAkBC;IAED;;;;OAIG;IACH,kBAFY,MAAM,CAIjB;;CA8DF;;;;;;;;SAhuBa,MAAM;;;;SACN,MAAM;;;;SACN,MAAM;;;;SACN,MAAM;;;;WACN,KAAK;;;;SACL,MAAM;;;;SACN,MAAM;;;;SACN,MAAM;;;;;;;;;SAKN,MAAM;SACN,UAAU;;;eAKV,SAAS;eACT,SAAS;eACT,MAAM"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Token } from '../js/Token.js';
|
|
2
|
+
import { type ChatToolCall, type ToolResult } from './McpAgentTools.ts';
|
|
3
|
+
import { type McpContext } from './McpServer.ts';
|
|
4
|
+
import type { McpCapabilityToken } from './McpToolAuthorization.ts';
|
|
5
|
+
import type { YamlContent } from './YamlContent.ts';
|
|
6
|
+
export interface GenerativeChatAgentOptions {
|
|
7
|
+
targetScope: string;
|
|
8
|
+
defaultSystemPromptUrl?: URL | string;
|
|
9
|
+
defaultTemperature?: number;
|
|
10
|
+
maxToolRounds?: number;
|
|
11
|
+
mcpPath?: string;
|
|
12
|
+
}
|
|
13
|
+
export interface GenerativeChatMessage {
|
|
14
|
+
role?: string;
|
|
15
|
+
content?: string;
|
|
16
|
+
toolCalls?: ChatToolCall[];
|
|
17
|
+
toolResults?: ToolResult[];
|
|
18
|
+
}
|
|
19
|
+
export interface GenerativeChatRenderEvent {
|
|
20
|
+
role: 'user' | 'assistant' | 'tool' | 'tool-result';
|
|
21
|
+
content: string;
|
|
22
|
+
error?: boolean;
|
|
23
|
+
}
|
|
24
|
+
export interface GenerativeChatConversationResult {
|
|
25
|
+
events: GenerativeChatRenderEvent[];
|
|
26
|
+
clientToolCalls?: ChatToolCall[];
|
|
27
|
+
}
|
|
28
|
+
export interface GenerativeChatMcpContext extends McpContext {
|
|
29
|
+
party: string;
|
|
30
|
+
source: string;
|
|
31
|
+
protocol: string;
|
|
32
|
+
sourcePrefix: string;
|
|
33
|
+
yaml?: YamlContent;
|
|
34
|
+
token: Token | McpCapabilityToken | null;
|
|
35
|
+
request: Request;
|
|
36
|
+
}
|
|
37
|
+
export declare class GenerativeChatAgent {
|
|
38
|
+
#private;
|
|
39
|
+
constructor(options: GenerativeChatAgentOptions);
|
|
40
|
+
handler(request: Request): Promise<Response>;
|
|
41
|
+
askExpert(request: Request, question: string): Promise<{
|
|
42
|
+
answer: string;
|
|
43
|
+
}>;
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=GenerativeChatAgent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GenerativeChatAgent.d.ts","sourceRoot":"","sources":["../../../ts/GenerativeChatAgent.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtC,OAAO,EAEL,KAAK,YAAY,EAGjB,KAAK,UAAU,EAChB,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAGL,KAAK,UAAU,EAIhB,MAAM,gBAAgB,CAAA;AAEvB,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAA;AAGnE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAUnD,MAAM,WAAW,0BAA0B;IACzC,WAAW,EAAE,MAAM,CAAA;IACnB,sBAAsB,CAAC,EAAE,GAAG,GAAG,MAAM,CAAA;IACrC,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,SAAS,CAAC,EAAE,YAAY,EAAE,CAAA;IAC1B,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;CAC3B;AA4BD,MAAM,WAAW,yBAAyB;IACxC,IAAI,EAAE,MAAM,GAAG,WAAW,GAAG,MAAM,GAAG,aAAa,CAAA;IACnD,OAAO,EAAE,MAAM,CAAA;IACf,KAAK,CAAC,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,gCAAgC;IAC/C,MAAM,EAAE,yBAAyB,EAAE,CAAA;IACnC,eAAe,CAAC,EAAE,YAAY,EAAE,CAAA;CACjC;AAED,MAAM,WAAW,wBAAyB,SAAQ,UAAU;IAC1D,KAAK,EAAE,MAAM,CAAA;IACb,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,EAAE,MAAM,CAAA;IAChB,YAAY,EAAE,MAAM,CAAA;IACpB,IAAI,CAAC,EAAE,WAAW,CAAA;IAClB,KAAK,EAAE,KAAK,GAAG,kBAAkB,GAAG,IAAI,CAAA;IACxC,OAAO,EAAE,OAAO,CAAA;CACjB;AAED,qBAAa,mBAAmB;;gBAalB,OAAO,EAAE,0BAA0B;IA6BzC,OAAO,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC;IA4C5C,SAAS,CACb,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;CA6nB/B"}
|
|
@@ -17,7 +17,7 @@ export interface McpToolDefinition<TContext extends McpContext> {
|
|
|
17
17
|
call: (args: McpToolArguments, context: TContext) => Promise<JSONValue> | JSONValue;
|
|
18
18
|
}
|
|
19
19
|
export interface McpToolProvider<TContext extends McpContext> {
|
|
20
|
-
listTools(): JSONValue[];
|
|
20
|
+
listTools(context?: TContext): Promise<JSONValue[]> | JSONValue[];
|
|
21
21
|
callTool(name: string, args: McpToolArguments, context: TContext): Promise<JSONValue>;
|
|
22
22
|
}
|
|
23
23
|
export interface JsonRpcMcpServerOptions<TContext extends McpContext> {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"McpServer.d.ts","sourceRoot":"","sources":["../../../ts/McpServer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"McpServer.d.ts","sourceRoot":"","sources":["../../../ts/McpServer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAS5D,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;AAEtD,MAAM,WAAW,UAAU;IACzB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB;AAED,MAAM,WAAW,iBAAiB,CAAC,QAAQ,SAAS,UAAU;IAC5D,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,WAAW,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,SAAS,CAAA;IACtB,YAAY,CAAC,EAAE,SAAS,CAAA;IACxB,WAAW,CAAC,EAAE,UAAU,CAAA;IACxB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,IAAI,EAAE,CACJ,IAAI,EAAE,gBAAgB,EACtB,OAAO,EAAE,QAAQ,KACd,OAAO,CAAC,SAAS,CAAC,GAAG,SAAS,CAAA;CACpC;AAED,MAAM,WAAW,eAAe,CAAC,QAAQ,SAAS,UAAU;IAC1D,SAAS,CAAC,OAAO,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC,GAAG,SAAS,EAAE,CAAA;IACjE,QAAQ,CACN,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,gBAAgB,EACtB,OAAO,EAAE,QAAQ,GAChB,OAAO,CAAC,SAAS,CAAC,CAAA;CACtB;AAED,MAAM,WAAW,uBAAuB,CAAC,QAAQ,SAAS,UAAU;IAClE,UAAU,CAAC,EAAE;QACX,IAAI,EAAE,MAAM,CAAA;QACZ,OAAO,EAAE,MAAM,CAAA;KAChB,CAAA;IACD,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,QAAQ,CAAA;CACxC;AAED,qBAAa,eAAe,CAAC,QAAQ,SAAS,UAAU,CACtD,YAAW,eAAe,CAAC,QAAQ,CAAC;;gBAGxB,KAAK,EAAE,iBAAiB,CAAC,QAAQ,CAAC,EAAE;IAIhD,SAAS,IAAI,SAAS,EAAE;IAelB,QAAQ,CACZ,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,gBAAgB,EACtB,OAAO,EAAE,QAAQ,GAChB,OAAO,CAAC,SAAS,CAAC;CAOtB;AAED,qBAAa,gBAAgB,CAAC,QAAQ,SAAS,UAAU,GAAG,UAAU;;gBAMlE,KAAK,EAAE,eAAe,CAAC,QAAQ,CAAC,EAChC,gBAAgB,EACZ,CAAC,CAAC,OAAO,EAAE,OAAO,KAAK,QAAQ,CAAC,GAChC,uBAAuB,CAAC,QAAQ,CAAC;IAkBjC,MAAM,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,QAAQ,CAAC;CA8GlD;AAED,qBAAa,aAAc,SAAQ,KAAK;IACtC,IAAI,EAAE,MAAM,CAAA;gBAEA,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;CAI1C;AAED,wBAAgB,aAAa,CAC3B,iBAAiB,EAAE,SAAS,EAC5B,OAAO,UAAQ,GACd,SAAS,CAaX"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Grant, YamlContent } from
|
|
1
|
+
import type { Grant, YamlContent } from './YamlContent.ts';
|
|
2
2
|
export declare const USE_TOOLS_CAPABILITY = "useTools";
|
|
3
3
|
export interface McpCapabilityToken {
|
|
4
4
|
hasCapability(source: string, capability: string): boolean;
|
|
@@ -6,6 +6,21 @@ export interface McpCapabilityToken {
|
|
|
6
6
|
getSourceUrl(): URL;
|
|
7
7
|
getSrc(): string;
|
|
8
8
|
}
|
|
9
|
+
export interface OAuthMcpContext {
|
|
10
|
+
party?: string;
|
|
11
|
+
counterparty: string;
|
|
12
|
+
src: string;
|
|
13
|
+
scope: Record<string, string>;
|
|
14
|
+
}
|
|
15
|
+
export declare class OAuthMcpToken implements McpCapabilityToken {
|
|
16
|
+
#private;
|
|
17
|
+
constructor(context: OAuthMcpContext);
|
|
18
|
+
hasCapability(source: string, capability: string): boolean;
|
|
19
|
+
getParty(): string;
|
|
20
|
+
getCounterparty(): string;
|
|
21
|
+
getSourceUrl(): URL;
|
|
22
|
+
getSrc(): string;
|
|
23
|
+
}
|
|
9
24
|
export interface McpToolAuthorization {
|
|
10
25
|
token: McpCapabilityToken | null;
|
|
11
26
|
providerSource: string;
|
|
@@ -17,6 +32,6 @@ export declare function hasMcpToolCapability(authorization: McpToolAuthorization
|
|
|
17
32
|
export declare function tokenHasCapability(token: {
|
|
18
33
|
hasCapability(source: string, capability: string): boolean;
|
|
19
34
|
}, source: string, capability: string): boolean;
|
|
20
|
-
export declare function yamlDeclaresMcpToolCapability(yaml: Pick<YamlContent,
|
|
35
|
+
export declare function yamlDeclaresMcpToolCapability(yaml: Pick<YamlContent, 'mcp'>, toolName: string, capability: string): boolean;
|
|
21
36
|
export declare function yamlGrantsCapability(grant: Grant | undefined, counterparty: string, src: string, capability: string): boolean;
|
|
22
37
|
//# sourceMappingURL=McpToolAuthorization.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"McpToolAuthorization.d.ts","sourceRoot":"","sources":["../../../ts/McpToolAuthorization.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,
|
|
1
|
+
{"version":3,"file":"McpToolAuthorization.d.ts","sourceRoot":"","sources":["../../../ts/McpToolAuthorization.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAE1D,eAAO,MAAM,oBAAoB,aAAa,CAAA;AAI9C,MAAM,WAAW,kBAAkB;IACjC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAA;IAC1D,eAAe,IAAI,MAAM,CAAA;IACzB,YAAY,IAAI,GAAG,CAAA;IACnB,MAAM,IAAI,MAAM,CAAA;CACjB;AAED,MAAM,WAAW,eAAe;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,YAAY,EAAE,MAAM,CAAA;IACpB,GAAG,EAAE,MAAM,CAAA;IACX,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CAC9B;AAED,qBAAa,aAAc,YAAW,kBAAkB;;gBAG1C,OAAO,EAAE,eAAe;IAIpC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO;IAM1D,QAAQ,IAAI,MAAM;IAIlB,eAAe,IAAI,MAAM;IAIzB,YAAY,IAAI,GAAG;IAInB,MAAM,IAAI,MAAM;CAGjB;AAED,MAAM,WAAW,oBAAoB;IACnC,KAAK,EAAE,kBAAkB,GAAG,IAAI,CAAA;IAChC,cAAc,EAAE,MAAM,CAAA;IACtB,QAAQ,EAAE,MAAM,CAAA;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,YAAY,CAAC,EAAE,WAAW,CAAA;CAC3B;AAED,wBAAgB,oBAAoB,CAClC,aAAa,EAAE,oBAAoB,GAClC,OAAO,CAwBT;AAED,wBAAgB,kBAAkB,CAChC,KAAK,EAAE;IAAE,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAA;CAAE,EACrE,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,MAAM,GACjB,OAAO,CAMT;AAED,wBAAgB,6BAA6B,CAC3C,IAAI,EAAE,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,EAC9B,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,GACjB,OAAO,CAMT;AAED,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,KAAK,GAAG,SAAS,EACxB,YAAY,EAAE,MAAM,EACpB,GAAG,EAAE,MAAM,EACX,UAAU,EAAE,MAAM,GACjB,OAAO,CA2BT"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { JSONObject } from './Assertions.ts';
|
|
1
|
+
import { JSONObject, JSONValue } from './Assertions.ts';
|
|
2
2
|
export type Source = string;
|
|
3
3
|
export type Counterparty = string;
|
|
4
4
|
export type Capability = string;
|
|
@@ -25,9 +25,23 @@ export interface Tab {
|
|
|
25
25
|
src: string;
|
|
26
26
|
importmap?: string;
|
|
27
27
|
ttl?: number;
|
|
28
|
+
schedule?: TabScheduleSet;
|
|
28
29
|
config?: JSONObject;
|
|
29
30
|
};
|
|
30
31
|
}
|
|
32
|
+
export interface TabScheduleSet {
|
|
33
|
+
[name: string]: TabSchedule;
|
|
34
|
+
}
|
|
35
|
+
export interface TabSchedule {
|
|
36
|
+
every: string;
|
|
37
|
+
request: TabScheduleRequest;
|
|
38
|
+
}
|
|
39
|
+
export interface TabScheduleRequest {
|
|
40
|
+
method?: string;
|
|
41
|
+
path: string;
|
|
42
|
+
headers?: Record<string, string>;
|
|
43
|
+
body?: JSONValue;
|
|
44
|
+
}
|
|
31
45
|
export interface AgentApis {
|
|
32
46
|
[name: string]: {
|
|
33
47
|
tab: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"YamlContent.d.ts","sourceRoot":"","sources":["../../../ts/YamlContent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"YamlContent.d.ts","sourceRoot":"","sources":["../../../ts/YamlContent.ts"],"names":[],"mappings":"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"}
|