@valentine-efagene/qshelter-common 1.0.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/OpenApiHelper.ts +121 -0
- package/decorator/permission.decorator.ts +4 -0
- package/decorator/tenant.decorator.ts +16 -0
- package/dist/entities/BaseEntity.d.ts +11 -0
- package/dist/entities/BaseEntity.js +54 -0
- package/dist/entities/BaseEntity.js.map +1 -0
- package/dist/entities/TenantAwareEntity.d.ts +10 -0
- package/dist/entities/TenantAwareEntity.js +52 -0
- package/dist/entities/TenantAwareEntity.js.map +1 -0
- package/dist/entities/TenantAwareRepository.d.ts +13 -0
- package/dist/entities/TenantAwareRepository.js +65 -0
- package/dist/entities/TenantAwareRepository.js.map +1 -0
- package/dist/entities/amenity.entity.d.ts +4 -0
- package/dist/entities/amenity.entity.js +27 -0
- package/dist/entities/amenity.entity.js.map +1 -0
- package/dist/entities/common.entity.d.ts +17 -0
- package/dist/entities/common.entity.js +63 -0
- package/dist/entities/common.entity.js.map +1 -0
- package/dist/entities/common.pure.entity.d.ts +11 -0
- package/dist/entities/common.pure.entity.js +51 -0
- package/dist/entities/common.pure.entity.js.map +1 -0
- package/dist/entities/index.d.ts +27 -0
- package/dist/entities/index.js +44 -0
- package/dist/entities/index.js.map +1 -0
- package/dist/entities/mortgage-document.entity.d.ts +14 -0
- package/dist/entities/mortgage-document.entity.js +58 -0
- package/dist/entities/mortgage-document.entity.js.map +1 -0
- package/dist/entities/mortgage-downpayment-installment.entity.d.ts +19 -0
- package/dist/entities/mortgage-downpayment-installment.entity.js +63 -0
- package/dist/entities/mortgage-downpayment-installment.entity.js.map +1 -0
- package/dist/entities/mortgage-downpayment-payment.entity.d.ts +28 -0
- package/dist/entities/mortgage-downpayment-payment.entity.js +84 -0
- package/dist/entities/mortgage-downpayment-payment.entity.js.map +1 -0
- package/dist/entities/mortgage-downpayment.entity.d.ts +22 -0
- package/dist/entities/mortgage-downpayment.entity.js +66 -0
- package/dist/entities/mortgage-downpayment.entity.js.map +1 -0
- package/dist/entities/mortgage-step.entity.d.ts +12 -0
- package/dist/entities/mortgage-step.entity.js +52 -0
- package/dist/entities/mortgage-step.entity.js.map +1 -0
- package/dist/entities/mortgage-type.entity.d.ts +10 -0
- package/dist/entities/mortgage-type.entity.js +46 -0
- package/dist/entities/mortgage-type.entity.js.map +1 -0
- package/dist/entities/mortgage.entity.d.ts +37 -0
- package/dist/entities/mortgage.entity.js +124 -0
- package/dist/entities/mortgage.entity.js.map +1 -0
- package/dist/entities/password_reset_tokens.entity.d.ts +7 -0
- package/dist/entities/password_reset_tokens.entity.js +43 -0
- package/dist/entities/password_reset_tokens.entity.js.map +1 -0
- package/dist/entities/permission.entity.d.ts +6 -0
- package/dist/entities/permission.entity.js +30 -0
- package/dist/entities/permission.entity.js.map +1 -0
- package/dist/entities/property-document.entity.d.ts +6 -0
- package/dist/entities/property-document.entity.js +34 -0
- package/dist/entities/property-document.entity.js.map +1 -0
- package/dist/entities/property-media.entity.d.ts +6 -0
- package/dist/entities/property-media.entity.js +36 -0
- package/dist/entities/property-media.entity.js.map +1 -0
- package/dist/entities/property.entity.d.ts +36 -0
- package/dist/entities/property.entity.js +182 -0
- package/dist/entities/property.entity.js.map +1 -0
- package/dist/entities/refresh_token.entity.d.ts +7 -0
- package/dist/entities/refresh_token.entity.js +35 -0
- package/dist/entities/refresh_token.entity.js.map +1 -0
- package/dist/entities/role.entity.d.ts +8 -0
- package/dist/entities/role.entity.js +39 -0
- package/dist/entities/role.entity.js.map +1 -0
- package/dist/entities/settings.entity.d.ts +17 -0
- package/dist/entities/settings.entity.js +79 -0
- package/dist/entities/settings.entity.js.map +1 -0
- package/dist/entities/social.entity.d.ts +8 -0
- package/dist/entities/social.entity.js +46 -0
- package/dist/entities/social.entity.js.map +1 -0
- package/dist/entities/tenant.entity.d.ts +29 -0
- package/dist/entities/tenant.entity.js +82 -0
- package/dist/entities/tenant.entity.js.map +1 -0
- package/dist/entities/transaction.entity.d.ts +17 -0
- package/dist/entities/transaction.entity.js +84 -0
- package/dist/entities/transaction.entity.js.map +1 -0
- package/dist/entities/user.entity.d.ts +26 -0
- package/dist/entities/user.entity.js +103 -0
- package/dist/entities/user.entity.js.map +1 -0
- package/dist/entities/user_suspensions.entity.d.ts +7 -0
- package/dist/entities/user_suspensions.entity.js +42 -0
- package/dist/entities/user_suspensions.entity.js.map +1 -0
- package/dist/entities/wallet.entity.d.ts +17 -0
- package/dist/entities/wallet.entity.js +79 -0
- package/dist/entities/wallet.entity.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/pagination/index.d.ts +2 -0
- package/dist/pagination/index.js +19 -0
- package/dist/pagination/index.js.map +1 -0
- package/dist/pagination/pagination.helper.d.ts +7 -0
- package/dist/pagination/pagination.helper.js +40 -0
- package/dist/pagination/pagination.helper.js.map +1 -0
- package/dist/pagination/pagination.types.d.ts +19 -0
- package/dist/pagination/pagination.types.js +3 -0
- package/dist/pagination/pagination.types.js.map +1 -0
- package/dist/standard-response.d.ts +7 -0
- package/dist/standard-response.js +27 -0
- package/dist/standard-response.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types/common.type.d.ts +26 -0
- package/dist/types/common.type.js +26 -0
- package/dist/types/common.type.js.map +1 -0
- package/dist/types/mortgage-fsm.types.d.ts +180 -0
- package/dist/types/mortgage-fsm.types.js +130 -0
- package/dist/types/mortgage-fsm.types.js.map +1 -0
- package/dist/types/policy.types.d.ts +18 -0
- package/dist/types/policy.types.js +3 -0
- package/dist/types/policy.types.js.map +1 -0
- package/dist/types/property.type.d.ts +9 -0
- package/dist/types/property.type.js +15 -0
- package/dist/types/property.type.js.map +1 -0
- package/dist/types/social.enums.d.ts +15 -0
- package/dist/types/social.enums.js +22 -0
- package/dist/types/social.enums.js.map +1 -0
- package/dist/types/tenant.enums.d.ts +13 -0
- package/dist/types/tenant.enums.js +19 -0
- package/dist/types/tenant.enums.js.map +1 -0
- package/dist/types/transaction.type.d.ts +8 -0
- package/dist/types/transaction.type.js +14 -0
- package/dist/types/transaction.type.js.map +1 -0
- package/dist/types/user.enums.d.ts +10 -0
- package/dist/types/user.enums.js +16 -0
- package/dist/types/user.enums.js.map +1 -0
- package/entities/BaseEntity.ts +34 -0
- package/entities/TenantAwareEntity.ts +34 -0
- package/entities/TenantAwareRepository.ts +100 -0
- package/entities/amenity.entity.ts +10 -0
- package/entities/common.entity.ts +46 -0
- package/entities/common.pure.entity.ts +36 -0
- package/entities/index.ts +27 -0
- package/entities/mortgage-document.entity.ts +37 -0
- package/entities/mortgage-downpayment-installment.entity.ts +40 -0
- package/entities/mortgage-downpayment-payment.entity.ts +61 -0
- package/entities/mortgage-downpayment.entity.ts +43 -0
- package/entities/mortgage-step.entity.ts +33 -0
- package/entities/mortgage-type.entity.ts +31 -0
- package/entities/mortgage.entity.ts +89 -0
- package/entities/password_reset_tokens.entity.ts +25 -0
- package/entities/permission.entity.ts +12 -0
- package/entities/property-document.entity.ts +21 -0
- package/entities/property-media.entity.ts +23 -0
- package/entities/property.entity.ts +147 -0
- package/entities/refresh_token.entity.ts +16 -0
- package/entities/role.entity.ts +20 -0
- package/entities/settings.entity.ts +56 -0
- package/entities/social.entity.ts +27 -0
- package/entities/tenant.entity.ts +65 -0
- package/entities/transaction.entity.ts +56 -0
- package/entities/user.entity.ts +89 -0
- package/entities/user_suspensions.entity.ts +24 -0
- package/entities/wallet.entity.ts +54 -0
- package/guard/permission.guard.ts +42 -0
- package/guard/swagger-auth.guard.ts +9 -0
- package/helpers/ArrayHelper.ts +1 -0
- package/helpers/ConstantHelper.ts +101 -0
- package/helpers/CustomNamingStrategy.ts +27 -0
- package/helpers/DateHelper.ts +21 -0
- package/helpers/EmailHelper.ts +38 -0
- package/helpers/FileSystemHelper.ts +101 -0
- package/index.ts +9 -0
- package/middleware/TenantMiddleware.ts +52 -0
- package/package.json +46 -0
- package/pagination/index.ts +2 -0
- package/pagination/pagination.helper.ts +57 -0
- package/pagination/pagination.types.ts +21 -0
- package/standard-response.ts +16 -0
- package/tsconfig.json +33 -0
- package/types/common.type.ts +32 -0
- package/types/mortgage-fsm.types.ts +279 -0
- package/types/policy.types.ts +21 -0
- package/types/property.type.ts +10 -0
- package/types/social.enums.ts +17 -0
- package/types/tenant.enums.ts +14 -0
- package/types/transaction.type.ts +9 -0
- package/types/user.enums.ts +11 -0
package/OpenApiHelper.ts
ADDED
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { ApiHeaderOptions, ApiResponseOptions } from '@nestjs/swagger';
|
|
2
|
+
|
|
3
|
+
export default class OpenApiHelper {
|
|
4
|
+
public static userIdHeader: ApiHeaderOptions = {
|
|
5
|
+
name: 'user_id',
|
|
6
|
+
description: "Requesting user's ID",
|
|
7
|
+
required: true,
|
|
8
|
+
example: '1',
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
public static responseDoc: ApiResponseOptions = {
|
|
12
|
+
status: 200,
|
|
13
|
+
description: 'Successful response',
|
|
14
|
+
schema: {
|
|
15
|
+
type: 'object',
|
|
16
|
+
properties: {
|
|
17
|
+
statusCode: { type: 'number' },
|
|
18
|
+
message: { type: 'string' },
|
|
19
|
+
data: { type: 'object' },
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
public static paginatedResponseDoc: ApiResponseOptions = {
|
|
25
|
+
status: 200,
|
|
26
|
+
description: 'Successful response',
|
|
27
|
+
schema: {
|
|
28
|
+
type: 'object',
|
|
29
|
+
properties: {
|
|
30
|
+
statusCode: { type: 'number' },
|
|
31
|
+
message: { type: 'string' },
|
|
32
|
+
data: {
|
|
33
|
+
type: 'object',
|
|
34
|
+
properties: {
|
|
35
|
+
data: { type: 'array', items: { type: 'object' } }, // Adjust the type based on your actual item type
|
|
36
|
+
meta: {
|
|
37
|
+
type: 'object',
|
|
38
|
+
properties: {
|
|
39
|
+
itemsPerPage: { type: 'number' },
|
|
40
|
+
totalItems: { type: 'number' },
|
|
41
|
+
currentPage: { type: 'number' },
|
|
42
|
+
totalPages: { type: 'number' },
|
|
43
|
+
sortBy: { type: 'array' },
|
|
44
|
+
search: { type: 'string' },
|
|
45
|
+
filter: {
|
|
46
|
+
type: 'object',
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
link: {
|
|
51
|
+
type: 'object',
|
|
52
|
+
properties: {
|
|
53
|
+
first: { type: 'string' },
|
|
54
|
+
previous: { type: 'string' },
|
|
55
|
+
current: { type: 'string' },
|
|
56
|
+
next: { type: 'string' },
|
|
57
|
+
last: { type: 'string' },
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
},
|
|
61
|
+
},
|
|
62
|
+
},
|
|
63
|
+
},
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
public static arrayResponseDoc: ApiResponseOptions = {
|
|
67
|
+
status: 200,
|
|
68
|
+
description: 'Successful response',
|
|
69
|
+
schema: {
|
|
70
|
+
type: 'object',
|
|
71
|
+
properties: {
|
|
72
|
+
statusCode: { type: 'number' },
|
|
73
|
+
message: { type: 'string' },
|
|
74
|
+
data: {
|
|
75
|
+
type: 'array',
|
|
76
|
+
items: { type: 'object' },
|
|
77
|
+
},
|
|
78
|
+
},
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
public static nullResponseDoc: ApiResponseOptions = {
|
|
83
|
+
status: 200,
|
|
84
|
+
description: 'Successful response',
|
|
85
|
+
schema: {
|
|
86
|
+
oneOf: [
|
|
87
|
+
{
|
|
88
|
+
type: 'object',
|
|
89
|
+
properties: {
|
|
90
|
+
statusCode: { type: 'number' },
|
|
91
|
+
message: { type: 'string' },
|
|
92
|
+
data: {
|
|
93
|
+
type: 'string',
|
|
94
|
+
nullable: true,
|
|
95
|
+
description: 'Nothing is returned',
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
],
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
public static errorResponseDoc: ApiResponseOptions = {
|
|
104
|
+
status: 200,
|
|
105
|
+
description: 'Successful response',
|
|
106
|
+
schema: {
|
|
107
|
+
oneOf: [
|
|
108
|
+
{
|
|
109
|
+
type: 'object',
|
|
110
|
+
properties: {
|
|
111
|
+
statusCode: { type: 'number' },
|
|
112
|
+
message: { type: 'string' },
|
|
113
|
+
error: {
|
|
114
|
+
type: 'object',
|
|
115
|
+
},
|
|
116
|
+
},
|
|
117
|
+
},
|
|
118
|
+
],
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { createParamDecorator, ExecutionContext } from '@nestjs/common';
|
|
2
|
+
import { Tenant } from '../../tenant/tenant.entity';
|
|
3
|
+
|
|
4
|
+
export const CurrentTenant = createParamDecorator(
|
|
5
|
+
(data: unknown, ctx: ExecutionContext): Tenant | undefined => {
|
|
6
|
+
const request = ctx.switchToHttp().getRequest();
|
|
7
|
+
return request.tenant;
|
|
8
|
+
},
|
|
9
|
+
);
|
|
10
|
+
|
|
11
|
+
export const CurrentTenantId = createParamDecorator(
|
|
12
|
+
(data: unknown, ctx: ExecutionContext): number | undefined => {
|
|
13
|
+
const request = ctx.switchToHttp().getRequest();
|
|
14
|
+
return request.tenantId;
|
|
15
|
+
},
|
|
16
|
+
);
|
|
@@ -0,0 +1,54 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.TenantAwareBaseEntity = exports.BaseEntity = void 0;
|
|
16
|
+
const tenant_entity_1 = __importDefault(require("./tenant.entity"));
|
|
17
|
+
const typeorm_1 = require("typeorm");
|
|
18
|
+
class BaseEntity {
|
|
19
|
+
}
|
|
20
|
+
exports.BaseEntity = BaseEntity;
|
|
21
|
+
__decorate([
|
|
22
|
+
(0, typeorm_1.PrimaryGeneratedColumn)(),
|
|
23
|
+
__metadata("design:type", Number)
|
|
24
|
+
], BaseEntity.prototype, "id", void 0);
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, typeorm_1.CreateDateColumn)({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP' }),
|
|
27
|
+
__metadata("design:type", Date)
|
|
28
|
+
], BaseEntity.prototype, "createdAt", void 0);
|
|
29
|
+
__decorate([
|
|
30
|
+
(0, typeorm_1.UpdateDateColumn)({
|
|
31
|
+
type: 'timestamp',
|
|
32
|
+
default: () => 'CURRENT_TIMESTAMP',
|
|
33
|
+
onUpdate: 'CURRENT_TIMESTAMP',
|
|
34
|
+
}),
|
|
35
|
+
__metadata("design:type", Date)
|
|
36
|
+
], BaseEntity.prototype, "updatedAt", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, typeorm_1.DeleteDateColumn)({ nullable: true, default: null }),
|
|
39
|
+
__metadata("design:type", Date)
|
|
40
|
+
], BaseEntity.prototype, "deletedAt", void 0);
|
|
41
|
+
class TenantAwareBaseEntity extends BaseEntity {
|
|
42
|
+
}
|
|
43
|
+
exports.TenantAwareBaseEntity = TenantAwareBaseEntity;
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, typeorm_1.ManyToOne)(() => tenant_entity_1.default, { onDelete: 'CASCADE' }),
|
|
46
|
+
(0, typeorm_1.JoinColumn)({ name: 'tenant_id' }),
|
|
47
|
+
__metadata("design:type", tenant_entity_1.default)
|
|
48
|
+
], TenantAwareBaseEntity.prototype, "tenant", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, typeorm_1.Column)({ name: 'tenant_id' }),
|
|
51
|
+
(0, typeorm_1.Index)(),
|
|
52
|
+
__metadata("design:type", Number)
|
|
53
|
+
], TenantAwareBaseEntity.prototype, "tenantId", void 0);
|
|
54
|
+
//# sourceMappingURL=BaseEntity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BaseEntity.js","sourceRoot":"","sources":["../../entities/BaseEntity.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,oEAAqC;AACrC,qCAA6I;AAE7I,MAAa,UAAU;CAgBtB;AAhBD,gCAgBC;AAdC;IADC,IAAA,gCAAsB,GAAE;;sCACd;AAGX;IADC,IAAA,0BAAgB,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,mBAAmB,EAAE,CAAC;8BACjE,IAAI;6CAAC;AAOhB;IALC,IAAA,0BAAgB,EAAC;QAChB,IAAI,EAAE,WAAW;QACjB,OAAO,EAAE,GAAG,EAAE,CAAC,mBAAmB;QAClC,QAAQ,EAAE,mBAAmB;KAC9B,CAAC;8BACS,IAAI;6CAAC;AAGhB;IADC,IAAA,0BAAgB,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;8BACzC,IAAI;6CAAC;AAOlB,MAAa,qBAAsB,SAAQ,UAAU;CAQpD;AARD,sDAQC;AALC;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,uBAAM,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAChD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BAC1B,uBAAM;qDAAC;AAIf;IAFC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;IAC7B,IAAA,eAAK,GAAE;;uDACS"}
|
|
@@ -0,0 +1,52 @@
|
|
|
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 __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.TenantAwareEntity = void 0;
|
|
16
|
+
const tenant_entity_1 = __importDefault(require("./tenant.entity"));
|
|
17
|
+
const typeorm_1 = require("typeorm");
|
|
18
|
+
class TenantAwareEntity {
|
|
19
|
+
}
|
|
20
|
+
exports.TenantAwareEntity = TenantAwareEntity;
|
|
21
|
+
__decorate([
|
|
22
|
+
(0, typeorm_1.PrimaryGeneratedColumn)(),
|
|
23
|
+
__metadata("design:type", Number)
|
|
24
|
+
], TenantAwareEntity.prototype, "id", void 0);
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, typeorm_1.ManyToOne)(() => tenant_entity_1.default, { onDelete: 'CASCADE' }),
|
|
27
|
+
(0, typeorm_1.JoinColumn)({ name: 'tenant_id' }),
|
|
28
|
+
__metadata("design:type", tenant_entity_1.default)
|
|
29
|
+
], TenantAwareEntity.prototype, "tenant", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, typeorm_1.Column)({ name: 'tenant_id' }),
|
|
32
|
+
(0, typeorm_1.Index)(),
|
|
33
|
+
__metadata("design:type", Number)
|
|
34
|
+
], TenantAwareEntity.prototype, "tenantId", void 0);
|
|
35
|
+
__decorate([
|
|
36
|
+
(0, typeorm_1.CreateDateColumn)({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP' }),
|
|
37
|
+
__metadata("design:type", Date)
|
|
38
|
+
], TenantAwareEntity.prototype, "createdAt", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
(0, typeorm_1.UpdateDateColumn)({
|
|
41
|
+
type: 'timestamp',
|
|
42
|
+
default: () => 'CURRENT_TIMESTAMP',
|
|
43
|
+
onUpdate: 'CURRENT_TIMESTAMP',
|
|
44
|
+
}),
|
|
45
|
+
__metadata("design:type", Date)
|
|
46
|
+
], TenantAwareEntity.prototype, "updatedAt", void 0);
|
|
47
|
+
__decorate([
|
|
48
|
+
(0, typeorm_1.DeleteDateColumn)({ nullable: true, default: null }),
|
|
49
|
+
__metadata("design:type", Date)
|
|
50
|
+
], TenantAwareEntity.prototype, "deletedAt", void 0);
|
|
51
|
+
exports.default = TenantAwareEntity;
|
|
52
|
+
//# sourceMappingURL=TenantAwareEntity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TenantAwareEntity.js","sourceRoot":"","sources":["../../entities/TenantAwareEntity.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,oEAAqC;AACrC,qCAA6I;AAM7I,MAAa,iBAAiB;CAwB7B;AAxBD,8CAwBC;AAtBG;IADC,IAAA,gCAAsB,GAAE;;6CACd;AAIX;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,uBAAM,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAChD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BAC1B,uBAAM;iDAAC;AAIf;IAFC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;IAC7B,IAAA,eAAK,GAAE;;mDACS;AAGjB;IADC,IAAA,0BAAgB,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,mBAAmB,EAAE,CAAC;8BACjE,IAAI;oDAAC;AAOhB;IALC,IAAA,0BAAgB,EAAC;QACd,IAAI,EAAE,WAAW;QACjB,OAAO,EAAE,GAAG,EAAE,CAAC,mBAAmB;QAClC,QAAQ,EAAE,mBAAmB;KAChC,CAAC;8BACS,IAAI;oDAAC;AAGhB;IADC,IAAA,0BAAgB,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;8BACzC,IAAI;oDAAC;AAGpB,kBAAe,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Repository, FindManyOptions, FindOneOptions, DeepPartial } from 'typeorm';
|
|
2
|
+
export declare class TenantAwareRepository<Entity extends {
|
|
3
|
+
tenantId: number;
|
|
4
|
+
}> extends Repository<Entity> {
|
|
5
|
+
findByTenant(tenantId: number, options?: FindManyOptions<Entity>): Promise<Entity[]>;
|
|
6
|
+
findOneByTenant(tenantId: number, options?: FindOneOptions<Entity>): Promise<Entity | null>;
|
|
7
|
+
countByTenant(tenantId: number, options?: FindManyOptions<Entity>): Promise<number>;
|
|
8
|
+
createForTenant(tenantId: number, entityData: DeepPartial<Entity>): Promise<Entity>;
|
|
9
|
+
updateForTenant(tenantId: number, id: number, entityData: DeepPartial<Entity>): Promise<Entity>;
|
|
10
|
+
deleteForTenant(tenantId: number, id: number): Promise<void>;
|
|
11
|
+
softDeleteForTenant(tenantId: number, id: number): Promise<void>;
|
|
12
|
+
}
|
|
13
|
+
export default TenantAwareRepository;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TenantAwareRepository = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
class TenantAwareRepository extends typeorm_1.Repository {
|
|
6
|
+
async findByTenant(tenantId, options) {
|
|
7
|
+
return this.find({
|
|
8
|
+
...options,
|
|
9
|
+
where: {
|
|
10
|
+
...options?.where,
|
|
11
|
+
tenantId,
|
|
12
|
+
},
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
async findOneByTenant(tenantId, options) {
|
|
16
|
+
return this.findOne({
|
|
17
|
+
...options,
|
|
18
|
+
where: {
|
|
19
|
+
...options?.where,
|
|
20
|
+
tenantId,
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
async countByTenant(tenantId, options) {
|
|
25
|
+
return this.count({
|
|
26
|
+
...options,
|
|
27
|
+
where: {
|
|
28
|
+
...options?.where,
|
|
29
|
+
tenantId,
|
|
30
|
+
},
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
async createForTenant(tenantId, entityData) {
|
|
34
|
+
const entity = this.create({
|
|
35
|
+
...entityData,
|
|
36
|
+
tenantId,
|
|
37
|
+
});
|
|
38
|
+
return this.save(entity);
|
|
39
|
+
}
|
|
40
|
+
async updateForTenant(tenantId, id, entityData) {
|
|
41
|
+
const entity = await this.findOneByTenant(tenantId, { where: { id } });
|
|
42
|
+
if (!entity) {
|
|
43
|
+
throw new Error(`Entity with ID ${id} not found for tenant ${tenantId}`);
|
|
44
|
+
}
|
|
45
|
+
Object.assign(entity, entityData);
|
|
46
|
+
return this.save(entity);
|
|
47
|
+
}
|
|
48
|
+
async deleteForTenant(tenantId, id) {
|
|
49
|
+
const entity = await this.findOneByTenant(tenantId, { where: { id } });
|
|
50
|
+
if (!entity) {
|
|
51
|
+
throw new Error(`Entity with ID ${id} not found for tenant ${tenantId}`);
|
|
52
|
+
}
|
|
53
|
+
await this.remove(entity);
|
|
54
|
+
}
|
|
55
|
+
async softDeleteForTenant(tenantId, id) {
|
|
56
|
+
const entity = await this.findOneByTenant(tenantId, { where: { id } });
|
|
57
|
+
if (!entity) {
|
|
58
|
+
throw new Error(`Entity with ID ${id} not found for tenant ${tenantId}`);
|
|
59
|
+
}
|
|
60
|
+
await this.softRemove(entity);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
exports.TenantAwareRepository = TenantAwareRepository;
|
|
64
|
+
exports.default = TenantAwareRepository;
|
|
65
|
+
//# sourceMappingURL=TenantAwareRepository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TenantAwareRepository.js","sourceRoot":"","sources":["../../entities/TenantAwareRepository.ts"],"names":[],"mappings":";;;AAAA,qCAAqG;AAMrG,MAAa,qBAA2D,SAAQ,oBAAkB;IAI9F,KAAK,CAAC,YAAY,CAAC,QAAgB,EAAE,OAAiC;QAClE,OAAO,IAAI,CAAC,IAAI,CAAC;YACb,GAAG,OAAO;YACV,KAAK,EAAE;gBACH,GAAG,OAAO,EAAE,KAAK;gBACjB,QAAQ;aACiB;SAChC,CAAC,CAAC;IACP,CAAC;IAKD,KAAK,CAAC,eAAe,CACjB,QAAgB,EAChB,OAAgC;QAEhC,OAAO,IAAI,CAAC,OAAO,CAAC;YAChB,GAAG,OAAO;YACV,KAAK,EAAE;gBACH,GAAG,OAAO,EAAE,KAAK;gBACjB,QAAQ;aACiB;SAChC,CAAC,CAAC;IACP,CAAC;IAKD,KAAK,CAAC,aAAa,CAAC,QAAgB,EAAE,OAAiC;QACnE,OAAO,IAAI,CAAC,KAAK,CAAC;YACd,GAAG,OAAO;YACV,KAAK,EAAE;gBACH,GAAG,OAAO,EAAE,KAAK;gBACjB,QAAQ;aACiB;SAChC,CAAC,CAAC;IACP,CAAC;IAKD,KAAK,CAAC,eAAe,CAAC,QAAgB,EAAE,UAA+B;QACnE,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,GAAG,UAAU;YACb,QAAQ;SACY,CAAC,CAAC;QAC1B,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAKD,KAAK,CAAC,eAAe,CACjB,QAAgB,EAChB,EAAU,EACV,UAA+B;QAE/B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAS,EAAE,CAAC,CAAC;QAC9E,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CAAC,kBAAkB,EAAE,yBAAyB,QAAQ,EAAE,CAAC,CAAC;QAC7E,CAAC;QACD,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAKD,KAAK,CAAC,eAAe,CAAC,QAAgB,EAAE,EAAU;QAC9C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAS,EAAE,CAAC,CAAC;QAC9E,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CAAC,kBAAkB,EAAE,yBAAyB,QAAQ,EAAE,CAAC,CAAC;QAC7E,CAAC;QACD,MAAM,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;IAKD,KAAK,CAAC,mBAAmB,CAAC,QAAgB,EAAE,EAAU;QAClD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,EAAS,EAAE,CAAC,CAAC;QAC9E,IAAI,CAAC,MAAM,EAAE,CAAC;YACV,MAAM,IAAI,KAAK,CAAC,kBAAkB,EAAE,yBAAyB,QAAQ,EAAE,CAAC,CAAC;QAC7E,CAAC;QACD,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;CACJ;AA3FD,sDA2FC;AAED,kBAAe,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
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.Amenity = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const BaseEntity_1 = require("./BaseEntity");
|
|
15
|
+
let Amenity = class Amenity extends BaseEntity_1.BaseEntity {
|
|
16
|
+
};
|
|
17
|
+
exports.Amenity = Amenity;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, typeorm_1.Column)({
|
|
20
|
+
nullable: false
|
|
21
|
+
}),
|
|
22
|
+
__metadata("design:type", String)
|
|
23
|
+
], Amenity.prototype, "name", void 0);
|
|
24
|
+
exports.Amenity = Amenity = __decorate([
|
|
25
|
+
(0, typeorm_1.Entity)({ name: 'amenity' })
|
|
26
|
+
], Amenity);
|
|
27
|
+
//# sourceMappingURL=amenity.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"amenity.entity.js","sourceRoot":"","sources":["../../entities/amenity.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAAyC;AACzC,6CAA0C;AAGnC,IAAM,OAAO,GAAb,MAAM,OAAQ,SAAQ,uBAAU;CAKtC,CAAA;AALY,0BAAO;AAIlB;IAHC,IAAA,gBAAM,EAAC;QACN,QAAQ,EAAE,KAAK;KAChB,CAAC;;qCACU;kBAJD,OAAO;IADnB,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;GACf,OAAO,CAKnB"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { User } from './user.entity';
|
|
2
|
+
import { DocumentStatus } from '../types/common.type';
|
|
3
|
+
import { AbstractTenantAwareEntity } from './common.pure.entity';
|
|
4
|
+
export declare abstract class AbstractBaseReviewableEntity extends AbstractTenantAwareEntity {
|
|
5
|
+
reviewer: User;
|
|
6
|
+
reviewedAt: string;
|
|
7
|
+
}
|
|
8
|
+
export declare abstract class AbstractBaseDocumentEntity extends AbstractBaseReviewableEntity {
|
|
9
|
+
status: DocumentStatus;
|
|
10
|
+
comment: string;
|
|
11
|
+
url: string;
|
|
12
|
+
description: string;
|
|
13
|
+
name: string;
|
|
14
|
+
size: number;
|
|
15
|
+
}
|
|
16
|
+
export declare abstract class AbstractBaseMediaEntity extends AbstractBaseDocumentEntity {
|
|
17
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
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.AbstractBaseMediaEntity = exports.AbstractBaseDocumentEntity = exports.AbstractBaseReviewableEntity = void 0;
|
|
13
|
+
const user_entity_1 = require("./user.entity");
|
|
14
|
+
const typeorm_1 = require("typeorm");
|
|
15
|
+
const common_type_1 = require("../types/common.type");
|
|
16
|
+
const common_pure_entity_1 = require("./common.pure.entity");
|
|
17
|
+
class AbstractBaseReviewableEntity extends common_pure_entity_1.AbstractTenantAwareEntity {
|
|
18
|
+
}
|
|
19
|
+
exports.AbstractBaseReviewableEntity = AbstractBaseReviewableEntity;
|
|
20
|
+
__decorate([
|
|
21
|
+
(0, typeorm_1.ManyToOne)(() => user_entity_1.User, { eager: true }),
|
|
22
|
+
(0, typeorm_1.JoinColumn)({ name: 'reviewed_by' }),
|
|
23
|
+
__metadata("design:type", user_entity_1.User)
|
|
24
|
+
], AbstractBaseReviewableEntity.prototype, "reviewer", void 0);
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, typeorm_1.Column)({ type: 'timestamp', nullable: true }),
|
|
27
|
+
__metadata("design:type", String)
|
|
28
|
+
], AbstractBaseReviewableEntity.prototype, "reviewedAt", void 0);
|
|
29
|
+
class AbstractBaseDocumentEntity extends AbstractBaseReviewableEntity {
|
|
30
|
+
}
|
|
31
|
+
exports.AbstractBaseDocumentEntity = AbstractBaseDocumentEntity;
|
|
32
|
+
__decorate([
|
|
33
|
+
(0, typeorm_1.Column)({
|
|
34
|
+
type: 'enum',
|
|
35
|
+
enum: common_type_1.DocumentStatus,
|
|
36
|
+
default: common_type_1.DocumentStatus.PENDING,
|
|
37
|
+
}),
|
|
38
|
+
__metadata("design:type", String)
|
|
39
|
+
], AbstractBaseDocumentEntity.prototype, "status", void 0);
|
|
40
|
+
__decorate([
|
|
41
|
+
(0, typeorm_1.Column)({ nullable: true }),
|
|
42
|
+
__metadata("design:type", String)
|
|
43
|
+
], AbstractBaseDocumentEntity.prototype, "comment", void 0);
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: false }),
|
|
46
|
+
__metadata("design:type", String)
|
|
47
|
+
], AbstractBaseDocumentEntity.prototype, "url", void 0);
|
|
48
|
+
__decorate([
|
|
49
|
+
(0, typeorm_1.Column)({ nullable: true }),
|
|
50
|
+
__metadata("design:type", String)
|
|
51
|
+
], AbstractBaseDocumentEntity.prototype, "description", void 0);
|
|
52
|
+
__decorate([
|
|
53
|
+
(0, typeorm_1.Column)({ nullable: true }),
|
|
54
|
+
__metadata("design:type", String)
|
|
55
|
+
], AbstractBaseDocumentEntity.prototype, "name", void 0);
|
|
56
|
+
__decorate([
|
|
57
|
+
(0, typeorm_1.Column)({ nullable: false, comment: "In bytes" }),
|
|
58
|
+
__metadata("design:type", Number)
|
|
59
|
+
], AbstractBaseDocumentEntity.prototype, "size", void 0);
|
|
60
|
+
class AbstractBaseMediaEntity extends AbstractBaseDocumentEntity {
|
|
61
|
+
}
|
|
62
|
+
exports.AbstractBaseMediaEntity = AbstractBaseMediaEntity;
|
|
63
|
+
//# sourceMappingURL=common.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.entity.js","sourceRoot":"","sources":["../../entities/common.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+CAAqC;AACrC,qCAIiB;AACjB,sDAAsD;AACtD,6DAAiE;AAEjE,MAAsB,4BAA6B,SAAQ,8CAAyB;CAOnF;AAPD,oEAOC;AAJC;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IACtC,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;8BAC1B,kBAAI;8DAAC;AAGf;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;gEAC3B;AAGrB,MAAsB,0BAA2B,SAAQ,4BAA4B;CAsBpF;AAtBD,gEAsBC;AAhBC;IALC,IAAA,gBAAM,EAAC;QACN,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,4BAAc;QACpB,OAAO,EAAE,4BAAc,CAAC,OAAO;KAChC,CAAC;;0DACqB;AAGvB;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;2DACX;AAGhB;IADC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;;uDAC9B;AAGZ;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;+DACP;AAGpB;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;wDACd;AAGb;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;;wDACrC;AAGd,MAAsB,uBAAwB,SAAQ,0BAA0B;CAG/E;AAHD,0DAGC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Tenant } from "./tenant.entity";
|
|
2
|
+
export declare abstract class AbstractBaseEntity {
|
|
3
|
+
id: number;
|
|
4
|
+
createdAt: Date;
|
|
5
|
+
updatedAt: Date;
|
|
6
|
+
deletedAt: Date;
|
|
7
|
+
}
|
|
8
|
+
export declare abstract class AbstractTenantAwareEntity extends AbstractBaseEntity {
|
|
9
|
+
tenant: Tenant;
|
|
10
|
+
tenantId: number;
|
|
11
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
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.AbstractTenantAwareEntity = exports.AbstractBaseEntity = void 0;
|
|
13
|
+
const typeorm_1 = require("typeorm");
|
|
14
|
+
const tenant_entity_1 = require("./tenant.entity");
|
|
15
|
+
class AbstractBaseEntity {
|
|
16
|
+
}
|
|
17
|
+
exports.AbstractBaseEntity = AbstractBaseEntity;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, typeorm_1.PrimaryGeneratedColumn)(),
|
|
20
|
+
__metadata("design:type", Number)
|
|
21
|
+
], AbstractBaseEntity.prototype, "id", void 0);
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, typeorm_1.CreateDateColumn)({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP' }),
|
|
24
|
+
__metadata("design:type", Date)
|
|
25
|
+
], AbstractBaseEntity.prototype, "createdAt", void 0);
|
|
26
|
+
__decorate([
|
|
27
|
+
(0, typeorm_1.UpdateDateColumn)({
|
|
28
|
+
type: 'timestamp',
|
|
29
|
+
default: () => 'CURRENT_TIMESTAMP',
|
|
30
|
+
onUpdate: 'CURRENT_TIMESTAMP',
|
|
31
|
+
}),
|
|
32
|
+
__metadata("design:type", Date)
|
|
33
|
+
], AbstractBaseEntity.prototype, "updatedAt", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, typeorm_1.DeleteDateColumn)({ nullable: true, default: null }),
|
|
36
|
+
__metadata("design:type", Date)
|
|
37
|
+
], AbstractBaseEntity.prototype, "deletedAt", void 0);
|
|
38
|
+
class AbstractTenantAwareEntity extends AbstractBaseEntity {
|
|
39
|
+
}
|
|
40
|
+
exports.AbstractTenantAwareEntity = AbstractTenantAwareEntity;
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, typeorm_1.ManyToOne)(() => tenant_entity_1.Tenant, { onDelete: 'CASCADE' }),
|
|
43
|
+
(0, typeorm_1.JoinColumn)({ name: 'tenant_id' }),
|
|
44
|
+
__metadata("design:type", tenant_entity_1.Tenant)
|
|
45
|
+
], AbstractTenantAwareEntity.prototype, "tenant", void 0);
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, typeorm_1.Column)({ name: 'tenant_id' }),
|
|
48
|
+
(0, typeorm_1.Index)(),
|
|
49
|
+
__metadata("design:type", Number)
|
|
50
|
+
], AbstractTenantAwareEntity.prototype, "tenantId", void 0);
|
|
51
|
+
//# sourceMappingURL=common.pure.entity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.pure.entity.js","sourceRoot":"","sources":["../../entities/common.pure.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,qCAA6I;AAC7I,mDAAyC;AAGzC,MAAsB,kBAAkB;CAgBvC;AAhBD,gDAgBC;AAdG;IADC,IAAA,gCAAsB,GAAE;;8CACd;AAGX;IADC,IAAA,0BAAgB,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,mBAAmB,EAAE,CAAC;8BACjE,IAAI;qDAAC;AAOhB;IALC,IAAA,0BAAgB,EAAC;QACd,IAAI,EAAE,WAAW;QACjB,OAAO,EAAE,GAAG,EAAE,CAAC,mBAAmB;QAClC,QAAQ,EAAE,mBAAmB;KAChC,CAAC;8BACS,IAAI;qDAAC;AAGhB;IADC,IAAA,0BAAgB,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;8BACzC,IAAI;qDAAC;AAOpB,MAAsB,yBAA0B,SAAQ,kBAAkB;CAQzE;AARD,8DAQC;AALG;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,sBAAM,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAChD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BAC1B,sBAAM;yDAAC;AAIf;IAFC,IAAA,gBAAM,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;IAC7B,IAAA,eAAK,GAAE;;2DACS"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export * from './BaseEntity';
|
|
2
|
+
export * from './TenantAwareEntity';
|
|
3
|
+
export * from './TenantAwareRepository';
|
|
4
|
+
export * from './amenity.entity';
|
|
5
|
+
export * from './common.entity';
|
|
6
|
+
export * from './common.pure.entity';
|
|
7
|
+
export * from './mortgage-document.entity';
|
|
8
|
+
export * from './mortgage-downpayment-installment.entity';
|
|
9
|
+
export * from './mortgage-downpayment-payment.entity';
|
|
10
|
+
export * from './mortgage-downpayment.entity';
|
|
11
|
+
export * from './mortgage-step.entity';
|
|
12
|
+
export * from './mortgage-type.entity';
|
|
13
|
+
export * from './mortgage.entity';
|
|
14
|
+
export * from './password_reset_tokens.entity';
|
|
15
|
+
export * from './permission.entity';
|
|
16
|
+
export * from './property-document.entity';
|
|
17
|
+
export * from './property-media.entity';
|
|
18
|
+
export * from './property.entity';
|
|
19
|
+
export * from './refresh_token.entity';
|
|
20
|
+
export * from './role.entity';
|
|
21
|
+
export * from './settings.entity';
|
|
22
|
+
export * from './social.entity';
|
|
23
|
+
export * from './tenant.entity';
|
|
24
|
+
export * from './transaction.entity';
|
|
25
|
+
export * from './user.entity';
|
|
26
|
+
export * from './user_suspensions.entity';
|
|
27
|
+
export * from './wallet.entity';
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./BaseEntity"), exports);
|
|
18
|
+
__exportStar(require("./TenantAwareEntity"), exports);
|
|
19
|
+
__exportStar(require("./TenantAwareRepository"), exports);
|
|
20
|
+
__exportStar(require("./amenity.entity"), exports);
|
|
21
|
+
__exportStar(require("./common.entity"), exports);
|
|
22
|
+
__exportStar(require("./common.pure.entity"), exports);
|
|
23
|
+
__exportStar(require("./mortgage-document.entity"), exports);
|
|
24
|
+
__exportStar(require("./mortgage-downpayment-installment.entity"), exports);
|
|
25
|
+
__exportStar(require("./mortgage-downpayment-payment.entity"), exports);
|
|
26
|
+
__exportStar(require("./mortgage-downpayment.entity"), exports);
|
|
27
|
+
__exportStar(require("./mortgage-step.entity"), exports);
|
|
28
|
+
__exportStar(require("./mortgage-type.entity"), exports);
|
|
29
|
+
__exportStar(require("./mortgage.entity"), exports);
|
|
30
|
+
__exportStar(require("./password_reset_tokens.entity"), exports);
|
|
31
|
+
__exportStar(require("./permission.entity"), exports);
|
|
32
|
+
__exportStar(require("./property-document.entity"), exports);
|
|
33
|
+
__exportStar(require("./property-media.entity"), exports);
|
|
34
|
+
__exportStar(require("./property.entity"), exports);
|
|
35
|
+
__exportStar(require("./refresh_token.entity"), exports);
|
|
36
|
+
__exportStar(require("./role.entity"), exports);
|
|
37
|
+
__exportStar(require("./settings.entity"), exports);
|
|
38
|
+
__exportStar(require("./social.entity"), exports);
|
|
39
|
+
__exportStar(require("./tenant.entity"), exports);
|
|
40
|
+
__exportStar(require("./transaction.entity"), exports);
|
|
41
|
+
__exportStar(require("./user.entity"), exports);
|
|
42
|
+
__exportStar(require("./user_suspensions.entity"), exports);
|
|
43
|
+
__exportStar(require("./wallet.entity"), exports);
|
|
44
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../entities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA6B;AAC7B,sDAAoC;AACpC,0DAAwC;AACxC,mDAAiC;AACjC,kDAAgC;AAChC,uDAAqC;AACrC,6DAA2C;AAC3C,4EAA0D;AAC1D,wEAAsD;AACtD,gEAA8C;AAC9C,yDAAuC;AACvC,yDAAuC;AACvC,oDAAkC;AAClC,iEAA+C;AAC/C,sDAAoC;AACpC,6DAA2C;AAC3C,0DAAwC;AACxC,oDAAkC;AAClC,yDAAuC;AACvC,gDAA8B;AAC9B,oDAAkC;AAClC,kDAAgC;AAChC,kDAAgC;AAChC,uDAAqC;AACrC,gDAA8B;AAC9B,4DAA0C;AAC1C,kDAAgC"}
|