@campxdev/server-shared 1.3.25 → 1.3.26
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/common/decorators/batch-validation.decorator.d.ts +3 -0
- package/dist/common/decorators/batch-validation.decorator.d.ts.map +1 -0
- package/dist/common/decorators/batch-validation.decorator.js +27 -0
- package/dist/common/decorators/batch-validation.decorator.js.map +1 -0
- package/dist/common/filters/unhandled-exception.filter.js +2 -3
- package/dist/common/filters/unhandled-exception.filter.js.map +1 -1
- package/dist/common/guards/guard.d.ts +2 -0
- package/dist/common/guards/guard.d.ts.map +1 -1
- package/dist/common/guards/guard.js +6 -1
- package/dist/common/guards/guard.js.map +1 -1
- package/dist/common/index.d.ts +1 -1
- package/dist/common/index.d.ts.map +1 -1
- package/dist/common/index.js +1 -1
- package/dist/common/index.js.map +1 -1
- package/dist/common/interceptors/request.interceptor.d.ts +6 -1
- package/dist/common/interceptors/request.interceptor.d.ts.map +1 -1
- package/dist/common/interceptors/request.interceptor.js +53 -13
- package/dist/common/interceptors/request.interceptor.js.map +1 -1
- package/dist/common/interfaces/context.interface.d.ts +62 -32
- package/dist/common/interfaces/context.interface.d.ts.map +1 -1
- package/dist/common/store/request-store.d.ts +27 -7
- package/dist/common/store/request-store.d.ts.map +1 -1
- package/dist/common/store/request-store.js +96 -23
- package/dist/common/store/request-store.js.map +1 -1
- package/dist/common/store/store.interceptor.js +2 -3
- package/dist/common/store/store.interceptor.js.map +1 -1
- package/dist/domain/db-connection.module.js +2 -3
- package/dist/domain/db-connection.module.js.map +1 -1
- package/dist/domain/entities/evaluator.entity.js +2 -16
- package/dist/domain/entities/evaluator.entity.js.map +1 -1
- package/dist/domain/entities/leads.entity.js +2 -26
- package/dist/domain/entities/leads.entity.js.map +1 -1
- package/dist/domain/entities/profile-permission.entity.d.ts +2 -0
- package/dist/domain/entities/profile-permission.entity.d.ts.map +1 -1
- package/dist/domain/entities/profile-permission.entity.js +7 -12
- package/dist/domain/entities/profile-permission.entity.js.map +1 -1
- package/dist/domain/entities/profile.entity.d.ts +17 -1
- package/dist/domain/entities/profile.entity.d.ts.map +1 -1
- package/dist/domain/entities/profile.entity.js +45 -14
- package/dist/domain/entities/profile.entity.js.map +1 -1
- package/dist/domain/entities/student.entity.d.ts +11 -31
- package/dist/domain/entities/student.entity.d.ts.map +1 -1
- package/dist/domain/entities/student.entity.js +38 -170
- package/dist/domain/entities/student.entity.js.map +1 -1
- package/dist/domain/entities/user.entity.d.ts +0 -3
- package/dist/domain/entities/user.entity.d.ts.map +1 -1
- package/dist/domain/entities/user.entity.js +2 -29
- package/dist/domain/entities/user.entity.js.map +1 -1
- package/dist/domain/index.d.ts +8 -2
- package/dist/domain/index.d.ts.map +1 -1
- package/dist/domain/index.js +8 -2
- package/dist/domain/index.js.map +1 -1
- package/dist/domain/schemas/admission.schema.d.ts +257 -0
- package/dist/domain/schemas/admission.schema.d.ts.map +1 -0
- package/dist/domain/schemas/admission.schema.js +707 -0
- package/dist/domain/schemas/admission.schema.js.map +1 -0
- package/dist/domain/schemas/course.schema.d.ts +54 -0
- package/dist/domain/schemas/course.schema.d.ts.map +1 -0
- package/dist/domain/schemas/course.schema.js +89 -0
- package/dist/domain/schemas/course.schema.js.map +1 -0
- package/dist/domain/schemas/global-users.schema.d.ts +12 -3
- package/dist/domain/schemas/global-users.schema.d.ts.map +1 -1
- package/dist/domain/schemas/global-users.schema.js +46 -23
- package/dist/domain/schemas/global-users.schema.js.map +1 -1
- package/dist/domain/schemas/institution.schema.d.ts +53 -0
- package/dist/domain/schemas/institution.schema.d.ts.map +1 -0
- package/dist/domain/schemas/institution.schema.js +94 -0
- package/dist/domain/schemas/institution.schema.js.map +1 -0
- package/dist/domain/schemas/media-record.schema.d.ts +53 -0
- package/dist/domain/schemas/media-record.schema.d.ts.map +1 -0
- package/dist/domain/schemas/media-record.schema.js +86 -0
- package/dist/domain/schemas/media-record.schema.js.map +1 -0
- package/dist/domain/schemas/program.schema.d.ts +49 -0
- package/dist/domain/schemas/program.schema.d.ts.map +1 -0
- package/dist/domain/schemas/program.schema.js +81 -0
- package/dist/domain/schemas/program.schema.js.map +1 -0
- package/dist/domain/schemas/quota.schema.d.ts +47 -0
- package/dist/domain/schemas/quota.schema.d.ts.map +1 -0
- package/dist/domain/schemas/quota.schema.js +64 -0
- package/dist/domain/schemas/quota.schema.js.map +1 -0
- package/dist/domain/schemas/semester.schema.d.ts +50 -0
- package/dist/domain/schemas/semester.schema.d.ts.map +1 -0
- package/dist/domain/schemas/semester.schema.js +84 -0
- package/dist/domain/schemas/semester.schema.js.map +1 -0
- package/dist/domain/schemas/sub-schemas.schema.d.ts +270 -0
- package/dist/domain/schemas/sub-schemas.schema.d.ts.map +1 -0
- package/dist/domain/schemas/sub-schemas.schema.js +904 -0
- package/dist/domain/schemas/sub-schemas.schema.js.map +1 -0
- package/dist/domain/schemas/tenant.schema.d.ts +89 -35
- package/dist/domain/schemas/tenant.schema.d.ts.map +1 -1
- package/dist/domain/schemas/tenant.schema.js +274 -85
- package/dist/domain/schemas/tenant.schema.js.map +1 -1
- package/dist/domain/shared-domain.module.js +2 -3
- package/dist/domain/shared-domain.module.js.map +1 -1
- package/dist/permissions/app-permissions/commute-x-permissions.d.ts +119 -0
- package/dist/permissions/app-permissions/commute-x-permissions.d.ts.map +1 -0
- package/dist/permissions/app-permissions/commute-x-permissions.js +129 -0
- package/dist/permissions/app-permissions/commute-x-permissions.js.map +1 -0
- package/dist/permissions/app-permissions/enroll-x-permissions.d.ts +538 -0
- package/dist/permissions/app-permissions/enroll-x-permissions.d.ts.map +1 -0
- package/dist/permissions/app-permissions/enroll-x-permissions.js +876 -0
- package/dist/permissions/app-permissions/enroll-x-permissions.js.map +1 -0
- package/dist/permissions/app-permissions/exams-permissions.d.ts +912 -0
- package/dist/permissions/app-permissions/exams-permissions.d.ts.map +1 -0
- package/dist/permissions/app-permissions/exams-permissions.js +1702 -0
- package/dist/permissions/app-permissions/exams-permissions.js.map +1 -0
- package/dist/permissions/app-permissions/hostels-permissions.d.ts +452 -0
- package/dist/permissions/app-permissions/hostels-permissions.d.ts.map +1 -0
- package/dist/permissions/app-permissions/hostels-permissions.js +580 -0
- package/dist/permissions/app-permissions/hostels-permissions.js.map +1 -0
- package/dist/permissions/app-permissions/payments-permissions.d.ts +473 -0
- package/dist/permissions/app-permissions/payments-permissions.d.ts.map +1 -0
- package/dist/permissions/app-permissions/payments-permissions.js +794 -0
- package/dist/permissions/app-permissions/payments-permissions.js.map +1 -0
- package/dist/permissions/app-permissions/people-x-permissions.d.ts +434 -0
- package/dist/permissions/app-permissions/people-x-permissions.d.ts.map +1 -0
- package/dist/permissions/app-permissions/people-x-permissions.js +530 -0
- package/dist/permissions/app-permissions/people-x-permissions.js.map +1 -0
- package/dist/permissions/app-permissions/square-permissions.d.ts +1673 -0
- package/dist/permissions/app-permissions/square-permissions.d.ts.map +1 -0
- package/dist/permissions/app-permissions/square-permissions.js +3024 -0
- package/dist/permissions/app-permissions/square-permissions.js.map +1 -0
- package/dist/permissions/check-permission.guard.d.ts +5 -46
- package/dist/permissions/check-permission.guard.d.ts.map +1 -1
- package/dist/permissions/check-permission.guard.js +14 -8
- package/dist/permissions/check-permission.guard.js.map +1 -1
- package/dist/permissions/index.d.ts +7 -0
- package/dist/permissions/index.d.ts.map +1 -1
- package/dist/permissions/index.js +15 -0
- package/dist/permissions/index.js.map +1 -1
- package/dist/permissions/permissions.d.ts +8021 -762
- package/dist/permissions/permissions.d.ts.map +1 -1
- package/dist/permissions/permissions.js +94 -1916
- package/dist/permissions/permissions.js.map +1 -1
- package/dist/shared-module/shared.module.d.ts +1 -0
- package/dist/shared-module/shared.module.d.ts.map +1 -1
- package/dist/shared-module/shared.module.js +2 -3
- package/dist/shared-module/shared.module.js.map +1 -1
- package/dist/shared-module/shared.service.d.ts +11 -2
- package/dist/shared-module/shared.service.d.ts.map +1 -1
- package/dist/shared-module/shared.service.js +73 -20
- package/dist/shared-module/shared.service.js.map +1 -1
- package/dist/utils/constants.d.ts +19 -4
- package/dist/utils/constants.d.ts.map +1 -1
- package/dist/utils/constants.js +15 -5
- package/dist/utils/constants.js.map +1 -1
- package/dist/utils/utils.d.ts +29 -3
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +132 -12
- package/dist/utils/utils.js.map +1 -1
- package/package.json +1 -1
- package/dist/common/databases/mongoose.repository.d.ts +0 -41
- package/dist/common/databases/mongoose.repository.d.ts.map +0 -1
- package/dist/common/databases/mongoose.repository.js +0 -95
- package/dist/common/databases/mongoose.repository.js.map +0 -1
- package/dist/domain/entities/department.entity.d.ts +0 -10
- package/dist/domain/entities/department.entity.d.ts.map +0 -1
- package/dist/domain/entities/department.entity.js +0 -51
- package/dist/domain/entities/department.entity.js.map +0 -1
- package/dist/domain/entities/program.entity.d.ts +0 -14
- package/dist/domain/entities/program.entity.d.ts.map +0 -1
- package/dist/domain/entities/program.entity.js +0 -71
- package/dist/domain/entities/program.entity.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"batch-validation.decorator.d.ts","sourceRoot":"","sources":["../../../src/common/decorators/batch-validation.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAEvE,wBAAgB,OAAO,CAAC,iBAAiB,CAAC,EAAE,iBAAiB,SAC9C,MAAM,gBAAgB,MAAM,UAkB1C"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IsBatch = void 0;
|
|
4
|
+
const class_validator_1 = require("class-validator");
|
|
5
|
+
function IsBatch(validationOptions) {
|
|
6
|
+
return (obj, propertyName) => {
|
|
7
|
+
(0, class_validator_1.registerDecorator)({
|
|
8
|
+
propertyName: propertyName,
|
|
9
|
+
target: obj.constructor,
|
|
10
|
+
options: validationOptions,
|
|
11
|
+
name: 'isBatch',
|
|
12
|
+
validator: {
|
|
13
|
+
validate(value) {
|
|
14
|
+
if (typeof value !== 'string')
|
|
15
|
+
return false;
|
|
16
|
+
const batchRegex = /^([0-9]{4})\s-\s([0-9]{4})$/;
|
|
17
|
+
return batchRegex.test(value);
|
|
18
|
+
},
|
|
19
|
+
defaultMessage() {
|
|
20
|
+
return `${propertyName} must be a valid batch in the format of "YYYY - YYYY"`;
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
exports.IsBatch = IsBatch;
|
|
27
|
+
//# sourceMappingURL=batch-validation.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"batch-validation.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/batch-validation.decorator.ts"],"names":[],"mappings":";;;AAAA,qDAAuE;AAEvE,SAAgB,OAAO,CAAC,iBAAqC;IAC3D,OAAO,CAAC,GAAW,EAAE,YAAoB,EAAE,EAAE;QAC3C,IAAA,mCAAiB,EAAC;YAChB,YAAY,EAAE,YAAY;YAC1B,MAAM,EAAE,GAAG,CAAC,WAAW;YACvB,OAAO,EAAE,iBAAiB;YAC1B,IAAI,EAAE,SAAS;YACf,SAAS,EAAE;gBACT,QAAQ,CAAC,KAAU;oBACjB,IAAI,OAAO,KAAK,KAAK,QAAQ;wBAAE,OAAO,KAAK,CAAC;oBAC5C,MAAM,UAAU,GAAG,6BAA6B,CAAC;oBACjD,OAAO,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC;gBACD,cAAc;oBACZ,OAAO,GAAG,YAAY,uDAAuD,CAAC;gBAChF,CAAC;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAnBD,0BAmBC"}
|
|
@@ -9,7 +9,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
9
9
|
exports.UnhandledExceptionFilter = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
11
|
const microservices_1 = require("@nestjs/microservices");
|
|
12
|
-
let UnhandledExceptionFilter = class UnhandledExceptionFilter {
|
|
12
|
+
let UnhandledExceptionFilter = exports.UnhandledExceptionFilter = class UnhandledExceptionFilter {
|
|
13
13
|
catch(exception, host) {
|
|
14
14
|
console.log(exception);
|
|
15
15
|
const status = exception['status'];
|
|
@@ -32,8 +32,7 @@ let UnhandledExceptionFilter = class UnhandledExceptionFilter {
|
|
|
32
32
|
});
|
|
33
33
|
}
|
|
34
34
|
};
|
|
35
|
-
UnhandledExceptionFilter = __decorate([
|
|
35
|
+
exports.UnhandledExceptionFilter = UnhandledExceptionFilter = __decorate([
|
|
36
36
|
(0, common_1.Catch)()
|
|
37
37
|
], UnhandledExceptionFilter);
|
|
38
|
-
exports.UnhandledExceptionFilter = UnhandledExceptionFilter;
|
|
39
38
|
//# sourceMappingURL=unhandled-exception.filter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unhandled-exception.filter.js","sourceRoot":"","sources":["../../../src/common/filters/unhandled-exception.filter.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuE;AACvE,yDAAqD;AAG9C,IAAM,wBAAwB,
|
|
1
|
+
{"version":3,"file":"unhandled-exception.filter.js","sourceRoot":"","sources":["../../../src/common/filters/unhandled-exception.filter.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuE;AACvE,yDAAqD;AAG9C,IAAM,wBAAwB,sCAA9B,MAAM,wBAAwB;IACnC,KAAK,CAAC,SAAY,EAAE,IAAmB;QACrC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACvB,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;QACnC,MAAM,QAAQ,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC;QAEvC,IAAI,MAAM,IAAI,QAAQ,EAAE;YACtB,MAAM,IAAI,4BAAY,CAAC;gBACrB,UAAU,EAAE,MAAM;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,OAAO,EAAE,SAAS,CAAC,OAAO;aAC3B,CAAC,CAAC;SACJ;QAED,MAAM,IAAI,4BAAY,CAAC;YACrB,UAAU,EAAE,GAAG;YACf,QAAQ,EAAE;gBACR,UAAU,EAAE,GAAG;gBACf,KAAK,EAAE,uBAAuB;gBAC9B,OAAO,EAAE,SAAS,CAAC,OAAO;aAC3B;YACD,OAAO,EAAE,SAAS,CAAC,OAAO;SAC3B,CAAC,CAAC;IACL,CAAC;CACF,CAAA;mCAxBY,wBAAwB;IADpC,IAAA,cAAK,GAAE;GACK,wBAAwB,CAwBpC"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
export declare const AUTHENTICATE = "authenticate";
|
|
2
|
+
export declare const LEAD_AUTHENTICATE = "leadAuthenticate";
|
|
2
3
|
export declare const JwtAuthGuard: () => import("@nestjs/common").CustomDecorator<string>;
|
|
4
|
+
export declare const LeadJwtAuthGuard: () => import("@nestjs/common").CustomDecorator<string>;
|
|
3
5
|
export declare const CHECK_PERMISSION_KEY = "checkPermissionKey";
|
|
4
6
|
export declare const CheckPermission: (permission: string) => import("@nestjs/common").CustomDecorator<string>;
|
|
5
7
|
export declare const CHECK_EVALUATOR = "checkEvaluator";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"guard.d.ts","sourceRoot":"","sources":["../../../src/common/guards/guard.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,YAAY,iBAAiB,CAAC;AAE3C,eAAO,MAAM,YAAY,wDAExB,CAAC;AAEF,eAAO,MAAM,oBAAoB,uBAAuB,CAAC;AAEzD,eAAO,MAAM,eAAe,eAAgB,MAAM,qDAEjD,CAAC;AAEF,eAAO,MAAM,eAAe,mBAAmB,CAAC;AAEhD,eAAO,MAAM,cAAc,wDAE1B,CAAC"}
|
|
1
|
+
{"version":3,"file":"guard.d.ts","sourceRoot":"","sources":["../../../src/common/guards/guard.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,YAAY,iBAAiB,CAAC;AAE3C,eAAO,MAAM,iBAAiB,qBAAqB,CAAC;AAEpD,eAAO,MAAM,YAAY,wDAExB,CAAC;AAEF,eAAO,MAAM,gBAAgB,wDAE5B,CAAC;AAEF,eAAO,MAAM,oBAAoB,uBAAuB,CAAC;AAEzD,eAAO,MAAM,eAAe,eAAgB,MAAM,qDAEjD,CAAC;AAEF,eAAO,MAAM,eAAe,mBAAmB,CAAC;AAEhD,eAAO,MAAM,cAAc,wDAE1B,CAAC"}
|
|
@@ -1,12 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CheckEvaluator = exports.CHECK_EVALUATOR = exports.CheckPermission = exports.CHECK_PERMISSION_KEY = exports.JwtAuthGuard = exports.AUTHENTICATE = void 0;
|
|
3
|
+
exports.CheckEvaluator = exports.CHECK_EVALUATOR = exports.CheckPermission = exports.CHECK_PERMISSION_KEY = exports.LeadJwtAuthGuard = exports.JwtAuthGuard = exports.LEAD_AUTHENTICATE = exports.AUTHENTICATE = void 0;
|
|
4
4
|
const common_1 = require("@nestjs/common");
|
|
5
5
|
exports.AUTHENTICATE = 'authenticate';
|
|
6
|
+
exports.LEAD_AUTHENTICATE = 'leadAuthenticate';
|
|
6
7
|
const JwtAuthGuard = () => {
|
|
7
8
|
return (0, common_1.SetMetadata)(exports.AUTHENTICATE, true);
|
|
8
9
|
};
|
|
9
10
|
exports.JwtAuthGuard = JwtAuthGuard;
|
|
11
|
+
const LeadJwtAuthGuard = () => {
|
|
12
|
+
return (0, common_1.SetMetadata)(exports.LEAD_AUTHENTICATE, true);
|
|
13
|
+
};
|
|
14
|
+
exports.LeadJwtAuthGuard = LeadJwtAuthGuard;
|
|
10
15
|
exports.CHECK_PERMISSION_KEY = 'checkPermissionKey';
|
|
11
16
|
const CheckPermission = (permission) => {
|
|
12
17
|
return (0, common_1.SetMetadata)(exports.CHECK_PERMISSION_KEY, permission);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"guard.js","sourceRoot":"","sources":["../../../src/common/guards/guard.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAEhC,QAAA,YAAY,GAAG,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"guard.js","sourceRoot":"","sources":["../../../src/common/guards/guard.ts"],"names":[],"mappings":";;;AAAA,2CAA6C;AAEhC,QAAA,YAAY,GAAG,cAAc,CAAC;AAE9B,QAAA,iBAAiB,GAAG,kBAAkB,CAAC;AAE7C,MAAM,YAAY,GAAG,GAAG,EAAE;IAC/B,OAAO,IAAA,oBAAW,EAAC,oBAAY,EAAE,IAAI,CAAC,CAAC;AACzC,CAAC,CAAC;AAFW,QAAA,YAAY,gBAEvB;AAEK,MAAM,gBAAgB,GAAG,GAAG,EAAE;IACnC,OAAO,IAAA,oBAAW,EAAC,yBAAiB,EAAE,IAAI,CAAC,CAAC;AAC9C,CAAC,CAAC;AAFW,QAAA,gBAAgB,oBAE3B;AAEW,QAAA,oBAAoB,GAAG,oBAAoB,CAAC;AAElD,MAAM,eAAe,GAAG,CAAC,UAAkB,EAAE,EAAE;IACpD,OAAO,IAAA,oBAAW,EAAC,4BAAoB,EAAE,UAAU,CAAC,CAAC;AACvD,CAAC,CAAC;AAFW,QAAA,eAAe,mBAE1B;AAEW,QAAA,eAAe,GAAG,gBAAgB,CAAC;AAEzC,MAAM,cAAc,GAAG,GAAG,EAAE;IACjC,OAAO,IAAA,oBAAW,EAAC,uBAAe,EAAE,IAAI,CAAC,CAAC;AAC5C,CAAC,CAAC;AAFW,QAAA,cAAc,kBAEzB"}
|
package/dist/common/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export * from './config/mongo.config';
|
|
2
|
-
export * from './
|
|
2
|
+
export * from './decorators/batch-validation.decorator';
|
|
3
3
|
export * from './decorators/request.decorators';
|
|
4
4
|
export * from './decorators/time-validation.decorator';
|
|
5
5
|
export * from './filters/unhandled-exception.filter';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,yCAAyC,CAAC;AACxD,cAAc,iCAAiC,CAAC;AAChD,cAAc,wCAAwC,CAAC;AACvD,cAAc,sCAAsC,CAAC;AACrD,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oCAAoC,CAAC;AACnD,cAAc,gCAAgC,CAAC;AAC/C,cAAc,uBAAuB,CAAC;AACtC,cAAc,sBAAsB,CAAC;AACrC,cAAc,2BAA2B,CAAC"}
|
package/dist/common/index.js
CHANGED
|
@@ -15,7 +15,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./config/mongo.config"), exports);
|
|
18
|
-
__exportStar(require("./
|
|
18
|
+
__exportStar(require("./decorators/batch-validation.decorator"), exports);
|
|
19
19
|
__exportStar(require("./decorators/request.decorators"), exports);
|
|
20
20
|
__exportStar(require("./decorators/time-validation.decorator"), exports);
|
|
21
21
|
__exportStar(require("./filters/unhandled-exception.filter"), exports);
|
package/dist/common/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAsC;AACtC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wDAAsC;AACtC,0EAAwD;AACxD,kEAAgD;AAChD,yEAAuD;AACvD,uEAAqD;AACrD,iDAA+B;AAC/B,qEAAmD;AACnD,iEAA+C;AAC/C,wDAAsC;AACtC,uDAAqC;AACrC,4DAA0C"}
|
|
@@ -1,15 +1,20 @@
|
|
|
1
1
|
import { CallHandler, ExecutionContext, NestInterceptor } from '@nestjs/common';
|
|
2
2
|
import { Reflector } from '@nestjs/core';
|
|
3
|
+
import { Model } from 'mongoose';
|
|
4
|
+
import { GlobalUser } from '../../domain';
|
|
3
5
|
import { SharedService } from '../../shared-module';
|
|
4
6
|
export declare class RequestInterceptor implements NestInterceptor {
|
|
5
7
|
private readonly reflector;
|
|
6
8
|
private readonly sharedService;
|
|
7
|
-
|
|
9
|
+
private readonly globalUserModel;
|
|
10
|
+
constructor(reflector: Reflector, sharedService: SharedService, globalUserModel: Model<GlobalUser>);
|
|
8
11
|
intercept(context: ExecutionContext, next: CallHandler<any>): Promise<import("rxjs").Observable<any>>;
|
|
9
12
|
private hasAuth;
|
|
10
13
|
private checkAuth;
|
|
11
14
|
private hasPermission;
|
|
12
15
|
private checkPermission;
|
|
16
|
+
private hasLeadAuth;
|
|
17
|
+
private checkLeadAuth;
|
|
13
18
|
private hasEvaluatorAuth;
|
|
14
19
|
private checkEvaluatorAuth;
|
|
15
20
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"request.interceptor.d.ts","sourceRoot":"","sources":["../../../src/common/interceptors/request.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,gBAAgB,EAGhB,eAAe,EAGhB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"request.interceptor.d.ts","sourceRoot":"","sources":["../../../src/common/interceptors/request.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,gBAAgB,EAGhB,eAAe,EAGhB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAEjC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAmBpD,qBACa,kBAAmB,YAAW,eAAe;IAEtD,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,aAAa;IACA,OAAO,CAAC,QAAQ,CAAC,eAAe;gBAF7C,SAAS,EAAE,SAAS,EACpB,aAAa,EAAE,aAAa,EACE,eAAe,EAAE,KAAK,CAAC,UAAU,CAAC;IAG7E,SAAS,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,WAAW,CAAC,GAAG,CAAC;IA6CjE,OAAO,CAAC,OAAO;IAMf,OAAO,CAAC,SAAS;IAoBjB,OAAO,CAAC,aAAa;YASP,eAAe;IAa7B,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,aAAa;IAarB,OAAO,CAAC,gBAAgB;IAMxB,OAAO,CAAC,kBAAkB;CAY3B"}
|
|
@@ -8,29 +8,37 @@ 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
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
15
|
exports.RequestInterceptor = void 0;
|
|
13
16
|
const common_1 = require("@nestjs/common");
|
|
14
17
|
const core_1 = require("@nestjs/core");
|
|
18
|
+
const mongoose_1 = require("@nestjs/mongoose");
|
|
19
|
+
const mongoose_2 = require("mongoose");
|
|
20
|
+
const rxjs_1 = require("rxjs");
|
|
21
|
+
const domain_1 = require("../../domain");
|
|
15
22
|
const check_permission_guard_1 = require("../../permissions/check-permission.guard");
|
|
16
23
|
const shared_module_1 = require("../../shared-module");
|
|
17
24
|
const utils_1 = require("../../utils");
|
|
18
25
|
const guard_1 = require("../guards/guard");
|
|
19
26
|
const request_store_1 = require("../store/request-store");
|
|
20
|
-
let RequestInterceptor = class RequestInterceptor {
|
|
21
|
-
reflector
|
|
22
|
-
sharedService;
|
|
23
|
-
constructor(reflector, sharedService) {
|
|
27
|
+
let RequestInterceptor = exports.RequestInterceptor = class RequestInterceptor {
|
|
28
|
+
constructor(reflector, sharedService, globalUserModel) {
|
|
24
29
|
this.reflector = reflector;
|
|
25
30
|
this.sharedService = sharedService;
|
|
31
|
+
this.globalUserModel = globalUserModel;
|
|
26
32
|
}
|
|
27
33
|
async intercept(context, next) {
|
|
28
34
|
const data = context.switchToRpc().getData();
|
|
35
|
+
const startTime = new Date();
|
|
29
36
|
(0, request_store_1.setRequest)(data);
|
|
30
37
|
const connection = await this.sharedService.getConnection(data);
|
|
31
|
-
(0, request_store_1.setTenantDataSource)(connection
|
|
38
|
+
(0, request_store_1.setTenantDataSource)(connection?.rootDataSource);
|
|
32
39
|
(0, request_store_1.setTenantDetails)(data.tenantDetails);
|
|
33
40
|
(0, request_store_1.setUserData)(data.userData);
|
|
41
|
+
(0, request_store_1.setInstitution)(data.institution);
|
|
34
42
|
// Check if the request is authenticated
|
|
35
43
|
if (this.hasAuth(context))
|
|
36
44
|
this.checkAuth(data.isMicroservice);
|
|
@@ -39,10 +47,23 @@ let RequestInterceptor = class RequestInterceptor {
|
|
|
39
47
|
if (permission.check) {
|
|
40
48
|
await this.checkPermission(permission.permissionSlug, data.isMicroservice);
|
|
41
49
|
}
|
|
50
|
+
// Check if the request is authenticated as lead user
|
|
51
|
+
if (this.hasLeadAuth(context))
|
|
52
|
+
this.checkLeadAuth(data);
|
|
42
53
|
// Check if the request is authenticated as an evaluator
|
|
43
54
|
if (this.hasEvaluatorAuth(context))
|
|
44
55
|
this.checkEvaluatorAuth(data);
|
|
45
|
-
|
|
56
|
+
// show the execution time of the request
|
|
57
|
+
return next.handle().pipe((0, rxjs_1.tap)(() => {
|
|
58
|
+
if (process.env.CAMPX_ENVIRONMENT !== 'development')
|
|
59
|
+
return;
|
|
60
|
+
const endTime = new Date();
|
|
61
|
+
const executionTime = endTime.getTime() - startTime.getTime();
|
|
62
|
+
const minutes = Math.floor(executionTime / 60000);
|
|
63
|
+
const seconds = Math.floor((executionTime % 60000) / 1000);
|
|
64
|
+
const milliseconds = executionTime % 1000;
|
|
65
|
+
console.log(JSON.stringify(data.cmd), `Execution time: ${minutes} m(s) ${seconds} s(s) ${milliseconds} ms(s)`);
|
|
66
|
+
}));
|
|
46
67
|
}
|
|
47
68
|
hasAuth(context) {
|
|
48
69
|
const authMethod = this.reflector.get(guard_1.AUTHENTICATE, context.getHandler());
|
|
@@ -63,6 +84,9 @@ let RequestInterceptor = class RequestInterceptor {
|
|
|
63
84
|
if (!userData.isActive) {
|
|
64
85
|
throw new common_1.UnauthorizedException('User is not active');
|
|
65
86
|
}
|
|
87
|
+
if (!userData.id || !userData.userId) {
|
|
88
|
+
throw new common_1.UnauthorizedException('User is not active');
|
|
89
|
+
}
|
|
66
90
|
}
|
|
67
91
|
hasPermission(context) {
|
|
68
92
|
const methodPermission = this.reflector.get(guard_1.CHECK_PERMISSION_KEY, context.getHandler());
|
|
@@ -76,11 +100,29 @@ let RequestInterceptor = class RequestInterceptor {
|
|
|
76
100
|
if (isMicroservice)
|
|
77
101
|
return;
|
|
78
102
|
this.checkAuth();
|
|
79
|
-
const val = await (0, check_permission_guard_1.validateRequestPermission)(permission, this.sharedService.getCheckPermission());
|
|
103
|
+
const val = await (0, check_permission_guard_1.validateRequestPermission)(permission, this.sharedService.getCheckPermission(), this.globalUserModel);
|
|
80
104
|
if (!val) {
|
|
81
105
|
throw new common_1.ForbiddenException('You are not authorized to perform this action');
|
|
82
106
|
}
|
|
83
107
|
}
|
|
108
|
+
hasLeadAuth(context) {
|
|
109
|
+
const authMethod = this.reflector.get(guard_1.LEAD_AUTHENTICATE, context.getHandler());
|
|
110
|
+
const authClass = this.reflector.get(guard_1.LEAD_AUTHENTICATE, context.getClass());
|
|
111
|
+
return !!authMethod || !!authClass;
|
|
112
|
+
}
|
|
113
|
+
checkLeadAuth(data) {
|
|
114
|
+
if (data.isMicroservice)
|
|
115
|
+
return;
|
|
116
|
+
if (!data.userData) {
|
|
117
|
+
throw new common_1.UnauthorizedException();
|
|
118
|
+
}
|
|
119
|
+
if (!(0, utils_1.checkEqual)(data.userData.tenantId, data.tenantDetails.id)) {
|
|
120
|
+
throw new common_1.UnprocessableEntityException('Invalid Client Request');
|
|
121
|
+
}
|
|
122
|
+
if (!data.userData.leadId) {
|
|
123
|
+
throw new common_1.ForbiddenException('You are not a lead user');
|
|
124
|
+
}
|
|
125
|
+
}
|
|
84
126
|
hasEvaluatorAuth(context) {
|
|
85
127
|
const authMethod = this.reflector.get(guard_1.CHECK_EVALUATOR, context.getHandler());
|
|
86
128
|
const authClass = this.reflector.get(guard_1.CHECK_EVALUATOR, context.getClass());
|
|
@@ -95,18 +137,16 @@ let RequestInterceptor = class RequestInterceptor {
|
|
|
95
137
|
if (!(0, utils_1.checkEqual)(data.userData.tenantId, data.tenantDetails.id)) {
|
|
96
138
|
throw new common_1.UnprocessableEntityException('Invalid Client Request');
|
|
97
139
|
}
|
|
98
|
-
if (!data.userData.isActive) {
|
|
99
|
-
throw new common_1.UnauthorizedException('User is not active');
|
|
100
|
-
}
|
|
101
140
|
if (!data.userData.evaluatorId) {
|
|
102
141
|
throw new common_1.ForbiddenException('User is not evaluator');
|
|
103
142
|
}
|
|
104
143
|
}
|
|
105
144
|
};
|
|
106
|
-
RequestInterceptor = __decorate([
|
|
145
|
+
exports.RequestInterceptor = RequestInterceptor = __decorate([
|
|
107
146
|
(0, common_1.Injectable)(),
|
|
147
|
+
__param(2, (0, mongoose_1.InjectModel)(domain_1.GlobalUser.name)),
|
|
108
148
|
__metadata("design:paramtypes", [core_1.Reflector,
|
|
109
|
-
shared_module_1.SharedService
|
|
149
|
+
shared_module_1.SharedService,
|
|
150
|
+
mongoose_2.Model])
|
|
110
151
|
], RequestInterceptor);
|
|
111
|
-
exports.RequestInterceptor = RequestInterceptor;
|
|
112
152
|
//# sourceMappingURL=request.interceptor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"request.interceptor.js","sourceRoot":"","sources":["../../../src/common/interceptors/request.interceptor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"request.interceptor.js","sourceRoot":"","sources":["../../../src/common/interceptors/request.interceptor.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import * as mongoose from 'mongoose';
|
|
2
|
+
import { PaymentCredentials } from '../../domain/schemas/tenant.schema';
|
|
2
3
|
export interface IRequest {
|
|
3
4
|
cmd: {
|
|
4
5
|
cmd: string;
|
|
5
6
|
action: string;
|
|
7
|
+
version?: string;
|
|
6
8
|
service?: string;
|
|
7
9
|
};
|
|
8
10
|
body?: any;
|
|
@@ -16,6 +18,7 @@ export interface IRequest {
|
|
|
16
18
|
};
|
|
17
19
|
tenantDetails?: TenantDetails;
|
|
18
20
|
userData?: UserData;
|
|
21
|
+
institution?: IInstitution;
|
|
19
22
|
isMicroservice?: boolean;
|
|
20
23
|
}
|
|
21
24
|
export interface TenantDetails {
|
|
@@ -23,14 +26,14 @@ export interface TenantDetails {
|
|
|
23
26
|
id: string;
|
|
24
27
|
name: string;
|
|
25
28
|
subDomain: string;
|
|
26
|
-
host: string;
|
|
27
|
-
port: number;
|
|
28
|
-
username: string;
|
|
29
|
-
password: string;
|
|
30
29
|
database: string;
|
|
30
|
+
institutionType: string;
|
|
31
31
|
env: Env;
|
|
32
32
|
easyWDMSConfig: IEasyWDMSConfig;
|
|
33
|
-
|
|
33
|
+
smtpConfig?: SmtpConfig;
|
|
34
|
+
paymentCredentials?: PaymentCredentials[];
|
|
35
|
+
masterInstitutionId?: string;
|
|
36
|
+
masterInstitutionUniqueId?: number;
|
|
34
37
|
}
|
|
35
38
|
export interface SmtpConfig {
|
|
36
39
|
host: string;
|
|
@@ -41,31 +44,15 @@ export interface SmtpConfig {
|
|
|
41
44
|
from: string;
|
|
42
45
|
}
|
|
43
46
|
export interface Env {
|
|
44
|
-
s3AccessKeyId: string;
|
|
45
|
-
s3SecretAccessKey: string;
|
|
46
47
|
s3BucketName: string;
|
|
47
|
-
|
|
48
|
-
s3Endpoint: string;
|
|
49
|
-
sentryDsn: null;
|
|
50
|
-
razorpayKey: string;
|
|
51
|
-
razorpaySecret: string;
|
|
48
|
+
sentryDsn: string;
|
|
52
49
|
clientName: string;
|
|
50
|
+
studentAndroidApp: string;
|
|
51
|
+
studentIOSApp: string;
|
|
52
|
+
facultyAndroidApp: string;
|
|
53
|
+
facultyIOSApp: string;
|
|
53
54
|
_id: string;
|
|
54
55
|
}
|
|
55
|
-
export interface SendEmailInterface {
|
|
56
|
-
from: string;
|
|
57
|
-
to: string;
|
|
58
|
-
subject: string;
|
|
59
|
-
html: string;
|
|
60
|
-
smtp: {
|
|
61
|
-
host: string;
|
|
62
|
-
port: number;
|
|
63
|
-
secure: boolean;
|
|
64
|
-
username: string;
|
|
65
|
-
password: string;
|
|
66
|
-
};
|
|
67
|
-
attachments?: any;
|
|
68
|
-
}
|
|
69
56
|
export interface IEasyWDMSConfig {
|
|
70
57
|
_id: string;
|
|
71
58
|
host: string;
|
|
@@ -79,6 +66,8 @@ export interface UserData {
|
|
|
79
66
|
id?: number;
|
|
80
67
|
userId?: string;
|
|
81
68
|
email?: string;
|
|
69
|
+
type?: string;
|
|
70
|
+
username?: string;
|
|
82
71
|
fullName?: string;
|
|
83
72
|
isSuperUser?: boolean;
|
|
84
73
|
isActive: boolean;
|
|
@@ -86,12 +75,8 @@ export interface UserData {
|
|
|
86
75
|
evaluatorId?: number;
|
|
87
76
|
leadId?: number;
|
|
88
77
|
userAgent?: string;
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
tokens: string[];
|
|
92
|
-
title: string;
|
|
93
|
-
body: any;
|
|
94
|
-
senderId: string;
|
|
78
|
+
departmentIds?: string[];
|
|
79
|
+
groupId?: string;
|
|
95
80
|
}
|
|
96
81
|
export interface SendSmsInterface {
|
|
97
82
|
to: string[];
|
|
@@ -99,4 +84,49 @@ export interface SendSmsInterface {
|
|
|
99
84
|
sender: string;
|
|
100
85
|
apiKey: string;
|
|
101
86
|
}
|
|
87
|
+
export interface IInstitution {
|
|
88
|
+
_id?: string;
|
|
89
|
+
id?: number;
|
|
90
|
+
name?: string;
|
|
91
|
+
code?: string;
|
|
92
|
+
address?: string;
|
|
93
|
+
recognitionDetails?: string;
|
|
94
|
+
phone?: string;
|
|
95
|
+
email?: string;
|
|
96
|
+
createdById?: number;
|
|
97
|
+
updatedById?: number;
|
|
98
|
+
updatedAt?: string;
|
|
99
|
+
createdAt?: string;
|
|
100
|
+
images?: Image;
|
|
101
|
+
imageSquare?: Image;
|
|
102
|
+
principals?: IInstitutionPrincipalDetails[];
|
|
103
|
+
isMaster?: boolean;
|
|
104
|
+
}
|
|
105
|
+
export interface IInstitutionPrincipalDetails {
|
|
106
|
+
name?: string;
|
|
107
|
+
email?: string;
|
|
108
|
+
}
|
|
109
|
+
export interface Image {
|
|
110
|
+
id?: number;
|
|
111
|
+
originalFileName?: string;
|
|
112
|
+
key?: string;
|
|
113
|
+
type?: string;
|
|
114
|
+
typeId?: number;
|
|
115
|
+
subtype?: string;
|
|
116
|
+
mediaType?: string;
|
|
117
|
+
mimeType?: string;
|
|
118
|
+
fileSize?: number;
|
|
119
|
+
storageDetails?: StorageDetails;
|
|
120
|
+
createdAt?: string;
|
|
121
|
+
updatedAt?: string;
|
|
122
|
+
url?: string;
|
|
123
|
+
}
|
|
124
|
+
export interface StorageDetails {
|
|
125
|
+
Key?: string;
|
|
126
|
+
key?: string;
|
|
127
|
+
ETag?: string;
|
|
128
|
+
Bucket?: string;
|
|
129
|
+
Location?: string;
|
|
130
|
+
ServerSideEncryption?: string;
|
|
131
|
+
}
|
|
102
132
|
//# sourceMappingURL=context.interface.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.interface.d.ts","sourceRoot":"","sources":["../../../src/common/interfaces/context.interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"context.interface.d.ts","sourceRoot":"","sources":["../../../src/common/interfaces/context.interface.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { NextFunction, Request, Response } from 'express';
|
|
2
2
|
import { DataSource, EntityManager } from 'typeorm';
|
|
3
|
-
import { IRequest, TenantDetails, UserData } from '../interfaces/context.interface';
|
|
4
|
-
export declare const EXPRESS_REQUEST = "EXPRESS_REQUEST";
|
|
5
|
-
export declare const TENANT_EASY_WDMS_DATA_SOURCE = "TENANT_EASY_WDMS_DATA_SOURCE";
|
|
6
|
-
export declare const TENANT_DATA_SOURCE = "TENANT_DATA_SOURCE";
|
|
7
|
-
export declare const TENANT_DETAILS = "TENANT_DETAILS";
|
|
8
|
-
export declare const USER_DATA = "USER_DATA";
|
|
3
|
+
import { IInstitution, IRequest, TenantDetails, UserData } from '../interfaces/context.interface';
|
|
9
4
|
export declare function setExpressRequest(req: Request): void;
|
|
10
5
|
export declare function getExpressRequest(): any;
|
|
11
6
|
export declare const storeMiddleWare: (req: Request, _res: Response, next: NextFunction) => void;
|
|
7
|
+
type IStoreSession<T> = {
|
|
8
|
+
setParams: () => void;
|
|
9
|
+
session: () => T | Promise<T>;
|
|
10
|
+
};
|
|
11
|
+
export declare const storeSession: <T>({ session, setParams }: IStoreSession<T>) => Promise<T>;
|
|
12
12
|
export declare function setRequest(req: any): void;
|
|
13
13
|
export declare function getRequest(): IRequest;
|
|
14
14
|
export declare function setTenantDataSource(dataSource: DataSource): void;
|
|
@@ -17,11 +17,31 @@ export declare function getManager(): EntityManager;
|
|
|
17
17
|
export declare function setTenantDetails(tenant: TenantDetails): void;
|
|
18
18
|
export declare function getTenantDetailsIfExists(): TenantDetails;
|
|
19
19
|
export declare function getTenantDetails(): TenantDetails;
|
|
20
|
-
export declare function
|
|
20
|
+
export declare function isMasterInstitution(institutionId?: number): boolean;
|
|
21
|
+
export declare function isMasterGlobalInstitution(institutionId?: string): boolean;
|
|
21
22
|
export declare function setUserData(user: UserData): void;
|
|
22
23
|
export declare function getUserData(): UserData;
|
|
23
24
|
export declare function getEvaluatorId(): number;
|
|
24
25
|
export declare function getLeadId(): number;
|
|
25
26
|
export declare function getEasyWDMSDataSource(): DataSource;
|
|
26
27
|
export declare function getEasyWDMSManager(): EntityManager;
|
|
28
|
+
export declare function getAWSKeys(): {
|
|
29
|
+
accessKeyId: string;
|
|
30
|
+
secretAccessKey: string;
|
|
31
|
+
region: string;
|
|
32
|
+
bucketName: string;
|
|
33
|
+
baseUrl: string;
|
|
34
|
+
};
|
|
35
|
+
export declare function getS3BucketName(): string;
|
|
36
|
+
export declare function getS3BaseUrl(): string;
|
|
37
|
+
export declare function getMySQLCredentials(): {
|
|
38
|
+
host: string;
|
|
39
|
+
port: number;
|
|
40
|
+
username: string;
|
|
41
|
+
password: string;
|
|
42
|
+
};
|
|
43
|
+
export declare function setInstitution(institution: IInstitution): void;
|
|
44
|
+
export declare function getInstitutionOrFail(): IInstitution;
|
|
45
|
+
export declare function getInstitution(): IInstitution;
|
|
46
|
+
export {};
|
|
27
47
|
//# sourceMappingURL=request-store.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"request-store.d.ts","sourceRoot":"","sources":["../../../src/common/store/request-store.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"request-store.d.ts","sourceRoot":"","sources":["../../../src/common/store/request-store.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAGpD,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAUlG,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI,CAEpD;AAED,wBAAgB,iBAAiB,IAAI,GAAG,CAEvC;AAED,eAAO,MAAM,eAAe,QAAS,OAAO,QAAQ,QAAQ,QAAQ,YAAY,SAK/E,CAAC;AAEF,KAAK,aAAa,CAAC,CAAC,IAAI;IACtB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CAC/B,CAAC;AAEF,eAAO,MAAM,YAAY,6DAYxB,CAAC;AAEF,wBAAgB,UAAU,CAAC,GAAG,EAAE,GAAG,GAAG,IAAI,CAEzC;AAED,wBAAgB,UAAU,IAAI,QAAQ,CAErC;AAED,wBAAgB,mBAAmB,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI,CAEhE;AAED,wBAAgB,aAAa,IAAI,UAAU,CAM1C;AAED,wBAAgB,UAAU,IAAI,aAAa,CAG1C;AAED,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI,CAE5D;AAED,wBAAgB,wBAAwB,IAAI,aAAa,CAExD;AAED,wBAAgB,gBAAgB,IAAI,aAAa,CAOhD;AAED,wBAAgB,mBAAmB,CAAC,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAMnE;AAED,wBAAgB,yBAAyB,CAAC,aAAa,CAAC,EAAE,MAAM,GAAG,OAAO,CAMzE;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,QAAQ,GAAG,IAAI,CAEhD;AAED,wBAAgB,WAAW,IAAI,QAAQ,CAEtC;AAED,wBAAgB,cAAc,IAAI,MAAM,CAMvC;AAED,wBAAgB,SAAS,IAAI,MAAM,CAOlC;AAED,wBAAgB,qBAAqB,IAAI,UAAU,CAMlD;AAED,wBAAgB,kBAAkB,IAAI,aAAa,CAGlD;AAGD,wBAAgB,UAAU;;;;;;EAQzB;AAED,wBAAgB,eAAe,WAE9B;AAED,wBAAgB,YAAY,WAE3B;AAGD,wBAAgB,mBAAmB;;;;;EAOlC;AAED,wBAAgB,cAAc,CAAC,WAAW,EAAE,YAAY,GAAG,IAAI,CAE9D;AAED,wBAAgB,oBAAoB,IAAI,YAAY,CAEnD;AAED,wBAAgB,cAAc,IAAI,YAAY,CAM7C"}
|