@darraghor/nest-backend-libs 1.27.0 → 1.29.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/dist/configuration/ValidatedConfigurationService.js +4 -3
- package/dist/configuration/ValidatedConfigurationService.js.map +1 -1
- package/dist/index.d.ts +5 -3
- package/dist/index.js +9 -5
- package/dist/index.js.map +1 -1
- package/dist/smtp-email-client/EmailClientProvider.d.ts +7 -0
- package/dist/smtp-email-client/EmailClientProvider.js +22 -0
- package/dist/smtp-email-client/EmailClientProvider.js.map +1 -0
- package/dist/{email-client → smtp-email-client}/EmailConfigurationService.d.ts +2 -0
- package/dist/{email-client → smtp-email-client}/EmailConfigurationService.js +20 -2
- package/dist/smtp-email-client/EmailConfigurationService.js.map +1 -0
- package/dist/{email-client → smtp-email-client}/EmailConfigurationVariables.d.ts +12 -8
- package/dist/{email-client → smtp-email-client}/EmailConfigurationVariables.js +6 -4
- package/dist/smtp-email-client/EmailConfigurationVariables.js.map +1 -0
- package/dist/{email-client → smtp-email-client}/email-client.service.d.ts +5 -4
- package/dist/{email-client → smtp-email-client}/email-client.service.js +21 -27
- package/dist/smtp-email-client/email-client.service.js.map +1 -0
- package/dist/{email-client → smtp-email-client}/email.controller.d.ts +2 -2
- package/dist/{email-client → smtp-email-client}/email.controller.js +1 -1
- package/dist/smtp-email-client/email.controller.js.map +1 -0
- package/dist/{email-client → smtp-email-client}/email.entity.d.ts +0 -0
- package/dist/{email-client → smtp-email-client}/email.entity.js +0 -0
- package/dist/smtp-email-client/email.entity.js.map +1 -0
- package/dist/smtp-email-client/smtp-email-client.module.d.ts +2 -0
- package/dist/{email-client/email-client.module.js → smtp-email-client/smtp-email-client.module.js} +8 -8
- package/dist/smtp-email-client/smtp-email-client.module.js.map +1 -0
- package/dist/twitter-client/TwitterClientConfigurationService.d.ts +10 -0
- package/dist/twitter-client/TwitterClientConfigurationService.js +65 -0
- package/dist/twitter-client/TwitterClientConfigurationService.js.map +1 -0
- package/dist/twitter-client/TwitterClientProvider.d.ts +7 -0
- package/dist/twitter-client/TwitterClientProvider.js +19 -0
- package/dist/twitter-client/TwitterClientProvider.js.map +1 -0
- package/dist/twitter-client/TwitterConfigurationVariables.d.ts +12 -0
- package/dist/twitter-client/TwitterConfigurationVariables.js +10 -0
- package/dist/twitter-client/TwitterConfigurationVariables.js.map +1 -0
- package/dist/twitter-client/services/twitter-client.service.d.ts +9 -0
- package/dist/twitter-client/services/twitter-client.service.js +47 -0
- package/dist/twitter-client/services/twitter-client.service.js.map +1 -0
- package/dist/twitter-client/twitter-account.module.d.ts +3 -0
- package/dist/twitter-client/twitter-account.module.js +35 -0
- package/dist/twitter-client/twitter-account.module.js.map +1 -0
- package/package.json +5 -4
- package/dist/email-client/EmailConfigurationService.js.map +0 -1
- package/dist/email-client/EmailConfigurationVariables.js.map +0 -1
- package/dist/email-client/email-client.module.d.ts +0 -2
- package/dist/email-client/email-client.module.js.map +0 -1
- package/dist/email-client/email-client.service.js.map +0 -1
- package/dist/email-client/email.controller.js.map +0 -1
- package/dist/email-client/email.entity.js.map +0 -1
|
@@ -13,13 +13,14 @@ let ValidatedConfigurationService = class ValidatedConfigurationService {
|
|
|
13
13
|
async onModuleInit() {
|
|
14
14
|
const result = await (0, class_validator_1.validate)(this);
|
|
15
15
|
if (result.length > 0) {
|
|
16
|
-
|
|
17
|
-
${JSON.stringify(result.map((v) => {
|
|
16
|
+
const json = JSON.stringify(result.map((v) => {
|
|
18
17
|
return {
|
|
19
18
|
property: v.property,
|
|
20
19
|
constraints: v.constraints,
|
|
21
20
|
};
|
|
22
|
-
}), undefined, 2)
|
|
21
|
+
}), undefined, 2);
|
|
22
|
+
throw new Error(`Configuration failed - Is there an environment variable missing?
|
|
23
|
+
${json}`);
|
|
23
24
|
}
|
|
24
25
|
}
|
|
25
26
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ValidatedConfigurationService.js","sourceRoot":"","sources":["../../src/configuration/ValidatedConfigurationService.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwD;AACxD,qDAAyC;AAIlC,IAAe,6BAA6B,GAA5C,MAAe,6BAA6B;IAC/C,KAAK,CAAC,YAAY;QACd,MAAM,MAAM,GAAG,MAAM,IAAA,0BAAQ,EAAC,IAAI,CAAC,CAAC;QACpC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YACnB,MAAM,IAAI,
|
|
1
|
+
{"version":3,"file":"ValidatedConfigurationService.js","sourceRoot":"","sources":["../../src/configuration/ValidatedConfigurationService.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwD;AACxD,qDAAyC;AAIlC,IAAe,6BAA6B,GAA5C,MAAe,6BAA6B;IAC/C,KAAK,CAAC,YAAY;QACd,MAAM,MAAM,GAAG,MAAM,IAAA,0BAAQ,EAAC,IAAI,CAAC,CAAC;QACpC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YACnB,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CACvB,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACb,OAAO;oBACH,QAAQ,EAAE,CAAC,CAAC,QAAQ;oBACpB,WAAW,EAAE,CAAC,CAAC,WAAW;iBAC7B,CAAC;YACN,CAAC,CAAC,EACF,SAAS,EACT,CAAC,CACJ,CAAC;YACF,MAAM,IAAI,KAAK,CACX;EACd,IAAI,EAAE,CACK,CAAC;SACL;IACL,CAAC;CACJ,CAAA;AApBqB,6BAA6B;IAFlD,IAAA,mBAAU,GAAE;IACb,iFAAiF;GAC3D,6BAA6B,CAoBlD;AApBqB,sEAA6B"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { SmtpEmailClientModule } from "./smtp-email-client/smtp-email-client.module";
|
|
2
|
+
import { EUploadMimeType } from "twitter-api-v2";
|
|
1
3
|
import { AuthzModule } from "./authz/authz.module";
|
|
2
4
|
import { JwtStrategy } from "./authz/authzstrategy";
|
|
3
5
|
import { DefaultAuthGuard } from "./authz/DefaultAuthGuard";
|
|
@@ -8,8 +10,7 @@ import { PostgresDatabaseModule } from "./database-postgres/PostgresDatabase.mod
|
|
|
8
10
|
import { PostgresTypeOrmConfigurationProvider } from "./database-postgres/PostgresTypeOrmConfigurationProvider";
|
|
9
11
|
import { SqliteDatabaseModule } from "./database-sqlite/SqliteDatabase.module";
|
|
10
12
|
import { SqliteDatabaseConfigurationService } from "./database-sqlite/SqliteDatabaseConfigurationService";
|
|
11
|
-
import {
|
|
12
|
-
import { EmailClient } from "./email-client/email-client.service";
|
|
13
|
+
import { SmtpEmailClient } from "./smtp-email-client/email-client.service";
|
|
13
14
|
import CoreLoggerService from "./logger/CoreLoggerService";
|
|
14
15
|
import { OrganisationModule } from "./organisation/organisation.module";
|
|
15
16
|
import { Person } from "./person/entities/person.entity";
|
|
@@ -17,4 +18,5 @@ import { PersonModule } from "./person/person.module";
|
|
|
17
18
|
import { PersonService } from "./person/person.service";
|
|
18
19
|
import { CoreModule } from "./root-app/core-app.module";
|
|
19
20
|
import { SwaggerGen } from "./root-app/SwaggerGen";
|
|
20
|
-
|
|
21
|
+
import { TwitterClientService } from "./twitter-client/services/twitter-client.service";
|
|
22
|
+
export { CoreLoggerService, CoreConfigurationService, SmtpEmailClientModule, CoreModule, SwaggerGen, DefaultAuthGuard, PostgresDatabaseModule as DatabaseModule, JwtStrategy, AuthzModule, Person, PostgresTypeOrmConfigurationProvider as TypeOrmConfigurationProvider, SmtpEmailClient, ValidatedConfigurationService, RequestWithUser, PersonModule, OrganisationModule, PersonService, SqliteDatabaseModule, SqliteDatabaseConfigurationService, TwitterClientService, EUploadMimeType, };
|
package/dist/index.js
CHANGED
|
@@ -3,8 +3,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.SqliteDatabaseConfigurationService = exports.SqliteDatabaseModule = exports.PersonService = exports.OrganisationModule = exports.PersonModule = exports.ValidatedConfigurationService = exports.
|
|
6
|
+
exports.EUploadMimeType = exports.TwitterClientService = exports.SqliteDatabaseConfigurationService = exports.SqliteDatabaseModule = exports.PersonService = exports.OrganisationModule = exports.PersonModule = exports.ValidatedConfigurationService = exports.SmtpEmailClient = exports.TypeOrmConfigurationProvider = exports.Person = exports.AuthzModule = exports.JwtStrategy = exports.DatabaseModule = exports.DefaultAuthGuard = exports.SwaggerGen = exports.CoreModule = exports.SmtpEmailClientModule = exports.CoreConfigurationService = exports.CoreLoggerService = void 0;
|
|
7
7
|
/* eslint-disable unicorn/prefer-export-from */
|
|
8
|
+
const smtp_email_client_module_1 = require("./smtp-email-client/smtp-email-client.module");
|
|
9
|
+
Object.defineProperty(exports, "SmtpEmailClientModule", { enumerable: true, get: function () { return smtp_email_client_module_1.SmtpEmailClientModule; } });
|
|
10
|
+
const twitter_api_v2_1 = require("twitter-api-v2");
|
|
11
|
+
Object.defineProperty(exports, "EUploadMimeType", { enumerable: true, get: function () { return twitter_api_v2_1.EUploadMimeType; } });
|
|
8
12
|
const authz_module_1 = require("./authz/authz.module");
|
|
9
13
|
Object.defineProperty(exports, "AuthzModule", { enumerable: true, get: function () { return authz_module_1.AuthzModule; } });
|
|
10
14
|
const authzstrategy_1 = require("./authz/authzstrategy");
|
|
@@ -23,10 +27,8 @@ const SqliteDatabase_module_1 = require("./database-sqlite/SqliteDatabase.module
|
|
|
23
27
|
Object.defineProperty(exports, "SqliteDatabaseModule", { enumerable: true, get: function () { return SqliteDatabase_module_1.SqliteDatabaseModule; } });
|
|
24
28
|
const SqliteDatabaseConfigurationService_1 = require("./database-sqlite/SqliteDatabaseConfigurationService");
|
|
25
29
|
Object.defineProperty(exports, "SqliteDatabaseConfigurationService", { enumerable: true, get: function () { return SqliteDatabaseConfigurationService_1.SqliteDatabaseConfigurationService; } });
|
|
26
|
-
const
|
|
27
|
-
Object.defineProperty(exports, "
|
|
28
|
-
const email_client_service_1 = require("./email-client/email-client.service");
|
|
29
|
-
Object.defineProperty(exports, "EmailClient", { enumerable: true, get: function () { return email_client_service_1.EmailClient; } });
|
|
30
|
+
const email_client_service_1 = require("./smtp-email-client/email-client.service");
|
|
31
|
+
Object.defineProperty(exports, "SmtpEmailClient", { enumerable: true, get: function () { return email_client_service_1.SmtpEmailClient; } });
|
|
30
32
|
const CoreLoggerService_1 = __importDefault(require("./logger/CoreLoggerService"));
|
|
31
33
|
exports.CoreLoggerService = CoreLoggerService_1.default;
|
|
32
34
|
const organisation_module_1 = require("./organisation/organisation.module");
|
|
@@ -41,4 +43,6 @@ const core_app_module_1 = require("./root-app/core-app.module");
|
|
|
41
43
|
Object.defineProperty(exports, "CoreModule", { enumerable: true, get: function () { return core_app_module_1.CoreModule; } });
|
|
42
44
|
const SwaggerGen_1 = require("./root-app/SwaggerGen");
|
|
43
45
|
Object.defineProperty(exports, "SwaggerGen", { enumerable: true, get: function () { return SwaggerGen_1.SwaggerGen; } });
|
|
46
|
+
const twitter_client_service_1 = require("./twitter-client/services/twitter-client.service");
|
|
47
|
+
Object.defineProperty(exports, "TwitterClientService", { enumerable: true, get: function () { return twitter_client_service_1.TwitterClientService; } });
|
|
44
48
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;AAAA,+CAA+C;AAC/C,uDAAiD;AA6B7C,4FA7BI,0BAAW,OA6BJ;AA5Bf,yDAAkD;AA2B9C,4FA3BI,2BAAW,OA2BJ;AA1Bf,+DAA0D;AAwBtD,iGAxBI,mCAAgB,OAwBJ;AAtBpB,iGAA4F;AA6BxF,8GA7BI,6DAA6B,OA6BJ;AA5BjC,qFAAgF;AAiB5E,yGAjBI,mDAAwB,OAiBJ;AAhB5B,yFAAmF;AAqBrD,+FArBtB,gDAAsB,OAqBc;AApB5C,mHAA8G;AAwBlE,6GAxBpC,2EAAoC,OAwB4B;AAvBxE,mFAA6E;AA8BzE,qGA9BI,4CAAoB,OA8BJ;AA7BxB,6GAAwG;AA8BpG,mHA9BI,uEAAkC,OA8BJ;AA7BtC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;AAAA,+CAA+C;AAC/C,2FAAmF;AAyB/E,sGAzBI,gDAAqB,OAyBJ;AAxBzB,mDAA+C;AA0C3C,gGA1CI,gCAAe,OA0CJ;AAzCnB,uDAAiD;AA6B7C,4FA7BI,0BAAW,OA6BJ;AA5Bf,yDAAkD;AA2B9C,4FA3BI,2BAAW,OA2BJ;AA1Bf,+DAA0D;AAwBtD,iGAxBI,mCAAgB,OAwBJ;AAtBpB,iGAA4F;AA6BxF,8GA7BI,6DAA6B,OA6BJ;AA5BjC,qFAAgF;AAiB5E,yGAjBI,mDAAwB,OAiBJ;AAhB5B,yFAAmF;AAqBrD,+FArBtB,gDAAsB,OAqBc;AApB5C,mHAA8G;AAwBlE,6GAxBpC,2EAAoC,OAwB4B;AAvBxE,mFAA6E;AA8BzE,qGA9BI,4CAAoB,OA8BJ;AA7BxB,6GAAwG;AA8BpG,mHA9BI,uEAAkC,OA8BJ;AA7BtC,mFAAyE;AAsBrE,gGAtBI,sCAAe,OAsBJ;AArBnB,mFAA2D;AAUvD,4BAVG,2BAAiB,CAUH;AATrB,4EAAsE;AAwBlE,mGAxBI,wCAAkB,OAwBJ;AAvBtB,mEAAuD;AAiBnD,uFAjBI,sBAAM,OAiBJ;AAhBV,0DAAoD;AAqBhD,6FArBI,4BAAY,OAqBJ;AApBhB,4DAAsD;AAsBlD,8FAtBI,8BAAa,OAsBJ;AArBjB,gEAAsD;AAQlD,2FARI,4BAAU,OAQJ;AAPd,sDAAiD;AAQ7C,2FARI,uBAAU,OAQJ;AAPd,6FAAsF;AAsBlF,qGAtBI,6CAAoB,OAsBJ"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Transporter } from "nodemailer";
|
|
2
|
+
import { EmailConfigurationService } from "./EmailConfigurationService";
|
|
3
|
+
export declare const EmailClientProvider: {
|
|
4
|
+
provide: string;
|
|
5
|
+
useFactory: (config: EmailConfigurationService) => Transporter;
|
|
6
|
+
inject: (typeof EmailConfigurationService)[];
|
|
7
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EmailClientProvider = void 0;
|
|
4
|
+
const nodemailer_1 = require("nodemailer");
|
|
5
|
+
const EmailConfigurationService_1 = require("./EmailConfigurationService");
|
|
6
|
+
exports.EmailClientProvider = {
|
|
7
|
+
provide: "SmtpEmailClient",
|
|
8
|
+
useFactory: (config) => {
|
|
9
|
+
return (0, nodemailer_1.createTransport)({
|
|
10
|
+
host: config.smtpHost,
|
|
11
|
+
port: config.smtpPort,
|
|
12
|
+
secure: config.smtpPort === 465 ? true : false,
|
|
13
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
14
|
+
auth: {
|
|
15
|
+
user: config.emailUsername,
|
|
16
|
+
pass: config.emailPassword,
|
|
17
|
+
},
|
|
18
|
+
});
|
|
19
|
+
},
|
|
20
|
+
inject: [EmailConfigurationService_1.EmailConfigurationService],
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=EmailClientProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmailClientProvider.js","sourceRoot":"","sources":["../../src/smtp-email-client/EmailClientProvider.ts"],"names":[],"mappings":";;;AAAA,2CAAwD;AACxD,2EAAsE;AAEzD,QAAA,mBAAmB,GAAG;IAC/B,OAAO,EAAE,iBAAiB;IAC1B,UAAU,EAAE,CAAC,MAAiC,EAAe,EAAE;QAC3D,OAAO,IAAA,4BAAe,EAAC;YACnB,IAAI,EAAE,MAAM,CAAC,QAAQ;YACrB,IAAI,EAAE,MAAM,CAAC,QAAQ;YACrB,MAAM,EAAE,MAAM,CAAC,QAAQ,KAAK,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;YAC9C,mEAAmE;YACnE,IAAI,EAAE;gBACF,IAAI,EAAE,MAAM,CAAC,aAAa;gBAC1B,IAAI,EAAE,MAAM,CAAC,aAAa;aAC7B;SACJ,CAAC,CAAC;IACP,CAAC;IACD,MAAM,EAAE,CAAC,qDAAyB,CAAC;CACtC,CAAC"}
|
|
@@ -6,6 +6,8 @@ export declare class EmailConfigurationService extends ValidatedConfigurationSer
|
|
|
6
6
|
get isEmailSyncSendEnabled(): boolean;
|
|
7
7
|
get emailBcc(): string;
|
|
8
8
|
get emailPassword(): string;
|
|
9
|
+
get smtpHost(): string;
|
|
10
|
+
get smtpPort(): number;
|
|
9
11
|
get emailUsername(): string;
|
|
10
12
|
get senderEmailAddress(): string;
|
|
11
13
|
get senderName(): string;
|
|
@@ -28,10 +28,16 @@ let EmailConfigurationService = class EmailConfigurationService extends Validate
|
|
|
28
28
|
return this.configService.get("email.emailBcc");
|
|
29
29
|
}
|
|
30
30
|
get emailPassword() {
|
|
31
|
-
return this.configService.get("email.
|
|
31
|
+
return this.configService.get("email.smtpPassword");
|
|
32
|
+
}
|
|
33
|
+
get smtpHost() {
|
|
34
|
+
return this.configService.get("email.smtpHost");
|
|
35
|
+
}
|
|
36
|
+
get smtpPort() {
|
|
37
|
+
return this.configService.get("email.smtpPort");
|
|
32
38
|
}
|
|
33
39
|
get emailUsername() {
|
|
34
|
-
return this.configService.get("email.
|
|
40
|
+
return this.configService.get("email.smtpUsername");
|
|
35
41
|
}
|
|
36
42
|
get senderEmailAddress() {
|
|
37
43
|
return this.configService.get("email.senderEmailAddress");
|
|
@@ -58,6 +64,18 @@ __decorate([
|
|
|
58
64
|
__metadata("design:type", String),
|
|
59
65
|
__metadata("design:paramtypes", [])
|
|
60
66
|
], EmailConfigurationService.prototype, "emailPassword", null);
|
|
67
|
+
__decorate([
|
|
68
|
+
(0, class_validator_1.IsDefined)(),
|
|
69
|
+
(0, class_validator_1.IsString)(),
|
|
70
|
+
__metadata("design:type", String),
|
|
71
|
+
__metadata("design:paramtypes", [])
|
|
72
|
+
], EmailConfigurationService.prototype, "smtpHost", null);
|
|
73
|
+
__decorate([
|
|
74
|
+
(0, class_validator_1.IsDefined)(),
|
|
75
|
+
(0, class_validator_1.IsInt)(),
|
|
76
|
+
__metadata("design:type", Number),
|
|
77
|
+
__metadata("design:paramtypes", [])
|
|
78
|
+
], EmailConfigurationService.prototype, "smtpPort", null);
|
|
61
79
|
__decorate([
|
|
62
80
|
(0, class_validator_1.IsDefined)(),
|
|
63
81
|
(0, class_validator_1.IsString)(),
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmailConfigurationService.js","sourceRoot":"","sources":["../../src/smtp-email-client/EmailConfigurationService.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6DAA6D;AAC7D,2CAA0C;AAC1C,2CAA6C;AAC7C,qDAAsE;AACtE,kGAA6F;AAGtF,IAAM,yBAAyB,GAA/B,MAAM,yBAA0B,SAAQ,6DAA6B;IACxE,YAAoB,aAA4B;QAC5C,KAAK,EAAE,CAAC;QADQ,kBAAa,GAAb,aAAa,CAAe;IAEhD,CAAC;IAED,IAEI,sBAAsB;QACtB,OAAO,CACH,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,8BAA8B,CAAC;YAC9D,MAAM,CACT,CAAC;IACN,CAAC;IAED,IAEI,QAAQ;QACR,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,gBAAgB,CAAE,CAAC;IAC7D,CAAC;IAED,IAEI,aAAa;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,oBAAoB,CAAE,CAAC;IACjE,CAAC;IAED,IAEI,QAAQ;QACR,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,gBAAgB,CAAE,CAAC;IAC7D,CAAC;IAED,IAEI,QAAQ;QACR,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,gBAAgB,CAAE,CAAC;IAC7D,CAAC;IAED,IAEI,aAAa;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,oBAAoB,CAAE,CAAC;IACjE,CAAC;IAED,IAEI,kBAAkB;QAClB,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,0BAA0B,CAAE,CAAC;IACvE,CAAC;IAED,IAEI,UAAU;QACV,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,kBAAkB,CAAE,CAAC;IAC/D,CAAC;CACJ,CAAA;AAlDG;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,2BAAS,GAAE;;;uEAMX;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;yDAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;8DAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;yDAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,uBAAK,GAAE;;;yDAGP;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;8DAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;mEAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;2DAGV;AAtDQ,yBAAyB;IADrC,IAAA,mBAAU,GAAE;qCAE0B,sBAAa;GADvC,yBAAyB,CAuDrC;AAvDY,8DAAyB"}
|
|
@@ -1,16 +1,20 @@
|
|
|
1
1
|
declare const _default: (() => {
|
|
2
|
-
isEmailSyncSendEnabled: string | undefined;
|
|
3
2
|
emailBcc: string | undefined;
|
|
4
|
-
emailPassword: string | undefined;
|
|
5
|
-
emailUsername: string | undefined;
|
|
6
|
-
senderEmailAddress: string | undefined;
|
|
7
3
|
senderName: string | undefined;
|
|
8
|
-
|
|
4
|
+
senderEmailAddress: string | undefined;
|
|
9
5
|
isEmailSyncSendEnabled: string | undefined;
|
|
6
|
+
smtpPassword: string | undefined;
|
|
7
|
+
smtpUsername: string | undefined;
|
|
8
|
+
smtpHost: string | undefined;
|
|
9
|
+
smtpPort: string | undefined;
|
|
10
|
+
}) & import("@nestjs/config").ConfigFactoryKeyHost<{
|
|
10
11
|
emailBcc: string | undefined;
|
|
11
|
-
emailPassword: string | undefined;
|
|
12
|
-
emailUsername: string | undefined;
|
|
13
|
-
senderEmailAddress: string | undefined;
|
|
14
12
|
senderName: string | undefined;
|
|
13
|
+
senderEmailAddress: string | undefined;
|
|
14
|
+
isEmailSyncSendEnabled: string | undefined;
|
|
15
|
+
smtpPassword: string | undefined;
|
|
16
|
+
smtpUsername: string | undefined;
|
|
17
|
+
smtpHost: string | undefined;
|
|
18
|
+
smtpPort: string | undefined;
|
|
15
19
|
}>;
|
|
16
20
|
export default _default;
|
|
@@ -2,11 +2,13 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const config_1 = require("@nestjs/config");
|
|
4
4
|
exports.default = (0, config_1.registerAs)("email", () => ({
|
|
5
|
-
isEmailSyncSendEnabled: process.env.EMAIL_SYNC_SEND_ENABLED,
|
|
6
5
|
emailBcc: process.env.EMAIL_BCC,
|
|
7
|
-
emailPassword: process.env.EMAIL_PASSWORD,
|
|
8
|
-
emailUsername: process.env.EMAIL_USERNAME,
|
|
9
|
-
senderEmailAddress: process.env.EMAIL_SENDER_ADDRESS,
|
|
10
6
|
senderName: process.env.EMAIL_SENDER_NAME,
|
|
7
|
+
senderEmailAddress: process.env.EMAIL_SENDER_ADDRESS,
|
|
8
|
+
isEmailSyncSendEnabled: process.env.EMAIL_SYNC_SEND_ENABLED,
|
|
9
|
+
smtpPassword: process.env.SMTP_EMAIL_PASSWORD,
|
|
10
|
+
smtpUsername: process.env.SMTP_EMAIL_USERNAME,
|
|
11
|
+
smtpHost: process.env.SMTP_EMAIL_HOST,
|
|
12
|
+
smtpPort: process.env.SMTP_EMAIL_PORT,
|
|
11
13
|
}));
|
|
12
14
|
//# sourceMappingURL=EmailConfigurationVariables.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmailConfigurationVariables.js","sourceRoot":"","sources":["../../src/smtp-email-client/EmailConfigurationVariables.ts"],"names":[],"mappings":";;AAAA,2CAA0C;AAE1C,kBAAe,IAAA,mBAAU,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;IACtC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS;IAC/B,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB;IACzC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,oBAAoB;IAEpD,sBAAsB,EAAE,OAAO,CAAC,GAAG,CAAC,uBAAuB;IAE3D,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAmB;IAC7C,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAmB;IAC7C,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,eAAe;IACrC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,eAAe;CACxC,CAAC,CAAC,CAAC"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
+
import { Transporter } from "nodemailer";
|
|
1
2
|
import { Repository } from "typeorm";
|
|
2
3
|
import CoreLoggerService from "../logger/CoreLoggerService";
|
|
3
4
|
import { Email } from "./email.entity";
|
|
4
5
|
import { EmailConfigurationService } from "./EmailConfigurationService";
|
|
5
|
-
export declare class
|
|
6
|
+
export declare class SmtpEmailClient {
|
|
6
7
|
private logger;
|
|
7
8
|
private emailRepository;
|
|
8
9
|
private config;
|
|
9
|
-
private
|
|
10
|
-
constructor(logger: CoreLoggerService, emailRepository: Repository<Email>, config: EmailConfigurationService);
|
|
10
|
+
private smtpEmailTransporter;
|
|
11
|
+
constructor(logger: CoreLoggerService, emailRepository: Repository<Email>, config: EmailConfigurationService, smtpEmailTransporter: Transporter);
|
|
11
12
|
verify(): Promise<void>;
|
|
12
|
-
sendMail(to: string[], bccTo: string[], subject: string,
|
|
13
|
+
sendMail(to: string[], bccTo: string[], subject: string, sendingUserId: string, plainTextBody?: string, htmlBody?: string): Promise<void>;
|
|
13
14
|
}
|
|
@@ -15,43 +15,36 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
15
15
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
16
16
|
};
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
exports.
|
|
18
|
+
exports.SmtpEmailClient = void 0;
|
|
19
19
|
const common_1 = require("@nestjs/common");
|
|
20
20
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
21
|
-
const nodemailer_1 = require("nodemailer");
|
|
22
21
|
const typeorm_2 = require("typeorm");
|
|
23
22
|
const CoreLoggerService_1 = __importDefault(require("../logger/CoreLoggerService"));
|
|
24
23
|
const email_entity_1 = require("./email.entity");
|
|
25
24
|
const EmailConfigurationService_1 = require("./EmailConfigurationService");
|
|
26
|
-
let
|
|
27
|
-
constructor(logger, emailRepository, config) {
|
|
25
|
+
let SmtpEmailClient = class SmtpEmailClient {
|
|
26
|
+
constructor(logger, emailRepository, config, smtpEmailTransporter) {
|
|
28
27
|
this.logger = logger;
|
|
29
28
|
this.emailRepository = emailRepository;
|
|
30
29
|
this.config = config;
|
|
31
|
-
|
|
32
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-call
|
|
33
|
-
this.transporter = (0, nodemailer_1.createTransport)({
|
|
34
|
-
host: "smtp.fastmail.com",
|
|
35
|
-
port: 587,
|
|
36
|
-
secure: false,
|
|
37
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
38
|
-
auth: {
|
|
39
|
-
user: this.config.emailUsername,
|
|
40
|
-
pass: this.config.emailPassword,
|
|
41
|
-
},
|
|
42
|
-
});
|
|
30
|
+
this.smtpEmailTransporter = smtpEmailTransporter;
|
|
43
31
|
}
|
|
44
32
|
async verify() {
|
|
45
33
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-call
|
|
46
|
-
await this.
|
|
34
|
+
await this.smtpEmailTransporter.verify();
|
|
47
35
|
}
|
|
48
|
-
async sendMail(to, bccTo, subject,
|
|
36
|
+
async sendMail(to, bccTo, subject, sendingUserId, plainTextBody, htmlBody) {
|
|
37
|
+
if (!plainTextBody && !htmlBody) {
|
|
38
|
+
throw new Error("You must provide either html or plain text body for email");
|
|
39
|
+
}
|
|
49
40
|
const serialisedEmailAddresses = to.join(",");
|
|
50
41
|
const email = this.emailRepository.create();
|
|
51
|
-
|
|
42
|
+
// one of these must be present based on the guard above
|
|
43
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
44
|
+
email.body = plainTextBody || htmlBody;
|
|
52
45
|
email.to = serialisedEmailAddresses;
|
|
53
46
|
email.subject = subject;
|
|
54
|
-
email.ownerId =
|
|
47
|
+
email.ownerId = sendingUserId;
|
|
55
48
|
const savedEmail = await this.emailRepository.save(email);
|
|
56
49
|
if (!this.config.isEmailSyncSendEnabled) {
|
|
57
50
|
this.logger.log(`Email saved but not sent because email is disabled. Email id: ${savedEmail.id}`);
|
|
@@ -59,24 +52,25 @@ let EmailClient = class EmailClient {
|
|
|
59
52
|
}
|
|
60
53
|
this.logger.log(`Sending an email. Email id: ${savedEmail.id}`);
|
|
61
54
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access,@typescript-eslint/no-unsafe-call, @typescript-eslint/no-unsafe-argument
|
|
62
|
-
const info = await this.
|
|
55
|
+
const info = await this.smtpEmailTransporter.sendMail({
|
|
63
56
|
from: `"${this.config.senderName}" <${this.config.senderEmailAddress}>`,
|
|
64
57
|
to: serialisedEmailAddresses,
|
|
65
58
|
subject: subject,
|
|
66
|
-
text:
|
|
67
|
-
|
|
59
|
+
text: plainTextBody,
|
|
60
|
+
html: htmlBody,
|
|
68
61
|
});
|
|
69
62
|
email.sentDate = new Date();
|
|
70
63
|
await this.emailRepository.save(email);
|
|
71
64
|
this.logger.log(info);
|
|
72
65
|
}
|
|
73
66
|
};
|
|
74
|
-
|
|
67
|
+
SmtpEmailClient = __decorate([
|
|
75
68
|
(0, common_1.Injectable)(),
|
|
76
69
|
__param(1, (0, typeorm_1.InjectRepository)(email_entity_1.Email)),
|
|
70
|
+
__param(3, (0, common_1.Inject)("SmtpEmailClient")),
|
|
77
71
|
__metadata("design:paramtypes", [CoreLoggerService_1.default,
|
|
78
72
|
typeorm_2.Repository,
|
|
79
|
-
EmailConfigurationService_1.EmailConfigurationService])
|
|
80
|
-
],
|
|
81
|
-
exports.
|
|
73
|
+
EmailConfigurationService_1.EmailConfigurationService, Object])
|
|
74
|
+
], SmtpEmailClient);
|
|
75
|
+
exports.SmtpEmailClient = SmtpEmailClient;
|
|
82
76
|
//# sourceMappingURL=email-client.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email-client.service.js","sourceRoot":"","sources":["../../src/smtp-email-client/email-client.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,2CAAkD;AAClD,6CAAiD;AAEjD,qCAAmC;AACnC,oFAA4D;AAC5D,iDAAqC;AACrC,2EAAsE;AAG/D,IAAM,eAAe,GAArB,MAAM,eAAe;IACxB,YACY,MAAyB,EAEzB,eAAkC,EAClC,MAAiC,EAEjC,oBAAiC;QALjC,WAAM,GAAN,MAAM,CAAmB;QAEzB,oBAAe,GAAf,eAAe,CAAmB;QAClC,WAAM,GAAN,MAAM,CAA2B;QAEjC,yBAAoB,GAApB,oBAAoB,CAAa;IAC1C,CAAC;IAEG,KAAK,CAAC,MAAM;QACf,wGAAwG;QACxG,MAAM,IAAI,CAAC,oBAAoB,CAAC,MAAM,EAAE,CAAC;IAC7C,CAAC;IAEM,KAAK,CAAC,QAAQ,CACjB,EAAY,EACZ,KAAe,EACf,OAAe,EACf,aAAqB,EACrB,aAAsB,EACtB,QAAiB;QAEjB,IAAI,CAAC,aAAa,IAAI,CAAC,QAAQ,EAAE;YAC7B,MAAM,IAAI,KAAK,CACX,2DAA2D,CAC9D,CAAC;SACL;QACD,MAAM,wBAAwB,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;QAE5C,wDAAwD;QACxD,oEAAoE;QACpE,KAAK,CAAC,IAAI,GAAG,aAAc,IAAI,QAAS,CAAC;QAEzC,KAAK,CAAC,EAAE,GAAG,wBAAwB,CAAC;QACpC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QACxB,KAAK,CAAC,OAAO,GAAG,aAAa,CAAC;QAE9B,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1D,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE;YACrC,IAAI,CAAC,MAAM,CAAC,GAAG,CACX,iEAAiE,UAAU,CAAC,EAAE,EAAE,CACnF,CAAC;YACF,OAAO;SACV;QAED,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,+BAA+B,UAAU,CAAC,EAAE,EAAE,CAAC,CAAC;QAChE,wLAAwL;QACxL,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC;YAClD,IAAI,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,MAAM,IAAI,CAAC,MAAM,CAAC,kBAAkB,GAAG;YACvE,EAAE,EAAE,wBAAwB;YAC5B,OAAO,EAAE,OAAO;YAChB,IAAI,EAAE,aAAa;YACnB,IAAI,EAAE,QAAQ;SACV,CAAC,CAAC;QAEV,KAAK,CAAC,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC;QAC5B,MAAM,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;CACJ,CAAA;AA7DY,eAAe;IAD3B,IAAA,mBAAU,GAAE;IAIJ,WAAA,IAAA,0BAAgB,EAAC,oBAAK,CAAC,CAAA;IAGvB,WAAA,IAAA,eAAM,EAAC,iBAAiB,CAAC,CAAA;qCAJV,2BAAiB;QAER,oBAAU;QACnB,qDAAyB;GALpC,eAAe,CA6D3B;AA7DY,0CAAe"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { SmtpEmailClient } from "./email-client.service";
|
|
2
2
|
export declare class EmailClientController {
|
|
3
3
|
private readonly service;
|
|
4
|
-
constructor(service:
|
|
4
|
+
constructor(service: SmtpEmailClient);
|
|
5
5
|
verify(): Promise<void>;
|
|
6
6
|
}
|
|
@@ -34,7 +34,7 @@ EmailClientController = __decorate([
|
|
|
34
34
|
(0, swagger_1.ApiTags)("email-client"),
|
|
35
35
|
(0, common_1.UseGuards)((0, passport_1.AuthGuard)("jwt")),
|
|
36
36
|
(0, common_1.Controller)("email-client"),
|
|
37
|
-
__metadata("design:paramtypes", [email_client_service_1.
|
|
37
|
+
__metadata("design:paramtypes", [email_client_service_1.SmtpEmailClient])
|
|
38
38
|
], EmailClientController);
|
|
39
39
|
exports.EmailClientController = EmailClientController;
|
|
40
40
|
//# sourceMappingURL=email.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email.controller.js","sourceRoot":"","sources":["../../src/smtp-email-client/email.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA0D;AAC1D,+CAA2C;AAC3C,6CAAsE;AACtE,iEAAuD;AAMhD,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAC9B,YAA6B,OAAwB;QAAxB,YAAO,GAAP,OAAO,CAAiB;IAAG,CAAC;IAInD,AAAN,KAAK,CAAC,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;IACjC,CAAC;CACJ,CAAA;AAHS;IAFL,IAAA,YAAG,EAAC,QAAQ,CAAC;IACb,IAAA,uBAAa,GAAE;;;;mDAGf;AAPQ,qBAAqB;IAJjC,IAAA,uBAAa,GAAE;IACf,IAAA,iBAAO,EAAC,cAAc,CAAC;IACvB,IAAA,kBAAS,EAAC,IAAA,oBAAS,EAAC,KAAK,CAAC,CAAC;IAC3B,IAAA,mBAAU,EAAC,cAAc,CAAC;qCAEe,sCAAe;GAD5C,qBAAqB,CAQjC;AARY,sDAAqB"}
|
|
File without changes
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email.entity.js","sourceRoot":"","sources":["../../src/smtp-email-client/email.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCASiB;AACjB,yDAA0C;AAC1C,6CAAiE;AAG1D,IAAM,KAAK,GAAX,MAAM,KAAK;CA2CjB,CAAA;AA1CG;IAAC,IAAA,gCAAsB,GAAE;IACxB,IAAA,qBAAW,GAAE;;iCACF;AAEZ;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,gBAAM,EAAC,EAAC,QAAQ,EAAE,KAAK,EAAC,CAAC;IACzB,IAAA,eAAK,GAAE;IACP,IAAA,2BAAO,GAAE;;sCACO;AAEjB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,gBAAM,EAAC,EAAC,QAAQ,EAAE,KAAK,EAAC,CAAC;IACzB,IAAA,mBAAS,EAAC,MAAM,CAAC;;mCACJ;AAEd;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,qBAAW,EAAC,EAAC,IAAI,EAAE,MAAM,EAAC,CAAC;;iCAChB;AAEZ;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,qBAAW,GAAE;;mCACA;AAEd;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,qBAAW,GAAE;;sCACG;AAEjB;IAAC,IAAA,gBAAM,EAAC,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC;IACxB,IAAA,6BAAmB,GAAE;8BACX,IAAI;uCAAC;AAEhB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,0BAAgB,GAAE;8BACL,IAAI;0CAAC;AAEnB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,0BAAgB,GAAE;8BACL,IAAI;0CAAC;AAEnB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,0BAAgB,GAAE;8BACL,IAAI;0CAAC;AA1CV,KAAK;IADjB,IAAA,gBAAM,GAAE;GACI,KAAK,CA2CjB;AA3CY,sBAAK"}
|
package/dist/{email-client/email-client.module.js → smtp-email-client/smtp-email-client.module.js}
RENAMED
|
@@ -9,7 +9,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
9
9
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.
|
|
12
|
+
exports.SmtpEmailClientModule = void 0;
|
|
13
13
|
const common_1 = require("@nestjs/common");
|
|
14
14
|
const config_1 = require("@nestjs/config");
|
|
15
15
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
@@ -19,19 +19,19 @@ const email_controller_1 = require("./email.controller");
|
|
|
19
19
|
const email_entity_1 = require("./email.entity");
|
|
20
20
|
const EmailConfigurationService_1 = require("./EmailConfigurationService");
|
|
21
21
|
const EmailConfigurationVariables_1 = __importDefault(require("./EmailConfigurationVariables"));
|
|
22
|
-
let
|
|
22
|
+
let SmtpEmailClientModule = class SmtpEmailClientModule {
|
|
23
23
|
};
|
|
24
|
-
|
|
24
|
+
SmtpEmailClientModule = __decorate([
|
|
25
25
|
(0, common_1.Module)({
|
|
26
26
|
imports: [
|
|
27
27
|
config_1.ConfigModule.forFeature(EmailConfigurationVariables_1.default),
|
|
28
28
|
logger_module_1.LoggerModule,
|
|
29
29
|
typeorm_1.TypeOrmModule.forFeature([email_entity_1.Email]),
|
|
30
30
|
],
|
|
31
|
-
providers: [email_client_service_1.
|
|
31
|
+
providers: [email_client_service_1.SmtpEmailClient, EmailConfigurationService_1.EmailConfigurationService],
|
|
32
32
|
controllers: [email_controller_1.EmailClientController],
|
|
33
|
-
exports: [email_client_service_1.
|
|
33
|
+
exports: [email_client_service_1.SmtpEmailClient],
|
|
34
34
|
})
|
|
35
|
-
],
|
|
36
|
-
exports.
|
|
37
|
-
//# sourceMappingURL=email-client.module.js.map
|
|
35
|
+
], SmtpEmailClientModule);
|
|
36
|
+
exports.SmtpEmailClientModule = SmtpEmailClientModule;
|
|
37
|
+
//# sourceMappingURL=smtp-email-client.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smtp-email-client.module.js","sourceRoot":"","sources":["../../src/smtp-email-client/smtp-email-client.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAsC;AACtC,2CAA4C;AAC5C,6CAA8C;AAC9C,2DAAqD;AACrD,iEAAuD;AACvD,yDAAyD;AACzD,iDAAqC;AACrC,2EAAsE;AACtE,gGAA4D;AAYrD,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;CAAG,CAAA;AAAxB,qBAAqB;IAVjC,IAAA,eAAM,EAAC;QACJ,OAAO,EAAE;YACL,qBAAY,CAAC,UAAU,CAAC,qCAAe,CAAC;YACxC,4BAAY;YACZ,uBAAa,CAAC,UAAU,CAAC,CAAC,oBAAK,CAAC,CAAC;SACpC;QACD,SAAS,EAAE,CAAC,sCAAe,EAAE,qDAAyB,CAAC;QACvD,WAAW,EAAE,CAAC,wCAAqB,CAAC;QACpC,OAAO,EAAE,CAAC,sCAAe,CAAC;KAC7B,CAAC;GACW,qBAAqB,CAAG;AAAxB,sDAAqB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ConfigService } from "@nestjs/config";
|
|
2
|
+
import { ValidatedConfigurationService } from "../configuration/ValidatedConfigurationService";
|
|
3
|
+
export declare class TwitterClientConfigurationService extends ValidatedConfigurationService {
|
|
4
|
+
private configService;
|
|
5
|
+
constructor(configService: ConfigService);
|
|
6
|
+
get appSecret(): string;
|
|
7
|
+
get appKey(): string;
|
|
8
|
+
get accessToken(): string;
|
|
9
|
+
get accessSecret(): string;
|
|
10
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.TwitterClientConfigurationService = void 0;
|
|
13
|
+
/* eslint-disable @typescript-eslint/no-non-null-assertion */
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const config_1 = require("@nestjs/config");
|
|
16
|
+
const class_validator_1 = require("class-validator");
|
|
17
|
+
const ValidatedConfigurationService_1 = require("../configuration/ValidatedConfigurationService");
|
|
18
|
+
let TwitterClientConfigurationService = class TwitterClientConfigurationService extends ValidatedConfigurationService_1.ValidatedConfigurationService {
|
|
19
|
+
constructor(configService) {
|
|
20
|
+
super();
|
|
21
|
+
this.configService = configService;
|
|
22
|
+
}
|
|
23
|
+
get appSecret() {
|
|
24
|
+
return this.configService.get("twitter-client.appSecret");
|
|
25
|
+
}
|
|
26
|
+
get appKey() {
|
|
27
|
+
return this.configService.get("twitter-client.appKey");
|
|
28
|
+
}
|
|
29
|
+
get accessToken() {
|
|
30
|
+
return this.configService.get("twitter-client.accessToken");
|
|
31
|
+
}
|
|
32
|
+
get accessSecret() {
|
|
33
|
+
return this.configService.get("twitter-client.accessSecret");
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
__decorate([
|
|
37
|
+
(0, class_validator_1.IsDefined)(),
|
|
38
|
+
(0, class_validator_1.IsString)(),
|
|
39
|
+
__metadata("design:type", String),
|
|
40
|
+
__metadata("design:paramtypes", [])
|
|
41
|
+
], TwitterClientConfigurationService.prototype, "appSecret", null);
|
|
42
|
+
__decorate([
|
|
43
|
+
(0, class_validator_1.IsDefined)(),
|
|
44
|
+
(0, class_validator_1.IsString)(),
|
|
45
|
+
__metadata("design:type", String),
|
|
46
|
+
__metadata("design:paramtypes", [])
|
|
47
|
+
], TwitterClientConfigurationService.prototype, "appKey", null);
|
|
48
|
+
__decorate([
|
|
49
|
+
(0, class_validator_1.IsDefined)(),
|
|
50
|
+
(0, class_validator_1.IsString)(),
|
|
51
|
+
__metadata("design:type", String),
|
|
52
|
+
__metadata("design:paramtypes", [])
|
|
53
|
+
], TwitterClientConfigurationService.prototype, "accessToken", null);
|
|
54
|
+
__decorate([
|
|
55
|
+
(0, class_validator_1.IsDefined)(),
|
|
56
|
+
(0, class_validator_1.IsString)(),
|
|
57
|
+
__metadata("design:type", String),
|
|
58
|
+
__metadata("design:paramtypes", [])
|
|
59
|
+
], TwitterClientConfigurationService.prototype, "accessSecret", null);
|
|
60
|
+
TwitterClientConfigurationService = __decorate([
|
|
61
|
+
(0, common_1.Injectable)(),
|
|
62
|
+
__metadata("design:paramtypes", [config_1.ConfigService])
|
|
63
|
+
], TwitterClientConfigurationService);
|
|
64
|
+
exports.TwitterClientConfigurationService = TwitterClientConfigurationService;
|
|
65
|
+
//# sourceMappingURL=TwitterClientConfigurationService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TwitterClientConfigurationService.js","sourceRoot":"","sources":["../../src/twitter-client/TwitterClientConfigurationService.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6DAA6D;AAC7D,2CAA0C;AAC1C,2CAA6C;AAC7C,qDAAoD;AACpD,kGAA6F;AAGtF,IAAM,iCAAiC,GAAvC,MAAM,iCAAkC,SAAQ,6DAA6B;IAChF,YAAoB,aAA4B;QAC5C,KAAK,EAAE,CAAC;QADQ,kBAAa,GAAb,aAAa,CAAe;IAEhD,CAAC;IAED,IAEI,SAAS;QACT,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,0BAA0B,CAAE,CAAC;IACvE,CAAC;IACD,IAEI,MAAM;QACN,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,uBAAuB,CAAE,CAAC;IACpE,CAAC;IACD,IAEI,WAAW;QACX,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,4BAA4B,CAAE,CAAC;IACzE,CAAC;IACD,IAEI,YAAY;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,6BAA6B,CAAE,CAAC;IAC1E,CAAC;CACJ,CAAA;AApBG;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;kEAGV;AACD;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;+DAGV;AACD;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;oEAGV;AACD;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;qEAGV;AAxBQ,iCAAiC;IAD7C,IAAA,mBAAU,GAAE;qCAE0B,sBAAa;GADvC,iCAAiC,CAyB7C;AAzBY,8EAAiC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { TwitterApiReadWrite } from "twitter-api-v2";
|
|
2
|
+
import { TwitterClientConfigurationService } from "./TwitterClientConfigurationService";
|
|
3
|
+
export declare const TwitterClientProvider: {
|
|
4
|
+
provide: string;
|
|
5
|
+
useFactory: (config: TwitterClientConfigurationService) => TwitterApiReadWrite;
|
|
6
|
+
inject: (typeof TwitterClientConfigurationService)[];
|
|
7
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TwitterClientProvider = void 0;
|
|
4
|
+
const twitter_api_v2_1 = require("twitter-api-v2");
|
|
5
|
+
const TwitterClientConfigurationService_1 = require("./TwitterClientConfigurationService");
|
|
6
|
+
exports.TwitterClientProvider = {
|
|
7
|
+
provide: "TwitterClient",
|
|
8
|
+
useFactory: (config) => {
|
|
9
|
+
const fullClient = new twitter_api_v2_1.TwitterApi({
|
|
10
|
+
accessSecret: config.accessSecret,
|
|
11
|
+
accessToken: config.accessToken,
|
|
12
|
+
appKey: config.appKey,
|
|
13
|
+
appSecret: config.appSecret,
|
|
14
|
+
});
|
|
15
|
+
return fullClient.readWrite;
|
|
16
|
+
},
|
|
17
|
+
inject: [TwitterClientConfigurationService_1.TwitterClientConfigurationService],
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=TwitterClientProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TwitterClientProvider.js","sourceRoot":"","sources":["../../src/twitter-client/TwitterClientProvider.ts"],"names":[],"mappings":";;;AAAA,mDAA+D;AAC/D,2FAAsF;AAEzE,QAAA,qBAAqB,GAAG;IACjC,OAAO,EAAE,eAAe;IACxB,UAAU,EAAE,CACR,MAAyC,EACtB,EAAE;QACrB,MAAM,UAAU,GAAe,IAAI,2BAAU,CAAC;YAC1C,YAAY,EAAE,MAAM,CAAC,YAAY;YACjC,WAAW,EAAE,MAAM,CAAC,WAAW;YAC/B,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,SAAS,EAAE,MAAM,CAAC,SAAS;SAC9B,CAAC,CAAC;QAEH,OAAO,UAAU,CAAC,SAAS,CAAC;IAChC,CAAC;IACD,MAAM,EAAE,CAAC,qEAAiC,CAAC;CAC9C,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
declare const _default: (() => {
|
|
2
|
+
accessSecret: string | undefined;
|
|
3
|
+
accessToken: string | undefined;
|
|
4
|
+
appKey: string | undefined;
|
|
5
|
+
appSecret: string | undefined;
|
|
6
|
+
}) & import("@nestjs/config").ConfigFactoryKeyHost<{
|
|
7
|
+
accessSecret: string | undefined;
|
|
8
|
+
accessToken: string | undefined;
|
|
9
|
+
appKey: string | undefined;
|
|
10
|
+
appSecret: string | undefined;
|
|
11
|
+
}>;
|
|
12
|
+
export default _default;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const config_1 = require("@nestjs/config");
|
|
4
|
+
exports.default = (0, config_1.registerAs)("twitter-client", () => ({
|
|
5
|
+
accessSecret: process.env.TWITTER_ACCESS_SECRET,
|
|
6
|
+
accessToken: process.env.TWITTER_ACCESS_TOKEN,
|
|
7
|
+
appKey: process.env.TWITTER_APP_KEY,
|
|
8
|
+
appSecret: process.env.TWITTER_APP_SECRET,
|
|
9
|
+
}));
|
|
10
|
+
//# sourceMappingURL=TwitterConfigurationVariables.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TwitterConfigurationVariables.js","sourceRoot":"","sources":["../../src/twitter-client/TwitterConfigurationVariables.ts"],"names":[],"mappings":";;AAAA,2CAA0C;AAE1C,kBAAe,IAAA,mBAAU,EAAC,gBAAgB,EAAE,GAAG,EAAE,CAAC,CAAC;IAC/C,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAqB;IAC/C,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,oBAAoB;IAC7C,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,eAAe;IACnC,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB;CAC5C,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { EUploadMimeType, TwitterApiReadWrite } from "twitter-api-v2";
|
|
2
|
+
import CoreLoggerService from "../../logger/CoreLoggerService";
|
|
3
|
+
export declare class TwitterClientService {
|
|
4
|
+
private readonly logger;
|
|
5
|
+
private readonly clientInstance;
|
|
6
|
+
constructor(logger: CoreLoggerService, clientInstance: TwitterApiReadWrite);
|
|
7
|
+
uploadMedia(bytes: string, type: EUploadMimeType): Promise<string>;
|
|
8
|
+
sendTweet(message: string, mediaIds?: string[]): Promise<void>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
15
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
16
|
+
};
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.TwitterClientService = void 0;
|
|
19
|
+
/* eslint-disable @typescript-eslint/naming-convention */
|
|
20
|
+
const common_1 = require("@nestjs/common");
|
|
21
|
+
const twitter_api_v2_1 = require("twitter-api-v2");
|
|
22
|
+
const CoreLoggerService_1 = __importDefault(require("../../logger/CoreLoggerService"));
|
|
23
|
+
let TwitterClientService = class TwitterClientService {
|
|
24
|
+
constructor(logger, clientInstance) {
|
|
25
|
+
this.logger = logger;
|
|
26
|
+
this.clientInstance = clientInstance;
|
|
27
|
+
this.logger.log("Setting up twitter client");
|
|
28
|
+
}
|
|
29
|
+
async uploadMedia(bytes, type) {
|
|
30
|
+
return this.clientInstance.v1.uploadMedia(
|
|
31
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
|
|
32
|
+
Buffer.from(bytes, "binary"), { type });
|
|
33
|
+
}
|
|
34
|
+
async sendTweet(message, mediaIds) {
|
|
35
|
+
await this.clientInstance.v2.tweet(message, {
|
|
36
|
+
media: { media_ids: mediaIds },
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
TwitterClientService = __decorate([
|
|
41
|
+
(0, common_1.Injectable)(),
|
|
42
|
+
__param(1, (0, common_1.Inject)("TwitterClient")),
|
|
43
|
+
__metadata("design:paramtypes", [CoreLoggerService_1.default,
|
|
44
|
+
twitter_api_v2_1.TwitterApiReadWrite])
|
|
45
|
+
], TwitterClientService);
|
|
46
|
+
exports.TwitterClientService = TwitterClientService;
|
|
47
|
+
//# sourceMappingURL=twitter-client.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"twitter-client.service.js","sourceRoot":"","sources":["../../../src/twitter-client/services/twitter-client.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,yDAAyD;AACzD,2CAAkD;AAClD,mDAAoE;AACpE,uFAA+D;AAGxD,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAC7B,YACqB,MAAyB,EAEzB,cAAmC;QAFnC,WAAM,GAAN,MAAM,CAAmB;QAEzB,mBAAc,GAAd,cAAc,CAAqB;QAEpD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;IACjD,CAAC;IAEM,KAAK,CAAC,WAAW,CACpB,KAAa,EACb,IAAqB;QAErB,OAAO,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,WAAW;QACrC,iEAAiE;QACjE,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,CAAC,EAC5B,EAAC,IAAI,EAAC,CACT,CAAC;IACN,CAAC;IAEM,KAAK,CAAC,SAAS,CAClB,OAAe,EACf,QAAmB;QAEnB,MAAM,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE;YACxC,KAAK,EAAE,EAAC,SAAS,EAAE,QAAQ,EAAC;SAC/B,CAAC,CAAC;IACP,CAAC;CACJ,CAAA;AA5BY,oBAAoB;IADhC,IAAA,mBAAU,GAAE;IAIJ,WAAA,IAAA,eAAM,EAAC,eAAe,CAAC,CAAA;qCADC,2BAAiB;QAET,oCAAmB;GAJ/C,oBAAoB,CA4BhC;AA5BY,oDAAoB"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
9
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.TwitterAccountModule = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
require("reflect-metadata");
|
|
15
|
+
const TwitterClientConfigurationService_1 = require("./TwitterClientConfigurationService");
|
|
16
|
+
const twitter_client_service_1 = require("./services/twitter-client.service");
|
|
17
|
+
const TwitterConfigurationVariables_1 = __importDefault(require("./TwitterConfigurationVariables"));
|
|
18
|
+
const config_1 = require("@nestjs/config");
|
|
19
|
+
const core_app_module_1 = require("../root-app/core-app.module");
|
|
20
|
+
const TwitterClientProvider_1 = require("./TwitterClientProvider");
|
|
21
|
+
let TwitterAccountModule = class TwitterAccountModule {
|
|
22
|
+
};
|
|
23
|
+
TwitterAccountModule = __decorate([
|
|
24
|
+
(0, common_1.Module)({
|
|
25
|
+
imports: [config_1.ConfigModule.forFeature(TwitterConfigurationVariables_1.default), core_app_module_1.CoreModule],
|
|
26
|
+
providers: [
|
|
27
|
+
TwitterClientProvider_1.TwitterClientProvider,
|
|
28
|
+
TwitterClientConfigurationService_1.TwitterClientConfigurationService,
|
|
29
|
+
twitter_client_service_1.TwitterClientService,
|
|
30
|
+
],
|
|
31
|
+
controllers: [],
|
|
32
|
+
})
|
|
33
|
+
], TwitterAccountModule);
|
|
34
|
+
exports.TwitterAccountModule = TwitterAccountModule;
|
|
35
|
+
//# sourceMappingURL=twitter-account.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"twitter-account.module.js","sourceRoot":"","sources":["../../src/twitter-client/twitter-account.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAsC;AACtC,4BAA0B;AAC1B,2FAAsF;AACtF,8EAAuE;AACvE,oGAA8D;AAC9D,2CAA4C;AAC5C,iEAAuD;AACvD,mEAA8D;AAWvD,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;CAAG,CAAA;AAAvB,oBAAoB;IAThC,IAAA,eAAM,EAAC;QACJ,OAAO,EAAE,CAAC,qBAAY,CAAC,UAAU,CAAC,uCAAe,CAAC,EAAE,4BAAU,CAAC;QAC/D,SAAS,EAAE;YACP,6CAAqB;YACrB,qEAAiC;YACjC,6CAAoB;SACvB;QACD,WAAW,EAAE,EAAE;KAClB,CAAC;GACW,oBAAoB,CAAG;AAAvB,oDAAoB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@darraghor/nest-backend-libs",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.29.0",
|
|
4
4
|
"license": "UNLICENSED",
|
|
5
5
|
"description": "Some helpers for personal projects in nestjs",
|
|
6
6
|
"homepage": "https://github.com/darraghoriordan/nest-backend-libs",
|
|
@@ -64,12 +64,13 @@
|
|
|
64
64
|
"rxjs": "7.5.7",
|
|
65
65
|
"swagger-ui-express": "4.6.0",
|
|
66
66
|
"tslog": "3.3.4",
|
|
67
|
+
"twitter-api-v2": "1.12.9",
|
|
67
68
|
"typeorm": "^0.3.10"
|
|
68
69
|
},
|
|
69
70
|
"devDependencies": {
|
|
70
71
|
"@commitlint/cli": "17.3.0",
|
|
71
72
|
"@commitlint/config-conventional": "17.3.0",
|
|
72
|
-
"@darraghor/eslint-plugin-nestjs-typed": "3.17.
|
|
73
|
+
"@darraghor/eslint-plugin-nestjs-typed": "3.17.1",
|
|
73
74
|
"@nestjs/cli": "9.1.5",
|
|
74
75
|
"@nestjs/schematics": "^9.0.3",
|
|
75
76
|
"@semantic-release/changelog": "6.0.2",
|
|
@@ -85,7 +86,7 @@
|
|
|
85
86
|
"@typescript-eslint/eslint-plugin": "5.45.0",
|
|
86
87
|
"@typescript-eslint/parser": "5.45.0",
|
|
87
88
|
"copyfiles": "2.4.1",
|
|
88
|
-
"eslint": "8.
|
|
89
|
+
"eslint": "8.29.0",
|
|
89
90
|
"eslint-config-prettier": "8.5.0",
|
|
90
91
|
"eslint-plugin-eslint-comments": "3.2.0",
|
|
91
92
|
"eslint-plugin-jest": "27.1.6",
|
|
@@ -101,7 +102,7 @@
|
|
|
101
102
|
"prettier": "2.8.0",
|
|
102
103
|
"semantic-release": "19.0.5",
|
|
103
104
|
"ts-jest": "29.0.3",
|
|
104
|
-
"ts-loader": "9.4.
|
|
105
|
+
"ts-loader": "9.4.2",
|
|
105
106
|
"ts-node": "10.9.1",
|
|
106
107
|
"tsconfig-paths": "4.1.1",
|
|
107
108
|
"typescript": "4.9.3"
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"EmailConfigurationService.js","sourceRoot":"","sources":["../../src/email-client/EmailConfigurationService.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6DAA6D;AAC7D,2CAA0C;AAC1C,2CAA6C;AAC7C,qDAA+D;AAC/D,kGAA6F;AAGtF,IAAM,yBAAyB,GAA/B,MAAM,yBAA0B,SAAQ,6DAA6B;IACxE,YAAoB,aAA4B;QAC5C,KAAK,EAAE,CAAC;QADQ,kBAAa,GAAb,aAAa,CAAe;IAEhD,CAAC;IAED,IAEI,sBAAsB;QACtB,OAAO,CACH,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,8BAA8B,CAAC;YAC9D,MAAM,CACT,CAAC;IACN,CAAC;IAED,IAEI,QAAQ;QACR,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,gBAAgB,CAAE,CAAC;IAC7D,CAAC;IAED,IAEI,aAAa;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,qBAAqB,CAAE,CAAC;IAClE,CAAC;IAED,IAEI,aAAa;QACb,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,qBAAqB,CAAE,CAAC;IAClE,CAAC;IAED,IAEI,kBAAkB;QAClB,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,0BAA0B,CAAE,CAAC;IACvE,CAAC;IAED,IAEI,UAAU;QACV,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,kBAAkB,CAAE,CAAC;IAC/D,CAAC;CACJ,CAAA;AAtCG;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,2BAAS,GAAE;;;uEAMX;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;yDAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;8DAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;8DAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;mEAGV;AAED;IAAC,IAAA,2BAAS,GAAE;IACX,IAAA,0BAAQ,GAAE;;;2DAGV;AA1CQ,yBAAyB;IADrC,IAAA,mBAAU,GAAE;qCAE0B,sBAAa;GADvC,yBAAyB,CA2CrC;AA3CY,8DAAyB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"EmailConfigurationVariables.js","sourceRoot":"","sources":["../../src/email-client/EmailConfigurationVariables.ts"],"names":[],"mappings":";;AAAA,2CAA0C;AAE1C,kBAAe,IAAA,mBAAU,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC;IACtC,sBAAsB,EAAE,OAAO,CAAC,GAAG,CAAC,uBAAuB;IAC3D,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS;IAC/B,aAAa,EAAE,OAAO,CAAC,GAAG,CAAC,cAAc;IACzC,aAAa,EAAE,OAAO,CAAC,GAAG,CAAC,cAAc;IACzC,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,oBAAoB;IACpD,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB;CAC5C,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"email-client.module.js","sourceRoot":"","sources":["../../src/email-client/email-client.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAsC;AACtC,2CAA4C;AAC5C,6CAA8C;AAC9C,2DAAqD;AACrD,iEAAmD;AACnD,yDAAyD;AACzD,iDAAqC;AACrC,2EAAsE;AACtE,gGAA4D;AAYrD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;CAAG,CAAA;AAApB,iBAAiB;IAV7B,IAAA,eAAM,EAAC;QACJ,OAAO,EAAE;YACL,qBAAY,CAAC,UAAU,CAAC,qCAAe,CAAC;YACxC,4BAAY;YACZ,uBAAa,CAAC,UAAU,CAAC,CAAC,oBAAK,CAAC,CAAC;SACpC;QACD,SAAS,EAAE,CAAC,kCAAW,EAAE,qDAAyB,CAAC;QACnD,WAAW,EAAE,CAAC,wCAAqB,CAAC;QACpC,OAAO,EAAE,CAAC,kCAAW,CAAC;KACzB,CAAC;GACW,iBAAiB,CAAG;AAApB,8CAAiB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"email-client.service.js","sourceRoot":"","sources":["../../src/email-client/email-client.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,2CAA0C;AAC1C,6CAAiD;AACjD,2CAAwD;AACxD,qCAAmC;AACnC,oFAA4D;AAC5D,iDAAqC;AACrC,2EAAsE;AAG/D,IAAM,WAAW,GAAjB,MAAM,WAAW;IAEpB,YACY,MAAyB,EAEzB,eAAkC,EAClC,MAAiC;QAHjC,WAAM,GAAN,MAAM,CAAmB;QAEzB,oBAAe,GAAf,eAAe,CAAmB;QAClC,WAAM,GAAN,MAAM,CAA2B;QAEzC,sEAAsE;QACtE,qGAAqG;QACrG,IAAI,CAAC,WAAW,GAAG,IAAA,4BAAe,EAAC;YAC/B,IAAI,EAAE,mBAAmB;YACzB,IAAI,EAAE,GAAG;YACT,MAAM,EAAE,KAAK;YACb,mEAAmE;YACnE,IAAI,EAAE;gBACF,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa;gBAC/B,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa;aAClC;SACJ,CAAC,CAAC;IACP,CAAC;IAEM,KAAK,CAAC,MAAM;QACf,wGAAwG;QACxG,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;IACpC,CAAC;IAEM,KAAK,CAAC,QAAQ,CACjB,EAAY,EACZ,KAAe,EACf,OAAe,EACf,IAAY,EACZ,kBAA0B;QAE1B,MAAM,wBAAwB,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAE9C,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;QAC5C,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;QAClB,KAAK,CAAC,EAAE,GAAG,wBAAwB,CAAC;QACpC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QACxB,KAAK,CAAC,OAAO,GAAG,kBAAkB,CAAC;QAEnC,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1D,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE;YACrC,IAAI,CAAC,MAAM,CAAC,GAAG,CACX,iEAAiE,UAAU,CAAC,EAAE,EAAE,CACnF,CAAC;YACF,OAAO;SACV;QAED,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,+BAA+B,UAAU,CAAC,EAAE,EAAE,CAAC,CAAC;QAChE,wLAAwL;QACxL,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC;YACzC,IAAI,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,MAAM,IAAI,CAAC,MAAM,CAAC,kBAAkB,GAAG;YACvE,EAAE,EAAE,wBAAwB;YAC5B,OAAO,EAAE,OAAO;YAChB,IAAI,EAAE,IAAI,EAAE,kBAAkB;YAC9B,6CAA6C;SACzC,CAAC,CAAC;QACV,KAAK,CAAC,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC;QAC5B,MAAM,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;CACJ,CAAA;AA/DY,WAAW;IADvB,IAAA,mBAAU,GAAE;IAKJ,WAAA,IAAA,0BAAgB,EAAC,oBAAK,CAAC,CAAA;qCADR,2BAAiB;QAER,oBAAU;QACnB,qDAAyB;GANpC,WAAW,CA+DvB;AA/DY,kCAAW"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"email.controller.js","sourceRoot":"","sources":["../../src/email-client/email.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA0D;AAC1D,+CAA2C;AAC3C,6CAAsE;AACtE,iEAAmD;AAM5C,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAC9B,YAA6B,OAAoB;QAApB,YAAO,GAAP,OAAO,CAAa;IAAG,CAAC;IAI/C,AAAN,KAAK,CAAC,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;IACjC,CAAC;CACJ,CAAA;AAHS;IAFL,IAAA,YAAG,EAAC,QAAQ,CAAC;IACb,IAAA,uBAAa,GAAE;;;;mDAGf;AAPQ,qBAAqB;IAJjC,IAAA,uBAAa,GAAE;IACf,IAAA,iBAAO,EAAC,cAAc,CAAC;IACvB,IAAA,kBAAS,EAAC,IAAA,oBAAS,EAAC,KAAK,CAAC,CAAC;IAC3B,IAAA,mBAAU,EAAC,cAAc,CAAC;qCAEe,kCAAW;GADxC,qBAAqB,CAQjC;AARY,sDAAqB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"email.entity.js","sourceRoot":"","sources":["../../src/email-client/email.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCASiB;AACjB,yDAA0C;AAC1C,6CAAiE;AAG1D,IAAM,KAAK,GAAX,MAAM,KAAK;CA2CjB,CAAA;AA1CG;IAAC,IAAA,gCAAsB,GAAE;IACxB,IAAA,qBAAW,GAAE;;iCACF;AAEZ;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,gBAAM,EAAC,EAAC,QAAQ,EAAE,KAAK,EAAC,CAAC;IACzB,IAAA,eAAK,GAAE;IACP,IAAA,2BAAO,GAAE;;sCACO;AAEjB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,gBAAM,EAAC,EAAC,QAAQ,EAAE,KAAK,EAAC,CAAC;IACzB,IAAA,mBAAS,EAAC,MAAM,CAAC;;mCACJ;AAEd;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,qBAAW,EAAC,EAAC,IAAI,EAAE,MAAM,EAAC,CAAC;;iCAChB;AAEZ;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,qBAAW,GAAE;;mCACA;AAEd;IAAC,IAAA,gBAAM,GAAE;IACR,IAAA,qBAAW,GAAE;;sCACG;AAEjB;IAAC,IAAA,gBAAM,EAAC,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC;IACxB,IAAA,6BAAmB,GAAE;8BACX,IAAI;uCAAC;AAEhB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,0BAAgB,GAAE;8BACL,IAAI;0CAAC;AAEnB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,0BAAgB,GAAE;8BACL,IAAI;0CAAC;AAEnB;IAAC,IAAA,qBAAW,GAAE;IACb,IAAA,0BAAgB,GAAE;8BACL,IAAI;0CAAC;AA1CV,KAAK;IADjB,IAAA,gBAAM,GAAE;GACI,KAAK,CA2CjB;AA3CY,sBAAK"}
|