@darraghor/nest-backend-libs 1.0.5 → 1.1.2
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/authz/authz.module.js +2 -13
- package/dist/authz/authz.module.js.map +1 -1
- package/dist/authzclient/AuthClientConfigurationService.d.ts +7 -0
- package/dist/authzclient/AuthClientConfigurationService.js +38 -0
- package/dist/authzclient/AuthClientConfigurationService.js.map +1 -0
- package/dist/authzclient/AuthClientConfigurationVariables.d.ts +4 -0
- package/dist/authzclient/AuthClientConfigurationVariables.js +7 -0
- package/dist/authzclient/AuthClientConfigurationVariables.js.map +1 -0
- package/dist/authzclient/AuthzClientProvider.d.ts +7 -0
- package/dist/authzclient/AuthzClientProvider.js +17 -0
- package/dist/authzclient/AuthzClientProvider.js.map +1 -0
- package/dist/{authz → authzclient}/UserProfile.dto.d.ts +0 -0
- package/dist/{authz → authzclient}/UserProfile.dto.js +0 -0
- package/dist/authzclient/UserProfile.dto.js.map +1 -0
- package/dist/authzclient/authz-client.module.d.ts +2 -0
- package/dist/authzclient/authz-client.module.js +33 -0
- package/dist/authzclient/authz-client.module.js.map +1 -0
- package/dist/authzclient/authz.service.d.ts +9 -0
- package/dist/{authz → authzclient}/authz.service.js +8 -11
- package/dist/authzclient/authz.service.js.map +1 -0
- package/dist/configuration/ValidatedConfigurationService.js +14 -1
- package/dist/configuration/ValidatedConfigurationService.js.map +1 -1
- package/dist/database/TypeOrmConfigurationProvider.js +11 -12
- package/dist/database/TypeOrmConfigurationProvider.js.map +1 -1
- package/dist/index.d.ts +4 -2
- package/dist/index.js +7 -3
- package/dist/index.js.map +1 -1
- package/dist/person/person.module.js +6 -2
- package/dist/person/person.module.js.map +1 -1
- package/dist/person/person.service.d.ts +2 -2
- package/dist/person/person.service.js +2 -2
- package/dist/person/person.service.js.map +1 -1
- package/dist/root-app/SwaggerGen.js +1 -1
- package/dist/root-app/SwaggerGen.js.map +1 -1
- package/dist/root-app/{app.module.d.ts → core-app.module.d.ts} +1 -1
- package/dist/root-app/{app.module.js → core-app.module.js} +12 -19
- package/dist/root-app/core-app.module.js.map +1 -0
- package/package.json +1 -1
- package/dist/authz/UserProfile.dto.js.map +0 -1
- package/dist/authz/authz.service.d.ts +0 -10
- package/dist/authz/authz.service.js.map +0 -1
- package/dist/root-app/app.module.js.map +0 -1
|
@@ -15,7 +15,6 @@ const passport_1 = require("@nestjs/passport");
|
|
|
15
15
|
const logger_module_1 = require("../logger/logger.module");
|
|
16
16
|
const person_module_1 = require("../person/person.module");
|
|
17
17
|
const AuthConfigurationService_1 = require("./AuthConfigurationService");
|
|
18
|
-
const authz_service_1 = require("./authz.service");
|
|
19
18
|
const authzstrategy_1 = require("./authzstrategy");
|
|
20
19
|
const AuthConfigurationVariables_1 = __importDefault(require("./AuthConfigurationVariables"));
|
|
21
20
|
const config_1 = require("@nestjs/config");
|
|
@@ -30,18 +29,8 @@ AuthzModule = __decorate([
|
|
|
30
29
|
logger_module_1.LoggerModule,
|
|
31
30
|
person_module_1.PersonModule,
|
|
32
31
|
],
|
|
33
|
-
providers: [
|
|
34
|
-
|
|
35
|
-
authz_service_1.AuthZClientService,
|
|
36
|
-
AuthConfigurationService_1.AuthConfigurationService,
|
|
37
|
-
DefaultAuthGuard_1.DefaultAuthGuard,
|
|
38
|
-
],
|
|
39
|
-
exports: [
|
|
40
|
-
passport_1.PassportModule,
|
|
41
|
-
authz_service_1.AuthZClientService,
|
|
42
|
-
AuthConfigurationService_1.AuthConfigurationService,
|
|
43
|
-
DefaultAuthGuard_1.DefaultAuthGuard,
|
|
44
|
-
],
|
|
32
|
+
providers: [authzstrategy_1.JwtStrategy, AuthConfigurationService_1.AuthConfigurationService, DefaultAuthGuard_1.DefaultAuthGuard],
|
|
33
|
+
exports: [passport_1.PassportModule, AuthConfigurationService_1.AuthConfigurationService, DefaultAuthGuard_1.DefaultAuthGuard],
|
|
45
34
|
})
|
|
46
35
|
], AuthzModule);
|
|
47
36
|
exports.AuthzModule = AuthzModule;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"authz.module.js","sourceRoot":"","sources":["../../src/authz/authz.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAsC;AACtC,+CAAgD;AAChD,2DAAqD;AACrD,2DAAqD;AACrD,yEAAoE;AACpE,
|
|
1
|
+
{"version":3,"file":"authz.module.js","sourceRoot":"","sources":["../../src/authz/authz.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAsC;AACtC,+CAAgD;AAChD,2DAAqD;AACrD,2DAAqD;AACrD,yEAAoE;AACpE,mDAA4C;AAC5C,8FAA2D;AAC3D,2CAA4C;AAC5C,yDAAoD;AAYpD,IAAa,WAAW,GAAxB,MAAa,WAAW;CAAG,CAAA;AAAd,WAAW;IAVvB,eAAM,CAAC;QACJ,OAAO,EAAE;YACL,qBAAY,CAAC,UAAU,CAAC,oCAAe,CAAC;YACxC,yBAAc,CAAC,QAAQ,CAAC,EAAC,eAAe,EAAE,KAAK,EAAC,CAAC;YACjD,4BAAY;YACZ,4BAAY;SACf;QACD,SAAS,EAAE,CAAC,2BAAW,EAAE,mDAAwB,EAAE,mCAAgB,CAAC;QACpE,OAAO,EAAE,CAAC,yBAAc,EAAE,mDAAwB,EAAE,mCAAgB,CAAC;KACxE,CAAC;GACW,WAAW,CAAG;AAAd,kCAAW"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ConfigService } from "@nestjs/config";
|
|
2
|
+
import { ValidatedConfigurationService } from "../configuration/ValidatedConfigurationService";
|
|
3
|
+
export declare class AuthClientConfigurationService extends ValidatedConfigurationService {
|
|
4
|
+
private configService;
|
|
5
|
+
constructor(configService: ConfigService);
|
|
6
|
+
get auth0Domain(): string;
|
|
7
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
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.AuthClientConfigurationService = 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 AuthClientConfigurationService = class AuthClientConfigurationService extends ValidatedConfigurationService_1.ValidatedConfigurationService {
|
|
19
|
+
constructor(configService) {
|
|
20
|
+
super();
|
|
21
|
+
this.configService = configService;
|
|
22
|
+
}
|
|
23
|
+
get auth0Domain() {
|
|
24
|
+
return this.configService.get("authclient.auth0Domain");
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
__decorate([
|
|
28
|
+
class_validator_1.IsDefined(),
|
|
29
|
+
class_validator_1.IsString(),
|
|
30
|
+
__metadata("design:type", String),
|
|
31
|
+
__metadata("design:paramtypes", [])
|
|
32
|
+
], AuthClientConfigurationService.prototype, "auth0Domain", null);
|
|
33
|
+
AuthClientConfigurationService = __decorate([
|
|
34
|
+
common_1.Injectable(),
|
|
35
|
+
__metadata("design:paramtypes", [config_1.ConfigService])
|
|
36
|
+
], AuthClientConfigurationService);
|
|
37
|
+
exports.AuthClientConfigurationService = AuthClientConfigurationService;
|
|
38
|
+
//# sourceMappingURL=AuthClientConfigurationService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthClientConfigurationService.js","sourceRoot":"","sources":["../../src/authzclient/AuthClientConfigurationService.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6DAA6D;AAC7D,2CAA0C;AAC1C,2CAA6C;AAC7C,qDAAoD;AACpD,kGAA6F;AAG7F,IAAa,8BAA8B,GAA3C,MAAa,8BAA+B,SAAQ,6DAA6B;IAC7E,YAAoB,aAA4B;QAC5C,KAAK,EAAE,CAAC;QADQ,kBAAa,GAAb,aAAa,CAAe;IAEhD,CAAC;IAID,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,aAAa,CAAC,GAAG,CAAS,wBAAwB,CAAE,CAAC;IACrE,CAAC;CACJ,CAAA;AAHG;IAFC,2BAAS,EAAE;IACX,0BAAQ,EAAE;;;iEAGV;AATQ,8BAA8B;IAD1C,mBAAU,EAAE;qCAE0B,sBAAa;GADvC,8BAA8B,CAU1C;AAVY,wEAA8B"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const config_1 = require("@nestjs/config");
|
|
4
|
+
exports.default = config_1.registerAs("authclient", () => ({
|
|
5
|
+
auth0Domain: process.env.AUTH0_DOMAIN,
|
|
6
|
+
}));
|
|
7
|
+
//# sourceMappingURL=AuthClientConfigurationVariables.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthClientConfigurationVariables.js","sourceRoot":"","sources":["../../src/authzclient/AuthClientConfigurationVariables.ts"],"names":[],"mappings":";;AAAA,2CAA0C;AAE1C,kBAAe,mBAAU,CAAC,YAAY,EAAE,GAAG,EAAE,CAAC,CAAC;IAC3C,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY;CACxC,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AuthenticationClient } from "auth0";
|
|
2
|
+
import { AuthClientConfigurationService } from "./AuthClientConfigurationService";
|
|
3
|
+
export declare const AuthzClientProvider: {
|
|
4
|
+
provide: string;
|
|
5
|
+
useFactory: (config: AuthClientConfigurationService) => AuthenticationClient;
|
|
6
|
+
inject: (typeof AuthClientConfigurationService)[];
|
|
7
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AuthzClientProvider = void 0;
|
|
4
|
+
const auth0_1 = require("auth0");
|
|
5
|
+
const AuthClientConfigurationService_1 = require("./AuthClientConfigurationService");
|
|
6
|
+
exports.AuthzClientProvider = {
|
|
7
|
+
provide: "AuthzClient",
|
|
8
|
+
useFactory: (config) => {
|
|
9
|
+
const options = {
|
|
10
|
+
domain: config.auth0Domain,
|
|
11
|
+
};
|
|
12
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-call
|
|
13
|
+
return new auth0_1.AuthenticationClient(options);
|
|
14
|
+
},
|
|
15
|
+
inject: [AuthClientConfigurationService_1.AuthClientConfigurationService],
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=AuthzClientProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthzClientProvider.js","sourceRoot":"","sources":["../../src/authzclient/AuthzClientProvider.ts"],"names":[],"mappings":";;;AAAA,iCAAwE;AACxE,qFAAgF;AAEnE,QAAA,mBAAmB,GAAG;IAC/B,OAAO,EAAE,aAAa;IACtB,UAAU,EAAE,CAAC,MAAsC,EAAE,EAAE;QACnD,MAAM,OAAO,GAAgC;YACzC,MAAM,EAAE,MAAM,CAAC,WAAW;SAC7B,CAAC;QACF,qGAAqG;QACrG,OAAO,IAAI,4BAAoB,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IACD,MAAM,EAAE,CAAC,+DAA8B,CAAC;CAC3C,CAAC"}
|
|
File without changes
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserProfile.dto.js","sourceRoot":"","sources":["../../src/authzclient/UserProfile.dto.ts"],"names":[],"mappings":";;;AAAA,yDAAyD;AACzD,MAAa,WAAW;CAuBvB;AAvBD,kCAuBC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
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.AuthzClientModule = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const AuthClientConfigurationService_1 = require("./AuthClientConfigurationService");
|
|
15
|
+
const authz_service_1 = require("./authz.service");
|
|
16
|
+
const AuthClientConfigurationVariables_1 = __importDefault(require("./AuthClientConfigurationVariables"));
|
|
17
|
+
const config_1 = require("@nestjs/config");
|
|
18
|
+
const AuthzClientProvider_1 = require("./AuthzClientProvider");
|
|
19
|
+
let AuthzClientModule = class AuthzClientModule {
|
|
20
|
+
};
|
|
21
|
+
AuthzClientModule = __decorate([
|
|
22
|
+
common_1.Module({
|
|
23
|
+
imports: [config_1.ConfigModule.forFeature(AuthClientConfigurationVariables_1.default)],
|
|
24
|
+
providers: [
|
|
25
|
+
AuthzClientProvider_1.AuthzClientProvider,
|
|
26
|
+
authz_service_1.AuthZClientService,
|
|
27
|
+
AuthClientConfigurationService_1.AuthClientConfigurationService,
|
|
28
|
+
],
|
|
29
|
+
exports: [authz_service_1.AuthZClientService],
|
|
30
|
+
})
|
|
31
|
+
], AuthzClientModule);
|
|
32
|
+
exports.AuthzClientModule = AuthzClientModule;
|
|
33
|
+
//# sourceMappingURL=authz-client.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authz-client.module.js","sourceRoot":"","sources":["../../src/authzclient/authz-client.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAsC;AACtC,qFAAgF;AAChF,mDAAmD;AACnD,0GAAiE;AACjE,2CAA4C;AAC5C,+DAAiF;AAWjF,IAAa,iBAAiB,GAA9B,MAAa,iBAAiB;CAAG,CAAA;AAApB,iBAAiB;IAT7B,eAAM,CAAC;QACJ,OAAO,EAAE,CAAC,qBAAY,CAAC,UAAU,CAAC,0CAAe,CAAC,CAAC;QACnD,SAAS,EAAE;YACP,yCAAmB;YACnB,kCAAkB;YAClB,+DAA8B;SACjC;QACD,OAAO,EAAE,CAAC,kCAAkB,CAAC;KAChC,CAAC;GACW,iBAAiB,CAAG;AAApB,8CAAiB"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AuthenticationClient } from "auth0";
|
|
2
|
+
import CoreLoggerService from "../logger/CoreLoggerService";
|
|
3
|
+
import { UserProfile } from "./UserProfile.dto";
|
|
4
|
+
export declare class AuthZClientService {
|
|
5
|
+
private readonly logger;
|
|
6
|
+
private readonly auth0Client;
|
|
7
|
+
constructor(logger: CoreLoggerService, auth0Client: AuthenticationClient);
|
|
8
|
+
getUser(accessToken: string): Promise<UserProfile | undefined>;
|
|
9
|
+
}
|
|
@@ -8,6 +8,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
11
14
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
15
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
16
|
};
|
|
@@ -16,33 +19,27 @@ exports.AuthZClientService = void 0;
|
|
|
16
19
|
const common_1 = require("@nestjs/common");
|
|
17
20
|
const auth0_1 = require("auth0");
|
|
18
21
|
const CoreLoggerService_1 = __importDefault(require("../logger/CoreLoggerService"));
|
|
19
|
-
const AuthConfigurationService_1 = require("./AuthConfigurationService");
|
|
20
22
|
let AuthZClientService = class AuthZClientService {
|
|
21
|
-
constructor(logger,
|
|
23
|
+
constructor(logger, auth0Client) {
|
|
22
24
|
this.logger = logger;
|
|
23
|
-
this.
|
|
24
|
-
const options = {
|
|
25
|
-
domain: this.configuration.auth0Domain,
|
|
26
|
-
};
|
|
27
|
-
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-call
|
|
28
|
-
this.auth0Client = new auth0_1.AuthenticationClient(options);
|
|
25
|
+
this.auth0Client = auth0Client;
|
|
29
26
|
}
|
|
30
27
|
async getUser(accessToken) {
|
|
31
28
|
try {
|
|
32
29
|
this.logger.debug("Attempting to get auth0 profile", accessToken);
|
|
33
30
|
return (await this.auth0Client.getProfile(accessToken));
|
|
34
|
-
// eslint-disable-next-line unicorn/prefer-optional-catch-binding
|
|
35
31
|
}
|
|
36
32
|
catch (error) {
|
|
37
|
-
this.logger.error("Failed to load user from auth0");
|
|
33
|
+
this.logger.error("Failed to load user from auth0", error);
|
|
38
34
|
}
|
|
39
35
|
return undefined;
|
|
40
36
|
}
|
|
41
37
|
};
|
|
42
38
|
AuthZClientService = __decorate([
|
|
43
39
|
common_1.Injectable(),
|
|
40
|
+
__param(1, common_1.Inject("AuthzClient")),
|
|
44
41
|
__metadata("design:paramtypes", [CoreLoggerService_1.default,
|
|
45
|
-
|
|
42
|
+
auth0_1.AuthenticationClient])
|
|
46
43
|
], AuthZClientService);
|
|
47
44
|
exports.AuthZClientService = AuthZClientService;
|
|
48
45
|
//# sourceMappingURL=authz.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authz.service.js","sourceRoot":"","sources":["../../src/authzclient/authz.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,2CAAkD;AAClD,iCAA2C;AAC3C,oFAA4D;AAG5D,IAAa,kBAAkB,GAA/B,MAAa,kBAAkB;IAC3B,YACqB,MAAyB,EAEzB,WAAiC;QAFjC,WAAM,GAAN,MAAM,CAAmB;QAEzB,gBAAW,GAAX,WAAW,CAAsB;IACnD,CAAC;IAEG,KAAK,CAAC,OAAO,CAChB,WAAmB;QAEnB,IAAI;YACA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,iCAAiC,EAAE,WAAW,CAAC,CAAC;YAElE,OAAO,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,UAAU,CACrC,WAAW,CACd,CAAyB,CAAC;SAC9B;QAAC,OAAO,KAAK,EAAE;YACZ,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAC;SAC9D;QACD,OAAO,SAAS,CAAC;IACrB,CAAC;CACJ,CAAA;AArBY,kBAAkB;IAD9B,mBAAU,EAAE;IAIJ,WAAA,eAAM,CAAC,aAAa,CAAC,CAAA;qCADG,2BAAiB;QAEZ,4BAAoB;GAJ7C,kBAAkB,CAqB9B;AArBY,gDAAkB"}
|
|
@@ -1,7 +1,16 @@
|
|
|
1
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
|
+
};
|
|
2
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
9
|
exports.ValidatedConfigurationService = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
4
11
|
const class_validator_1 = require("class-validator");
|
|
12
|
+
let ValidatedConfigurationService =
|
|
13
|
+
// eslint-disable-next-line @darraghor/nestjs-typed/injectable-should-be-provided
|
|
5
14
|
class ValidatedConfigurationService {
|
|
6
15
|
async onModuleInit() {
|
|
7
16
|
const result = await class_validator_1.validate(this);
|
|
@@ -15,6 +24,10 @@ ${JSON.stringify(result.map((v) => {
|
|
|
15
24
|
}), undefined, 2)}`);
|
|
16
25
|
}
|
|
17
26
|
}
|
|
18
|
-
}
|
|
27
|
+
};
|
|
28
|
+
ValidatedConfigurationService = __decorate([
|
|
29
|
+
common_1.Injectable()
|
|
30
|
+
// eslint-disable-next-line @darraghor/nestjs-typed/injectable-should-be-provided
|
|
31
|
+
], ValidatedConfigurationService);
|
|
19
32
|
exports.ValidatedConfigurationService = ValidatedConfigurationService;
|
|
20
33
|
//# sourceMappingURL=ValidatedConfigurationService.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ValidatedConfigurationService.js","sourceRoot":"","sources":["../../src/configuration/ValidatedConfigurationService.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ValidatedConfigurationService.js","sourceRoot":"","sources":["../../src/configuration/ValidatedConfigurationService.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwD;AACxD,qDAAyC;AAIzC,IAAsB,6BAA6B;AADnD,iFAAiF;AACjF,MAAsB,6BAA6B;IAC/C,KAAK,CAAC,YAAY;QACd,MAAM,MAAM,GAAG,MAAM,0BAAQ,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;YACnB,MAAM,IAAI,KAAK,CACX;EACd,IAAI,CAAC,SAAS,CACZ,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,EAAE,CACU,CAAC;SACL;IACL,CAAC;CACJ,CAAA;AAnBqB,6BAA6B;IAFlD,mBAAU,EAAE;IACb,iFAAiF;GAC3D,6BAA6B,CAmBlD;AAnBqB,sEAA6B"}
|
|
@@ -12,6 +12,13 @@ class TypeOrmConfigurationProvider {
|
|
|
12
12
|
* @returns
|
|
13
13
|
*/
|
|
14
14
|
static getTypeOrmConfig() {
|
|
15
|
+
console.log("DIRNAME", __dirname);
|
|
16
|
+
const nodeModuleCorePath = path_1.default.join(__dirname, process.env.CORE_MODULE_ENTITY_PATH || "", "**", "*.entity.{ts,js}");
|
|
17
|
+
console.log("Using core entity path", nodeModuleCorePath);
|
|
18
|
+
const appModulePath = path_1.default.join(__dirname, process.env.APP_MODULE_ENTITY_PATH || "", "**", "*.entity.{ts,js}");
|
|
19
|
+
console.log("Using application entity path", appModulePath);
|
|
20
|
+
const migrationsPath = path_1.default.join(__dirname, process.env.MIGRATIONS_PATH || "", "**", "migration", "*.{ts,js}");
|
|
21
|
+
console.log("Using migration path", migrationsPath);
|
|
15
22
|
if (process.env.DATABASE_URL) {
|
|
16
23
|
return {
|
|
17
24
|
type: "postgres",
|
|
@@ -20,12 +27,8 @@ class TypeOrmConfigurationProvider {
|
|
|
20
27
|
migrationsTableName: "migrations",
|
|
21
28
|
migrationsRun: true,
|
|
22
29
|
synchronize: false,
|
|
23
|
-
entities: [
|
|
24
|
-
|
|
25
|
-
],
|
|
26
|
-
migrations: [
|
|
27
|
-
path_1.default.join(__dirname, "..", process.env.DB_CONFIG_ROOT || "", "**", "migration", "*.{ts,js}"),
|
|
28
|
-
],
|
|
30
|
+
entities: [nodeModuleCorePath, appModulePath],
|
|
31
|
+
migrations: [migrationsPath],
|
|
29
32
|
cli: {
|
|
30
33
|
migrationsDir: "src/migrations",
|
|
31
34
|
},
|
|
@@ -43,12 +46,8 @@ class TypeOrmConfigurationProvider {
|
|
|
43
46
|
migrationsRun: true,
|
|
44
47
|
logging: true,
|
|
45
48
|
synchronize: false,
|
|
46
|
-
entities: [
|
|
47
|
-
|
|
48
|
-
],
|
|
49
|
-
migrations: [
|
|
50
|
-
path_1.default.join(__dirname, "..", process.env.DB_CONFIG_ROOT || "", "**", "migration", "*.{ts,js}"),
|
|
51
|
-
],
|
|
49
|
+
entities: [nodeModuleCorePath, appModulePath],
|
|
50
|
+
migrations: [migrationsPath],
|
|
52
51
|
cli: {
|
|
53
52
|
migrationsDir: "src/migration",
|
|
54
53
|
},
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TypeOrmConfigurationProvider.js","sourceRoot":"","sources":["../../src/database/TypeOrmConfigurationProvider.ts"],"names":[],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"TypeOrmConfigurationProvider.js","sourceRoot":"","sources":["../../src/database/TypeOrmConfigurationProvider.ts"],"names":[],"mappings":";;;;;;AAGA,gDAAwB;AAExB,MAAa,4BAA4B;IACrC;;;;OAIG;IACI,MAAM,CAAC,gBAAgB;QAC1B,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QAClC,MAAM,kBAAkB,GAAG,cAAI,CAAC,IAAI,CAChC,SAAS,EACT,OAAO,CAAC,GAAG,CAAC,uBAAuB,IAAI,EAAE,EACzC,IAAI,EACJ,kBAAkB,CACrB,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,wBAAwB,EAAE,kBAAkB,CAAC,CAAC;QAE1D,MAAM,aAAa,GAAG,cAAI,CAAC,IAAI,CAC3B,SAAS,EACT,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,EAAE,EACxC,IAAI,EACJ,kBAAkB,CACrB,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAAE,aAAa,CAAC,CAAC;QAE5D,MAAM,cAAc,GAAG,cAAI,CAAC,IAAI,CAC5B,SAAS,EACT,OAAO,CAAC,GAAG,CAAC,eAAe,IAAI,EAAE,EACjC,IAAI,EACJ,WAAW,EACX,WAAW,CACd,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,cAAc,CAAC,CAAC;QAEpD,IAAI,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE;YAC1B,OAAO;gBACH,IAAI,EAAE,UAAU;gBAChB,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY;gBAC7B,OAAO,EAAE,KAAK;gBACd,mBAAmB,EAAE,YAAY;gBACjC,aAAa,EAAE,IAAI;gBACnB,WAAW,EAAE,KAAK;gBAClB,QAAQ,EAAE,CAAC,kBAAkB,EAAE,aAAa,CAAC;gBAC7C,UAAU,EAAE,CAAC,cAAc,CAAC;gBAC5B,GAAG,EAAE;oBACD,aAAa,EAAE,gBAAgB;iBAClC;aACJ,CAAC;SACL;QAED,OAAO;YACH,IAAI,EAAE,UAAU;YAChB,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB;YACnC,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,MAAM,EAAE,EAAE,CAAC;YAClE,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB;YACvC,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAqB;YAC3C,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,qBAAqB;YAC3C,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,mBAAmB;YACvC,mBAAmB,EAAE,YAAY;YACjC,aAAa,EAAE,IAAI;YACnB,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,KAAK;YAClB,QAAQ,EAAE,CAAC,kBAAkB,EAAE,aAAa,CAAC;YAC7C,UAAU,EAAE,CAAC,cAAc,CAAC;YAC5B,GAAG,EAAE;gBACD,aAAa,EAAE,eAAe;aACjC;SACJ,CAAC;IACN,CAAC;CACJ;AApED,oEAoEC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -2,10 +2,12 @@ import { AuthzModule } from "./authz/authz.module";
|
|
|
2
2
|
import { JwtStrategy } from "./authz/authzstrategy";
|
|
3
3
|
import { DefaultAuthGuard } from "./authz/DefaultAuthGuard";
|
|
4
4
|
import { ValidatedConfigurationService } from "./configuration/ValidatedConfigurationService";
|
|
5
|
+
import { CoreConfigurationService } from "./core-config/CoreConfigurationService";
|
|
5
6
|
import { DatabaseModule } from "./database/Database.module";
|
|
6
7
|
import { TypeOrmConfigurationProvider } from "./database/TypeOrmConfigurationProvider";
|
|
8
|
+
import { EmailClientModule } from "./email-client/email-client.module";
|
|
7
9
|
import { EmailClient } from "./email-client/email-client.service";
|
|
8
10
|
import CoreLoggerService from "./logger/CoreLoggerService";
|
|
9
|
-
import {
|
|
11
|
+
import { CoreModule } from "./root-app/core-app.module";
|
|
10
12
|
import { SwaggerGen } from "./root-app/SwaggerGen";
|
|
11
|
-
export { CoreLoggerService,
|
|
13
|
+
export { CoreLoggerService, CoreConfigurationService, EmailClientModule, CoreModule, SwaggerGen, DefaultAuthGuard, DatabaseModule, JwtStrategy, AuthzModule, TypeOrmConfigurationProvider, EmailClient, ValidatedConfigurationService, };
|
package/dist/index.js
CHANGED
|
@@ -3,7 +3,7 @@ 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.ValidatedConfigurationService = exports.EmailClient = exports.TypeOrmConfigurationProvider = exports.AuthzModule = exports.JwtStrategy = exports.DatabaseModule = exports.DefaultAuthGuard = exports.SwaggerGen = exports.
|
|
6
|
+
exports.ValidatedConfigurationService = exports.EmailClient = exports.TypeOrmConfigurationProvider = exports.AuthzModule = exports.JwtStrategy = exports.DatabaseModule = exports.DefaultAuthGuard = exports.SwaggerGen = exports.CoreModule = exports.EmailClientModule = exports.CoreConfigurationService = exports.CoreLoggerService = void 0;
|
|
7
7
|
const authz_module_1 = require("./authz/authz.module");
|
|
8
8
|
Object.defineProperty(exports, "AuthzModule", { enumerable: true, get: function () { return authz_module_1.AuthzModule; } });
|
|
9
9
|
const authzstrategy_1 = require("./authz/authzstrategy");
|
|
@@ -12,16 +12,20 @@ const DefaultAuthGuard_1 = require("./authz/DefaultAuthGuard");
|
|
|
12
12
|
Object.defineProperty(exports, "DefaultAuthGuard", { enumerable: true, get: function () { return DefaultAuthGuard_1.DefaultAuthGuard; } });
|
|
13
13
|
const ValidatedConfigurationService_1 = require("./configuration/ValidatedConfigurationService");
|
|
14
14
|
Object.defineProperty(exports, "ValidatedConfigurationService", { enumerable: true, get: function () { return ValidatedConfigurationService_1.ValidatedConfigurationService; } });
|
|
15
|
+
const CoreConfigurationService_1 = require("./core-config/CoreConfigurationService");
|
|
16
|
+
Object.defineProperty(exports, "CoreConfigurationService", { enumerable: true, get: function () { return CoreConfigurationService_1.CoreConfigurationService; } });
|
|
15
17
|
const Database_module_1 = require("./database/Database.module");
|
|
16
18
|
Object.defineProperty(exports, "DatabaseModule", { enumerable: true, get: function () { return Database_module_1.DatabaseModule; } });
|
|
17
19
|
const TypeOrmConfigurationProvider_1 = require("./database/TypeOrmConfigurationProvider");
|
|
18
20
|
Object.defineProperty(exports, "TypeOrmConfigurationProvider", { enumerable: true, get: function () { return TypeOrmConfigurationProvider_1.TypeOrmConfigurationProvider; } });
|
|
21
|
+
const email_client_module_1 = require("./email-client/email-client.module");
|
|
22
|
+
Object.defineProperty(exports, "EmailClientModule", { enumerable: true, get: function () { return email_client_module_1.EmailClientModule; } });
|
|
19
23
|
const email_client_service_1 = require("./email-client/email-client.service");
|
|
20
24
|
Object.defineProperty(exports, "EmailClient", { enumerable: true, get: function () { return email_client_service_1.EmailClient; } });
|
|
21
25
|
const CoreLoggerService_1 = __importDefault(require("./logger/CoreLoggerService"));
|
|
22
26
|
exports.CoreLoggerService = CoreLoggerService_1.default;
|
|
23
|
-
const
|
|
24
|
-
Object.defineProperty(exports, "
|
|
27
|
+
const core_app_module_1 = require("./root-app/core-app.module");
|
|
28
|
+
Object.defineProperty(exports, "CoreModule", { enumerable: true, get: function () { return core_app_module_1.CoreModule; } });
|
|
25
29
|
const SwaggerGen_1 = require("./root-app/SwaggerGen");
|
|
26
30
|
Object.defineProperty(exports, "SwaggerGen", { enumerable: true, get: function () { return SwaggerGen_1.SwaggerGen; } });
|
|
27
31
|
//# 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,uDAAiD;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAiD;AAsB7C,4FAtBI,0BAAW,OAsBJ;AArBf,yDAAkD;AAoB9C,4FApBI,2BAAW,OAoBJ;AAnBf,+DAA0D;AAiBtD,iGAjBI,mCAAgB,OAiBJ;AAhBpB,iGAA4F;AAsBxF,8GAtBI,6DAA6B,OAsBJ;AArBjC,qFAAgF;AAW5E,yGAXI,mDAAwB,OAWJ;AAV5B,gEAA0D;AAetD,+FAfI,gCAAc,OAeJ;AAdlB,0FAAqF;AAiBjF,6GAjBI,2DAA4B,OAiBJ;AAhBhC,4EAAqE;AASjE,kGATI,uCAAiB,OASJ;AARrB,8EAAgE;AAgB5D,4FAhBI,kCAAW,OAgBJ;AAff,mFAA2D;AAKvD,4BALG,2BAAiB,CAKH;AAJrB,gEAAsD;AAOlD,2FAPI,4BAAU,OAOJ;AANd,sDAAiD;AAO7C,2FAPI,uBAAU,OAOJ"}
|
|
@@ -13,12 +13,16 @@ const person_controller_1 = require("./person.controller");
|
|
|
13
13
|
const person_entity_1 = require("./entities/person.entity");
|
|
14
14
|
const logger_module_1 = require("../logger/logger.module");
|
|
15
15
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
16
|
-
const
|
|
16
|
+
const authz_client_module_1 = require("../authzclient/authz-client.module");
|
|
17
17
|
let PersonModule = class PersonModule {
|
|
18
18
|
};
|
|
19
19
|
PersonModule = __decorate([
|
|
20
20
|
common_1.Module({
|
|
21
|
-
imports: [
|
|
21
|
+
imports: [
|
|
22
|
+
logger_module_1.LoggerModule,
|
|
23
|
+
typeorm_1.TypeOrmModule.forFeature([person_entity_1.Person]),
|
|
24
|
+
authz_client_module_1.AuthzClientModule,
|
|
25
|
+
],
|
|
22
26
|
controllers: [person_controller_1.PersonController],
|
|
23
27
|
providers: [person_service_1.PersonService],
|
|
24
28
|
exports: [person_service_1.PersonService],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"person.module.js","sourceRoot":"","sources":["../../src/person/person.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAsC;AACtC,qDAA+C;AAC/C,2DAAqD;AACrD,4DAAgD;AAChD,2DAAqD;AACrD,6CAA8C;AAC9C,
|
|
1
|
+
{"version":3,"file":"person.module.js","sourceRoot":"","sources":["../../src/person/person.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAsC;AACtC,qDAA+C;AAC/C,2DAAqD;AACrD,4DAAgD;AAChD,2DAAqD;AACrD,6CAA8C;AAC9C,4EAAqE;AAYrE,IAAa,YAAY,GAAzB,MAAa,YAAY;CAAG,CAAA;AAAf,YAAY;IAVxB,eAAM,CAAC;QACJ,OAAO,EAAE;YACL,4BAAY;YACZ,uBAAa,CAAC,UAAU,CAAC,CAAC,sBAAM,CAAC,CAAC;YAClC,uCAAiB;SACpB;QACD,WAAW,EAAE,CAAC,oCAAgB,CAAC;QAC/B,SAAS,EAAE,CAAC,8BAAa,CAAC;QAC1B,OAAO,EAAE,CAAC,8BAAa,CAAC;KAC3B,CAAC;GACW,YAAY,CAAG;AAAf,oCAAY"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Repository } from "typeorm";
|
|
2
2
|
import { AccessToken } from "../authz/AccessToken";
|
|
3
|
-
import { AuthZClientService } from "../
|
|
4
|
-
import { UserProfile } from "../
|
|
3
|
+
import { AuthZClientService } from "../authzclient/authz.service";
|
|
4
|
+
import { UserProfile } from "../authzclient/UserProfile.dto";
|
|
5
5
|
import CoreLoggerService from "../logger/CoreLoggerService";
|
|
6
6
|
import { CreatePersonDto } from "./dto/create-person.dto";
|
|
7
7
|
import { UpdatePersonDto } from "./dto/update-person.dto";
|
|
@@ -19,8 +19,8 @@ exports.PersonService = void 0;
|
|
|
19
19
|
const common_1 = require("@nestjs/common");
|
|
20
20
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
21
21
|
const typeorm_2 = require("typeorm");
|
|
22
|
-
const authz_service_1 = require("../
|
|
23
|
-
const UserProfile_dto_1 = require("../
|
|
22
|
+
const authz_service_1 = require("../authzclient/authz.service");
|
|
23
|
+
const UserProfile_dto_1 = require("../authzclient/UserProfile.dto");
|
|
24
24
|
const CoreLoggerService_1 = __importDefault(require("../logger/CoreLoggerService"));
|
|
25
25
|
const organisation_entity_1 = require("../organisation/entities/organisation.entity");
|
|
26
26
|
const person_entity_1 = require("./entities/person.entity");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"person.service.js","sourceRoot":"","sources":["../../src/person/person.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,2CAA0C;AAC1C,6CAAiD;AACjD,qCAAmC;AAEnC,
|
|
1
|
+
{"version":3,"file":"person.service.js","sourceRoot":"","sources":["../../src/person/person.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -37,7 +37,7 @@ class SwaggerGen {
|
|
|
37
37
|
.setDescription("Describes the backend api")
|
|
38
38
|
.build();
|
|
39
39
|
const document = swagger_1.SwaggerModule.createDocument(app, config);
|
|
40
|
-
swagger_1.SwaggerModule.setup("
|
|
40
|
+
swagger_1.SwaggerModule.setup("swagger", app, document);
|
|
41
41
|
// tslint:disable-next-line: non-literal-fs-path
|
|
42
42
|
fs_1.default.writeFileSync(pathToSave, JSON.stringify(document));
|
|
43
43
|
this.logger.log(`Wrote swagger api doc to ${pathToSave}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SwaggerGen.js","sourceRoot":"","sources":["../../src/root-app/SwaggerGen.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA4D;AAC5D,6CAA+D;AAC/D,4CAAoB;AAEpB,iDAAoC;AACpC,oFAA4D;AAE5D,0BAA0B;AAG1B,IAAa,UAAU;AADvB,iFAAiF;AACjF,MAAa,UAAU;IACnB,YAAoB,MAAyB;QAAzB,WAAM,GAAN,MAAM,CAAmB;IAAG,CAAC;IAC1C,QAAQ,CAAC,GAAqB,EAAE,UAAkB;QACrD,IAAI,CAAC,YAAU,CAAC,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE;YAChE,IAAI,CAAC,MAAM,CAAC,GAAG,CACX,wDAAwD,CAC3D,CAAC;YACF,OAAO;SACV;QACD,MAAM,MAAM,GAAG,IAAI,yBAAe,EAAE;aAC/B,aAAa,EAAE;aACf,QAAQ,CAAC,cAAc,CAAC;aACxB,cAAc,CAAC,2BAA2B,CAAC;aAC3C,KAAK,EAAE,CAAC;QACb,MAAM,QAAQ,GAAG,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC3D,uBAAa,CAAC,KAAK,CAAC,
|
|
1
|
+
{"version":3,"file":"SwaggerGen.js","sourceRoot":"","sources":["../../src/root-app/SwaggerGen.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA4D;AAC5D,6CAA+D;AAC/D,4CAAoB;AAEpB,iDAAoC;AACpC,oFAA4D;AAE5D,0BAA0B;AAG1B,IAAa,UAAU;AADvB,iFAAiF;AACjF,MAAa,UAAU;IACnB,YAAoB,MAAyB;QAAzB,WAAM,GAAN,MAAM,CAAmB;IAAG,CAAC;IAC1C,QAAQ,CAAC,GAAqB,EAAE,UAAkB;QACrD,IAAI,CAAC,YAAU,CAAC,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE;YAChE,IAAI,CAAC,MAAM,CAAC,GAAG,CACX,wDAAwD,CAC3D,CAAC;YACF,OAAO;SACV;QACD,MAAM,MAAM,GAAG,IAAI,yBAAe,EAAE;aAC/B,aAAa,EAAE;aACf,QAAQ,CAAC,cAAc,CAAC;aACxB,cAAc,CAAC,2BAA2B,CAAC;aAC3C,KAAK,EAAE,CAAC;QACb,MAAM,QAAQ,GAAG,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC3D,uBAAa,CAAC,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;QAE9C,gDAAgD;QAChD,YAAE,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACvD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,4BAA4B,UAAU,EAAE,CAAC,CAAC;QAE1D,MAAM,cAAc,GAAG,qBAAK,CAAC,eAAe,EAAE;YAC1C,KAAK,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC;YACtC,KAAK,EAAE,IAAI;SACd,CAAC,CAAC;QAEH,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;YAC3B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,MAAM,CAAC,oBAAoB,CAAC,eAAwB;QACvD,OAAO,eAAe,EAAE,WAAW,EAAE,KAAK,MAAM,CAAC;IACrD,CAAC;CACJ,CAAA;AAlCY,UAAU;IAFtB,mBAAU,EAAE;IACb,iFAAiF;;qCAEjD,2BAAiB;GADpC,UAAU,CAkCtB;AAlCY,gCAAU"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import "reflect-metadata";
|
|
2
2
|
import { INestApplication, NestApplicationOptions } from "@nestjs/common";
|
|
3
|
-
export declare class
|
|
3
|
+
export declare class CoreModule {
|
|
4
4
|
static initApplication(rootModule: any, callback: (appModule: INestApplication) => void | Promise<void>, options?: NestApplicationOptions): void;
|
|
5
5
|
}
|
|
@@ -8,34 +8,31 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
9
9
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
10
10
|
};
|
|
11
|
-
var AppModule_1;
|
|
12
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
exports.
|
|
12
|
+
exports.CoreModule = void 0;
|
|
14
13
|
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
|
15
14
|
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
|
16
15
|
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
17
16
|
require("reflect-metadata");
|
|
18
17
|
const common_1 = require("@nestjs/common");
|
|
19
|
-
const authz_module_1 = require("../authz/authz.module");
|
|
20
18
|
const logger_module_1 = require("../logger/logger.module");
|
|
21
19
|
const app_controller_1 = require("./app.controller");
|
|
22
20
|
const app_service_1 = require("./app.service");
|
|
23
21
|
const SwaggerGen_1 = require("./SwaggerGen");
|
|
24
|
-
const email_client_module_1 = require("../email-client/email-client.module");
|
|
25
|
-
const Database_module_1 = require("../database/Database.module");
|
|
26
22
|
const core_1 = require("@nestjs/core");
|
|
27
23
|
const CoreLoggerService_1 = __importDefault(require("../logger/CoreLoggerService"));
|
|
28
24
|
const CoreConfigurationService_1 = require("../core-config/CoreConfigurationService");
|
|
29
25
|
const LoggingInterceptor_1 = require("../logger/LoggingInterceptor");
|
|
30
26
|
const httpLogResponseContent_1 = require("./httpLogResponseContent");
|
|
31
27
|
const CoreConfig_module_1 = require("../core-config/CoreConfig.module");
|
|
32
|
-
|
|
28
|
+
const config_1 = require("@nestjs/config");
|
|
29
|
+
let CoreModule = class CoreModule {
|
|
33
30
|
static initApplication(
|
|
34
31
|
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types,@typescript-eslint/no-explicit-any
|
|
35
32
|
rootModule, callback, options) {
|
|
36
33
|
void (async () => {
|
|
37
34
|
try {
|
|
38
|
-
const app = await core_1.NestFactory.create(
|
|
35
|
+
const app = await core_1.NestFactory.create(rootModule);
|
|
39
36
|
const loggerService = app.get(CoreLoggerService_1.default);
|
|
40
37
|
const configService = app.get(CoreConfigurationService_1.CoreConfigurationService);
|
|
41
38
|
app.useLogger(loggerService);
|
|
@@ -43,14 +40,12 @@ let AppModule = AppModule_1 = class AppModule {
|
|
|
43
40
|
app.useGlobalPipes(new common_1.ValidationPipe({
|
|
44
41
|
transform: true,
|
|
45
42
|
skipMissingProperties: false,
|
|
43
|
+
whitelist: true,
|
|
44
|
+
forbidNonWhitelisted: true,
|
|
46
45
|
}));
|
|
47
46
|
app.useGlobalInterceptors(new common_1.ClassSerializerInterceptor(app.get(core_1.Reflector)), new LoggingInterceptor_1.LoggingInterceptor(loggerService));
|
|
48
47
|
app.useGlobalInterceptors(new httpLogResponseContent_1.HttpLogResponse());
|
|
49
|
-
|
|
50
|
-
const swaggerGen = app.get(SwaggerGen_1.SwaggerGen);
|
|
51
|
-
swaggerGen.generate(app, "open-api/swagger.json");
|
|
52
|
-
await app.listen(configuredPort);
|
|
53
|
-
loggerService.log(`listening on http://localhost:${configService.webPort}`);
|
|
48
|
+
loggerService.log(`will listen on port ${configService.webPort} (DEV: http://localhost:${configService.webPort} )`);
|
|
54
49
|
await callback(app);
|
|
55
50
|
}
|
|
56
51
|
catch (initialisationError) {
|
|
@@ -64,19 +59,17 @@ let AppModule = AppModule_1 = class AppModule {
|
|
|
64
59
|
})();
|
|
65
60
|
}
|
|
66
61
|
};
|
|
67
|
-
|
|
62
|
+
CoreModule = __decorate([
|
|
68
63
|
common_1.Module({
|
|
69
64
|
imports: [
|
|
65
|
+
config_1.ConfigModule.forRoot({ cache: true }),
|
|
70
66
|
logger_module_1.LoggerModule,
|
|
71
67
|
CoreConfig_module_1.CoreConfigModule,
|
|
72
|
-
Database_module_1.DatabaseModule,
|
|
73
|
-
authz_module_1.AuthzModule,
|
|
74
|
-
email_client_module_1.EmailClientModule,
|
|
75
68
|
],
|
|
76
69
|
controllers: [app_controller_1.AppController],
|
|
77
70
|
providers: [app_service_1.AppService, SwaggerGen_1.SwaggerGen],
|
|
78
71
|
exports: [SwaggerGen_1.SwaggerGen],
|
|
79
72
|
})
|
|
80
|
-
],
|
|
81
|
-
exports.
|
|
82
|
-
//# sourceMappingURL=app.module.js.map
|
|
73
|
+
], CoreModule);
|
|
74
|
+
exports.CoreModule = CoreModule;
|
|
75
|
+
//# sourceMappingURL=core-app.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-app.module.js","sourceRoot":"","sources":["../../src/root-app/core-app.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,sDAAsD;AACtD,+DAA+D;AAC/D,4DAA4D;AAC5D,4BAA0B;AAC1B,2CAMwB;AACxB,2DAAqD;AACrD,qDAA+C;AAC/C,+CAAyC;AACzC,6CAAwC;AACxC,uCAAoD;AACpD,oFAA4D;AAC5D,sFAAiF;AACjF,qEAAgE;AAChE,qEAAyD;AACzD,wEAAkE;AAClE,2CAA4C;AAY5C,IAAa,UAAU,GAAvB,MAAa,UAAU;IACZ,MAAM,CAAC,eAAe;IACzB,gHAAgH;IAChH,UAAe,EACf,QAA+D,EAC/D,OAAgC;QAEhC,KAAK,CAAC,KAAK,IAAI,EAAE;YACb,IAAI;gBACA,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;gBACjD,MAAM,aAAa,GAAG,GAAG,CAAC,GAAG,CAAC,2BAAiB,CAAC,CAAC;gBACjD,MAAM,aAAa,GAAG,GAAG,CAAC,GAAG,CAAC,mDAAwB,CAAC,CAAC;gBACxD,GAAG,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;gBAE7B,GAAG,CAAC,UAAU,CAAC,EAAC,MAAM,EAAE,aAAa,CAAC,aAAa,EAAC,CAAC,CAAC;gBACtD,GAAG,CAAC,cAAc,CACd,IAAI,uBAAc,CAAC;oBACf,SAAS,EAAE,IAAI;oBACf,qBAAqB,EAAE,KAAK;oBAC5B,SAAS,EAAE,IAAI;oBACf,oBAAoB,EAAE,IAAI;iBAC7B,CAAC,CACL,CAAC;gBACF,GAAG,CAAC,qBAAqB,CACrB,IAAI,mCAA0B,CAAC,GAAG,CAAC,GAAG,CAAC,gBAAS,CAAC,CAAC,EAClD,IAAI,uCAAkB,CAAC,aAAa,CAAC,CACxC,CAAC;gBACF,GAAG,CAAC,qBAAqB,CAAC,IAAI,wCAAe,EAAE,CAAC,CAAC;gBAEjD,aAAa,CAAC,GAAG,CACb,uBAAuB,aAAa,CAAC,OAAO,2BAA2B,aAAa,CAAC,OAAO,IAAI,CACnG,CAAC;gBAEF,MAAM,QAAQ,CAAC,GAAG,CAAC,CAAC;aACvB;YAAC,OAAO,mBAAmB,EAAE;gBAC1B,uEAAuE;gBACvE,OAAO,CAAC,KAAK;gBACT,4EAA4E;gBAC5E,iCAAiC,mBAAmB,EAAE,CACzD,CAAC;gBACF,mDAAmD;gBACnD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACnB;QACL,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;CACJ,CAAA;AA7CY,UAAU;IAVtB,eAAM,CAAC;QACJ,OAAO,EAAE;YACL,qBAAY,CAAC,OAAO,CAAC,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC;YACnC,4BAAY;YACZ,oCAAgB;SACnB;QACD,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE,CAAC,wBAAU,EAAE,uBAAU,CAAC;QACnC,OAAO,EAAE,CAAC,uBAAU,CAAC;KACxB,CAAC;GACW,UAAU,CA6CtB;AA7CY,gCAAU"}
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UserProfile.dto.js","sourceRoot":"","sources":["../../src/authz/UserProfile.dto.ts"],"names":[],"mappings":";;;AAAA,yDAAyD;AACzD,MAAa,WAAW;CAuBvB;AAvBD,kCAuBC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import CoreLoggerService from "../logger/CoreLoggerService";
|
|
2
|
-
import { AuthConfigurationService } from "./AuthConfigurationService";
|
|
3
|
-
import { UserProfile } from "./UserProfile.dto";
|
|
4
|
-
export declare class AuthZClientService {
|
|
5
|
-
private logger;
|
|
6
|
-
private configuration;
|
|
7
|
-
private auth0Client;
|
|
8
|
-
constructor(logger: CoreLoggerService, configuration: AuthConfigurationService);
|
|
9
|
-
getUser(accessToken: string): Promise<UserProfile | undefined>;
|
|
10
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"authz.service.js","sourceRoot":"","sources":["../../src/authz/authz.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA0C;AAC1C,iCAAwE;AACxE,oFAA4D;AAC5D,yEAAoE;AAGpE,IAAa,kBAAkB,GAA/B,MAAa,kBAAkB;IAG3B,YACY,MAAyB,EACzB,aAAuC;QADvC,WAAM,GAAN,MAAM,CAAmB;QACzB,kBAAa,GAAb,aAAa,CAA0B;QAE/C,MAAM,OAAO,GAAgC;YACzC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,WAAW;SACzC,CAAC;QACF,qGAAqG;QACrG,IAAI,CAAC,WAAW,GAAG,IAAI,4BAAoB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC;IAEM,KAAK,CAAC,OAAO,CAChB,WAAmB;QAEnB,IAAI;YACA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,iCAAiC,EAAE,WAAW,CAAC,CAAC;YAElE,OAAO,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,UAAU,CACrC,WAAW,CACd,CAAyB,CAAC;YAC3B,iEAAiE;SACpE;QAAC,OAAO,KAAK,EAAE;YACZ,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;SACvD;QACD,OAAO,SAAS,CAAC;IACrB,CAAC;CACJ,CAAA;AA7BY,kBAAkB;IAD9B,mBAAU,EAAE;qCAKW,2BAAiB;QACV,mDAAwB;GAL1C,kBAAkB,CA6B9B;AA7BY,gDAAkB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"app.module.js","sourceRoot":"","sources":["../../src/root-app/app.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,sDAAsD;AACtD,+DAA+D;AAC/D,4DAA4D;AAC5D,4BAA0B;AAC1B,2CAMwB;AACxB,wDAAkD;AAClD,2DAAqD;AACrD,qDAA+C;AAC/C,+CAAyC;AACzC,6CAAwC;AACxC,6EAAsE;AACtE,iEAA2D;AAC3D,uCAAoD;AACpD,oFAA4D;AAC5D,sFAAiF;AACjF,qEAAgE;AAChE,qEAAyD;AACzD,wEAAkE;AAclE,IAAa,SAAS,iBAAtB,MAAa,SAAS;IACX,MAAM,CAAC,eAAe;IACzB,gHAAgH;IAChH,UAAe,EACf,QAA+D,EAC/D,OAAgC;QAEhC,KAAK,CAAC,KAAK,IAAI,EAAE;YACb,IAAI;gBACA,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAC,WAAS,CAAC,CAAC;gBAChD,MAAM,aAAa,GAAG,GAAG,CAAC,GAAG,CAAC,2BAAiB,CAAC,CAAC;gBACjD,MAAM,aAAa,GAAG,GAAG,CAAC,GAAG,CAAC,mDAAwB,CAAC,CAAC;gBACxD,GAAG,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;gBAE7B,GAAG,CAAC,UAAU,CAAC,EAAC,MAAM,EAAE,aAAa,CAAC,aAAa,EAAC,CAAC,CAAC;gBACtD,GAAG,CAAC,cAAc,CACd,IAAI,uBAAc,CAAC;oBACf,SAAS,EAAE,IAAI;oBACf,qBAAqB,EAAE,KAAK;iBAC/B,CAAC,CACL,CAAC;gBACF,GAAG,CAAC,qBAAqB,CACrB,IAAI,mCAA0B,CAAC,GAAG,CAAC,GAAG,CAAC,gBAAS,CAAC,CAAC,EAClD,IAAI,uCAAkB,CAAC,aAAa,CAAC,CACxC,CAAC;gBACF,GAAG,CAAC,qBAAqB,CAAC,IAAI,wCAAe,EAAE,CAAC,CAAC;gBACjD,MAAM,cAAc,GAAG,aAAa,CAAC,OAAO,CAAC;gBAC7C,MAAM,UAAU,GAAG,GAAG,CAAC,GAAG,CAAC,uBAAU,CAAC,CAAC;gBACvC,UAAU,CAAC,QAAQ,CAAC,GAAG,EAAE,uBAAuB,CAAC,CAAC;gBAElD,MAAM,GAAG,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;gBAEjC,aAAa,CAAC,GAAG,CACb,iCAAiC,aAAa,CAAC,OAAO,EAAE,CAC3D,CAAC;gBAEF,MAAM,QAAQ,CAAC,GAAG,CAAC,CAAC;aACvB;YAAC,OAAO,mBAAmB,EAAE;gBAC1B,uEAAuE;gBACvE,OAAO,CAAC,KAAK;gBACT,4EAA4E;gBAC5E,iCAAiC,mBAAmB,EAAE,CACzD,CAAC;gBACF,mDAAmD;gBACnD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACnB;QACL,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;CACJ,CAAA;AAhDY,SAAS;IAZrB,eAAM,CAAC;QACJ,OAAO,EAAE;YACL,4BAAY;YACZ,oCAAgB;YAChB,gCAAc;YACd,0BAAW;YACX,uCAAiB;SACpB;QACD,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE,CAAC,wBAAU,EAAE,uBAAU,CAAC;QACnC,OAAO,EAAE,CAAC,uBAAU,CAAC;KACxB,CAAC;GACW,SAAS,CAgDrB;AAhDY,8BAAS"}
|