@mcp-weave/webui 0.1.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/LICENSE +21 -0
- package/README.md +99 -0
- package/dist/index.d.mts +178 -0
- package/dist/index.d.ts +178 -0
- package/dist/index.js +2196 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +2189 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +50 -0
package/dist/index.js
ADDED
|
@@ -0,0 +1,2196 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __commonJS = (cb, mod) => function __require() {
|
|
9
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
10
|
+
};
|
|
11
|
+
var __export = (target, all) => {
|
|
12
|
+
for (var name in all)
|
|
13
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
14
|
+
};
|
|
15
|
+
var __copyProps = (to, from, except, desc) => {
|
|
16
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
17
|
+
for (let key of __getOwnPropNames(from))
|
|
18
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
19
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
20
|
+
}
|
|
21
|
+
return to;
|
|
22
|
+
};
|
|
23
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
24
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
25
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
26
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
27
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
28
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
29
|
+
mod
|
|
30
|
+
));
|
|
31
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
32
|
+
|
|
33
|
+
// ../../node_modules/.pnpm/reflect-metadata@0.2.2/node_modules/reflect-metadata/Reflect.js
|
|
34
|
+
var require_Reflect = __commonJS({
|
|
35
|
+
"../../node_modules/.pnpm/reflect-metadata@0.2.2/node_modules/reflect-metadata/Reflect.js"() {
|
|
36
|
+
"use strict";
|
|
37
|
+
var Reflect2;
|
|
38
|
+
(function(Reflect3) {
|
|
39
|
+
(function(factory) {
|
|
40
|
+
var root = typeof globalThis === "object" ? globalThis : typeof global === "object" ? global : typeof self === "object" ? self : typeof this === "object" ? this : sloppyModeThis();
|
|
41
|
+
var exporter = makeExporter(Reflect3);
|
|
42
|
+
if (typeof root.Reflect !== "undefined") {
|
|
43
|
+
exporter = makeExporter(root.Reflect, exporter);
|
|
44
|
+
}
|
|
45
|
+
factory(exporter, root);
|
|
46
|
+
if (typeof root.Reflect === "undefined") {
|
|
47
|
+
root.Reflect = Reflect3;
|
|
48
|
+
}
|
|
49
|
+
function makeExporter(target, previous) {
|
|
50
|
+
return function(key, value) {
|
|
51
|
+
Object.defineProperty(target, key, { configurable: true, writable: true, value });
|
|
52
|
+
if (previous)
|
|
53
|
+
previous(key, value);
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
function functionThis() {
|
|
57
|
+
try {
|
|
58
|
+
return Function("return this;")();
|
|
59
|
+
} catch (_) {
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
function indirectEvalThis() {
|
|
63
|
+
try {
|
|
64
|
+
return (void 0, eval)("(function() { return this; })()");
|
|
65
|
+
} catch (_) {
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
function sloppyModeThis() {
|
|
69
|
+
return functionThis() || indirectEvalThis();
|
|
70
|
+
}
|
|
71
|
+
})(function(exporter, root) {
|
|
72
|
+
var hasOwn = Object.prototype.hasOwnProperty;
|
|
73
|
+
var supportsSymbol = typeof Symbol === "function";
|
|
74
|
+
var toPrimitiveSymbol = supportsSymbol && typeof Symbol.toPrimitive !== "undefined" ? Symbol.toPrimitive : "@@toPrimitive";
|
|
75
|
+
var iteratorSymbol = supportsSymbol && typeof Symbol.iterator !== "undefined" ? Symbol.iterator : "@@iterator";
|
|
76
|
+
var supportsCreate = typeof Object.create === "function";
|
|
77
|
+
var supportsProto = { __proto__: [] } instanceof Array;
|
|
78
|
+
var downLevel = !supportsCreate && !supportsProto;
|
|
79
|
+
var HashMap = {
|
|
80
|
+
// create an object in dictionary mode (a.k.a. "slow" mode in v8)
|
|
81
|
+
create: supportsCreate ? function() {
|
|
82
|
+
return MakeDictionary(/* @__PURE__ */ Object.create(null));
|
|
83
|
+
} : supportsProto ? function() {
|
|
84
|
+
return MakeDictionary({ __proto__: null });
|
|
85
|
+
} : function() {
|
|
86
|
+
return MakeDictionary({});
|
|
87
|
+
},
|
|
88
|
+
has: downLevel ? function(map, key) {
|
|
89
|
+
return hasOwn.call(map, key);
|
|
90
|
+
} : function(map, key) {
|
|
91
|
+
return key in map;
|
|
92
|
+
},
|
|
93
|
+
get: downLevel ? function(map, key) {
|
|
94
|
+
return hasOwn.call(map, key) ? map[key] : void 0;
|
|
95
|
+
} : function(map, key) {
|
|
96
|
+
return map[key];
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
var functionPrototype = Object.getPrototypeOf(Function);
|
|
100
|
+
var _Map = typeof Map === "function" && typeof Map.prototype.entries === "function" ? Map : CreateMapPolyfill();
|
|
101
|
+
var _Set = typeof Set === "function" && typeof Set.prototype.entries === "function" ? Set : CreateSetPolyfill();
|
|
102
|
+
var _WeakMap = typeof WeakMap === "function" ? WeakMap : CreateWeakMapPolyfill();
|
|
103
|
+
var registrySymbol = supportsSymbol ? /* @__PURE__ */ Symbol.for("@reflect-metadata:registry") : void 0;
|
|
104
|
+
var metadataRegistry = GetOrCreateMetadataRegistry();
|
|
105
|
+
var metadataProvider = CreateMetadataProvider(metadataRegistry);
|
|
106
|
+
function decorate(decorators, target, propertyKey, attributes) {
|
|
107
|
+
if (!IsUndefined(propertyKey)) {
|
|
108
|
+
if (!IsArray(decorators))
|
|
109
|
+
throw new TypeError();
|
|
110
|
+
if (!IsObject(target))
|
|
111
|
+
throw new TypeError();
|
|
112
|
+
if (!IsObject(attributes) && !IsUndefined(attributes) && !IsNull(attributes))
|
|
113
|
+
throw new TypeError();
|
|
114
|
+
if (IsNull(attributes))
|
|
115
|
+
attributes = void 0;
|
|
116
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
117
|
+
return DecorateProperty(decorators, target, propertyKey, attributes);
|
|
118
|
+
} else {
|
|
119
|
+
if (!IsArray(decorators))
|
|
120
|
+
throw new TypeError();
|
|
121
|
+
if (!IsConstructor(target))
|
|
122
|
+
throw new TypeError();
|
|
123
|
+
return DecorateConstructor(decorators, target);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
exporter("decorate", decorate);
|
|
127
|
+
function metadata(metadataKey, metadataValue) {
|
|
128
|
+
function decorator(target, propertyKey) {
|
|
129
|
+
if (!IsObject(target))
|
|
130
|
+
throw new TypeError();
|
|
131
|
+
if (!IsUndefined(propertyKey) && !IsPropertyKey(propertyKey))
|
|
132
|
+
throw new TypeError();
|
|
133
|
+
OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);
|
|
134
|
+
}
|
|
135
|
+
return decorator;
|
|
136
|
+
}
|
|
137
|
+
exporter("metadata", metadata);
|
|
138
|
+
function defineMetadata(metadataKey, metadataValue, target, propertyKey) {
|
|
139
|
+
if (!IsObject(target))
|
|
140
|
+
throw new TypeError();
|
|
141
|
+
if (!IsUndefined(propertyKey))
|
|
142
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
143
|
+
return OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);
|
|
144
|
+
}
|
|
145
|
+
exporter("defineMetadata", defineMetadata);
|
|
146
|
+
function hasMetadata(metadataKey, target, propertyKey) {
|
|
147
|
+
if (!IsObject(target))
|
|
148
|
+
throw new TypeError();
|
|
149
|
+
if (!IsUndefined(propertyKey))
|
|
150
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
151
|
+
return OrdinaryHasMetadata(metadataKey, target, propertyKey);
|
|
152
|
+
}
|
|
153
|
+
exporter("hasMetadata", hasMetadata);
|
|
154
|
+
function hasOwnMetadata(metadataKey, target, propertyKey) {
|
|
155
|
+
if (!IsObject(target))
|
|
156
|
+
throw new TypeError();
|
|
157
|
+
if (!IsUndefined(propertyKey))
|
|
158
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
159
|
+
return OrdinaryHasOwnMetadata(metadataKey, target, propertyKey);
|
|
160
|
+
}
|
|
161
|
+
exporter("hasOwnMetadata", hasOwnMetadata);
|
|
162
|
+
function getMetadata(metadataKey, target, propertyKey) {
|
|
163
|
+
if (!IsObject(target))
|
|
164
|
+
throw new TypeError();
|
|
165
|
+
if (!IsUndefined(propertyKey))
|
|
166
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
167
|
+
return OrdinaryGetMetadata(metadataKey, target, propertyKey);
|
|
168
|
+
}
|
|
169
|
+
exporter("getMetadata", getMetadata);
|
|
170
|
+
function getOwnMetadata(metadataKey, target, propertyKey) {
|
|
171
|
+
if (!IsObject(target))
|
|
172
|
+
throw new TypeError();
|
|
173
|
+
if (!IsUndefined(propertyKey))
|
|
174
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
175
|
+
return OrdinaryGetOwnMetadata(metadataKey, target, propertyKey);
|
|
176
|
+
}
|
|
177
|
+
exporter("getOwnMetadata", getOwnMetadata);
|
|
178
|
+
function getMetadataKeys(target, propertyKey) {
|
|
179
|
+
if (!IsObject(target))
|
|
180
|
+
throw new TypeError();
|
|
181
|
+
if (!IsUndefined(propertyKey))
|
|
182
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
183
|
+
return OrdinaryMetadataKeys(target, propertyKey);
|
|
184
|
+
}
|
|
185
|
+
exporter("getMetadataKeys", getMetadataKeys);
|
|
186
|
+
function getOwnMetadataKeys(target, propertyKey) {
|
|
187
|
+
if (!IsObject(target))
|
|
188
|
+
throw new TypeError();
|
|
189
|
+
if (!IsUndefined(propertyKey))
|
|
190
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
191
|
+
return OrdinaryOwnMetadataKeys(target, propertyKey);
|
|
192
|
+
}
|
|
193
|
+
exporter("getOwnMetadataKeys", getOwnMetadataKeys);
|
|
194
|
+
function deleteMetadata(metadataKey, target, propertyKey) {
|
|
195
|
+
if (!IsObject(target))
|
|
196
|
+
throw new TypeError();
|
|
197
|
+
if (!IsUndefined(propertyKey))
|
|
198
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
199
|
+
if (!IsObject(target))
|
|
200
|
+
throw new TypeError();
|
|
201
|
+
if (!IsUndefined(propertyKey))
|
|
202
|
+
propertyKey = ToPropertyKey(propertyKey);
|
|
203
|
+
var provider = GetMetadataProvider(
|
|
204
|
+
target,
|
|
205
|
+
propertyKey,
|
|
206
|
+
/*Create*/
|
|
207
|
+
false
|
|
208
|
+
);
|
|
209
|
+
if (IsUndefined(provider))
|
|
210
|
+
return false;
|
|
211
|
+
return provider.OrdinaryDeleteMetadata(metadataKey, target, propertyKey);
|
|
212
|
+
}
|
|
213
|
+
exporter("deleteMetadata", deleteMetadata);
|
|
214
|
+
function DecorateConstructor(decorators, target) {
|
|
215
|
+
for (var i = decorators.length - 1; i >= 0; --i) {
|
|
216
|
+
var decorator = decorators[i];
|
|
217
|
+
var decorated = decorator(target);
|
|
218
|
+
if (!IsUndefined(decorated) && !IsNull(decorated)) {
|
|
219
|
+
if (!IsConstructor(decorated))
|
|
220
|
+
throw new TypeError();
|
|
221
|
+
target = decorated;
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
return target;
|
|
225
|
+
}
|
|
226
|
+
function DecorateProperty(decorators, target, propertyKey, descriptor) {
|
|
227
|
+
for (var i = decorators.length - 1; i >= 0; --i) {
|
|
228
|
+
var decorator = decorators[i];
|
|
229
|
+
var decorated = decorator(target, propertyKey, descriptor);
|
|
230
|
+
if (!IsUndefined(decorated) && !IsNull(decorated)) {
|
|
231
|
+
if (!IsObject(decorated))
|
|
232
|
+
throw new TypeError();
|
|
233
|
+
descriptor = decorated;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
return descriptor;
|
|
237
|
+
}
|
|
238
|
+
function OrdinaryHasMetadata(MetadataKey, O, P) {
|
|
239
|
+
var hasOwn2 = OrdinaryHasOwnMetadata(MetadataKey, O, P);
|
|
240
|
+
if (hasOwn2)
|
|
241
|
+
return true;
|
|
242
|
+
var parent = OrdinaryGetPrototypeOf(O);
|
|
243
|
+
if (!IsNull(parent))
|
|
244
|
+
return OrdinaryHasMetadata(MetadataKey, parent, P);
|
|
245
|
+
return false;
|
|
246
|
+
}
|
|
247
|
+
function OrdinaryHasOwnMetadata(MetadataKey, O, P) {
|
|
248
|
+
var provider = GetMetadataProvider(
|
|
249
|
+
O,
|
|
250
|
+
P,
|
|
251
|
+
/*Create*/
|
|
252
|
+
false
|
|
253
|
+
);
|
|
254
|
+
if (IsUndefined(provider))
|
|
255
|
+
return false;
|
|
256
|
+
return ToBoolean(provider.OrdinaryHasOwnMetadata(MetadataKey, O, P));
|
|
257
|
+
}
|
|
258
|
+
function OrdinaryGetMetadata(MetadataKey, O, P) {
|
|
259
|
+
var hasOwn2 = OrdinaryHasOwnMetadata(MetadataKey, O, P);
|
|
260
|
+
if (hasOwn2)
|
|
261
|
+
return OrdinaryGetOwnMetadata(MetadataKey, O, P);
|
|
262
|
+
var parent = OrdinaryGetPrototypeOf(O);
|
|
263
|
+
if (!IsNull(parent))
|
|
264
|
+
return OrdinaryGetMetadata(MetadataKey, parent, P);
|
|
265
|
+
return void 0;
|
|
266
|
+
}
|
|
267
|
+
function OrdinaryGetOwnMetadata(MetadataKey, O, P) {
|
|
268
|
+
var provider = GetMetadataProvider(
|
|
269
|
+
O,
|
|
270
|
+
P,
|
|
271
|
+
/*Create*/
|
|
272
|
+
false
|
|
273
|
+
);
|
|
274
|
+
if (IsUndefined(provider))
|
|
275
|
+
return;
|
|
276
|
+
return provider.OrdinaryGetOwnMetadata(MetadataKey, O, P);
|
|
277
|
+
}
|
|
278
|
+
function OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) {
|
|
279
|
+
var provider = GetMetadataProvider(
|
|
280
|
+
O,
|
|
281
|
+
P,
|
|
282
|
+
/*Create*/
|
|
283
|
+
true
|
|
284
|
+
);
|
|
285
|
+
provider.OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P);
|
|
286
|
+
}
|
|
287
|
+
function OrdinaryMetadataKeys(O, P) {
|
|
288
|
+
var ownKeys = OrdinaryOwnMetadataKeys(O, P);
|
|
289
|
+
var parent = OrdinaryGetPrototypeOf(O);
|
|
290
|
+
if (parent === null)
|
|
291
|
+
return ownKeys;
|
|
292
|
+
var parentKeys = OrdinaryMetadataKeys(parent, P);
|
|
293
|
+
if (parentKeys.length <= 0)
|
|
294
|
+
return ownKeys;
|
|
295
|
+
if (ownKeys.length <= 0)
|
|
296
|
+
return parentKeys;
|
|
297
|
+
var set = new _Set();
|
|
298
|
+
var keys = [];
|
|
299
|
+
for (var _i = 0, ownKeys_1 = ownKeys; _i < ownKeys_1.length; _i++) {
|
|
300
|
+
var key = ownKeys_1[_i];
|
|
301
|
+
var hasKey = set.has(key);
|
|
302
|
+
if (!hasKey) {
|
|
303
|
+
set.add(key);
|
|
304
|
+
keys.push(key);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
for (var _a = 0, parentKeys_1 = parentKeys; _a < parentKeys_1.length; _a++) {
|
|
308
|
+
var key = parentKeys_1[_a];
|
|
309
|
+
var hasKey = set.has(key);
|
|
310
|
+
if (!hasKey) {
|
|
311
|
+
set.add(key);
|
|
312
|
+
keys.push(key);
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
return keys;
|
|
316
|
+
}
|
|
317
|
+
function OrdinaryOwnMetadataKeys(O, P) {
|
|
318
|
+
var provider = GetMetadataProvider(
|
|
319
|
+
O,
|
|
320
|
+
P,
|
|
321
|
+
/*create*/
|
|
322
|
+
false
|
|
323
|
+
);
|
|
324
|
+
if (!provider) {
|
|
325
|
+
return [];
|
|
326
|
+
}
|
|
327
|
+
return provider.OrdinaryOwnMetadataKeys(O, P);
|
|
328
|
+
}
|
|
329
|
+
function Type(x) {
|
|
330
|
+
if (x === null)
|
|
331
|
+
return 1;
|
|
332
|
+
switch (typeof x) {
|
|
333
|
+
case "undefined":
|
|
334
|
+
return 0;
|
|
335
|
+
case "boolean":
|
|
336
|
+
return 2;
|
|
337
|
+
case "string":
|
|
338
|
+
return 3;
|
|
339
|
+
case "symbol":
|
|
340
|
+
return 4;
|
|
341
|
+
case "number":
|
|
342
|
+
return 5;
|
|
343
|
+
case "object":
|
|
344
|
+
return x === null ? 1 : 6;
|
|
345
|
+
default:
|
|
346
|
+
return 6;
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
function IsUndefined(x) {
|
|
350
|
+
return x === void 0;
|
|
351
|
+
}
|
|
352
|
+
function IsNull(x) {
|
|
353
|
+
return x === null;
|
|
354
|
+
}
|
|
355
|
+
function IsSymbol(x) {
|
|
356
|
+
return typeof x === "symbol";
|
|
357
|
+
}
|
|
358
|
+
function IsObject(x) {
|
|
359
|
+
return typeof x === "object" ? x !== null : typeof x === "function";
|
|
360
|
+
}
|
|
361
|
+
function ToPrimitive(input, PreferredType) {
|
|
362
|
+
switch (Type(input)) {
|
|
363
|
+
case 0:
|
|
364
|
+
return input;
|
|
365
|
+
case 1:
|
|
366
|
+
return input;
|
|
367
|
+
case 2:
|
|
368
|
+
return input;
|
|
369
|
+
case 3:
|
|
370
|
+
return input;
|
|
371
|
+
case 4:
|
|
372
|
+
return input;
|
|
373
|
+
case 5:
|
|
374
|
+
return input;
|
|
375
|
+
}
|
|
376
|
+
var hint = PreferredType === 3 ? "string" : PreferredType === 5 ? "number" : "default";
|
|
377
|
+
var exoticToPrim = GetMethod(input, toPrimitiveSymbol);
|
|
378
|
+
if (exoticToPrim !== void 0) {
|
|
379
|
+
var result = exoticToPrim.call(input, hint);
|
|
380
|
+
if (IsObject(result))
|
|
381
|
+
throw new TypeError();
|
|
382
|
+
return result;
|
|
383
|
+
}
|
|
384
|
+
return OrdinaryToPrimitive(input, hint === "default" ? "number" : hint);
|
|
385
|
+
}
|
|
386
|
+
function OrdinaryToPrimitive(O, hint) {
|
|
387
|
+
if (hint === "string") {
|
|
388
|
+
var toString_1 = O.toString;
|
|
389
|
+
if (IsCallable(toString_1)) {
|
|
390
|
+
var result = toString_1.call(O);
|
|
391
|
+
if (!IsObject(result))
|
|
392
|
+
return result;
|
|
393
|
+
}
|
|
394
|
+
var valueOf = O.valueOf;
|
|
395
|
+
if (IsCallable(valueOf)) {
|
|
396
|
+
var result = valueOf.call(O);
|
|
397
|
+
if (!IsObject(result))
|
|
398
|
+
return result;
|
|
399
|
+
}
|
|
400
|
+
} else {
|
|
401
|
+
var valueOf = O.valueOf;
|
|
402
|
+
if (IsCallable(valueOf)) {
|
|
403
|
+
var result = valueOf.call(O);
|
|
404
|
+
if (!IsObject(result))
|
|
405
|
+
return result;
|
|
406
|
+
}
|
|
407
|
+
var toString_2 = O.toString;
|
|
408
|
+
if (IsCallable(toString_2)) {
|
|
409
|
+
var result = toString_2.call(O);
|
|
410
|
+
if (!IsObject(result))
|
|
411
|
+
return result;
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
throw new TypeError();
|
|
415
|
+
}
|
|
416
|
+
function ToBoolean(argument) {
|
|
417
|
+
return !!argument;
|
|
418
|
+
}
|
|
419
|
+
function ToString(argument) {
|
|
420
|
+
return "" + argument;
|
|
421
|
+
}
|
|
422
|
+
function ToPropertyKey(argument) {
|
|
423
|
+
var key = ToPrimitive(
|
|
424
|
+
argument,
|
|
425
|
+
3
|
|
426
|
+
/* String */
|
|
427
|
+
);
|
|
428
|
+
if (IsSymbol(key))
|
|
429
|
+
return key;
|
|
430
|
+
return ToString(key);
|
|
431
|
+
}
|
|
432
|
+
function IsArray(argument) {
|
|
433
|
+
return Array.isArray ? Array.isArray(argument) : argument instanceof Object ? argument instanceof Array : Object.prototype.toString.call(argument) === "[object Array]";
|
|
434
|
+
}
|
|
435
|
+
function IsCallable(argument) {
|
|
436
|
+
return typeof argument === "function";
|
|
437
|
+
}
|
|
438
|
+
function IsConstructor(argument) {
|
|
439
|
+
return typeof argument === "function";
|
|
440
|
+
}
|
|
441
|
+
function IsPropertyKey(argument) {
|
|
442
|
+
switch (Type(argument)) {
|
|
443
|
+
case 3:
|
|
444
|
+
return true;
|
|
445
|
+
case 4:
|
|
446
|
+
return true;
|
|
447
|
+
default:
|
|
448
|
+
return false;
|
|
449
|
+
}
|
|
450
|
+
}
|
|
451
|
+
function SameValueZero(x, y) {
|
|
452
|
+
return x === y || x !== x && y !== y;
|
|
453
|
+
}
|
|
454
|
+
function GetMethod(V, P) {
|
|
455
|
+
var func = V[P];
|
|
456
|
+
if (func === void 0 || func === null)
|
|
457
|
+
return void 0;
|
|
458
|
+
if (!IsCallable(func))
|
|
459
|
+
throw new TypeError();
|
|
460
|
+
return func;
|
|
461
|
+
}
|
|
462
|
+
function GetIterator(obj) {
|
|
463
|
+
var method = GetMethod(obj, iteratorSymbol);
|
|
464
|
+
if (!IsCallable(method))
|
|
465
|
+
throw new TypeError();
|
|
466
|
+
var iterator = method.call(obj);
|
|
467
|
+
if (!IsObject(iterator))
|
|
468
|
+
throw new TypeError();
|
|
469
|
+
return iterator;
|
|
470
|
+
}
|
|
471
|
+
function IteratorValue(iterResult) {
|
|
472
|
+
return iterResult.value;
|
|
473
|
+
}
|
|
474
|
+
function IteratorStep(iterator) {
|
|
475
|
+
var result = iterator.next();
|
|
476
|
+
return result.done ? false : result;
|
|
477
|
+
}
|
|
478
|
+
function IteratorClose(iterator) {
|
|
479
|
+
var f = iterator["return"];
|
|
480
|
+
if (f)
|
|
481
|
+
f.call(iterator);
|
|
482
|
+
}
|
|
483
|
+
function OrdinaryGetPrototypeOf(O) {
|
|
484
|
+
var proto = Object.getPrototypeOf(O);
|
|
485
|
+
if (typeof O !== "function" || O === functionPrototype)
|
|
486
|
+
return proto;
|
|
487
|
+
if (proto !== functionPrototype)
|
|
488
|
+
return proto;
|
|
489
|
+
var prototype = O.prototype;
|
|
490
|
+
var prototypeProto = prototype && Object.getPrototypeOf(prototype);
|
|
491
|
+
if (prototypeProto == null || prototypeProto === Object.prototype)
|
|
492
|
+
return proto;
|
|
493
|
+
var constructor = prototypeProto.constructor;
|
|
494
|
+
if (typeof constructor !== "function")
|
|
495
|
+
return proto;
|
|
496
|
+
if (constructor === O)
|
|
497
|
+
return proto;
|
|
498
|
+
return constructor;
|
|
499
|
+
}
|
|
500
|
+
function CreateMetadataRegistry() {
|
|
501
|
+
var fallback;
|
|
502
|
+
if (!IsUndefined(registrySymbol) && typeof root.Reflect !== "undefined" && !(registrySymbol in root.Reflect) && typeof root.Reflect.defineMetadata === "function") {
|
|
503
|
+
fallback = CreateFallbackProvider(root.Reflect);
|
|
504
|
+
}
|
|
505
|
+
var first;
|
|
506
|
+
var second;
|
|
507
|
+
var rest;
|
|
508
|
+
var targetProviderMap = new _WeakMap();
|
|
509
|
+
var registry = {
|
|
510
|
+
registerProvider,
|
|
511
|
+
getProvider,
|
|
512
|
+
setProvider
|
|
513
|
+
};
|
|
514
|
+
return registry;
|
|
515
|
+
function registerProvider(provider) {
|
|
516
|
+
if (!Object.isExtensible(registry)) {
|
|
517
|
+
throw new Error("Cannot add provider to a frozen registry.");
|
|
518
|
+
}
|
|
519
|
+
switch (true) {
|
|
520
|
+
case fallback === provider:
|
|
521
|
+
break;
|
|
522
|
+
case IsUndefined(first):
|
|
523
|
+
first = provider;
|
|
524
|
+
break;
|
|
525
|
+
case first === provider:
|
|
526
|
+
break;
|
|
527
|
+
case IsUndefined(second):
|
|
528
|
+
second = provider;
|
|
529
|
+
break;
|
|
530
|
+
case second === provider:
|
|
531
|
+
break;
|
|
532
|
+
default:
|
|
533
|
+
if (rest === void 0)
|
|
534
|
+
rest = new _Set();
|
|
535
|
+
rest.add(provider);
|
|
536
|
+
break;
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
function getProviderNoCache(O, P) {
|
|
540
|
+
if (!IsUndefined(first)) {
|
|
541
|
+
if (first.isProviderFor(O, P))
|
|
542
|
+
return first;
|
|
543
|
+
if (!IsUndefined(second)) {
|
|
544
|
+
if (second.isProviderFor(O, P))
|
|
545
|
+
return first;
|
|
546
|
+
if (!IsUndefined(rest)) {
|
|
547
|
+
var iterator = GetIterator(rest);
|
|
548
|
+
while (true) {
|
|
549
|
+
var next = IteratorStep(iterator);
|
|
550
|
+
if (!next) {
|
|
551
|
+
return void 0;
|
|
552
|
+
}
|
|
553
|
+
var provider = IteratorValue(next);
|
|
554
|
+
if (provider.isProviderFor(O, P)) {
|
|
555
|
+
IteratorClose(iterator);
|
|
556
|
+
return provider;
|
|
557
|
+
}
|
|
558
|
+
}
|
|
559
|
+
}
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
if (!IsUndefined(fallback) && fallback.isProviderFor(O, P)) {
|
|
563
|
+
return fallback;
|
|
564
|
+
}
|
|
565
|
+
return void 0;
|
|
566
|
+
}
|
|
567
|
+
function getProvider(O, P) {
|
|
568
|
+
var providerMap = targetProviderMap.get(O);
|
|
569
|
+
var provider;
|
|
570
|
+
if (!IsUndefined(providerMap)) {
|
|
571
|
+
provider = providerMap.get(P);
|
|
572
|
+
}
|
|
573
|
+
if (!IsUndefined(provider)) {
|
|
574
|
+
return provider;
|
|
575
|
+
}
|
|
576
|
+
provider = getProviderNoCache(O, P);
|
|
577
|
+
if (!IsUndefined(provider)) {
|
|
578
|
+
if (IsUndefined(providerMap)) {
|
|
579
|
+
providerMap = new _Map();
|
|
580
|
+
targetProviderMap.set(O, providerMap);
|
|
581
|
+
}
|
|
582
|
+
providerMap.set(P, provider);
|
|
583
|
+
}
|
|
584
|
+
return provider;
|
|
585
|
+
}
|
|
586
|
+
function hasProvider(provider) {
|
|
587
|
+
if (IsUndefined(provider))
|
|
588
|
+
throw new TypeError();
|
|
589
|
+
return first === provider || second === provider || !IsUndefined(rest) && rest.has(provider);
|
|
590
|
+
}
|
|
591
|
+
function setProvider(O, P, provider) {
|
|
592
|
+
if (!hasProvider(provider)) {
|
|
593
|
+
throw new Error("Metadata provider not registered.");
|
|
594
|
+
}
|
|
595
|
+
var existingProvider = getProvider(O, P);
|
|
596
|
+
if (existingProvider !== provider) {
|
|
597
|
+
if (!IsUndefined(existingProvider)) {
|
|
598
|
+
return false;
|
|
599
|
+
}
|
|
600
|
+
var providerMap = targetProviderMap.get(O);
|
|
601
|
+
if (IsUndefined(providerMap)) {
|
|
602
|
+
providerMap = new _Map();
|
|
603
|
+
targetProviderMap.set(O, providerMap);
|
|
604
|
+
}
|
|
605
|
+
providerMap.set(P, provider);
|
|
606
|
+
}
|
|
607
|
+
return true;
|
|
608
|
+
}
|
|
609
|
+
}
|
|
610
|
+
function GetOrCreateMetadataRegistry() {
|
|
611
|
+
var metadataRegistry2;
|
|
612
|
+
if (!IsUndefined(registrySymbol) && IsObject(root.Reflect) && Object.isExtensible(root.Reflect)) {
|
|
613
|
+
metadataRegistry2 = root.Reflect[registrySymbol];
|
|
614
|
+
}
|
|
615
|
+
if (IsUndefined(metadataRegistry2)) {
|
|
616
|
+
metadataRegistry2 = CreateMetadataRegistry();
|
|
617
|
+
}
|
|
618
|
+
if (!IsUndefined(registrySymbol) && IsObject(root.Reflect) && Object.isExtensible(root.Reflect)) {
|
|
619
|
+
Object.defineProperty(root.Reflect, registrySymbol, {
|
|
620
|
+
enumerable: false,
|
|
621
|
+
configurable: false,
|
|
622
|
+
writable: false,
|
|
623
|
+
value: metadataRegistry2
|
|
624
|
+
});
|
|
625
|
+
}
|
|
626
|
+
return metadataRegistry2;
|
|
627
|
+
}
|
|
628
|
+
function CreateMetadataProvider(registry) {
|
|
629
|
+
var metadata2 = new _WeakMap();
|
|
630
|
+
var provider = {
|
|
631
|
+
isProviderFor: function(O, P) {
|
|
632
|
+
var targetMetadata = metadata2.get(O);
|
|
633
|
+
if (IsUndefined(targetMetadata))
|
|
634
|
+
return false;
|
|
635
|
+
return targetMetadata.has(P);
|
|
636
|
+
},
|
|
637
|
+
OrdinaryDefineOwnMetadata: OrdinaryDefineOwnMetadata2,
|
|
638
|
+
OrdinaryHasOwnMetadata: OrdinaryHasOwnMetadata2,
|
|
639
|
+
OrdinaryGetOwnMetadata: OrdinaryGetOwnMetadata2,
|
|
640
|
+
OrdinaryOwnMetadataKeys: OrdinaryOwnMetadataKeys2,
|
|
641
|
+
OrdinaryDeleteMetadata
|
|
642
|
+
};
|
|
643
|
+
metadataRegistry.registerProvider(provider);
|
|
644
|
+
return provider;
|
|
645
|
+
function GetOrCreateMetadataMap(O, P, Create) {
|
|
646
|
+
var targetMetadata = metadata2.get(O);
|
|
647
|
+
var createdTargetMetadata = false;
|
|
648
|
+
if (IsUndefined(targetMetadata)) {
|
|
649
|
+
if (!Create)
|
|
650
|
+
return void 0;
|
|
651
|
+
targetMetadata = new _Map();
|
|
652
|
+
metadata2.set(O, targetMetadata);
|
|
653
|
+
createdTargetMetadata = true;
|
|
654
|
+
}
|
|
655
|
+
var metadataMap = targetMetadata.get(P);
|
|
656
|
+
if (IsUndefined(metadataMap)) {
|
|
657
|
+
if (!Create)
|
|
658
|
+
return void 0;
|
|
659
|
+
metadataMap = new _Map();
|
|
660
|
+
targetMetadata.set(P, metadataMap);
|
|
661
|
+
if (!registry.setProvider(O, P, provider)) {
|
|
662
|
+
targetMetadata.delete(P);
|
|
663
|
+
if (createdTargetMetadata) {
|
|
664
|
+
metadata2.delete(O);
|
|
665
|
+
}
|
|
666
|
+
throw new Error("Wrong provider for target.");
|
|
667
|
+
}
|
|
668
|
+
}
|
|
669
|
+
return metadataMap;
|
|
670
|
+
}
|
|
671
|
+
function OrdinaryHasOwnMetadata2(MetadataKey, O, P) {
|
|
672
|
+
var metadataMap = GetOrCreateMetadataMap(
|
|
673
|
+
O,
|
|
674
|
+
P,
|
|
675
|
+
/*Create*/
|
|
676
|
+
false
|
|
677
|
+
);
|
|
678
|
+
if (IsUndefined(metadataMap))
|
|
679
|
+
return false;
|
|
680
|
+
return ToBoolean(metadataMap.has(MetadataKey));
|
|
681
|
+
}
|
|
682
|
+
function OrdinaryGetOwnMetadata2(MetadataKey, O, P) {
|
|
683
|
+
var metadataMap = GetOrCreateMetadataMap(
|
|
684
|
+
O,
|
|
685
|
+
P,
|
|
686
|
+
/*Create*/
|
|
687
|
+
false
|
|
688
|
+
);
|
|
689
|
+
if (IsUndefined(metadataMap))
|
|
690
|
+
return void 0;
|
|
691
|
+
return metadataMap.get(MetadataKey);
|
|
692
|
+
}
|
|
693
|
+
function OrdinaryDefineOwnMetadata2(MetadataKey, MetadataValue, O, P) {
|
|
694
|
+
var metadataMap = GetOrCreateMetadataMap(
|
|
695
|
+
O,
|
|
696
|
+
P,
|
|
697
|
+
/*Create*/
|
|
698
|
+
true
|
|
699
|
+
);
|
|
700
|
+
metadataMap.set(MetadataKey, MetadataValue);
|
|
701
|
+
}
|
|
702
|
+
function OrdinaryOwnMetadataKeys2(O, P) {
|
|
703
|
+
var keys = [];
|
|
704
|
+
var metadataMap = GetOrCreateMetadataMap(
|
|
705
|
+
O,
|
|
706
|
+
P,
|
|
707
|
+
/*Create*/
|
|
708
|
+
false
|
|
709
|
+
);
|
|
710
|
+
if (IsUndefined(metadataMap))
|
|
711
|
+
return keys;
|
|
712
|
+
var keysObj = metadataMap.keys();
|
|
713
|
+
var iterator = GetIterator(keysObj);
|
|
714
|
+
var k = 0;
|
|
715
|
+
while (true) {
|
|
716
|
+
var next = IteratorStep(iterator);
|
|
717
|
+
if (!next) {
|
|
718
|
+
keys.length = k;
|
|
719
|
+
return keys;
|
|
720
|
+
}
|
|
721
|
+
var nextValue = IteratorValue(next);
|
|
722
|
+
try {
|
|
723
|
+
keys[k] = nextValue;
|
|
724
|
+
} catch (e) {
|
|
725
|
+
try {
|
|
726
|
+
IteratorClose(iterator);
|
|
727
|
+
} finally {
|
|
728
|
+
throw e;
|
|
729
|
+
}
|
|
730
|
+
}
|
|
731
|
+
k++;
|
|
732
|
+
}
|
|
733
|
+
}
|
|
734
|
+
function OrdinaryDeleteMetadata(MetadataKey, O, P) {
|
|
735
|
+
var metadataMap = GetOrCreateMetadataMap(
|
|
736
|
+
O,
|
|
737
|
+
P,
|
|
738
|
+
/*Create*/
|
|
739
|
+
false
|
|
740
|
+
);
|
|
741
|
+
if (IsUndefined(metadataMap))
|
|
742
|
+
return false;
|
|
743
|
+
if (!metadataMap.delete(MetadataKey))
|
|
744
|
+
return false;
|
|
745
|
+
if (metadataMap.size === 0) {
|
|
746
|
+
var targetMetadata = metadata2.get(O);
|
|
747
|
+
if (!IsUndefined(targetMetadata)) {
|
|
748
|
+
targetMetadata.delete(P);
|
|
749
|
+
if (targetMetadata.size === 0) {
|
|
750
|
+
metadata2.delete(targetMetadata);
|
|
751
|
+
}
|
|
752
|
+
}
|
|
753
|
+
}
|
|
754
|
+
return true;
|
|
755
|
+
}
|
|
756
|
+
}
|
|
757
|
+
function CreateFallbackProvider(reflect) {
|
|
758
|
+
var defineMetadata2 = reflect.defineMetadata, hasOwnMetadata2 = reflect.hasOwnMetadata, getOwnMetadata2 = reflect.getOwnMetadata, getOwnMetadataKeys2 = reflect.getOwnMetadataKeys, deleteMetadata2 = reflect.deleteMetadata;
|
|
759
|
+
var metadataOwner = new _WeakMap();
|
|
760
|
+
var provider = {
|
|
761
|
+
isProviderFor: function(O, P) {
|
|
762
|
+
var metadataPropertySet = metadataOwner.get(O);
|
|
763
|
+
if (!IsUndefined(metadataPropertySet) && metadataPropertySet.has(P)) {
|
|
764
|
+
return true;
|
|
765
|
+
}
|
|
766
|
+
if (getOwnMetadataKeys2(O, P).length) {
|
|
767
|
+
if (IsUndefined(metadataPropertySet)) {
|
|
768
|
+
metadataPropertySet = new _Set();
|
|
769
|
+
metadataOwner.set(O, metadataPropertySet);
|
|
770
|
+
}
|
|
771
|
+
metadataPropertySet.add(P);
|
|
772
|
+
return true;
|
|
773
|
+
}
|
|
774
|
+
return false;
|
|
775
|
+
},
|
|
776
|
+
OrdinaryDefineOwnMetadata: defineMetadata2,
|
|
777
|
+
OrdinaryHasOwnMetadata: hasOwnMetadata2,
|
|
778
|
+
OrdinaryGetOwnMetadata: getOwnMetadata2,
|
|
779
|
+
OrdinaryOwnMetadataKeys: getOwnMetadataKeys2,
|
|
780
|
+
OrdinaryDeleteMetadata: deleteMetadata2
|
|
781
|
+
};
|
|
782
|
+
return provider;
|
|
783
|
+
}
|
|
784
|
+
function GetMetadataProvider(O, P, Create) {
|
|
785
|
+
var registeredProvider = metadataRegistry.getProvider(O, P);
|
|
786
|
+
if (!IsUndefined(registeredProvider)) {
|
|
787
|
+
return registeredProvider;
|
|
788
|
+
}
|
|
789
|
+
if (Create) {
|
|
790
|
+
if (metadataRegistry.setProvider(O, P, metadataProvider)) {
|
|
791
|
+
return metadataProvider;
|
|
792
|
+
}
|
|
793
|
+
throw new Error("Illegal state.");
|
|
794
|
+
}
|
|
795
|
+
return void 0;
|
|
796
|
+
}
|
|
797
|
+
function CreateMapPolyfill() {
|
|
798
|
+
var cacheSentinel = {};
|
|
799
|
+
var arraySentinel = [];
|
|
800
|
+
var MapIterator = (
|
|
801
|
+
/** @class */
|
|
802
|
+
(function() {
|
|
803
|
+
function MapIterator2(keys, values, selector) {
|
|
804
|
+
this._index = 0;
|
|
805
|
+
this._keys = keys;
|
|
806
|
+
this._values = values;
|
|
807
|
+
this._selector = selector;
|
|
808
|
+
}
|
|
809
|
+
MapIterator2.prototype["@@iterator"] = function() {
|
|
810
|
+
return this;
|
|
811
|
+
};
|
|
812
|
+
MapIterator2.prototype[iteratorSymbol] = function() {
|
|
813
|
+
return this;
|
|
814
|
+
};
|
|
815
|
+
MapIterator2.prototype.next = function() {
|
|
816
|
+
var index = this._index;
|
|
817
|
+
if (index >= 0 && index < this._keys.length) {
|
|
818
|
+
var result = this._selector(this._keys[index], this._values[index]);
|
|
819
|
+
if (index + 1 >= this._keys.length) {
|
|
820
|
+
this._index = -1;
|
|
821
|
+
this._keys = arraySentinel;
|
|
822
|
+
this._values = arraySentinel;
|
|
823
|
+
} else {
|
|
824
|
+
this._index++;
|
|
825
|
+
}
|
|
826
|
+
return { value: result, done: false };
|
|
827
|
+
}
|
|
828
|
+
return { value: void 0, done: true };
|
|
829
|
+
};
|
|
830
|
+
MapIterator2.prototype.throw = function(error) {
|
|
831
|
+
if (this._index >= 0) {
|
|
832
|
+
this._index = -1;
|
|
833
|
+
this._keys = arraySentinel;
|
|
834
|
+
this._values = arraySentinel;
|
|
835
|
+
}
|
|
836
|
+
throw error;
|
|
837
|
+
};
|
|
838
|
+
MapIterator2.prototype.return = function(value) {
|
|
839
|
+
if (this._index >= 0) {
|
|
840
|
+
this._index = -1;
|
|
841
|
+
this._keys = arraySentinel;
|
|
842
|
+
this._values = arraySentinel;
|
|
843
|
+
}
|
|
844
|
+
return { value, done: true };
|
|
845
|
+
};
|
|
846
|
+
return MapIterator2;
|
|
847
|
+
})()
|
|
848
|
+
);
|
|
849
|
+
var Map2 = (
|
|
850
|
+
/** @class */
|
|
851
|
+
(function() {
|
|
852
|
+
function Map3() {
|
|
853
|
+
this._keys = [];
|
|
854
|
+
this._values = [];
|
|
855
|
+
this._cacheKey = cacheSentinel;
|
|
856
|
+
this._cacheIndex = -2;
|
|
857
|
+
}
|
|
858
|
+
Object.defineProperty(Map3.prototype, "size", {
|
|
859
|
+
get: function() {
|
|
860
|
+
return this._keys.length;
|
|
861
|
+
},
|
|
862
|
+
enumerable: true,
|
|
863
|
+
configurable: true
|
|
864
|
+
});
|
|
865
|
+
Map3.prototype.has = function(key) {
|
|
866
|
+
return this._find(
|
|
867
|
+
key,
|
|
868
|
+
/*insert*/
|
|
869
|
+
false
|
|
870
|
+
) >= 0;
|
|
871
|
+
};
|
|
872
|
+
Map3.prototype.get = function(key) {
|
|
873
|
+
var index = this._find(
|
|
874
|
+
key,
|
|
875
|
+
/*insert*/
|
|
876
|
+
false
|
|
877
|
+
);
|
|
878
|
+
return index >= 0 ? this._values[index] : void 0;
|
|
879
|
+
};
|
|
880
|
+
Map3.prototype.set = function(key, value) {
|
|
881
|
+
var index = this._find(
|
|
882
|
+
key,
|
|
883
|
+
/*insert*/
|
|
884
|
+
true
|
|
885
|
+
);
|
|
886
|
+
this._values[index] = value;
|
|
887
|
+
return this;
|
|
888
|
+
};
|
|
889
|
+
Map3.prototype.delete = function(key) {
|
|
890
|
+
var index = this._find(
|
|
891
|
+
key,
|
|
892
|
+
/*insert*/
|
|
893
|
+
false
|
|
894
|
+
);
|
|
895
|
+
if (index >= 0) {
|
|
896
|
+
var size = this._keys.length;
|
|
897
|
+
for (var i = index + 1; i < size; i++) {
|
|
898
|
+
this._keys[i - 1] = this._keys[i];
|
|
899
|
+
this._values[i - 1] = this._values[i];
|
|
900
|
+
}
|
|
901
|
+
this._keys.length--;
|
|
902
|
+
this._values.length--;
|
|
903
|
+
if (SameValueZero(key, this._cacheKey)) {
|
|
904
|
+
this._cacheKey = cacheSentinel;
|
|
905
|
+
this._cacheIndex = -2;
|
|
906
|
+
}
|
|
907
|
+
return true;
|
|
908
|
+
}
|
|
909
|
+
return false;
|
|
910
|
+
};
|
|
911
|
+
Map3.prototype.clear = function() {
|
|
912
|
+
this._keys.length = 0;
|
|
913
|
+
this._values.length = 0;
|
|
914
|
+
this._cacheKey = cacheSentinel;
|
|
915
|
+
this._cacheIndex = -2;
|
|
916
|
+
};
|
|
917
|
+
Map3.prototype.keys = function() {
|
|
918
|
+
return new MapIterator(this._keys, this._values, getKey);
|
|
919
|
+
};
|
|
920
|
+
Map3.prototype.values = function() {
|
|
921
|
+
return new MapIterator(this._keys, this._values, getValue);
|
|
922
|
+
};
|
|
923
|
+
Map3.prototype.entries = function() {
|
|
924
|
+
return new MapIterator(this._keys, this._values, getEntry);
|
|
925
|
+
};
|
|
926
|
+
Map3.prototype["@@iterator"] = function() {
|
|
927
|
+
return this.entries();
|
|
928
|
+
};
|
|
929
|
+
Map3.prototype[iteratorSymbol] = function() {
|
|
930
|
+
return this.entries();
|
|
931
|
+
};
|
|
932
|
+
Map3.prototype._find = function(key, insert) {
|
|
933
|
+
if (!SameValueZero(this._cacheKey, key)) {
|
|
934
|
+
this._cacheIndex = -1;
|
|
935
|
+
for (var i = 0; i < this._keys.length; i++) {
|
|
936
|
+
if (SameValueZero(this._keys[i], key)) {
|
|
937
|
+
this._cacheIndex = i;
|
|
938
|
+
break;
|
|
939
|
+
}
|
|
940
|
+
}
|
|
941
|
+
}
|
|
942
|
+
if (this._cacheIndex < 0 && insert) {
|
|
943
|
+
this._cacheIndex = this._keys.length;
|
|
944
|
+
this._keys.push(key);
|
|
945
|
+
this._values.push(void 0);
|
|
946
|
+
}
|
|
947
|
+
return this._cacheIndex;
|
|
948
|
+
};
|
|
949
|
+
return Map3;
|
|
950
|
+
})()
|
|
951
|
+
);
|
|
952
|
+
return Map2;
|
|
953
|
+
function getKey(key, _) {
|
|
954
|
+
return key;
|
|
955
|
+
}
|
|
956
|
+
function getValue(_, value) {
|
|
957
|
+
return value;
|
|
958
|
+
}
|
|
959
|
+
function getEntry(key, value) {
|
|
960
|
+
return [key, value];
|
|
961
|
+
}
|
|
962
|
+
}
|
|
963
|
+
function CreateSetPolyfill() {
|
|
964
|
+
var Set2 = (
|
|
965
|
+
/** @class */
|
|
966
|
+
(function() {
|
|
967
|
+
function Set3() {
|
|
968
|
+
this._map = new _Map();
|
|
969
|
+
}
|
|
970
|
+
Object.defineProperty(Set3.prototype, "size", {
|
|
971
|
+
get: function() {
|
|
972
|
+
return this._map.size;
|
|
973
|
+
},
|
|
974
|
+
enumerable: true,
|
|
975
|
+
configurable: true
|
|
976
|
+
});
|
|
977
|
+
Set3.prototype.has = function(value) {
|
|
978
|
+
return this._map.has(value);
|
|
979
|
+
};
|
|
980
|
+
Set3.prototype.add = function(value) {
|
|
981
|
+
return this._map.set(value, value), this;
|
|
982
|
+
};
|
|
983
|
+
Set3.prototype.delete = function(value) {
|
|
984
|
+
return this._map.delete(value);
|
|
985
|
+
};
|
|
986
|
+
Set3.prototype.clear = function() {
|
|
987
|
+
this._map.clear();
|
|
988
|
+
};
|
|
989
|
+
Set3.prototype.keys = function() {
|
|
990
|
+
return this._map.keys();
|
|
991
|
+
};
|
|
992
|
+
Set3.prototype.values = function() {
|
|
993
|
+
return this._map.keys();
|
|
994
|
+
};
|
|
995
|
+
Set3.prototype.entries = function() {
|
|
996
|
+
return this._map.entries();
|
|
997
|
+
};
|
|
998
|
+
Set3.prototype["@@iterator"] = function() {
|
|
999
|
+
return this.keys();
|
|
1000
|
+
};
|
|
1001
|
+
Set3.prototype[iteratorSymbol] = function() {
|
|
1002
|
+
return this.keys();
|
|
1003
|
+
};
|
|
1004
|
+
return Set3;
|
|
1005
|
+
})()
|
|
1006
|
+
);
|
|
1007
|
+
return Set2;
|
|
1008
|
+
}
|
|
1009
|
+
function CreateWeakMapPolyfill() {
|
|
1010
|
+
var UUID_SIZE = 16;
|
|
1011
|
+
var keys = HashMap.create();
|
|
1012
|
+
var rootKey = CreateUniqueKey();
|
|
1013
|
+
return (
|
|
1014
|
+
/** @class */
|
|
1015
|
+
(function() {
|
|
1016
|
+
function WeakMap2() {
|
|
1017
|
+
this._key = CreateUniqueKey();
|
|
1018
|
+
}
|
|
1019
|
+
WeakMap2.prototype.has = function(target) {
|
|
1020
|
+
var table = GetOrCreateWeakMapTable(
|
|
1021
|
+
target,
|
|
1022
|
+
/*create*/
|
|
1023
|
+
false
|
|
1024
|
+
);
|
|
1025
|
+
return table !== void 0 ? HashMap.has(table, this._key) : false;
|
|
1026
|
+
};
|
|
1027
|
+
WeakMap2.prototype.get = function(target) {
|
|
1028
|
+
var table = GetOrCreateWeakMapTable(
|
|
1029
|
+
target,
|
|
1030
|
+
/*create*/
|
|
1031
|
+
false
|
|
1032
|
+
);
|
|
1033
|
+
return table !== void 0 ? HashMap.get(table, this._key) : void 0;
|
|
1034
|
+
};
|
|
1035
|
+
WeakMap2.prototype.set = function(target, value) {
|
|
1036
|
+
var table = GetOrCreateWeakMapTable(
|
|
1037
|
+
target,
|
|
1038
|
+
/*create*/
|
|
1039
|
+
true
|
|
1040
|
+
);
|
|
1041
|
+
table[this._key] = value;
|
|
1042
|
+
return this;
|
|
1043
|
+
};
|
|
1044
|
+
WeakMap2.prototype.delete = function(target) {
|
|
1045
|
+
var table = GetOrCreateWeakMapTable(
|
|
1046
|
+
target,
|
|
1047
|
+
/*create*/
|
|
1048
|
+
false
|
|
1049
|
+
);
|
|
1050
|
+
return table !== void 0 ? delete table[this._key] : false;
|
|
1051
|
+
};
|
|
1052
|
+
WeakMap2.prototype.clear = function() {
|
|
1053
|
+
this._key = CreateUniqueKey();
|
|
1054
|
+
};
|
|
1055
|
+
return WeakMap2;
|
|
1056
|
+
})()
|
|
1057
|
+
);
|
|
1058
|
+
function CreateUniqueKey() {
|
|
1059
|
+
var key;
|
|
1060
|
+
do
|
|
1061
|
+
key = "@@WeakMap@@" + CreateUUID();
|
|
1062
|
+
while (HashMap.has(keys, key));
|
|
1063
|
+
keys[key] = true;
|
|
1064
|
+
return key;
|
|
1065
|
+
}
|
|
1066
|
+
function GetOrCreateWeakMapTable(target, create) {
|
|
1067
|
+
if (!hasOwn.call(target, rootKey)) {
|
|
1068
|
+
if (!create)
|
|
1069
|
+
return void 0;
|
|
1070
|
+
Object.defineProperty(target, rootKey, { value: HashMap.create() });
|
|
1071
|
+
}
|
|
1072
|
+
return target[rootKey];
|
|
1073
|
+
}
|
|
1074
|
+
function FillRandomBytes(buffer, size) {
|
|
1075
|
+
for (var i = 0; i < size; ++i)
|
|
1076
|
+
buffer[i] = Math.random() * 255 | 0;
|
|
1077
|
+
return buffer;
|
|
1078
|
+
}
|
|
1079
|
+
function GenRandomBytes(size) {
|
|
1080
|
+
if (typeof Uint8Array === "function") {
|
|
1081
|
+
var array = new Uint8Array(size);
|
|
1082
|
+
if (typeof crypto !== "undefined") {
|
|
1083
|
+
crypto.getRandomValues(array);
|
|
1084
|
+
} else if (typeof msCrypto !== "undefined") {
|
|
1085
|
+
msCrypto.getRandomValues(array);
|
|
1086
|
+
} else {
|
|
1087
|
+
FillRandomBytes(array, size);
|
|
1088
|
+
}
|
|
1089
|
+
return array;
|
|
1090
|
+
}
|
|
1091
|
+
return FillRandomBytes(new Array(size), size);
|
|
1092
|
+
}
|
|
1093
|
+
function CreateUUID() {
|
|
1094
|
+
var data = GenRandomBytes(UUID_SIZE);
|
|
1095
|
+
data[6] = data[6] & 79 | 64;
|
|
1096
|
+
data[8] = data[8] & 191 | 128;
|
|
1097
|
+
var result = "";
|
|
1098
|
+
for (var offset = 0; offset < UUID_SIZE; ++offset) {
|
|
1099
|
+
var byte = data[offset];
|
|
1100
|
+
if (offset === 4 || offset === 6 || offset === 8)
|
|
1101
|
+
result += "-";
|
|
1102
|
+
if (byte < 16)
|
|
1103
|
+
result += "0";
|
|
1104
|
+
result += byte.toString(16).toLowerCase();
|
|
1105
|
+
}
|
|
1106
|
+
return result;
|
|
1107
|
+
}
|
|
1108
|
+
}
|
|
1109
|
+
function MakeDictionary(obj) {
|
|
1110
|
+
obj.__ = void 0;
|
|
1111
|
+
delete obj.__;
|
|
1112
|
+
return obj;
|
|
1113
|
+
}
|
|
1114
|
+
});
|
|
1115
|
+
})(Reflect2 || (Reflect2 = {}));
|
|
1116
|
+
}
|
|
1117
|
+
});
|
|
1118
|
+
|
|
1119
|
+
// src/index.ts
|
|
1120
|
+
var index_exports = {};
|
|
1121
|
+
__export(index_exports, {
|
|
1122
|
+
McpWebUI: () => McpWebUI,
|
|
1123
|
+
VERSION: () => VERSION
|
|
1124
|
+
});
|
|
1125
|
+
module.exports = __toCommonJS(index_exports);
|
|
1126
|
+
var import_reflect_metadata2 = __toESM(require_Reflect());
|
|
1127
|
+
|
|
1128
|
+
// src/server.ts
|
|
1129
|
+
var import_reflect_metadata = __toESM(require_Reflect());
|
|
1130
|
+
var import_events = require("events");
|
|
1131
|
+
var http = __toESM(require("http"));
|
|
1132
|
+
var url = __toESM(require("url"));
|
|
1133
|
+
var import_nestjs = require("@mcp-weave/nestjs");
|
|
1134
|
+
var McpWebUI = class extends import_events.EventEmitter {
|
|
1135
|
+
serverClass;
|
|
1136
|
+
serverInstance;
|
|
1137
|
+
options;
|
|
1138
|
+
httpServer = null;
|
|
1139
|
+
serverInfo = null;
|
|
1140
|
+
callHistory = [];
|
|
1141
|
+
logs = [];
|
|
1142
|
+
constructor(serverClass, options = {}) {
|
|
1143
|
+
super();
|
|
1144
|
+
if (!(0, import_nestjs.isMcpServer)(serverClass)) {
|
|
1145
|
+
throw new Error(`Class ${serverClass.name} is not decorated with @McpServer`);
|
|
1146
|
+
}
|
|
1147
|
+
this.serverClass = serverClass;
|
|
1148
|
+
this.options = {
|
|
1149
|
+
port: options.port ?? 3e3,
|
|
1150
|
+
host: options.host ?? "localhost",
|
|
1151
|
+
title: options.title ?? "MCP Server Dashboard",
|
|
1152
|
+
theme: options.theme ?? "dark",
|
|
1153
|
+
enableLogs: options.enableLogs ?? true
|
|
1154
|
+
};
|
|
1155
|
+
}
|
|
1156
|
+
/**
|
|
1157
|
+
* Initialize server instance and extract metadata
|
|
1158
|
+
*/
|
|
1159
|
+
initialize() {
|
|
1160
|
+
this.serverInstance = new this.serverClass();
|
|
1161
|
+
const serverMeta = (0, import_nestjs.getServerMetadata)(this.serverClass);
|
|
1162
|
+
const toolsMeta = (0, import_nestjs.getToolsMetadata)(this.serverClass);
|
|
1163
|
+
const resourcesMeta = (0, import_nestjs.getResourcesMetadata)(this.serverClass);
|
|
1164
|
+
const promptsMeta = (0, import_nestjs.getPromptsMetadata)(this.serverClass);
|
|
1165
|
+
this.serverInfo = {
|
|
1166
|
+
name: serverMeta?.name ?? "Unknown Server",
|
|
1167
|
+
version: serverMeta?.version ?? "1.0.0",
|
|
1168
|
+
description: serverMeta?.description,
|
|
1169
|
+
tools: toolsMeta.map((t) => ({
|
|
1170
|
+
name: t.name,
|
|
1171
|
+
description: t.description,
|
|
1172
|
+
method: String(t.propertyKey),
|
|
1173
|
+
inputSchema: t.inputSchema
|
|
1174
|
+
})),
|
|
1175
|
+
resources: resourcesMeta.map((r) => ({
|
|
1176
|
+
uri: r.uri,
|
|
1177
|
+
name: r.name,
|
|
1178
|
+
description: r.description,
|
|
1179
|
+
mimeType: r.mimeType,
|
|
1180
|
+
method: String(r.propertyKey)
|
|
1181
|
+
})),
|
|
1182
|
+
prompts: promptsMeta.map((p) => ({
|
|
1183
|
+
name: p.name,
|
|
1184
|
+
description: p.description,
|
|
1185
|
+
method: String(p.propertyKey),
|
|
1186
|
+
arguments: p.arguments
|
|
1187
|
+
}))
|
|
1188
|
+
};
|
|
1189
|
+
}
|
|
1190
|
+
/**
|
|
1191
|
+
* Start the Web UI server
|
|
1192
|
+
*/
|
|
1193
|
+
async start() {
|
|
1194
|
+
this.initialize();
|
|
1195
|
+
return new Promise((resolve, reject) => {
|
|
1196
|
+
this.httpServer = http.createServer((req, res) => {
|
|
1197
|
+
this.handleRequest(req, res);
|
|
1198
|
+
});
|
|
1199
|
+
this.httpServer.on("error", reject);
|
|
1200
|
+
this.httpServer.listen(this.options.port, this.options.host, () => {
|
|
1201
|
+
const address = this.httpServer.address();
|
|
1202
|
+
if (address && typeof address === "object") {
|
|
1203
|
+
this.options.port = address.port;
|
|
1204
|
+
}
|
|
1205
|
+
this.log(`\u{1F3A8} MCP Web UI started at ${this.getUrl()}`);
|
|
1206
|
+
resolve();
|
|
1207
|
+
});
|
|
1208
|
+
});
|
|
1209
|
+
}
|
|
1210
|
+
/**
|
|
1211
|
+
* Stop the Web UI server
|
|
1212
|
+
*/
|
|
1213
|
+
async stop() {
|
|
1214
|
+
return new Promise((resolve, reject) => {
|
|
1215
|
+
if (!this.httpServer) {
|
|
1216
|
+
resolve();
|
|
1217
|
+
return;
|
|
1218
|
+
}
|
|
1219
|
+
this.httpServer.close((err) => {
|
|
1220
|
+
this.httpServer = null;
|
|
1221
|
+
if (err) reject(err);
|
|
1222
|
+
else resolve();
|
|
1223
|
+
});
|
|
1224
|
+
});
|
|
1225
|
+
}
|
|
1226
|
+
/**
|
|
1227
|
+
* Get the URL of the dashboard
|
|
1228
|
+
*/
|
|
1229
|
+
getUrl() {
|
|
1230
|
+
return `http://${this.options.host}:${this.options.port}`;
|
|
1231
|
+
}
|
|
1232
|
+
/**
|
|
1233
|
+
* Get server information
|
|
1234
|
+
*/
|
|
1235
|
+
getServerInfo() {
|
|
1236
|
+
return this.serverInfo;
|
|
1237
|
+
}
|
|
1238
|
+
/**
|
|
1239
|
+
* Get call history
|
|
1240
|
+
*/
|
|
1241
|
+
getCallHistory() {
|
|
1242
|
+
return this.callHistory;
|
|
1243
|
+
}
|
|
1244
|
+
/**
|
|
1245
|
+
* Log a message
|
|
1246
|
+
*/
|
|
1247
|
+
log(message) {
|
|
1248
|
+
const timestamp = (/* @__PURE__ */ new Date()).toISOString();
|
|
1249
|
+
const logEntry = `[${timestamp}] ${message}`;
|
|
1250
|
+
this.logs.push(logEntry);
|
|
1251
|
+
if (this.logs.length > 1e3) {
|
|
1252
|
+
this.logs.shift();
|
|
1253
|
+
}
|
|
1254
|
+
this.emit("log", logEntry);
|
|
1255
|
+
}
|
|
1256
|
+
/**
|
|
1257
|
+
* Handle HTTP requests
|
|
1258
|
+
*/
|
|
1259
|
+
handleRequest(req, res) {
|
|
1260
|
+
const parsedUrl = url.parse(req.url ?? "/", true);
|
|
1261
|
+
const pathname = parsedUrl.pathname ?? "/";
|
|
1262
|
+
res.setHeader("Access-Control-Allow-Origin", "*");
|
|
1263
|
+
res.setHeader("Access-Control-Allow-Methods", "GET, POST, OPTIONS");
|
|
1264
|
+
res.setHeader("Access-Control-Allow-Headers", "Content-Type");
|
|
1265
|
+
if (req.method === "OPTIONS") {
|
|
1266
|
+
res.writeHead(200);
|
|
1267
|
+
res.end();
|
|
1268
|
+
return;
|
|
1269
|
+
}
|
|
1270
|
+
if (pathname === "/" && req.method === "GET") {
|
|
1271
|
+
this.serveDashboard(res);
|
|
1272
|
+
} else if (pathname === "/api/info" && req.method === "GET") {
|
|
1273
|
+
this.serveServerInfo(res);
|
|
1274
|
+
} else if (pathname === "/api/tools" && req.method === "GET") {
|
|
1275
|
+
this.serveTools(res);
|
|
1276
|
+
} else if (pathname === "/api/resources" && req.method === "GET") {
|
|
1277
|
+
this.serveResources(res);
|
|
1278
|
+
} else if (pathname === "/api/prompts" && req.method === "GET") {
|
|
1279
|
+
this.servePrompts(res);
|
|
1280
|
+
} else if (pathname === "/api/call-tool" && req.method === "POST") {
|
|
1281
|
+
this.handleCallTool(req, res);
|
|
1282
|
+
} else if (pathname === "/api/read-resource" && req.method === "POST") {
|
|
1283
|
+
this.handleReadResource(req, res);
|
|
1284
|
+
} else if (pathname === "/api/get-prompt" && req.method === "POST") {
|
|
1285
|
+
this.handleGetPrompt(req, res);
|
|
1286
|
+
} else if (pathname === "/api/history" && req.method === "GET") {
|
|
1287
|
+
this.serveHistory(res);
|
|
1288
|
+
} else if (pathname === "/api/logs" && req.method === "GET") {
|
|
1289
|
+
this.serveLogs(res);
|
|
1290
|
+
} else {
|
|
1291
|
+
res.writeHead(404, { "Content-Type": "application/json" });
|
|
1292
|
+
res.end(JSON.stringify({ error: "Not Found" }));
|
|
1293
|
+
}
|
|
1294
|
+
}
|
|
1295
|
+
/**
|
|
1296
|
+
* Serve the main dashboard HTML
|
|
1297
|
+
*/
|
|
1298
|
+
serveDashboard(res) {
|
|
1299
|
+
const html = this.generateDashboardHTML();
|
|
1300
|
+
res.writeHead(200, { "Content-Type": "text/html" });
|
|
1301
|
+
res.end(html);
|
|
1302
|
+
}
|
|
1303
|
+
/**
|
|
1304
|
+
* Serve server info as JSON
|
|
1305
|
+
*/
|
|
1306
|
+
serveServerInfo(res) {
|
|
1307
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1308
|
+
res.end(JSON.stringify(this.serverInfo));
|
|
1309
|
+
}
|
|
1310
|
+
/**
|
|
1311
|
+
* Serve tools list
|
|
1312
|
+
*/
|
|
1313
|
+
serveTools(res) {
|
|
1314
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1315
|
+
res.end(JSON.stringify(this.serverInfo?.tools ?? []));
|
|
1316
|
+
}
|
|
1317
|
+
/**
|
|
1318
|
+
* Serve resources list
|
|
1319
|
+
*/
|
|
1320
|
+
serveResources(res) {
|
|
1321
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1322
|
+
res.end(JSON.stringify(this.serverInfo?.resources ?? []));
|
|
1323
|
+
}
|
|
1324
|
+
/**
|
|
1325
|
+
* Serve prompts list
|
|
1326
|
+
*/
|
|
1327
|
+
servePrompts(res) {
|
|
1328
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1329
|
+
res.end(JSON.stringify(this.serverInfo?.prompts ?? []));
|
|
1330
|
+
}
|
|
1331
|
+
/**
|
|
1332
|
+
* Serve call history
|
|
1333
|
+
*/
|
|
1334
|
+
serveHistory(res) {
|
|
1335
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1336
|
+
res.end(JSON.stringify(this.callHistory));
|
|
1337
|
+
}
|
|
1338
|
+
/**
|
|
1339
|
+
* Serve server logs
|
|
1340
|
+
*/
|
|
1341
|
+
serveLogs(res) {
|
|
1342
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1343
|
+
res.end(JSON.stringify(this.logs));
|
|
1344
|
+
}
|
|
1345
|
+
/**
|
|
1346
|
+
* Handle tool call request
|
|
1347
|
+
*/
|
|
1348
|
+
async handleCallTool(req, res) {
|
|
1349
|
+
try {
|
|
1350
|
+
const body = await this.readBody(req);
|
|
1351
|
+
const { name, input } = JSON.parse(body);
|
|
1352
|
+
const tool = this.serverInfo?.tools.find((t) => t.name === name);
|
|
1353
|
+
if (!tool) {
|
|
1354
|
+
res.writeHead(404, { "Content-Type": "application/json" });
|
|
1355
|
+
res.end(JSON.stringify({ error: `Tool '${name}' not found` }));
|
|
1356
|
+
return;
|
|
1357
|
+
}
|
|
1358
|
+
const startTime = Date.now();
|
|
1359
|
+
const historyEntry = {
|
|
1360
|
+
id: this.generateId(),
|
|
1361
|
+
type: "tool",
|
|
1362
|
+
name,
|
|
1363
|
+
input,
|
|
1364
|
+
timestamp: /* @__PURE__ */ new Date(),
|
|
1365
|
+
duration: 0
|
|
1366
|
+
};
|
|
1367
|
+
try {
|
|
1368
|
+
this.log(`Calling tool: ${name}`);
|
|
1369
|
+
this.emit("tool:call", name, input);
|
|
1370
|
+
const method = this.serverInstance[tool.method];
|
|
1371
|
+
const result = await method.call(this.serverInstance, input);
|
|
1372
|
+
historyEntry.output = result;
|
|
1373
|
+
historyEntry.duration = Date.now() - startTime;
|
|
1374
|
+
this.callHistory.unshift(historyEntry);
|
|
1375
|
+
this.log(`Tool ${name} completed in ${historyEntry.duration}ms`);
|
|
1376
|
+
this.emit("tool:result", name, result);
|
|
1377
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1378
|
+
res.end(JSON.stringify({ success: true, result }));
|
|
1379
|
+
} catch (error) {
|
|
1380
|
+
historyEntry.error = error instanceof Error ? error.message : String(error);
|
|
1381
|
+
historyEntry.duration = Date.now() - startTime;
|
|
1382
|
+
this.callHistory.unshift(historyEntry);
|
|
1383
|
+
this.log(`Tool ${name} failed: ${historyEntry.error}`);
|
|
1384
|
+
res.writeHead(500, { "Content-Type": "application/json" });
|
|
1385
|
+
res.end(JSON.stringify({ success: false, error: historyEntry.error }));
|
|
1386
|
+
}
|
|
1387
|
+
} catch (error) {
|
|
1388
|
+
res.writeHead(400, { "Content-Type": "application/json" });
|
|
1389
|
+
res.end(JSON.stringify({ error: "Invalid request body" }));
|
|
1390
|
+
}
|
|
1391
|
+
}
|
|
1392
|
+
/**
|
|
1393
|
+
* Handle resource read request
|
|
1394
|
+
*/
|
|
1395
|
+
async handleReadResource(req, res) {
|
|
1396
|
+
try {
|
|
1397
|
+
const body = await this.readBody(req);
|
|
1398
|
+
const { uri } = JSON.parse(body);
|
|
1399
|
+
const resource = this.serverInfo?.resources.find((r) => {
|
|
1400
|
+
const pattern = r.uri.replace(/{[^}]+}/g, "[^/]+");
|
|
1401
|
+
const regex = new RegExp(`^${pattern}$`);
|
|
1402
|
+
return regex.test(uri);
|
|
1403
|
+
});
|
|
1404
|
+
if (!resource) {
|
|
1405
|
+
res.writeHead(404, { "Content-Type": "application/json" });
|
|
1406
|
+
res.end(JSON.stringify({ error: `Resource matching '${uri}' not found` }));
|
|
1407
|
+
return;
|
|
1408
|
+
}
|
|
1409
|
+
const startTime = Date.now();
|
|
1410
|
+
const historyEntry = {
|
|
1411
|
+
id: this.generateId(),
|
|
1412
|
+
type: "resource",
|
|
1413
|
+
name: uri,
|
|
1414
|
+
timestamp: /* @__PURE__ */ new Date(),
|
|
1415
|
+
duration: 0
|
|
1416
|
+
};
|
|
1417
|
+
try {
|
|
1418
|
+
this.log(`Reading resource: ${uri}`);
|
|
1419
|
+
this.emit("resource:read", uri);
|
|
1420
|
+
const params = this.extractUriParams(resource.uri, uri);
|
|
1421
|
+
const method = this.serverInstance[resource.method];
|
|
1422
|
+
const result = await method.call(this.serverInstance, params);
|
|
1423
|
+
historyEntry.output = result;
|
|
1424
|
+
historyEntry.duration = Date.now() - startTime;
|
|
1425
|
+
this.callHistory.unshift(historyEntry);
|
|
1426
|
+
this.log(`Resource ${uri} read in ${historyEntry.duration}ms`);
|
|
1427
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1428
|
+
res.end(JSON.stringify({ success: true, result }));
|
|
1429
|
+
} catch (error) {
|
|
1430
|
+
historyEntry.error = error instanceof Error ? error.message : String(error);
|
|
1431
|
+
historyEntry.duration = Date.now() - startTime;
|
|
1432
|
+
this.callHistory.unshift(historyEntry);
|
|
1433
|
+
this.log(`Resource ${uri} failed: ${historyEntry.error}`);
|
|
1434
|
+
res.writeHead(500, { "Content-Type": "application/json" });
|
|
1435
|
+
res.end(JSON.stringify({ success: false, error: historyEntry.error }));
|
|
1436
|
+
}
|
|
1437
|
+
} catch (error) {
|
|
1438
|
+
res.writeHead(400, { "Content-Type": "application/json" });
|
|
1439
|
+
res.end(JSON.stringify({ error: "Invalid request body" }));
|
|
1440
|
+
}
|
|
1441
|
+
}
|
|
1442
|
+
/**
|
|
1443
|
+
* Handle prompt get request
|
|
1444
|
+
*/
|
|
1445
|
+
async handleGetPrompt(req, res) {
|
|
1446
|
+
try {
|
|
1447
|
+
const body = await this.readBody(req);
|
|
1448
|
+
const { name, args } = JSON.parse(body);
|
|
1449
|
+
const prompt = this.serverInfo?.prompts.find((p) => p.name === name);
|
|
1450
|
+
if (!prompt) {
|
|
1451
|
+
res.writeHead(404, { "Content-Type": "application/json" });
|
|
1452
|
+
res.end(JSON.stringify({ error: `Prompt '${name}' not found` }));
|
|
1453
|
+
return;
|
|
1454
|
+
}
|
|
1455
|
+
const startTime = Date.now();
|
|
1456
|
+
const historyEntry = {
|
|
1457
|
+
id: this.generateId(),
|
|
1458
|
+
type: "prompt",
|
|
1459
|
+
name,
|
|
1460
|
+
input: args,
|
|
1461
|
+
timestamp: /* @__PURE__ */ new Date(),
|
|
1462
|
+
duration: 0
|
|
1463
|
+
};
|
|
1464
|
+
try {
|
|
1465
|
+
this.log(`Getting prompt: ${name}`);
|
|
1466
|
+
this.emit("prompt:get", name, args);
|
|
1467
|
+
const method = this.serverInstance[prompt.method];
|
|
1468
|
+
const result = await method.call(this.serverInstance, args);
|
|
1469
|
+
historyEntry.output = result;
|
|
1470
|
+
historyEntry.duration = Date.now() - startTime;
|
|
1471
|
+
this.callHistory.unshift(historyEntry);
|
|
1472
|
+
this.log(`Prompt ${name} completed in ${historyEntry.duration}ms`);
|
|
1473
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
1474
|
+
res.end(JSON.stringify({ success: true, result }));
|
|
1475
|
+
} catch (error) {
|
|
1476
|
+
historyEntry.error = error instanceof Error ? error.message : String(error);
|
|
1477
|
+
historyEntry.duration = Date.now() - startTime;
|
|
1478
|
+
this.callHistory.unshift(historyEntry);
|
|
1479
|
+
this.log(`Prompt ${name} failed: ${historyEntry.error}`);
|
|
1480
|
+
res.writeHead(500, { "Content-Type": "application/json" });
|
|
1481
|
+
res.end(JSON.stringify({ success: false, error: historyEntry.error }));
|
|
1482
|
+
}
|
|
1483
|
+
} catch (error) {
|
|
1484
|
+
res.writeHead(400, { "Content-Type": "application/json" });
|
|
1485
|
+
res.end(JSON.stringify({ error: "Invalid request body" }));
|
|
1486
|
+
}
|
|
1487
|
+
}
|
|
1488
|
+
/**
|
|
1489
|
+
* Read request body
|
|
1490
|
+
*/
|
|
1491
|
+
readBody(req) {
|
|
1492
|
+
return new Promise((resolve, reject) => {
|
|
1493
|
+
let body = "";
|
|
1494
|
+
req.on("data", (chunk) => body += chunk);
|
|
1495
|
+
req.on("end", () => resolve(body));
|
|
1496
|
+
req.on("error", reject);
|
|
1497
|
+
});
|
|
1498
|
+
}
|
|
1499
|
+
/**
|
|
1500
|
+
* Extract parameters from URI template
|
|
1501
|
+
*/
|
|
1502
|
+
extractUriParams(template, uri) {
|
|
1503
|
+
const params = {};
|
|
1504
|
+
const templateParts = template.split("/");
|
|
1505
|
+
const uriParts = uri.split("/");
|
|
1506
|
+
templateParts.forEach((part, index) => {
|
|
1507
|
+
const match = part.match(/^{([^}]+)}$/);
|
|
1508
|
+
const uriPart = uriParts[index];
|
|
1509
|
+
if (match && match[1] && uriPart) {
|
|
1510
|
+
params[match[1]] = uriPart;
|
|
1511
|
+
}
|
|
1512
|
+
});
|
|
1513
|
+
return params;
|
|
1514
|
+
}
|
|
1515
|
+
/**
|
|
1516
|
+
* Generate unique ID
|
|
1517
|
+
*/
|
|
1518
|
+
generateId() {
|
|
1519
|
+
return `${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
|
|
1520
|
+
}
|
|
1521
|
+
/**
|
|
1522
|
+
* Generate the dashboard HTML
|
|
1523
|
+
*/
|
|
1524
|
+
generateDashboardHTML() {
|
|
1525
|
+
const isDark = this.options.theme === "dark";
|
|
1526
|
+
return `<!DOCTYPE html>
|
|
1527
|
+
<html lang="en">
|
|
1528
|
+
<head>
|
|
1529
|
+
<meta charset="UTF-8">
|
|
1530
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
1531
|
+
<title>${this.options.title}</title>
|
|
1532
|
+
<style>
|
|
1533
|
+
:root {
|
|
1534
|
+
--bg-primary: ${isDark ? "#1a1a2e" : "#ffffff"};
|
|
1535
|
+
--bg-secondary: ${isDark ? "#16213e" : "#f5f5f5"};
|
|
1536
|
+
--bg-card: ${isDark ? "#0f3460" : "#ffffff"};
|
|
1537
|
+
--text-primary: ${isDark ? "#ffffff" : "#1a1a2e"};
|
|
1538
|
+
--text-secondary: ${isDark ? "#a0a0a0" : "#666666"};
|
|
1539
|
+
--accent: #e94560;
|
|
1540
|
+
--accent-hover: #ff6b6b;
|
|
1541
|
+
--success: #4caf50;
|
|
1542
|
+
--error: #f44336;
|
|
1543
|
+
--border: ${isDark ? "#2a2a4a" : "#e0e0e0"};
|
|
1544
|
+
--code-bg: ${isDark ? "#0d1117" : "#f6f8fa"};
|
|
1545
|
+
}
|
|
1546
|
+
|
|
1547
|
+
* { box-sizing: border-box; margin: 0; padding: 0; }
|
|
1548
|
+
|
|
1549
|
+
body {
|
|
1550
|
+
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
|
|
1551
|
+
background: var(--bg-primary);
|
|
1552
|
+
color: var(--text-primary);
|
|
1553
|
+
line-height: 1.6;
|
|
1554
|
+
}
|
|
1555
|
+
|
|
1556
|
+
.container {
|
|
1557
|
+
max-width: 1400px;
|
|
1558
|
+
margin: 0 auto;
|
|
1559
|
+
padding: 20px;
|
|
1560
|
+
}
|
|
1561
|
+
|
|
1562
|
+
header {
|
|
1563
|
+
background: var(--bg-secondary);
|
|
1564
|
+
padding: 20px;
|
|
1565
|
+
border-bottom: 1px solid var(--border);
|
|
1566
|
+
margin-bottom: 20px;
|
|
1567
|
+
}
|
|
1568
|
+
|
|
1569
|
+
header h1 {
|
|
1570
|
+
color: var(--accent);
|
|
1571
|
+
font-size: 24px;
|
|
1572
|
+
display: flex;
|
|
1573
|
+
align-items: center;
|
|
1574
|
+
gap: 10px;
|
|
1575
|
+
}
|
|
1576
|
+
|
|
1577
|
+
.server-info {
|
|
1578
|
+
display: flex;
|
|
1579
|
+
gap: 20px;
|
|
1580
|
+
margin-top: 10px;
|
|
1581
|
+
color: var(--text-secondary);
|
|
1582
|
+
font-size: 14px;
|
|
1583
|
+
}
|
|
1584
|
+
|
|
1585
|
+
.badge {
|
|
1586
|
+
background: var(--accent);
|
|
1587
|
+
color: white;
|
|
1588
|
+
padding: 2px 8px;
|
|
1589
|
+
border-radius: 12px;
|
|
1590
|
+
font-size: 12px;
|
|
1591
|
+
}
|
|
1592
|
+
|
|
1593
|
+
.grid {
|
|
1594
|
+
display: grid;
|
|
1595
|
+
grid-template-columns: 300px 1fr 350px;
|
|
1596
|
+
gap: 20px;
|
|
1597
|
+
height: calc(100vh - 150px);
|
|
1598
|
+
}
|
|
1599
|
+
|
|
1600
|
+
.panel {
|
|
1601
|
+
background: var(--bg-card);
|
|
1602
|
+
border: 1px solid var(--border);
|
|
1603
|
+
border-radius: 8px;
|
|
1604
|
+
overflow: hidden;
|
|
1605
|
+
display: flex;
|
|
1606
|
+
flex-direction: column;
|
|
1607
|
+
}
|
|
1608
|
+
|
|
1609
|
+
.panel-header {
|
|
1610
|
+
background: var(--bg-secondary);
|
|
1611
|
+
padding: 12px 16px;
|
|
1612
|
+
font-weight: 600;
|
|
1613
|
+
border-bottom: 1px solid var(--border);
|
|
1614
|
+
display: flex;
|
|
1615
|
+
justify-content: space-between;
|
|
1616
|
+
align-items: center;
|
|
1617
|
+
}
|
|
1618
|
+
|
|
1619
|
+
.panel-content {
|
|
1620
|
+
padding: 16px;
|
|
1621
|
+
overflow-y: auto;
|
|
1622
|
+
flex: 1;
|
|
1623
|
+
}
|
|
1624
|
+
|
|
1625
|
+
.tabs {
|
|
1626
|
+
display: flex;
|
|
1627
|
+
gap: 0;
|
|
1628
|
+
background: var(--bg-secondary);
|
|
1629
|
+
border-bottom: 1px solid var(--border);
|
|
1630
|
+
}
|
|
1631
|
+
|
|
1632
|
+
.tab {
|
|
1633
|
+
padding: 10px 16px;
|
|
1634
|
+
cursor: pointer;
|
|
1635
|
+
border: none;
|
|
1636
|
+
background: transparent;
|
|
1637
|
+
color: var(--text-secondary);
|
|
1638
|
+
font-size: 14px;
|
|
1639
|
+
border-bottom: 2px solid transparent;
|
|
1640
|
+
transition: all 0.2s;
|
|
1641
|
+
}
|
|
1642
|
+
|
|
1643
|
+
.tab:hover { color: var(--text-primary); }
|
|
1644
|
+
.tab.active {
|
|
1645
|
+
color: var(--accent);
|
|
1646
|
+
border-bottom-color: var(--accent);
|
|
1647
|
+
}
|
|
1648
|
+
|
|
1649
|
+
.item {
|
|
1650
|
+
padding: 12px;
|
|
1651
|
+
border: 1px solid var(--border);
|
|
1652
|
+
border-radius: 6px;
|
|
1653
|
+
margin-bottom: 8px;
|
|
1654
|
+
cursor: pointer;
|
|
1655
|
+
transition: all 0.2s;
|
|
1656
|
+
}
|
|
1657
|
+
|
|
1658
|
+
.item:hover {
|
|
1659
|
+
border-color: var(--accent);
|
|
1660
|
+
background: var(--bg-secondary);
|
|
1661
|
+
}
|
|
1662
|
+
|
|
1663
|
+
.item.selected {
|
|
1664
|
+
border-color: var(--accent);
|
|
1665
|
+
background: var(--bg-secondary);
|
|
1666
|
+
}
|
|
1667
|
+
|
|
1668
|
+
.item-name {
|
|
1669
|
+
font-weight: 600;
|
|
1670
|
+
color: var(--accent);
|
|
1671
|
+
}
|
|
1672
|
+
|
|
1673
|
+
.item-desc {
|
|
1674
|
+
color: var(--text-secondary);
|
|
1675
|
+
font-size: 13px;
|
|
1676
|
+
margin-top: 4px;
|
|
1677
|
+
}
|
|
1678
|
+
|
|
1679
|
+
.form-group {
|
|
1680
|
+
margin-bottom: 16px;
|
|
1681
|
+
}
|
|
1682
|
+
|
|
1683
|
+
.form-group label {
|
|
1684
|
+
display: block;
|
|
1685
|
+
margin-bottom: 6px;
|
|
1686
|
+
font-weight: 500;
|
|
1687
|
+
font-size: 14px;
|
|
1688
|
+
}
|
|
1689
|
+
|
|
1690
|
+
.form-group input,
|
|
1691
|
+
.form-group textarea {
|
|
1692
|
+
width: 100%;
|
|
1693
|
+
padding: 10px 12px;
|
|
1694
|
+
border: 1px solid var(--border);
|
|
1695
|
+
border-radius: 6px;
|
|
1696
|
+
background: var(--bg-primary);
|
|
1697
|
+
color: var(--text-primary);
|
|
1698
|
+
font-family: inherit;
|
|
1699
|
+
font-size: 14px;
|
|
1700
|
+
}
|
|
1701
|
+
|
|
1702
|
+
.form-group textarea {
|
|
1703
|
+
min-height: 150px;
|
|
1704
|
+
font-family: 'Monaco', 'Menlo', monospace;
|
|
1705
|
+
font-size: 13px;
|
|
1706
|
+
}
|
|
1707
|
+
|
|
1708
|
+
.form-group input:focus,
|
|
1709
|
+
.form-group textarea:focus {
|
|
1710
|
+
outline: none;
|
|
1711
|
+
border-color: var(--accent);
|
|
1712
|
+
}
|
|
1713
|
+
|
|
1714
|
+
.btn {
|
|
1715
|
+
padding: 10px 20px;
|
|
1716
|
+
border: none;
|
|
1717
|
+
border-radius: 6px;
|
|
1718
|
+
font-weight: 600;
|
|
1719
|
+
cursor: pointer;
|
|
1720
|
+
transition: all 0.2s;
|
|
1721
|
+
font-size: 14px;
|
|
1722
|
+
}
|
|
1723
|
+
|
|
1724
|
+
.btn-primary {
|
|
1725
|
+
background: var(--accent);
|
|
1726
|
+
color: white;
|
|
1727
|
+
}
|
|
1728
|
+
|
|
1729
|
+
.btn-primary:hover { background: var(--accent-hover); }
|
|
1730
|
+
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
|
|
1731
|
+
|
|
1732
|
+
.result {
|
|
1733
|
+
background: var(--code-bg);
|
|
1734
|
+
border-radius: 6px;
|
|
1735
|
+
padding: 16px;
|
|
1736
|
+
font-family: 'Monaco', 'Menlo', monospace;
|
|
1737
|
+
font-size: 13px;
|
|
1738
|
+
white-space: pre-wrap;
|
|
1739
|
+
word-break: break-all;
|
|
1740
|
+
max-height: 300px;
|
|
1741
|
+
overflow-y: auto;
|
|
1742
|
+
}
|
|
1743
|
+
|
|
1744
|
+
.result.success { border-left: 3px solid var(--success); }
|
|
1745
|
+
.result.error { border-left: 3px solid var(--error); }
|
|
1746
|
+
|
|
1747
|
+
.history-item {
|
|
1748
|
+
padding: 10px 12px;
|
|
1749
|
+
border: 1px solid var(--border);
|
|
1750
|
+
border-radius: 6px;
|
|
1751
|
+
margin-bottom: 8px;
|
|
1752
|
+
font-size: 13px;
|
|
1753
|
+
}
|
|
1754
|
+
|
|
1755
|
+
.history-item .type {
|
|
1756
|
+
display: inline-block;
|
|
1757
|
+
padding: 2px 6px;
|
|
1758
|
+
border-radius: 4px;
|
|
1759
|
+
font-size: 11px;
|
|
1760
|
+
text-transform: uppercase;
|
|
1761
|
+
font-weight: 600;
|
|
1762
|
+
}
|
|
1763
|
+
|
|
1764
|
+
.history-item .type.tool { background: #2196f3; color: white; }
|
|
1765
|
+
.history-item .type.resource { background: #9c27b0; color: white; }
|
|
1766
|
+
.history-item .type.prompt { background: #ff9800; color: white; }
|
|
1767
|
+
|
|
1768
|
+
.history-item .name {
|
|
1769
|
+
font-weight: 600;
|
|
1770
|
+
margin-left: 8px;
|
|
1771
|
+
}
|
|
1772
|
+
|
|
1773
|
+
.history-item .time {
|
|
1774
|
+
color: var(--text-secondary);
|
|
1775
|
+
font-size: 12px;
|
|
1776
|
+
margin-top: 4px;
|
|
1777
|
+
}
|
|
1778
|
+
|
|
1779
|
+
.history-item .duration {
|
|
1780
|
+
color: var(--success);
|
|
1781
|
+
}
|
|
1782
|
+
|
|
1783
|
+
.history-item.error .duration { color: var(--error); }
|
|
1784
|
+
|
|
1785
|
+
.empty-state {
|
|
1786
|
+
text-align: center;
|
|
1787
|
+
padding: 40px 20px;
|
|
1788
|
+
color: var(--text-secondary);
|
|
1789
|
+
}
|
|
1790
|
+
|
|
1791
|
+
.spinner {
|
|
1792
|
+
border: 3px solid var(--border);
|
|
1793
|
+
border-top: 3px solid var(--accent);
|
|
1794
|
+
border-radius: 50%;
|
|
1795
|
+
width: 24px;
|
|
1796
|
+
height: 24px;
|
|
1797
|
+
animation: spin 1s linear infinite;
|
|
1798
|
+
margin: 20px auto;
|
|
1799
|
+
}
|
|
1800
|
+
|
|
1801
|
+
@keyframes spin {
|
|
1802
|
+
0% { transform: rotate(0deg); }
|
|
1803
|
+
100% { transform: rotate(360deg); }
|
|
1804
|
+
}
|
|
1805
|
+
|
|
1806
|
+
.logs {
|
|
1807
|
+
font-family: 'Monaco', 'Menlo', monospace;
|
|
1808
|
+
font-size: 12px;
|
|
1809
|
+
background: var(--code-bg);
|
|
1810
|
+
padding: 12px;
|
|
1811
|
+
border-radius: 6px;
|
|
1812
|
+
max-height: 200px;
|
|
1813
|
+
overflow-y: auto;
|
|
1814
|
+
}
|
|
1815
|
+
|
|
1816
|
+
.log-entry {
|
|
1817
|
+
color: var(--text-secondary);
|
|
1818
|
+
margin-bottom: 4px;
|
|
1819
|
+
}
|
|
1820
|
+
</style>
|
|
1821
|
+
</head>
|
|
1822
|
+
<body>
|
|
1823
|
+
<header>
|
|
1824
|
+
<div class="container">
|
|
1825
|
+
<h1>\u{1F527} ${this.options.title}</h1>
|
|
1826
|
+
<div class="server-info" id="server-info">Loading...</div>
|
|
1827
|
+
</div>
|
|
1828
|
+
</header>
|
|
1829
|
+
|
|
1830
|
+
<div class="container">
|
|
1831
|
+
<div class="grid">
|
|
1832
|
+
<!-- Left Panel: Items List -->
|
|
1833
|
+
<div class="panel">
|
|
1834
|
+
<div class="tabs">
|
|
1835
|
+
<button class="tab active" data-tab="tools">Tools</button>
|
|
1836
|
+
<button class="tab" data-tab="resources">Resources</button>
|
|
1837
|
+
<button class="tab" data-tab="prompts">Prompts</button>
|
|
1838
|
+
</div>
|
|
1839
|
+
<div class="panel-content" id="items-list">
|
|
1840
|
+
<div class="empty-state">Loading...</div>
|
|
1841
|
+
</div>
|
|
1842
|
+
</div>
|
|
1843
|
+
|
|
1844
|
+
<!-- Center Panel: Tester -->
|
|
1845
|
+
<div class="panel">
|
|
1846
|
+
<div class="panel-header">
|
|
1847
|
+
<span id="tester-title">Select an item to test</span>
|
|
1848
|
+
</div>
|
|
1849
|
+
<div class="panel-content" id="tester">
|
|
1850
|
+
<div class="empty-state">
|
|
1851
|
+
<p>Select a tool, resource, or prompt from the left panel to test it.</p>
|
|
1852
|
+
</div>
|
|
1853
|
+
</div>
|
|
1854
|
+
</div>
|
|
1855
|
+
|
|
1856
|
+
<!-- Right Panel: History -->
|
|
1857
|
+
<div class="panel">
|
|
1858
|
+
<div class="panel-header">
|
|
1859
|
+
<span>Call History</span>
|
|
1860
|
+
<button class="btn" onclick="clearHistory()" style="padding: 4px 8px; font-size: 12px;">Clear</button>
|
|
1861
|
+
</div>
|
|
1862
|
+
<div class="panel-content" id="history">
|
|
1863
|
+
<div class="empty-state">No calls yet</div>
|
|
1864
|
+
</div>
|
|
1865
|
+
</div>
|
|
1866
|
+
</div>
|
|
1867
|
+
</div>
|
|
1868
|
+
|
|
1869
|
+
<script>
|
|
1870
|
+
// State
|
|
1871
|
+
let serverInfo = null;
|
|
1872
|
+
let currentTab = 'tools';
|
|
1873
|
+
let selectedItem = null;
|
|
1874
|
+
let isLoading = false;
|
|
1875
|
+
let history = [];
|
|
1876
|
+
|
|
1877
|
+
// Initialize
|
|
1878
|
+
async function init() {
|
|
1879
|
+
await loadServerInfo();
|
|
1880
|
+
await loadItems();
|
|
1881
|
+
setupTabs();
|
|
1882
|
+
pollHistory();
|
|
1883
|
+
}
|
|
1884
|
+
|
|
1885
|
+
// Load server info
|
|
1886
|
+
async function loadServerInfo() {
|
|
1887
|
+
try {
|
|
1888
|
+
const res = await fetch('/api/info');
|
|
1889
|
+
serverInfo = await res.json();
|
|
1890
|
+
document.getElementById('server-info').innerHTML = \`
|
|
1891
|
+
<span><strong>Name:</strong> \${serverInfo.name}</span>
|
|
1892
|
+
<span><strong>Version:</strong> \${serverInfo.version}</span>
|
|
1893
|
+
<span class="badge">\${serverInfo.tools.length} Tools</span>
|
|
1894
|
+
<span class="badge">\${serverInfo.resources.length} Resources</span>
|
|
1895
|
+
<span class="badge">\${serverInfo.prompts.length} Prompts</span>
|
|
1896
|
+
\`;
|
|
1897
|
+
} catch (err) {
|
|
1898
|
+
console.error('Failed to load server info:', err);
|
|
1899
|
+
}
|
|
1900
|
+
}
|
|
1901
|
+
|
|
1902
|
+
// Load items based on current tab
|
|
1903
|
+
async function loadItems() {
|
|
1904
|
+
const container = document.getElementById('items-list');
|
|
1905
|
+
let items = [];
|
|
1906
|
+
|
|
1907
|
+
if (currentTab === 'tools') {
|
|
1908
|
+
items = serverInfo?.tools || [];
|
|
1909
|
+
} else if (currentTab === 'resources') {
|
|
1910
|
+
items = serverInfo?.resources || [];
|
|
1911
|
+
} else if (currentTab === 'prompts') {
|
|
1912
|
+
items = serverInfo?.prompts || [];
|
|
1913
|
+
}
|
|
1914
|
+
|
|
1915
|
+
if (items.length === 0) {
|
|
1916
|
+
container.innerHTML = '<div class="empty-state">No ' + currentTab + ' available</div>';
|
|
1917
|
+
return;
|
|
1918
|
+
}
|
|
1919
|
+
|
|
1920
|
+
container.innerHTML = items.map((item, index) => \`
|
|
1921
|
+
<div class="item" onclick="selectItem('\${currentTab}', \${index})">
|
|
1922
|
+
<div class="item-name">\${item.name || item.uri}</div>
|
|
1923
|
+
<div class="item-desc">\${item.description || ''}</div>
|
|
1924
|
+
</div>
|
|
1925
|
+
\`).join('');
|
|
1926
|
+
}
|
|
1927
|
+
|
|
1928
|
+
// Setup tabs
|
|
1929
|
+
function setupTabs() {
|
|
1930
|
+
document.querySelectorAll('.tab').forEach(tab => {
|
|
1931
|
+
tab.addEventListener('click', () => {
|
|
1932
|
+
document.querySelectorAll('.tab').forEach(t => t.classList.remove('active'));
|
|
1933
|
+
tab.classList.add('active');
|
|
1934
|
+
currentTab = tab.dataset.tab;
|
|
1935
|
+
loadItems();
|
|
1936
|
+
clearTester();
|
|
1937
|
+
});
|
|
1938
|
+
});
|
|
1939
|
+
}
|
|
1940
|
+
|
|
1941
|
+
// Select an item
|
|
1942
|
+
function selectItem(type, index) {
|
|
1943
|
+
let items = type === 'tools' ? serverInfo.tools :
|
|
1944
|
+
type === 'resources' ? serverInfo.resources :
|
|
1945
|
+
serverInfo.prompts;
|
|
1946
|
+
selectedItem = { type, item: items[index] };
|
|
1947
|
+
renderTester();
|
|
1948
|
+
}
|
|
1949
|
+
|
|
1950
|
+
// Clear tester
|
|
1951
|
+
function clearTester() {
|
|
1952
|
+
selectedItem = null;
|
|
1953
|
+
document.getElementById('tester-title').textContent = 'Select an item to test';
|
|
1954
|
+
document.getElementById('tester').innerHTML = \`
|
|
1955
|
+
<div class="empty-state">
|
|
1956
|
+
<p>Select a tool, resource, or prompt from the left panel to test it.</p>
|
|
1957
|
+
</div>
|
|
1958
|
+
\`;
|
|
1959
|
+
}
|
|
1960
|
+
|
|
1961
|
+
// Render tester for selected item
|
|
1962
|
+
function renderTester() {
|
|
1963
|
+
if (!selectedItem) return;
|
|
1964
|
+
|
|
1965
|
+
const { type, item } = selectedItem;
|
|
1966
|
+
document.getElementById('tester-title').textContent = item.name || item.uri;
|
|
1967
|
+
|
|
1968
|
+
let html = '';
|
|
1969
|
+
|
|
1970
|
+
if (type === 'tools') {
|
|
1971
|
+
html = \`
|
|
1972
|
+
<div class="form-group">
|
|
1973
|
+
<label>Description</label>
|
|
1974
|
+
<p style="color: var(--text-secondary); font-size: 14px;">\${item.description || 'No description'}</p>
|
|
1975
|
+
</div>
|
|
1976
|
+
<div class="form-group">
|
|
1977
|
+
<label>Input (JSON)</label>
|
|
1978
|
+
<textarea id="tool-input" placeholder='{"key": "value"}'>{}</textarea>
|
|
1979
|
+
</div>
|
|
1980
|
+
<button class="btn btn-primary" onclick="callTool()" id="call-btn">Call Tool</button>
|
|
1981
|
+
<div id="result-container" style="margin-top: 16px;"></div>
|
|
1982
|
+
\`;
|
|
1983
|
+
} else if (type === 'resources') {
|
|
1984
|
+
html = \`
|
|
1985
|
+
<div class="form-group">
|
|
1986
|
+
<label>URI Template</label>
|
|
1987
|
+
<p style="color: var(--text-secondary); font-size: 14px;">\${item.uri}</p>
|
|
1988
|
+
</div>
|
|
1989
|
+
<div class="form-group">
|
|
1990
|
+
<label>URI to Read</label>
|
|
1991
|
+
<input type="text" id="resource-uri" value="\${item.uri.replace(/{[^}]+}/g, 'example')}" />
|
|
1992
|
+
</div>
|
|
1993
|
+
<button class="btn btn-primary" onclick="readResource()" id="call-btn">Read Resource</button>
|
|
1994
|
+
<div id="result-container" style="margin-top: 16px;"></div>
|
|
1995
|
+
\`;
|
|
1996
|
+
} else if (type === 'prompts') {
|
|
1997
|
+
const args = item.arguments || [];
|
|
1998
|
+
html = \`
|
|
1999
|
+
<div class="form-group">
|
|
2000
|
+
<label>Description</label>
|
|
2001
|
+
<p style="color: var(--text-secondary); font-size: 14px;">\${item.description || 'No description'}</p>
|
|
2002
|
+
</div>
|
|
2003
|
+
<div class="form-group">
|
|
2004
|
+
<label>Arguments (JSON)</label>
|
|
2005
|
+
<textarea id="prompt-args" placeholder='{"arg1": "value1"}'>\${JSON.stringify(args.reduce((acc, a) => ({ ...acc, [a.name]: '' }), {}), null, 2)}</textarea>
|
|
2006
|
+
</div>
|
|
2007
|
+
<button class="btn btn-primary" onclick="getPrompt()" id="call-btn">Get Prompt</button>
|
|
2008
|
+
<div id="result-container" style="margin-top: 16px;"></div>
|
|
2009
|
+
\`;
|
|
2010
|
+
}
|
|
2011
|
+
|
|
2012
|
+
document.getElementById('tester').innerHTML = html;
|
|
2013
|
+
}
|
|
2014
|
+
|
|
2015
|
+
// Call tool
|
|
2016
|
+
async function callTool() {
|
|
2017
|
+
if (isLoading) return;
|
|
2018
|
+
isLoading = true;
|
|
2019
|
+
|
|
2020
|
+
const btn = document.getElementById('call-btn');
|
|
2021
|
+
btn.disabled = true;
|
|
2022
|
+
btn.textContent = 'Calling...';
|
|
2023
|
+
|
|
2024
|
+
try {
|
|
2025
|
+
const input = JSON.parse(document.getElementById('tool-input').value || '{}');
|
|
2026
|
+
const res = await fetch('/api/call-tool', {
|
|
2027
|
+
method: 'POST',
|
|
2028
|
+
headers: { 'Content-Type': 'application/json' },
|
|
2029
|
+
body: JSON.stringify({ name: selectedItem.item.name, input })
|
|
2030
|
+
});
|
|
2031
|
+
const data = await res.json();
|
|
2032
|
+
showResult(data);
|
|
2033
|
+
} catch (err) {
|
|
2034
|
+
showResult({ success: false, error: err.message });
|
|
2035
|
+
} finally {
|
|
2036
|
+
isLoading = false;
|
|
2037
|
+
btn.disabled = false;
|
|
2038
|
+
btn.textContent = 'Call Tool';
|
|
2039
|
+
}
|
|
2040
|
+
}
|
|
2041
|
+
|
|
2042
|
+
// Read resource
|
|
2043
|
+
async function readResource() {
|
|
2044
|
+
if (isLoading) return;
|
|
2045
|
+
isLoading = true;
|
|
2046
|
+
|
|
2047
|
+
const btn = document.getElementById('call-btn');
|
|
2048
|
+
btn.disabled = true;
|
|
2049
|
+
btn.textContent = 'Reading...';
|
|
2050
|
+
|
|
2051
|
+
try {
|
|
2052
|
+
const uri = document.getElementById('resource-uri').value;
|
|
2053
|
+
const res = await fetch('/api/read-resource', {
|
|
2054
|
+
method: 'POST',
|
|
2055
|
+
headers: { 'Content-Type': 'application/json' },
|
|
2056
|
+
body: JSON.stringify({ uri })
|
|
2057
|
+
});
|
|
2058
|
+
const data = await res.json();
|
|
2059
|
+
showResult(data);
|
|
2060
|
+
} catch (err) {
|
|
2061
|
+
showResult({ success: false, error: err.message });
|
|
2062
|
+
} finally {
|
|
2063
|
+
isLoading = false;
|
|
2064
|
+
btn.disabled = false;
|
|
2065
|
+
btn.textContent = 'Read Resource';
|
|
2066
|
+
}
|
|
2067
|
+
}
|
|
2068
|
+
|
|
2069
|
+
// Get prompt
|
|
2070
|
+
async function getPrompt() {
|
|
2071
|
+
if (isLoading) return;
|
|
2072
|
+
isLoading = true;
|
|
2073
|
+
|
|
2074
|
+
const btn = document.getElementById('call-btn');
|
|
2075
|
+
btn.disabled = true;
|
|
2076
|
+
btn.textContent = 'Getting...';
|
|
2077
|
+
|
|
2078
|
+
try {
|
|
2079
|
+
const args = JSON.parse(document.getElementById('prompt-args').value || '{}');
|
|
2080
|
+
const res = await fetch('/api/get-prompt', {
|
|
2081
|
+
method: 'POST',
|
|
2082
|
+
headers: { 'Content-Type': 'application/json' },
|
|
2083
|
+
body: JSON.stringify({ name: selectedItem.item.name, args })
|
|
2084
|
+
});
|
|
2085
|
+
const data = await res.json();
|
|
2086
|
+
showResult(data);
|
|
2087
|
+
} catch (err) {
|
|
2088
|
+
showResult({ success: false, error: err.message });
|
|
2089
|
+
} finally {
|
|
2090
|
+
isLoading = false;
|
|
2091
|
+
btn.disabled = false;
|
|
2092
|
+
btn.textContent = 'Get Prompt';
|
|
2093
|
+
}
|
|
2094
|
+
}
|
|
2095
|
+
|
|
2096
|
+
// Show result
|
|
2097
|
+
function showResult(data) {
|
|
2098
|
+
const container = document.getElementById('result-container');
|
|
2099
|
+
const success = data.success;
|
|
2100
|
+
const content = success ? JSON.stringify(data.result, null, 2) : data.error;
|
|
2101
|
+
|
|
2102
|
+
container.innerHTML = \`
|
|
2103
|
+
<div class="result \${success ? 'success' : 'error'}">
|
|
2104
|
+
\${escapeHtml(content)}
|
|
2105
|
+
</div>
|
|
2106
|
+
\`;
|
|
2107
|
+
|
|
2108
|
+
refreshHistory();
|
|
2109
|
+
}
|
|
2110
|
+
|
|
2111
|
+
// Escape HTML
|
|
2112
|
+
function escapeHtml(text) {
|
|
2113
|
+
const div = document.createElement('div');
|
|
2114
|
+
div.textContent = text;
|
|
2115
|
+
return div.innerHTML;
|
|
2116
|
+
}
|
|
2117
|
+
|
|
2118
|
+
// Poll history
|
|
2119
|
+
async function pollHistory() {
|
|
2120
|
+
await refreshHistory();
|
|
2121
|
+
setTimeout(pollHistory, 2000);
|
|
2122
|
+
}
|
|
2123
|
+
|
|
2124
|
+
// Refresh history
|
|
2125
|
+
async function refreshHistory() {
|
|
2126
|
+
try {
|
|
2127
|
+
const res = await fetch('/api/history');
|
|
2128
|
+
history = await res.json();
|
|
2129
|
+
renderHistory();
|
|
2130
|
+
} catch (err) {
|
|
2131
|
+
console.error('Failed to load history:', err);
|
|
2132
|
+
}
|
|
2133
|
+
}
|
|
2134
|
+
|
|
2135
|
+
// Render history
|
|
2136
|
+
function renderHistory() {
|
|
2137
|
+
const container = document.getElementById('history');
|
|
2138
|
+
|
|
2139
|
+
if (history.length === 0) {
|
|
2140
|
+
container.innerHTML = '<div class="empty-state">No calls yet</div>';
|
|
2141
|
+
return;
|
|
2142
|
+
}
|
|
2143
|
+
|
|
2144
|
+
container.innerHTML = history.slice(0, 50).map(entry => \`
|
|
2145
|
+
<div class="history-item \${entry.error ? 'error' : ''}">
|
|
2146
|
+
<span class="type \${entry.type}">\${entry.type}</span>
|
|
2147
|
+
<span class="name">\${entry.name}</span>
|
|
2148
|
+
<div class="time">
|
|
2149
|
+
\${new Date(entry.timestamp).toLocaleTimeString()} -
|
|
2150
|
+
<span class="duration">\${entry.duration}ms</span>
|
|
2151
|
+
\${entry.error ? '<span style="color: var(--error);"> - Error</span>' : ''}
|
|
2152
|
+
</div>
|
|
2153
|
+
</div>
|
|
2154
|
+
\`).join('');
|
|
2155
|
+
}
|
|
2156
|
+
|
|
2157
|
+
// Clear history
|
|
2158
|
+
function clearHistory() {
|
|
2159
|
+
history = [];
|
|
2160
|
+
renderHistory();
|
|
2161
|
+
}
|
|
2162
|
+
|
|
2163
|
+
// Start
|
|
2164
|
+
init();
|
|
2165
|
+
</script>
|
|
2166
|
+
</body>
|
|
2167
|
+
</html>`;
|
|
2168
|
+
}
|
|
2169
|
+
};
|
|
2170
|
+
|
|
2171
|
+
// src/index.ts
|
|
2172
|
+
var VERSION = "0.1.0";
|
|
2173
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
2174
|
+
0 && (module.exports = {
|
|
2175
|
+
McpWebUI,
|
|
2176
|
+
VERSION
|
|
2177
|
+
});
|
|
2178
|
+
/*! Bundled license information:
|
|
2179
|
+
|
|
2180
|
+
reflect-metadata/Reflect.js:
|
|
2181
|
+
(*! *****************************************************************************
|
|
2182
|
+
Copyright (C) Microsoft. All rights reserved.
|
|
2183
|
+
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
|
|
2184
|
+
this file except in compliance with the License. You may obtain a copy of the
|
|
2185
|
+
License at http://www.apache.org/licenses/LICENSE-2.0
|
|
2186
|
+
|
|
2187
|
+
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
2188
|
+
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
|
|
2189
|
+
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
|
|
2190
|
+
MERCHANTABLITY OR NON-INFRINGEMENT.
|
|
2191
|
+
|
|
2192
|
+
See the Apache Version 2.0 License for specific language governing permissions
|
|
2193
|
+
and limitations under the License.
|
|
2194
|
+
***************************************************************************** *)
|
|
2195
|
+
*/
|
|
2196
|
+
//# sourceMappingURL=index.js.map
|