@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.
@@ -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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"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * @safekeylab/mcp-core
3
+ * Core utilities for SafeKeyLab MCP servers
4
+ */
5
+ export * from './types.js';
6
+ export * from './client.js';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -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,7 @@
1
+ /**
2
+ * @safekeylab/mcp-core
3
+ * Core utilities for SafeKeyLab MCP servers
4
+ */
5
+ export * from './types.js';
6
+ export * from './client.js';
7
+ //# sourceMappingURL=index.js.map
@@ -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"}
@@ -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,6 @@
1
+ /**
2
+ * SafeKeyLab MCP Core Types
3
+ * Shared type definitions across all MCP servers
4
+ */
5
+ export {};
6
+ //# sourceMappingURL=types.js.map
@@ -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
+ }