@inkeep/agents-core 0.1.4 → 0.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/SUPPLEMENTAL_TERMS.md +40 -0
- package/dist/chunk-BMKWVKI2.js +126 -0
- package/dist/chunk-H2F72PDA.js +15 -0
- package/dist/chunk-MKBO26DX.js +9 -0
- package/dist/chunk-MXQKLGQK.js +925 -0
- package/dist/chunk-R3VVJXX7.js +575 -0
- package/dist/chunk-SVGQSPW4.js +24 -0
- package/dist/client-exports.cjs +1702 -0
- package/dist/client-exports.js +202 -246
- package/dist/db/schema.cjs +922 -0
- package/dist/db/schema.js +1 -696
- package/dist/index.cjs +10122 -0
- package/dist/index.js +7989 -13
- package/dist/types/index.cjs +45 -0
- package/dist/types/index.js +2 -6
- package/dist/validation/index.cjs +1772 -0
- package/dist/validation/index.js +2 -5
- package/package.json +11 -6
- package/dist/__tests__/integration/helpers.d.ts +0 -5
- package/dist/__tests__/integration/helpers.d.ts.map +0 -1
- package/dist/__tests__/integration/helpers.js +0 -37
- package/dist/__tests__/integration/helpers.js.map +0 -1
- package/dist/__tests__/setup.d.ts +0 -3
- package/dist/__tests__/setup.d.ts.map +0 -1
- package/dist/__tests__/setup.js +0 -29
- package/dist/__tests__/setup.js.map +0 -1
- package/dist/client-exports.d.ts +0 -300
- package/dist/client-exports.d.ts.map +0 -1
- package/dist/client-exports.js.map +0 -1
- package/dist/context/ContextConfig.d.ts +0 -54
- package/dist/context/ContextConfig.d.ts.map +0 -1
- package/dist/context/ContextConfig.js +0 -302
- package/dist/context/ContextConfig.js.map +0 -1
- package/dist/context/ContextFetcher.d.ts +0 -64
- package/dist/context/ContextFetcher.d.ts.map +0 -1
- package/dist/context/ContextFetcher.js +0 -325
- package/dist/context/ContextFetcher.js.map +0 -1
- package/dist/context/ContextResolver.d.ts +0 -52
- package/dist/context/ContextResolver.d.ts.map +0 -1
- package/dist/context/ContextResolver.js +0 -298
- package/dist/context/ContextResolver.js.map +0 -1
- package/dist/context/TemplateEngine.d.ts +0 -46
- package/dist/context/TemplateEngine.d.ts.map +0 -1
- package/dist/context/TemplateEngine.js +0 -175
- package/dist/context/TemplateEngine.js.map +0 -1
- package/dist/context/context.d.ts +0 -8
- package/dist/context/context.d.ts.map +0 -1
- package/dist/context/context.js +0 -157
- package/dist/context/context.js.map +0 -1
- package/dist/context/contextCache.d.ts +0 -50
- package/dist/context/contextCache.d.ts.map +0 -1
- package/dist/context/contextCache.js +0 -175
- package/dist/context/contextCache.js.map +0 -1
- package/dist/context/index.d.ts +0 -11
- package/dist/context/index.d.ts.map +0 -1
- package/dist/context/index.js +0 -8
- package/dist/context/index.js.map +0 -1
- package/dist/credential-stores/CredentialStoreRegistry.d.ts +0 -39
- package/dist/credential-stores/CredentialStoreRegistry.d.ts.map +0 -1
- package/dist/credential-stores/CredentialStoreRegistry.js +0 -65
- package/dist/credential-stores/CredentialStoreRegistry.js.map +0 -1
- package/dist/credential-stores/defaults.d.ts +0 -6
- package/dist/credential-stores/defaults.d.ts.map +0 -1
- package/dist/credential-stores/defaults.js +0 -22
- package/dist/credential-stores/defaults.js.map +0 -1
- package/dist/credential-stores/index.d.ts +0 -6
- package/dist/credential-stores/index.d.ts.map +0 -1
- package/dist/credential-stores/index.js +0 -6
- package/dist/credential-stores/index.js.map +0 -1
- package/dist/credential-stores/keychain-store.d.ts +0 -100
- package/dist/credential-stores/keychain-store.d.ts.map +0 -1
- package/dist/credential-stores/keychain-store.js +0 -225
- package/dist/credential-stores/keychain-store.js.map +0 -1
- package/dist/credential-stores/memory-store.d.ts +0 -39
- package/dist/credential-stores/memory-store.d.ts.map +0 -1
- package/dist/credential-stores/memory-store.js +0 -58
- package/dist/credential-stores/memory-store.js.map +0 -1
- package/dist/credential-stores/nango-store.d.ts +0 -59
- package/dist/credential-stores/nango-store.d.ts.map +0 -1
- package/dist/credential-stores/nango-store.js +0 -264
- package/dist/credential-stores/nango-store.js.map +0 -1
- package/dist/credential-stuffer/CredentialStuffer.d.ts +0 -80
- package/dist/credential-stuffer/CredentialStuffer.d.ts.map +0 -1
- package/dist/credential-stuffer/CredentialStuffer.js +0 -186
- package/dist/credential-stuffer/CredentialStuffer.js.map +0 -1
- package/dist/credential-stuffer/index.d.ts +0 -2
- package/dist/credential-stuffer/index.d.ts.map +0 -1
- package/dist/credential-stuffer/index.js +0 -2
- package/dist/credential-stuffer/index.js.map +0 -1
- package/dist/data-access/agentDataComponents.d.ts +0 -1
- package/dist/data-access/agentDataComponents.d.ts.map +0 -1
- package/dist/data-access/agentDataComponents.js +0 -2
- package/dist/data-access/agentDataComponents.js.map +0 -1
- package/dist/data-access/agentGraphs.d.ts +0 -406
- package/dist/data-access/agentGraphs.d.ts.map +0 -1
- package/dist/data-access/agentGraphs.js +0 -551
- package/dist/data-access/agentGraphs.js.map +0 -1
- package/dist/data-access/agentRelations.d.ts +0 -456
- package/dist/data-access/agentRelations.d.ts.map +0 -1
- package/dist/data-access/agentRelations.js +0 -471
- package/dist/data-access/agentRelations.js.map +0 -1
- package/dist/data-access/agents.d.ts +0 -218
- package/dist/data-access/agents.d.ts.map +0 -1
- package/dist/data-access/agents.js +0 -130
- package/dist/data-access/agents.js.map +0 -1
- package/dist/data-access/apiKeys.d.ts +0 -114
- package/dist/data-access/apiKeys.d.ts.map +0 -1
- package/dist/data-access/apiKeys.js +0 -185
- package/dist/data-access/apiKeys.js.map +0 -1
- package/dist/data-access/artifactComponents.d.ts +0 -152
- package/dist/data-access/artifactComponents.d.ts.map +0 -1
- package/dist/data-access/artifactComponents.js +0 -214
- package/dist/data-access/artifactComponents.js.map +0 -1
- package/dist/data-access/contextCache.d.ts +0 -68
- package/dist/data-access/contextCache.d.ts.map +0 -1
- package/dist/data-access/contextCache.js +0 -160
- package/dist/data-access/contextCache.js.map +0 -1
- package/dist/data-access/contextConfigs.d.ts +0 -110
- package/dist/data-access/contextConfigs.d.ts.map +0 -1
- package/dist/data-access/contextConfigs.js +0 -156
- package/dist/data-access/contextConfigs.js.map +0 -1
- package/dist/data-access/conversations.d.ts +0 -125
- package/dist/data-access/conversations.d.ts.map +0 -1
- package/dist/data-access/conversations.js +0 -244
- package/dist/data-access/conversations.js.map +0 -1
- package/dist/data-access/credentialReferences.d.ts +0 -86
- package/dist/data-access/credentialReferences.d.ts.map +0 -1
- package/dist/data-access/credentialReferences.js +0 -175
- package/dist/data-access/credentialReferences.js.map +0 -1
- package/dist/data-access/dataComponents.d.ts +0 -129
- package/dist/data-access/dataComponents.d.ts.map +0 -1
- package/dist/data-access/dataComponents.js +0 -213
- package/dist/data-access/dataComponents.js.map +0 -1
- package/dist/data-access/externalAgents.d.ts +0 -83
- package/dist/data-access/externalAgents.d.ts.map +0 -1
- package/dist/data-access/externalAgents.js +0 -163
- package/dist/data-access/externalAgents.js.map +0 -1
- package/dist/data-access/graphFull.d.ts +0 -32
- package/dist/data-access/graphFull.d.ts.map +0 -1
- package/dist/data-access/graphFull.js +0 -996
- package/dist/data-access/graphFull.js.map +0 -1
- package/dist/data-access/index.d.ts +0 -21
- package/dist/data-access/index.d.ts.map +0 -1
- package/dist/data-access/index.js +0 -22
- package/dist/data-access/index.js.map +0 -1
- package/dist/data-access/ledgerArtifacts.d.ts +0 -49
- package/dist/data-access/ledgerArtifacts.d.ts.map +0 -1
- package/dist/data-access/ledgerArtifacts.js +0 -112
- package/dist/data-access/ledgerArtifacts.js.map +0 -1
- package/dist/data-access/messages.d.ts +0 -209
- package/dist/data-access/messages.d.ts.map +0 -1
- package/dist/data-access/messages.js +0 -100
- package/dist/data-access/messages.js.map +0 -1
- package/dist/data-access/projects.d.ts +0 -67
- package/dist/data-access/projects.d.ts.map +0 -1
- package/dist/data-access/projects.js +0 -337
- package/dist/data-access/projects.js.map +0 -1
- package/dist/data-access/tasks.d.ts +0 -37
- package/dist/data-access/tasks.d.ts.map +0 -1
- package/dist/data-access/tasks.js +0 -40
- package/dist/data-access/tasks.js.map +0 -1
- package/dist/data-access/tools.d.ts +0 -277
- package/dist/data-access/tools.d.ts.map +0 -1
- package/dist/data-access/tools.js +0 -183
- package/dist/data-access/tools.js.map +0 -1
- package/dist/data-access/validation.d.ts +0 -17
- package/dist/data-access/validation.d.ts.map +0 -1
- package/dist/data-access/validation.js +0 -52
- package/dist/data-access/validation.js.map +0 -1
- package/dist/db/clean.d.ts +0 -6
- package/dist/db/clean.d.ts.map +0 -1
- package/dist/db/clean.js +0 -81
- package/dist/db/clean.js.map +0 -1
- package/dist/db/client.d.ts +0 -19
- package/dist/db/client.d.ts.map +0 -1
- package/dist/db/client.js +0 -24
- package/dist/db/client.js.map +0 -1
- package/dist/db/schema.d.ts +0 -4337
- package/dist/db/schema.d.ts.map +0 -1
- package/dist/db/schema.js.map +0 -1
- package/dist/db/test-client.d.ts +0 -25
- package/dist/db/test-client.d.ts.map +0 -1
- package/dist/db/test-client.js +0 -136
- package/dist/db/test-client.js.map +0 -1
- package/dist/env.d.ts +0 -19
- package/dist/env.d.ts.map +0 -1
- package/dist/env.js +0 -49
- package/dist/env.js.map +0 -1
- package/dist/index.d.ts +0 -12
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/middleware/contextValidation.d.ts +0 -49
- package/dist/middleware/contextValidation.d.ts.map +0 -1
- package/dist/middleware/contextValidation.js +0 -473
- package/dist/middleware/contextValidation.js.map +0 -1
- package/dist/middleware/index.d.ts +0 -2
- package/dist/middleware/index.d.ts.map +0 -1
- package/dist/middleware/index.js +0 -2
- package/dist/middleware/index.js.map +0 -1
- package/dist/server/BaseServer.d.ts +0 -83
- package/dist/server/BaseServer.d.ts.map +0 -1
- package/dist/server/BaseServer.js +0 -218
- package/dist/server/BaseServer.js.map +0 -1
- package/dist/types/a2a.d.ts +0 -373
- package/dist/types/a2a.d.ts.map +0 -1
- package/dist/types/a2a.js +0 -14
- package/dist/types/a2a.js.map +0 -1
- package/dist/types/entities.d.ts +0 -147
- package/dist/types/entities.d.ts.map +0 -1
- package/dist/types/entities.js +0 -2
- package/dist/types/entities.js.map +0 -1
- package/dist/types/index.d.ts +0 -5
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js.map +0 -1
- package/dist/types/server.d.ts +0 -116
- package/dist/types/server.d.ts.map +0 -1
- package/dist/types/server.js +0 -2
- package/dist/types/server.js.map +0 -1
- package/dist/types/utility.d.ts +0 -213
- package/dist/types/utility.d.ts.map +0 -1
- package/dist/types/utility.js +0 -9
- package/dist/types/utility.js.map +0 -1
- package/dist/utils/apiKeys.d.ts +0 -32
- package/dist/utils/apiKeys.d.ts.map +0 -1
- package/dist/utils/apiKeys.js +0 -117
- package/dist/utils/apiKeys.js.map +0 -1
- package/dist/utils/auth-detection.d.ts +0 -23
- package/dist/utils/auth-detection.d.ts.map +0 -1
- package/dist/utils/auth-detection.js +0 -148
- package/dist/utils/auth-detection.js.map +0 -1
- package/dist/utils/credential-store-utils.d.ts +0 -11
- package/dist/utils/credential-store-utils.d.ts.map +0 -1
- package/dist/utils/credential-store-utils.js +0 -19
- package/dist/utils/credential-store-utils.js.map +0 -1
- package/dist/utils/error.d.ts +0 -526
- package/dist/utils/error.d.ts.map +0 -1
- package/dist/utils/error.js +0 -282
- package/dist/utils/error.js.map +0 -1
- package/dist/utils/execution.d.ts +0 -18
- package/dist/utils/execution.d.ts.map +0 -1
- package/dist/utils/execution.js +0 -25
- package/dist/utils/execution.js.map +0 -1
- package/dist/utils/index.d.ts +0 -9
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js +0 -9
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/logger.d.ts +0 -79
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js +0 -102
- package/dist/utils/logger.js.map +0 -1
- package/dist/utils/logging.d.ts +0 -11
- package/dist/utils/logging.d.ts.map +0 -1
- package/dist/utils/logging.js +0 -6
- package/dist/utils/logging.js.map +0 -1
- package/dist/utils/mcp-client.d.ts +0 -48
- package/dist/utils/mcp-client.d.ts.map +0 -1
- package/dist/utils/mcp-client.js +0 -174
- package/dist/utils/mcp-client.js.map +0 -1
- package/dist/utils/tracer.d.ts +0 -24
- package/dist/utils/tracer.d.ts.map +0 -1
- package/dist/utils/tracer.js +0 -110
- package/dist/utils/tracer.js.map +0 -1
- package/dist/validation/graphFull.d.ts +0 -36
- package/dist/validation/graphFull.d.ts.map +0 -1
- package/dist/validation/graphFull.js +0 -128
- package/dist/validation/graphFull.js.map +0 -1
- package/dist/validation/id-validation.d.ts +0 -38
- package/dist/validation/id-validation.d.ts.map +0 -1
- package/dist/validation/id-validation.js +0 -60
- package/dist/validation/id-validation.js.map +0 -1
- package/dist/validation/index.d.ts +0 -4
- package/dist/validation/index.d.ts.map +0 -1
- package/dist/validation/index.js.map +0 -1
- package/dist/validation/schemas.d.ts +0 -7238
- package/dist/validation/schemas.d.ts.map +0 -1
- package/dist/validation/schemas.js +0 -575
- package/dist/validation/schemas.js.map +0 -1
package/dist/utils/apiKeys.js
DELETED
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import { randomBytes, scrypt, timingSafeEqual } from 'node:crypto';
|
|
2
|
-
import { promisify } from 'node:util';
|
|
3
|
-
import { customAlphabet, nanoid } from 'nanoid';
|
|
4
|
-
import { getLogger } from './logger';
|
|
5
|
-
const scryptAsync = promisify(scrypt);
|
|
6
|
-
const logger = getLogger('api-key');
|
|
7
|
-
// API key configuration
|
|
8
|
-
const API_KEY_LENGTH = 32; // Length of random bytes
|
|
9
|
-
const SALT_LENGTH = 32; // Length of salt for hashing
|
|
10
|
-
const KEY_LENGTH = 64; // Length of derived key from scrypt
|
|
11
|
-
const PUBLIC_ID_LENGTH = 12;
|
|
12
|
-
// Custom alphabet excluding underscores and dots
|
|
13
|
-
const PUBLIC_ID_ALPHABET = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-';
|
|
14
|
-
const generatePublicId = customAlphabet(PUBLIC_ID_ALPHABET, PUBLIC_ID_LENGTH);
|
|
15
|
-
/**
|
|
16
|
-
* Generate a new API key with secure random bytes
|
|
17
|
-
*/
|
|
18
|
-
export async function generateApiKey() {
|
|
19
|
-
const publicId = generatePublicId();
|
|
20
|
-
// Generate secret part (random bytes)
|
|
21
|
-
const secretBytes = randomBytes(API_KEY_LENGTH);
|
|
22
|
-
const secret = secretBytes.toString('base64url');
|
|
23
|
-
// Create key in format: sk_<env>_<publicId>.<secret>
|
|
24
|
-
const key = `sk_${publicId}.${secret}`;
|
|
25
|
-
// Extract prefix for identification (first 12 chars)
|
|
26
|
-
const keyPrefix = key.substring(0, 12);
|
|
27
|
-
// Hash the entire key for storage
|
|
28
|
-
const keyHash = await hashApiKey(key);
|
|
29
|
-
// Generate unique ID for database record
|
|
30
|
-
const id = nanoid();
|
|
31
|
-
return {
|
|
32
|
-
id,
|
|
33
|
-
publicId,
|
|
34
|
-
key,
|
|
35
|
-
keyHash,
|
|
36
|
-
keyPrefix,
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Hash an API key using scrypt
|
|
41
|
-
*/
|
|
42
|
-
export async function hashApiKey(key) {
|
|
43
|
-
// Generate a random salt
|
|
44
|
-
const salt = randomBytes(SALT_LENGTH);
|
|
45
|
-
// Hash the key with scrypt
|
|
46
|
-
const hashedBuffer = (await scryptAsync(key, salt, KEY_LENGTH));
|
|
47
|
-
// Combine salt and hash for storage
|
|
48
|
-
const combined = Buffer.concat([salt, hashedBuffer]);
|
|
49
|
-
// Return as base64 string
|
|
50
|
-
return combined.toString('base64');
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Validate an API key against its hash
|
|
54
|
-
*/
|
|
55
|
-
export async function validateApiKey(key, storedHash) {
|
|
56
|
-
try {
|
|
57
|
-
// Decode the stored hash
|
|
58
|
-
const combined = Buffer.from(storedHash, 'base64');
|
|
59
|
-
// Extract salt and hash
|
|
60
|
-
const salt = combined.subarray(0, SALT_LENGTH);
|
|
61
|
-
const storedHashBuffer = combined.subarray(SALT_LENGTH);
|
|
62
|
-
// Hash the provided key with the same salt
|
|
63
|
-
const hashedBuffer = (await scryptAsync(key, salt, KEY_LENGTH));
|
|
64
|
-
// Use timing-safe comparison to prevent timing attacks
|
|
65
|
-
return timingSafeEqual(storedHashBuffer, hashedBuffer);
|
|
66
|
-
}
|
|
67
|
-
catch (error) {
|
|
68
|
-
logger.error({ error }, 'Error validating API key');
|
|
69
|
-
// Return false for any errors (invalid format, etc.)
|
|
70
|
-
return false;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Check if an API key has expired
|
|
75
|
-
*/
|
|
76
|
-
export function isApiKeyExpired(expiresAt) {
|
|
77
|
-
if (!expiresAt) {
|
|
78
|
-
return false; // No expiration set
|
|
79
|
-
}
|
|
80
|
-
const expirationDate = new Date(expiresAt);
|
|
81
|
-
const now = new Date();
|
|
82
|
-
return now > expirationDate;
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Extract the publicId from an API key
|
|
86
|
-
*/
|
|
87
|
-
export function extractPublicId(key) {
|
|
88
|
-
try {
|
|
89
|
-
// Expected format: sk_<env>_<publicId>.<secret> or sk_<publicId>.<secret>
|
|
90
|
-
const parts = key.split('.');
|
|
91
|
-
if (parts.length !== 2) {
|
|
92
|
-
return null;
|
|
93
|
-
}
|
|
94
|
-
const prefixPart = parts[0]; // e.g., "sk_test_abc123def456" or "sk_abc123def456"
|
|
95
|
-
const segments = prefixPart.split('_');
|
|
96
|
-
if (segments.length < 2) {
|
|
97
|
-
return null;
|
|
98
|
-
}
|
|
99
|
-
// Get the last segment which should be the publicId
|
|
100
|
-
const publicId = segments[segments.length - 1];
|
|
101
|
-
// Validate publicId length (should be 12 chars)
|
|
102
|
-
if (publicId.length !== 12) {
|
|
103
|
-
return null;
|
|
104
|
-
}
|
|
105
|
-
return publicId;
|
|
106
|
-
}
|
|
107
|
-
catch {
|
|
108
|
-
return null;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
/**
|
|
112
|
-
* Mask an API key for display (show only prefix and last 4 chars)
|
|
113
|
-
*/
|
|
114
|
-
export function maskApiKey(keyPrefix) {
|
|
115
|
-
return `${keyPrefix}...`;
|
|
116
|
-
}
|
|
117
|
-
//# sourceMappingURL=apiKeys.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"apiKeys.js","sourceRoot":"","sources":["../../src/utils/apiKeys.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Centralized authentication detection utilities for MCP tools
|
|
3
|
-
*/
|
|
4
|
-
import type { McpTool } from '../types/entities';
|
|
5
|
-
import type { Logger } from './logging';
|
|
6
|
-
/**
|
|
7
|
-
* OAuth configuration interface
|
|
8
|
-
*/
|
|
9
|
-
export interface OAuthConfig {
|
|
10
|
-
authorizationUrl: string;
|
|
11
|
-
tokenUrl: string;
|
|
12
|
-
registrationUrl?: string;
|
|
13
|
-
supportsDynamicRegistration: boolean;
|
|
14
|
-
}
|
|
15
|
-
/**
|
|
16
|
-
* Full OAuth endpoint discovery with complete configuration
|
|
17
|
-
*/
|
|
18
|
-
export declare const discoverOAuthEndpoints: (serverUrl: string, logger?: Logger) => Promise<OAuthConfig | null>;
|
|
19
|
-
/**
|
|
20
|
-
* Detect if OAuth 2.1/PKCE authentication is specifically required for a tool
|
|
21
|
-
*/
|
|
22
|
-
export declare const detectAuthenticationRequired: (tool: McpTool, error: Error, logger?: Logger) => Promise<boolean>;
|
|
23
|
-
//# sourceMappingURL=auth-detection.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-detection.d.ts","sourceRoot":"","sources":["../../src/utils/auth-detection.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AAExC;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,gBAAgB,EAAE,MAAM,CAAC;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,2BAA2B,EAAE,OAAO,CAAC;CACtC;AA6DD;;GAEG;AACH,eAAO,MAAM,sBAAsB,GACjC,WAAW,MAAM,EACjB,SAAS,MAAM,KACd,OAAO,CAAC,WAAW,GAAG,IAAI,CAkC5B,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,4BAA4B,GACvC,MAAM,OAAO,EACb,OAAO,KAAK,EACZ,SAAS,MAAM,KACd,OAAO,CAAC,OAAO,CAsEjB,CAAC"}
|
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Centralized authentication detection utilities for MCP tools
|
|
3
|
-
*/
|
|
4
|
-
/**
|
|
5
|
-
* Helper function to construct well-known OAuth endpoint URLs
|
|
6
|
-
*/
|
|
7
|
-
const getWellKnownUrls = (baseUrl) => [
|
|
8
|
-
`${baseUrl}/.well-known/oauth-authorization-server`,
|
|
9
|
-
`${baseUrl}/.well-known/openid-configuration`,
|
|
10
|
-
];
|
|
11
|
-
/**
|
|
12
|
-
* Helper function to validate OAuth metadata for PKCE support
|
|
13
|
-
*/
|
|
14
|
-
const validateOAuthMetadata = (metadata) => {
|
|
15
|
-
return metadata.code_challenge_methods_supported?.includes('S256');
|
|
16
|
-
};
|
|
17
|
-
/**
|
|
18
|
-
* Helper function to construct OAuthConfig from metadata
|
|
19
|
-
*/
|
|
20
|
-
const buildOAuthConfig = (metadata) => ({
|
|
21
|
-
authorizationUrl: metadata.authorization_endpoint,
|
|
22
|
-
tokenUrl: metadata.token_endpoint,
|
|
23
|
-
registrationUrl: metadata.registration_endpoint,
|
|
24
|
-
supportsDynamicRegistration: !!metadata.registration_endpoint,
|
|
25
|
-
});
|
|
26
|
-
/**
|
|
27
|
-
* Helper function to try OAuth discovery at well-known endpoints
|
|
28
|
-
*/
|
|
29
|
-
const tryWellKnownEndpoints = async (baseUrl, logger) => {
|
|
30
|
-
const wellKnownUrls = getWellKnownUrls(baseUrl);
|
|
31
|
-
for (const wellKnownUrl of wellKnownUrls) {
|
|
32
|
-
try {
|
|
33
|
-
const response = await fetch(wellKnownUrl);
|
|
34
|
-
if (response.ok) {
|
|
35
|
-
const metadata = await response.json();
|
|
36
|
-
if (validateOAuthMetadata(metadata)) {
|
|
37
|
-
logger?.debug({ baseUrl, wellKnownUrl }, 'OAuth 2.1/PKCE support detected');
|
|
38
|
-
return buildOAuthConfig(metadata);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
catch (error) {
|
|
43
|
-
logger?.debug({ wellKnownUrl, error }, 'OAuth endpoint check failed');
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
return null;
|
|
47
|
-
};
|
|
48
|
-
/**
|
|
49
|
-
* Check if a server supports OAuth 2.1/PKCE endpoints (simple boolean)
|
|
50
|
-
*/
|
|
51
|
-
const checkForOAuthEndpoints = async (serverUrl, logger) => {
|
|
52
|
-
const config = await discoverOAuthEndpoints(serverUrl, logger);
|
|
53
|
-
return config !== null;
|
|
54
|
-
};
|
|
55
|
-
/**
|
|
56
|
-
* Full OAuth endpoint discovery with complete configuration
|
|
57
|
-
*/
|
|
58
|
-
export const discoverOAuthEndpoints = async (serverUrl, logger) => {
|
|
59
|
-
try {
|
|
60
|
-
// 1. Try direct 401 response first
|
|
61
|
-
const response = await fetch(serverUrl, {
|
|
62
|
-
method: 'POST',
|
|
63
|
-
headers: { 'Content-Type': 'application/json' },
|
|
64
|
-
body: JSON.stringify({}),
|
|
65
|
-
});
|
|
66
|
-
if (response.status === 401) {
|
|
67
|
-
const wwwAuth = response.headers.get('WWW-Authenticate');
|
|
68
|
-
if (wwwAuth) {
|
|
69
|
-
// Parse Protected Resource Metadata URL from WWW-Authenticate header
|
|
70
|
-
const metadataMatch = wwwAuth.match(/as_uri="([^"]+)"/);
|
|
71
|
-
if (metadataMatch) {
|
|
72
|
-
const metadataResponse = await fetch(metadataMatch[1]);
|
|
73
|
-
if (metadataResponse.ok) {
|
|
74
|
-
const metadata = (await metadataResponse.json());
|
|
75
|
-
if (metadata.authorization_servers?.length > 0) {
|
|
76
|
-
return await tryWellKnownEndpoints(metadata.authorization_servers[0], logger);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
catch (_error) {
|
|
84
|
-
// Continue to well-known endpoints
|
|
85
|
-
}
|
|
86
|
-
// 2. Try well-known endpoints
|
|
87
|
-
const url = new URL(serverUrl);
|
|
88
|
-
const baseUrl = `${url.protocol}//${url.host}`;
|
|
89
|
-
return await tryWellKnownEndpoints(baseUrl, logger);
|
|
90
|
-
};
|
|
91
|
-
/**
|
|
92
|
-
* Detect if OAuth 2.1/PKCE authentication is specifically required for a tool
|
|
93
|
-
*/
|
|
94
|
-
export const detectAuthenticationRequired = async (tool, error, logger) => {
|
|
95
|
-
const serverUrl = tool.config.mcp.server.url;
|
|
96
|
-
// 1. First, try OAuth 2.1/PKCE endpoint discovery (most reliable for our use case)
|
|
97
|
-
let hasOAuthEndpoints = false;
|
|
98
|
-
try {
|
|
99
|
-
hasOAuthEndpoints = await checkForOAuthEndpoints(serverUrl);
|
|
100
|
-
if (hasOAuthEndpoints) {
|
|
101
|
-
logger?.info({ toolId: tool.id, serverUrl }, 'OAuth 2.1/PKCE support confirmed via endpoint discovery');
|
|
102
|
-
return true; // Server supports OAuth 2.1/PKCE, prioritize this
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
catch (discoveryError) {
|
|
106
|
-
logger?.debug({ toolId: tool.id, discoveryError }, 'OAuth endpoint discovery failed');
|
|
107
|
-
}
|
|
108
|
-
// 2. Check for 401 with OAuth-specific WWW-Authenticate header
|
|
109
|
-
try {
|
|
110
|
-
const response = await fetch(serverUrl, {
|
|
111
|
-
method: 'POST',
|
|
112
|
-
headers: { 'Content-Type': 'application/json' },
|
|
113
|
-
body: JSON.stringify({
|
|
114
|
-
jsonrpc: '2.0',
|
|
115
|
-
method: 'initialize',
|
|
116
|
-
id: 1,
|
|
117
|
-
params: { protocolVersion: '2024-11-05', capabilities: {} },
|
|
118
|
-
}),
|
|
119
|
-
});
|
|
120
|
-
// Check for 401 with OAuth-specific WWW-Authenticate header
|
|
121
|
-
if (response.status === 401) {
|
|
122
|
-
const wwwAuth = response.headers.get('WWW-Authenticate');
|
|
123
|
-
// Only return true for OAuth-specific auth schemes (not Basic, API Key, etc.)
|
|
124
|
-
if (wwwAuth &&
|
|
125
|
-
(wwwAuth.toLowerCase().includes('bearer') ||
|
|
126
|
-
wwwAuth.toLowerCase().includes('oauth') ||
|
|
127
|
-
wwwAuth.toLowerCase().includes('authorization_uri'))) {
|
|
128
|
-
logger?.info({ toolId: tool.id, wwwAuth }, 'OAuth authentication detected via WWW-Authenticate header');
|
|
129
|
-
return true;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
catch (fetchError) {
|
|
134
|
-
logger?.debug({ toolId: tool.id, fetchError }, 'Direct fetch authentication check failed');
|
|
135
|
-
}
|
|
136
|
-
// 3. Check if 401 error message AND OAuth endpoints exist together
|
|
137
|
-
if (error.message.includes('401') || error.message.toLowerCase().includes('unauthorized')) {
|
|
138
|
-
if (hasOAuthEndpoints) {
|
|
139
|
-
logger?.info({ toolId: tool.id, error: error.message }, 'OAuth required: 401 error + OAuth endpoints detected');
|
|
140
|
-
return true; // Only return true if BOTH 401 AND OAuth endpoints exist
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
// If none of the OAuth-specific checks pass, return false
|
|
144
|
-
// (This means we won't trigger OAuth flow for Basic Auth, API keys, etc.)
|
|
145
|
-
logger?.debug({ toolId: tool.id, error: error.message }, 'No OAuth authentication requirement detected');
|
|
146
|
-
return false;
|
|
147
|
-
};
|
|
148
|
-
//# sourceMappingURL=auth-detection.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-detection.js","sourceRoot":"","sources":["../../src/utils/auth-detection.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Get a lookup key for a credential store from retrieval params
|
|
3
|
-
* @param retrievalParams - The retrieval params for the credential store
|
|
4
|
-
* @param credentialStoreType - The type of credential store
|
|
5
|
-
* @returns A lookup key for the credential store, used to call <CredentialStore>.get()
|
|
6
|
-
*/
|
|
7
|
-
export declare function getCredentialStoreLookupKeyFromRetrievalParams({ retrievalParams, credentialStoreType, }: {
|
|
8
|
-
retrievalParams: Record<string, unknown>;
|
|
9
|
-
credentialStoreType: string;
|
|
10
|
-
}): string | null;
|
|
11
|
-
//# sourceMappingURL=credential-store-utils.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"credential-store-utils.d.ts","sourceRoot":"","sources":["../../src/utils/credential-store-utils.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,wBAAgB,8CAA8C,CAAC,EAC7D,eAAe,EACf,mBAAmB,GACpB,EAAE;IACD,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACzC,mBAAmB,EAAE,MAAM,CAAC;CAC7B,GAAG,MAAM,GAAG,IAAI,CAahB"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Get a lookup key for a credential store from retrieval params
|
|
3
|
-
* @param retrievalParams - The retrieval params for the credential store
|
|
4
|
-
* @param credentialStoreType - The type of credential store
|
|
5
|
-
* @returns A lookup key for the credential store, used to call <CredentialStore>.get()
|
|
6
|
-
*/
|
|
7
|
-
export function getCredentialStoreLookupKeyFromRetrievalParams({ retrievalParams, credentialStoreType, }) {
|
|
8
|
-
if (retrievalParams.key) {
|
|
9
|
-
return retrievalParams.key;
|
|
10
|
-
}
|
|
11
|
-
if (credentialStoreType === 'nango') {
|
|
12
|
-
return JSON.stringify({
|
|
13
|
-
connectionId: retrievalParams.connectionId,
|
|
14
|
-
providerConfigKey: retrievalParams.providerConfigKey,
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
return null;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=credential-store-utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"credential-store-utils.js","sourceRoot":"","sources":["../../src/utils/credential-store-utils.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AACH,MAAM,UAAU,8CAA8C,CAAC,EAC7D,eAAe,EACf,mBAAmB,GAIpB;IACC,IAAI,eAAe,CAAC,GAAG,EAAE,CAAC;QACxB,OAAO,eAAe,CAAC,GAAa,CAAC;IACvC,CAAC;IAED,IAAI,mBAAmB,KAAK,OAAO,EAAE,CAAC;QACpC,OAAO,IAAI,CAAC,SAAS,CAAC;YACpB,YAAY,EAAE,eAAe,CAAC,YAAY;YAC1C,iBAAiB,EAAE,eAAe,CAAC,iBAAiB;SACrD,CAAC,CAAC;IACL,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC"}
|