@uecsio/pages-api 1.3.0 → 2.1.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/README.md +30 -1
- package/dist/dto/create-page.dto.d.ts +2 -2
- package/dist/dto/create-page.dto.d.ts.map +1 -1
- package/dist/dto/create-page.dto.js +13 -6
- package/dist/dto/create-page.dto.js.map +1 -1
- package/dist/dto/update-page.dto.d.ts +10 -5
- package/dist/dto/update-page.dto.d.ts.map +1 -1
- package/dist/dto/update-page.dto.js +90 -7
- package/dist/dto/update-page.dto.js.map +1 -1
- package/dist/entities/page.entity.js +2 -2
- package/dist/entities/page.entity.js.map +1 -1
- package/dist/index.d.ts +1 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -4
- package/dist/index.js.map +1 -1
- package/dist/migrations/{1700000000000-CreatePagesTable.d.ts → 1704067200000-CreatePagesTable.d.ts} +2 -2
- package/dist/migrations/{1700000000000-CreatePagesTable.d.ts.map → 1704067200000-CreatePagesTable.d.ts.map} +1 -1
- package/dist/migrations/{1700000000000-CreatePagesTable.js → 1704067200000-CreatePagesTable.js} +23 -23
- package/dist/migrations/1704067200000-CreatePagesTable.js.map +1 -0
- package/dist/migrations/1735689600000-AddUniqueConstraintToUrl.d.ts +6 -0
- package/dist/migrations/1735689600000-AddUniqueConstraintToUrl.d.ts.map +1 -0
- package/dist/migrations/1735689600000-AddUniqueConstraintToUrl.js +18 -0
- package/dist/migrations/1735689600000-AddUniqueConstraintToUrl.js.map +1 -0
- package/dist/migrations/migration.config.d.ts +4 -3
- package/dist/migrations/migration.config.d.ts.map +1 -1
- package/dist/migrations/migration.config.js +6 -4
- package/dist/migrations/migration.config.js.map +1 -1
- package/dist/pages.module.d.ts.map +1 -1
- package/dist/pages.module.js +16 -5
- package/dist/pages.module.js.map +1 -1
- package/dist/services/page-url.service.d.ts +10 -0
- package/dist/services/page-url.service.d.ts.map +1 -0
- package/dist/services/page-url.service.js +38 -0
- package/dist/services/page-url.service.js.map +1 -0
- package/dist/services/pages.service.d.ts +3 -3
- package/dist/services/pages.service.d.ts.map +1 -1
- package/dist/services/pages.service.js +4 -4
- package/dist/services/pages.service.js.map +1 -1
- package/dist/subscribers/page-url.subscriber.d.ts +12 -0
- package/dist/subscribers/page-url.subscriber.d.ts.map +1 -0
- package/dist/subscribers/page-url.subscriber.js +44 -0
- package/dist/subscribers/page-url.subscriber.js.map +1 -0
- package/dist/{specs → tests}/pages.test.config.d.ts +0 -2
- package/dist/tests/pages.test.config.d.ts.map +1 -0
- package/dist/{specs → tests}/pages.test.config.js +0 -3
- package/dist/tests/pages.test.config.js.map +1 -0
- package/dist/validators/is-unique-url.constraint.d.ts +10 -0
- package/dist/validators/is-unique-url.constraint.d.ts.map +1 -0
- package/dist/validators/is-unique-url.constraint.js +51 -0
- package/dist/validators/is-unique-url.constraint.js.map +1 -0
- package/dist/validators/is-unique-url.validator.d.ts +3 -0
- package/dist/validators/is-unique-url.validator.d.ts.map +1 -0
- package/dist/validators/is-unique-url.validator.js +18 -0
- package/dist/validators/is-unique-url.validator.js.map +1 -0
- package/package.json +11 -4
- package/dist/controllers/pages.controller.d.ts +0 -8
- package/dist/controllers/pages.controller.d.ts.map +0 -1
- package/dist/controllers/pages.controller.js +0 -48
- package/dist/controllers/pages.controller.js.map +0 -1
- package/dist/migrations/1700000000000-CreatePagesTable.js.map +0 -1
- package/dist/specs/pages.test.config.d.ts.map +0 -1
- package/dist/specs/pages.test.config.js.map +0 -1
package/README.md
CHANGED
|
@@ -2,6 +2,35 @@
|
|
|
2
2
|
|
|
3
3
|
A reusable NestJS Pages module for content management with full CRUD operations, validation, and Swagger documentation.
|
|
4
4
|
|
|
5
|
+
## ⚠️ Breaking Changes in v2.0.0
|
|
6
|
+
|
|
7
|
+
### Migrated to @dataui/crud
|
|
8
|
+
|
|
9
|
+
Version 2.0.0 migrates from `@nestjs-library/crud` to `@dataui/crud`.
|
|
10
|
+
|
|
11
|
+
**What Changed:**
|
|
12
|
+
- CRUD library: `@nestjs-library/crud` → `@dataui/crud` + `@dataui/crud-typeorm`
|
|
13
|
+
- Enhanced query features (better filtering, sorting, pagination)
|
|
14
|
+
- Improved Swagger documentation
|
|
15
|
+
- Tests reorganized: `specs/` → `tests/` with `unit/` and `integration/` separation
|
|
16
|
+
|
|
17
|
+
**What Stayed the Same:**
|
|
18
|
+
- All entity fields (rich schema preserved)
|
|
19
|
+
- Auto-URL generation from titles
|
|
20
|
+
- Async validators
|
|
21
|
+
- All API endpoints and functionality
|
|
22
|
+
- Database schema (no migrations needed for upgrade)
|
|
23
|
+
|
|
24
|
+
**Installation:**
|
|
25
|
+
```bash
|
|
26
|
+
npm install @uecsio/pages-api@^2.0.0
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
**Usage:**
|
|
30
|
+
No code changes needed in consuming applications. The public API remains identical.
|
|
31
|
+
|
|
32
|
+
---
|
|
33
|
+
|
|
5
34
|
## 🚀 Features
|
|
6
35
|
|
|
7
36
|
- **Full CRUD Operations**: Create, Read, Update, Delete pages
|
|
@@ -22,7 +51,7 @@ npm install @uecsio/pages-api
|
|
|
22
51
|
This package requires the following peer dependencies in your NestJS application:
|
|
23
52
|
|
|
24
53
|
```bash
|
|
25
|
-
npm install @nestjs/common @nestjs/typeorm typeorm class-validator class-transformer @
|
|
54
|
+
npm install @nestjs/common @nestjs/typeorm typeorm class-validator class-transformer @dataui/crud @dataui/crud-typeorm
|
|
26
55
|
```
|
|
27
56
|
|
|
28
57
|
## 📖 Usage
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-page.dto.d.ts","sourceRoot":"","sources":["../../src/dto/create-page.dto.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"create-page.dto.d.ts","sourceRoot":"","sources":["../../src/dto/create-page.dto.ts"],"names":[],"mappings":"AAMA,qBAAa,aAAa;IAOxB,KAAK,EAAE,MAAM,CAAC;IAUd,GAAG,EAAE,MAAM,CAAC;IAOZ,OAAO,EAAE,MAAM,CAAC;IAShB,SAAS,CAAC,EAAE,MAAM,CAAC;IASnB,YAAY,CAAC,EAAE,MAAM,CAAC;IAQtB,eAAe,CAAC,EAAE,MAAM,CAAC;IAYzB,MAAM,EAAE,MAAM,CAAC;IAQf,YAAY,CAAC,EAAE,MAAM,CAAC;IAQtB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB"}
|
|
@@ -11,7 +11,10 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.CreatePageDto = void 0;
|
|
13
13
|
const class_validator_1 = require("class-validator");
|
|
14
|
+
const class_transformer_1 = require("class-transformer");
|
|
14
15
|
const swagger_1 = require("@nestjs/swagger");
|
|
16
|
+
const utils_api_1 = require("@uecsio/utils-api");
|
|
17
|
+
const page_entity_1 = require("../entities/page.entity");
|
|
15
18
|
class CreatePageDto {
|
|
16
19
|
}
|
|
17
20
|
exports.CreatePageDto = CreatePageDto;
|
|
@@ -26,12 +29,13 @@ __decorate([
|
|
|
26
29
|
], CreatePageDto.prototype, "title", void 0);
|
|
27
30
|
__decorate([
|
|
28
31
|
(0, swagger_1.ApiProperty)({
|
|
29
|
-
description: 'The URL of the page',
|
|
30
|
-
example: '
|
|
32
|
+
description: 'The URL path of the page (without protocol and domain)',
|
|
33
|
+
example: '/welcome',
|
|
31
34
|
maxLength: 255,
|
|
32
35
|
}),
|
|
33
36
|
(0, class_validator_1.IsString)(),
|
|
34
|
-
(0,
|
|
37
|
+
(0, utils_api_1.IsUrlPath)(),
|
|
38
|
+
(0, utils_api_1.IsUniqueValue)(page_entity_1.Page, 'url'),
|
|
35
39
|
__metadata("design:type", String)
|
|
36
40
|
], CreatePageDto.prototype, "url", void 0);
|
|
37
41
|
__decorate([
|
|
@@ -78,7 +82,10 @@ __decorate([
|
|
|
78
82
|
minimum: 0,
|
|
79
83
|
maximum: 2,
|
|
80
84
|
}),
|
|
81
|
-
(0,
|
|
85
|
+
(0, class_transformer_1.Type)(() => Number),
|
|
86
|
+
(0, class_validator_1.IsInt)(),
|
|
87
|
+
(0, class_validator_1.Min)(0),
|
|
88
|
+
(0, class_validator_1.Max)(2),
|
|
82
89
|
__metadata("design:type", Number)
|
|
83
90
|
], CreatePageDto.prototype, "status", void 0);
|
|
84
91
|
__decorate([
|
|
@@ -88,7 +95,7 @@ __decorate([
|
|
|
88
95
|
}),
|
|
89
96
|
(0, class_validator_1.IsOptional)(),
|
|
90
97
|
(0, class_validator_1.IsDateString)(),
|
|
91
|
-
__metadata("design:type",
|
|
98
|
+
__metadata("design:type", String)
|
|
92
99
|
], CreatePageDto.prototype, "activateFrom", void 0);
|
|
93
100
|
__decorate([
|
|
94
101
|
(0, swagger_1.ApiPropertyOptional)({
|
|
@@ -97,6 +104,6 @@ __decorate([
|
|
|
97
104
|
}),
|
|
98
105
|
(0, class_validator_1.IsOptional)(),
|
|
99
106
|
(0, class_validator_1.IsDateString)(),
|
|
100
|
-
__metadata("design:type",
|
|
107
|
+
__metadata("design:type", String)
|
|
101
108
|
], CreatePageDto.prototype, "activateTo", void 0);
|
|
102
109
|
//# sourceMappingURL=create-page.dto.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-page.dto.js","sourceRoot":"","sources":["../../src/dto/create-page.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAsF;AACtF,6CAAmE;
|
|
1
|
+
{"version":3,"file":"create-page.dto.js","sourceRoot":"","sources":["../../src/dto/create-page.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAsF;AACtF,yDAAyC;AACzC,6CAAmE;AACnE,iDAA6D;AAC7D,yDAA+C;AAE/C,MAAa,aAAa;CA+EzB;AA/ED,sCA+EC;AAxEC;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,uBAAuB;QACpC,OAAO,EAAE,wBAAwB;QACjC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,0BAAQ,GAAE;;4CACG;AAUd;IARC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,wDAAwD;QACrE,OAAO,EAAE,UAAU;QACnB,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,0BAAQ,GAAE;IACV,IAAA,qBAAS,GAAE;IACX,IAAA,yBAAa,EAAC,kBAAI,EAAE,KAAK,CAAC;;0CACf;AAOZ;IALC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,8BAA8B;QAC3C,OAAO,EAAE,iEAAiE;KAC3E,CAAC;IACD,IAAA,0BAAQ,GAAE;;8CACK;AAShB;IAPC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,6BAA6B;QAC1C,OAAO,EAAE,8BAA8B;QACvC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;gDACQ;AASnB;IAPC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,gCAAgC;QAC7C,OAAO,EAAE,4BAA4B;QACrC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;mDACW;AAQtB;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,gEAAgE;KAC1E,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;sDACc;AAYzB;IAVC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,gDAAgD;QAC7D,OAAO,EAAE,CAAC;QACV,OAAO,EAAE,CAAC;QACV,OAAO,EAAE,CAAC;KACX,CAAC;IACD,IAAA,wBAAI,EAAC,GAAG,EAAE,CAAC,MAAM,CAAC;IAClB,IAAA,uBAAK,GAAE;IACP,IAAA,qBAAG,EAAC,CAAC,CAAC;IACN,IAAA,qBAAG,EAAC,CAAC,CAAC;;6CACQ;AAQf;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,0BAA0B;KACpC,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,8BAAY,GAAE;;mDACO;AAQtB;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,qCAAqC;QAClD,OAAO,EAAE,0BAA0B;KACpC,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,8BAAY,GAAE;;iDACK"}
|
|
@@ -1,7 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
export declare class UpdatePageDto {
|
|
2
|
+
title?: string;
|
|
3
|
+
url?: string;
|
|
4
|
+
content?: string;
|
|
5
|
+
metaTitle?: string;
|
|
6
|
+
metaKeywords?: string;
|
|
7
|
+
metaDescription?: string;
|
|
8
|
+
status?: number;
|
|
9
|
+
activateFrom?: string;
|
|
10
|
+
activateTo?: string;
|
|
5
11
|
}
|
|
6
|
-
export {};
|
|
7
12
|
//# sourceMappingURL=update-page.dto.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update-page.dto.d.ts","sourceRoot":"","sources":["../../src/dto/update-page.dto.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"update-page.dto.d.ts","sourceRoot":"","sources":["../../src/dto/update-page.dto.ts"],"names":[],"mappings":"AAMA,qBAAa,aAAa;IAQxB,KAAK,CAAC,EAAE,MAAM,CAAC;IAWf,GAAG,CAAC,EAAE,MAAM,CAAC;IAQb,OAAO,CAAC,EAAE,MAAM,CAAC;IASjB,SAAS,CAAC,EAAE,MAAM,CAAC;IASnB,YAAY,CAAC,EAAE,MAAM,CAAC;IAQtB,eAAe,CAAC,EAAE,MAAM,CAAC;IAazB,MAAM,CAAC,EAAE,MAAM,CAAC;IAQhB,YAAY,CAAC,EAAE,MAAM,CAAC;IAQtB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB"}
|
|
@@ -10,21 +10,104 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
10
10
|
};
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.UpdatePageDto = void 0;
|
|
13
|
-
const mapped_types_1 = require("@nestjs/mapped-types");
|
|
14
13
|
const class_validator_1 = require("class-validator");
|
|
14
|
+
const class_transformer_1 = require("class-transformer");
|
|
15
15
|
const swagger_1 = require("@nestjs/swagger");
|
|
16
|
-
const
|
|
17
|
-
|
|
16
|
+
const utils_api_1 = require("@uecsio/utils-api");
|
|
17
|
+
const page_entity_1 = require("../entities/page.entity");
|
|
18
|
+
class UpdatePageDto {
|
|
18
19
|
}
|
|
19
20
|
exports.UpdatePageDto = UpdatePageDto;
|
|
20
21
|
__decorate([
|
|
21
22
|
(0, swagger_1.ApiPropertyOptional)({
|
|
22
|
-
description: 'The
|
|
23
|
+
description: 'The title of the page',
|
|
24
|
+
example: 'Welcome to Our Website',
|
|
25
|
+
maxLength: 255,
|
|
26
|
+
}),
|
|
27
|
+
(0, class_validator_1.IsOptional)(),
|
|
28
|
+
(0, class_validator_1.IsString)(),
|
|
29
|
+
__metadata("design:type", String)
|
|
30
|
+
], UpdatePageDto.prototype, "title", void 0);
|
|
31
|
+
__decorate([
|
|
32
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
33
|
+
description: 'The URL path of the page (without protocol and domain)',
|
|
34
|
+
example: '/welcome',
|
|
35
|
+
maxLength: 255,
|
|
36
|
+
}),
|
|
37
|
+
(0, class_validator_1.IsOptional)(),
|
|
38
|
+
(0, class_validator_1.IsString)(),
|
|
39
|
+
(0, utils_api_1.IsUrlPath)(),
|
|
40
|
+
(0, utils_api_1.IsUniqueValue)(page_entity_1.Page, 'url'),
|
|
41
|
+
__metadata("design:type", String)
|
|
42
|
+
], UpdatePageDto.prototype, "url", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
45
|
+
description: 'The main content of the page',
|
|
46
|
+
example: 'Welcome to our amazing website! We provide the best services...',
|
|
47
|
+
}),
|
|
48
|
+
(0, class_validator_1.IsOptional)(),
|
|
49
|
+
(0, class_validator_1.IsString)(),
|
|
50
|
+
__metadata("design:type", String)
|
|
51
|
+
], UpdatePageDto.prototype, "content", void 0);
|
|
52
|
+
__decorate([
|
|
53
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
54
|
+
description: 'SEO meta title for the page',
|
|
55
|
+
example: 'Welcome Page - Best Services',
|
|
56
|
+
maxLength: 255,
|
|
57
|
+
}),
|
|
58
|
+
(0, class_validator_1.IsOptional)(),
|
|
59
|
+
(0, class_validator_1.IsString)(),
|
|
60
|
+
__metadata("design:type", String)
|
|
61
|
+
], UpdatePageDto.prototype, "metaTitle", void 0);
|
|
62
|
+
__decorate([
|
|
63
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
64
|
+
description: 'SEO meta keywords for the page',
|
|
65
|
+
example: 'welcome, services, website',
|
|
66
|
+
maxLength: 255,
|
|
67
|
+
}),
|
|
68
|
+
(0, class_validator_1.IsOptional)(),
|
|
69
|
+
(0, class_validator_1.IsString)(),
|
|
70
|
+
__metadata("design:type", String)
|
|
71
|
+
], UpdatePageDto.prototype, "metaKeywords", void 0);
|
|
72
|
+
__decorate([
|
|
73
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
74
|
+
description: 'SEO meta description for the page',
|
|
75
|
+
example: 'Welcome to our website where you can find the best services...',
|
|
76
|
+
}),
|
|
77
|
+
(0, class_validator_1.IsOptional)(),
|
|
78
|
+
(0, class_validator_1.IsString)(),
|
|
79
|
+
__metadata("design:type", String)
|
|
80
|
+
], UpdatePageDto.prototype, "metaDescription", void 0);
|
|
81
|
+
__decorate([
|
|
82
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
83
|
+
description: 'Page status (1: active, 0: inactive, 2: draft)',
|
|
23
84
|
example: 1,
|
|
24
|
-
|
|
85
|
+
minimum: 0,
|
|
86
|
+
maximum: 2,
|
|
25
87
|
}),
|
|
26
88
|
(0, class_validator_1.IsOptional)(),
|
|
27
|
-
(0,
|
|
89
|
+
(0, class_transformer_1.Type)(() => Number),
|
|
90
|
+
(0, class_validator_1.IsInt)(),
|
|
91
|
+
(0, class_validator_1.Min)(0),
|
|
92
|
+
(0, class_validator_1.Max)(2),
|
|
28
93
|
__metadata("design:type", Number)
|
|
29
|
-
], UpdatePageDto.prototype, "
|
|
94
|
+
], UpdatePageDto.prototype, "status", void 0);
|
|
95
|
+
__decorate([
|
|
96
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
97
|
+
description: 'Date when the page becomes active',
|
|
98
|
+
example: '2024-01-01T00:00:00.000Z',
|
|
99
|
+
}),
|
|
100
|
+
(0, class_validator_1.IsOptional)(),
|
|
101
|
+
(0, class_validator_1.IsDateString)(),
|
|
102
|
+
__metadata("design:type", String)
|
|
103
|
+
], UpdatePageDto.prototype, "activateFrom", void 0);
|
|
104
|
+
__decorate([
|
|
105
|
+
(0, swagger_1.ApiPropertyOptional)({
|
|
106
|
+
description: 'Date when the page becomes inactive',
|
|
107
|
+
example: '2024-12-31T23:59:59.999Z',
|
|
108
|
+
}),
|
|
109
|
+
(0, class_validator_1.IsOptional)(),
|
|
110
|
+
(0, class_validator_1.IsDateString)(),
|
|
111
|
+
__metadata("design:type", String)
|
|
112
|
+
], UpdatePageDto.prototype, "activateTo", void 0);
|
|
30
113
|
//# sourceMappingURL=update-page.dto.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update-page.dto.js","sourceRoot":"","sources":["../../src/dto/update-page.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"update-page.dto.js","sourceRoot":"","sources":["../../src/dto/update-page.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAsF;AACtF,yDAAyC;AACzC,6CAAsD;AACtD,iDAA6D;AAC7D,yDAA+C;AAE/C,MAAa,aAAa;CAmFzB;AAnFD,sCAmFC;AA3EC;IAPC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,uBAAuB;QACpC,OAAO,EAAE,wBAAwB;QACjC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;4CACI;AAWf;IATC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,wDAAwD;QACrE,OAAO,EAAE,UAAU;QACnB,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;IACV,IAAA,qBAAS,GAAE;IACX,IAAA,yBAAa,EAAC,kBAAI,EAAE,KAAK,CAAC;;0CACd;AAQb;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,8BAA8B;QAC3C,OAAO,EAAE,iEAAiE;KAC3E,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;8CACM;AASjB;IAPC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,6BAA6B;QAC1C,OAAO,EAAE,8BAA8B;QACvC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;gDACQ;AASnB;IAPC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,gCAAgC;QAC7C,OAAO,EAAE,4BAA4B;QACrC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;mDACW;AAQtB;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,gEAAgE;KAC1E,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;sDACc;AAazB;IAXC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,gDAAgD;QAC7D,OAAO,EAAE,CAAC;QACV,OAAO,EAAE,CAAC;QACV,OAAO,EAAE,CAAC;KACX,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,wBAAI,EAAC,GAAG,EAAE,CAAC,MAAM,CAAC;IAClB,IAAA,uBAAK,GAAE;IACP,IAAA,qBAAG,EAAC,CAAC,CAAC;IACN,IAAA,qBAAG,EAAC,CAAC,CAAC;;6CACS;AAQhB;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,0BAA0B;KACpC,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,8BAAY,GAAE;;mDACO;AAQtB;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,qCAAqC;QAClD,OAAO,EAAE,0BAA0B;KACpC,CAAC;IACD,IAAA,4BAAU,GAAE;IACZ,IAAA,8BAAY,GAAE;;iDACK"}
|
|
@@ -39,7 +39,7 @@ __decorate([
|
|
|
39
39
|
example: 'https://example.com/welcome',
|
|
40
40
|
maxLength: 255,
|
|
41
41
|
}),
|
|
42
|
-
(0, typeorm_1.Column)({ length: 255 }),
|
|
42
|
+
(0, typeorm_1.Column)({ length: 255, unique: true }),
|
|
43
43
|
__metadata("design:type", String)
|
|
44
44
|
], Page.prototype, "url", void 0);
|
|
45
45
|
__decorate([
|
|
@@ -121,6 +121,6 @@ __decorate([
|
|
|
121
121
|
__metadata("design:type", Date)
|
|
122
122
|
], Page.prototype, "updatedAt", void 0);
|
|
123
123
|
exports.Page = Page = __decorate([
|
|
124
|
-
(0, typeorm_1.Entity)()
|
|
124
|
+
(0, typeorm_1.Entity)('page')
|
|
125
125
|
], Page);
|
|
126
126
|
//# sourceMappingURL=page.entity.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"page.entity.js","sourceRoot":"","sources":["../../src/entities/page.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAAqG;AACrG,6CAAmE;AAG5D,IAAM,IAAI,GAAV,MAAM,IAAI;CA6FhB,CAAA;AA7FY,oBAAI;AAOf;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,CAAC;QACV,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,gCAAsB,GAAE;;gCACd;AAQX;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,uBAAuB;QACpC,OAAO,EAAE,wBAAwB;QACjC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;mCACV;AAQd;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,qBAAqB;QAClC,OAAO,EAAE,6BAA6B;QACtC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;
|
|
1
|
+
{"version":3,"file":"page.entity.js","sourceRoot":"","sources":["../../src/entities/page.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qCAAqG;AACrG,6CAAmE;AAG5D,IAAM,IAAI,GAAV,MAAM,IAAI;CA6FhB,CAAA;AA7FY,oBAAI;AAOf;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,CAAC;QACV,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,gCAAsB,GAAE;;gCACd;AAQX;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,uBAAuB;QACpC,OAAO,EAAE,wBAAwB;QACjC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;mCACV;AAQd;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,qBAAqB;QAClC,OAAO,EAAE,6BAA6B;QACtC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;;iCAC1B;AAOZ;IALC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,8BAA8B;QAC3C,OAAO,EAAE,iEAAiE;KAC3E,CAAC;IACD,IAAA,gBAAM,GAAE;;qCACO;AAQhB;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,6BAA6B;QAC1C,OAAO,EAAE,8BAA8B;QACvC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;uCACtB;AAQlB;IANC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,gCAAgC;QAC7C,OAAO,EAAE,4BAA4B;QACrC,SAAS,EAAE,GAAG;KACf,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;;0CACnB;AAOrB;IALC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,gEAAgE;KAC1E,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;6CACH;AASxB;IAPC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,gDAAgD;QAC7D,OAAO,EAAE,CAAC;QACV,OAAO,EAAE,CAAC;QACV,OAAO,EAAE,CAAC;KACX,CAAC;IACD,IAAA,gBAAM,GAAE;;oCACM;AAOf;IALC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,mCAAmC;QAChD,OAAO,EAAE,0BAA0B;KACpC,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACb,IAAI;0CAAC;AAOnB;IALC,IAAA,6BAAmB,EAAC;QACnB,WAAW,EAAE,qCAAqC;QAClD,OAAO,EAAE,0BAA0B;KACpC,CAAC;IACD,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;8BACf,IAAI;wCAAC;AAQjB;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,gCAAgC;QAC7C,OAAO,EAAE,0BAA0B;QACnC,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,0BAAgB,GAAE;8BACR,IAAI;uCAAC;AAQhB;IANC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,qCAAqC;QAClD,OAAO,EAAE,0BAA0B;QACnC,QAAQ,EAAE,IAAI;KACf,CAAC;IACD,IAAA,0BAAgB,GAAE;8BACR,IAAI;uCAAC;eA5FL,IAAI;IADhB,IAAA,gBAAM,EAAC,MAAM,CAAC;GACF,IAAI,CA6FhB"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
export * from './pages.module';
|
|
2
2
|
export * from './services/pages.service';
|
|
3
|
-
export * from './controllers/pages.controller';
|
|
4
3
|
export * from './dto/create-page.dto';
|
|
5
4
|
export * from './dto/update-page.dto';
|
|
6
5
|
export * from './entities/page.entity';
|
|
6
|
+
export * from './subscribers/page-url.subscriber';
|
|
7
7
|
export * from './migrations/migration.config';
|
|
8
8
|
export { Page } from './entities/page.entity';
|
|
9
9
|
export { CreatePageDto } from './dto/create-page.dto';
|
|
10
10
|
export { UpdatePageDto } from './dto/update-page.dto';
|
|
11
11
|
export { PagesService } from './services/pages.service';
|
|
12
|
-
export { PagesController } from './controllers/pages.controller';
|
|
13
12
|
export { PagesModule } from './pages.module';
|
|
14
13
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,0BAA0B,CAAC;AACzC,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,0BAA0B,CAAC;AACzC,cAAc,uBAAuB,CAAC;AACtC,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mCAAmC,CAAC;AAGlD,cAAc,+BAA+B,CAAC;AAG9C,OAAO,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -14,13 +14,13 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.PagesModule = exports.
|
|
17
|
+
exports.PagesModule = exports.PagesService = exports.UpdatePageDto = exports.CreatePageDto = exports.Page = void 0;
|
|
18
18
|
__exportStar(require("./pages.module"), exports);
|
|
19
19
|
__exportStar(require("./services/pages.service"), exports);
|
|
20
|
-
__exportStar(require("./controllers/pages.controller"), exports);
|
|
21
20
|
__exportStar(require("./dto/create-page.dto"), exports);
|
|
22
21
|
__exportStar(require("./dto/update-page.dto"), exports);
|
|
23
22
|
__exportStar(require("./entities/page.entity"), exports);
|
|
23
|
+
__exportStar(require("./subscribers/page-url.subscriber"), exports);
|
|
24
24
|
__exportStar(require("./migrations/migration.config"), exports);
|
|
25
25
|
var page_entity_1 = require("./entities/page.entity");
|
|
26
26
|
Object.defineProperty(exports, "Page", { enumerable: true, get: function () { return page_entity_1.Page; } });
|
|
@@ -30,8 +30,6 @@ var update_page_dto_1 = require("./dto/update-page.dto");
|
|
|
30
30
|
Object.defineProperty(exports, "UpdatePageDto", { enumerable: true, get: function () { return update_page_dto_1.UpdatePageDto; } });
|
|
31
31
|
var pages_service_1 = require("./services/pages.service");
|
|
32
32
|
Object.defineProperty(exports, "PagesService", { enumerable: true, get: function () { return pages_service_1.PagesService; } });
|
|
33
|
-
var pages_controller_1 = require("./controllers/pages.controller");
|
|
34
|
-
Object.defineProperty(exports, "PagesController", { enumerable: true, get: function () { return pages_controller_1.PagesController; } });
|
|
35
33
|
var pages_module_1 = require("./pages.module");
|
|
36
34
|
Object.defineProperty(exports, "PagesModule", { enumerable: true, get: function () { return pages_module_1.PagesModule; } });
|
|
37
35
|
//# 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":";;;;;;;;;;;;;;;;;AACA,iDAA+B;AAC/B,2DAAyC;AACzC,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,iDAA+B;AAC/B,2DAAyC;AACzC,wDAAsC;AACtC,wDAAsC;AACtC,yDAAuC;AACvC,oEAAkD;AAGlD,gEAA8C;AAG9C,sDAA8C;AAArC,mGAAA,IAAI,OAAA;AACb,yDAAsD;AAA7C,gHAAA,aAAa,OAAA;AACtB,yDAAsD;AAA7C,gHAAA,aAAa,OAAA;AACtB,0DAAwD;AAA/C,6GAAA,YAAY,OAAA;AACrB,+CAA6C;AAApC,2GAAA,WAAW,OAAA"}
|
package/dist/migrations/{1700000000000-CreatePagesTable.d.ts → 1704067200000-CreatePagesTable.d.ts}
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
-
export declare class
|
|
2
|
+
export declare class CreatePagesTable1704067200000 implements MigrationInterface {
|
|
3
3
|
up(queryRunner: QueryRunner): Promise<void>;
|
|
4
4
|
down(queryRunner: QueryRunner): Promise<void>;
|
|
5
5
|
}
|
|
6
|
-
//# sourceMappingURL=
|
|
6
|
+
//# sourceMappingURL=1704067200000-CreatePagesTable.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"
|
|
1
|
+
{"version":3,"file":"1704067200000-CreatePagesTable.d.ts","sourceRoot":"","sources":["../../src/migrations/1704067200000-CreatePagesTable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAqB,MAAM,SAAS,CAAC;AAE7E,qBAAa,6BAA8B,YAAW,kBAAkB;IACzD,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAwG3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAG3D"}
|
package/dist/migrations/{1700000000000-CreatePagesTable.js → 1704067200000-CreatePagesTable.js}
RENAMED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.CreatePagesTable1704067200000 = void 0;
|
|
4
4
|
const typeorm_1 = require("typeorm");
|
|
5
|
-
class
|
|
5
|
+
class CreatePagesTable1704067200000 {
|
|
6
6
|
async up(queryRunner) {
|
|
7
7
|
await queryRunner.createTable(new typeorm_1.Table({
|
|
8
|
-
name: '
|
|
8
|
+
name: 'page',
|
|
9
9
|
columns: [
|
|
10
10
|
{
|
|
11
11
|
name: 'id',
|
|
@@ -23,27 +23,27 @@ class CreatePagesTable1700000000000 {
|
|
|
23
23
|
{
|
|
24
24
|
name: 'url',
|
|
25
25
|
type: 'varchar',
|
|
26
|
-
length: '
|
|
26
|
+
length: '255',
|
|
27
27
|
isNullable: false,
|
|
28
28
|
},
|
|
29
29
|
{
|
|
30
30
|
name: 'content',
|
|
31
31
|
type: 'text',
|
|
32
|
-
isNullable:
|
|
32
|
+
isNullable: false,
|
|
33
33
|
},
|
|
34
34
|
{
|
|
35
|
-
name: '
|
|
35
|
+
name: 'metaTitle',
|
|
36
36
|
type: 'varchar',
|
|
37
37
|
length: '255',
|
|
38
38
|
isNullable: true,
|
|
39
39
|
},
|
|
40
40
|
{
|
|
41
|
-
name: '
|
|
41
|
+
name: 'metaKeywords',
|
|
42
42
|
type: 'text',
|
|
43
43
|
isNullable: true,
|
|
44
44
|
},
|
|
45
45
|
{
|
|
46
|
-
name: '
|
|
46
|
+
name: 'metaDescription',
|
|
47
47
|
type: 'text',
|
|
48
48
|
isNullable: true,
|
|
49
49
|
},
|
|
@@ -54,23 +54,23 @@ class CreatePagesTable1700000000000 {
|
|
|
54
54
|
isNullable: false,
|
|
55
55
|
},
|
|
56
56
|
{
|
|
57
|
-
name: '
|
|
57
|
+
name: 'activateFrom',
|
|
58
58
|
type: 'timestamp',
|
|
59
59
|
isNullable: true,
|
|
60
60
|
},
|
|
61
61
|
{
|
|
62
|
-
name: '
|
|
62
|
+
name: 'activateTo',
|
|
63
63
|
type: 'timestamp',
|
|
64
64
|
isNullable: true,
|
|
65
65
|
},
|
|
66
66
|
{
|
|
67
|
-
name: '
|
|
67
|
+
name: 'createdAt',
|
|
68
68
|
type: 'timestamp',
|
|
69
69
|
default: 'CURRENT_TIMESTAMP',
|
|
70
70
|
isNullable: false,
|
|
71
71
|
},
|
|
72
72
|
{
|
|
73
|
-
name: '
|
|
73
|
+
name: 'updatedAt',
|
|
74
74
|
type: 'timestamp',
|
|
75
75
|
default: 'CURRENT_TIMESTAMP',
|
|
76
76
|
onUpdate: 'CURRENT_TIMESTAMP',
|
|
@@ -78,22 +78,22 @@ class CreatePagesTable1700000000000 {
|
|
|
78
78
|
},
|
|
79
79
|
],
|
|
80
80
|
}), true);
|
|
81
|
-
await queryRunner.createIndex('
|
|
82
|
-
name: '
|
|
81
|
+
await queryRunner.createIndex('page', new typeorm_1.TableIndex({
|
|
82
|
+
name: 'IDX_PAGE_STATUS',
|
|
83
83
|
columnNames: ['status'],
|
|
84
84
|
}));
|
|
85
|
-
await queryRunner.createIndex('
|
|
86
|
-
name: '
|
|
87
|
-
columnNames: ['
|
|
85
|
+
await queryRunner.createIndex('page', new typeorm_1.TableIndex({
|
|
86
|
+
name: 'IDX_PAGE_ACTIVATE_FROM',
|
|
87
|
+
columnNames: ['activateFrom'],
|
|
88
88
|
}));
|
|
89
|
-
await queryRunner.createIndex('
|
|
90
|
-
name: '
|
|
91
|
-
columnNames: ['
|
|
89
|
+
await queryRunner.createIndex('page', new typeorm_1.TableIndex({
|
|
90
|
+
name: 'IDX_PAGE_ACTIVATE_TO',
|
|
91
|
+
columnNames: ['activateTo'],
|
|
92
92
|
}));
|
|
93
93
|
}
|
|
94
94
|
async down(queryRunner) {
|
|
95
|
-
await queryRunner.dropTable('
|
|
95
|
+
await queryRunner.dropTable('page');
|
|
96
96
|
}
|
|
97
97
|
}
|
|
98
|
-
exports.
|
|
99
|
-
//# sourceMappingURL=
|
|
98
|
+
exports.CreatePagesTable1704067200000 = CreatePagesTable1704067200000;
|
|
99
|
+
//# sourceMappingURL=1704067200000-CreatePagesTable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1704067200000-CreatePagesTable.js","sourceRoot":"","sources":["../../src/migrations/1704067200000-CreatePagesTable.ts"],"names":[],"mappings":";;;AAAA,qCAA6E;AAE7E,MAAa,6BAA6B;IACjC,KAAK,CAAC,EAAE,CAAC,WAAwB;QACtC,MAAM,WAAW,CAAC,WAAW,CAC3B,IAAI,eAAK,CAAC;YACR,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE;gBACP;oBACE,IAAI,EAAE,IAAI;oBACV,IAAI,EAAE,KAAK;oBACX,SAAS,EAAE,IAAI;oBACf,WAAW,EAAE,IAAI;oBACjB,kBAAkB,EAAE,WAAW;iBAChC;gBACD;oBACE,IAAI,EAAE,OAAO;oBACb,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,KAAK;oBACX,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,SAAS;oBACf,IAAI,EAAE,MAAM;oBACZ,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,WAAW;oBACjB,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,cAAc;oBACpB,IAAI,EAAE,MAAM;oBACZ,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,iBAAiB;oBACvB,IAAI,EAAE,MAAM;oBACZ,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,KAAK;oBACX,OAAO,EAAE,CAAC;oBACV,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,cAAc;oBACpB,IAAI,EAAE,WAAW;oBACjB,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,YAAY;oBAClB,IAAI,EAAE,WAAW;oBACjB,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,WAAW;oBACjB,IAAI,EAAE,WAAW;oBACjB,OAAO,EAAE,mBAAmB;oBAC5B,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,WAAW;oBACjB,IAAI,EAAE,WAAW;oBACjB,OAAO,EAAE,mBAAmB;oBAC5B,QAAQ,EAAE,mBAAmB;oBAC7B,UAAU,EAAE,KAAK;iBAClB;aACF;SACF,CAAC,EACF,IAAI,CACL,CAAC;QAEF,MAAM,WAAW,CAAC,WAAW,CAC3B,MAAM,EACN,IAAI,oBAAU,CAAC;YACb,IAAI,EAAE,iBAAiB;YACvB,WAAW,EAAE,CAAC,QAAQ,CAAC;SACxB,CAAC,CACH,CAAC;QAEF,MAAM,WAAW,CAAC,WAAW,CAC3B,MAAM,EACN,IAAI,oBAAU,CAAC;YACb,IAAI,EAAE,wBAAwB;YAC9B,WAAW,EAAE,CAAC,cAAc,CAAC;SAC9B,CAAC,CACH,CAAC;QAEF,MAAM,WAAW,CAAC,WAAW,CAC3B,MAAM,EACN,IAAI,oBAAU,CAAC;YACb,IAAI,EAAE,sBAAsB;YAC5B,WAAW,EAAE,CAAC,YAAY,CAAC;SAC5B,CAAC,CACH,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,WAAwB;QACxC,MAAM,WAAW,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;CACF;AA5GD,sEA4GC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
+
export declare class AddUniqueConstraintToUrl1735689600000 implements MigrationInterface {
|
|
3
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
4
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=1735689600000-AddUniqueConstraintToUrl.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1735689600000-AddUniqueConstraintToUrl.d.ts","sourceRoot":"","sources":["../../src/migrations/1735689600000-AddUniqueConstraintToUrl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAc,MAAM,SAAS,CAAC;AAEtE,qBAAa,qCAAsC,YAAW,kBAAkB;IACjE,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAY3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAI3D"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AddUniqueConstraintToUrl1735689600000 = void 0;
|
|
4
|
+
const typeorm_1 = require("typeorm");
|
|
5
|
+
class AddUniqueConstraintToUrl1735689600000 {
|
|
6
|
+
async up(queryRunner) {
|
|
7
|
+
await queryRunner.createIndex('page', new typeorm_1.TableIndex({
|
|
8
|
+
name: 'UQ_PAGE_URL',
|
|
9
|
+
columnNames: ['url'],
|
|
10
|
+
isUnique: true,
|
|
11
|
+
}));
|
|
12
|
+
}
|
|
13
|
+
async down(queryRunner) {
|
|
14
|
+
await queryRunner.dropIndex('page', 'UQ_PAGE_URL');
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.AddUniqueConstraintToUrl1735689600000 = AddUniqueConstraintToUrl1735689600000;
|
|
18
|
+
//# sourceMappingURL=1735689600000-AddUniqueConstraintToUrl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1735689600000-AddUniqueConstraintToUrl.js","sourceRoot":"","sources":["../../src/migrations/1735689600000-AddUniqueConstraintToUrl.ts"],"names":[],"mappings":";;;AAAA,qCAAsE;AAEtE,MAAa,qCAAqC;IACzC,KAAK,CAAC,EAAE,CAAC,WAAwB;QAEtC,MAAM,WAAW,CAAC,WAAW,CAC3B,MAAM,EACN,IAAI,oBAAU,CAAC;YACb,IAAI,EAAE,aAAa;YACnB,WAAW,EAAE,CAAC,KAAK,CAAC;YACpB,QAAQ,EAAE,IAAI;SACf,CAAC,CACH,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,WAAwB;QAExC,MAAM,WAAW,CAAC,SAAS,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IACrD,CAAC;CACF;AAjBD,sFAiBC"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { Page } from '../entities/page.entity';
|
|
2
|
-
import {
|
|
2
|
+
import { CreatePagesTable1704067200000 } from './1704067200000-CreatePagesTable';
|
|
3
|
+
import { AddUniqueConstraintToUrl1735689600000 } from './1735689600000-AddUniqueConstraintToUrl';
|
|
3
4
|
export declare const PagesMigrationConfig: {
|
|
4
5
|
entities: (typeof Page)[];
|
|
5
|
-
migrations: (typeof
|
|
6
|
+
migrations: (typeof CreatePagesTable1704067200000)[];
|
|
6
7
|
migrationsTableName: string;
|
|
7
8
|
};
|
|
8
|
-
export {
|
|
9
|
+
export { CreatePagesTable1704067200000, AddUniqueConstraintToUrl1735689600000 };
|
|
9
10
|
export { Page };
|
|
10
11
|
//# sourceMappingURL=migration.config.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migration.config.d.ts","sourceRoot":"","sources":["../../src/migrations/migration.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,6BAA6B,EAAE,MAAM,kCAAkC,CAAC;
|
|
1
|
+
{"version":3,"file":"migration.config.d.ts","sourceRoot":"","sources":["../../src/migrations/migration.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,6BAA6B,EAAE,MAAM,kCAAkC,CAAC;AACjF,OAAO,EAAE,qCAAqC,EAAE,MAAM,0CAA0C,CAAC;AAMjG,eAAO,MAAM,oBAAoB;;;;CAIhC,CAAC;AAKF,OAAO,EAAE,6BAA6B,EAAE,qCAAqC,EAAE,CAAC;AAKhF,OAAO,EAAE,IAAI,EAAE,CAAC"}
|
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Page = exports.
|
|
3
|
+
exports.Page = exports.AddUniqueConstraintToUrl1735689600000 = exports.CreatePagesTable1704067200000 = exports.PagesMigrationConfig = void 0;
|
|
4
4
|
const page_entity_1 = require("../entities/page.entity");
|
|
5
5
|
Object.defineProperty(exports, "Page", { enumerable: true, get: function () { return page_entity_1.Page; } });
|
|
6
|
-
const
|
|
7
|
-
Object.defineProperty(exports, "
|
|
6
|
+
const _1704067200000_CreatePagesTable_1 = require("./1704067200000-CreatePagesTable");
|
|
7
|
+
Object.defineProperty(exports, "CreatePagesTable1704067200000", { enumerable: true, get: function () { return _1704067200000_CreatePagesTable_1.CreatePagesTable1704067200000; } });
|
|
8
|
+
const _1735689600000_AddUniqueConstraintToUrl_1 = require("./1735689600000-AddUniqueConstraintToUrl");
|
|
9
|
+
Object.defineProperty(exports, "AddUniqueConstraintToUrl1735689600000", { enumerable: true, get: function () { return _1735689600000_AddUniqueConstraintToUrl_1.AddUniqueConstraintToUrl1735689600000; } });
|
|
8
10
|
exports.PagesMigrationConfig = {
|
|
9
11
|
entities: [page_entity_1.Page],
|
|
10
|
-
migrations: [
|
|
12
|
+
migrations: [_1704067200000_CreatePagesTable_1.CreatePagesTable1704067200000, _1735689600000_AddUniqueConstraintToUrl_1.AddUniqueConstraintToUrl1735689600000],
|
|
11
13
|
migrationsTableName: 'migrations',
|
|
12
14
|
};
|
|
13
15
|
//# sourceMappingURL=migration.config.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migration.config.js","sourceRoot":"","sources":["../../src/migrations/migration.config.ts"],"names":[],"mappings":";;;AAAA,yDAA+C;
|
|
1
|
+
{"version":3,"file":"migration.config.js","sourceRoot":"","sources":["../../src/migrations/migration.config.ts"],"names":[],"mappings":";;;AAAA,yDAA+C;AAsBtC,qFAtBA,kBAAI,OAsBA;AArBb,sFAAiF;AAgBxE,8GAhBA,+DAA6B,OAgBA;AAftC,sGAAiG;AAezD,sHAf/B,+EAAqC,OAe+B;AAThE,QAAA,oBAAoB,GAAG;IAClC,QAAQ,EAAE,CAAC,kBAAI,CAAC;IAChB,UAAU,EAAE,CAAC,+DAA6B,EAAE,+EAAqC,CAAC;IAClF,mBAAmB,EAAE,YAAY;CAClC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.module.d.ts","sourceRoot":"","sources":["../src/pages.module.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pages.module.d.ts","sourceRoot":"","sources":["../src/pages.module.ts"],"names":[],"mappings":"AAUA,qBAaa,WAAW;CAAG"}
|
package/dist/pages.module.js
CHANGED
|
@@ -8,18 +8,29 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
9
|
exports.PagesModule = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
|
-
const
|
|
11
|
+
const nestjs_crud_module_1 = require("@uecsio/nestjs-crud-module");
|
|
12
12
|
const page_entity_1 = require("./entities/page.entity");
|
|
13
|
-
const
|
|
13
|
+
const create_page_dto_1 = require("./dto/create-page.dto");
|
|
14
|
+
const update_page_dto_1 = require("./dto/update-page.dto");
|
|
14
15
|
const pages_service_1 = require("./services/pages.service");
|
|
16
|
+
const page_url_service_1 = require("./services/page-url.service");
|
|
17
|
+
const page_url_subscriber_1 = require("./subscribers/page-url.subscriber");
|
|
18
|
+
const utils_api_1 = require("@uecsio/utils-api");
|
|
15
19
|
let PagesModule = class PagesModule {
|
|
16
20
|
};
|
|
17
21
|
exports.PagesModule = PagesModule;
|
|
18
22
|
exports.PagesModule = PagesModule = __decorate([
|
|
19
23
|
(0, common_1.Module)({
|
|
20
|
-
imports: [
|
|
21
|
-
|
|
22
|
-
|
|
24
|
+
imports: [
|
|
25
|
+
nestjs_crud_module_1.CrudModule.register({
|
|
26
|
+
entity: page_entity_1.Page,
|
|
27
|
+
path: 'pages',
|
|
28
|
+
createDto: create_page_dto_1.CreatePageDto,
|
|
29
|
+
updateDto: update_page_dto_1.UpdatePageDto,
|
|
30
|
+
service: pages_service_1.PagesService,
|
|
31
|
+
}),
|
|
32
|
+
],
|
|
33
|
+
providers: [page_url_service_1.PageUrlService, page_url_subscriber_1.PageUrlSubscriber, utils_api_1.UrlGeneratorService, utils_api_1.IsUniqueValueConstraint],
|
|
23
34
|
exports: [pages_service_1.PagesService],
|
|
24
35
|
})
|
|
25
36
|
], PagesModule);
|
package/dist/pages.module.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.module.js","sourceRoot":"","sources":["../src/pages.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,
|
|
1
|
+
{"version":3,"file":"pages.module.js","sourceRoot":"","sources":["../src/pages.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,mEAAwD;AACxD,wDAA8C;AAC9C,2DAAsD;AACtD,2DAAsD;AACtD,4DAAwD;AACxD,kEAA6D;AAC7D,2EAAsE;AACtE,iDAAiF;AAe1E,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IAbvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,+BAAU,CAAC,QAAQ,CAAC;gBAClB,MAAM,EAAE,kBAAI;gBACZ,IAAI,EAAE,OAAO;gBACb,SAAS,EAAE,+BAAa;gBACxB,SAAS,EAAE,+BAAa;gBACxB,OAAO,EAAE,4BAAY;aACtB,CAAC;SACH;QACD,SAAS,EAAE,CAAC,iCAAc,EAAE,uCAAiB,EAAE,+BAAmB,EAAE,mCAAuB,CAAC;QAC5F,OAAO,EAAE,CAAC,4BAAY,CAAC;KACxB,CAAC;GACW,WAAW,CAAG"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Page } from '../entities/page.entity';
|
|
2
|
+
import { PagesService } from './pages.service';
|
|
3
|
+
import { UrlGeneratorService } from '@uecsio/utils-api';
|
|
4
|
+
export declare class PageUrlService {
|
|
5
|
+
private readonly pagesService;
|
|
6
|
+
private readonly urlGenerator;
|
|
7
|
+
constructor(pagesService: PagesService, urlGenerator: UrlGeneratorService);
|
|
8
|
+
ensureUrl(entity: Page | null | undefined): Promise<void>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=page-url.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-url.service.d.ts","sourceRoot":"","sources":["../../src/services/page-url.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAsB,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAK5E,qBACa,cAAc;IAEvB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,YAAY;gBADZ,YAAY,EAAE,YAAY,EAC1B,YAAY,EAAE,mBAAmB;IAG9C,SAAS,CAAC,MAAM,EAAE,IAAI,GAAG,IAAI,GAAG,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;CAehE"}
|
|
@@ -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.PageUrlService = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const pages_service_1 = require("./pages.service");
|
|
15
|
+
const utils_api_1 = require("@uecsio/utils-api");
|
|
16
|
+
const hasTitle = (entity) => !!entity && typeof entity === 'object' && 'title' in entity && typeof entity.title === 'string';
|
|
17
|
+
let PageUrlService = class PageUrlService {
|
|
18
|
+
constructor(pagesService, urlGenerator) {
|
|
19
|
+
this.pagesService = pagesService;
|
|
20
|
+
this.urlGenerator = urlGenerator;
|
|
21
|
+
}
|
|
22
|
+
async ensureUrl(entity) {
|
|
23
|
+
if (!entity || !hasTitle(entity) || entity.url) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const repository = this.pagesService.getRepository();
|
|
27
|
+
entity.url = await this.urlGenerator.generateUrl('url', entity.title, repository, {
|
|
28
|
+
excludeId: entity.id,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
exports.PageUrlService = PageUrlService;
|
|
33
|
+
exports.PageUrlService = PageUrlService = __decorate([
|
|
34
|
+
(0, common_1.Injectable)(),
|
|
35
|
+
__metadata("design:paramtypes", [pages_service_1.PagesService,
|
|
36
|
+
utils_api_1.UrlGeneratorService])
|
|
37
|
+
], PageUrlService);
|
|
38
|
+
//# sourceMappingURL=page-url.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-url.service.js","sourceRoot":"","sources":["../../src/services/page-url.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAE5C,mDAA+C;AAC/C,iDAA4E;AAE5E,MAAM,QAAQ,GAAG,CAAC,MAAe,EAAkB,EAAE,CACnD,CAAC,CAAC,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,OAAO,IAAI,MAAM,IAAI,OAAQ,MAAe,CAAC,KAAK,KAAK,QAAQ,CAAC;AAGrG,IAAM,cAAc,GAApB,MAAM,cAAc;IACzB,YACmB,YAA0B,EAC1B,YAAiC;QADjC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,iBAAY,GAAZ,YAAY,CAAqB;IACjD,CAAC;IAEJ,KAAK,CAAC,SAAS,CAAC,MAA+B;QAC7C,IAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,GAAG,EAAE,CAAC;YAC/C,OAAO;QACT,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC;QACrD,MAAM,CAAC,GAAG,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,WAAW,CAC9C,KAAK,EACL,MAAM,CAAC,KAAK,EACZ,UAAsC,EACtC;YACE,SAAS,EAAE,MAAM,CAAC,EAAE;SACrB,CACF,CAAC;IACJ,CAAC;CACF,CAAA;AArBY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAGsB,4BAAY;QACZ,+BAAmB;GAHzC,cAAc,CAqB1B"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { CrudService } from '@nestjs-library/crud';
|
|
2
1
|
import { Repository } from 'typeorm';
|
|
2
|
+
import { BaseTypeOrmCrudService } from '@uecsio/utils-api';
|
|
3
3
|
import { Page } from '../entities/page.entity';
|
|
4
|
-
export declare class PagesService extends
|
|
5
|
-
constructor(
|
|
4
|
+
export declare class PagesService extends BaseTypeOrmCrudService<Page> {
|
|
5
|
+
constructor(repo: Repository<Page>);
|
|
6
6
|
}
|
|
7
7
|
//# sourceMappingURL=pages.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.service.d.ts","sourceRoot":"","sources":["../../src/services/pages.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"pages.service.d.ts","sourceRoot":"","sources":["../../src/services/pages.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBACa,YAAa,SAAQ,sBAAsB,CAAC,IAAI,CAAC;gBACxB,IAAI,EAAE,UAAU,CAAC,IAAI,CAAC;CAG3D"}
|
|
@@ -15,12 +15,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
15
15
|
exports.PagesService = void 0;
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
18
|
-
const crud_1 = require("@nestjs-library/crud");
|
|
19
18
|
const typeorm_2 = require("typeorm");
|
|
19
|
+
const utils_api_1 = require("@uecsio/utils-api");
|
|
20
20
|
const page_entity_1 = require("../entities/page.entity");
|
|
21
|
-
let PagesService = class PagesService extends
|
|
22
|
-
constructor(
|
|
23
|
-
super(
|
|
21
|
+
let PagesService = class PagesService extends utils_api_1.BaseTypeOrmCrudService {
|
|
22
|
+
constructor(repo) {
|
|
23
|
+
super(repo);
|
|
24
24
|
}
|
|
25
25
|
};
|
|
26
26
|
exports.PagesService = PagesService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pages.service.js","sourceRoot":"","sources":["../../src/services/pages.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAmD;AACnD
|
|
1
|
+
{"version":3,"file":"pages.service.js","sourceRoot":"","sources":["../../src/services/pages.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAmD;AACnD,qCAAqC;AACrC,iDAA2D;AAC3D,yDAA+C;AAGxC,IAAM,YAAY,GAAlB,MAAM,YAAa,SAAQ,kCAA4B;IAC5D,YAAoC,IAAsB;QACxD,KAAK,CAAC,IAAI,CAAC,CAAC;IACd,CAAC;CACF,CAAA;AAJY,oCAAY;uBAAZ,YAAY;IADxB,IAAA,mBAAU,GAAE;IAEE,WAAA,IAAA,0BAAgB,EAAC,kBAAI,CAAC,CAAA;qCAAO,oBAAU;GADzC,YAAY,CAIxB"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { DataSource, EntitySubscriberInterface, InsertEvent, UpdateEvent } from 'typeorm';
|
|
2
|
+
import { Page } from '../entities/page.entity';
|
|
3
|
+
import { PageUrlService } from '../services/page-url.service';
|
|
4
|
+
export declare class PageUrlSubscriber implements EntitySubscriberInterface<Page> {
|
|
5
|
+
private readonly dataSource;
|
|
6
|
+
private readonly pageUrlService;
|
|
7
|
+
constructor(dataSource: DataSource, pageUrlService: PageUrlService);
|
|
8
|
+
listenTo: () => typeof Page;
|
|
9
|
+
beforeInsert(event: InsertEvent<Page>): Promise<void>;
|
|
10
|
+
beforeUpdate(event: UpdateEvent<Page>): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=page-url.subscriber.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-url.subscriber.d.ts","sourceRoot":"","sources":["../../src/subscribers/page-url.subscriber.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,UAAU,EACV,yBAAyB,EAEzB,WAAW,EACX,WAAW,EACZ,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAE9D,qBAEa,iBAAkB,YAAW,yBAAyB,CAAC,IAAI,CAAC;IAEjD,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC/C,OAAO,CAAC,QAAQ,CAAC,cAAc;gBADM,UAAU,EAAE,UAAU,EAC1C,cAAc,EAAE,cAAc;IAKjD,QAAQ,oBAAc;IAEhB,YAAY,CAAC,KAAK,EAAE,WAAW,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAKrD,YAAY,CAAC,KAAK,EAAE,WAAW,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;CAG5D"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PageUrlSubscriber = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
18
|
+
const typeorm_2 = require("typeorm");
|
|
19
|
+
const page_entity_1 = require("../entities/page.entity");
|
|
20
|
+
const page_url_service_1 = require("../services/page-url.service");
|
|
21
|
+
let PageUrlSubscriber = class PageUrlSubscriber {
|
|
22
|
+
constructor(dataSource, pageUrlService) {
|
|
23
|
+
this.dataSource = dataSource;
|
|
24
|
+
this.pageUrlService = pageUrlService;
|
|
25
|
+
this.listenTo = () => page_entity_1.Page;
|
|
26
|
+
this.dataSource.subscribers.push(this);
|
|
27
|
+
}
|
|
28
|
+
async beforeInsert(event) {
|
|
29
|
+
console.log('beforeInsert', event.entity);
|
|
30
|
+
await this.pageUrlService.ensureUrl(event.entity);
|
|
31
|
+
}
|
|
32
|
+
async beforeUpdate(event) {
|
|
33
|
+
await this.pageUrlService.ensureUrl(event.entity);
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.PageUrlSubscriber = PageUrlSubscriber;
|
|
37
|
+
exports.PageUrlSubscriber = PageUrlSubscriber = __decorate([
|
|
38
|
+
(0, common_1.Injectable)(),
|
|
39
|
+
(0, typeorm_2.EventSubscriber)(),
|
|
40
|
+
__param(0, (0, typeorm_1.InjectDataSource)()),
|
|
41
|
+
__metadata("design:paramtypes", [typeorm_2.DataSource,
|
|
42
|
+
page_url_service_1.PageUrlService])
|
|
43
|
+
], PageUrlSubscriber);
|
|
44
|
+
//# sourceMappingURL=page-url.subscriber.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"page-url.subscriber.js","sourceRoot":"","sources":["../../src/subscribers/page-url.subscriber.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAmD;AACnD,qCAMiB;AACjB,yDAA+C;AAC/C,mEAA8D;AAIvD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC5B,YACsB,UAAuC,EAC1C,cAA8B;QADV,eAAU,GAAV,UAAU,CAAY;QAC1C,mBAAc,GAAd,cAAc,CAAgB;QAKjD,aAAQ,GAAG,GAAG,EAAE,CAAC,kBAAI,CAAC;QAHpB,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;IAID,KAAK,CAAC,YAAY,CAAC,KAAwB;QACzC,OAAO,CAAC,GAAG,CAAC,cAAc,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QAC1C,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,KAAK,CAAC,MAAc,CAAC,CAAC;IAC5D,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,KAAwB;QACzC,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,KAAK,CAAC,MAAc,CAAC,CAAC;IAC5D,CAAC;CACF,CAAA;AAlBY,8CAAiB;4BAAjB,iBAAiB;IAF7B,IAAA,mBAAU,GAAE;IACZ,IAAA,yBAAe,GAAE;IAGb,WAAA,IAAA,0BAAgB,GAAE,CAAA;qCAA8B,oBAAU;QAC1B,iCAAc;GAHtC,iBAAiB,CAkB7B"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
import { TestingModule } from '@nestjs/testing';
|
|
2
2
|
import { Repository } from 'typeorm';
|
|
3
|
-
import { PagesController } from '../controllers/pages.controller';
|
|
4
3
|
import { PagesService } from '../services/pages.service';
|
|
5
4
|
import { Page } from '../entities/page.entity';
|
|
6
5
|
export interface TestContext {
|
|
7
6
|
module: TestingModule;
|
|
8
|
-
controller: PagesController;
|
|
9
7
|
service: PagesService;
|
|
10
8
|
repository: Repository<Page>;
|
|
11
9
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.test.config.d.ts","sourceRoot":"","sources":["../../src/tests/pages.test.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEtD,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,aAAa,CAAC;IACtB,OAAO,EAAE,YAAY,CAAC;IACtB,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;CAC9B;AAED,eAAO,MAAM,gBAAgB,QAAa,OAAO,CAAC,WAAW,CAgC5D,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,IAatB,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;;;;;;;;CAU7B,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;CAG7B,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,YAAY,UAAU,CAAC,IAAI,CAAC,SAOhE,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,YAAY,UAAU,CAAC,IAAI,CAAC,SAEhE,CAAC"}
|
|
@@ -4,7 +4,6 @@ exports.clearRepositoryMocks = exports.setupRepositoryMocks = exports.mockUpdate
|
|
|
4
4
|
const testing_1 = require("@nestjs/testing");
|
|
5
5
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
6
6
|
const pages_module_1 = require("../pages.module");
|
|
7
|
-
const pages_controller_1 = require("../controllers/pages.controller");
|
|
8
7
|
const pages_service_1 = require("../services/pages.service");
|
|
9
8
|
const page_entity_1 = require("../entities/page.entity");
|
|
10
9
|
const createTestModule = async () => {
|
|
@@ -30,12 +29,10 @@ const createTestModule = async () => {
|
|
|
30
29
|
})),
|
|
31
30
|
})
|
|
32
31
|
.compile();
|
|
33
|
-
const controller = module.get(pages_controller_1.PagesController);
|
|
34
32
|
const service = module.get(pages_service_1.PagesService);
|
|
35
33
|
const repository = module.get((0, typeorm_1.getRepositoryToken)(page_entity_1.Page));
|
|
36
34
|
return {
|
|
37
35
|
module,
|
|
38
|
-
controller,
|
|
39
36
|
service,
|
|
40
37
|
repository,
|
|
41
38
|
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.test.config.js","sourceRoot":"","sources":["../../src/tests/pages.test.config.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ValidatorConstraintInterface, ValidationArguments } from 'class-validator';
|
|
2
|
+
import { Repository } from 'typeorm';
|
|
3
|
+
import { Page } from '../entities/page.entity';
|
|
4
|
+
export declare class IsUniqueUrlConstraint implements ValidatorConstraintInterface {
|
|
5
|
+
private readonly pageRepository;
|
|
6
|
+
constructor(pageRepository: Repository<Page>);
|
|
7
|
+
validate(url: string, args: ValidationArguments): Promise<boolean>;
|
|
8
|
+
defaultMessage(args: ValidationArguments): string;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=is-unique-url.constraint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-unique-url.constraint.d.ts","sourceRoot":"","sources":["../../src/validators/is-unique-url.constraint.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,4BAA4B,EAC5B,mBAAmB,EACpB,MAAM,iBAAiB,CAAC;AAGzB,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,qBAEa,qBAAsB,YAAW,4BAA4B;IAGtE,OAAO,CAAC,QAAQ,CAAC,cAAc;gBAAd,cAAc,EAAE,UAAU,CAAC,IAAI,CAAC;IAG7C,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,OAAO,CAAC;IA0BxE,cAAc,CAAC,IAAI,EAAE,mBAAmB,GAAG,MAAM;CAGlD"}
|
|
@@ -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
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.IsUniqueUrlConstraint = void 0;
|
|
16
|
+
const class_validator_1 = require("class-validator");
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
19
|
+
const typeorm_2 = require("typeorm");
|
|
20
|
+
const page_entity_1 = require("../entities/page.entity");
|
|
21
|
+
let IsUniqueUrlConstraint = class IsUniqueUrlConstraint {
|
|
22
|
+
constructor(pageRepository) {
|
|
23
|
+
this.pageRepository = pageRepository;
|
|
24
|
+
}
|
|
25
|
+
async validate(url, args) {
|
|
26
|
+
if (!url || typeof url !== 'string') {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
const object = args.object;
|
|
30
|
+
const excludeId = object.id || object['id'];
|
|
31
|
+
const queryBuilder = this.pageRepository
|
|
32
|
+
.createQueryBuilder('page')
|
|
33
|
+
.where('page.url = :url', { url });
|
|
34
|
+
if (excludeId) {
|
|
35
|
+
queryBuilder.andWhere('page.id != :id', { id: excludeId });
|
|
36
|
+
}
|
|
37
|
+
const existingPage = await queryBuilder.getOne();
|
|
38
|
+
return !existingPage;
|
|
39
|
+
}
|
|
40
|
+
defaultMessage(args) {
|
|
41
|
+
return 'A page with this URL already exists';
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
exports.IsUniqueUrlConstraint = IsUniqueUrlConstraint;
|
|
45
|
+
exports.IsUniqueUrlConstraint = IsUniqueUrlConstraint = __decorate([
|
|
46
|
+
(0, class_validator_1.ValidatorConstraint)({ name: 'isUniqueUrl', async: true }),
|
|
47
|
+
(0, common_1.Injectable)(),
|
|
48
|
+
__param(0, (0, typeorm_1.InjectRepository)(page_entity_1.Page)),
|
|
49
|
+
__metadata("design:paramtypes", [typeorm_2.Repository])
|
|
50
|
+
], IsUniqueUrlConstraint);
|
|
51
|
+
//# sourceMappingURL=is-unique-url.constraint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-unique-url.constraint.js","sourceRoot":"","sources":["../../src/validators/is-unique-url.constraint.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,qDAIyB;AACzB,2CAA4C;AAC5C,6CAAmD;AACnD,qCAAqC;AACrC,yDAA+C;AAIxC,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAChC,YAEmB,cAAgC;QAAhC,mBAAc,GAAd,cAAc,CAAkB;IAChD,CAAC;IAEJ,KAAK,CAAC,QAAQ,CAAC,GAAW,EAAE,IAAyB;QAGnD,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;YACpC,OAAO,IAAI,CAAC;QACd,CAAC;QAGD,MAAM,MAAM,GAAG,IAAI,CAAC,MAAa,CAAC;QAGlC,MAAM,SAAS,GAAG,MAAM,CAAC,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;QAE5C,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc;aACrC,kBAAkB,CAAC,MAAM,CAAC;aAC1B,KAAK,CAAC,iBAAiB,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC;QAErC,IAAI,SAAS,EAAE,CAAC;YACd,YAAY,CAAC,QAAQ,CAAC,gBAAgB,EAAE,EAAE,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;QAC7D,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,YAAY,CAAC,MAAM,EAAE,CAAC;QAEjD,OAAO,CAAC,YAAY,CAAC;IACvB,CAAC;IAED,cAAc,CAAC,IAAyB;QACtC,OAAO,qCAAqC,CAAC;IAC/C,CAAC;CACF,CAAA;AAnCY,sDAAqB;gCAArB,qBAAqB;IAFjC,IAAA,qCAAmB,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IACzD,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,0BAAgB,EAAC,kBAAI,CAAC,CAAA;qCACU,oBAAU;GAHlC,qBAAqB,CAmCjC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-unique-url.validator.d.ts","sourceRoot":"","sources":["../../src/validators/is-unique-url.validator.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EAElB,MAAM,iBAAiB,CAAC;AAwBzB,wBAAgB,WAAW,CAAC,iBAAiB,CAAC,EAAE,iBAAiB,IAC9C,QAAQ,MAAM,EAAE,cAAc,MAAM,UAUtD"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IsUniqueUrl = IsUniqueUrl;
|
|
4
|
+
const class_validator_1 = require("class-validator");
|
|
5
|
+
const is_unique_url_constraint_1 = require("./is-unique-url.constraint");
|
|
6
|
+
function IsUniqueUrl(validationOptions) {
|
|
7
|
+
return function (object, propertyName) {
|
|
8
|
+
(0, class_validator_1.registerDecorator)({
|
|
9
|
+
name: 'isUniqueUrl',
|
|
10
|
+
target: object.constructor,
|
|
11
|
+
propertyName: propertyName,
|
|
12
|
+
options: validationOptions,
|
|
13
|
+
constraints: [],
|
|
14
|
+
validator: is_unique_url_constraint_1.IsUniqueUrlConstraint,
|
|
15
|
+
});
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=is-unique-url.validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-unique-url.validator.js","sourceRoot":"","sources":["../../src/validators/is-unique-url.validator.ts"],"names":[],"mappings":";;AA4BA,kCAWC;AAvCD,qDAIyB;AACzB,yEAAmE;AAuBnE,SAAgB,WAAW,CAAC,iBAAqC;IAC/D,OAAO,UAAU,MAAc,EAAE,YAAoB;QACnD,IAAA,mCAAiB,EAAC;YAChB,IAAI,EAAE,aAAa;YACnB,MAAM,EAAE,MAAM,CAAC,WAAW;YAC1B,YAAY,EAAE,YAAY;YAC1B,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,EAAE;YACf,SAAS,EAAE,gDAAqB;SACjC,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@uecsio/pages-api",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "2.1.0",
|
|
4
4
|
"description": "A reusable NestJS API Pages module for content management",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"nestjs",
|
|
@@ -35,11 +35,15 @@
|
|
|
35
35
|
"typeorm": "^0.3.0",
|
|
36
36
|
"class-validator": "^0.14.0",
|
|
37
37
|
"class-transformer": "^0.5.1",
|
|
38
|
-
"@
|
|
38
|
+
"@dataui/crud": "^5.3.4",
|
|
39
|
+
"@dataui/crud-typeorm": "^5.3.4",
|
|
40
|
+
"@uecsio/nestjs-crud-module": "^1.0.0",
|
|
41
|
+
"@uecsio/utils-api": "^0.0.2"
|
|
39
42
|
},
|
|
40
43
|
"devDependencies": {
|
|
41
44
|
"@nestjs/common": "^11.0.0",
|
|
42
45
|
"@nestjs/core": "^11.0.0",
|
|
46
|
+
"@nestjs/swagger": "^11.2.0",
|
|
43
47
|
"@nestjs/testing": "^11.0.0",
|
|
44
48
|
"@nestjs/typeorm": "^11.0.0",
|
|
45
49
|
"@types/jest": "^30.0.0",
|
|
@@ -50,8 +54,11 @@
|
|
|
50
54
|
"typeorm": "^0.3.26",
|
|
51
55
|
"class-validator": "^0.14.2",
|
|
52
56
|
"class-transformer": "^0.5.1",
|
|
53
|
-
"@
|
|
54
|
-
"
|
|
57
|
+
"@dataui/crud": "^5.3.4",
|
|
58
|
+
"@dataui/crud-typeorm": "^5.3.4",
|
|
59
|
+
"@uecsio/nestjs-crud-module": "^1.0.0",
|
|
60
|
+
"rimraf": "^5.0.0",
|
|
61
|
+
"@uecsio/utils-api": "^0.0.2"
|
|
55
62
|
},
|
|
56
63
|
"jest": {
|
|
57
64
|
"moduleFileExtensions": [
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { CrudController } from '@nestjs-library/crud';
|
|
2
|
-
import { Page } from '../entities/page.entity';
|
|
3
|
-
import { PagesService } from '../services/pages.service';
|
|
4
|
-
export declare class PagesController implements CrudController<Page> {
|
|
5
|
-
readonly crudService: PagesService;
|
|
6
|
-
constructor(crudService: PagesService);
|
|
7
|
-
}
|
|
8
|
-
//# sourceMappingURL=pages.controller.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pages.controller.d.ts","sourceRoot":"","sources":["../../src/controllers/pages.controller.ts"],"names":[],"mappings":"AACA,OAAO,EAAQ,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE5D,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAIzD,qBAmBa,eAAgB,YAAW,cAAc,CAAC,IAAI,CAAC;aAC9B,WAAW,EAAE,YAAY;gBAAzB,WAAW,EAAE,YAAY;CACtD"}
|
|
@@ -1,48 +0,0 @@
|
|
|
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.PagesController = void 0;
|
|
13
|
-
const common_1 = require("@nestjs/common");
|
|
14
|
-
const crud_1 = require("@nestjs-library/crud");
|
|
15
|
-
const swagger_1 = require("@nestjs/swagger");
|
|
16
|
-
const page_entity_1 = require("../entities/page.entity");
|
|
17
|
-
const pages_service_1 = require("../services/pages.service");
|
|
18
|
-
const create_page_dto_1 = require("../dto/create-page.dto");
|
|
19
|
-
const update_page_dto_1 = require("../dto/update-page.dto");
|
|
20
|
-
let PagesController = class PagesController {
|
|
21
|
-
constructor(crudService) {
|
|
22
|
-
this.crudService = crudService;
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
exports.PagesController = PagesController;
|
|
26
|
-
exports.PagesController = PagesController = __decorate([
|
|
27
|
-
(0, swagger_1.ApiTags)('pages'),
|
|
28
|
-
(0, crud_1.Crud)({
|
|
29
|
-
entity: page_entity_1.Page,
|
|
30
|
-
routes: {
|
|
31
|
-
create: {
|
|
32
|
-
swagger: {
|
|
33
|
-
body: create_page_dto_1.CreatePageDto,
|
|
34
|
-
response: page_entity_1.Page,
|
|
35
|
-
},
|
|
36
|
-
},
|
|
37
|
-
update: {
|
|
38
|
-
swagger: {
|
|
39
|
-
body: update_page_dto_1.UpdatePageDto,
|
|
40
|
-
response: page_entity_1.Page,
|
|
41
|
-
},
|
|
42
|
-
},
|
|
43
|
-
},
|
|
44
|
-
}),
|
|
45
|
-
(0, common_1.Controller)('pages'),
|
|
46
|
-
__metadata("design:paramtypes", [pages_service_1.PagesService])
|
|
47
|
-
], PagesController);
|
|
48
|
-
//# sourceMappingURL=pages.controller.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pages.controller.js","sourceRoot":"","sources":["../../src/controllers/pages.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,+CAA4D;AAC5D,6CAA0C;AAC1C,yDAA+C;AAC/C,6DAAyD;AACzD,4DAAuD;AACvD,4DAAuD;AAqBhD,IAAM,eAAe,GAArB,MAAM,eAAe;IAC1B,YAA4B,WAAyB;QAAzB,gBAAW,GAAX,WAAW,CAAc;IAAG,CAAC;CAC1D,CAAA;AAFY,0CAAe;0BAAf,eAAe;IAnB3B,IAAA,iBAAO,EAAC,OAAO,CAAC;IAChB,IAAA,WAAI,EAAC;QACJ,MAAM,EAAE,kBAAI;QACZ,MAAM,EAAE;YACN,MAAM,EAAE;gBACN,OAAO,EAAE;oBACP,IAAI,EAAE,+BAAa;oBACnB,QAAQ,EAAE,kBAAI;iBACf;aACF;YACD,MAAM,EAAE;gBACN,OAAO,EAAE;oBACP,IAAI,EAAE,+BAAa;oBACnB,QAAQ,EAAE,kBAAI;iBACf;aACF;SACF;KACF,CAAC;IACD,IAAA,mBAAU,EAAC,OAAO,CAAC;qCAEuB,4BAAY;GAD1C,eAAe,CAE3B"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"1700000000000-CreatePagesTable.js","sourceRoot":"","sources":["../../src/migrations/1700000000000-CreatePagesTable.ts"],"names":[],"mappings":";;;AAAA,qCAA6E;AAE7E,MAAa,6BAA6B;IACjC,KAAK,CAAC,EAAE,CAAC,WAAwB;QACtC,MAAM,WAAW,CAAC,WAAW,CAC3B,IAAI,eAAK,CAAC;YACR,IAAI,EAAE,OAAO;YACb,OAAO,EAAE;gBACP;oBACE,IAAI,EAAE,IAAI;oBACV,IAAI,EAAE,KAAK;oBACX,SAAS,EAAE,IAAI;oBACf,WAAW,EAAE,IAAI;oBACjB,kBAAkB,EAAE,WAAW;iBAChC;gBACD;oBACE,IAAI,EAAE,OAAO;oBACb,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,KAAK;oBACX,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,SAAS;oBACf,IAAI,EAAE,MAAM;oBACZ,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,YAAY;oBAClB,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,KAAK;oBACb,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,eAAe;oBACrB,IAAI,EAAE,MAAM;oBACZ,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,kBAAkB;oBACxB,IAAI,EAAE,MAAM;oBACZ,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,KAAK;oBACX,OAAO,EAAE,CAAC;oBACV,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,eAAe;oBACrB,IAAI,EAAE,WAAW;oBACjB,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,aAAa;oBACnB,IAAI,EAAE,WAAW;oBACjB,UAAU,EAAE,IAAI;iBACjB;gBACD;oBACE,IAAI,EAAE,YAAY;oBAClB,IAAI,EAAE,WAAW;oBACjB,OAAO,EAAE,mBAAmB;oBAC5B,UAAU,EAAE,KAAK;iBAClB;gBACD;oBACE,IAAI,EAAE,YAAY;oBAClB,IAAI,EAAE,WAAW;oBACjB,OAAO,EAAE,mBAAmB;oBAC5B,QAAQ,EAAE,mBAAmB;oBAC7B,UAAU,EAAE,KAAK;iBAClB;aACF;SACF,CAAC,EACF,IAAI,CACL,CAAC;QAEF,MAAM,WAAW,CAAC,WAAW,CAC3B,OAAO,EACP,IAAI,oBAAU,CAAC;YACb,IAAI,EAAE,kBAAkB;YACxB,WAAW,EAAE,CAAC,QAAQ,CAAC;SACxB,CAAC,CACH,CAAC;QAEF,MAAM,WAAW,CAAC,WAAW,CAC3B,OAAO,EACP,IAAI,oBAAU,CAAC;YACb,IAAI,EAAE,yBAAyB;YAC/B,WAAW,EAAE,CAAC,eAAe,CAAC;SAC/B,CAAC,CACH,CAAC;QAEF,MAAM,WAAW,CAAC,WAAW,CAC3B,OAAO,EACP,IAAI,oBAAU,CAAC;YACb,IAAI,EAAE,uBAAuB;YAC7B,WAAW,EAAE,CAAC,aAAa,CAAC;SAC7B,CAAC,CACH,CAAC;IACJ,CAAC;IAEM,KAAK,CAAC,IAAI,CAAC,WAAwB;QACxC,MAAM,WAAW,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;CACF;AA5GD,sEA4GC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pages.test.config.d.ts","sourceRoot":"","sources":["../../src/specs/pages.test.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEtD,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAE/C,MAAM,WAAW,WAAW;IAC1B,MAAM,EAAE,aAAa,CAAC;IACtB,UAAU,EAAE,eAAe,CAAC;IAC5B,OAAO,EAAE,YAAY,CAAC;IACtB,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;CAC9B;AAED,eAAO,MAAM,gBAAgB,QAAa,OAAO,CAAC,WAAW,CAkC5D,CAAC;AAEF,eAAO,MAAM,QAAQ,EAAE,IAatB,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;;;;;;;;CAU7B,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;CAG7B,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,YAAY,UAAU,CAAC,IAAI,CAAC,SAOhE,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,YAAY,UAAU,CAAC,IAAI,CAAC,SAEhE,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pages.test.config.js","sourceRoot":"","sources":["../../src/specs/pages.test.config.ts"],"names":[],"mappings":"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"}
|