@adgenit/shared 0.1.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/lib/auth/AuthenticatedRequest.d.ts +20 -0
- package/lib/auth/AuthenticatedRequest.d.ts.map +1 -0
- package/lib/auth/AuthenticatedRequest.js +2 -0
- package/lib/auth/AuthenticatedRequest.js.map +1 -0
- package/lib/auth/ServiceAuthMiddleware.d.ts +4 -0
- package/lib/auth/ServiceAuthMiddleware.d.ts.map +1 -0
- package/lib/auth/ServiceAuthMiddleware.js +19 -0
- package/lib/auth/ServiceAuthMiddleware.js.map +1 -0
- package/lib/auth/ServiceTokenProvider.d.ts +11 -0
- package/lib/auth/ServiceTokenProvider.d.ts.map +1 -0
- package/lib/auth/ServiceTokenProvider.js +11 -0
- package/lib/auth/ServiceTokenProvider.js.map +1 -0
- package/lib/auth/ServiceTokenVerifier.d.ts +7 -0
- package/lib/auth/ServiceTokenVerifier.d.ts.map +1 -0
- package/lib/auth/ServiceTokenVerifier.js +18 -0
- package/lib/auth/ServiceTokenVerifier.js.map +1 -0
- package/lib/auth/UserContextClient.d.ts +23 -0
- package/lib/auth/UserContextClient.d.ts.map +1 -0
- package/lib/auth/UserContextClient.js +40 -0
- package/lib/auth/UserContextClient.js.map +1 -0
- package/lib/auth/UserContextMiddleware.d.ts +4 -0
- package/lib/auth/UserContextMiddleware.d.ts.map +1 -0
- package/lib/auth/UserContextMiddleware.js +23 -0
- package/lib/auth/UserContextMiddleware.js.map +1 -0
- package/lib/auth/index.d.ts +8 -0
- package/lib/auth/index.d.ts.map +1 -0
- package/lib/auth/index.js +6 -0
- package/lib/auth/index.js.map +1 -0
- package/lib/errors/AdGenError.d.ts +21 -0
- package/lib/errors/AdGenError.d.ts.map +1 -0
- package/lib/errors/AdGenError.js +39 -0
- package/lib/errors/AdGenError.js.map +1 -0
- package/lib/errors/errorMiddleware.d.ts +11 -0
- package/lib/errors/errorMiddleware.d.ts.map +1 -0
- package/lib/errors/errorMiddleware.js +17 -0
- package/lib/errors/errorMiddleware.js.map +1 -0
- package/lib/index.d.ts +13 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +8 -0
- package/lib/index.js.map +1 -0
- package/lib/rateLimit/RateLimiter.d.ts +22 -0
- package/lib/rateLimit/RateLimiter.d.ts.map +1 -0
- package/lib/rateLimit/RateLimiter.js +40 -0
- package/lib/rateLimit/RateLimiter.js.map +1 -0
- package/lib/rateLimit/rateLimitMiddleware.d.ts +9 -0
- package/lib/rateLimit/rateLimitMiddleware.d.ts.map +1 -0
- package/lib/rateLimit/rateLimitMiddleware.js +21 -0
- package/lib/rateLimit/rateLimitMiddleware.js.map +1 -0
- package/lib/requestId/requestIdMiddleware.d.ts +4 -0
- package/lib/requestId/requestIdMiddleware.d.ts.map +1 -0
- package/lib/requestId/requestIdMiddleware.js +11 -0
- package/lib/requestId/requestIdMiddleware.js.map +1 -0
- package/lib/validation/validate.d.ts +9 -0
- package/lib/validation/validate.d.ts.map +1 -0
- package/lib/validation/validate.js +23 -0
- package/lib/validation/validate.js.map +1 -0
- package/package.json +38 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { Request } from 'express';
|
|
2
|
+
export interface UserContext {
|
|
3
|
+
userId: string;
|
|
4
|
+
email: string;
|
|
5
|
+
plan: string;
|
|
6
|
+
}
|
|
7
|
+
export interface IntrospectedUser extends UserContext {
|
|
8
|
+
fullName: string;
|
|
9
|
+
emailVerified: boolean;
|
|
10
|
+
}
|
|
11
|
+
export interface ServiceTokenPayload {
|
|
12
|
+
type: 'service';
|
|
13
|
+
serviceId: string;
|
|
14
|
+
scopes?: string[];
|
|
15
|
+
}
|
|
16
|
+
export interface AuthenticatedRequest extends Request {
|
|
17
|
+
user?: UserContext;
|
|
18
|
+
service?: ServiceTokenPayload;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=AuthenticatedRequest.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthenticatedRequest.d.ts","sourceRoot":"","sources":["../../src/auth/AuthenticatedRequest.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAEvC,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,gBAAiB,SAAQ,WAAW;IACnD,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,SAAS,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,MAAM,WAAW,oBAAqB,SAAQ,OAAO;IACnD,IAAI,CAAC,EAAE,WAAW,CAAC;IACnB,OAAO,CAAC,EAAE,mBAAmB,CAAC;CAC/B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthenticatedRequest.js","sourceRoot":"","sources":["../../src/auth/AuthenticatedRequest.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
import { ServiceTokenVerifier } from './ServiceTokenVerifier.js';
|
|
3
|
+
export declare function serviceAuthMiddleware(verifier: ServiceTokenVerifier): (req: Request, res: Response, next: NextFunction) => void;
|
|
4
|
+
//# sourceMappingURL=ServiceAuthMiddleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceAuthMiddleware.d.ts","sourceRoot":"","sources":["../../src/auth/ServiceAuthMiddleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAGjE,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,oBAAoB,IAC1D,KAAK,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,KAAG,IAAI,CAkB/D"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export function serviceAuthMiddleware(verifier) {
|
|
2
|
+
return (req, res, next) => {
|
|
3
|
+
const authHeader = req.headers.authorization;
|
|
4
|
+
if (authHeader === undefined || !authHeader.startsWith('Bearer ')) {
|
|
5
|
+
res.status(401).json({ error: 'Missing or invalid service authorization header' });
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
const token = authHeader.slice(7);
|
|
9
|
+
try {
|
|
10
|
+
const payload = verifier.verify(token);
|
|
11
|
+
req.service = payload;
|
|
12
|
+
next();
|
|
13
|
+
}
|
|
14
|
+
catch {
|
|
15
|
+
res.status(403).json({ error: 'Invalid or expired service token' });
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=ServiceAuthMiddleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceAuthMiddleware.js","sourceRoot":"","sources":["../../src/auth/ServiceAuthMiddleware.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,qBAAqB,CAAC,QAA8B;IAClE,OAAO,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAQ,EAAE;QAC/D,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC;QAE7C,IAAI,UAAU,KAAK,SAAS,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAClE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,iDAAiD,EAAE,CAAC,CAAC;YACnF,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAElC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACtC,GAA4B,CAAC,OAAO,GAAG,OAAO,CAAC;YAChD,IAAI,EAAE,CAAC;QACT,CAAC;QAAC,MAAM,CAAC;YACP,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,kCAAkC,EAAE,CAAC,CAAC;QACtE,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface ServiceTokenPayload {
|
|
2
|
+
type: 'service';
|
|
3
|
+
serviceId: string;
|
|
4
|
+
scopes?: string[];
|
|
5
|
+
}
|
|
6
|
+
export declare class ServiceTokenProvider {
|
|
7
|
+
private readonly secret;
|
|
8
|
+
constructor(secret: string);
|
|
9
|
+
sign(serviceId: string, scopes?: string[], expiresIn?: string | number): string;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=ServiceTokenProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceTokenProvider.d.ts","sourceRoot":"","sources":["../../src/auth/ServiceTokenProvider.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,SAAS,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,qBAAa,oBAAoB;IACnB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAE3C,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,SAAS,GAAE,MAAM,GAAG,MAAa,GAAG,MAAM;CAOtF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import jwt from 'jsonwebtoken';
|
|
2
|
+
export class ServiceTokenProvider {
|
|
3
|
+
secret;
|
|
4
|
+
constructor(secret) {
|
|
5
|
+
this.secret = secret;
|
|
6
|
+
}
|
|
7
|
+
sign(serviceId, scopes, expiresIn = '1h') {
|
|
8
|
+
return jwt.sign({ type: 'service', serviceId, scopes }, this.secret, { expiresIn });
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=ServiceTokenProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceTokenProvider.js","sourceRoot":"","sources":["../../src/auth/ServiceTokenProvider.ts"],"names":[],"mappings":"AAAA,OAAO,GAAyB,MAAM,cAAc,CAAC;AAQrD,MAAM,OAAO,oBAAoB;IACF;IAA7B,YAA6B,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;IAAG,CAAC;IAE/C,IAAI,CAAC,SAAiB,EAAE,MAAiB,EAAE,YAA6B,IAAI;QAC1E,OAAO,GAAG,CAAC,IAAI,CACb,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,EAAyB,EAC7D,IAAI,CAAC,MAAM,EACX,EAAE,SAAS,EAAiB,CAC7B,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ServiceTokenPayload } from './AuthenticatedRequest.js';
|
|
2
|
+
export declare class ServiceTokenVerifier {
|
|
3
|
+
private readonly secret;
|
|
4
|
+
constructor(secret: string);
|
|
5
|
+
verify(token: string): ServiceTokenPayload;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=ServiceTokenVerifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceTokenVerifier.d.ts","sourceRoot":"","sources":["../../src/auth/ServiceTokenVerifier.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAErE,qBAAa,oBAAoB;IACnB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAE3C,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,mBAAmB;CAc3C"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import jwt from 'jsonwebtoken';
|
|
2
|
+
export class ServiceTokenVerifier {
|
|
3
|
+
secret;
|
|
4
|
+
constructor(secret) {
|
|
5
|
+
this.secret = secret;
|
|
6
|
+
}
|
|
7
|
+
verify(token) {
|
|
8
|
+
const decoded = jwt.verify(token, this.secret);
|
|
9
|
+
if (typeof decoded !== 'object' ||
|
|
10
|
+
decoded === null ||
|
|
11
|
+
decoded.type !== 'service' ||
|
|
12
|
+
typeof decoded.serviceId !== 'string') {
|
|
13
|
+
throw new Error('Invalid service token payload');
|
|
14
|
+
}
|
|
15
|
+
return decoded;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=ServiceTokenVerifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ServiceTokenVerifier.js","sourceRoot":"","sources":["../../src/auth/ServiceTokenVerifier.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,cAAc,CAAC;AAG/B,MAAM,OAAO,oBAAoB;IACF;IAA7B,YAA6B,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;IAAG,CAAC;IAE/C,MAAM,CAAC,KAAa;QAClB,MAAM,OAAO,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAE/C,IACE,OAAO,OAAO,KAAK,QAAQ;YAC3B,OAAO,KAAK,IAAI;YAChB,OAAO,CAAC,IAAI,KAAK,SAAS;YAC1B,OAAO,OAAO,CAAC,SAAS,KAAK,QAAQ,EACrC,CAAC;YACD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACnD,CAAC;QAED,OAAO,OAA8B,CAAC;IACxC,CAAC;CACF"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { UserContext, IntrospectedUser } from './AuthenticatedRequest.js';
|
|
2
|
+
export interface UserContextClientOptions {
|
|
3
|
+
baseUrl: string;
|
|
4
|
+
serviceToken: string;
|
|
5
|
+
fetchImpl?: typeof fetch;
|
|
6
|
+
}
|
|
7
|
+
export interface VerifyResponse {
|
|
8
|
+
valid: boolean;
|
|
9
|
+
user?: UserContext;
|
|
10
|
+
}
|
|
11
|
+
export interface IntrospectResponse {
|
|
12
|
+
active: boolean;
|
|
13
|
+
user?: IntrospectedUser;
|
|
14
|
+
}
|
|
15
|
+
export declare class UserContextClient {
|
|
16
|
+
private readonly baseUrl;
|
|
17
|
+
private readonly serviceToken;
|
|
18
|
+
private readonly fetchImpl;
|
|
19
|
+
constructor(options: UserContextClientOptions);
|
|
20
|
+
verify(token: string): Promise<UserContext | null>;
|
|
21
|
+
introspect(token: string): Promise<IntrospectResponse | null>;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=UserContextClient.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserContextClient.d.ts","sourceRoot":"","sources":["../../src/auth/UserContextClient.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAE/E,MAAM,WAAW,wBAAwB;IACvC,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,OAAO,KAAK,CAAC;CAC1B;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,OAAO,CAAC;IACf,IAAI,CAAC,EAAE,WAAW,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,OAAO,CAAC;IAChB,IAAI,CAAC,EAAE,gBAAgB,CAAC;CACzB;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAe;gBAE7B,OAAO,EAAE,wBAAwB;IAMvC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAkBlD,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;CAgBpE"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export class UserContextClient {
|
|
2
|
+
baseUrl;
|
|
3
|
+
serviceToken;
|
|
4
|
+
fetchImpl;
|
|
5
|
+
constructor(options) {
|
|
6
|
+
this.baseUrl = options.baseUrl.replace(/\/$/, '');
|
|
7
|
+
this.serviceToken = options.serviceToken;
|
|
8
|
+
this.fetchImpl = options.fetchImpl ?? fetch;
|
|
9
|
+
}
|
|
10
|
+
async verify(token) {
|
|
11
|
+
const res = await this.fetchImpl(`${this.baseUrl}/internal/auth/verify`, {
|
|
12
|
+
method: 'POST',
|
|
13
|
+
headers: {
|
|
14
|
+
'Content-Type': 'application/json',
|
|
15
|
+
Authorization: `Bearer ${this.serviceToken}`,
|
|
16
|
+
},
|
|
17
|
+
body: JSON.stringify({ token }),
|
|
18
|
+
});
|
|
19
|
+
if (!res.ok) {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
const body = (await res.json());
|
|
23
|
+
return body.valid && body.user !== undefined ? body.user : null;
|
|
24
|
+
}
|
|
25
|
+
async introspect(token) {
|
|
26
|
+
const res = await this.fetchImpl(`${this.baseUrl}/internal/auth/introspect`, {
|
|
27
|
+
method: 'POST',
|
|
28
|
+
headers: {
|
|
29
|
+
'Content-Type': 'application/json',
|
|
30
|
+
Authorization: `Bearer ${this.serviceToken}`,
|
|
31
|
+
},
|
|
32
|
+
body: JSON.stringify({ token }),
|
|
33
|
+
});
|
|
34
|
+
if (!res.ok) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
return (await res.json());
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=UserContextClient.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserContextClient.js","sourceRoot":"","sources":["../../src/auth/UserContextClient.ts"],"names":[],"mappings":"AAkBA,MAAM,OAAO,iBAAiB;IACX,OAAO,CAAS;IAChB,YAAY,CAAS;IACrB,SAAS,CAAe;IAEzC,YAAY,OAAiC;QAC3C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAClD,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;QACzC,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,KAAK,CAAC;IAC9C,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,KAAa;QACxB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,OAAO,uBAAuB,EAAE;YACvE,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,UAAU,IAAI,CAAC,YAAY,EAAE;aAC7C;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,CAAC;SAChC,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACZ,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAmB,CAAC;QAClD,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAClE,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,KAAa;QAC5B,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,OAAO,2BAA2B,EAAE;YAC3E,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,UAAU,IAAI,CAAC,YAAY,EAAE;aAC7C;YACD,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,CAAC;SAChC,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;YACZ,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,EAAE,CAAuB,CAAC;IAClD,CAAC;CACF"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
import { UserContextClient } from './UserContextClient.js';
|
|
3
|
+
export declare function userContextMiddleware(client: UserContextClient): (req: Request, res: Response, next: NextFunction) => Promise<void>;
|
|
4
|
+
//# sourceMappingURL=UserContextMiddleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserContextMiddleware.d.ts","sourceRoot":"","sources":["../../src/auth/UserContextMiddleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAG3D,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,iBAAiB,IAC/C,KAAK,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,KAAG,OAAO,CAAC,IAAI,CAAC,CAwB9E"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export function userContextMiddleware(client) {
|
|
2
|
+
return async (req, res, next) => {
|
|
3
|
+
const authHeader = req.headers.authorization;
|
|
4
|
+
if (authHeader === undefined || !authHeader.startsWith('Bearer ')) {
|
|
5
|
+
res.status(401).json({ error: 'Missing or invalid authorization header' });
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
const token = authHeader.slice(7);
|
|
9
|
+
try {
|
|
10
|
+
const context = await client.verify(token);
|
|
11
|
+
if (context === null) {
|
|
12
|
+
res.status(401).json({ error: 'Invalid or expired token' });
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
req.user = context;
|
|
16
|
+
next();
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
res.status(401).json({ error: 'Invalid or expired token' });
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=UserContextMiddleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserContextMiddleware.js","sourceRoot":"","sources":["../../src/auth/UserContextMiddleware.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,qBAAqB,CAAC,MAAyB;IAC7D,OAAO,KAAK,EAAE,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAiB,EAAE;QAC9E,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC;QAE7C,IAAI,UAAU,KAAK,SAAS,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAClE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,yCAAyC,EAAE,CAAC,CAAC;YAC3E,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAElC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAE3C,IAAI,OAAO,KAAK,IAAI,EAAE,CAAC;gBACrB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,0BAA0B,EAAE,CAAC,CAAC;gBAC5D,OAAO;YACT,CAAC;YAEA,GAA4B,CAAC,IAAI,GAAG,OAAO,CAAC;YAC7C,IAAI,EAAE,CAAC;QACT,CAAC;QAAC,MAAM,CAAC;YACP,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,0BAA0B,EAAE,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { UserContextClient } from './UserContextClient.js';
|
|
2
|
+
export { userContextMiddleware } from './UserContextMiddleware.js';
|
|
3
|
+
export { ServiceTokenProvider } from './ServiceTokenProvider.js';
|
|
4
|
+
export { ServiceTokenVerifier } from './ServiceTokenVerifier.js';
|
|
5
|
+
export { serviceAuthMiddleware } from './ServiceAuthMiddleware.js';
|
|
6
|
+
export type { UserContext, IntrospectedUser, ServiceTokenPayload, AuthenticatedRequest, } from './AuthenticatedRequest.js';
|
|
7
|
+
export type { UserContextClientOptions, VerifyResponse, IntrospectResponse } from './UserContextClient.js';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,YAAY,EACV,WAAW,EACX,gBAAgB,EAChB,mBAAmB,EACnB,oBAAoB,GACrB,MAAM,2BAA2B,CAAC;AACnC,YAAY,EAAE,wBAAwB,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { UserContextClient } from './UserContextClient.js';
|
|
2
|
+
export { userContextMiddleware } from './UserContextMiddleware.js';
|
|
3
|
+
export { ServiceTokenProvider } from './ServiceTokenProvider.js';
|
|
4
|
+
export { ServiceTokenVerifier } from './ServiceTokenVerifier.js';
|
|
5
|
+
export { serviceAuthMiddleware } from './ServiceAuthMiddleware.js';
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/auth/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export type ErrorCode = 'BAD_REQUEST' | 'UNAUTHORIZED' | 'FORBIDDEN' | 'NOT_FOUND' | 'CONFLICT' | 'RATE_LIMITED' | 'INTERNAL_ERROR' | 'SERVICE_UNAVAILABLE';
|
|
2
|
+
export interface ErrorDetails {
|
|
3
|
+
field?: string;
|
|
4
|
+
message: string;
|
|
5
|
+
}
|
|
6
|
+
export declare class AdGenError extends Error {
|
|
7
|
+
readonly statusCode: number;
|
|
8
|
+
readonly code: ErrorCode;
|
|
9
|
+
readonly details?: ErrorDetails[];
|
|
10
|
+
readonly isOperational: boolean;
|
|
11
|
+
constructor(statusCode: number, code: ErrorCode, message: string, details?: ErrorDetails[], isOperational?: boolean);
|
|
12
|
+
static badRequest(message: string, details?: ErrorDetails[]): AdGenError;
|
|
13
|
+
static unauthorized(message?: string): AdGenError;
|
|
14
|
+
static forbidden(message?: string): AdGenError;
|
|
15
|
+
static notFound(message?: string): AdGenError;
|
|
16
|
+
static conflict(message: string): AdGenError;
|
|
17
|
+
static rateLimited(message?: string): AdGenError;
|
|
18
|
+
static internal(message?: string): AdGenError;
|
|
19
|
+
static unavailable(message?: string): AdGenError;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=AdGenError.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AdGenError.d.ts","sourceRoot":"","sources":["../../src/errors/AdGenError.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,GACjB,aAAa,GACb,cAAc,GACd,WAAW,GACX,WAAW,GACX,UAAU,GACV,cAAc,GACd,gBAAgB,GAChB,qBAAqB,CAAC;AAE1B,MAAM,WAAW,YAAY;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,UAAW,SAAQ,KAAK;IACnC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,IAAI,EAAE,SAAS,CAAC;IAChC,SAAgB,OAAO,CAAC,EAAE,YAAY,EAAE,CAAC;IACzC,SAAgB,aAAa,EAAE,OAAO,CAAC;gBAGrC,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE,SAAS,EACf,OAAO,EAAE,MAAM,EACf,OAAO,CAAC,EAAE,YAAY,EAAE,EACxB,aAAa,UAAO;IAUtB,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,YAAY,EAAE,GAAG,UAAU;IAIxE,MAAM,CAAC,YAAY,CAAC,OAAO,SAAiB,GAAG,UAAU;IAIzD,MAAM,CAAC,SAAS,CAAC,OAAO,SAAc,GAAG,UAAU;IAInD,MAAM,CAAC,QAAQ,CAAC,OAAO,SAAc,GAAG,UAAU;IAIlD,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU;IAI5C,MAAM,CAAC,WAAW,CAAC,OAAO,SAAsB,GAAG,UAAU;IAI7D,MAAM,CAAC,QAAQ,CAAC,OAAO,SAA0B,GAAG,UAAU;IAI9D,MAAM,CAAC,WAAW,CAAC,OAAO,SAAwB,GAAG,UAAU;CAGhE"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export class AdGenError extends Error {
|
|
2
|
+
statusCode;
|
|
3
|
+
code;
|
|
4
|
+
details;
|
|
5
|
+
isOperational;
|
|
6
|
+
constructor(statusCode, code, message, details, isOperational = true) {
|
|
7
|
+
super(message);
|
|
8
|
+
this.statusCode = statusCode;
|
|
9
|
+
this.code = code;
|
|
10
|
+
this.details = details;
|
|
11
|
+
this.isOperational = isOperational;
|
|
12
|
+
Object.setPrototypeOf(this, AdGenError.prototype);
|
|
13
|
+
}
|
|
14
|
+
static badRequest(message, details) {
|
|
15
|
+
return new AdGenError(400, 'BAD_REQUEST', message, details);
|
|
16
|
+
}
|
|
17
|
+
static unauthorized(message = 'Unauthorized') {
|
|
18
|
+
return new AdGenError(401, 'UNAUTHORIZED', message);
|
|
19
|
+
}
|
|
20
|
+
static forbidden(message = 'Forbidden') {
|
|
21
|
+
return new AdGenError(403, 'FORBIDDEN', message);
|
|
22
|
+
}
|
|
23
|
+
static notFound(message = 'Not found') {
|
|
24
|
+
return new AdGenError(404, 'NOT_FOUND', message);
|
|
25
|
+
}
|
|
26
|
+
static conflict(message) {
|
|
27
|
+
return new AdGenError(409, 'CONFLICT', message);
|
|
28
|
+
}
|
|
29
|
+
static rateLimited(message = 'Too many requests') {
|
|
30
|
+
return new AdGenError(429, 'RATE_LIMITED', message);
|
|
31
|
+
}
|
|
32
|
+
static internal(message = 'Internal server error') {
|
|
33
|
+
return new AdGenError(500, 'INTERNAL_ERROR', message, undefined, false);
|
|
34
|
+
}
|
|
35
|
+
static unavailable(message = 'Service unavailable') {
|
|
36
|
+
return new AdGenError(503, 'SERVICE_UNAVAILABLE', message);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=AdGenError.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AdGenError.js","sourceRoot":"","sources":["../../src/errors/AdGenError.ts"],"names":[],"mappings":"AAeA,MAAM,OAAO,UAAW,SAAQ,KAAK;IACnB,UAAU,CAAS;IACnB,IAAI,CAAY;IAChB,OAAO,CAAkB;IACzB,aAAa,CAAU;IAEvC,YACE,UAAkB,EAClB,IAAe,EACf,OAAe,EACf,OAAwB,EACxB,aAAa,GAAG,IAAI;QAEpB,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QACnC,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;IAED,MAAM,CAAC,UAAU,CAAC,OAAe,EAAE,OAAwB;QACzD,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,aAAa,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAC9D,CAAC;IAED,MAAM,CAAC,YAAY,CAAC,OAAO,GAAG,cAAc;QAC1C,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,CAAC,SAAS,CAAC,OAAO,GAAG,WAAW;QACpC,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,OAAO,GAAG,WAAW;QACnC,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;IACnD,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,OAAe;QAC7B,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;IAClD,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,OAAO,GAAG,mBAAmB;QAC9C,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,cAAc,EAAE,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,OAAO,GAAG,uBAAuB;QAC/C,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,gBAAgB,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;IAC1E,CAAC;IAED,MAAM,CAAC,WAAW,CAAC,OAAO,GAAG,qBAAqB;QAChD,OAAO,IAAI,UAAU,CAAC,GAAG,EAAE,qBAAqB,EAAE,OAAO,CAAC,CAAC;IAC7D,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
export interface ErrorResponse {
|
|
3
|
+
error: string;
|
|
4
|
+
code: string;
|
|
5
|
+
details?: Array<{
|
|
6
|
+
field?: string;
|
|
7
|
+
message: string;
|
|
8
|
+
}>;
|
|
9
|
+
}
|
|
10
|
+
export declare function errorMiddleware(err: Error, _req: Request, res: Response, _next: NextFunction): void;
|
|
11
|
+
//# sourceMappingURL=errorMiddleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorMiddleware.d.ts","sourceRoot":"","sources":["../../src/errors/errorMiddleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAG/D,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,KAAK,CAAC;QAAE,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CACtD;AAED,wBAAgB,eAAe,CAC7B,GAAG,EAAE,KAAK,EACV,IAAI,EAAE,OAAO,EACb,GAAG,EAAE,QAAQ,EACb,KAAK,EAAE,YAAY,GAClB,IAAI,CAiBN"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { AdGenError } from './AdGenError.js';
|
|
2
|
+
export function errorMiddleware(err, _req, res, _next) {
|
|
3
|
+
if (err instanceof AdGenError) {
|
|
4
|
+
const body = {
|
|
5
|
+
error: err.message,
|
|
6
|
+
code: err.code,
|
|
7
|
+
};
|
|
8
|
+
if (err.details !== undefined && err.details.length > 0) {
|
|
9
|
+
body.details = err.details;
|
|
10
|
+
}
|
|
11
|
+
res.status(err.statusCode).json(body);
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
console.error('Unhandled error', err);
|
|
15
|
+
res.status(500).json({ error: 'Internal server error', code: 'INTERNAL_ERROR' });
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=errorMiddleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorMiddleware.js","sourceRoot":"","sources":["../../src/errors/errorMiddleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAQ7C,MAAM,UAAU,eAAe,CAC7B,GAAU,EACV,IAAa,EACb,GAAa,EACb,KAAmB;IAEnB,IAAI,GAAG,YAAY,UAAU,EAAE,CAAC;QAC9B,MAAM,IAAI,GAAkB;YAC1B,KAAK,EAAE,GAAG,CAAC,OAAO;YAClB,IAAI,EAAE,GAAG,CAAC,IAAI;SACf,CAAC;QAEF,IAAI,GAAG,CAAC,OAAO,KAAK,SAAS,IAAI,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxD,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC;QAC7B,CAAC;QAED,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtC,OAAO;IACT,CAAC;IAED,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE,GAAG,CAAC,CAAC;IACtC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,uBAAuB,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAAC,CAAC;AACnF,CAAC"}
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export { AdGenError } from './errors/AdGenError.js';
|
|
2
|
+
export { errorMiddleware } from './errors/errorMiddleware.js';
|
|
3
|
+
export type { ErrorCode, ErrorDetails } from './errors/AdGenError.js';
|
|
4
|
+
export type { ErrorResponse } from './errors/errorMiddleware.js';
|
|
5
|
+
export { RateLimiter } from './rateLimit/RateLimiter.js';
|
|
6
|
+
export { rateLimitMiddleware } from './rateLimit/rateLimitMiddleware.js';
|
|
7
|
+
export type { RateLimitResult, RateLimiterOptions } from './rateLimit/RateLimiter.js';
|
|
8
|
+
export type { RateLimitMiddlewareOptions } from './rateLimit/rateLimitMiddleware.js';
|
|
9
|
+
export { UserContextClient, userContextMiddleware, ServiceTokenProvider, ServiceTokenVerifier, serviceAuthMiddleware, } from './auth/index.js';
|
|
10
|
+
export type { UserContext, IntrospectedUser, ServiceTokenPayload, AuthenticatedRequest, UserContextClientOptions, VerifyResponse, IntrospectResponse, } from './auth/index.js';
|
|
11
|
+
export { requestIdMiddleware, REQUEST_ID_HEADER } from './requestId/requestIdMiddleware.js';
|
|
12
|
+
export { validate, ValidationTarget } from './validation/validate.js';
|
|
13
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,YAAY,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtE,YAAY,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAEjE,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,YAAY,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AACtF,YAAY,EAAE,0BAA0B,EAAE,MAAM,oCAAoC,CAAC;AAErF,OAAO,EACL,iBAAiB,EACjB,qBAAqB,EACrB,oBAAoB,EACpB,oBAAoB,EACpB,qBAAqB,GACtB,MAAM,iBAAiB,CAAC;AACzB,YAAY,EACV,WAAW,EACX,gBAAgB,EAChB,mBAAmB,EACnB,oBAAoB,EACpB,wBAAwB,EACxB,cAAc,EACd,kBAAkB,GACnB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAE5F,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC"}
|
package/lib/index.js
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { AdGenError } from './errors/AdGenError.js';
|
|
2
|
+
export { errorMiddleware } from './errors/errorMiddleware.js';
|
|
3
|
+
export { RateLimiter } from './rateLimit/RateLimiter.js';
|
|
4
|
+
export { rateLimitMiddleware } from './rateLimit/rateLimitMiddleware.js';
|
|
5
|
+
export { UserContextClient, userContextMiddleware, ServiceTokenProvider, ServiceTokenVerifier, serviceAuthMiddleware, } from './auth/index.js';
|
|
6
|
+
export { requestIdMiddleware, REQUEST_ID_HEADER } from './requestId/requestIdMiddleware.js';
|
|
7
|
+
export { validate, ValidationTarget } from './validation/validate.js';
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAI9D,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AAIzE,OAAO,EACL,iBAAiB,EACjB,qBAAqB,EACrB,oBAAoB,EACpB,oBAAoB,EACpB,qBAAqB,GACtB,MAAM,iBAAiB,CAAC;AAWzB,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAE5F,OAAO,EAAE,QAAQ,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { Redis as RedisType } from 'ioredis';
|
|
2
|
+
export interface RateLimitResult {
|
|
3
|
+
allowed: boolean;
|
|
4
|
+
limit: number;
|
|
5
|
+
remaining: number;
|
|
6
|
+
resetAt: number;
|
|
7
|
+
}
|
|
8
|
+
export interface RateLimiterOptions {
|
|
9
|
+
redis: RedisType;
|
|
10
|
+
windowMs: number;
|
|
11
|
+
maxRequests: number;
|
|
12
|
+
keyPrefix?: string;
|
|
13
|
+
}
|
|
14
|
+
export declare class RateLimiter {
|
|
15
|
+
private readonly redis;
|
|
16
|
+
private readonly windowMs;
|
|
17
|
+
private readonly maxRequests;
|
|
18
|
+
private readonly keyPrefix;
|
|
19
|
+
constructor(options: RateLimiterOptions);
|
|
20
|
+
isAllowed(key: string): Promise<RateLimitResult>;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=RateLimiter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RateLimiter.d.ts","sourceRoot":"","sources":["../../src/rateLimit/RateLimiter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,SAAS,CAAC;AAElD,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,SAAS,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAY;IAClC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;gBAEvB,OAAO,EAAE,kBAAkB;IAOjC,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC;CAiCvD"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export class RateLimiter {
|
|
2
|
+
redis;
|
|
3
|
+
windowMs;
|
|
4
|
+
maxRequests;
|
|
5
|
+
keyPrefix;
|
|
6
|
+
constructor(options) {
|
|
7
|
+
this.redis = options.redis;
|
|
8
|
+
this.windowMs = options.windowMs;
|
|
9
|
+
this.maxRequests = options.maxRequests;
|
|
10
|
+
this.keyPrefix = options.keyPrefix ?? 'ratelimit';
|
|
11
|
+
}
|
|
12
|
+
async isAllowed(key) {
|
|
13
|
+
const windowSeconds = Math.ceil(this.windowMs / 1000);
|
|
14
|
+
const now = Date.now();
|
|
15
|
+
const resetAt = Math.ceil((now + this.windowMs) / 1000);
|
|
16
|
+
const redisKey = `${this.keyPrefix}:${key}`;
|
|
17
|
+
const pipeline = this.redis.pipeline();
|
|
18
|
+
pipeline.incr(redisKey);
|
|
19
|
+
pipeline.ttl(redisKey);
|
|
20
|
+
const pipelineResult = await pipeline.exec();
|
|
21
|
+
if (pipelineResult === null) {
|
|
22
|
+
throw new Error('Redis pipeline failed');
|
|
23
|
+
}
|
|
24
|
+
const [incrResult, ttlResult] = pipelineResult;
|
|
25
|
+
const count = incrResult?.[1];
|
|
26
|
+
const ttl = ttlResult?.[1];
|
|
27
|
+
if (ttl === -1) {
|
|
28
|
+
await this.redis.expire(redisKey, windowSeconds);
|
|
29
|
+
}
|
|
30
|
+
const allowed = count <= this.maxRequests;
|
|
31
|
+
const remaining = Math.max(0, this.maxRequests - count);
|
|
32
|
+
return {
|
|
33
|
+
allowed,
|
|
34
|
+
limit: this.maxRequests,
|
|
35
|
+
remaining,
|
|
36
|
+
resetAt,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=RateLimiter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RateLimiter.js","sourceRoot":"","sources":["../../src/rateLimit/RateLimiter.ts"],"names":[],"mappings":"AAgBA,MAAM,OAAO,WAAW;IACL,KAAK,CAAY;IACjB,QAAQ,CAAS;IACjB,WAAW,CAAS;IACpB,SAAS,CAAS;IAEnC,YAAY,OAA2B;QACrC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC3B,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;QACvC,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,WAAW,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,GAAW;QACzB,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;QACtD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,CAAC;QACxD,MAAM,QAAQ,GAAG,GAAG,IAAI,CAAC,SAAS,IAAI,GAAG,EAAE,CAAC;QAE5C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACvC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACxB,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACvB,MAAM,cAAc,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAE7C,IAAI,cAAc,KAAK,IAAI,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;QAC3C,CAAC;QAED,MAAM,CAAC,UAAU,EAAE,SAAS,CAAC,GAAG,cAAc,CAAC;QAC/C,MAAM,KAAK,GAAG,UAAU,EAAE,CAAC,CAAC,CAAW,CAAC;QACxC,MAAM,GAAG,GAAG,SAAS,EAAE,CAAC,CAAC,CAAW,CAAC;QAErC,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC;YACf,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;QACnD,CAAC;QAED,MAAM,OAAO,GAAG,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC;QAC1C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC;QAExD,OAAO;YACL,OAAO;YACP,KAAK,EAAE,IAAI,CAAC,WAAW;YACvB,SAAS;YACT,OAAO;SACR,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
import { RateLimiter } from './RateLimiter.js';
|
|
3
|
+
export interface RateLimitMiddlewareOptions {
|
|
4
|
+
limiter: RateLimiter;
|
|
5
|
+
keyExtractor: (req: Request) => string;
|
|
6
|
+
skip?: (req: Request) => boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare function rateLimitMiddleware(options: RateLimitMiddlewareOptions): (req: Request, res: Response, next: NextFunction) => Promise<void>;
|
|
9
|
+
//# sourceMappingURL=rateLimitMiddleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rateLimitMiddleware.d.ts","sourceRoot":"","sources":["../../src/rateLimit/rateLimitMiddleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAG/C,MAAM,WAAW,0BAA0B;IACzC,OAAO,EAAE,WAAW,CAAC;IACrB,YAAY,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAC;IACvC,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,OAAO,CAAC;CAClC;AAED,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,0BAA0B,IAGvD,KAAK,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,YAAY,KAAG,OAAO,CAAC,IAAI,CAAC,CAoB9E"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { AdGenError } from '../errors/AdGenError.js';
|
|
2
|
+
export function rateLimitMiddleware(options) {
|
|
3
|
+
const { limiter, keyExtractor, skip } = options;
|
|
4
|
+
return async (req, res, next) => {
|
|
5
|
+
if (skip?.(req) === true) {
|
|
6
|
+
next();
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
const key = keyExtractor(req);
|
|
10
|
+
const result = await limiter.isAllowed(key);
|
|
11
|
+
res.setHeader('X-RateLimit-Limit', String(result.limit));
|
|
12
|
+
res.setHeader('X-RateLimit-Remaining', String(result.remaining));
|
|
13
|
+
res.setHeader('X-RateLimit-Reset', String(result.resetAt));
|
|
14
|
+
if (!result.allowed) {
|
|
15
|
+
next(AdGenError.rateLimited('Too many requests'));
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
next();
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=rateLimitMiddleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rateLimitMiddleware.js","sourceRoot":"","sources":["../../src/rateLimit/rateLimitMiddleware.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAQrD,MAAM,UAAU,mBAAmB,CAAC,OAAmC;IACrE,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;IAEhD,OAAO,KAAK,EAAE,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAiB,EAAE;QAC9E,IAAI,IAAI,EAAE,CAAC,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC;YACzB,IAAI,EAAE,CAAC;YACP,OAAO;QACT,CAAC;QAED,MAAM,GAAG,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAE5C,GAAG,CAAC,SAAS,CAAC,mBAAmB,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;QACzD,GAAG,CAAC,SAAS,CAAC,uBAAuB,EAAE,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;QACjE,GAAG,CAAC,SAAS,CAAC,mBAAmB,EAAE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;QAE3D,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC,CAAC;YAClD,OAAO;QACT,CAAC;QAED,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
export declare const REQUEST_ID_HEADER = "x-request-id";
|
|
3
|
+
export declare function requestIdMiddleware(headerName?: string): (req: Request, res: Response, next: NextFunction) => void;
|
|
4
|
+
//# sourceMappingURL=requestIdMiddleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"requestIdMiddleware.d.ts","sourceRoot":"","sources":["../../src/requestId/requestIdMiddleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAG/D,eAAO,MAAM,iBAAiB,iBAAiB,CAAC;AAEhD,wBAAgB,mBAAmB,CACjC,UAAU,GAAE,MAA0B,GACrC,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,KAAK,IAAI,CAO3D"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { randomUUID } from 'crypto';
|
|
2
|
+
export const REQUEST_ID_HEADER = 'x-request-id';
|
|
3
|
+
export function requestIdMiddleware(headerName = REQUEST_ID_HEADER) {
|
|
4
|
+
return (req, res, next) => {
|
|
5
|
+
const requestId = req.get(headerName) ?? randomUUID();
|
|
6
|
+
req.headers[headerName.toLowerCase()] = requestId;
|
|
7
|
+
res.setHeader(headerName, requestId);
|
|
8
|
+
next();
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=requestIdMiddleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"requestIdMiddleware.js","sourceRoot":"","sources":["../../src/requestId/requestIdMiddleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEpC,MAAM,CAAC,MAAM,iBAAiB,GAAG,cAAc,CAAC;AAEhD,MAAM,UAAU,mBAAmB,CACjC,aAAqB,iBAAiB;IAEtC,OAAO,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAQ,EAAE;QAC/D,MAAM,SAAS,GAAG,GAAG,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,UAAU,EAAE,CAAC;QACtD,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,GAAG,SAAS,CAAC;QAClD,GAAG,CAAC,SAAS,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QACrC,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Request, Response, NextFunction } from 'express';
|
|
2
|
+
import type { ZodSchema } from 'zod';
|
|
3
|
+
export declare enum ValidationTarget {
|
|
4
|
+
Body = "body",
|
|
5
|
+
Query = "query",
|
|
6
|
+
Params = "params"
|
|
7
|
+
}
|
|
8
|
+
export declare function validate<T>(schema: ZodSchema<T>, target?: ValidationTarget): (req: Request, _res: Response, next: NextFunction) => void;
|
|
9
|
+
//# sourceMappingURL=validate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../../src/validation/validate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAY,MAAM,KAAK,CAAC;AAG/C,oBAAY,gBAAgB;IAC1B,IAAI,SAAS;IACb,KAAK,UAAU;IACf,MAAM,WAAW;CAClB;AAED,wBAAgB,QAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,GAAE,gBAAwC,IACxF,KAAK,OAAO,EAAE,MAAM,QAAQ,EAAE,MAAM,YAAY,KAAG,IAAI,CAehE"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { AdGenError } from '../errors/AdGenError.js';
|
|
2
|
+
export var ValidationTarget;
|
|
3
|
+
(function (ValidationTarget) {
|
|
4
|
+
ValidationTarget["Body"] = "body";
|
|
5
|
+
ValidationTarget["Query"] = "query";
|
|
6
|
+
ValidationTarget["Params"] = "params";
|
|
7
|
+
})(ValidationTarget || (ValidationTarget = {}));
|
|
8
|
+
export function validate(schema, target = ValidationTarget.Body) {
|
|
9
|
+
return (req, _res, next) => {
|
|
10
|
+
const result = schema.safeParse(req[target]);
|
|
11
|
+
if (!result.success) {
|
|
12
|
+
const zodError = result.error;
|
|
13
|
+
const details = zodError.issues.map((issue) => ({
|
|
14
|
+
field: issue.path.join('.'),
|
|
15
|
+
message: issue.message,
|
|
16
|
+
}));
|
|
17
|
+
next(AdGenError.badRequest('Invalid input', details));
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
next();
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=validate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.js","sourceRoot":"","sources":["../../src/validation/validate.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,MAAM,CAAN,IAAY,gBAIX;AAJD,WAAY,gBAAgB;IAC1B,iCAAa,CAAA;IACb,mCAAe,CAAA;IACf,qCAAiB,CAAA;AACnB,CAAC,EAJW,gBAAgB,KAAhB,gBAAgB,QAI3B;AAED,MAAM,UAAU,QAAQ,CAAI,MAAoB,EAAE,SAA2B,gBAAgB,CAAC,IAAI;IAChG,OAAO,CAAC,GAAY,EAAE,IAAc,EAAE,IAAkB,EAAQ,EAAE;QAChE,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;QAE7C,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,QAAQ,GAAG,MAAM,CAAC,KAAiB,CAAC;YAC1C,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC9C,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC3B,OAAO,EAAE,KAAK,CAAC,OAAO;aACvB,CAAC,CAAC,CAAC;YACJ,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC;YACtD,OAAO;QACT,CAAC;QAED,IAAI,EAAE,CAAC;IACT,CAAC,CAAC;AACJ,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@adgenit/shared",
|
|
3
|
+
"version": "0.1.0",
|
|
4
|
+
"description": "Shared utilities for AdGen microservices",
|
|
5
|
+
"license": "UNLICENSED",
|
|
6
|
+
"type": "module",
|
|
7
|
+
"main": "lib/index.js",
|
|
8
|
+
"types": "lib/index.d.ts",
|
|
9
|
+
"files": [
|
|
10
|
+
"lib"
|
|
11
|
+
],
|
|
12
|
+
"scripts": {
|
|
13
|
+
"build": "tsc -p tsconfig.build.json",
|
|
14
|
+
"lint": "eslint src",
|
|
15
|
+
"lint:fix": "eslint src --fix",
|
|
16
|
+
"prepublishOnly": "npm run build"
|
|
17
|
+
},
|
|
18
|
+
"peerDependencies": {
|
|
19
|
+
"express": "^4.19.2",
|
|
20
|
+
"ioredis": "^5.10.1",
|
|
21
|
+
"jsonwebtoken": "^9.0.2",
|
|
22
|
+
"reflect-metadata": "^0.2.2",
|
|
23
|
+
"tsyringe": "^4.8.0",
|
|
24
|
+
"zod": "^3.23.8"
|
|
25
|
+
},
|
|
26
|
+
"devDependencies": {
|
|
27
|
+
"@types/express": "^4.17.21",
|
|
28
|
+
"@types/jsonwebtoken": "^9.0.6",
|
|
29
|
+
"@types/node": "^20.14.12",
|
|
30
|
+
"express": "^4.19.2",
|
|
31
|
+
"ioredis": "^5.10.1",
|
|
32
|
+
"jsonwebtoken": "^9.0.2",
|
|
33
|
+
"reflect-metadata": "^0.2.2",
|
|
34
|
+
"tsyringe": "^4.8.0",
|
|
35
|
+
"typescript": "^5.5.4",
|
|
36
|
+
"zod": "^3.23.8"
|
|
37
|
+
}
|
|
38
|
+
}
|