docta-package 1.2.13 → 1.2.15

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/build/config.d.ts CHANGED
@@ -10,6 +10,10 @@ interface GeneralConfig {
10
10
  forgotPasswordTokenSecret: string;
11
11
  activationTokenSecret: string;
12
12
  rabbitmqHost: string;
13
+ awsSesHost: string;
14
+ awsSesPort: number;
15
+ awsSesUsername: string;
16
+ awsSesPassword: string;
13
17
  }
14
18
  export declare const getGeneralConfig: () => GeneralConfig;
15
19
  export {};
package/build/config.js CHANGED
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.getGeneralConfig = void 0;
4
4
  const getGeneralConfig = () => {
5
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
5
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
6
6
  return ({
7
7
  accessTokenSecret: (_a = process.env.ACCESS_TOKEN_SECRET) !== null && _a !== void 0 ? _a : "",
8
8
  refreshTokenSecret: (_b = process.env.REFRESH_TOKEN_SECRET) !== null && _b !== void 0 ? _b : "",
@@ -15,6 +15,10 @@ const getGeneralConfig = () => {
15
15
  forgotPasswordTokenSecret: (_j = process.env.FORGOT_PASSWORD_TOKEN_SECRET) !== null && _j !== void 0 ? _j : "",
16
16
  activationTokenSecret: (_k = process.env.ACTIVATION_TOKEN_SECRET) !== null && _k !== void 0 ? _k : "",
17
17
  rabbitmqHost: (_l = process.env.RABBITMQ_HOST) !== null && _l !== void 0 ? _l : "",
18
+ awsSesHost: (_m = process.env.AWS_SES_HOST) !== null && _m !== void 0 ? _m : "",
19
+ awsSesPort: Number((_o = process.env.AWS_SES_PORT) !== null && _o !== void 0 ? _o : 0),
20
+ awsSesUsername: (_p = process.env.AWS_SES_USERNAME) !== null && _p !== void 0 ? _p : "",
21
+ awsSesPassword: (_q = process.env.AWS_SES_PASSWORD) !== null && _q !== void 0 ? _q : "",
18
22
  });
19
23
  };
20
24
  exports.getGeneralConfig = getGeneralConfig;
@@ -39,61 +39,3 @@ function publishToTopicExchange(_a) {
39
39
  }
40
40
  });
41
41
  }
42
- // import amqp from "amqplib";
43
- // interface ListenerOptions<T> {
44
- // exchange: string;
45
- // queue: string;
46
- // routingKeys: string[];
47
- // }
48
- // export async function listenToQueue<T>({
49
- // exchange,
50
- // queue,
51
- // routingKeys,
52
- // }: ListenerOptions<T>) {
53
- // try {
54
- // const connection = await amqp.connect("amqp://localhost");
55
- // const channel = await connection.createChannel();
56
- // await channel.assertExchange(exchange, "topic", { durable: true });
57
- // await channel.assertQueue(queue, { durable: true });
58
- // // Bind queue to each routing key
59
- // for (const key of routingKeys) {
60
- // await channel.bindQueue(queue, exchange, key);
61
- // console.log(`✅ Bound queue "${queue}" to routing key "${key}"`);
62
- // }
63
- // console.log(
64
- // `🎧 Listening on "${queue}" for routing keys: [${routingKeys.join(", ")}]`
65
- // );
66
- // await channel.consume(
67
- // queue,
68
- // (msg) => {
69
- // if (!msg) return;
70
- // const routingKey = msg.fields.routingKey;
71
- // const content = msg.content.toString();
72
- // try {
73
- // const data: T = JSON.parse(content);
74
- // // Handle messages based on routing key
75
- // switch (routingKey) {
76
- // case "user.created":
77
- // console.log("👤 User created:", data);
78
- // break;
79
- // case "user.updated":
80
- // console.log("✏️ User updated:", data);
81
- // break;
82
- // case "user.deleted":
83
- // console.log("🗑️ User deleted:", data);
84
- // break;
85
- // default:
86
- // console.warn("⚠️ Unhandled routing key:", routingKey, data);
87
- // }
88
- // channel.ack(msg);
89
- // } catch (err) {
90
- // console.error("❌ Failed to process message:", err);
91
- // channel.nack(msg, false, true);
92
- // }
93
- // },
94
- // { noAck: false }
95
- // );
96
- // } catch (error) {
97
- // console.error("Error setting up listener:", error);
98
- // }
99
- // }
@@ -0,0 +1,6 @@
1
+ import SMTPTransport from "nodemailer/lib/smtp-transport";
2
+ export declare class AwsSesHelper {
3
+ private transporter;
4
+ constructor();
5
+ sendEmail(receiver: string, sender: string, html: string, subject: string): Promise<SMTPTransport.SentMessageInfo>;
6
+ }
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.AwsSesHelper = void 0;
16
+ const nodemailer_1 = __importDefault(require("nodemailer"));
17
+ const config_1 = require("../config");
18
+ class AwsSesHelper {
19
+ constructor() {
20
+ this.transporter = nodemailer_1.default.createTransport({
21
+ host: (0, config_1.getGeneralConfig)().awsSesHost,
22
+ port: (0, config_1.getGeneralConfig)().awsSesPort,
23
+ auth: {
24
+ user: (0, config_1.getGeneralConfig)().awsSesUsername,
25
+ pass: (0, config_1.getGeneralConfig)().awsSesPassword,
26
+ },
27
+ // tls: {
28
+ // rejectUnauthorized: false, // Bypass certificate validation
29
+ // },
30
+ });
31
+ }
32
+ sendEmail(receiver, sender, html, subject) {
33
+ return __awaiter(this, void 0, void 0, function* () {
34
+ const mailOptions = {
35
+ from: sender,
36
+ to: receiver,
37
+ subject,
38
+ html,
39
+ };
40
+ const data = yield this.transporter.sendMail(mailOptions);
41
+ return data;
42
+ });
43
+ }
44
+ }
45
+ exports.AwsSesHelper = AwsSesHelper;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "docta-package",
3
- "version": "1.2.13",
3
+ "version": "1.2.15",
4
4
  "description": "This package will contail all the required files to run the docta micro-service app",
5
5
  "main": "build/index.js",
6
6
  "types": "build/index.d.ts",
@@ -30,13 +30,16 @@
30
30
  "@aws-sdk/client-s3": "^3.908.0",
31
31
  "@aws-sdk/s3-request-presigner": "^3.908.0",
32
32
  "@types/amqplib": "^0.10.7",
33
+ "@types/nodemailer": "^7.0.2",
33
34
  "amqplib": "^0.10.9",
34
35
  "bcryptjs": "^3.0.2",
35
36
  "class-transformer": "^0.5.1",
36
37
  "class-validator": "^0.14.2",
37
38
  "express": "^5.1.0",
39
+ "jsonwebtoken": "^9.0.2",
38
40
  "mongoose": "^8.19.1",
39
41
  "multer": "^2.0.2",
42
+ "nodemailer": "^7.0.9",
40
43
  "reflect-metadata": "^0.2.2",
41
44
  "winston": "^3.18.3",
42
45
  "winston-daily-rotate-file": "^5.0.0"