@stackmemoryai/stackmemory 0.2.4 → 0.2.6
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 +108 -0
- package/dist/index.js +382 -0
- package/dist/src/analytics/api/analytics-api.d.ts +24 -0
- package/dist/src/analytics/api/analytics-api.d.ts.map +1 -0
- package/dist/src/analytics/api/analytics-api.js +279 -0
- package/dist/src/analytics/api/analytics-api.js.map +1 -0
- package/dist/src/analytics/core/analytics-service.d.ts +23 -0
- package/dist/src/analytics/core/analytics-service.d.ts.map +1 -0
- package/dist/src/analytics/core/analytics-service.js +160 -0
- package/dist/src/analytics/core/analytics-service.js.map +1 -0
- package/dist/src/analytics/index.d.ts +12 -0
- package/dist/src/analytics/index.d.ts.map +1 -0
- package/dist/src/analytics/index.js +11 -0
- package/dist/src/analytics/index.js.map +1 -0
- package/dist/src/analytics/queries/metrics-queries.d.ts +11 -0
- package/dist/src/analytics/queries/metrics-queries.d.ts.map +1 -0
- package/dist/src/analytics/queries/metrics-queries.js +179 -0
- package/dist/src/analytics/queries/metrics-queries.js.map +1 -0
- package/dist/src/analytics/types/metrics.d.ts +60 -0
- package/dist/src/analytics/types/metrics.d.ts.map +1 -0
- package/dist/src/analytics/types/metrics.js +2 -0
- package/dist/src/analytics/types/metrics.js.map +1 -0
- package/dist/src/cli/analytics-viewer.d.ts +3 -0
- package/dist/src/cli/analytics-viewer.d.ts.map +1 -0
- package/dist/src/cli/analytics-viewer.js +89 -0
- package/dist/src/cli/analytics-viewer.js.map +1 -0
- package/dist/src/cli/browser-test.d.ts +6 -0
- package/dist/src/cli/browser-test.d.ts.map +1 -0
- package/dist/src/cli/browser-test.js +32 -0
- package/dist/src/cli/browser-test.js.map +1 -0
- package/dist/src/cli/cli.js +157 -0
- package/dist/src/cli/cli.js.map +1 -1
- package/dist/src/cli/commands/projects.d.ts +8 -0
- package/dist/src/cli/commands/projects.d.ts.map +1 -0
- package/dist/src/cli/commands/projects.js +220 -0
- package/dist/src/cli/commands/projects.js.map +1 -0
- package/dist/src/cli/index.d.ts +7 -0
- package/dist/src/cli/index.d.ts.map +1 -0
- package/dist/src/cli/index.js +704 -0
- package/dist/src/cli/index.js.map +1 -0
- package/dist/src/cli/project-commands.d.ts +8 -0
- package/dist/src/cli/project-commands.d.ts.map +1 -0
- package/dist/src/cli/project-commands.js +212 -0
- package/dist/src/cli/project-commands.js.map +1 -0
- package/dist/src/cli/utils/viewer.d.ts +3 -0
- package/dist/src/cli/utils/viewer.d.ts.map +1 -0
- package/dist/src/cli/utils/viewer.js +89 -0
- package/dist/src/cli/utils/viewer.js.map +1 -0
- package/dist/src/core/context/frame-manager.d.ts +106 -0
- package/dist/src/core/context/frame-manager.d.ts.map +1 -0
- package/dist/src/core/context/frame-manager.js +387 -0
- package/dist/src/core/context/frame-manager.js.map +1 -0
- package/dist/src/core/logger.test.js +1 -1
- package/dist/src/core/logger.test.js.map +1 -1
- package/dist/src/core/monitoring/error-handler.d.ts +46 -0
- package/dist/src/core/monitoring/error-handler.d.ts.map +1 -0
- package/dist/src/core/monitoring/error-handler.js +212 -0
- package/dist/src/core/monitoring/error-handler.js.map +1 -0
- package/dist/src/core/monitoring/logger.d.ts +24 -0
- package/dist/src/core/monitoring/logger.d.ts.map +1 -0
- package/dist/src/core/monitoring/logger.js +121 -0
- package/dist/src/core/monitoring/logger.js.map +1 -0
- package/dist/src/core/monitoring/metrics.d.ts +7 -0
- package/dist/src/core/monitoring/metrics.d.ts.map +1 -0
- package/dist/src/core/monitoring/metrics.js +13 -0
- package/dist/src/core/monitoring/metrics.js.map +1 -0
- package/dist/src/core/monitoring/progress-tracker.d.ts +95 -0
- package/dist/src/core/monitoring/progress-tracker.d.ts.map +1 -0
- package/dist/src/core/monitoring/progress-tracker.js +178 -0
- package/dist/src/core/monitoring/progress-tracker.js.map +1 -0
- package/dist/src/core/project-manager.d.ts +130 -0
- package/dist/src/core/project-manager.d.ts.map +1 -0
- package/dist/src/core/project-manager.js +582 -0
- package/dist/src/core/project-manager.js.map +1 -0
- package/dist/src/core/projects/project-manager.d.ts +130 -0
- package/dist/src/core/projects/project-manager.d.ts.map +1 -0
- package/dist/src/core/projects/project-manager.js +591 -0
- package/dist/src/core/projects/project-manager.js.map +1 -0
- package/dist/src/core/utils/update-checker.d.ts +38 -0
- package/dist/src/core/utils/update-checker.d.ts.map +1 -0
- package/dist/src/core/utils/update-checker.js +156 -0
- package/dist/src/core/utils/update-checker.js.map +1 -0
- package/dist/src/features/analytics/api/analytics-api.d.ts +24 -0
- package/dist/src/features/analytics/api/analytics-api.d.ts.map +1 -0
- package/dist/src/features/analytics/api/analytics-api.js +289 -0
- package/dist/src/features/analytics/api/analytics-api.js.map +1 -0
- package/dist/src/features/analytics/core/analytics-service.d.ts +23 -0
- package/dist/src/features/analytics/core/analytics-service.d.ts.map +1 -0
- package/dist/src/features/analytics/core/analytics-service.js +160 -0
- package/dist/src/features/analytics/core/analytics-service.js.map +1 -0
- package/dist/src/features/analytics/index.d.ts +12 -0
- package/dist/src/features/analytics/index.d.ts.map +1 -0
- package/dist/src/features/analytics/index.js +11 -0
- package/dist/src/features/analytics/index.js.map +1 -0
- package/dist/src/features/analytics/queries/metrics-queries.d.ts +11 -0
- package/dist/src/features/analytics/queries/metrics-queries.d.ts.map +1 -0
- package/dist/src/features/analytics/queries/metrics-queries.js +183 -0
- package/dist/src/features/analytics/queries/metrics-queries.js.map +1 -0
- package/dist/src/features/analytics/types/metrics.d.ts +60 -0
- package/dist/src/features/analytics/types/metrics.d.ts.map +1 -0
- package/dist/src/features/analytics/types/metrics.js +2 -0
- package/dist/src/features/analytics/types/metrics.js.map +1 -0
- package/dist/src/features/browser/browser-mcp.d.ts +94 -0
- package/dist/src/features/browser/browser-mcp.d.ts.map +1 -0
- package/dist/src/features/browser/browser-mcp.js +456 -0
- package/dist/src/features/browser/browser-mcp.js.map +1 -0
- package/dist/src/features/tasks/pebbles-task-store.d.ts +117 -0
- package/dist/src/features/tasks/pebbles-task-store.d.ts.map +1 -0
- package/dist/src/features/tasks/pebbles-task-store.js +335 -0
- package/dist/src/features/tasks/pebbles-task-store.js.map +1 -0
- package/dist/src/features/tasks/task-aware-context.d.ts +103 -0
- package/dist/src/features/tasks/task-aware-context.d.ts.map +1 -0
- package/dist/src/features/tasks/task-aware-context.js +412 -0
- package/dist/src/features/tasks/task-aware-context.js.map +1 -0
- package/dist/src/index.d.ts +4 -4
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +4 -4
- package/dist/src/index.js.map +1 -1
- package/dist/src/integrations/browser-mcp.d.ts +94 -0
- package/dist/src/integrations/browser-mcp.d.ts.map +1 -0
- package/dist/src/integrations/browser-mcp.js +431 -0
- package/dist/src/integrations/browser-mcp.js.map +1 -0
- package/dist/src/integrations/linear/auth.d.ts +99 -0
- package/dist/src/integrations/linear/auth.d.ts.map +1 -0
- package/dist/src/integrations/linear/auth.js +319 -0
- package/dist/src/integrations/linear/auth.js.map +1 -0
- package/dist/src/integrations/linear/auto-sync.d.ts +77 -0
- package/dist/src/integrations/linear/auto-sync.d.ts.map +1 -0
- package/dist/src/integrations/linear/auto-sync.js +268 -0
- package/dist/src/integrations/linear/auto-sync.js.map +1 -0
- package/dist/src/integrations/linear/client.d.ts +86 -0
- package/dist/src/integrations/linear/client.d.ts.map +1 -0
- package/dist/src/integrations/linear/client.js +277 -0
- package/dist/src/integrations/linear/client.js.map +1 -0
- package/dist/src/integrations/linear/config.d.ts +51 -0
- package/dist/src/integrations/linear/config.d.ts.map +1 -0
- package/dist/src/integrations/linear/config.js +103 -0
- package/dist/src/integrations/linear/config.js.map +1 -0
- package/dist/src/integrations/linear/sync.d.ts +97 -0
- package/dist/src/integrations/linear/sync.d.ts.map +1 -0
- package/dist/src/integrations/linear/sync.js +391 -0
- package/dist/src/integrations/linear/sync.js.map +1 -0
- package/dist/src/integrations/mcp/server.d.ts +40 -0
- package/dist/src/integrations/mcp/server.d.ts.map +1 -0
- package/dist/src/integrations/mcp/server.js +828 -0
- package/dist/src/integrations/mcp/server.js.map +1 -0
- package/dist/src/mcp/mcp-server.d.ts +1 -0
- package/dist/src/mcp/mcp-server.d.ts.map +1 -1
- package/dist/src/mcp/mcp-server.js +11 -0
- package/dist/src/mcp/mcp-server.js.map +1 -1
- package/dist/src/railway/index.d.ts +7 -0
- package/dist/src/railway/index.d.ts.map +1 -0
- package/dist/src/railway/index.js +401 -0
- package/dist/src/railway/index.js.map +1 -0
- package/dist/src/runway/auth/auth-middleware.d.ts +66 -0
- package/dist/src/runway/auth/auth-middleware.d.ts.map +1 -0
- package/dist/src/runway/auth/auth-middleware.js +337 -0
- package/dist/src/runway/auth/auth-middleware.js.map +1 -0
- package/dist/src/runway/server/runway-mcp-server.d.ts +46 -0
- package/dist/src/runway/server/runway-mcp-server.d.ts.map +1 -0
- package/dist/src/runway/server/runway-mcp-server.js +601 -0
- package/dist/src/runway/server/runway-mcp-server.js.map +1 -0
- package/dist/src/runway.bak/auth/auth-middleware.d.ts +66 -0
- package/dist/src/runway.bak/auth/auth-middleware.d.ts.map +1 -0
- package/dist/src/runway.bak/auth/auth-middleware.js +337 -0
- package/dist/src/runway.bak/auth/auth-middleware.js.map +1 -0
- package/dist/src/runway.bak/server/runway-mcp-server.d.ts +46 -0
- package/dist/src/runway.bak/server/runway-mcp-server.d.ts.map +1 -0
- package/dist/src/runway.bak/server/runway-mcp-server.js +601 -0
- package/dist/src/runway.bak/server/runway-mcp-server.js.map +1 -0
- package/dist/src/servers/production/auth-middleware.d.ts +66 -0
- package/dist/src/servers/production/auth-middleware.d.ts.map +1 -0
- package/dist/src/servers/production/auth-middleware.js +346 -0
- package/dist/src/servers/production/auth-middleware.js.map +1 -0
- package/dist/src/servers/railway/index.d.ts +7 -0
- package/dist/src/servers/railway/index.d.ts.map +1 -0
- package/dist/src/servers/railway/index.js +401 -0
- package/dist/src/servers/railway/index.js.map +1 -0
- package/package.json +27 -5
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Production Authentication Middleware for Runway MCP Server
|
|
3
|
+
* Implements JWT validation with Auth0, refresh tokens, and rate limiting
|
|
4
|
+
*/
|
|
5
|
+
import { Request, Response, NextFunction } from 'express';
|
|
6
|
+
import { RateLimiterRes } from 'rate-limiter-flexible';
|
|
7
|
+
export interface AuthUser {
|
|
8
|
+
id: string;
|
|
9
|
+
email: string;
|
|
10
|
+
sub: string;
|
|
11
|
+
name?: string;
|
|
12
|
+
picture?: string;
|
|
13
|
+
tier: 'free' | 'pro' | 'enterprise';
|
|
14
|
+
organizations?: string[];
|
|
15
|
+
permissions: string[];
|
|
16
|
+
metadata?: Record<string, any>;
|
|
17
|
+
}
|
|
18
|
+
export interface AuthRequest extends Request {
|
|
19
|
+
user?: AuthUser;
|
|
20
|
+
rateLimitInfo?: RateLimiterRes;
|
|
21
|
+
}
|
|
22
|
+
export declare class AuthMiddleware {
|
|
23
|
+
private config;
|
|
24
|
+
private jwksClient;
|
|
25
|
+
private redis;
|
|
26
|
+
private rateLimiters;
|
|
27
|
+
private blacklistedTokens;
|
|
28
|
+
constructor(config: {
|
|
29
|
+
auth0Domain: string;
|
|
30
|
+
auth0Audience: string;
|
|
31
|
+
redisUrl: string;
|
|
32
|
+
jwtSecret?: string;
|
|
33
|
+
bypassAuth?: boolean;
|
|
34
|
+
});
|
|
35
|
+
private initializeRateLimiters;
|
|
36
|
+
private setupTokenBlacklistSync;
|
|
37
|
+
private getSigningKey;
|
|
38
|
+
/**
|
|
39
|
+
* Main authentication middleware
|
|
40
|
+
*/
|
|
41
|
+
authenticate: (req: AuthRequest, res: Response, next: NextFunction) => Promise<any>;
|
|
42
|
+
/**
|
|
43
|
+
* WebSocket authentication handler
|
|
44
|
+
*/
|
|
45
|
+
authenticateWebSocket: (token: string) => Promise<AuthUser | null>;
|
|
46
|
+
/**
|
|
47
|
+
* Permission checking middleware
|
|
48
|
+
*/
|
|
49
|
+
requirePermission: (permission: string) => (req: AuthRequest, res: Response, next: NextFunction) => Response<any, Record<string, any>>;
|
|
50
|
+
/**
|
|
51
|
+
* Organization access middleware
|
|
52
|
+
*/
|
|
53
|
+
requireOrganization: (req: AuthRequest, res: Response, next: NextFunction) => Response<any, Record<string, any>>;
|
|
54
|
+
private extractToken;
|
|
55
|
+
private loadUser;
|
|
56
|
+
private getMockUser;
|
|
57
|
+
/**
|
|
58
|
+
* Revoke a token (add to blacklist)
|
|
59
|
+
*/
|
|
60
|
+
revokeToken(token: string): Promise<void>;
|
|
61
|
+
/**
|
|
62
|
+
* Cleanup resources
|
|
63
|
+
*/
|
|
64
|
+
close(): Promise<void>;
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=auth-middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-middleware.d.ts","sourceRoot":"","sources":["../../../../src/servers/production/auth-middleware.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAoB,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAKzE,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,GAAG,KAAK,GAAG,YAAY,CAAC;IACpC,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,WAAY,SAAQ,OAAO;IAC1C,IAAI,CAAC,EAAE,QAAQ,CAAC;IAChB,aAAa,CAAC,EAAE,cAAc,CAAC;CAChC;AAED,qBAAa,cAAc;IAOvB,OAAO,CAAC,MAAM;IANhB,OAAO,CAAC,UAAU,CAAqB;IACvC,OAAO,CAAC,KAAK,CAAQ;IACrB,OAAO,CAAC,YAAY,CAAgC;IACpD,OAAO,CAAC,iBAAiB,CAA0B;gBAGzC,MAAM,EAAE;QACd,WAAW,EAAE,MAAM,CAAC;QACpB,aAAa,EAAE,MAAM,CAAC;QACtB,QAAQ,EAAE,MAAM,CAAC;QACjB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,UAAU,CAAC,EAAE,OAAO,CAAC;KACtB;IAeH,OAAO,CAAC,sBAAsB;IAgD9B,OAAO,CAAC,uBAAuB;YAgBjB,aAAa;IAiB3B;;OAEG;IACI,YAAY,GACjB,KAAK,WAAW,EAChB,KAAK,QAAQ,EACb,MAAM,YAAY,KACjB,OAAO,CAAC,GAAG,CAAC,CA0Ib;IAEF;;OAEG;IACI,qBAAqB,GAC1B,OAAO,MAAM,KACZ,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CAmBzB;IAEF;;OAEG;IACI,iBAAiB,GAAI,YAAY,MAAM,MACpC,KAAK,WAAW,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,wCAmB3D;IAEF;;OAEG;IACI,mBAAmB,GACxB,KAAK,WAAW,EAChB,KAAK,QAAQ,EACb,MAAM,YAAY,wCAmBlB;IAEF,OAAO,CAAC,YAAY;YAUN,QAAQ;IAwBtB,OAAO,CAAC,WAAW;IAYnB;;OAEG;IACU,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IActD;;OAEG;IACU,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAGpC"}
|
|
@@ -0,0 +1,346 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Production Authentication Middleware for Runway MCP Server
|
|
3
|
+
* Implements JWT validation with Auth0, refresh tokens, and rate limiting
|
|
4
|
+
*/
|
|
5
|
+
import jwt from 'jsonwebtoken';
|
|
6
|
+
import jwksRsa from 'jwks-rsa';
|
|
7
|
+
import { RateLimiterRedis } from 'rate-limiter-flexible';
|
|
8
|
+
import Redis from 'ioredis';
|
|
9
|
+
import { logger } from '../../core/monitoring/logger.js';
|
|
10
|
+
import { metrics } from '../../core/monitoring/metrics.js';
|
|
11
|
+
export class AuthMiddleware {
|
|
12
|
+
config;
|
|
13
|
+
jwksClient;
|
|
14
|
+
redis;
|
|
15
|
+
rateLimiters;
|
|
16
|
+
blacklistedTokens = new Set();
|
|
17
|
+
constructor(config) {
|
|
18
|
+
this.config = config;
|
|
19
|
+
this.redis = new Redis(config.redisUrl);
|
|
20
|
+
this.jwksClient = jwksRsa({
|
|
21
|
+
jwksUri: `https://${config.auth0Domain}/.well-known/jwks.json`,
|
|
22
|
+
cache: true,
|
|
23
|
+
cacheMaxAge: 600000, // 10 minutes
|
|
24
|
+
rateLimit: true,
|
|
25
|
+
jwksRequestsPerMinute: 5,
|
|
26
|
+
});
|
|
27
|
+
this.initializeRateLimiters();
|
|
28
|
+
this.setupTokenBlacklistSync();
|
|
29
|
+
}
|
|
30
|
+
initializeRateLimiters() {
|
|
31
|
+
// Different rate limits for different tiers
|
|
32
|
+
this.rateLimiters = new Map([
|
|
33
|
+
[
|
|
34
|
+
'free',
|
|
35
|
+
new RateLimiterRedis({
|
|
36
|
+
storeClient: this.redis,
|
|
37
|
+
keyPrefix: 'rl:free',
|
|
38
|
+
points: 100, // requests
|
|
39
|
+
duration: 900, // per 15 minutes
|
|
40
|
+
blockDuration: 900, // block for 15 minutes
|
|
41
|
+
}),
|
|
42
|
+
],
|
|
43
|
+
[
|
|
44
|
+
'pro',
|
|
45
|
+
new RateLimiterRedis({
|
|
46
|
+
storeClient: this.redis,
|
|
47
|
+
keyPrefix: 'rl:pro',
|
|
48
|
+
points: 1000,
|
|
49
|
+
duration: 900,
|
|
50
|
+
blockDuration: 300,
|
|
51
|
+
}),
|
|
52
|
+
],
|
|
53
|
+
[
|
|
54
|
+
'enterprise',
|
|
55
|
+
new RateLimiterRedis({
|
|
56
|
+
storeClient: this.redis,
|
|
57
|
+
keyPrefix: 'rl:enterprise',
|
|
58
|
+
points: 10000,
|
|
59
|
+
duration: 900,
|
|
60
|
+
blockDuration: 60,
|
|
61
|
+
}),
|
|
62
|
+
],
|
|
63
|
+
]);
|
|
64
|
+
// Special rate limiter for auth endpoints
|
|
65
|
+
this.rateLimiters.set('auth', new RateLimiterRedis({
|
|
66
|
+
storeClient: this.redis,
|
|
67
|
+
keyPrefix: 'rl:auth',
|
|
68
|
+
points: 10, // Only 10 auth attempts
|
|
69
|
+
duration: 900,
|
|
70
|
+
blockDuration: 3600, // Block for 1 hour on excessive auth attempts
|
|
71
|
+
}));
|
|
72
|
+
}
|
|
73
|
+
setupTokenBlacklistSync() {
|
|
74
|
+
// Subscribe to token revocation events
|
|
75
|
+
const subscriber = new Redis(this.config.redisUrl);
|
|
76
|
+
subscriber.subscribe('token:revoked');
|
|
77
|
+
subscriber.on('message', (channel, token) => {
|
|
78
|
+
if (channel === 'token:revoked') {
|
|
79
|
+
this.blacklistedTokens.add(token);
|
|
80
|
+
// Clean up old tokens periodically
|
|
81
|
+
if (this.blacklistedTokens.size > 10000) {
|
|
82
|
+
this.blacklistedTokens.clear();
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
async getSigningKey(kid) {
|
|
88
|
+
return new Promise((resolve, reject) => {
|
|
89
|
+
this.jwksClient.getSigningKey(kid, (err, key) => {
|
|
90
|
+
if (err) {
|
|
91
|
+
reject(err);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
const signingKey = key?.getPublicKey();
|
|
95
|
+
if (!signingKey) {
|
|
96
|
+
reject(new Error('No signing key found'));
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
resolve(signingKey);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Main authentication middleware
|
|
107
|
+
*/
|
|
108
|
+
authenticate = async (req, res, next) => {
|
|
109
|
+
const startTime = Date.now();
|
|
110
|
+
try {
|
|
111
|
+
// Bypass auth for health checks
|
|
112
|
+
if (req.path === '/health' || req.path === '/metrics') {
|
|
113
|
+
return next();
|
|
114
|
+
}
|
|
115
|
+
// Development bypass
|
|
116
|
+
if (this.config.bypassAuth && process.env.NODE_ENV === 'development') {
|
|
117
|
+
req.user = this.getMockUser();
|
|
118
|
+
return next();
|
|
119
|
+
}
|
|
120
|
+
// Extract token
|
|
121
|
+
const token = this.extractToken(req);
|
|
122
|
+
if (!token) {
|
|
123
|
+
metrics.increment('auth.missing_token');
|
|
124
|
+
return res.status(401).json({
|
|
125
|
+
error: 'Authentication required',
|
|
126
|
+
code: 'MISSING_TOKEN',
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
// Check blacklist
|
|
130
|
+
if (this.blacklistedTokens.has(token)) {
|
|
131
|
+
metrics.increment('auth.blacklisted_token');
|
|
132
|
+
return res.status(401).json({
|
|
133
|
+
error: 'Token has been revoked',
|
|
134
|
+
code: 'TOKEN_REVOKED',
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
// Decode and verify token
|
|
138
|
+
const decoded = jwt.decode(token, { complete: true });
|
|
139
|
+
if (!decoded) {
|
|
140
|
+
metrics.increment('auth.invalid_token');
|
|
141
|
+
return res.status(401).json({
|
|
142
|
+
error: 'Invalid token format',
|
|
143
|
+
code: 'INVALID_TOKEN',
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
// Get signing key and verify
|
|
147
|
+
const signingKey = await this.getSigningKey(decoded.header.kid);
|
|
148
|
+
const verified = jwt.verify(token, signingKey, {
|
|
149
|
+
algorithms: ['RS256'],
|
|
150
|
+
audience: this.config.auth0Audience,
|
|
151
|
+
issuer: `https://${this.config.auth0Domain}/`,
|
|
152
|
+
});
|
|
153
|
+
// Load user from database or cache
|
|
154
|
+
const user = await this.loadUser(verified.sub);
|
|
155
|
+
if (!user) {
|
|
156
|
+
metrics.increment('auth.user_not_found');
|
|
157
|
+
return res.status(403).json({
|
|
158
|
+
error: 'User not found',
|
|
159
|
+
code: 'USER_NOT_FOUND',
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
// Check user suspension
|
|
163
|
+
if (user.metadata?.suspended) {
|
|
164
|
+
metrics.increment('auth.user_suspended');
|
|
165
|
+
return res.status(403).json({
|
|
166
|
+
error: 'Account suspended',
|
|
167
|
+
code: 'ACCOUNT_SUSPENDED',
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
// Apply rate limiting
|
|
171
|
+
const rateLimiter = this.rateLimiters.get(user.tier) || this.rateLimiters.get('free');
|
|
172
|
+
try {
|
|
173
|
+
const rateLimitRes = await rateLimiter.consume(user.id);
|
|
174
|
+
req.rateLimitInfo = rateLimitRes;
|
|
175
|
+
// Add rate limit headers
|
|
176
|
+
res.setHeader('X-RateLimit-Limit', rateLimiter.points.toString());
|
|
177
|
+
res.setHeader('X-RateLimit-Remaining', rateLimitRes.remainingPoints.toString());
|
|
178
|
+
res.setHeader('X-RateLimit-Reset', new Date(Date.now() + rateLimitRes.msBeforeNext).toISOString());
|
|
179
|
+
}
|
|
180
|
+
catch (rateLimitError) {
|
|
181
|
+
metrics.increment('auth.rate_limited');
|
|
182
|
+
res.setHeader('Retry-After', Math.round(rateLimitError.msBeforeNext / 1000).toString());
|
|
183
|
+
return res.status(429).json({
|
|
184
|
+
error: 'Too many requests',
|
|
185
|
+
code: 'RATE_LIMITED',
|
|
186
|
+
retryAfter: rateLimitError.msBeforeNext,
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
// Attach user to request
|
|
190
|
+
req.user = user;
|
|
191
|
+
// Track metrics
|
|
192
|
+
metrics.increment('auth.success', { tier: user.tier });
|
|
193
|
+
metrics.timing('auth.duration', Date.now() - startTime);
|
|
194
|
+
logger.info('Authentication successful', {
|
|
195
|
+
userId: user.id,
|
|
196
|
+
tier: user.tier,
|
|
197
|
+
path: req.path,
|
|
198
|
+
});
|
|
199
|
+
next();
|
|
200
|
+
}
|
|
201
|
+
catch (error) {
|
|
202
|
+
metrics.increment('auth.error');
|
|
203
|
+
logger.error('Authentication error', error);
|
|
204
|
+
if (error.name === 'TokenExpiredError') {
|
|
205
|
+
return res.status(401).json({
|
|
206
|
+
error: 'Token expired',
|
|
207
|
+
code: 'TOKEN_EXPIRED',
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
if (error.name === 'JsonWebTokenError') {
|
|
211
|
+
return res.status(401).json({
|
|
212
|
+
error: 'Invalid token',
|
|
213
|
+
code: 'INVALID_TOKEN',
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
res.status(500).json({
|
|
217
|
+
error: 'Authentication failed',
|
|
218
|
+
code: 'AUTH_ERROR',
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
};
|
|
222
|
+
/**
|
|
223
|
+
* WebSocket authentication handler
|
|
224
|
+
*/
|
|
225
|
+
authenticateWebSocket = async (token) => {
|
|
226
|
+
try {
|
|
227
|
+
const decoded = jwt.decode(token, { complete: true });
|
|
228
|
+
if (!decoded || this.blacklistedTokens.has(token)) {
|
|
229
|
+
return null;
|
|
230
|
+
}
|
|
231
|
+
const signingKey = await this.getSigningKey(decoded.header.kid);
|
|
232
|
+
const verified = jwt.verify(token, signingKey, {
|
|
233
|
+
algorithms: ['RS256'],
|
|
234
|
+
audience: this.config.auth0Audience,
|
|
235
|
+
issuer: `https://${this.config.auth0Domain}/`,
|
|
236
|
+
});
|
|
237
|
+
return await this.loadUser(verified.sub);
|
|
238
|
+
}
|
|
239
|
+
catch (error) {
|
|
240
|
+
logger.error('WebSocket authentication failed', error);
|
|
241
|
+
return null;
|
|
242
|
+
}
|
|
243
|
+
};
|
|
244
|
+
/**
|
|
245
|
+
* Permission checking middleware
|
|
246
|
+
*/
|
|
247
|
+
requirePermission = (permission) => {
|
|
248
|
+
return (req, res, next) => {
|
|
249
|
+
if (!req.user) {
|
|
250
|
+
return res.status(401).json({
|
|
251
|
+
error: 'Authentication required',
|
|
252
|
+
code: 'NOT_AUTHENTICATED',
|
|
253
|
+
});
|
|
254
|
+
}
|
|
255
|
+
if (!req.user.permissions.includes(permission)) {
|
|
256
|
+
metrics.increment('auth.permission_denied', { permission });
|
|
257
|
+
return res.status(403).json({
|
|
258
|
+
error: 'Insufficient permissions',
|
|
259
|
+
code: 'PERMISSION_DENIED',
|
|
260
|
+
required: permission,
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
next();
|
|
264
|
+
};
|
|
265
|
+
};
|
|
266
|
+
/**
|
|
267
|
+
* Organization access middleware
|
|
268
|
+
*/
|
|
269
|
+
requireOrganization = (req, res, next) => {
|
|
270
|
+
const orgId = req.params.orgId || req.query.orgId;
|
|
271
|
+
if (!req.user || !orgId) {
|
|
272
|
+
return res.status(401).json({
|
|
273
|
+
error: 'Authentication required',
|
|
274
|
+
code: 'NOT_AUTHENTICATED',
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
if (!req.user.organizations?.includes(orgId)) {
|
|
278
|
+
return res.status(403).json({
|
|
279
|
+
error: 'Organization access denied',
|
|
280
|
+
code: 'ORG_ACCESS_DENIED',
|
|
281
|
+
});
|
|
282
|
+
}
|
|
283
|
+
next();
|
|
284
|
+
};
|
|
285
|
+
extractToken(req) {
|
|
286
|
+
const authHeader = req.headers.authorization;
|
|
287
|
+
if (authHeader?.startsWith('Bearer ')) {
|
|
288
|
+
return authHeader.substring(7);
|
|
289
|
+
}
|
|
290
|
+
// Also check cookie for web clients
|
|
291
|
+
return req.cookies?.access_token || null;
|
|
292
|
+
}
|
|
293
|
+
async loadUser(sub) {
|
|
294
|
+
// Try cache first
|
|
295
|
+
const cached = await this.redis.get(`user:${sub}`);
|
|
296
|
+
if (cached) {
|
|
297
|
+
return JSON.parse(cached);
|
|
298
|
+
}
|
|
299
|
+
// Load from database (implement your database logic)
|
|
300
|
+
// This is a placeholder - implement actual database loading
|
|
301
|
+
const user = {
|
|
302
|
+
id: sub,
|
|
303
|
+
sub,
|
|
304
|
+
email: `${sub}@example.com`,
|
|
305
|
+
tier: 'free',
|
|
306
|
+
permissions: ['read', 'write'],
|
|
307
|
+
organizations: [],
|
|
308
|
+
};
|
|
309
|
+
// Cache for 5 minutes
|
|
310
|
+
await this.redis.setex(`user:${sub}`, 300, JSON.stringify(user));
|
|
311
|
+
return user;
|
|
312
|
+
}
|
|
313
|
+
getMockUser() {
|
|
314
|
+
return {
|
|
315
|
+
id: 'mock-user-id',
|
|
316
|
+
sub: 'mock-sub',
|
|
317
|
+
email: 'test@example.com',
|
|
318
|
+
name: 'Test User',
|
|
319
|
+
tier: 'pro',
|
|
320
|
+
permissions: ['read', 'write', 'admin'],
|
|
321
|
+
organizations: ['test-org'],
|
|
322
|
+
};
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Revoke a token (add to blacklist)
|
|
326
|
+
*/
|
|
327
|
+
async revokeToken(token) {
|
|
328
|
+
this.blacklistedTokens.add(token);
|
|
329
|
+
await this.redis.publish('token:revoked', token);
|
|
330
|
+
// Also store in Redis with TTL matching token expiry
|
|
331
|
+
const decoded = jwt.decode(token);
|
|
332
|
+
if (decoded?.exp) {
|
|
333
|
+
const ttl = decoded.exp - Math.floor(Date.now() / 1000);
|
|
334
|
+
if (ttl > 0) {
|
|
335
|
+
await this.redis.setex(`blacklist:${token}`, ttl, '1');
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
/**
|
|
340
|
+
* Cleanup resources
|
|
341
|
+
*/
|
|
342
|
+
async close() {
|
|
343
|
+
await this.redis.quit();
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
//# sourceMappingURL=auth-middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-middleware.js","sourceRoot":"","sources":["../../../../src/servers/production/auth-middleware.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/servers/railway/index.ts"],"names":[],"mappings":";AACA;;;GAGG"}
|