integrate-sdk 0.7.29 → 0.7.32
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/adapters/index.js +10 -9
- package/dist/adapters/solid-start.js +10 -9
- package/dist/adapters/svelte-kit.js +10 -9
- package/dist/index.js +13 -12
- package/dist/server.js +11 -10
- package/dist/src/client.d.ts +16 -15
- package/dist/src/client.d.ts.map +1 -1
- package/dist/src/index.d.ts +2 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/integrations/types.d.ts +5 -5
- package/dist/src/integrations/types.d.ts.map +1 -1
- package/dist/src/oauth/manager.d.ts +6 -6
- package/dist/src/oauth/manager.d.ts.map +1 -1
- package/dist/src/oauth/types.d.ts +2 -2
- package/dist/src/oauth/types.d.ts.map +1 -1
- package/dist/src/server.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/adapters/index.js
CHANGED
|
@@ -1134,14 +1134,13 @@ class OAuthManager {
|
|
|
1134
1134
|
state,
|
|
1135
1135
|
codeVerifier,
|
|
1136
1136
|
codeChallenge,
|
|
1137
|
-
scopes: config.scopes,
|
|
1138
1137
|
redirectUri: config.redirectUri,
|
|
1139
1138
|
returnUrl,
|
|
1140
1139
|
initiatedAt: Date.now()
|
|
1141
1140
|
};
|
|
1142
1141
|
this.pendingAuths.set(state, pendingAuth);
|
|
1143
1142
|
this.savePendingAuthToStorage(state, pendingAuth);
|
|
1144
|
-
const authUrl = await this.getAuthorizationUrl(provider,
|
|
1143
|
+
const authUrl = await this.getAuthorizationUrl(provider, state, codeChallenge, config.redirectUri);
|
|
1145
1144
|
if (this.flowConfig.mode === "popup") {
|
|
1146
1145
|
this.windowManager.openPopup(authUrl, this.flowConfig.popupOptions);
|
|
1147
1146
|
try {
|
|
@@ -1366,7 +1365,7 @@ class OAuthManager {
|
|
|
1366
1365
|
}
|
|
1367
1366
|
}
|
|
1368
1367
|
}
|
|
1369
|
-
async getAuthorizationUrl(provider,
|
|
1368
|
+
async getAuthorizationUrl(provider, state, codeChallenge, redirectUri) {
|
|
1370
1369
|
const url = this.apiBaseUrl ? `${this.apiBaseUrl}${this.oauthApiBase}/authorize` : `${this.oauthApiBase}/authorize`;
|
|
1371
1370
|
const response = await fetch(url, {
|
|
1372
1371
|
method: "POST",
|
|
@@ -1375,7 +1374,6 @@ class OAuthManager {
|
|
|
1375
1374
|
},
|
|
1376
1375
|
body: JSON.stringify({
|
|
1377
1376
|
provider,
|
|
1378
|
-
scopes,
|
|
1379
1377
|
state,
|
|
1380
1378
|
codeChallenge,
|
|
1381
1379
|
codeChallengeMethod: "S256",
|
|
@@ -1453,7 +1451,7 @@ class SimpleEventEmitter {
|
|
|
1453
1451
|
var MCP_SERVER_URL2 = "https://mcp.integrate.dev/api/v1/mcp";
|
|
1454
1452
|
var clientCache = new Map;
|
|
1455
1453
|
var cleanupClients = new Set;
|
|
1456
|
-
class
|
|
1454
|
+
class MCPClientBase {
|
|
1457
1455
|
transport;
|
|
1458
1456
|
integrations;
|
|
1459
1457
|
availableTools = new Map;
|
|
@@ -1467,8 +1465,6 @@ class MCPClient {
|
|
|
1467
1465
|
eventEmitter = new SimpleEventEmitter;
|
|
1468
1466
|
apiRouteBase;
|
|
1469
1467
|
apiBaseUrl;
|
|
1470
|
-
github;
|
|
1471
|
-
gmail;
|
|
1472
1468
|
server;
|
|
1473
1469
|
constructor(config) {
|
|
1474
1470
|
this.transport = new HttpSessionTransport({
|
|
@@ -1510,8 +1506,13 @@ class MCPClient {
|
|
|
1510
1506
|
this.authState.set(integration.oauth.provider, { authenticated: hasToken });
|
|
1511
1507
|
}
|
|
1512
1508
|
}
|
|
1513
|
-
|
|
1514
|
-
|
|
1509
|
+
const integrationIds = this.integrations.map((i) => i.id);
|
|
1510
|
+
if (integrationIds.includes("github")) {
|
|
1511
|
+
this.github = this.createIntegrationProxy("github");
|
|
1512
|
+
}
|
|
1513
|
+
if (integrationIds.includes("gmail")) {
|
|
1514
|
+
this.gmail = this.createIntegrationProxy("gmail");
|
|
1515
|
+
}
|
|
1515
1516
|
this.server = this.createServerProxy();
|
|
1516
1517
|
this.initializeIntegrations();
|
|
1517
1518
|
}
|
|
@@ -999,14 +999,13 @@ class OAuthManager {
|
|
|
999
999
|
state,
|
|
1000
1000
|
codeVerifier,
|
|
1001
1001
|
codeChallenge,
|
|
1002
|
-
scopes: config.scopes,
|
|
1003
1002
|
redirectUri: config.redirectUri,
|
|
1004
1003
|
returnUrl,
|
|
1005
1004
|
initiatedAt: Date.now()
|
|
1006
1005
|
};
|
|
1007
1006
|
this.pendingAuths.set(state, pendingAuth);
|
|
1008
1007
|
this.savePendingAuthToStorage(state, pendingAuth);
|
|
1009
|
-
const authUrl = await this.getAuthorizationUrl(provider,
|
|
1008
|
+
const authUrl = await this.getAuthorizationUrl(provider, state, codeChallenge, config.redirectUri);
|
|
1010
1009
|
if (this.flowConfig.mode === "popup") {
|
|
1011
1010
|
this.windowManager.openPopup(authUrl, this.flowConfig.popupOptions);
|
|
1012
1011
|
try {
|
|
@@ -1231,7 +1230,7 @@ class OAuthManager {
|
|
|
1231
1230
|
}
|
|
1232
1231
|
}
|
|
1233
1232
|
}
|
|
1234
|
-
async getAuthorizationUrl(provider,
|
|
1233
|
+
async getAuthorizationUrl(provider, state, codeChallenge, redirectUri) {
|
|
1235
1234
|
const url = this.apiBaseUrl ? `${this.apiBaseUrl}${this.oauthApiBase}/authorize` : `${this.oauthApiBase}/authorize`;
|
|
1236
1235
|
const response = await fetch(url, {
|
|
1237
1236
|
method: "POST",
|
|
@@ -1240,7 +1239,6 @@ class OAuthManager {
|
|
|
1240
1239
|
},
|
|
1241
1240
|
body: JSON.stringify({
|
|
1242
1241
|
provider,
|
|
1243
|
-
scopes,
|
|
1244
1242
|
state,
|
|
1245
1243
|
codeChallenge,
|
|
1246
1244
|
codeChallengeMethod: "S256",
|
|
@@ -1318,7 +1316,7 @@ class SimpleEventEmitter {
|
|
|
1318
1316
|
var MCP_SERVER_URL2 = "https://mcp.integrate.dev/api/v1/mcp";
|
|
1319
1317
|
var clientCache = new Map;
|
|
1320
1318
|
var cleanupClients = new Set;
|
|
1321
|
-
class
|
|
1319
|
+
class MCPClientBase {
|
|
1322
1320
|
transport;
|
|
1323
1321
|
integrations;
|
|
1324
1322
|
availableTools = new Map;
|
|
@@ -1332,8 +1330,6 @@ class MCPClient {
|
|
|
1332
1330
|
eventEmitter = new SimpleEventEmitter;
|
|
1333
1331
|
apiRouteBase;
|
|
1334
1332
|
apiBaseUrl;
|
|
1335
|
-
github;
|
|
1336
|
-
gmail;
|
|
1337
1333
|
server;
|
|
1338
1334
|
constructor(config) {
|
|
1339
1335
|
this.transport = new HttpSessionTransport({
|
|
@@ -1375,8 +1371,13 @@ class MCPClient {
|
|
|
1375
1371
|
this.authState.set(integration.oauth.provider, { authenticated: hasToken });
|
|
1376
1372
|
}
|
|
1377
1373
|
}
|
|
1378
|
-
|
|
1379
|
-
|
|
1374
|
+
const integrationIds = this.integrations.map((i) => i.id);
|
|
1375
|
+
if (integrationIds.includes("github")) {
|
|
1376
|
+
this.github = this.createIntegrationProxy("github");
|
|
1377
|
+
}
|
|
1378
|
+
if (integrationIds.includes("gmail")) {
|
|
1379
|
+
this.gmail = this.createIntegrationProxy("gmail");
|
|
1380
|
+
}
|
|
1380
1381
|
this.server = this.createServerProxy();
|
|
1381
1382
|
this.initializeIntegrations();
|
|
1382
1383
|
}
|
|
@@ -999,14 +999,13 @@ class OAuthManager {
|
|
|
999
999
|
state,
|
|
1000
1000
|
codeVerifier,
|
|
1001
1001
|
codeChallenge,
|
|
1002
|
-
scopes: config.scopes,
|
|
1003
1002
|
redirectUri: config.redirectUri,
|
|
1004
1003
|
returnUrl,
|
|
1005
1004
|
initiatedAt: Date.now()
|
|
1006
1005
|
};
|
|
1007
1006
|
this.pendingAuths.set(state, pendingAuth);
|
|
1008
1007
|
this.savePendingAuthToStorage(state, pendingAuth);
|
|
1009
|
-
const authUrl = await this.getAuthorizationUrl(provider,
|
|
1008
|
+
const authUrl = await this.getAuthorizationUrl(provider, state, codeChallenge, config.redirectUri);
|
|
1010
1009
|
if (this.flowConfig.mode === "popup") {
|
|
1011
1010
|
this.windowManager.openPopup(authUrl, this.flowConfig.popupOptions);
|
|
1012
1011
|
try {
|
|
@@ -1231,7 +1230,7 @@ class OAuthManager {
|
|
|
1231
1230
|
}
|
|
1232
1231
|
}
|
|
1233
1232
|
}
|
|
1234
|
-
async getAuthorizationUrl(provider,
|
|
1233
|
+
async getAuthorizationUrl(provider, state, codeChallenge, redirectUri) {
|
|
1235
1234
|
const url = this.apiBaseUrl ? `${this.apiBaseUrl}${this.oauthApiBase}/authorize` : `${this.oauthApiBase}/authorize`;
|
|
1236
1235
|
const response = await fetch(url, {
|
|
1237
1236
|
method: "POST",
|
|
@@ -1240,7 +1239,6 @@ class OAuthManager {
|
|
|
1240
1239
|
},
|
|
1241
1240
|
body: JSON.stringify({
|
|
1242
1241
|
provider,
|
|
1243
|
-
scopes,
|
|
1244
1242
|
state,
|
|
1245
1243
|
codeChallenge,
|
|
1246
1244
|
codeChallengeMethod: "S256",
|
|
@@ -1318,7 +1316,7 @@ class SimpleEventEmitter {
|
|
|
1318
1316
|
var MCP_SERVER_URL2 = "https://mcp.integrate.dev/api/v1/mcp";
|
|
1319
1317
|
var clientCache = new Map;
|
|
1320
1318
|
var cleanupClients = new Set;
|
|
1321
|
-
class
|
|
1319
|
+
class MCPClientBase {
|
|
1322
1320
|
transport;
|
|
1323
1321
|
integrations;
|
|
1324
1322
|
availableTools = new Map;
|
|
@@ -1332,8 +1330,6 @@ class MCPClient {
|
|
|
1332
1330
|
eventEmitter = new SimpleEventEmitter;
|
|
1333
1331
|
apiRouteBase;
|
|
1334
1332
|
apiBaseUrl;
|
|
1335
|
-
github;
|
|
1336
|
-
gmail;
|
|
1337
1333
|
server;
|
|
1338
1334
|
constructor(config) {
|
|
1339
1335
|
this.transport = new HttpSessionTransport({
|
|
@@ -1375,8 +1371,13 @@ class MCPClient {
|
|
|
1375
1371
|
this.authState.set(integration.oauth.provider, { authenticated: hasToken });
|
|
1376
1372
|
}
|
|
1377
1373
|
}
|
|
1378
|
-
|
|
1379
|
-
|
|
1374
|
+
const integrationIds = this.integrations.map((i) => i.id);
|
|
1375
|
+
if (integrationIds.includes("github")) {
|
|
1376
|
+
this.github = this.createIntegrationProxy("github");
|
|
1377
|
+
}
|
|
1378
|
+
if (integrationIds.includes("gmail")) {
|
|
1379
|
+
this.gmail = this.createIntegrationProxy("gmail");
|
|
1380
|
+
}
|
|
1380
1381
|
this.server = this.createServerProxy();
|
|
1381
1382
|
this.initializeIntegrations();
|
|
1382
1383
|
}
|
package/dist/index.js
CHANGED
|
@@ -846,14 +846,13 @@ class OAuthManager {
|
|
|
846
846
|
state,
|
|
847
847
|
codeVerifier,
|
|
848
848
|
codeChallenge,
|
|
849
|
-
scopes: config.scopes,
|
|
850
849
|
redirectUri: config.redirectUri,
|
|
851
850
|
returnUrl,
|
|
852
851
|
initiatedAt: Date.now()
|
|
853
852
|
};
|
|
854
853
|
this.pendingAuths.set(state, pendingAuth);
|
|
855
854
|
this.savePendingAuthToStorage(state, pendingAuth);
|
|
856
|
-
const authUrl = await this.getAuthorizationUrl(provider,
|
|
855
|
+
const authUrl = await this.getAuthorizationUrl(provider, state, codeChallenge, config.redirectUri);
|
|
857
856
|
if (this.flowConfig.mode === "popup") {
|
|
858
857
|
this.windowManager.openPopup(authUrl, this.flowConfig.popupOptions);
|
|
859
858
|
try {
|
|
@@ -1078,7 +1077,7 @@ class OAuthManager {
|
|
|
1078
1077
|
}
|
|
1079
1078
|
}
|
|
1080
1079
|
}
|
|
1081
|
-
async getAuthorizationUrl(provider,
|
|
1080
|
+
async getAuthorizationUrl(provider, state, codeChallenge, redirectUri) {
|
|
1082
1081
|
const url = this.apiBaseUrl ? `${this.apiBaseUrl}${this.oauthApiBase}/authorize` : `${this.oauthApiBase}/authorize`;
|
|
1083
1082
|
const response = await fetch(url, {
|
|
1084
1083
|
method: "POST",
|
|
@@ -1087,7 +1086,6 @@ class OAuthManager {
|
|
|
1087
1086
|
},
|
|
1088
1087
|
body: JSON.stringify({
|
|
1089
1088
|
provider,
|
|
1090
|
-
scopes,
|
|
1091
1089
|
state,
|
|
1092
1090
|
codeChallenge,
|
|
1093
1091
|
codeChallengeMethod: "S256",
|
|
@@ -1167,7 +1165,7 @@ var clientCache = new Map;
|
|
|
1167
1165
|
var cleanupClients = new Set;
|
|
1168
1166
|
var cleanupHandlersRegistered = false;
|
|
1169
1167
|
|
|
1170
|
-
class
|
|
1168
|
+
class MCPClientBase {
|
|
1171
1169
|
transport;
|
|
1172
1170
|
integrations;
|
|
1173
1171
|
availableTools = new Map;
|
|
@@ -1181,8 +1179,6 @@ class MCPClient {
|
|
|
1181
1179
|
eventEmitter = new SimpleEventEmitter;
|
|
1182
1180
|
apiRouteBase;
|
|
1183
1181
|
apiBaseUrl;
|
|
1184
|
-
github;
|
|
1185
|
-
gmail;
|
|
1186
1182
|
server;
|
|
1187
1183
|
constructor(config) {
|
|
1188
1184
|
this.transport = new HttpSessionTransport({
|
|
@@ -1224,8 +1220,13 @@ class MCPClient {
|
|
|
1224
1220
|
this.authState.set(integration.oauth.provider, { authenticated: hasToken });
|
|
1225
1221
|
}
|
|
1226
1222
|
}
|
|
1227
|
-
|
|
1228
|
-
|
|
1223
|
+
const integrationIds = this.integrations.map((i) => i.id);
|
|
1224
|
+
if (integrationIds.includes("github")) {
|
|
1225
|
+
this.github = this.createIntegrationProxy("github");
|
|
1226
|
+
}
|
|
1227
|
+
if (integrationIds.includes("gmail")) {
|
|
1228
|
+
this.gmail = this.createIntegrationProxy("gmail");
|
|
1229
|
+
}
|
|
1229
1230
|
this.server = this.createServerProxy();
|
|
1230
1231
|
this.initializeIntegrations();
|
|
1231
1232
|
}
|
|
@@ -1678,7 +1679,7 @@ function createMCPClient(config) {
|
|
|
1678
1679
|
clientCache.delete(cacheKey);
|
|
1679
1680
|
cleanupClients.delete(existing);
|
|
1680
1681
|
}
|
|
1681
|
-
const client = new
|
|
1682
|
+
const client = new MCPClientBase(config);
|
|
1682
1683
|
clientCache.set(cacheKey, client);
|
|
1683
1684
|
if (autoCleanup) {
|
|
1684
1685
|
cleanupClients.add(client);
|
|
@@ -1694,7 +1695,7 @@ function createMCPClient(config) {
|
|
|
1694
1695
|
}
|
|
1695
1696
|
return client;
|
|
1696
1697
|
} else {
|
|
1697
|
-
const client = new
|
|
1698
|
+
const client = new MCPClientBase(config);
|
|
1698
1699
|
if (autoCleanup) {
|
|
1699
1700
|
cleanupClients.add(client);
|
|
1700
1701
|
registerCleanupHandlers();
|
|
@@ -2410,7 +2411,7 @@ export {
|
|
|
2410
2411
|
OAuthManager,
|
|
2411
2412
|
OAuthHandler,
|
|
2412
2413
|
MCPMethod,
|
|
2413
|
-
|
|
2414
|
+
MCPClientBase,
|
|
2414
2415
|
IntegrateSDKError,
|
|
2415
2416
|
HttpSessionTransport,
|
|
2416
2417
|
ConnectionError,
|
package/dist/server.js
CHANGED
|
@@ -839,14 +839,13 @@ class OAuthManager {
|
|
|
839
839
|
state,
|
|
840
840
|
codeVerifier,
|
|
841
841
|
codeChallenge,
|
|
842
|
-
scopes: config.scopes,
|
|
843
842
|
redirectUri: config.redirectUri,
|
|
844
843
|
returnUrl,
|
|
845
844
|
initiatedAt: Date.now()
|
|
846
845
|
};
|
|
847
846
|
this.pendingAuths.set(state, pendingAuth);
|
|
848
847
|
this.savePendingAuthToStorage(state, pendingAuth);
|
|
849
|
-
const authUrl = await this.getAuthorizationUrl(provider,
|
|
848
|
+
const authUrl = await this.getAuthorizationUrl(provider, state, codeChallenge, config.redirectUri);
|
|
850
849
|
if (this.flowConfig.mode === "popup") {
|
|
851
850
|
this.windowManager.openPopup(authUrl, this.flowConfig.popupOptions);
|
|
852
851
|
try {
|
|
@@ -1071,7 +1070,7 @@ class OAuthManager {
|
|
|
1071
1070
|
}
|
|
1072
1071
|
}
|
|
1073
1072
|
}
|
|
1074
|
-
async getAuthorizationUrl(provider,
|
|
1073
|
+
async getAuthorizationUrl(provider, state, codeChallenge, redirectUri) {
|
|
1075
1074
|
const url = this.apiBaseUrl ? `${this.apiBaseUrl}${this.oauthApiBase}/authorize` : `${this.oauthApiBase}/authorize`;
|
|
1076
1075
|
const response = await fetch(url, {
|
|
1077
1076
|
method: "POST",
|
|
@@ -1080,7 +1079,6 @@ class OAuthManager {
|
|
|
1080
1079
|
},
|
|
1081
1080
|
body: JSON.stringify({
|
|
1082
1081
|
provider,
|
|
1083
|
-
scopes,
|
|
1084
1082
|
state,
|
|
1085
1083
|
codeChallenge,
|
|
1086
1084
|
codeChallengeMethod: "S256",
|
|
@@ -1158,7 +1156,7 @@ class SimpleEventEmitter {
|
|
|
1158
1156
|
var MCP_SERVER_URL = "https://mcp.integrate.dev/api/v1/mcp";
|
|
1159
1157
|
var clientCache = new Map;
|
|
1160
1158
|
var cleanupClients = new Set;
|
|
1161
|
-
class
|
|
1159
|
+
class MCPClientBase {
|
|
1162
1160
|
transport;
|
|
1163
1161
|
integrations;
|
|
1164
1162
|
availableTools = new Map;
|
|
@@ -1172,8 +1170,6 @@ class MCPClient {
|
|
|
1172
1170
|
eventEmitter = new SimpleEventEmitter;
|
|
1173
1171
|
apiRouteBase;
|
|
1174
1172
|
apiBaseUrl;
|
|
1175
|
-
github;
|
|
1176
|
-
gmail;
|
|
1177
1173
|
server;
|
|
1178
1174
|
constructor(config) {
|
|
1179
1175
|
this.transport = new HttpSessionTransport({
|
|
@@ -1215,8 +1211,13 @@ class MCPClient {
|
|
|
1215
1211
|
this.authState.set(integration.oauth.provider, { authenticated: hasToken });
|
|
1216
1212
|
}
|
|
1217
1213
|
}
|
|
1218
|
-
|
|
1219
|
-
|
|
1214
|
+
const integrationIds = this.integrations.map((i) => i.id);
|
|
1215
|
+
if (integrationIds.includes("github")) {
|
|
1216
|
+
this.github = this.createIntegrationProxy("github");
|
|
1217
|
+
}
|
|
1218
|
+
if (integrationIds.includes("gmail")) {
|
|
1219
|
+
this.gmail = this.createIntegrationProxy("gmail");
|
|
1220
|
+
}
|
|
1220
1221
|
this.server = this.createServerProxy();
|
|
1221
1222
|
this.initializeIntegrations();
|
|
1222
1223
|
}
|
|
@@ -1978,7 +1979,7 @@ function createMCPServer(config) {
|
|
|
1978
1979
|
connectionMode: config.connectionMode || "lazy",
|
|
1979
1980
|
singleton: config.singleton ?? true
|
|
1980
1981
|
};
|
|
1981
|
-
const client = new
|
|
1982
|
+
const client = new MCPClientBase(clientConfig);
|
|
1982
1983
|
if (config.apiKey) {
|
|
1983
1984
|
client.setRequestHeader("X-API-KEY", config.apiKey);
|
|
1984
1985
|
}
|
package/dist/src/client.d.ts
CHANGED
|
@@ -27,23 +27,30 @@ type ExtractIntegrationId<T> = T extends {
|
|
|
27
27
|
} ? Id : never;
|
|
28
28
|
type IntegrationIds<TIntegrations extends readonly MCPIntegration[]> = ExtractIntegrationId<TIntegrations[number]>;
|
|
29
29
|
/**
|
|
30
|
-
*
|
|
30
|
+
* Map of all possible integration namespaces
|
|
31
31
|
*/
|
|
32
|
-
|
|
32
|
+
interface AllIntegrationNamespaces {
|
|
33
|
+
github: GitHubIntegrationClient;
|
|
34
|
+
gmail: GmailIntegrationClient;
|
|
35
|
+
}
|
|
33
36
|
/**
|
|
34
37
|
* Integration namespace type mapping - only includes properties for configured integrations
|
|
38
|
+
* Uses Pick to select only the integration IDs that are actually configured
|
|
35
39
|
*/
|
|
36
|
-
type IntegrationNamespaces<TIntegrations extends readonly MCPIntegration[]> =
|
|
37
|
-
github: GitHubIntegrationClient;
|
|
38
|
-
} : {}) & (HasIntegrationId<TIntegrations, "gmail"> extends true ? {
|
|
39
|
-
gmail: GmailIntegrationClient;
|
|
40
|
-
} : {});
|
|
40
|
+
type IntegrationNamespaces<TIntegrations extends readonly MCPIntegration[]> = Pick<AllIntegrationNamespaces, Extract<IntegrationIds<TIntegrations>, keyof AllIntegrationNamespaces>>;
|
|
41
41
|
/**
|
|
42
42
|
* MCP Client Class
|
|
43
43
|
*
|
|
44
|
-
* Provides type-safe access to MCP server tools with integration-based configuration
|
|
44
|
+
* Provides type-safe access to MCP server tools with integration-based configuration.
|
|
45
|
+
* Integration namespaces (github, gmail, etc.) are only available when configured.
|
|
46
|
+
*/
|
|
47
|
+
export type MCPClient<TIntegrations extends readonly MCPIntegration[] = readonly MCPIntegration[]> = MCPClientBase<TIntegrations> & IntegrationNamespaces<TIntegrations>;
|
|
48
|
+
/**
|
|
49
|
+
* Base MCP Client Class (without integration namespaces)
|
|
50
|
+
* Integration namespaces are added dynamically at runtime and via type intersection
|
|
51
|
+
* @internal
|
|
45
52
|
*/
|
|
46
|
-
export declare class
|
|
53
|
+
export declare class MCPClientBase<TIntegrations extends readonly MCPIntegration[] = readonly MCPIntegration[]> {
|
|
47
54
|
private transport;
|
|
48
55
|
private integrations;
|
|
49
56
|
private availableTools;
|
|
@@ -57,12 +64,6 @@ export declare class MCPClient<TIntegrations extends readonly MCPIntegration[] =
|
|
|
57
64
|
private eventEmitter;
|
|
58
65
|
private apiRouteBase;
|
|
59
66
|
private apiBaseUrl?;
|
|
60
|
-
readonly github: IntegrationNamespaces<TIntegrations> extends {
|
|
61
|
-
github: GitHubIntegrationClient;
|
|
62
|
-
} ? GitHubIntegrationClient : never;
|
|
63
|
-
readonly gmail: IntegrationNamespaces<TIntegrations> extends {
|
|
64
|
-
gmail: GmailIntegrationClient;
|
|
65
|
-
} ? GmailIntegrationClient : never;
|
|
66
67
|
readonly server: ServerIntegrationClient;
|
|
67
68
|
constructor(config: MCPClientConfig<TIntegrations>);
|
|
68
69
|
/**
|
package/dist/src/client.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EACV,OAAO,EAEP,mBAAmB,EAGpB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,KAAK,EAAE,eAAe,EAAiB,MAAM,mBAAmB,CAAC;AACxE,OAAO,EAGL,KAAK,mBAAmB,EACzB,MAAM,aAAa,CAAC;AAErB,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAC/E,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AAC7E,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,iCAAiC,CAAC;AAE/E,OAAO,KAAK,EACV,UAAU,EACV,mBAAmB,EACnB,iBAAiB,EACjB,gBAAgB,EAChB,iBAAiB,EACjB,cAAc,EACd,eAAe,EACf,mBAAmB,EACpB,MAAM,kBAAkB,CAAC;AAgE1B;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,gBAAgB;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,qBAAqB;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC;AAED;;GAEG;AACH,KAAK,oBAAoB,CAAC,CAAC,IAAI,CAAC,SAAS;IAAE,EAAE,EAAE,MAAM,EAAE,CAAA;CAAE,GAAG,EAAE,GAAG,KAAK,CAAC;AACvE,KAAK,cAAc,CAAC,aAAa,SAAS,SAAS,cAAc,EAAE,IAAI,oBAAoB,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;AAEnH;;GAEG;AACH,
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/client.ts"],"names":[],"mappings":"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"}
|
package/dist/src/index.d.ts
CHANGED
|
@@ -2,7 +2,8 @@
|
|
|
2
2
|
* Integrate SDK
|
|
3
3
|
* Type-safe TypeScript SDK for MCP Client
|
|
4
4
|
*/
|
|
5
|
-
export { MCPClient
|
|
5
|
+
export type { MCPClient } from "./client.js";
|
|
6
|
+
export { MCPClientBase, createMCPClient, clearClientCache } from "./client.js";
|
|
6
7
|
export type { ToolInvocationOptions } from "./client.js";
|
|
7
8
|
export { OAuthManager } from "./oauth/manager.js";
|
|
8
9
|
export { OAuthWindowManager, sendCallbackToOpener } from "./oauth/window-manager.js";
|
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
* Integration System Types
|
|
3
3
|
* Inspired by BetterAuth's provider pattern
|
|
4
4
|
*/
|
|
5
|
-
import type {
|
|
5
|
+
import type { MCPClientBase } from "../client.js";
|
|
6
6
|
/**
|
|
7
7
|
* OAuth Configuration for a integration
|
|
8
8
|
*
|
|
@@ -45,13 +45,13 @@ export interface MCPIntegration {
|
|
|
45
45
|
/** OAuth configuration for this integration */
|
|
46
46
|
oauth?: OAuthConfig;
|
|
47
47
|
/** Called when the integration is initialized with the client */
|
|
48
|
-
onInit?: (client:
|
|
48
|
+
onInit?: (client: MCPClientBase<any>) => Promise<void> | void;
|
|
49
49
|
/** Called before the client connects to the server */
|
|
50
|
-
onBeforeConnect?: (client:
|
|
50
|
+
onBeforeConnect?: (client: MCPClientBase<any>) => Promise<void> | void;
|
|
51
51
|
/** Called after the client successfully connects */
|
|
52
|
-
onAfterConnect?: (client:
|
|
52
|
+
onAfterConnect?: (client: MCPClientBase<any>) => Promise<void> | void;
|
|
53
53
|
/** Called when the client disconnects */
|
|
54
|
-
onDisconnect?: (client:
|
|
54
|
+
onDisconnect?: (client: MCPClientBase<any>) => Promise<void> | void;
|
|
55
55
|
}
|
|
56
56
|
/**
|
|
57
57
|
* Helper type to extract integration IDs from an array of integrations
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/integrations/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/integrations/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAElD;;;;;;;;GAQG;AACH,MAAM,WAAW,WAAW;IAC1B,2DAA2D;IAC3D,QAAQ,EAAE,MAAM,CAAC;IAEjB;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9B;;;OAGG;IACH,YAAY,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAElC,4BAA4B;IAC5B,MAAM,EAAE,MAAM,EAAE,CAAC;IAEjB,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,sCAAsC;IACtC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED;;;;GAIG;AACH,MAAM,WAAW,cAAc;IAC7B,oCAAoC;IACpC,EAAE,EAAE,MAAM,CAAC;IAEX,kDAAkD;IAClD,KAAK,EAAE,MAAM,EAAE,CAAC;IAEhB,+CAA+C;IAC/C,KAAK,CAAC,EAAE,WAAW,CAAC;IAEpB,iEAAiE;IACjE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAE9D,sDAAsD;IACtD,eAAe,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAEvE,oDAAoD;IACpD,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAEtE,yCAAyC;IACzC,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CACrE;AAED;;GAEG;AACH,MAAM,MAAM,qBAAqB,CAAC,CAAC,SAAS,SAAS,cAAc,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC;AAEzF;;GAEG;AACH,MAAM,MAAM,uBAAuB,CAAC,CAAC,SAAS,SAAS,cAAc,EAAE,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC;AAEtG;;GAEG;AACH,wBAAgB,cAAc,CAC5B,WAAW,EAAE,cAAc,GAC1B,WAAW,IAAI,cAAc,GAAG;IAAE,KAAK,EAAE,WAAW,CAAA;CAAE,CAExD"}
|
|
@@ -19,19 +19,19 @@ export declare class OAuthManager {
|
|
|
19
19
|
/**
|
|
20
20
|
* Initiate OAuth authorization flow
|
|
21
21
|
*
|
|
22
|
+
* Note: Scopes are defined server-side in integration configuration, not passed from client.
|
|
23
|
+
*
|
|
22
24
|
* @param provider - OAuth provider (github, gmail, etc.)
|
|
23
|
-
* @param config - OAuth configuration
|
|
25
|
+
* @param config - OAuth configuration (clientId/clientSecret not needed client-side)
|
|
24
26
|
* @param returnUrl - Optional URL to redirect to after OAuth completion
|
|
25
27
|
* @returns Promise that resolves when authorization is complete
|
|
26
28
|
*
|
|
27
29
|
* @example
|
|
28
30
|
* ```typescript
|
|
29
|
-
* // Basic flow
|
|
31
|
+
* // Basic flow - scopes are defined server-side
|
|
30
32
|
* await oauthManager.initiateFlow('github', {
|
|
31
33
|
* provider: 'github',
|
|
32
|
-
*
|
|
33
|
-
* clientSecret: 'secret',
|
|
34
|
-
* scopes: ['repo', 'user']
|
|
34
|
+
* scopes: [], // Ignored client-side - defined in server integration config
|
|
35
35
|
* });
|
|
36
36
|
*
|
|
37
37
|
* // With return URL
|
|
@@ -155,7 +155,7 @@ export declare class OAuthManager {
|
|
|
155
155
|
private cleanupExpiredPendingAuths;
|
|
156
156
|
/**
|
|
157
157
|
* Request authorization URL from user's API route
|
|
158
|
-
* The API route will add OAuth secrets and forward to MCP server
|
|
158
|
+
* The API route will add OAuth secrets and scopes from server config and forward to MCP server
|
|
159
159
|
*/
|
|
160
160
|
private getAuthorizationUrl;
|
|
161
161
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../../src/oauth/manager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,KAAK,EACV,eAAe,EAEf,UAAU,EAGV,iBAAiB,EAClB,MAAM,YAAY,CAAC;AAIpB;;;GAGG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,YAAY,CAAuC;IAC3D,OAAO,CAAC,cAAc,CAA6C;IACnE,OAAO,CAAC,aAAa,CAAqB;IAC1C,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,UAAU,CAAC,CAAS;gBAG1B,YAAY,EAAE,MAAM,EACpB,UAAU,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,EACrC,UAAU,CAAC,EAAE,MAAM;IAerB;;;;;;;;;;;;;;;;;;;;;OAqBG;IACG,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../../src/oauth/manager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,KAAK,EACV,eAAe,EAEf,UAAU,EAGV,iBAAiB,EAClB,MAAM,YAAY,CAAC;AAIpB;;;GAGG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,YAAY,CAAuC;IAC3D,OAAO,CAAC,cAAc,CAA6C;IACnE,OAAO,CAAC,aAAa,CAAqB;IAC1C,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,UAAU,CAAC,CAAS;gBAG1B,YAAY,EAAE,MAAM,EACpB,UAAU,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,EACrC,UAAU,CAAC,EAAE,MAAM;IAerB;;;;;;;;;;;;;;;;;;;;;OAqBG;IACG,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA8C5F;;;;;;;;;;;;;;OAcG;IACG,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,GAAG;QAAE,QAAQ,EAAE,MAAM,CAAA;KAAE,CAAC;IAkEpG;;;;;;;;;;;;;;;;;OAiBG;IACG,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAoB5D;;;;;;;;;;;;;;;;OAgBG;IACG,kBAAkB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAYzD;;OAEG;IACH,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,iBAAiB,GAAG,SAAS;IAIjE;;OAEG;IACH,oBAAoB,IAAI,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC;IAItD;;OAEG;IACH,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,iBAAiB,GAAG,IAAI;IAKtE;;OAEG;IACH,kBAAkB,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAW1C;;OAEG;IACH,sBAAsB,IAAI,IAAI;IAe9B;;;OAGG;IACH,oBAAoB,IAAI,IAAI;IAwB5B;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAWzB;;;OAGG;IACH,OAAO,CAAC,iBAAiB;IAezB;;OAEG;IACH,qBAAqB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI;IAShD;;;;;OAKG;IACH,OAAO,CAAC,wBAAwB;IAWhC;;;OAGG;IACH,OAAO,CAAC,0BAA0B;IAelC;;OAEG;IACH,OAAO,CAAC,4BAA4B;IAWpC;;;OAGG;IACH,OAAO,CAAC,0BAA0B;IAoClC;;;OAGG;YACW,mBAAmB;IAoCjC;;;OAGG;YACW,oBAAoB;IAkClC;;OAEG;IACH,KAAK,IAAI,IAAI;CAGd"}
|
|
@@ -38,6 +38,8 @@ export interface AuthStatus {
|
|
|
38
38
|
/**
|
|
39
39
|
* Pending OAuth authorization
|
|
40
40
|
* Tracks in-progress OAuth flows
|
|
41
|
+
*
|
|
42
|
+
* Note: Scopes are NOT stored client-side - they're defined server-side in integration config
|
|
41
43
|
*/
|
|
42
44
|
export interface PendingAuth {
|
|
43
45
|
/** OAuth provider (github, gmail, etc.) */
|
|
@@ -48,8 +50,6 @@ export interface PendingAuth {
|
|
|
48
50
|
codeVerifier: string;
|
|
49
51
|
/** PKCE code challenge */
|
|
50
52
|
codeChallenge: string;
|
|
51
|
-
/** OAuth scopes being requested */
|
|
52
|
-
scopes: string[];
|
|
53
53
|
/** Redirect URI */
|
|
54
54
|
redirectUri?: string;
|
|
55
55
|
/** Return URL - where to redirect after OAuth completion */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/oauth/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,4CAA4C;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,6CAA6C;IAC7C,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,yCAAyC;IACzC,IAAI,EAAE,OAAO,GAAG,UAAU,CAAC;IAC3B,oDAAoD;IACpD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,sDAAsD;IACtD,cAAc,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CACnF;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,yCAAyC;IACzC,UAAU,EAAE,OAAO,CAAC;IACpB,wBAAwB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,wBAAwB;IACxB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,4BAA4B;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/oauth/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,4CAA4C;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,6CAA6C;IAC7C,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,yCAAyC;IACzC,IAAI,EAAE,OAAO,GAAG,UAAU,CAAC;IAC3B,oDAAoD;IACpD,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,sDAAsD;IACtD,cAAc,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CACnF;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,yCAAyC;IACzC,UAAU,EAAE,OAAO,CAAC;IACpB,wBAAwB;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,wBAAwB;IACxB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,4BAA4B;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;;;;GAKG;AACH,MAAM,WAAW,WAAW;IAC1B,2CAA2C;IAC3C,QAAQ,EAAE,MAAM,CAAC;IACjB,4BAA4B;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,yBAAyB;IACzB,YAAY,EAAE,MAAM,CAAC;IACrB,0BAA0B;IAC1B,aAAa,EAAE,MAAM,CAAC;IACtB,mBAAmB;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,4DAA4D;IAC5D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,wCAAwC;IACxC,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,wBAAwB;IACvC,qDAAqD;IACrD,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED;;;GAGG;AACH,MAAM,WAAW,qBAAqB;IACpC,yBAAyB;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,0BAA0B;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,oCAAoC;IACpC,SAAS,EAAE,MAAM,CAAC;IAClB,uCAAuC;IACvC,SAAS,EAAE,MAAM,CAAC;IAClB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,yBAAyB;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,0BAA0B;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,oCAAoC;IACpC,SAAS,EAAE,MAAM,CAAC;IAClB,uCAAuC;IACvC,SAAS,EAAE,MAAM,CAAC;IAClB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,6CAA6C;IAC7C,IAAI,EAAE,MAAM,CAAC;IACb,0CAA0C;IAC1C,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,gCAAgC;IAChC,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,mCAAmC;IACnC,QAAQ,EAAE,MAAM,CAAC;IACjB,8CAA8C;IAC9C,WAAW,EAAE,MAAM,CAAC;IACpB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,yCAAyC;IACzC,QAAQ,EAAE,MAAM,CAAC;IACjB,0BAA0B;IAC1B,KAAK,EAAE,KAAK,CAAC;CACd;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;CAE/B;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,qCAAqC;IACrC,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,cAAc,GAAG,eAAe,GAAG,YAAY,GAAG,aAAa,GAAG,iBAAiB,CAAC;AAEjH;;GAEG;AACH,MAAM,MAAM,iBAAiB,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,IAAI,CAAC"}
|
package/dist/src/server.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server.ts"],"names":[],"mappings":"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"}
|