@rovi-tickets/common 1.0.0 → 1.0.3
Sign up to get free protection for your applications and to get access to all the features.
- package/build/errors/bad-request-error.d.ts +9 -0
- package/build/errors/bad-request-error.js +16 -0
- package/build/errors/custom-error.d.ts +8 -0
- package/build/errors/custom-error.js +10 -0
- package/build/errors/database-connection-error.d.ts +9 -0
- package/build/errors/database-connection-error.js +16 -0
- package/build/errors/not-authorized-error.d.ts +8 -0
- package/build/errors/not-authorized-error.js +15 -0
- package/build/errors/not-found-error.d.ts +8 -0
- package/build/errors/not-found-error.js +15 -0
- package/build/errors/request-validation-error.d.ts +14 -0
- package/build/errors/request-validation-error.js +22 -0
- package/build/events/base-listener.d.ts +18 -0
- package/build/events/base-listener.js +32 -0
- package/build/events/base-publisher.d.ts +13 -0
- package/build/events/base-publisher.js +20 -0
- package/build/events/subjects.d.ts +5 -0
- package/build/events/subjects.js +9 -0
- package/build/events/ticket-created-event.d.ts +9 -0
- package/build/events/ticket-created-event.js +2 -0
- package/build/events/ticket-updated-event.d.ts +10 -0
- package/build/events/ticket-updated-event.js +2 -0
- package/build/index.d.ts +15 -0
- package/build/index.js +31 -0
- package/build/middlewares/current-user.d.ts +14 -0
- package/build/middlewares/current-user.js +20 -0
- package/build/middlewares/error-handler.d.ts +2 -0
- package/build/middlewares/error-handler.js +13 -0
- package/build/middlewares/require-auth.d.ts +2 -0
- package/build/middlewares/require-auth.js +11 -0
- package/build/middlewares/validate-request.d.ts +2 -0
- package/build/middlewares/validate-request.js +13 -0
- package/package.json +3 -2
@@ -0,0 +1,16 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.BadRequestError = void 0;
|
4
|
+
const custom_error_1 = require("./custom-error");
|
5
|
+
class BadRequestError extends custom_error_1.CustomError {
|
6
|
+
constructor(message) {
|
7
|
+
super(message);
|
8
|
+
this.message = message;
|
9
|
+
this.statusCode = 400;
|
10
|
+
Object.setPrototypeOf(this, BadRequestError.prototype);
|
11
|
+
}
|
12
|
+
serializeErrors() {
|
13
|
+
return [{ message: this.message }];
|
14
|
+
}
|
15
|
+
}
|
16
|
+
exports.BadRequestError = BadRequestError;
|
@@ -0,0 +1,10 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.CustomError = void 0;
|
4
|
+
class CustomError extends Error {
|
5
|
+
constructor(message) {
|
6
|
+
super(message);
|
7
|
+
Object.setPrototypeOf(this, CustomError.prototype);
|
8
|
+
}
|
9
|
+
}
|
10
|
+
exports.CustomError = CustomError;
|
@@ -0,0 +1,16 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.DatabaseConnectionError = void 0;
|
4
|
+
const custom_error_1 = require("./custom-error");
|
5
|
+
class DatabaseConnectionError extends custom_error_1.CustomError {
|
6
|
+
constructor() {
|
7
|
+
super('Error connecting to db');
|
8
|
+
this.statusCode = 500;
|
9
|
+
this.reason = 'Error connecting to database';
|
10
|
+
Object.setPrototypeOf(this, DatabaseConnectionError.prototype);
|
11
|
+
}
|
12
|
+
serializeErrors() {
|
13
|
+
return [{ message: this.reason }];
|
14
|
+
}
|
15
|
+
}
|
16
|
+
exports.DatabaseConnectionError = DatabaseConnectionError;
|
@@ -0,0 +1,15 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.NotAuthorizedError = void 0;
|
4
|
+
const custom_error_1 = require("./custom-error");
|
5
|
+
class NotAuthorizedError extends custom_error_1.CustomError {
|
6
|
+
constructor() {
|
7
|
+
super('Not Authorized');
|
8
|
+
this.statusCode = 401;
|
9
|
+
Object.setPrototypeOf(this, NotAuthorizedError.prototype);
|
10
|
+
}
|
11
|
+
serializeErrors() {
|
12
|
+
return [{ message: 'Not authorized' }];
|
13
|
+
}
|
14
|
+
}
|
15
|
+
exports.NotAuthorizedError = NotAuthorizedError;
|
@@ -0,0 +1,15 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.NotFoundError = void 0;
|
4
|
+
const custom_error_1 = require("./custom-error");
|
5
|
+
class NotFoundError extends custom_error_1.CustomError {
|
6
|
+
constructor() {
|
7
|
+
super('Route not found');
|
8
|
+
this.statusCode = 404;
|
9
|
+
Object.setPrototypeOf(this, NotFoundError.prototype);
|
10
|
+
}
|
11
|
+
serializeErrors() {
|
12
|
+
return [{ message: 'Not Found' }];
|
13
|
+
}
|
14
|
+
}
|
15
|
+
exports.NotFoundError = NotFoundError;
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { ValidationError } from 'express-validator';
|
2
|
+
import { CustomError } from './custom-error';
|
3
|
+
export declare class RequestValidationError extends CustomError {
|
4
|
+
errors: ValidationError[];
|
5
|
+
statusCode: number;
|
6
|
+
constructor(errors: ValidationError[]);
|
7
|
+
serializeErrors(): ({
|
8
|
+
message: any;
|
9
|
+
field: string;
|
10
|
+
} | {
|
11
|
+
message: any;
|
12
|
+
field?: undefined;
|
13
|
+
})[];
|
14
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.RequestValidationError = void 0;
|
4
|
+
const custom_error_1 = require("./custom-error");
|
5
|
+
class RequestValidationError extends custom_error_1.CustomError {
|
6
|
+
constructor(errors) {
|
7
|
+
super('Invalid request parameters');
|
8
|
+
this.errors = errors;
|
9
|
+
this.statusCode = 400;
|
10
|
+
// Only because we are extending a built in class
|
11
|
+
Object.setPrototypeOf(this, RequestValidationError.prototype);
|
12
|
+
}
|
13
|
+
serializeErrors() {
|
14
|
+
return this.errors.map((err) => {
|
15
|
+
if (err.type === 'field') {
|
16
|
+
return { message: err.msg, field: err.path };
|
17
|
+
}
|
18
|
+
return { message: err.msg };
|
19
|
+
});
|
20
|
+
}
|
21
|
+
}
|
22
|
+
exports.RequestValidationError = RequestValidationError;
|
@@ -0,0 +1,18 @@
|
|
1
|
+
import { Message, Stan } from "node-nats-streaming";
|
2
|
+
import { Subjects } from "./subjects";
|
3
|
+
interface Event {
|
4
|
+
subject: Subjects;
|
5
|
+
data: any;
|
6
|
+
}
|
7
|
+
export declare abstract class Listener<T extends Event> {
|
8
|
+
abstract subject: T['subject'];
|
9
|
+
abstract queueGroupName: string;
|
10
|
+
abstract onMessage(data: T['data'], msg: Message): void;
|
11
|
+
private client;
|
12
|
+
protected ackWait: number;
|
13
|
+
constructor(client: Stan);
|
14
|
+
subscriptionOptions(): import("node-nats-streaming").SubscriptionOptions;
|
15
|
+
listen<T>(): void;
|
16
|
+
parseMessage(msg: Message): T;
|
17
|
+
}
|
18
|
+
export {};
|
@@ -0,0 +1,32 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Listener = void 0;
|
4
|
+
class Listener {
|
5
|
+
constructor(client) {
|
6
|
+
this.ackWait = 5 * 1000;
|
7
|
+
this.client = client;
|
8
|
+
}
|
9
|
+
subscriptionOptions() {
|
10
|
+
return this.client
|
11
|
+
.subscriptionOptions()
|
12
|
+
.setDeliverAllAvailable()
|
13
|
+
.setManualAckMode(true)
|
14
|
+
.setAckWait(this.ackWait)
|
15
|
+
.setDurableName(this.queueGroupName);
|
16
|
+
}
|
17
|
+
listen() {
|
18
|
+
const subscription = this.client.subscribe(this.subject, this.queueGroupName, this.subscriptionOptions());
|
19
|
+
subscription.on('message', (msg) => {
|
20
|
+
console.log(`Message received: ${this.subject} / ${this.queueGroupName}`);
|
21
|
+
const parsedData = this.parseMessage(msg);
|
22
|
+
this.onMessage(parsedData, msg);
|
23
|
+
});
|
24
|
+
}
|
25
|
+
parseMessage(msg) {
|
26
|
+
const data = msg.getData();
|
27
|
+
return typeof data === 'string'
|
28
|
+
? JSON.parse(data)
|
29
|
+
: JSON.parse(data.toString('utf8'));
|
30
|
+
}
|
31
|
+
}
|
32
|
+
exports.Listener = Listener;
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import { Stan } from "node-nats-streaming";
|
2
|
+
import { Subjects } from "./subjects";
|
3
|
+
interface Event {
|
4
|
+
subject: Subjects;
|
5
|
+
data: any;
|
6
|
+
}
|
7
|
+
export declare abstract class Publisher<T extends Event> {
|
8
|
+
abstract subject: T['subject'];
|
9
|
+
private client;
|
10
|
+
constructor(client: Stan);
|
11
|
+
publish(data: T['data']): Promise<void>;
|
12
|
+
}
|
13
|
+
export {};
|
@@ -0,0 +1,20 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Publisher = void 0;
|
4
|
+
class Publisher {
|
5
|
+
constructor(client) {
|
6
|
+
this.client = client;
|
7
|
+
}
|
8
|
+
publish(data) {
|
9
|
+
return new Promise((resolve, reject) => {
|
10
|
+
this.client.publish(this.subject, JSON.stringify(data), (err) => {
|
11
|
+
if (err) {
|
12
|
+
return reject(err);
|
13
|
+
}
|
14
|
+
console.log('Event published.');
|
15
|
+
resolve();
|
16
|
+
});
|
17
|
+
});
|
18
|
+
}
|
19
|
+
}
|
20
|
+
exports.Publisher = Publisher;
|
@@ -0,0 +1,9 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Subjects = void 0;
|
4
|
+
var Subjects;
|
5
|
+
(function (Subjects) {
|
6
|
+
Subjects["TicketCreated"] = "ticket:created";
|
7
|
+
Subjects["TicketUpdated"] = "ticket:updated";
|
8
|
+
Subjects["OrderUpdated"] = "order:updated";
|
9
|
+
})(Subjects || (exports.Subjects = Subjects = {}));
|
package/build/index.d.ts
ADDED
@@ -0,0 +1,15 @@
|
|
1
|
+
export * from './errors/bad-request-error';
|
2
|
+
export * from './errors/custom-error';
|
3
|
+
export * from './errors/database-connection-error';
|
4
|
+
export * from './errors/not-authorized-error';
|
5
|
+
export * from './errors/not-found-error';
|
6
|
+
export * from './errors/request-validation-error';
|
7
|
+
export * from './middlewares/current-user';
|
8
|
+
export * from './middlewares/error-handler';
|
9
|
+
export * from './middlewares/require-auth';
|
10
|
+
export * from './middlewares/validate-request';
|
11
|
+
export * from './events/base-listener';
|
12
|
+
export * from './events/base-publisher';
|
13
|
+
export * from './events/subjects';
|
14
|
+
export * from './events/ticket-created-event';
|
15
|
+
export * from './events/ticket-updated-event';
|
package/build/index.js
ADDED
@@ -0,0 +1,31 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./errors/bad-request-error"), exports);
|
18
|
+
__exportStar(require("./errors/custom-error"), exports);
|
19
|
+
__exportStar(require("./errors/database-connection-error"), exports);
|
20
|
+
__exportStar(require("./errors/not-authorized-error"), exports);
|
21
|
+
__exportStar(require("./errors/not-found-error"), exports);
|
22
|
+
__exportStar(require("./errors/request-validation-error"), exports);
|
23
|
+
__exportStar(require("./middlewares/current-user"), exports);
|
24
|
+
__exportStar(require("./middlewares/error-handler"), exports);
|
25
|
+
__exportStar(require("./middlewares/require-auth"), exports);
|
26
|
+
__exportStar(require("./middlewares/validate-request"), exports);
|
27
|
+
__exportStar(require("./events/base-listener"), exports);
|
28
|
+
__exportStar(require("./events/base-publisher"), exports);
|
29
|
+
__exportStar(require("./events/subjects"), exports);
|
30
|
+
__exportStar(require("./events/ticket-created-event"), exports);
|
31
|
+
__exportStar(require("./events/ticket-updated-event"), exports);
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { Request, Response, NextFunction } from 'express';
|
2
|
+
interface UserPayload {
|
3
|
+
id: string;
|
4
|
+
email: string;
|
5
|
+
}
|
6
|
+
declare global {
|
7
|
+
namespace Express {
|
8
|
+
interface Request {
|
9
|
+
currentUser?: UserPayload;
|
10
|
+
}
|
11
|
+
}
|
12
|
+
}
|
13
|
+
export declare const currentUser: (req: Request, res: Response, next: NextFunction) => void;
|
14
|
+
export {};
|
@@ -0,0 +1,20 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.currentUser = void 0;
|
7
|
+
const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
|
8
|
+
const currentUser = (req, res, next) => {
|
9
|
+
var _a;
|
10
|
+
if (!((_a = req.session) === null || _a === void 0 ? void 0 : _a.jwt)) {
|
11
|
+
return next();
|
12
|
+
}
|
13
|
+
try {
|
14
|
+
const payload = jsonwebtoken_1.default.verify(req.session.jwt, process.env.JWT_KEY);
|
15
|
+
req.currentUser = payload;
|
16
|
+
}
|
17
|
+
catch (err) { }
|
18
|
+
next();
|
19
|
+
};
|
20
|
+
exports.currentUser = currentUser;
|
@@ -0,0 +1,13 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.errorHandler = void 0;
|
4
|
+
const custom_error_1 = require("../errors/custom-error");
|
5
|
+
const errorHandler = (err, req, res, next) => {
|
6
|
+
if (err instanceof custom_error_1.CustomError) {
|
7
|
+
return res.status(err.statusCode).send({ errors: err.serializeErrors() });
|
8
|
+
}
|
9
|
+
res.status(400).send({
|
10
|
+
errors: [{ message: 'Something went wrong' }]
|
11
|
+
});
|
12
|
+
};
|
13
|
+
exports.errorHandler = errorHandler;
|
@@ -0,0 +1,11 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.requireAuth = void 0;
|
4
|
+
const not_authorized_error_1 = require("../errors/not-authorized-error");
|
5
|
+
const requireAuth = (req, res, next) => {
|
6
|
+
if (!req.currentUser) {
|
7
|
+
throw new not_authorized_error_1.NotAuthorizedError();
|
8
|
+
}
|
9
|
+
next();
|
10
|
+
};
|
11
|
+
exports.requireAuth = requireAuth;
|
@@ -0,0 +1,13 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.validateRequest = void 0;
|
4
|
+
const express_validator_1 = require("express-validator");
|
5
|
+
const request_validation_error_1 = require("../errors/request-validation-error");
|
6
|
+
const validateRequest = (req, res, next) => {
|
7
|
+
const errors = (0, express_validator_1.validationResult)(req);
|
8
|
+
if (!errors.isEmpty()) {
|
9
|
+
throw new request_validation_error_1.RequestValidationError(errors.array());
|
10
|
+
}
|
11
|
+
next();
|
12
|
+
};
|
13
|
+
exports.validateRequest = validateRequest;
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@rovi-tickets/common",
|
3
|
-
"version": "1.0.
|
3
|
+
"version": "1.0.3",
|
4
4
|
"description": "",
|
5
5
|
"main": "./build/index.js",
|
6
6
|
"types": "./build/index.d.ts",
|
@@ -26,6 +26,7 @@
|
|
26
26
|
"cookie-session": "^2.1.0",
|
27
27
|
"express": "^4.21.0",
|
28
28
|
"express-validator": "^7.2.0",
|
29
|
-
"jsonwebtoken": "^9.0.2"
|
29
|
+
"jsonwebtoken": "^9.0.2",
|
30
|
+
"node-nats-streaming": "^0.3.2"
|
30
31
|
}
|
31
32
|
}
|