@uecsio/pages-api 2.0.0 → 2.2.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 +27 -271
- package/dist/consts/index.d.ts +2 -0
- package/dist/consts/index.d.ts.map +1 -0
- package/dist/consts/index.js +5 -0
- package/dist/consts/index.js.map +1 -0
- package/dist/{pages-nestjs/src/dto → dto}/create-page.dto.d.ts +2 -2
- package/dist/dto/create-page.dto.d.ts.map +1 -0
- package/dist/{pages-nestjs/src/dto → dto}/create-page.dto.js +6 -13
- package/dist/dto/create-page.dto.js.map +1 -0
- package/dist/dto/update-page.dto.d.ts +7 -0
- package/dist/dto/update-page.dto.d.ts.map +1 -0
- package/dist/dto/update-page.dto.js +30 -0
- package/dist/dto/update-page.dto.js.map +1 -0
- package/dist/entities/page.entity.d.ts.map +1 -0
- package/dist/{pages-nestjs/src/entities → entities}/page.entity.js +2 -2
- package/dist/entities/page.entity.js.map +1 -0
- package/dist/{pages-nestjs/src/index.d.ts → index.d.ts} +1 -5
- package/dist/index.d.ts.map +1 -0
- package/dist/{pages-nestjs/src/index.js → index.js} +2 -8
- package/dist/index.js.map +1 -0
- package/dist/migrations/1704067200000-CreatePagesTable.d.ts.map +1 -0
- package/dist/{pages-nestjs/src/migrations → migrations}/1704067200000-CreatePagesTable.js +19 -19
- package/dist/migrations/1704067200000-CreatePagesTable.js.map +1 -0
- package/dist/{pages-nestjs/src/migrations → migrations}/migration.config.d.ts +1 -2
- package/dist/migrations/migration.config.d.ts.map +1 -0
- package/dist/{pages-nestjs/src/migrations → migrations}/migration.config.js +2 -4
- package/dist/migrations/migration.config.js.map +1 -0
- package/dist/pages.module.d.ts.map +1 -0
- package/dist/{pages-nestjs/src/pages.module.js → pages.module.js} +12 -10
- package/dist/pages.module.js.map +1 -0
- package/package.json +9 -9
- package/dist/pages-nestjs/src/controllers/pages.controller.d.ts +0 -8
- package/dist/pages-nestjs/src/controllers/pages.controller.d.ts.map +0 -1
- package/dist/pages-nestjs/src/controllers/pages.controller.js +0 -41
- package/dist/pages-nestjs/src/controllers/pages.controller.js.map +0 -1
- package/dist/pages-nestjs/src/dto/create-page.dto.d.ts.map +0 -1
- package/dist/pages-nestjs/src/dto/create-page.dto.js.map +0 -1
- package/dist/pages-nestjs/src/dto/update-page.dto.d.ts +0 -12
- package/dist/pages-nestjs/src/dto/update-page.dto.d.ts.map +0 -1
- package/dist/pages-nestjs/src/dto/update-page.dto.js +0 -113
- package/dist/pages-nestjs/src/dto/update-page.dto.js.map +0 -1
- package/dist/pages-nestjs/src/entities/page.entity.d.ts.map +0 -1
- package/dist/pages-nestjs/src/entities/page.entity.js.map +0 -1
- package/dist/pages-nestjs/src/index.d.ts.map +0 -1
- package/dist/pages-nestjs/src/index.js.map +0 -1
- package/dist/pages-nestjs/src/migrations/1704067200000-CreatePagesTable.d.ts.map +0 -1
- package/dist/pages-nestjs/src/migrations/1704067200000-CreatePagesTable.js.map +0 -1
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.d.ts +0 -6
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.d.ts.map +0 -1
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.js +0 -18
- package/dist/pages-nestjs/src/migrations/1735689600000-AddUniqueConstraintToUrl.js.map +0 -1
- package/dist/pages-nestjs/src/migrations/migration.config.d.ts.map +0 -1
- package/dist/pages-nestjs/src/migrations/migration.config.js.map +0 -1
- package/dist/pages-nestjs/src/pages.module.d.ts.map +0 -1
- package/dist/pages-nestjs/src/pages.module.js.map +0 -1
- package/dist/pages-nestjs/src/services/page-url.service.d.ts +0 -10
- package/dist/pages-nestjs/src/services/page-url.service.d.ts.map +0 -1
- package/dist/pages-nestjs/src/services/page-url.service.js +0 -38
- package/dist/pages-nestjs/src/services/page-url.service.js.map +0 -1
- package/dist/pages-nestjs/src/services/pages.service.d.ts +0 -7
- package/dist/pages-nestjs/src/services/pages.service.d.ts.map +0 -1
- package/dist/pages-nestjs/src/services/pages.service.js +0 -32
- package/dist/pages-nestjs/src/services/pages.service.js.map +0 -1
- package/dist/pages-nestjs/src/specs/pages.test.config.d.ts +0 -31
- package/dist/pages-nestjs/src/specs/pages.test.config.d.ts.map +0 -1
- package/dist/pages-nestjs/src/specs/pages.test.config.js +0 -86
- package/dist/pages-nestjs/src/specs/pages.test.config.js.map +0 -1
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.d.ts +0 -12
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.d.ts.map +0 -1
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.js +0 -44
- package/dist/pages-nestjs/src/subscribers/page-url.subscriber.js.map +0 -1
- package/dist/pages-nestjs/src/tests/pages.test.config.d.ts +0 -31
- package/dist/pages-nestjs/src/tests/pages.test.config.d.ts.map +0 -1
- package/dist/pages-nestjs/src/tests/pages.test.config.js +0 -86
- package/dist/pages-nestjs/src/tests/pages.test.config.js.map +0 -1
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.d.ts +0 -10
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.d.ts.map +0 -1
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.js +0 -51
- package/dist/pages-nestjs/src/validators/is-unique-url.constraint.js.map +0 -1
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.d.ts +0 -3
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.d.ts.map +0 -1
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.js +0 -18
- package/dist/pages-nestjs/src/validators/is-unique-url.validator.js.map +0 -1
- package/dist/utils/src/index.d.ts +0 -7
- package/dist/utils/src/index.d.ts.map +0 -1
- package/dist/utils/src/index.js +0 -27
- package/dist/utils/src/index.js.map +0 -1
- package/dist/utils/src/services/base-typeorm-crud.service.d.ts +0 -6
- package/dist/utils/src/services/base-typeorm-crud.service.d.ts.map +0 -1
- package/dist/utils/src/services/base-typeorm-crud.service.js +0 -21
- package/dist/utils/src/services/base-typeorm-crud.service.js.map +0 -1
- package/dist/utils/src/services/url-generator.service.d.ts +0 -14
- package/dist/utils/src/services/url-generator.service.d.ts.map +0 -1
- package/dist/utils/src/services/url-generator.service.js +0 -66
- package/dist/utils/src/services/url-generator.service.js.map +0 -1
- package/dist/utils/src/validators/is-unique-value.constraint.d.ts +0 -14
- package/dist/utils/src/validators/is-unique-value.constraint.d.ts.map +0 -1
- package/dist/utils/src/validators/is-unique-value.constraint.js +0 -60
- package/dist/utils/src/validators/is-unique-value.constraint.js.map +0 -1
- package/dist/utils/src/validators/is-unique-value.validator.d.ts +0 -4
- package/dist/utils/src/validators/is-unique-value.validator.d.ts.map +0 -1
- package/dist/utils/src/validators/is-unique-value.validator.js +0 -23
- package/dist/utils/src/validators/is-unique-value.validator.js.map +0 -1
- package/dist/utils/src/validators/is-url-path.validator.d.ts +0 -3
- package/dist/utils/src/validators/is-url-path.validator.d.ts.map +0 -1
- package/dist/utils/src/validators/is-url-path.validator.js +0 -27
- package/dist/utils/src/validators/is-url-path.validator.js.map +0 -1
- /package/dist/{pages-nestjs/src/entities → entities}/page.entity.d.ts +0 -0
- /package/dist/{pages-nestjs/src/migrations → migrations}/1704067200000-CreatePagesTable.d.ts +0 -0
- /package/dist/{pages-nestjs/src/pages.module.d.ts → pages.module.d.ts} +0 -0
|
@@ -1,32 +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
|
-
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.PagesService = void 0;
|
|
16
|
-
const common_1 = require("@nestjs/common");
|
|
17
|
-
const typeorm_1 = require("@nestjs/typeorm");
|
|
18
|
-
const typeorm_2 = require("typeorm");
|
|
19
|
-
const utils_1 = require("@uecsio/utils");
|
|
20
|
-
const page_entity_1 = require("../entities/page.entity");
|
|
21
|
-
let PagesService = class PagesService extends utils_1.BaseTypeOrmCrudService {
|
|
22
|
-
constructor(repo) {
|
|
23
|
-
super(repo);
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
exports.PagesService = PagesService;
|
|
27
|
-
exports.PagesService = PagesService = __decorate([
|
|
28
|
-
(0, common_1.Injectable)(),
|
|
29
|
-
__param(0, (0, typeorm_1.InjectRepository)(page_entity_1.Page)),
|
|
30
|
-
__metadata("design:paramtypes", [typeorm_2.Repository])
|
|
31
|
-
], PagesService);
|
|
32
|
-
//# sourceMappingURL=pages.service.js.map
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,31 +0,0 @@
|
|
|
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
|
|
@@ -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,86 +0,0 @@
|
|
|
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
|
|
@@ -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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"}
|
|
@@ -1,12 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,44 +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
|
-
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
|
|
@@ -1 +0,0 @@
|
|
|
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,31 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,86 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"pages.test.config.js","sourceRoot":"","sources":["../../../../src/tests/pages.test.config.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,51 +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
|
-
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,7 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
package/dist/utils/src/index.js
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,6 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,21 +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
|
-
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|