@joethebigbuddy/auth 0.0.1
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 +97 -0
- package/dist/express.d.ts +2 -0
- package/dist/express.d.ts.map +1 -0
- package/dist/express.js +2 -0
- package/dist/express.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/adapters/express/express-auth-adapter.d.ts +48 -0
- package/dist/lib/adapters/express/express-auth-adapter.d.ts.map +1 -0
- package/dist/lib/adapters/express/express-auth-adapter.js +161 -0
- package/dist/lib/adapters/express/express-auth-adapter.js.map +1 -0
- package/dist/lib/adapters/logging/create-logging-adapter.d.ts +4 -0
- package/dist/lib/adapters/logging/create-logging-adapter.d.ts.map +1 -0
- package/dist/lib/adapters/logging/create-logging-adapter.js +20 -0
- package/dist/lib/adapters/logging/create-logging-adapter.js.map +1 -0
- package/dist/lib/adapters/memory/memory-refresh-token-store.d.ts +10 -0
- package/dist/lib/adapters/memory/memory-refresh-token-store.d.ts.map +1 -0
- package/dist/lib/adapters/memory/memory-refresh-token-store.js +34 -0
- package/dist/lib/adapters/memory/memory-refresh-token-store.js.map +1 -0
- package/dist/lib/adapters/memory/memory-session-store.d.ts +12 -0
- package/dist/lib/adapters/memory/memory-session-store.d.ts.map +1 -0
- package/dist/lib/adapters/memory/memory-session-store.js +32 -0
- package/dist/lib/adapters/memory/memory-session-store.js.map +1 -0
- package/dist/lib/adapters/postgres/create-postgres-auth-storage.d.ts +16 -0
- package/dist/lib/adapters/postgres/create-postgres-auth-storage.d.ts.map +1 -0
- package/dist/lib/adapters/postgres/create-postgres-auth-storage.js +18 -0
- package/dist/lib/adapters/postgres/create-postgres-auth-storage.js.map +1 -0
- package/dist/lib/adapters/postgres/postgres-refresh-token-store.d.ts +13 -0
- package/dist/lib/adapters/postgres/postgres-refresh-token-store.d.ts.map +1 -0
- package/dist/lib/adapters/postgres/postgres-refresh-token-store.js +63 -0
- package/dist/lib/adapters/postgres/postgres-refresh-token-store.js.map +1 -0
- package/dist/lib/adapters/postgres/postgres-session-store.d.ts +15 -0
- package/dist/lib/adapters/postgres/postgres-session-store.d.ts.map +1 -0
- package/dist/lib/adapters/postgres/postgres-session-store.js +75 -0
- package/dist/lib/adapters/postgres/postgres-session-store.js.map +1 -0
- package/dist/lib/adapters/postgres/shared.d.ts +41 -0
- package/dist/lib/adapters/postgres/shared.d.ts.map +1 -0
- package/dist/lib/adapters/postgres/shared.js +83 -0
- package/dist/lib/adapters/postgres/shared.js.map +1 -0
- package/dist/lib/adapters/redis/create-redis-auth-storage.d.ts +2329 -0
- package/dist/lib/adapters/redis/create-redis-auth-storage.d.ts.map +1 -0
- package/dist/lib/adapters/redis/create-redis-auth-storage.js +25 -0
- package/dist/lib/adapters/redis/create-redis-auth-storage.js.map +1 -0
- package/dist/lib/adapters/redis/redis-refresh-token-store.d.ts +13 -0
- package/dist/lib/adapters/redis/redis-refresh-token-store.d.ts.map +1 -0
- package/dist/lib/adapters/redis/redis-refresh-token-store.js +46 -0
- package/dist/lib/adapters/redis/redis-refresh-token-store.js.map +1 -0
- package/dist/lib/adapters/redis/redis-session-store.d.ts +16 -0
- package/dist/lib/adapters/redis/redis-session-store.d.ts.map +1 -0
- package/dist/lib/adapters/redis/redis-session-store.js +49 -0
- package/dist/lib/adapters/redis/redis-session-store.js.map +1 -0
- package/dist/lib/adapters/redis/shared.d.ts +24 -0
- package/dist/lib/adapters/redis/shared.d.ts.map +1 -0
- package/dist/lib/adapters/redis/shared.js +60 -0
- package/dist/lib/adapters/redis/shared.js.map +1 -0
- package/dist/lib/core/authorization-service.d.ts +21 -0
- package/dist/lib/core/authorization-service.d.ts.map +1 -0
- package/dist/lib/core/authorization-service.js +125 -0
- package/dist/lib/core/authorization-service.js.map +1 -0
- package/dist/lib/core/create-auth-module.d.ts +3 -0
- package/dist/lib/core/create-auth-module.d.ts.map +1 -0
- package/dist/lib/core/create-auth-module.js +177 -0
- package/dist/lib/core/create-auth-module.js.map +1 -0
- package/dist/lib/core/defaults.d.ts +4 -0
- package/dist/lib/core/defaults.d.ts.map +1 -0
- package/dist/lib/core/defaults.js +50 -0
- package/dist/lib/core/defaults.js.map +1 -0
- package/dist/lib/core/logger.d.ts +4 -0
- package/dist/lib/core/logger.d.ts.map +1 -0
- package/dist/lib/core/logger.js +14 -0
- package/dist/lib/core/logger.js.map +1 -0
- package/dist/lib/core/session-service.d.ts +33 -0
- package/dist/lib/core/session-service.d.ts.map +1 -0
- package/dist/lib/core/session-service.js +96 -0
- package/dist/lib/core/session-service.js.map +1 -0
- package/dist/lib/core/token-service.d.ts +22 -0
- package/dist/lib/core/token-service.d.ts.map +1 -0
- package/dist/lib/core/token-service.js +111 -0
- package/dist/lib/core/token-service.js.map +1 -0
- package/dist/lib/errors.d.ts +21 -0
- package/dist/lib/errors.d.ts.map +1 -0
- package/dist/lib/errors.js +36 -0
- package/dist/lib/errors.js.map +1 -0
- package/dist/lib/ports.d.ts +32 -0
- package/dist/lib/ports.d.ts.map +1 -0
- package/dist/lib/ports.js +2 -0
- package/dist/lib/ports.js.map +1 -0
- package/dist/lib/types.d.ts +161 -0
- package/dist/lib/types.d.ts.map +1 -0
- package/dist/lib/types.js +2 -0
- package/dist/lib/types.js.map +1 -0
- package/dist/logging.d.ts +2 -0
- package/dist/logging.d.ts.map +1 -0
- package/dist/logging.js +2 -0
- package/dist/logging.js.map +1 -0
- package/dist/memory.d.ts +3 -0
- package/dist/memory.d.ts.map +1 -0
- package/dist/memory.js +3 -0
- package/dist/memory.js.map +1 -0
- package/dist/postgres.d.ts +5 -0
- package/dist/postgres.d.ts.map +1 -0
- package/dist/postgres.js +5 -0
- package/dist/postgres.js.map +1 -0
- package/dist/redis.d.ts +5 -0
- package/dist/redis.d.ts.map +1 -0
- package/dist/redis.js +5 -0
- package/dist/redis.js.map +1 -0
- package/package.json +69 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-auth-module.js","sourceRoot":"","sources":["../../../src/lib/core/create-auth-module.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { AuthModuleConfig } from '../types.js';
|
|
2
|
+
export declare function createDefaultAuthConfig(overrides?: Partial<AuthModuleConfig>): AuthModuleConfig;
|
|
3
|
+
export declare function validateAuthModuleConfig(config: AuthModuleConfig): void;
|
|
4
|
+
//# sourceMappingURL=defaults.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defaults.d.ts","sourceRoot":"","sources":["../../../src/lib/core/defaults.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAcpD,wBAAgB,uBAAuB,CAAC,SAAS,GAAE,OAAO,CAAC,gBAAgB,CAAM,GAAG,gBAAgB,CAYnG;AAED,wBAAgB,wBAAwB,CAAC,MAAM,EAAE,gBAAgB,GAAG,IAAI,CA4BvE"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { ConfigurationError } from '../errors.js';
|
|
2
|
+
const defaultConfig = {
|
|
3
|
+
issuer: '@joethebigbuddy/auth',
|
|
4
|
+
audience: 'authenticated-client',
|
|
5
|
+
accessTokenTtlSeconds: 15 * 60,
|
|
6
|
+
refreshTokenTtlSeconds: 7 * 24 * 60 * 60,
|
|
7
|
+
sessionTtlSeconds: 7 * 24 * 60 * 60,
|
|
8
|
+
allowSessionExtension: true,
|
|
9
|
+
signing: {
|
|
10
|
+
algorithm: 'HS256',
|
|
11
|
+
},
|
|
12
|
+
};
|
|
13
|
+
export function createDefaultAuthConfig(overrides = {}) {
|
|
14
|
+
const config = {
|
|
15
|
+
...defaultConfig,
|
|
16
|
+
...overrides,
|
|
17
|
+
signing: {
|
|
18
|
+
...defaultConfig.signing,
|
|
19
|
+
...overrides.signing,
|
|
20
|
+
},
|
|
21
|
+
};
|
|
22
|
+
validateAuthModuleConfig(config);
|
|
23
|
+
return config;
|
|
24
|
+
}
|
|
25
|
+
export function validateAuthModuleConfig(config) {
|
|
26
|
+
if (!config.issuer) {
|
|
27
|
+
throw new ConfigurationError('Auth issuer is required');
|
|
28
|
+
}
|
|
29
|
+
if (!config.audience) {
|
|
30
|
+
throw new ConfigurationError('Auth audience is required');
|
|
31
|
+
}
|
|
32
|
+
for (const [name, value] of [
|
|
33
|
+
['accessTokenTtlSeconds', config.accessTokenTtlSeconds],
|
|
34
|
+
['refreshTokenTtlSeconds', config.refreshTokenTtlSeconds],
|
|
35
|
+
['sessionTtlSeconds', config.sessionTtlSeconds],
|
|
36
|
+
]) {
|
|
37
|
+
if (!Number.isFinite(value) || value <= 0) {
|
|
38
|
+
throw new ConfigurationError(`${name} must be a positive number`);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (config.signing.algorithm === 'HS256' && !config.signing.secret) {
|
|
42
|
+
throw new ConfigurationError('HS256 signing requires a secret');
|
|
43
|
+
}
|
|
44
|
+
if (config.signing.algorithm === 'RS256') {
|
|
45
|
+
if (!config.signing.privateKey || !config.signing.publicKey) {
|
|
46
|
+
throw new ConfigurationError('RS256 signing requires both privateKey and publicKey');
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=defaults.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defaults.js","sourceRoot":"","sources":["../../../src/lib/core/defaults.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAGlD,MAAM,aAAa,GAAqB;IACtC,MAAM,EAAE,sBAAsB;IAC9B,QAAQ,EAAE,sBAAsB;IAChC,qBAAqB,EAAE,EAAE,GAAG,EAAE;IAC9B,sBAAsB,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE;IACxC,iBAAiB,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE;IACnC,qBAAqB,EAAE,IAAI;IAC3B,OAAO,EAAE;QACP,SAAS,EAAE,OAAO;KACnB;CACF,CAAC;AAEF,MAAM,UAAU,uBAAuB,CAAC,YAAuC,EAAE;IAC/E,MAAM,MAAM,GAAqB;QAC/B,GAAG,aAAa;QAChB,GAAG,SAAS;QACZ,OAAO,EAAE;YACP,GAAG,aAAa,CAAC,OAAO;YACxB,GAAG,SAAS,CAAC,OAAO;SACrB;KACF,CAAC;IAEF,wBAAwB,CAAC,MAAM,CAAC,CAAC;IACjC,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,MAAwB;IAC/D,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;QACnB,MAAM,IAAI,kBAAkB,CAAC,yBAAyB,CAAC,CAAC;IAC1D,CAAC;IAED,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACrB,MAAM,IAAI,kBAAkB,CAAC,2BAA2B,CAAC,CAAC;IAC5D,CAAC;IAED,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI;QAC1B,CAAC,uBAAuB,EAAE,MAAM,CAAC,qBAAqB,CAAC;QACvD,CAAC,wBAAwB,EAAE,MAAM,CAAC,sBAAsB,CAAC;QACzD,CAAC,mBAAmB,EAAE,MAAM,CAAC,iBAAiB,CAAC;KACvC,EAAE,CAAC;QACX,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;YAC1C,MAAM,IAAI,kBAAkB,CAAC,GAAG,IAAI,4BAA4B,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IAED,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,KAAK,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QACnE,MAAM,IAAI,kBAAkB,CAAC,iCAAiC,CAAC,CAAC;IAClE,CAAC;IAED,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,KAAK,OAAO,EAAE,CAAC;QACzC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;YAC5D,MAAM,IAAI,kBAAkB,CAAC,sDAAsD,CAAC,CAAC;QACvF,CAAC;IACH,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/lib/core/logger.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAY9C,eAAO,MAAM,UAAU,EAAE,UAA6B,CAAC;AAEvD,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,UAAU,CAEjG"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
class NoopLogger {
|
|
2
|
+
debug() { }
|
|
3
|
+
info() { }
|
|
4
|
+
warn() { }
|
|
5
|
+
error() { }
|
|
6
|
+
child() {
|
|
7
|
+
return this;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export const noopLogger = new NoopLogger();
|
|
11
|
+
export function withLoggerContext(logger, fields) {
|
|
12
|
+
return logger.child ? logger.child(fields) : logger;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/lib/core/logger.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU;IACd,KAAK,KAAU,CAAC;IAChB,IAAI,KAAU,CAAC;IACf,IAAI,KAAU,CAAC;IACf,KAAK,KAAU,CAAC;IAChB,KAAK;QACH,OAAO,IAAI,CAAC;IACd,CAAC;CACF;AAED,MAAM,CAAC,MAAM,UAAU,GAAe,IAAI,UAAU,EAAE,CAAC;AAEvD,MAAM,UAAU,iBAAiB,CAAC,MAAkB,EAAE,MAA+B;IACnF,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;AACtD,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { Clock, IdGenerator, LoggerPort, SessionStore } from '../ports.js';
|
|
2
|
+
import type { AuthModuleConfig, SessionRecord } from '../types.js';
|
|
3
|
+
export interface SessionServiceOptions {
|
|
4
|
+
config: Pick<AuthModuleConfig, 'sessionTtlSeconds' | 'allowSessionExtension'>;
|
|
5
|
+
sessionStore: SessionStore;
|
|
6
|
+
clock?: Clock;
|
|
7
|
+
generateId?: IdGenerator;
|
|
8
|
+
logger?: LoggerPort;
|
|
9
|
+
}
|
|
10
|
+
export declare class SessionService {
|
|
11
|
+
private readonly sessionTtlMs;
|
|
12
|
+
private readonly allowSessionExtension;
|
|
13
|
+
private readonly sessionStore;
|
|
14
|
+
private readonly clock;
|
|
15
|
+
private readonly generateId;
|
|
16
|
+
private readonly logger;
|
|
17
|
+
constructor(options: SessionServiceOptions);
|
|
18
|
+
createSession(subjectId: string, context?: {
|
|
19
|
+
ipAddress?: string;
|
|
20
|
+
userAgent?: string;
|
|
21
|
+
metadata?: Record<string, unknown>;
|
|
22
|
+
}): Promise<SessionRecord>;
|
|
23
|
+
getSession(sessionId: string): Promise<SessionRecord | null>;
|
|
24
|
+
assertActiveSession(sessionId: string, options?: {
|
|
25
|
+
touch?: boolean;
|
|
26
|
+
}): Promise<SessionRecord>;
|
|
27
|
+
touchSession(sessionOrId: SessionRecord | string): Promise<SessionRecord>;
|
|
28
|
+
revokeSession(sessionId: string): Promise<void>;
|
|
29
|
+
revokeAllSessionsForSubject(subjectId: string): Promise<number>;
|
|
30
|
+
listSessionsForSubject(subjectId: string): Promise<SessionRecord[]>;
|
|
31
|
+
private isInactive;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=session-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-service.d.ts","sourceRoot":"","sources":["../../../src/lib/core/session-service.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAChF,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAEnE,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,IAAI,CAAC,gBAAgB,EAAE,mBAAmB,GAAG,uBAAuB,CAAC,CAAC;IAC9E,YAAY,EAAE,YAAY,CAAC;IAC3B,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,UAAU,CAAC,EAAE,WAAW,CAAC;IACzB,MAAM,CAAC,EAAE,UAAU,CAAC;CACrB;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,qBAAqB,CAAU;IAChD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IAC5C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAQ;IAC9B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAc;IACzC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAa;gBAExB,OAAO,EAAE,qBAAqB;IASpC,aAAa,CACjB,SAAS,EAAE,MAAM,EACjB,OAAO,GAAE;QACP,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KAC/B,GACL,OAAO,CAAC,aAAa,CAAC;IAsBnB,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;IAa5D,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,GAAE;QAAE,KAAK,CAAC,EAAE,OAAO,CAAA;KAAO,GAAG,OAAO,CAAC,aAAa,CAAC;IAmBjG,YAAY,CAAC,WAAW,EAAE,aAAa,GAAG,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC;IAkBzE,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK/C,2BAA2B,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAM/D,sBAAsB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;IAMzE,OAAO,CAAC,UAAU;CAGnB"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
import { SessionExpiredError } from '../errors.js';
|
|
3
|
+
import { noopLogger } from './logger.js';
|
|
4
|
+
export class SessionService {
|
|
5
|
+
sessionTtlMs;
|
|
6
|
+
allowSessionExtension;
|
|
7
|
+
sessionStore;
|
|
8
|
+
clock;
|
|
9
|
+
generateId;
|
|
10
|
+
logger;
|
|
11
|
+
constructor(options) {
|
|
12
|
+
this.sessionTtlMs = options.config.sessionTtlSeconds * 1000;
|
|
13
|
+
this.allowSessionExtension = options.config.allowSessionExtension;
|
|
14
|
+
this.sessionStore = options.sessionStore;
|
|
15
|
+
this.clock = options.clock ?? (() => new Date());
|
|
16
|
+
this.generateId = options.generateId ?? randomUUID;
|
|
17
|
+
this.logger = options.logger ?? noopLogger;
|
|
18
|
+
}
|
|
19
|
+
async createSession(subjectId, context = {}) {
|
|
20
|
+
const now = this.clock();
|
|
21
|
+
const session = {
|
|
22
|
+
id: this.generateId(),
|
|
23
|
+
subjectId,
|
|
24
|
+
createdAt: now,
|
|
25
|
+
expiresAt: new Date(now.getTime() + this.sessionTtlMs),
|
|
26
|
+
lastSeenAt: now,
|
|
27
|
+
ipAddress: context.ipAddress,
|
|
28
|
+
userAgent: context.userAgent,
|
|
29
|
+
revokedAt: null,
|
|
30
|
+
metadata: context.metadata,
|
|
31
|
+
};
|
|
32
|
+
await this.sessionStore.create(session);
|
|
33
|
+
this.logger.info('Session created', {
|
|
34
|
+
subjectId,
|
|
35
|
+
sessionId: session.id,
|
|
36
|
+
});
|
|
37
|
+
return session;
|
|
38
|
+
}
|
|
39
|
+
async getSession(sessionId) {
|
|
40
|
+
const session = await this.sessionStore.get(sessionId);
|
|
41
|
+
if (!session) {
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
if (this.isInactive(session, this.clock())) {
|
|
45
|
+
return null;
|
|
46
|
+
}
|
|
47
|
+
return session;
|
|
48
|
+
}
|
|
49
|
+
async assertActiveSession(sessionId, options = {}) {
|
|
50
|
+
const session = await this.sessionStore.get(sessionId);
|
|
51
|
+
const now = this.clock();
|
|
52
|
+
if (!session || this.isInactive(session, now)) {
|
|
53
|
+
if (session) {
|
|
54
|
+
await this.revokeSession(session.id);
|
|
55
|
+
}
|
|
56
|
+
throw new SessionExpiredError();
|
|
57
|
+
}
|
|
58
|
+
if (options.touch !== false) {
|
|
59
|
+
return this.touchSession(session);
|
|
60
|
+
}
|
|
61
|
+
return session;
|
|
62
|
+
}
|
|
63
|
+
async touchSession(sessionOrId) {
|
|
64
|
+
const session = typeof sessionOrId === 'string'
|
|
65
|
+
? await this.assertActiveSession(sessionOrId, { touch: false })
|
|
66
|
+
: sessionOrId;
|
|
67
|
+
const now = this.clock();
|
|
68
|
+
const updated = {
|
|
69
|
+
...session,
|
|
70
|
+
lastSeenAt: now,
|
|
71
|
+
expiresAt: this.allowSessionExtension
|
|
72
|
+
? new Date(now.getTime() + this.sessionTtlMs)
|
|
73
|
+
: session.expiresAt,
|
|
74
|
+
};
|
|
75
|
+
await this.sessionStore.update(updated);
|
|
76
|
+
return updated;
|
|
77
|
+
}
|
|
78
|
+
async revokeSession(sessionId) {
|
|
79
|
+
await this.sessionStore.delete(sessionId);
|
|
80
|
+
this.logger.info('Session revoked', { sessionId });
|
|
81
|
+
}
|
|
82
|
+
async revokeAllSessionsForSubject(subjectId) {
|
|
83
|
+
const count = await this.sessionStore.deleteBySubject(subjectId);
|
|
84
|
+
this.logger.info('All sessions revoked for subject', { subjectId, count });
|
|
85
|
+
return count;
|
|
86
|
+
}
|
|
87
|
+
async listSessionsForSubject(subjectId) {
|
|
88
|
+
const now = this.clock();
|
|
89
|
+
const sessions = await this.sessionStore.listBySubject(subjectId);
|
|
90
|
+
return sessions.filter((session) => !this.isInactive(session, now));
|
|
91
|
+
}
|
|
92
|
+
isInactive(session, now) {
|
|
93
|
+
return Boolean(session.revokedAt) || session.expiresAt.getTime() <= now.getTime();
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=session-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-service.js","sourceRoot":"","sources":["../../../src/lib/core/session-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { Clock, IdGenerator, LoggerPort } from '../ports.js';
|
|
2
|
+
import type { AccessTokenClaims, AuthModuleConfig, AuthSubject, AuthTokens, Permission, RefreshTokenClaims } from '../types.js';
|
|
3
|
+
export interface TokenServiceOptions {
|
|
4
|
+
config: AuthModuleConfig;
|
|
5
|
+
clock?: Clock;
|
|
6
|
+
generateId?: IdGenerator;
|
|
7
|
+
logger?: LoggerPort;
|
|
8
|
+
}
|
|
9
|
+
export declare class TokenService {
|
|
10
|
+
private readonly config;
|
|
11
|
+
private readonly clock;
|
|
12
|
+
private readonly generateId;
|
|
13
|
+
private readonly logger;
|
|
14
|
+
constructor(options: TokenServiceOptions);
|
|
15
|
+
issueTokenPair(subject: AuthSubject, sessionId: string, permissions: Permission[]): AuthTokens;
|
|
16
|
+
verifyAccessToken(token: string): AccessTokenClaims;
|
|
17
|
+
verifyRefreshToken(token: string): RefreshTokenClaims;
|
|
18
|
+
private verify;
|
|
19
|
+
private getSigningKey;
|
|
20
|
+
private getVerificationKey;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=token-service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-service.d.ts","sourceRoot":"","sources":["../../../src/lib/core/token-service.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAClE,OAAO,KAAK,EACV,iBAAiB,EACjB,gBAAgB,EAChB,WAAW,EACX,UAAU,EACV,UAAU,EACV,kBAAkB,EACnB,MAAM,aAAa,CAAC;AAErB,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,gBAAgB,CAAC;IACzB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,UAAU,CAAC,EAAE,WAAW,CAAC;IACzB,MAAM,CAAC,EAAE,UAAU,CAAC;CACrB;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmB;IAC1C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAQ;IAC9B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAc;IACzC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAa;gBAExB,OAAO,EAAE,mBAAmB;IAOxC,cAAc,CAAC,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,GAAG,UAAU;IAkE9F,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,iBAAiB;IAQnD,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,kBAAkB;IAQrD,OAAO,CAAC,MAAM;IAgBd,OAAO,CAAC,aAAa;IAQrB,OAAO,CAAC,kBAAkB;CAO3B"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
import jwt from 'jsonwebtoken';
|
|
3
|
+
import { InvalidTokenError } from '../errors.js';
|
|
4
|
+
import { noopLogger } from './logger.js';
|
|
5
|
+
export class TokenService {
|
|
6
|
+
config;
|
|
7
|
+
clock;
|
|
8
|
+
generateId;
|
|
9
|
+
logger;
|
|
10
|
+
constructor(options) {
|
|
11
|
+
this.config = options.config;
|
|
12
|
+
this.clock = options.clock ?? (() => new Date());
|
|
13
|
+
this.generateId = options.generateId ?? randomUUID;
|
|
14
|
+
this.logger = options.logger ?? noopLogger;
|
|
15
|
+
}
|
|
16
|
+
issueTokenPair(subject, sessionId, permissions) {
|
|
17
|
+
const issuedAt = Math.floor(this.clock().getTime() / 1000);
|
|
18
|
+
const accessTokenId = this.generateId();
|
|
19
|
+
const refreshTokenId = this.generateId();
|
|
20
|
+
const accessToken = jwt.sign({
|
|
21
|
+
sub: subject.id,
|
|
22
|
+
sid: sessionId,
|
|
23
|
+
login: subject.login,
|
|
24
|
+
roles: subject.roles,
|
|
25
|
+
permissions,
|
|
26
|
+
typ: 'access',
|
|
27
|
+
jti: accessTokenId,
|
|
28
|
+
iat: issuedAt,
|
|
29
|
+
attributes: subject.attributes,
|
|
30
|
+
}, this.getSigningKey(), {
|
|
31
|
+
algorithm: this.config.signing.algorithm,
|
|
32
|
+
issuer: this.config.issuer,
|
|
33
|
+
audience: this.config.audience,
|
|
34
|
+
expiresIn: this.config.accessTokenTtlSeconds,
|
|
35
|
+
noTimestamp: true,
|
|
36
|
+
});
|
|
37
|
+
const refreshToken = jwt.sign({
|
|
38
|
+
sub: subject.id,
|
|
39
|
+
sid: sessionId,
|
|
40
|
+
typ: 'refresh',
|
|
41
|
+
jti: refreshTokenId,
|
|
42
|
+
iat: issuedAt,
|
|
43
|
+
}, this.getSigningKey(), {
|
|
44
|
+
algorithm: this.config.signing.algorithm,
|
|
45
|
+
issuer: this.config.issuer,
|
|
46
|
+
audience: this.config.audience,
|
|
47
|
+
expiresIn: this.config.refreshTokenTtlSeconds,
|
|
48
|
+
noTimestamp: true,
|
|
49
|
+
});
|
|
50
|
+
const accessTokenExpiresAt = new Date((issuedAt + this.config.accessTokenTtlSeconds) * 1000);
|
|
51
|
+
const refreshTokenExpiresAt = new Date((issuedAt + this.config.refreshTokenTtlSeconds) * 1000);
|
|
52
|
+
this.logger.info('Token pair issued', {
|
|
53
|
+
subjectId: subject.id,
|
|
54
|
+
sessionId,
|
|
55
|
+
accessTokenId,
|
|
56
|
+
refreshTokenId,
|
|
57
|
+
});
|
|
58
|
+
return {
|
|
59
|
+
accessToken,
|
|
60
|
+
refreshToken,
|
|
61
|
+
tokenType: 'Bearer',
|
|
62
|
+
accessTokenExpiresAt,
|
|
63
|
+
refreshTokenExpiresAt,
|
|
64
|
+
accessTokenId,
|
|
65
|
+
refreshTokenId,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
verifyAccessToken(token) {
|
|
69
|
+
const payload = this.verify(token);
|
|
70
|
+
if (payload.typ !== 'access' || !payload.login || !payload.sid) {
|
|
71
|
+
throw new InvalidTokenError('Invalid access token');
|
|
72
|
+
}
|
|
73
|
+
return payload;
|
|
74
|
+
}
|
|
75
|
+
verifyRefreshToken(token) {
|
|
76
|
+
const payload = this.verify(token);
|
|
77
|
+
if (payload.typ !== 'refresh' || !payload.sid) {
|
|
78
|
+
throw new InvalidTokenError('Invalid refresh token');
|
|
79
|
+
}
|
|
80
|
+
return payload;
|
|
81
|
+
}
|
|
82
|
+
verify(token) {
|
|
83
|
+
try {
|
|
84
|
+
return jwt.verify(token, this.getVerificationKey(), {
|
|
85
|
+
algorithms: [this.config.signing.algorithm],
|
|
86
|
+
issuer: this.config.issuer,
|
|
87
|
+
audience: this.config.audience,
|
|
88
|
+
clockTimestamp: Math.floor(this.clock().getTime() / 1000),
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
catch (error) {
|
|
92
|
+
this.logger.warn('Token verification failed', {
|
|
93
|
+
err: error,
|
|
94
|
+
});
|
|
95
|
+
throw new InvalidTokenError();
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
getSigningKey() {
|
|
99
|
+
if (this.config.signing.algorithm === 'RS256') {
|
|
100
|
+
return this.config.signing.privateKey;
|
|
101
|
+
}
|
|
102
|
+
return this.config.signing.secret;
|
|
103
|
+
}
|
|
104
|
+
getVerificationKey() {
|
|
105
|
+
if (this.config.signing.algorithm === 'RS256') {
|
|
106
|
+
return this.config.signing.publicKey;
|
|
107
|
+
}
|
|
108
|
+
return this.config.signing.secret;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
//# sourceMappingURL=token-service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-service.js","sourceRoot":"","sources":["../../../src/lib/core/token-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare class AuthError extends Error {
|
|
2
|
+
readonly code: string;
|
|
3
|
+
readonly statusCode: number;
|
|
4
|
+
constructor(message: string, code: string, statusCode: number);
|
|
5
|
+
}
|
|
6
|
+
export declare class ConfigurationError extends AuthError {
|
|
7
|
+
constructor(message: string);
|
|
8
|
+
}
|
|
9
|
+
export declare class AuthenticationError extends AuthError {
|
|
10
|
+
constructor(message: string, code?: string);
|
|
11
|
+
}
|
|
12
|
+
export declare class AuthorizationError extends AuthError {
|
|
13
|
+
constructor(message: string, code?: string);
|
|
14
|
+
}
|
|
15
|
+
export declare class InvalidTokenError extends AuthenticationError {
|
|
16
|
+
constructor(message?: string);
|
|
17
|
+
}
|
|
18
|
+
export declare class SessionExpiredError extends AuthenticationError {
|
|
19
|
+
constructor(message?: string);
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=errors.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../../src/lib/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,SAAU,SAAQ,KAAK;aAGhB,IAAI,EAAE,MAAM;aACZ,UAAU,EAAE,MAAM;gBAFlC,OAAO,EAAE,MAAM,EACC,IAAI,EAAE,MAAM,EACZ,UAAU,EAAE,MAAM;CAKrC;AAED,qBAAa,kBAAmB,SAAQ,SAAS;gBACnC,OAAO,EAAE,MAAM;CAG5B;AAED,qBAAa,mBAAoB,SAAQ,SAAS;gBACpC,OAAO,EAAE,MAAM,EAAE,IAAI,GAAE,MAA+B;CAGnE;AAED,qBAAa,kBAAmB,SAAQ,SAAS;gBACnC,OAAO,EAAE,MAAM,EAAE,IAAI,GAAE,MAA8B;CAGlE;AAED,qBAAa,iBAAkB,SAAQ,mBAAmB;gBAC5C,OAAO,GAAE,MAAwB;CAG9C;AAED,qBAAa,mBAAoB,SAAQ,mBAAmB;gBAC9C,OAAO,GAAE,MAA0B;CAGhD"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export class AuthError extends Error {
|
|
2
|
+
code;
|
|
3
|
+
statusCode;
|
|
4
|
+
constructor(message, code, statusCode) {
|
|
5
|
+
super(message);
|
|
6
|
+
this.code = code;
|
|
7
|
+
this.statusCode = statusCode;
|
|
8
|
+
this.name = new.target.name;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export class ConfigurationError extends AuthError {
|
|
12
|
+
constructor(message) {
|
|
13
|
+
super(message, 'CONFIGURATION_ERROR', 500);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export class AuthenticationError extends AuthError {
|
|
17
|
+
constructor(message, code = 'AUTHENTICATION_ERROR') {
|
|
18
|
+
super(message, code, 401);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export class AuthorizationError extends AuthError {
|
|
22
|
+
constructor(message, code = 'AUTHORIZATION_ERROR') {
|
|
23
|
+
super(message, code, 403);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export class InvalidTokenError extends AuthenticationError {
|
|
27
|
+
constructor(message = 'Invalid token') {
|
|
28
|
+
super(message, 'INVALID_TOKEN');
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export class SessionExpiredError extends AuthenticationError {
|
|
32
|
+
constructor(message = 'Session expired') {
|
|
33
|
+
super(message, 'SESSION_EXPIRED');
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/lib/errors.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,SAAU,SAAQ,KAAK;IAGhB;IACA;IAHlB,YACE,OAAe,EACC,IAAY,EACZ,UAAkB;QAElC,KAAK,CAAC,OAAO,CAAC,CAAC;QAHC,SAAI,GAAJ,IAAI,CAAQ;QACZ,eAAU,GAAV,UAAU,CAAQ;QAGlC,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;IAC9B,CAAC;CACF;AAED,MAAM,OAAO,kBAAmB,SAAQ,SAAS;IAC/C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,qBAAqB,EAAE,GAAG,CAAC,CAAC;IAC7C,CAAC;CACF;AAED,MAAM,OAAO,mBAAoB,SAAQ,SAAS;IAChD,YAAY,OAAe,EAAE,OAAe,sBAAsB;QAChE,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;IAC5B,CAAC;CACF;AAED,MAAM,OAAO,kBAAmB,SAAQ,SAAS;IAC/C,YAAY,OAAe,EAAE,OAAe,qBAAqB;QAC/D,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC;IAC5B,CAAC;CACF;AAED,MAAM,OAAO,iBAAkB,SAAQ,mBAAmB;IACxD,YAAY,UAAkB,eAAe;QAC3C,KAAK,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;IAClC,CAAC;CACF;AAED,MAAM,OAAO,mBAAoB,SAAQ,mBAAmB;IAC1D,YAAY,UAAkB,iBAAiB;QAC7C,KAAK,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC;IACpC,CAAC;CACF"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { AuthSubject, LoginInput, RefreshTokenRecord, SessionRecord } from './types.js';
|
|
2
|
+
export interface IdentityProvider {
|
|
3
|
+
verifyCredentials(input: LoginInput): Promise<AuthSubject | null>;
|
|
4
|
+
getSubjectById(subjectId: string): Promise<AuthSubject | null>;
|
|
5
|
+
}
|
|
6
|
+
export interface SessionStore {
|
|
7
|
+
create(session: SessionRecord): Promise<void>;
|
|
8
|
+
get(sessionId: string): Promise<SessionRecord | null>;
|
|
9
|
+
update(session: SessionRecord): Promise<void>;
|
|
10
|
+
delete(sessionId: string): Promise<void>;
|
|
11
|
+
deleteBySubject(subjectId: string): Promise<number>;
|
|
12
|
+
listBySubject(subjectId: string): Promise<SessionRecord[]>;
|
|
13
|
+
}
|
|
14
|
+
export interface RefreshTokenStore {
|
|
15
|
+
save(record: RefreshTokenRecord): Promise<void>;
|
|
16
|
+
get(tokenId: string): Promise<RefreshTokenRecord | null>;
|
|
17
|
+
revoke(tokenId: string): Promise<void>;
|
|
18
|
+
revokeBySession(sessionId: string): Promise<number>;
|
|
19
|
+
}
|
|
20
|
+
export interface PasswordVerifier {
|
|
21
|
+
verify(plainText: string, passwordHash: string): Promise<boolean>;
|
|
22
|
+
}
|
|
23
|
+
export interface LoggerPort {
|
|
24
|
+
debug(message: string, fields?: Record<string, unknown>): void;
|
|
25
|
+
info(message: string, fields?: Record<string, unknown>): void;
|
|
26
|
+
warn(message: string, fields?: Record<string, unknown>): void;
|
|
27
|
+
error(message: string, fields?: Record<string, unknown>): void;
|
|
28
|
+
child?(fields: Record<string, unknown>): LoggerPort;
|
|
29
|
+
}
|
|
30
|
+
export type Clock = () => Date;
|
|
31
|
+
export type IdGenerator = () => string;
|
|
32
|
+
//# sourceMappingURL=ports.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ports.d.ts","sourceRoot":"","sources":["../../src/lib/ports.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE7F,MAAM,WAAW,gBAAgB;IAC/B,iBAAiB,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;IAClE,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC;CAChE;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9C,GAAG,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,CAAC;IACtD,MAAM,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9C,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzC,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACpD,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;CAC5D;AAED,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAChD,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC,CAAC;IACzD,MAAM,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACvC,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CACrD;AAED,MAAM,WAAW,gBAAgB;IAC/B,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACnE;AAED,MAAM,WAAW,UAAU;IACzB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC9D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC9D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/D,KAAK,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,UAAU,CAAC;CACrD;AAED,MAAM,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC;AAC/B,MAAM,MAAM,WAAW,GAAG,MAAM,MAAM,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ports.js","sourceRoot":"","sources":["../../src/lib/ports.ts"],"names":[],"mappings":""}
|