@safekeylab/mcp-core 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/client.d.ts +111 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +296 -0
- package/dist/client.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/types.d.ts +288 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +6 -0
- package/dist/types.js.map +1 -0
- package/package.json +35 -0
package/dist/client.d.ts
ADDED
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SafeKeyLab API Client
|
|
3
|
+
* Unified client for all SafeKeyLab API endpoints
|
|
4
|
+
*/
|
|
5
|
+
import type { PIIDetectionResult, PIIRedactionResult, PIIEntityType, RedactionMethod, GuardResult, DetectionMode, ConversationMessage, ConversationAnalysis, SemanticGraphResult, PerturbationResult, CrossModalResult, ThreatFingerprint, ToolMatch, CounterfactualExplanation, FeatureAttribution, FormalGuarantee, AgentAction, AgentValidationResult, RAGContext, RAGFilterResult, IngestionScanResult, ComplianceFramework, ComplianceReport, AuditTrail, ReviewItem, ReviewDecision, UsageStats, SubscriptionInfo } from './types.js';
|
|
6
|
+
export interface ClientConfig {
|
|
7
|
+
apiKey: string;
|
|
8
|
+
baseUrl?: string;
|
|
9
|
+
timeout?: number;
|
|
10
|
+
organizationId?: string;
|
|
11
|
+
}
|
|
12
|
+
export declare class SafeKeyLabClient {
|
|
13
|
+
private apiKey;
|
|
14
|
+
private baseUrl;
|
|
15
|
+
private timeout;
|
|
16
|
+
private organizationId?;
|
|
17
|
+
constructor(config: ClientConfig);
|
|
18
|
+
private request;
|
|
19
|
+
detectPII(text: string, options?: {
|
|
20
|
+
entityTypes?: PIIEntityType[];
|
|
21
|
+
confidenceThreshold?: number;
|
|
22
|
+
}): Promise<PIIDetectionResult>;
|
|
23
|
+
detectPIIBatch(texts: string[], options?: {
|
|
24
|
+
entityTypes?: PIIEntityType[];
|
|
25
|
+
confidenceThreshold?: number;
|
|
26
|
+
}): Promise<PIIDetectionResult[]>;
|
|
27
|
+
detectPIIInFile(content: string, fileType: string, options?: {
|
|
28
|
+
entityTypes?: PIIEntityType[];
|
|
29
|
+
}): Promise<PIIDetectionResult>;
|
|
30
|
+
redactText(text: string, options?: {
|
|
31
|
+
redactionMethod?: RedactionMethod;
|
|
32
|
+
entityTypes?: PIIEntityType[];
|
|
33
|
+
}): Promise<PIIRedactionResult>;
|
|
34
|
+
anonymizeText(text: string, options?: {
|
|
35
|
+
preserveFormat?: boolean;
|
|
36
|
+
}): Promise<PIIRedactionResult>;
|
|
37
|
+
guardPrompt(prompt: string, options?: {
|
|
38
|
+
model?: string;
|
|
39
|
+
mode?: DetectionMode;
|
|
40
|
+
strictMode?: boolean;
|
|
41
|
+
includeExplanation?: boolean;
|
|
42
|
+
includeAttribution?: boolean;
|
|
43
|
+
includeGuarantee?: boolean;
|
|
44
|
+
sessionId?: string;
|
|
45
|
+
userId?: string;
|
|
46
|
+
}): Promise<GuardResult>;
|
|
47
|
+
guardResponse(response: string, options?: {
|
|
48
|
+
originalPrompt?: string;
|
|
49
|
+
detectPII?: boolean;
|
|
50
|
+
detectHarmful?: boolean;
|
|
51
|
+
}): Promise<{
|
|
52
|
+
filtered_response: string;
|
|
53
|
+
pii_found: boolean;
|
|
54
|
+
harmful_found: boolean;
|
|
55
|
+
}>;
|
|
56
|
+
analyzeConversation(messages: ConversationMessage[], options?: {
|
|
57
|
+
strictMode?: boolean;
|
|
58
|
+
detectEscalation?: boolean;
|
|
59
|
+
}): Promise<ConversationAnalysis>;
|
|
60
|
+
analyzeSemanticGraph(prompt: string, depth?: number): Promise<SemanticGraphResult>;
|
|
61
|
+
detectPerturbations(prompt: string, threshold?: number): Promise<PerturbationResult>;
|
|
62
|
+
detectCrossModal(content: string, contentType: string, options?: {
|
|
63
|
+
checkHiddenText?: boolean;
|
|
64
|
+
checkSteganography?: boolean;
|
|
65
|
+
}): Promise<CrossModalResult>;
|
|
66
|
+
fingerprintThreat(prompt: string): Promise<ThreatFingerprint>;
|
|
67
|
+
matchAttackTool(prompt: string): Promise<ToolMatch>;
|
|
68
|
+
explainThreat(prompt: string, detectionId?: string): Promise<CounterfactualExplanation>;
|
|
69
|
+
getAttribution(prompt: string): Promise<FeatureAttribution>;
|
|
70
|
+
getFormalGuarantee(prompt: string, confidence?: number): Promise<FormalGuarantee>;
|
|
71
|
+
provideFeedback(prompt: string, isThreat: boolean, threatType?: string): Promise<{
|
|
72
|
+
status: string;
|
|
73
|
+
feedback_id: string;
|
|
74
|
+
}>;
|
|
75
|
+
getLLMStatistics(days?: number): Promise<UsageStats>;
|
|
76
|
+
validateAgentAction(action: AgentAction): Promise<AgentValidationResult>;
|
|
77
|
+
checkAgentPolicy(action: string, policyId?: string): Promise<AgentValidationResult>;
|
|
78
|
+
filterRAGContext(context: RAGContext, options?: {
|
|
79
|
+
filterPII?: boolean;
|
|
80
|
+
filterSensitive?: boolean;
|
|
81
|
+
}): Promise<RAGFilterResult>;
|
|
82
|
+
scanIngestion(document: string, documentType: string): Promise<IngestionScanResult>;
|
|
83
|
+
generateComplianceReport(framework: ComplianceFramework, days?: number): Promise<ComplianceReport>;
|
|
84
|
+
getAuditTrail(options?: {
|
|
85
|
+
startDate?: string;
|
|
86
|
+
endDate?: string;
|
|
87
|
+
actionType?: string;
|
|
88
|
+
limit?: number;
|
|
89
|
+
}): Promise<AuditTrail>;
|
|
90
|
+
checkComplianceStatus(framework: ComplianceFramework): Promise<{
|
|
91
|
+
compliant: boolean;
|
|
92
|
+
score: number;
|
|
93
|
+
}>;
|
|
94
|
+
getReviewQueue(options?: {
|
|
95
|
+
limit?: number;
|
|
96
|
+
priority?: string;
|
|
97
|
+
}): Promise<ReviewItem[]>;
|
|
98
|
+
submitReviewDecision(decision: ReviewDecision): Promise<{
|
|
99
|
+
status: string;
|
|
100
|
+
}>;
|
|
101
|
+
getSubscriptionInfo(): Promise<SubscriptionInfo>;
|
|
102
|
+
getUsageMetrics(): Promise<UsageStats>;
|
|
103
|
+
}
|
|
104
|
+
export declare class SafeKeyLabError extends Error {
|
|
105
|
+
code: string;
|
|
106
|
+
statusCode: number;
|
|
107
|
+
constructor(message: string, code: string, statusCode: number);
|
|
108
|
+
}
|
|
109
|
+
export declare function createClient(config: ClientConfig): SafeKeyLabClient;
|
|
110
|
+
export declare function getClient(): SafeKeyLabClient;
|
|
111
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
package/dist/client.js
ADDED
|
@@ -0,0 +1,296 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SafeKeyLab API Client
|
|
3
|
+
* Unified client for all SafeKeyLab API endpoints
|
|
4
|
+
*/
|
|
5
|
+
export class SafeKeyLabClient {
|
|
6
|
+
apiKey;
|
|
7
|
+
baseUrl;
|
|
8
|
+
timeout;
|
|
9
|
+
organizationId;
|
|
10
|
+
constructor(config) {
|
|
11
|
+
this.apiKey = config.apiKey;
|
|
12
|
+
this.baseUrl = config.baseUrl || 'https://safekeylab-api-1054985024815.us-central1.run.app';
|
|
13
|
+
this.timeout = config.timeout || 30000;
|
|
14
|
+
this.organizationId = config.organizationId;
|
|
15
|
+
}
|
|
16
|
+
// ===========================================================================
|
|
17
|
+
// Private Helpers
|
|
18
|
+
// ===========================================================================
|
|
19
|
+
async request(method, endpoint, body) {
|
|
20
|
+
const controller = new AbortController();
|
|
21
|
+
const timeoutId = setTimeout(() => controller.abort(), this.timeout);
|
|
22
|
+
try {
|
|
23
|
+
const response = await fetch(`${this.baseUrl}${endpoint}`, {
|
|
24
|
+
method,
|
|
25
|
+
headers: {
|
|
26
|
+
'X-API-Key': this.apiKey,
|
|
27
|
+
'Content-Type': 'application/json',
|
|
28
|
+
...(this.organizationId && { 'X-Organization-ID': this.organizationId }),
|
|
29
|
+
},
|
|
30
|
+
body: body ? JSON.stringify(body) : undefined,
|
|
31
|
+
signal: controller.signal,
|
|
32
|
+
});
|
|
33
|
+
clearTimeout(timeoutId);
|
|
34
|
+
if (!response.ok) {
|
|
35
|
+
const errorData = await response.json().catch(() => ({}));
|
|
36
|
+
throw new SafeKeyLabError(errorData.message || `API request failed with status ${response.status}`, errorData.code || 'API_ERROR', response.status);
|
|
37
|
+
}
|
|
38
|
+
return response.json();
|
|
39
|
+
}
|
|
40
|
+
catch (error) {
|
|
41
|
+
clearTimeout(timeoutId);
|
|
42
|
+
if (error instanceof SafeKeyLabError)
|
|
43
|
+
throw error;
|
|
44
|
+
if (error instanceof Error && error.name === 'AbortError') {
|
|
45
|
+
throw new SafeKeyLabError('Request timeout', 'TIMEOUT', 408);
|
|
46
|
+
}
|
|
47
|
+
throw new SafeKeyLabError(error instanceof Error ? error.message : 'Unknown error', 'NETWORK_ERROR', 0);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
// ===========================================================================
|
|
51
|
+
// PII Detection Endpoints
|
|
52
|
+
// ===========================================================================
|
|
53
|
+
async detectPII(text, options) {
|
|
54
|
+
return this.request('POST', '/v1/detect', {
|
|
55
|
+
text,
|
|
56
|
+
entity_types: options?.entityTypes,
|
|
57
|
+
confidence_threshold: options?.confidenceThreshold ?? 0.8,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
async detectPIIBatch(texts, options) {
|
|
61
|
+
const response = await this.request('POST', '/v1/detect/batch', {
|
|
62
|
+
texts,
|
|
63
|
+
entity_types: options?.entityTypes,
|
|
64
|
+
confidence_threshold: options?.confidenceThreshold ?? 0.8,
|
|
65
|
+
});
|
|
66
|
+
return response.results;
|
|
67
|
+
}
|
|
68
|
+
async detectPIIInFile(content, fileType, options) {
|
|
69
|
+
return this.request('POST', '/v1/detect', {
|
|
70
|
+
content,
|
|
71
|
+
content_type: fileType,
|
|
72
|
+
entity_types: options?.entityTypes,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
async redactText(text, options) {
|
|
76
|
+
return this.request('POST', '/v1/protect', {
|
|
77
|
+
text,
|
|
78
|
+
redaction_method: options?.redactionMethod ?? 'mask',
|
|
79
|
+
entity_types: options?.entityTypes,
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
async anonymizeText(text, options) {
|
|
83
|
+
return this.request('POST', '/v1/protect', {
|
|
84
|
+
text,
|
|
85
|
+
redaction_method: 'replace',
|
|
86
|
+
preserve_format: options?.preserveFormat ?? true,
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
// ===========================================================================
|
|
90
|
+
// LLM Guard Endpoints
|
|
91
|
+
// ===========================================================================
|
|
92
|
+
async guardPrompt(prompt, options) {
|
|
93
|
+
return this.request('POST', '/v1/llm/validate-prompt', {
|
|
94
|
+
prompt,
|
|
95
|
+
context: {
|
|
96
|
+
model: options?.model ?? 'gpt-4',
|
|
97
|
+
session_id: options?.sessionId,
|
|
98
|
+
user_id: options?.userId,
|
|
99
|
+
},
|
|
100
|
+
options: {
|
|
101
|
+
mode: options?.mode ?? 'standard',
|
|
102
|
+
strict_mode: options?.strictMode ?? false,
|
|
103
|
+
include_explanation: options?.includeExplanation ?? false,
|
|
104
|
+
include_attribution: options?.includeAttribution ?? false,
|
|
105
|
+
include_guarantee: options?.includeGuarantee ?? false,
|
|
106
|
+
},
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
async guardResponse(response, options) {
|
|
110
|
+
return this.request('POST', '/v1/llm/filter-response', {
|
|
111
|
+
response,
|
|
112
|
+
original_prompt: options?.originalPrompt ?? '',
|
|
113
|
+
options: {
|
|
114
|
+
detect_pii: options?.detectPII ?? true,
|
|
115
|
+
detect_harmful: options?.detectHarmful ?? true,
|
|
116
|
+
},
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
async analyzeConversation(messages, options) {
|
|
120
|
+
return this.request('POST', '/v1/llm/analyze-conversation', {
|
|
121
|
+
messages,
|
|
122
|
+
strict_mode: options?.strictMode ?? false,
|
|
123
|
+
options: {
|
|
124
|
+
detect_escalation: options?.detectEscalation ?? true,
|
|
125
|
+
},
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
async analyzeSemanticGraph(prompt, depth = 3) {
|
|
129
|
+
return this.request('POST', '/v1/llm/analyze/semantic-graph', {
|
|
130
|
+
prompt,
|
|
131
|
+
depth: Math.min(Math.max(depth, 1), 5),
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
async detectPerturbations(prompt, threshold = 3) {
|
|
135
|
+
return this.request('POST', '/v1/llm/analyze/perturbations', {
|
|
136
|
+
prompt,
|
|
137
|
+
threshold,
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
async detectCrossModal(content, contentType, options) {
|
|
141
|
+
return this.request('POST', '/v1/llm/analyze/cross-modal', {
|
|
142
|
+
content,
|
|
143
|
+
content_type: contentType,
|
|
144
|
+
options: {
|
|
145
|
+
check_hidden_text: options?.checkHiddenText ?? true,
|
|
146
|
+
check_steganography: options?.checkSteganography ?? true,
|
|
147
|
+
},
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
async fingerprintThreat(prompt) {
|
|
151
|
+
return this.request('POST', '/v1/llm/threat-intelligence/fingerprint', {
|
|
152
|
+
prompt,
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
async matchAttackTool(prompt) {
|
|
156
|
+
return this.request('POST', '/v1/llm/threat-intelligence/tool-match', {
|
|
157
|
+
prompt,
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
async explainThreat(prompt, detectionId) {
|
|
161
|
+
return this.request('POST', '/v1/llm/explain/counterfactual', {
|
|
162
|
+
prompt,
|
|
163
|
+
detection_id: detectionId,
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
async getAttribution(prompt) {
|
|
167
|
+
return this.request('POST', '/v1/llm/explain/attribution', {
|
|
168
|
+
prompt,
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
async getFormalGuarantee(prompt, confidence = 0.95) {
|
|
172
|
+
return this.request('POST', '/v1/llm/explain/formal-guarantee', {
|
|
173
|
+
prompt,
|
|
174
|
+
confidence,
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
async provideFeedback(prompt, isThreat, threatType) {
|
|
178
|
+
return this.request('POST', '/v1/llm/feedback', {
|
|
179
|
+
prompt,
|
|
180
|
+
is_threat: isThreat,
|
|
181
|
+
threat_type: threatType,
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
async getLLMStatistics(days = 7) {
|
|
185
|
+
return this.request('GET', `/v1/llm/statistics?days=${days}`);
|
|
186
|
+
}
|
|
187
|
+
// ===========================================================================
|
|
188
|
+
// Enterprise Endpoints
|
|
189
|
+
// ===========================================================================
|
|
190
|
+
async validateAgentAction(action) {
|
|
191
|
+
return this.request('POST', '/api/v1/agent/validate-action', action);
|
|
192
|
+
}
|
|
193
|
+
async checkAgentPolicy(action, policyId) {
|
|
194
|
+
return this.request('POST', '/api/v1/agent/policy/check', {
|
|
195
|
+
action,
|
|
196
|
+
policy_id: policyId,
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
async filterRAGContext(context, options) {
|
|
200
|
+
return this.request('POST', '/api/v1/rag/context/filter', {
|
|
201
|
+
...context,
|
|
202
|
+
options: {
|
|
203
|
+
filter_pii: options?.filterPII ?? true,
|
|
204
|
+
filter_sensitive: options?.filterSensitive ?? true,
|
|
205
|
+
},
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
async scanIngestion(document, documentType) {
|
|
209
|
+
return this.request('POST', '/api/v1/rag/ingestion/scan', {
|
|
210
|
+
document,
|
|
211
|
+
document_type: documentType,
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
async generateComplianceReport(framework, days = 30) {
|
|
215
|
+
return this.request('POST', '/api/v1/observability/compliance-evidence', {
|
|
216
|
+
framework,
|
|
217
|
+
days,
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
async getAuditTrail(options) {
|
|
221
|
+
const params = new URLSearchParams();
|
|
222
|
+
if (options?.startDate)
|
|
223
|
+
params.set('start_date', options.startDate);
|
|
224
|
+
if (options?.endDate)
|
|
225
|
+
params.set('end_date', options.endDate);
|
|
226
|
+
if (options?.actionType)
|
|
227
|
+
params.set('action_type', options.actionType);
|
|
228
|
+
if (options?.limit)
|
|
229
|
+
params.set('limit', String(options.limit));
|
|
230
|
+
return this.request('GET', `/api/v1/agent/audit-trail?${params.toString()}`);
|
|
231
|
+
}
|
|
232
|
+
async checkComplianceStatus(framework) {
|
|
233
|
+
const report = await this.request('GET', `/v1/llm/compliance-report?framework=${framework}&days=1`);
|
|
234
|
+
return {
|
|
235
|
+
compliant: report.status === 'compliant',
|
|
236
|
+
score: report.score,
|
|
237
|
+
};
|
|
238
|
+
}
|
|
239
|
+
async getReviewQueue(options) {
|
|
240
|
+
const params = new URLSearchParams();
|
|
241
|
+
if (options?.limit)
|
|
242
|
+
params.set('limit', String(options.limit));
|
|
243
|
+
if (options?.priority)
|
|
244
|
+
params.set('priority', options.priority);
|
|
245
|
+
const response = await this.request('GET', `/api/confidence/review-queue?${params.toString()}`);
|
|
246
|
+
return response.items;
|
|
247
|
+
}
|
|
248
|
+
async submitReviewDecision(decision) {
|
|
249
|
+
return this.request('POST', `/api/confidence/review-queue/${decision.item_id}/complete`, {
|
|
250
|
+
decision: decision.decision,
|
|
251
|
+
reason: decision.reason,
|
|
252
|
+
corrections: decision.corrections,
|
|
253
|
+
});
|
|
254
|
+
}
|
|
255
|
+
async getSubscriptionInfo() {
|
|
256
|
+
return this.request('GET', '/api/billing/subscription');
|
|
257
|
+
}
|
|
258
|
+
async getUsageMetrics() {
|
|
259
|
+
return this.request('GET', '/api/metrics');
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
// ===========================================================================
|
|
263
|
+
// Error Classes
|
|
264
|
+
// ===========================================================================
|
|
265
|
+
export class SafeKeyLabError extends Error {
|
|
266
|
+
code;
|
|
267
|
+
statusCode;
|
|
268
|
+
constructor(message, code, statusCode) {
|
|
269
|
+
super(message);
|
|
270
|
+
this.name = 'SafeKeyLabError';
|
|
271
|
+
this.code = code;
|
|
272
|
+
this.statusCode = statusCode;
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
// ===========================================================================
|
|
276
|
+
// Client Factory
|
|
277
|
+
// ===========================================================================
|
|
278
|
+
let defaultClient = null;
|
|
279
|
+
export function createClient(config) {
|
|
280
|
+
return new SafeKeyLabClient(config);
|
|
281
|
+
}
|
|
282
|
+
export function getClient() {
|
|
283
|
+
if (!defaultClient) {
|
|
284
|
+
const apiKey = process.env.SAFEKEYLAB_API_KEY;
|
|
285
|
+
if (!apiKey) {
|
|
286
|
+
throw new SafeKeyLabError('SAFEKEYLAB_API_KEY environment variable is not set', 'MISSING_API_KEY', 401);
|
|
287
|
+
}
|
|
288
|
+
defaultClient = new SafeKeyLabClient({
|
|
289
|
+
apiKey,
|
|
290
|
+
baseUrl: process.env.SAFEKEYLAB_BASE_URL,
|
|
291
|
+
organizationId: process.env.SAFEKEYLAB_ORGANIZATION_ID,
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
return defaultClient;
|
|
295
|
+
}
|
|
296
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC"}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SafeKeyLab MCP Core Types
|
|
3
|
+
* Shared type definitions across all MCP servers
|
|
4
|
+
*/
|
|
5
|
+
export type PIIEntityType = 'ssn' | 'credit_card' | 'email' | 'phone' | 'address' | 'name' | 'date_of_birth' | 'passport' | 'driver_license' | 'bank_account' | 'iban' | 'ip_address' | 'url' | 'bitcoin_address' | 'ethereum_address' | 'medical_record' | 'health_insurance' | 'biometric' | 'genetic_data' | 'password' | 'api_key' | 'aws_key' | 'gcp_key' | 'azure_key' | 'jwt_token' | 'national_id' | 'tax_id' | 'vin' | 'mac_address' | 'imei';
|
|
6
|
+
export interface PIIEntity {
|
|
7
|
+
type: PIIEntityType;
|
|
8
|
+
value: string;
|
|
9
|
+
redacted_value?: string;
|
|
10
|
+
confidence: number;
|
|
11
|
+
start: number;
|
|
12
|
+
end: number;
|
|
13
|
+
context?: string;
|
|
14
|
+
}
|
|
15
|
+
export interface PIIDetectionResult {
|
|
16
|
+
pii_found: boolean;
|
|
17
|
+
entity_count: number;
|
|
18
|
+
entities: PIIEntity[];
|
|
19
|
+
processing_time_ms: number;
|
|
20
|
+
text_length: number;
|
|
21
|
+
}
|
|
22
|
+
export interface PIIRedactionResult {
|
|
23
|
+
original_text: string;
|
|
24
|
+
redacted_text: string;
|
|
25
|
+
entities_redacted: number;
|
|
26
|
+
redaction_method: RedactionMethod;
|
|
27
|
+
}
|
|
28
|
+
export type RedactionMethod = 'mask' | 'hash' | 'replace' | 'remove' | 'tokenize';
|
|
29
|
+
export type ThreatLevel = 'none' | 'low' | 'medium' | 'high' | 'critical';
|
|
30
|
+
export type DetectionMode = 'fast' | 'standard' | 'deep' | 'paranoid';
|
|
31
|
+
export interface ThreatDetection {
|
|
32
|
+
type: string;
|
|
33
|
+
score: number;
|
|
34
|
+
confidence: number;
|
|
35
|
+
description: string;
|
|
36
|
+
evidence: string[];
|
|
37
|
+
mitigation?: string;
|
|
38
|
+
}
|
|
39
|
+
export interface GuardResult {
|
|
40
|
+
is_threat: boolean;
|
|
41
|
+
threat_level: ThreatLevel;
|
|
42
|
+
overall_score: number;
|
|
43
|
+
safe: boolean;
|
|
44
|
+
should_block: boolean;
|
|
45
|
+
detections: ThreatDetection[];
|
|
46
|
+
recommendations: string[];
|
|
47
|
+
explanation?: CounterfactualExplanation;
|
|
48
|
+
attribution?: FeatureAttribution;
|
|
49
|
+
formal_guarantee?: FormalGuarantee;
|
|
50
|
+
processing_time_ms: number;
|
|
51
|
+
}
|
|
52
|
+
export interface ConversationMessage {
|
|
53
|
+
role: 'user' | 'assistant' | 'system';
|
|
54
|
+
content: string;
|
|
55
|
+
}
|
|
56
|
+
export interface ConversationAnalysis {
|
|
57
|
+
is_attack_sequence: boolean;
|
|
58
|
+
sequence_type?: string;
|
|
59
|
+
escalation_detected: boolean;
|
|
60
|
+
confidence: number;
|
|
61
|
+
turn_analysis: TurnAnalysis[];
|
|
62
|
+
attack_path?: string[];
|
|
63
|
+
}
|
|
64
|
+
export interface TurnAnalysis {
|
|
65
|
+
turn_index: number;
|
|
66
|
+
risk_score: number;
|
|
67
|
+
threat_indicators: string[];
|
|
68
|
+
}
|
|
69
|
+
export interface SemanticGraphResult {
|
|
70
|
+
node_count: number;
|
|
71
|
+
edge_count: number;
|
|
72
|
+
attack_paths: AttackPath[];
|
|
73
|
+
risk_score: number;
|
|
74
|
+
dominant_pattern?: string;
|
|
75
|
+
}
|
|
76
|
+
export interface AttackPath {
|
|
77
|
+
nodes: string[];
|
|
78
|
+
risk_score: number;
|
|
79
|
+
attack_type: string;
|
|
80
|
+
}
|
|
81
|
+
export interface PerturbationResult {
|
|
82
|
+
perturbations_found: boolean;
|
|
83
|
+
perturbation_count: number;
|
|
84
|
+
matches: PerturbationMatch[];
|
|
85
|
+
original_pattern?: string;
|
|
86
|
+
}
|
|
87
|
+
export interface PerturbationMatch {
|
|
88
|
+
original: string;
|
|
89
|
+
perturbed: string;
|
|
90
|
+
edit_distance: number;
|
|
91
|
+
perturbation_type: string;
|
|
92
|
+
}
|
|
93
|
+
export interface CrossModalResult {
|
|
94
|
+
threats_found: boolean;
|
|
95
|
+
modalities_analyzed: string[];
|
|
96
|
+
hidden_content: HiddenContent[];
|
|
97
|
+
risk_score: number;
|
|
98
|
+
}
|
|
99
|
+
export interface HiddenContent {
|
|
100
|
+
modality: string;
|
|
101
|
+
hiding_technique: string;
|
|
102
|
+
extracted_text: string;
|
|
103
|
+
risk_score: number;
|
|
104
|
+
}
|
|
105
|
+
export interface ThreatFingerprint {
|
|
106
|
+
fingerprint_id: string;
|
|
107
|
+
campaign_id?: string;
|
|
108
|
+
tool_detected?: string;
|
|
109
|
+
similarity_score: number;
|
|
110
|
+
known_actor?: string;
|
|
111
|
+
ttps: string[];
|
|
112
|
+
}
|
|
113
|
+
export interface ToolMatch {
|
|
114
|
+
tool_name: string;
|
|
115
|
+
tool_category: string;
|
|
116
|
+
confidence: number;
|
|
117
|
+
signature_type: string;
|
|
118
|
+
}
|
|
119
|
+
export interface CounterfactualExplanation {
|
|
120
|
+
original_text: string;
|
|
121
|
+
counterfactual_text: string;
|
|
122
|
+
changes_required: TextChange[];
|
|
123
|
+
explanation: string;
|
|
124
|
+
}
|
|
125
|
+
export interface TextChange {
|
|
126
|
+
original: string;
|
|
127
|
+
replacement: string;
|
|
128
|
+
position: {
|
|
129
|
+
start: number;
|
|
130
|
+
end: number;
|
|
131
|
+
};
|
|
132
|
+
reason: string;
|
|
133
|
+
}
|
|
134
|
+
export interface FeatureAttribution {
|
|
135
|
+
token_attributions: TokenAttribution[];
|
|
136
|
+
phrase_attributions: PhraseAttribution[];
|
|
137
|
+
top_contributors: string[];
|
|
138
|
+
}
|
|
139
|
+
export interface TokenAttribution {
|
|
140
|
+
token: string;
|
|
141
|
+
attribution: number;
|
|
142
|
+
position: number;
|
|
143
|
+
}
|
|
144
|
+
export interface PhraseAttribution {
|
|
145
|
+
phrase: string;
|
|
146
|
+
attribution: number;
|
|
147
|
+
start: number;
|
|
148
|
+
end: number;
|
|
149
|
+
}
|
|
150
|
+
export interface FormalGuarantee {
|
|
151
|
+
confidence_level: number;
|
|
152
|
+
lower_bound: number;
|
|
153
|
+
upper_bound: number;
|
|
154
|
+
certified: boolean;
|
|
155
|
+
certificate_id?: string;
|
|
156
|
+
}
|
|
157
|
+
export interface AgentAction {
|
|
158
|
+
tool_name: string;
|
|
159
|
+
tool_args: Record<string, unknown>;
|
|
160
|
+
agent_id?: string;
|
|
161
|
+
session_id?: string;
|
|
162
|
+
}
|
|
163
|
+
export interface AgentValidationResult {
|
|
164
|
+
allowed: boolean;
|
|
165
|
+
policy_violations: PolicyViolation[];
|
|
166
|
+
risk_score: number;
|
|
167
|
+
recommendations: string[];
|
|
168
|
+
}
|
|
169
|
+
export interface PolicyViolation {
|
|
170
|
+
policy_id: string;
|
|
171
|
+
policy_name: string;
|
|
172
|
+
violation_type: string;
|
|
173
|
+
severity: 'low' | 'medium' | 'high' | 'critical';
|
|
174
|
+
description: string;
|
|
175
|
+
}
|
|
176
|
+
export interface RAGContext {
|
|
177
|
+
chunks: ContextChunk[];
|
|
178
|
+
metadata?: Record<string, unknown>;
|
|
179
|
+
}
|
|
180
|
+
export interface ContextChunk {
|
|
181
|
+
content: string;
|
|
182
|
+
source?: string;
|
|
183
|
+
score?: number;
|
|
184
|
+
}
|
|
185
|
+
export interface RAGFilterResult {
|
|
186
|
+
filtered_chunks: FilteredChunk[];
|
|
187
|
+
pii_removed: number;
|
|
188
|
+
sensitive_removed: number;
|
|
189
|
+
processing_time_ms: number;
|
|
190
|
+
}
|
|
191
|
+
export interface FilteredChunk {
|
|
192
|
+
original_content: string;
|
|
193
|
+
filtered_content: string;
|
|
194
|
+
pii_entities: PIIEntity[];
|
|
195
|
+
is_sensitive: boolean;
|
|
196
|
+
}
|
|
197
|
+
export interface IngestionScanResult {
|
|
198
|
+
document_id: string;
|
|
199
|
+
safe_to_ingest: boolean;
|
|
200
|
+
pii_found: PIIEntity[];
|
|
201
|
+
sensitive_content: SensitiveContent[];
|
|
202
|
+
recommendations: string[];
|
|
203
|
+
}
|
|
204
|
+
export interface SensitiveContent {
|
|
205
|
+
type: string;
|
|
206
|
+
description: string;
|
|
207
|
+
location: string;
|
|
208
|
+
severity: string;
|
|
209
|
+
}
|
|
210
|
+
export type ComplianceFramework = 'GDPR' | 'HIPAA' | 'SOC2' | 'PCI-DSS' | 'CCPA';
|
|
211
|
+
export interface ComplianceReport {
|
|
212
|
+
framework: ComplianceFramework;
|
|
213
|
+
status: 'compliant' | 'non-compliant' | 'partial';
|
|
214
|
+
score: number;
|
|
215
|
+
period_days: number;
|
|
216
|
+
findings: ComplianceFinding[];
|
|
217
|
+
evidence: ComplianceEvidence[];
|
|
218
|
+
generated_at: string;
|
|
219
|
+
}
|
|
220
|
+
export interface ComplianceFinding {
|
|
221
|
+
finding_id: string;
|
|
222
|
+
category: string;
|
|
223
|
+
severity: string;
|
|
224
|
+
description: string;
|
|
225
|
+
recommendation: string;
|
|
226
|
+
}
|
|
227
|
+
export interface ComplianceEvidence {
|
|
228
|
+
evidence_id: string;
|
|
229
|
+
type: string;
|
|
230
|
+
description: string;
|
|
231
|
+
timestamp: string;
|
|
232
|
+
}
|
|
233
|
+
export interface AuditEntry {
|
|
234
|
+
entry_id: string;
|
|
235
|
+
timestamp: string;
|
|
236
|
+
action_type: string;
|
|
237
|
+
user_id?: string;
|
|
238
|
+
resource: string;
|
|
239
|
+
details: Record<string, unknown>;
|
|
240
|
+
outcome: 'success' | 'failure' | 'blocked';
|
|
241
|
+
}
|
|
242
|
+
export interface AuditTrail {
|
|
243
|
+
entries: AuditEntry[];
|
|
244
|
+
total_count: number;
|
|
245
|
+
start_date: string;
|
|
246
|
+
end_date: string;
|
|
247
|
+
}
|
|
248
|
+
export interface ReviewItem {
|
|
249
|
+
item_id: string;
|
|
250
|
+
content: string;
|
|
251
|
+
content_type: string;
|
|
252
|
+
detection_result: PIIDetectionResult | GuardResult;
|
|
253
|
+
confidence: number;
|
|
254
|
+
priority: 'low' | 'medium' | 'high' | 'urgent';
|
|
255
|
+
created_at: string;
|
|
256
|
+
status: 'pending' | 'claimed' | 'completed';
|
|
257
|
+
}
|
|
258
|
+
export interface ReviewDecision {
|
|
259
|
+
item_id: string;
|
|
260
|
+
decision: 'approve' | 'reject' | 'escalate';
|
|
261
|
+
reason?: string;
|
|
262
|
+
corrections?: Record<string, unknown>;
|
|
263
|
+
}
|
|
264
|
+
export interface APIResponse<T> {
|
|
265
|
+
success: boolean;
|
|
266
|
+
data?: T;
|
|
267
|
+
error?: APIError;
|
|
268
|
+
}
|
|
269
|
+
export interface APIError {
|
|
270
|
+
code: string;
|
|
271
|
+
message: string;
|
|
272
|
+
details?: Record<string, unknown>;
|
|
273
|
+
}
|
|
274
|
+
export interface UsageStats {
|
|
275
|
+
total_requests: number;
|
|
276
|
+
threats_detected: number;
|
|
277
|
+
pii_entities_found: number;
|
|
278
|
+
avg_response_time_ms: number;
|
|
279
|
+
period_days: number;
|
|
280
|
+
}
|
|
281
|
+
export interface SubscriptionInfo {
|
|
282
|
+
tier: 'free' | 'starter' | 'pro' | 'scale' | 'enterprise';
|
|
283
|
+
requests_used: number;
|
|
284
|
+
requests_limit: number;
|
|
285
|
+
features: string[];
|
|
286
|
+
expires_at?: string;
|
|
287
|
+
}
|
|
288
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
package/package.json
ADDED
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@safekeylab/mcp-core",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "Core utilities for SafeKeyLab MCP servers",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/index.js",
|
|
7
|
+
"types": "./dist/index.d.ts",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"types": "./dist/index.d.ts",
|
|
11
|
+
"import": "./dist/index.js"
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
"files": ["dist"],
|
|
15
|
+
"scripts": {
|
|
16
|
+
"build": "tsc",
|
|
17
|
+
"clean": "rm -rf dist",
|
|
18
|
+
"prepublishOnly": "npm run build"
|
|
19
|
+
},
|
|
20
|
+
"dependencies": {
|
|
21
|
+
"node-fetch": "^3.3.0"
|
|
22
|
+
},
|
|
23
|
+
"devDependencies": {
|
|
24
|
+
"@types/node": "^20.10.0",
|
|
25
|
+
"typescript": "^5.3.0"
|
|
26
|
+
},
|
|
27
|
+
"author": "SafeKey Lab Inc.",
|
|
28
|
+
"license": "MIT",
|
|
29
|
+
"repository": {
|
|
30
|
+
"type": "git",
|
|
31
|
+
"url": "https://github.com/SafeKeylab/safekeylab-mcp.git",
|
|
32
|
+
"directory": "packages/core"
|
|
33
|
+
},
|
|
34
|
+
"keywords": ["safekeylab", "mcp", "ai-security", "pii-detection", "llm-guard"]
|
|
35
|
+
}
|