@uecsio/pages-api 1.2.3 → 2.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/README.md +107 -2
- package/dist/pages-nestjs/src/controllers/pages.controller.d.ts +8 -0
- package/dist/pages-nestjs/src/controllers/pages.controller.d.ts.map +1 -0
- package/dist/{controllers → pages-nestjs/src/controllers}/pages.controller.js +11 -18
- package/dist/pages-nestjs/src/controllers/pages.controller.js.map +1 -0
- package/dist/{dto → pages-nestjs/src/dto}/create-page.dto.d.ts +2 -2
- package/dist/pages-nestjs/src/dto/create-page.dto.d.ts.map +1 -0
- package/dist/{dto → pages-nestjs/src/dto}/create-page.dto.js +13 -6
- package/dist/pages-nestjs/src/dto/create-page.dto.js.map +1 -0
- package/dist/pages-nestjs/src/dto/update-page.dto.d.ts +12 -0
- package/dist/pages-nestjs/src/dto/update-page.dto.d.ts.map +1 -0
- package/dist/pages-nestjs/src/dto/update-page.dto.js +113 -0
- package/dist/pages-nestjs/src/dto/update-page.dto.js.map +1 -0
- package/dist/pages-nestjs/src/entities/page.entity.d.ts.map +1 -0
- package/dist/{entities → pages-nestjs/src/entities}/page.entity.js +2 -2
- package/dist/pages-nestjs/src/entities/page.entity.js.map +1 -0
- package/dist/{index.d.ts → pages-nestjs/src/index.d.ts} +2 -0
- package/dist/pages-nestjs/src/index.d.ts.map +1 -0
- package/dist/{index.js → pages-nestjs/src/index.js} +2 -0
- package/dist/pages-nestjs/src/index.js.map +1 -0
- package/dist/pages-nestjs/src/migrations/1704067200000-CreatePagesTable.d.ts +6 -0
- package/dist/pages-nestjs/src/migrations/1704067200000-CreatePagesTable.d.ts.map +1 -0
- package/dist/pages-nestjs/src/migrations/1704067200000-CreatePagesTable.js +99 -0
- package/dist/pages-nestjs/src/migrations/1704067200000-CreatePagesTable.js.map +1 -0
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.d.ts +6 -0
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.d.ts.map +1 -0
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.js +18 -0
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.js.map +1 -0
- package/dist/pages-nestjs/src/migrations/migration.config.d.ts +11 -0
- package/dist/pages-nestjs/src/migrations/migration.config.d.ts.map +1 -0
- package/dist/pages-nestjs/src/migrations/migration.config.js +15 -0
- package/dist/pages-nestjs/src/migrations/migration.config.js.map +1 -0
- package/dist/pages-nestjs/src/pages.module.d.ts.map +1 -0
- package/dist/{pages.module.js → pages-nestjs/src/pages.module.js} +4 -1
- package/dist/pages-nestjs/src/pages.module.js.map +1 -0
- package/dist/pages-nestjs/src/services/page-url.service.d.ts +10 -0
- package/dist/pages-nestjs/src/services/page-url.service.d.ts.map +1 -0
- package/dist/pages-nestjs/src/services/page-url.service.js +38 -0
- package/dist/pages-nestjs/src/services/page-url.service.js.map +1 -0
- package/dist/pages-nestjs/src/services/pages.service.d.ts +7 -0
- package/dist/pages-nestjs/src/services/pages.service.d.ts.map +1 -0
- package/dist/{services → pages-nestjs/src/services}/pages.service.js +4 -4
- package/dist/pages-nestjs/src/services/pages.service.js.map +1 -0
- package/dist/pages-nestjs/src/specs/pages.test.config.d.ts.map +1 -0
- package/dist/pages-nestjs/src/specs/pages.test.config.js.map +1 -0
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.d.ts +12 -0
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.d.ts.map +1 -0
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.js +44 -0
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.js.map +1 -0
- package/dist/pages-nestjs/src/tests/pages.test.config.d.ts +31 -0
- package/dist/pages-nestjs/src/tests/pages.test.config.d.ts.map +1 -0
- package/dist/pages-nestjs/src/tests/pages.test.config.js +86 -0
- package/dist/pages-nestjs/src/tests/pages.test.config.js.map +1 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.d.ts +10 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.d.ts.map +1 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.js +51 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.js.map +1 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.d.ts +3 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.d.ts.map +1 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.js +18 -0
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.js.map +1 -0
- package/dist/utils/src/index.d.ts +7 -0
- package/dist/utils/src/index.d.ts.map +1 -0
- package/dist/utils/src/index.js +27 -0
- package/dist/utils/src/index.js.map +1 -0
- package/dist/utils/src/services/base-typeorm-crud.service.d.ts +6 -0
- package/dist/utils/src/services/base-typeorm-crud.service.d.ts.map +1 -0
- package/dist/utils/src/services/base-typeorm-crud.service.js +21 -0
- package/dist/utils/src/services/base-typeorm-crud.service.js.map +1 -0
- package/dist/utils/src/services/url-generator.service.d.ts +14 -0
- package/dist/utils/src/services/url-generator.service.d.ts.map +1 -0
- package/dist/utils/src/services/url-generator.service.js +66 -0
- package/dist/utils/src/services/url-generator.service.js.map +1 -0
- package/dist/utils/src/validators/is-unique-value.constraint.d.ts +14 -0
- package/dist/utils/src/validators/is-unique-value.constraint.d.ts.map +1 -0
- package/dist/utils/src/validators/is-unique-value.constraint.js +60 -0
- package/dist/utils/src/validators/is-unique-value.constraint.js.map +1 -0
- package/dist/utils/src/validators/is-unique-value.validator.d.ts +4 -0
- package/dist/utils/src/validators/is-unique-value.validator.d.ts.map +1 -0
- package/dist/utils/src/validators/is-unique-value.validator.js +23 -0
- package/dist/utils/src/validators/is-unique-value.validator.js.map +1 -0
- package/dist/utils/src/validators/is-url-path.validator.d.ts +3 -0
- package/dist/utils/src/validators/is-url-path.validator.d.ts.map +1 -0
- package/dist/utils/src/validators/is-url-path.validator.js +27 -0
- package/dist/utils/src/validators/is-url-path.validator.js.map +1 -0
- package/package.json +8 -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.map +0 -1
- package/dist/dto/create-page.dto.d.ts.map +0 -1
- package/dist/dto/create-page.dto.js.map +0 -1
- package/dist/dto/update-page.dto.d.ts +0 -7
- package/dist/dto/update-page.dto.d.ts.map +0 -1
- package/dist/dto/update-page.dto.js +0 -30
- package/dist/dto/update-page.dto.js.map +0 -1
- package/dist/entities/page.entity.d.ts.map +0 -1
- package/dist/entities/page.entity.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/pages.module.d.ts.map +0 -1
- package/dist/pages.module.js.map +0 -1
- package/dist/services/pages.service.d.ts +0 -7
- package/dist/services/pages.service.d.ts.map +0 -1
- package/dist/services/pages.service.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/dist/{entities → pages-nestjs/src/entities}/page.entity.d.ts +0 -0
- /package/dist/{pages.module.d.ts → pages-nestjs/src/pages.module.d.ts} +0 -0
- /package/dist/{specs → pages-nestjs/src/specs}/pages.test.config.d.ts +0 -0
- /package/dist/{specs → pages-nestjs/src/specs}/pages.test.config.js +0 -0
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Page = exports.AddUniqueConstraintToUrl1735689600000 = exports.CreatePagesTable1704067200000 = exports.PagesMigrationConfig = void 0;
|
|
4
|
+
const page_entity_1 = require("../entities/page.entity");
|
|
5
|
+
Object.defineProperty(exports, "Page", { enumerable: true, get: function () { return page_entity_1.Page; } });
|
|
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; } });
|
|
10
|
+
exports.PagesMigrationConfig = {
|
|
11
|
+
entities: [page_entity_1.Page],
|
|
12
|
+
migrations: [_1704067200000_CreatePagesTable_1.CreatePagesTable1704067200000, _1735689600000_AddUniqueConstraintToUrl_1.AddUniqueConstraintToUrl1735689600000],
|
|
13
|
+
migrationsTableName: 'migrations',
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=migration.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.module.d.ts","sourceRoot":"","sources":["../../../src/pages.module.ts"],"names":[],"mappings":"AASA,qBAMa,WAAW;CAAG"}
|
|
@@ -12,6 +12,9 @@ const typeorm_1 = require("@nestjs/typeorm");
|
|
|
12
12
|
const page_entity_1 = require("./entities/page.entity");
|
|
13
13
|
const pages_controller_1 = require("./controllers/pages.controller");
|
|
14
14
|
const pages_service_1 = require("./services/pages.service");
|
|
15
|
+
const page_url_service_1 = require("./services/page-url.service");
|
|
16
|
+
const page_url_subscriber_1 = require("./subscribers/page-url.subscriber");
|
|
17
|
+
const utils_1 = require("@uecsio/utils");
|
|
15
18
|
let PagesModule = class PagesModule {
|
|
16
19
|
};
|
|
17
20
|
exports.PagesModule = PagesModule;
|
|
@@ -19,7 +22,7 @@ exports.PagesModule = PagesModule = __decorate([
|
|
|
19
22
|
(0, common_1.Module)({
|
|
20
23
|
imports: [typeorm_1.TypeOrmModule.forFeature([page_entity_1.Page])],
|
|
21
24
|
controllers: [pages_controller_1.PagesController],
|
|
22
|
-
providers: [pages_service_1.PagesService],
|
|
25
|
+
providers: [pages_service_1.PagesService, page_url_service_1.PageUrlService, page_url_subscriber_1.PageUrlSubscriber, utils_1.UrlGeneratorService, utils_1.IsUniqueValueConstraint],
|
|
23
26
|
exports: [pages_service_1.PagesService],
|
|
24
27
|
})
|
|
25
28
|
], PagesModule);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.module.js","sourceRoot":"","sources":["../../../src/pages.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,6CAAgD;AAChD,wDAA8C;AAC9C,qEAAiE;AACjE,4DAAwD;AACxD,kEAA6D;AAC7D,2EAAsE;AACtE,yCAA6E;AAQtE,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IANvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,uBAAa,CAAC,UAAU,CAAC,CAAC,kBAAI,CAAC,CAAC,CAAC;QAC3C,WAAW,EAAE,CAAC,kCAAe,CAAC;QAC9B,SAAS,EAAE,CAAC,4BAAY,EAAE,iCAAc,EAAE,uCAAiB,EAAE,2BAAmB,EAAE,+BAAuB,CAAC;QAC1G,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';
|
|
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,eAAe,CAAC;AAKxE,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_1 = require("@uecsio/utils");
|
|
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_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,yCAAwE;AAExE,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,2BAAmB;GAHzC,cAAc,CAqB1B"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Repository } from 'typeorm';
|
|
2
|
+
import { BaseTypeOrmCrudService } from '@uecsio/utils';
|
|
3
|
+
import { Page } from '../entities/page.entity';
|
|
4
|
+
export declare class PagesService extends BaseTypeOrmCrudService<Page> {
|
|
5
|
+
constructor(repo: Repository<Page>);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=pages.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
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,eAAe,CAAC;AACvD,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_1 = require("@uecsio/utils");
|
|
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_1.BaseTypeOrmCrudService {
|
|
22
|
+
constructor(repo) {
|
|
23
|
+
super(repo);
|
|
24
24
|
}
|
|
25
25
|
};
|
|
26
26
|
exports.PagesService = PagesService;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.service.js","sourceRoot":"","sources":["../../../../src/services/pages.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAmD;AACnD,qCAAqC;AACrC,yCAAuD;AACvD,yDAA+C;AAGxC,IAAM,YAAY,GAAlB,MAAM,YAAa,SAAQ,8BAA4B;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 @@
|
|
|
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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pages.test.config.js","sourceRoot":"","sources":["../../../../src/specs/pages.test.config.ts"],"names":[],"mappings":"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"}
|
|
@@ -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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { TestingModule } from '@nestjs/testing';
|
|
2
|
+
import { Repository } from 'typeorm';
|
|
3
|
+
import { PagesController } from '../controllers/pages.controller';
|
|
4
|
+
import { PagesService } from '../services/pages.service';
|
|
5
|
+
import { Page } from '../entities/page.entity';
|
|
6
|
+
export interface TestContext {
|
|
7
|
+
module: TestingModule;
|
|
8
|
+
controller: PagesController;
|
|
9
|
+
service: PagesService;
|
|
10
|
+
repository: Repository<Page>;
|
|
11
|
+
}
|
|
12
|
+
export declare const createTestModule: () => Promise<TestContext>;
|
|
13
|
+
export declare const mockPage: Page;
|
|
14
|
+
export declare const mockCreatePageDto: {
|
|
15
|
+
title: string;
|
|
16
|
+
url: string;
|
|
17
|
+
content: string;
|
|
18
|
+
metaTitle: string;
|
|
19
|
+
metaKeywords: string;
|
|
20
|
+
metaDescription: string;
|
|
21
|
+
status: number;
|
|
22
|
+
activateFrom: Date;
|
|
23
|
+
activateTo: Date;
|
|
24
|
+
};
|
|
25
|
+
export declare const mockUpdatePageDto: {
|
|
26
|
+
title: string;
|
|
27
|
+
status: number;
|
|
28
|
+
};
|
|
29
|
+
export declare const setupRepositoryMocks: (repository: Repository<Page>) => void;
|
|
30
|
+
export declare const clearRepositoryMocks: (repository: Repository<Page>) => void;
|
|
31
|
+
//# sourceMappingURL=pages.test.config.d.ts.map
|
|
@@ -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,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"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.clearRepositoryMocks = exports.setupRepositoryMocks = exports.mockUpdatePageDto = exports.mockCreatePageDto = exports.mockPage = exports.createTestModule = void 0;
|
|
4
|
+
const testing_1 = require("@nestjs/testing");
|
|
5
|
+
const typeorm_1 = require("@nestjs/typeorm");
|
|
6
|
+
const pages_module_1 = require("../pages.module");
|
|
7
|
+
const pages_controller_1 = require("../controllers/pages.controller");
|
|
8
|
+
const pages_service_1 = require("../services/pages.service");
|
|
9
|
+
const page_entity_1 = require("../entities/page.entity");
|
|
10
|
+
const createTestModule = async () => {
|
|
11
|
+
const module = await testing_1.Test.createTestingModule({
|
|
12
|
+
imports: [pages_module_1.PagesModule],
|
|
13
|
+
})
|
|
14
|
+
.overrideProvider((0, typeorm_1.getRepositoryToken)(page_entity_1.Page))
|
|
15
|
+
.useValue({
|
|
16
|
+
create: jest.fn(),
|
|
17
|
+
save: jest.fn(),
|
|
18
|
+
find: jest.fn(),
|
|
19
|
+
findOne: jest.fn(),
|
|
20
|
+
update: jest.fn(),
|
|
21
|
+
delete: jest.fn(),
|
|
22
|
+
createQueryBuilder: jest.fn(() => ({
|
|
23
|
+
where: jest.fn().mockReturnThis(),
|
|
24
|
+
andWhere: jest.fn().mockReturnThis(),
|
|
25
|
+
orderBy: jest.fn().mockReturnThis(),
|
|
26
|
+
skip: jest.fn().mockReturnThis(),
|
|
27
|
+
take: jest.fn().mockReturnThis(),
|
|
28
|
+
getMany: jest.fn(),
|
|
29
|
+
getOne: jest.fn(),
|
|
30
|
+
})),
|
|
31
|
+
})
|
|
32
|
+
.compile();
|
|
33
|
+
const controller = module.get(pages_controller_1.PagesController);
|
|
34
|
+
const service = module.get(pages_service_1.PagesService);
|
|
35
|
+
const repository = module.get((0, typeorm_1.getRepositoryToken)(page_entity_1.Page));
|
|
36
|
+
return {
|
|
37
|
+
module,
|
|
38
|
+
controller,
|
|
39
|
+
service,
|
|
40
|
+
repository,
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
exports.createTestModule = createTestModule;
|
|
44
|
+
exports.mockPage = {
|
|
45
|
+
id: 1,
|
|
46
|
+
title: 'Test Page',
|
|
47
|
+
url: 'https://example.com/test',
|
|
48
|
+
content: 'This is a test page content',
|
|
49
|
+
metaTitle: 'Test Page - SEO Title',
|
|
50
|
+
metaKeywords: 'test, page, example',
|
|
51
|
+
metaDescription: 'A test page for testing purposes',
|
|
52
|
+
status: 1,
|
|
53
|
+
activateFrom: new Date('2024-01-01'),
|
|
54
|
+
activateTo: new Date('2024-12-31'),
|
|
55
|
+
createdAt: new Date('2024-01-01T00:00:00.000Z'),
|
|
56
|
+
updatedAt: new Date('2024-01-01T00:00:00.000Z'),
|
|
57
|
+
};
|
|
58
|
+
exports.mockCreatePageDto = {
|
|
59
|
+
title: 'New Test Page',
|
|
60
|
+
url: 'https://example.com/new-test',
|
|
61
|
+
content: 'This is a new test page content',
|
|
62
|
+
metaTitle: 'New Test Page - SEO Title',
|
|
63
|
+
metaKeywords: 'new, test, page',
|
|
64
|
+
metaDescription: 'A new test page for testing purposes',
|
|
65
|
+
status: 1,
|
|
66
|
+
activateFrom: new Date('2024-01-01'),
|
|
67
|
+
activateTo: new Date('2024-12-31'),
|
|
68
|
+
};
|
|
69
|
+
exports.mockUpdatePageDto = {
|
|
70
|
+
title: 'Updated Test Page',
|
|
71
|
+
status: 2,
|
|
72
|
+
};
|
|
73
|
+
const setupRepositoryMocks = (repository) => {
|
|
74
|
+
jest.spyOn(repository, 'create').mockReturnValue(exports.mockPage);
|
|
75
|
+
jest.spyOn(repository, 'save').mockResolvedValue(exports.mockPage);
|
|
76
|
+
jest.spyOn(repository, 'find').mockResolvedValue([exports.mockPage]);
|
|
77
|
+
jest.spyOn(repository, 'findOne').mockResolvedValue(exports.mockPage);
|
|
78
|
+
jest.spyOn(repository, 'update').mockResolvedValue({ affected: 1 });
|
|
79
|
+
jest.spyOn(repository, 'delete').mockResolvedValue({ affected: 1 });
|
|
80
|
+
};
|
|
81
|
+
exports.setupRepositoryMocks = setupRepositoryMocks;
|
|
82
|
+
const clearRepositoryMocks = (repository) => {
|
|
83
|
+
jest.clearAllMocks();
|
|
84
|
+
};
|
|
85
|
+
exports.clearRepositoryMocks = clearRepositoryMocks;
|
|
86
|
+
//# sourceMappingURL=pages.test.config.js.map
|
|
@@ -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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './services/url-generator.service';
|
|
2
|
+
export { BaseTypeOrmCrudService } from './services/base-typeorm-crud.service';
|
|
3
|
+
export { IsUrlPath } from './validators/is-url-path.validator';
|
|
4
|
+
export { IsUniqueValue } from './validators/is-unique-value.validator';
|
|
5
|
+
export { IsUniqueValueConstraint } from './validators/is-unique-value.constraint';
|
|
6
|
+
export type { UniqueValueConstraintOptions } from './validators/is-unique-value.constraint';
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../utils/src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kCAAkC,CAAC;AACjD,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AACvE,OAAO,EAAE,uBAAuB,EAAE,MAAM,yCAAyC,CAAC;AAClF,YAAY,EAAE,4BAA4B,EAAE,MAAM,yCAAyC,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
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
|
+
exports.IsUniqueValueConstraint = exports.IsUniqueValue = exports.IsUrlPath = exports.BaseTypeOrmCrudService = void 0;
|
|
18
|
+
__exportStar(require("./services/url-generator.service"), exports);
|
|
19
|
+
var base_typeorm_crud_service_1 = require("./services/base-typeorm-crud.service");
|
|
20
|
+
Object.defineProperty(exports, "BaseTypeOrmCrudService", { enumerable: true, get: function () { return base_typeorm_crud_service_1.BaseTypeOrmCrudService; } });
|
|
21
|
+
var is_url_path_validator_1 = require("./validators/is-url-path.validator");
|
|
22
|
+
Object.defineProperty(exports, "IsUrlPath", { enumerable: true, get: function () { return is_url_path_validator_1.IsUrlPath; } });
|
|
23
|
+
var is_unique_value_validator_1 = require("./validators/is-unique-value.validator");
|
|
24
|
+
Object.defineProperty(exports, "IsUniqueValue", { enumerable: true, get: function () { return is_unique_value_validator_1.IsUniqueValue; } });
|
|
25
|
+
var is_unique_value_constraint_1 = require("./validators/is-unique-value.constraint");
|
|
26
|
+
Object.defineProperty(exports, "IsUniqueValueConstraint", { enumerable: true, get: function () { return is_unique_value_constraint_1.IsUniqueValueConstraint; } });
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../utils/src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,mEAAiD;AACjD,kFAA8E;AAArE,mIAAA,sBAAsB,OAAA;AAC/B,4EAA+D;AAAtD,kHAAA,SAAS,OAAA;AAClB,oFAAuE;AAA9D,0HAAA,aAAa,OAAA;AACtB,sFAAkF;AAAzE,qIAAA,uBAAuB,OAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { TypeOrmCrudService } from '@dataui/crud-typeorm';
|
|
2
|
+
import { Repository, ObjectLiteral } from 'typeorm';
|
|
3
|
+
export declare abstract class BaseTypeOrmCrudService<T extends ObjectLiteral> extends TypeOrmCrudService<T> {
|
|
4
|
+
getRepository(): Repository<T>;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=base-typeorm-crud.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-typeorm-crud.service.d.ts","sourceRoot":"","sources":["../../../../../utils/src/services/base-typeorm-crud.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAsBpD,8BACsB,sBAAsB,CAAC,CAAC,SAAS,aAAa,CAAE,SAAQ,kBAAkB,CAAC,CAAC,CAAC;IAKjG,aAAa,IAAI,UAAU,CAAC,CAAC,CAAC;CAG/B"}
|
|
@@ -0,0 +1,21 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.BaseTypeOrmCrudService = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const crud_typeorm_1 = require("@dataui/crud-typeorm");
|
|
12
|
+
let BaseTypeOrmCrudService = class BaseTypeOrmCrudService extends crud_typeorm_1.TypeOrmCrudService {
|
|
13
|
+
getRepository() {
|
|
14
|
+
return this.repo;
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
exports.BaseTypeOrmCrudService = BaseTypeOrmCrudService;
|
|
18
|
+
exports.BaseTypeOrmCrudService = BaseTypeOrmCrudService = __decorate([
|
|
19
|
+
(0, common_1.Injectable)()
|
|
20
|
+
], BaseTypeOrmCrudService);
|
|
21
|
+
//# sourceMappingURL=base-typeorm-crud.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base-typeorm-crud.service.js","sourceRoot":"","sources":["../../../../../utils/src/services/base-typeorm-crud.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,uDAA0D;AAwBnD,IAAe,sBAAsB,GAArC,MAAe,sBAAgD,SAAQ,iCAAqB;IAKjG,aAAa;QACX,OAAQ,IAAY,CAAC,IAAI,CAAC;IAC5B,CAAC;CACF,CAAA;AARqB,wDAAsB;iCAAtB,sBAAsB;IAD3C,IAAA,mBAAU,GAAE;GACS,sBAAsB,CAQ3C"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { FindOptionsWhere, ObjectLiteral, Repository } from 'typeorm';
|
|
2
|
+
export type FindableRepository<TEntity extends ObjectLiteral> = Pick<Repository<TEntity>, 'findOne'>;
|
|
3
|
+
export type GenerateUrlOptions<TEntity extends ObjectLiteral> = {
|
|
4
|
+
extraCondition?: FindOptionsWhere<TEntity>;
|
|
5
|
+
excludeId?: number | string;
|
|
6
|
+
maxAttempts?: number;
|
|
7
|
+
};
|
|
8
|
+
export declare class UrlGeneratorService {
|
|
9
|
+
generateUrl<TEntity extends ObjectLiteral>(urlField: string, baseValue: string, repository: FindableRepository<TEntity>, options?: GenerateUrlOptions<TEntity>): Promise<string>;
|
|
10
|
+
private createSlug;
|
|
11
|
+
private buildWhere;
|
|
12
|
+
private incrementUrlIndex;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=url-generator.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"url-generator.service.d.ts","sourceRoot":"","sources":["../../../../../utils/src/services/url-generator.service.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAkB,gBAAgB,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAG3F,MAAM,MAAM,kBAAkB,CAAC,OAAO,SAAS,aAAa,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,SAAS,CAAC,CAAC;AAErG,MAAM,MAAM,kBAAkB,CAAC,OAAO,SAAS,aAAa,IAAI;IAE9D,cAAc,CAAC,EAAE,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAE3C,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAE5B,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AAKF,qBACa,mBAAmB;IAMxB,WAAW,CAAC,OAAO,SAAS,aAAa,EAC7C,QAAQ,EAAE,MAA0B,EACpC,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,kBAAkB,CAAC,OAAO,CAAC,EACvC,OAAO,GAAE,kBAAkB,CAAC,OAAO,CAAM,GACxC,OAAO,CAAC,MAAM,CAAC;IAwBlB,OAAO,CAAC,UAAU;IAMlB,OAAO,CAAC,UAAU;IAqBlB,OAAO,CAAC,iBAAiB;CAY1B"}
|