@drax/crud-back 0.4.0 → 0.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/controllers/AbstractFastifyController.js +114 -45
- package/dist/exports/AbstractExport.js +41 -0
- package/dist/exports/ExportCsv.js +86 -0
- package/dist/exports/ExportJson.js +60 -0
- package/dist/repository/AbstractMongoRepository.js +11 -0
- package/dist/services/AbstractService.js +44 -0
- package/dist/workers/ExportCsvWorker.js +12 -0
- package/package.json +8 -6
- package/src/controllers/AbstractFastifyController.ts +132 -48
- package/src/exports/AbstractExport.ts +74 -0
- package/src/exports/ExportCsv.ts +107 -0
- package/src/exports/ExportJson.ts +73 -0
- package/src/index.ts +0 -3
- package/src/repository/AbstractMongoRepository.ts +26 -5
- package/src/repository/AbstractSqliteRepository.ts +1 -1
- package/src/services/AbstractService.ts +81 -10
- package/src/workers/ExportCsvWorker.js +12 -0
- package/src/workers/ExportCsvWorker.ts +12 -0
- package/test/_mocks/MockRepository.ts +58 -0
- package/test/exports/ExportCsv.test.ts +137 -0
- package/test/services/AbstractService.test.ts +40 -0
- package/test/workers/ExportCsvWorker.test.ts +92 -0
- package/tsconfig.json +2 -2
- package/tsconfig.tsbuildinfo +1 -1
- package/types/controllers/AbstractFastifyController.d.ts +20 -9
- package/types/controllers/AbstractFastifyController.d.ts.map +1 -1
- package/types/exports/AbstractExport.d.ts +23 -0
- package/types/exports/AbstractExport.d.ts.map +1 -0
- package/types/exports/ExportCsv.d.ts +13 -0
- package/types/exports/ExportCsv.d.ts.map +1 -0
- package/types/exports/ExportJson.d.ts +8 -0
- package/types/exports/ExportJson.d.ts.map +1 -0
- package/types/index.d.ts +0 -2
- package/types/index.d.ts.map +1 -1
- package/types/repository/AbstractMongoRepository.d.ts +3 -3
- package/types/repository/AbstractMongoRepository.d.ts.map +1 -1
- package/types/repository/AbstractSqliteRepository.d.ts +1 -1
- package/types/repository/AbstractSqliteRepository.d.ts.map +1 -1
- package/types/services/AbstractService.d.ts +8 -5
- package/types/services/AbstractService.d.ts.map +1 -1
- package/types/workers/ExportCsvWorker.d.ts +2 -0
- package/types/workers/ExportCsvWorker.d.ts.map +1 -0
- package/dist/interfaces/ICrudRepository.js +0 -1
- package/dist/interfaces/IEntityPermission.js +0 -1
- package/dist/interfaces/IEntityRepository.js +0 -1
- package/src/interfaces/ICrudRepository.ts +0 -16
- package/src/interfaces/IEntityPermission.ts +0 -10
- package/types/interfaces/ICrudRepository.d.ts +0 -15
- package/types/interfaces/ICrudRepository.d.ts.map +0 -1
- package/types/interfaces/IEntityPermission.d.ts +0 -10
- package/types/interfaces/IEntityPermission.d.ts.map +0 -1
- package/types/interfaces/IEntityRepository.d.ts +0 -5
- package/types/interfaces/IEntityRepository.d.ts.map +0 -1
|
@@ -1,36 +1,47 @@
|
|
|
1
1
|
import AbstractService from "../services/AbstractService";
|
|
2
|
-
import { Rbac } from "@drax/identity-back";
|
|
3
2
|
import type { FastifyReply, FastifyRequest } from "fastify";
|
|
4
|
-
import {
|
|
3
|
+
import { IDraxPermission } from "@drax/crud-share";
|
|
5
4
|
declare module 'fastify' {
|
|
6
5
|
interface FastifyRequest {
|
|
7
|
-
rbac?:
|
|
6
|
+
rbac?: any;
|
|
8
7
|
}
|
|
9
8
|
}
|
|
10
9
|
type CustomRequest = FastifyRequest<{
|
|
11
10
|
Params: {
|
|
12
11
|
id?: string;
|
|
13
12
|
ids?: string;
|
|
13
|
+
format?: string;
|
|
14
14
|
};
|
|
15
15
|
Querystring: {
|
|
16
|
+
format?: string;
|
|
16
17
|
page?: number;
|
|
17
18
|
limit?: number;
|
|
18
19
|
orderBy?: string;
|
|
19
20
|
order?: 'asc' | 'desc' | boolean;
|
|
20
21
|
search?: string;
|
|
22
|
+
filters?: string;
|
|
23
|
+
headers?: string;
|
|
24
|
+
separator?: string;
|
|
21
25
|
};
|
|
22
26
|
}>;
|
|
23
27
|
declare class AbstractFastifyController<T, C, U> {
|
|
24
28
|
protected service: AbstractService<T, C, U>;
|
|
25
|
-
protected permission:
|
|
26
|
-
constructor(service: AbstractService<T, C, U>, permission:
|
|
27
|
-
|
|
28
|
-
findByIds(request: CustomRequest, reply: FastifyReply): Promise<T[]>;
|
|
29
|
-
search(request: CustomRequest, reply: FastifyReply): Promise<T[]>;
|
|
30
|
-
paginate(request: CustomRequest, reply: FastifyReply): Promise<import("packages/common/common-share/types").IDraxPaginateResult<T>>;
|
|
29
|
+
protected permission: IDraxPermission;
|
|
30
|
+
constructor(service: AbstractService<T, C, U>, permission: IDraxPermission);
|
|
31
|
+
parseFilters(stringFilters: string): any;
|
|
31
32
|
create(request: CustomRequest, reply: FastifyReply): Promise<T>;
|
|
32
33
|
update(request: CustomRequest, reply: FastifyReply): Promise<T>;
|
|
33
34
|
delete(request: CustomRequest, reply: FastifyReply): Promise<void>;
|
|
35
|
+
findById(request: CustomRequest, reply: FastifyReply): Promise<T>;
|
|
36
|
+
findByIds(request: CustomRequest, reply: FastifyReply): Promise<T[]>;
|
|
37
|
+
search(request: CustomRequest, reply: FastifyReply): Promise<T[]>;
|
|
38
|
+
paginate(request: CustomRequest, reply: FastifyReply): Promise<import("@drax/crud-share").IDraxPaginateResult<T>>;
|
|
39
|
+
export(request: CustomRequest, reply: FastifyReply): Promise<{
|
|
40
|
+
url: string;
|
|
41
|
+
rowCount: number;
|
|
42
|
+
time: number;
|
|
43
|
+
fileName: string;
|
|
44
|
+
}>;
|
|
34
45
|
}
|
|
35
46
|
export default AbstractFastifyController;
|
|
36
47
|
export { AbstractFastifyController };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractFastifyController.d.ts","sourceRoot":"","sources":["../../src/controllers/AbstractFastifyController.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,6BAA6B,CAAC;
|
|
1
|
+
{"version":3,"file":"AbstractFastifyController.d.ts","sourceRoot":"","sources":["../../src/controllers/AbstractFastifyController.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,MAAM,6BAA6B,CAAC;AAG1D,OAAO,KAAK,EAAC,YAAY,EAAE,cAAc,EAAC,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAoB,eAAe,EAAC,MAAM,kBAAkB,CAAC;AAGpE,OAAO,QAAQ,SAAS,CAAC;IACrB,UAAU,cAAc;QACpB,IAAI,CAAC,EAAE,GAAG,CAAC;KACd;CACJ;AAED,KAAK,aAAa,GAAG,cAAc,CAAC;IAChC,MAAM,EAAE;QACJ,EAAE,CAAC,EAAE,MAAM,CAAA;QACX,GAAG,CAAC,EAAE,MAAM,CAAA;QACZ,MAAM,CAAC,EAAE,MAAM,CAAA;KAClB,CAAC;IACF,WAAW,EAAC;QACR,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,IAAI,CAAC,EAAE,MAAM,CAAA;QACb,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,OAAO,CAAC,EAAE,MAAM,CAAA;QAChB,KAAK,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,OAAO,CAAA;QAChC,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,OAAO,CAAC,EAAE,MAAM,CAAA;QAChB,OAAO,CAAC,EAAE,MAAM,CAAA;QAChB,SAAS,CAAC,EAAE,MAAM,CAAA;KACrB,CAAA;CACJ,CAAC,CAAA;AAMF,cAAM,yBAAyB,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC;IAEjC,SAAS,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC,CAAA;IACzC,SAAS,CAAC,UAAU,EAAE,eAAe,CAAA;gBAEzB,OAAO,EAAE,eAAe,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,UAAU,EAAE,eAAe;IAM1E,YAAY,CAAC,aAAa,EAAE,MAAM,GAAG,GAAG;IAqBlC,MAAM,CAAC,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,YAAY;IAqBlD,MAAM,CAAC,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,YAAY;IA0BlD,MAAM,CAAC,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,YAAY;IAyBlD,QAAQ,CAAC,OAAO,EAAC,aAAa,EAAE,KAAK,EAAE,YAAY;IAyBnD,SAAS,CAAC,OAAO,EAAC,aAAa,EAAE,KAAK,EAAE,YAAY;IAyBpD,MAAM,CAAC,OAAO,EAAC,aAAa,EAAE,KAAK,EAAE,YAAY;IAqBjD,QAAQ,CAAC,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,YAAY;IA0BpD,MAAM,CAAC,OAAO,EAAC,aAAa,EAAE,KAAK,EAAE,YAAY;;;;;;CAoD1D;AAED,eAAe,yBAAyB,CAAC;AACzC,OAAO,EAAC,yBAAyB,EAAC,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
interface ExportOptions {
|
|
2
|
+
cursor: any;
|
|
3
|
+
destinationPath: string;
|
|
4
|
+
headers: string[] | string;
|
|
5
|
+
}
|
|
6
|
+
export type { ExportOptions };
|
|
7
|
+
declare class AbstractExport {
|
|
8
|
+
cursor: any;
|
|
9
|
+
destinationPath: string;
|
|
10
|
+
headers: string[];
|
|
11
|
+
fileName: string;
|
|
12
|
+
relativeFilePath: string;
|
|
13
|
+
constructor(options: ExportOptions);
|
|
14
|
+
createDirIfNotExist(): void;
|
|
15
|
+
generateFileName(extension: string): string;
|
|
16
|
+
generateFilePath(extension: string): string;
|
|
17
|
+
isIterableAsync(value: any): boolean;
|
|
18
|
+
isIterableSync(value: any): boolean;
|
|
19
|
+
getNestedProperty(obj: object, path: string): any;
|
|
20
|
+
}
|
|
21
|
+
export { AbstractExport, };
|
|
22
|
+
export default AbstractExport;
|
|
23
|
+
//# sourceMappingURL=AbstractExport.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AbstractExport.d.ts","sourceRoot":"","sources":["../../src/exports/AbstractExport.ts"],"names":[],"mappings":"AAIA,UAAU,aAAa;IACnB,MAAM,EAAE,GAAG,CAAA;IACX,eAAe,EAAE,MAAM,CAAA;IACvB,OAAO,EAAE,MAAM,EAAE,GAAG,MAAM,CAAA;CAC7B;AAED,YAAY,EAAC,aAAa,EAAC,CAAA;AAE3B,cAAM,cAAc;IAEhB,MAAM,EAAE,GAAG,CAAA;IACX,eAAe,EAAE,MAAM,CAAA;IACvB,OAAO,EAAE,MAAM,EAAE,CAAA;IAEjB,QAAQ,EAAE,MAAM,CAAA;IAChB,gBAAgB,EAAE,MAAM,CAAA;gBAEZ,OAAO,EAAE,aAAa;IAOlC,mBAAmB,IAAI,IAAI;IAI3B,gBAAgB,CAAC,SAAS,EAAC,MAAM,GAAG,MAAM;IAS1C,gBAAgB,CAAC,SAAS,EAAC,MAAM;IAQjC,eAAe,CAAC,KAAK,EAAE,GAAG;IAI1B,cAAc,CAAC,KAAK,EAAE,GAAG;IAIzB,iBAAiB,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;CAS9C;AAGD,OAAO,EACH,cAAc,GACjB,CAAA;AAED,eAAe,cAAc,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import AbstractExport from "./AbstractExport.js";
|
|
2
|
+
import type { ExportOptions } from "./AbstractExport";
|
|
3
|
+
interface ExportCsvOptions extends ExportOptions {
|
|
4
|
+
separator: string;
|
|
5
|
+
}
|
|
6
|
+
declare class ExportCsv extends AbstractExport {
|
|
7
|
+
separator: string;
|
|
8
|
+
constructor(options: ExportCsvOptions);
|
|
9
|
+
process(): Promise<any>;
|
|
10
|
+
convertRecordToCSVrow(record: object): string;
|
|
11
|
+
}
|
|
12
|
+
export default ExportCsv;
|
|
13
|
+
//# sourceMappingURL=ExportCsv.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExportCsv.d.ts","sourceRoot":"","sources":["../../src/exports/ExportCsv.ts"],"names":[],"mappings":"AACA,OAAO,cAAc,MAAM,qBAAqB,CAAC;AACjD,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAGpD,UAAU,gBAAiB,SAAQ,aAAa;IAC5C,SAAS,EAAE,MAAM,CAAA;CACpB;AAED,cAAM,SAAU,SAAQ,cAAc;IAElC,SAAS,EAAE,MAAM,CAAM;gBAEX,OAAO,EAAE,gBAAgB;IAMrC,OAAO,IAAI,OAAO,CAAC,GAAG,CAAC;IAoDvB,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;CAiChD;AAED,eAAe,SAAS,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import AbstractExport from "./AbstractExport.js";
|
|
2
|
+
import type { ExportOptions } from "./AbstractExport";
|
|
3
|
+
declare class ExportJson extends AbstractExport {
|
|
4
|
+
constructor(options: ExportOptions);
|
|
5
|
+
process(): Promise<any>;
|
|
6
|
+
}
|
|
7
|
+
export default ExportJson;
|
|
8
|
+
//# sourceMappingURL=ExportJson.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExportJson.d.ts","sourceRoot":"","sources":["../../src/exports/ExportJson.ts"],"names":[],"mappings":"AACA,OAAO,cAAc,MAAM,qBAAqB,CAAC;AACjD,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAKpD,cAAM,UAAW,SAAQ,cAAc;gBAEvB,OAAO,EAAE,aAAa;IAKlC,OAAO,IAAI,OAAO,CAAC,GAAG,CAAC;CAwD1B;AAED,eAAe,UAAU,CAAC"}
|
package/types/index.d.ts
CHANGED
|
@@ -2,7 +2,5 @@ import AbstractMongoRepository from "./repository/AbstractMongoRepository.js";
|
|
|
2
2
|
import AbstractSqliteRepository from "./repository/AbstractSqliteRepository.js";
|
|
3
3
|
import AbstractService from "./services/AbstractService.js";
|
|
4
4
|
import AbstractFastifyController from "./controllers/AbstractFastifyController.js";
|
|
5
|
-
import type { ICrudRepository } from "./interfaces/ICrudRepository";
|
|
6
|
-
export type { ICrudRepository };
|
|
7
5
|
export { AbstractMongoRepository, AbstractSqliteRepository, AbstractService, AbstractFastifyController, };
|
|
8
6
|
//# sourceMappingURL=index.d.ts.map
|
package/types/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,uBAAuB,MAAM,yCAAyC,CAAC;AAC9E,OAAO,wBAAwB,MAAM,0CAA0C,CAAC;AAChF,OAAO,eAAe,MAAM,+BAA+B,CAAC;AAC5D,OAAO,yBAAyB,MAAM,4CAA4C,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,uBAAuB,MAAM,yCAAyC,CAAC;AAC9E,OAAO,wBAAwB,MAAM,0CAA0C,CAAC;AAChF,OAAO,eAAe,MAAM,+BAA+B,CAAC;AAC5D,OAAO,yBAAyB,MAAM,4CAA4C,CAAC;AAGnF,OAAO,EAGH,uBAAuB,EACvB,wBAAwB,EACxB,eAAe,EACf,yBAAyB,GAE5B,CAAA"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import "mongoose-paginate-v2";
|
|
2
2
|
import mongoose from "mongoose";
|
|
3
|
-
import type { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/
|
|
3
|
+
import type { IDraxPaginateOptions, IDraxPaginateResult, IDraxFindOptions, IDraxCrud } from "@drax/crud-share";
|
|
4
4
|
import type { PaginateModel } from "mongoose";
|
|
5
|
-
|
|
6
|
-
declare class AbstractMongoRepository<T, C, U> implements ICrudRepository<T, C, U> {
|
|
5
|
+
declare class AbstractMongoRepository<T, C, U> implements IDraxCrud<T, C, U> {
|
|
7
6
|
_model: mongoose.Model<T> & PaginateModel<T>;
|
|
8
7
|
_searchFields: string[];
|
|
9
8
|
_populateFields: string[];
|
|
@@ -17,6 +16,7 @@ declare class AbstractMongoRepository<T, C, U> implements ICrudRepository<T, C,
|
|
|
17
16
|
fetchAll(): Promise<T[]>;
|
|
18
17
|
search(value: string, limit?: number): Promise<T[]>;
|
|
19
18
|
paginate({ page, limit, orderBy, order, search, filters }: IDraxPaginateOptions): Promise<IDraxPaginateResult<T>>;
|
|
19
|
+
find({ cursor, limit, orderBy, order, search, filters }: IDraxFindOptions): Promise<T[]>;
|
|
20
20
|
}
|
|
21
21
|
export default AbstractMongoRepository;
|
|
22
22
|
export { AbstractMongoRepository };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractMongoRepository.d.ts","sourceRoot":"","sources":["../../src/repository/AbstractMongoRepository.ts"],"names":[],"mappings":"AAAA,OAAO,sBAAsB,CAAC;AAC9B,OAAO,QAAQ,MAAM,UAAU,CAAC;AAGhC,OAAO,KAAK,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,
|
|
1
|
+
{"version":3,"file":"AbstractMongoRepository.d.ts","sourceRoot":"","sources":["../../src/repository/AbstractMongoRepository.ts"],"names":[],"mappings":"AAAA,OAAO,sBAAsB,CAAC;AAC9B,OAAO,QAAQ,MAAM,UAAU,CAAC;AAGhC,OAAO,KAAK,EAAC,oBAAoB,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,SAAS,EAAC,MAAM,kBAAkB,CAAC;AAC7G,OAAO,KAAK,EAAC,aAAa,EAAkC,MAAM,UAAU,CAAC;AAG7E,cAAM,uBAAuB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAE,YAAW,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAEhE,MAAM,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,CAAA;IAC5C,aAAa,EAAE,MAAM,EAAE,CAAK;IAC5B,eAAe,EAAE,MAAM,EAAE,CAAK;IAGxB,MAAM,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAiB3B,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAYvC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAKpC,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAKvC,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAK3C,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAMvD,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAM/C,QAAQ,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC;IAKxB,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,GAAE,MAAa,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAQzD,QAAQ,CAAC,EACI,IAAQ,EACR,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;IAsBlE,IAAI,CAAC,EACI,MAAc,EACd,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,gBAAgB,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;CAehD;AAED,eAAe,uBAAuB,CAAA;AACtC,OAAO,EAAC,uBAAuB,EAAC,CAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/
|
|
1
|
+
import type { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/crud-share";
|
|
2
2
|
import { SqliteTableField } from "@drax/common-back";
|
|
3
3
|
declare class AbstractSqliteRepository<T> {
|
|
4
4
|
protected db: any;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractSqliteRepository.d.ts","sourceRoot":"","sources":["../../src/repository/AbstractSqliteRepository.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,
|
|
1
|
+
{"version":3,"file":"AbstractSqliteRepository.d.ts","sourceRoot":"","sources":["../../src/repository/AbstractSqliteRepository.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,kBAAkB,CAAC;AAEhF,OAAO,EAC0C,gBAAgB,EAChC,MAAM,mBAAmB,CAAC;AAI3D,cAAM,wBAAwB,CAAC,CAAC;IAC5B,SAAS,CAAC,EAAE,EAAE,GAAG,CAAC;IAClB,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,YAAY,EAAE,MAAM,EAAE,CAAM;IACtC,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,CAAM;IACvC,SAAS,CAAC,UAAU,EAAE,MAAM,CAAQ;IACpC,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC;IAC3B,SAAS,CAAC,WAAW,EAAE,gBAAgB,EAAE,CAAC;gBAE9B,QAAQ,EAAC,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,GAAC,MAAa,EAAC,YAAY,GAAC,MAAM,EAAO,EAAE,aAAa,GAAC,MAAM,EAAO,EAAE,OAAO,GAAC,OAAe;IAmBzJ,KAAK;IAKC,MAAM,CAAC,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC;IA8B7B,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAKvC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC;IAKtD,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAKvD,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,CAAC;IAwBzC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAQpC,QAAQ,CAAC,EACI,IAAO,EACP,KAAQ,EACR,OAAW,EACX,KAAa,EACb,MAAU,EACV,OAAW,EAAC,EAAG,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;IAmClF,QAAQ,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;CAMnC;AAED,eAAe,wBAAwB,CAAA"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import type { ZodSchema } from "zod";
|
|
2
|
-
import type { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import type { IDraxPaginateOptions, IDraxPaginateResult, IDraxFindOptions, IDraxCrud, IDraxExportOptions } from "@drax/crud-share";
|
|
3
|
+
import { IDraxCrudService } from "@drax/crud-share";
|
|
4
|
+
import { IDraxExportResult } from "@drax/crud-share";
|
|
5
|
+
declare class AbstractService<T, C, U> implements IDraxCrudService<T, C, U> {
|
|
6
|
+
_repository: IDraxCrud<T, C, U>;
|
|
6
7
|
_schema?: ZodSchema | undefined;
|
|
7
|
-
constructor(repository:
|
|
8
|
+
constructor(repository: IDraxCrud<T, C, U>, schema?: ZodSchema);
|
|
8
9
|
create(data: C): Promise<T>;
|
|
9
10
|
update(id: string, data: U): Promise<T>;
|
|
10
11
|
delete(id: string): Promise<boolean>;
|
|
@@ -15,6 +16,8 @@ declare class AbstractService<T, C, U> {
|
|
|
15
16
|
fetchAll(): Promise<T[]>;
|
|
16
17
|
search(value: string): Promise<T[]>;
|
|
17
18
|
paginate({ page, limit, orderBy, order, search, filters }: IDraxPaginateOptions): Promise<IDraxPaginateResult<T>>;
|
|
19
|
+
find({ orderBy, order, search, filters }: IDraxFindOptions): Promise<T[]>;
|
|
20
|
+
export({ format, headers, separator, orderBy, order, search, filters }: IDraxExportOptions, destinationPath: string): Promise<IDraxExportResult>;
|
|
18
21
|
}
|
|
19
22
|
export default AbstractService;
|
|
20
23
|
export { AbstractService };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractService.d.ts","sourceRoot":"","sources":["../../src/services/AbstractService.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,KAAK,CAAC;AACnC,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"AbstractService.d.ts","sourceRoot":"","sources":["../../src/services/AbstractService.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,KAAK,CAAC;AACnC,OAAO,KAAK,EACR,oBAAoB,EACpB,mBAAmB,EACnB,gBAAgB,EAChB,SAAS,EACT,kBAAkB,EACrB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAC,gBAAgB,EAAC,MAAM,kBAAkB,CAAC;AAGlD,OAAO,EAAC,iBAAiB,EAAC,MAAM,kBAAkB,CAAC;AAEnD,cAAM,eAAe,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAE,YAAW,gBAAgB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAE/D,WAAW,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;IAC/B,OAAO,CAAC,EAAE,SAAS,GAAG,SAAS,CAAA;gBAEnB,UAAU,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,SAAS;IAKxD,MAAM,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAgB3B,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAgBvC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAWpC,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAUvC,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAU3C,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAW1D,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC;IAWzD,QAAQ,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC;IAWxB,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAWnC,QAAQ,CAAC,EACI,IAAQ,EACR,KAAS,EACT,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;IAWlE,IAAI,CAAC,EACI,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,gBAAgB,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAWvC,MAAM,CAAC,EACI,MAAe,EACf,OAAY,EACZ,SAAe,EACf,OAAY,EACZ,KAAa,EACb,MAAW,EACX,OAAY,EACf,EAAE,kBAAkB,EACrB,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,CAAC;CAqCpE;AAED,eAAe,eAAe,CAAA;AAC9B,OAAO,EAAC,eAAe,EAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ExportCsvWorker.d.ts","sourceRoot":"","sources":["../../src/workers/ExportCsvWorker.ts"],"names":[],"mappings":""}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import type {IDraxPaginateOptions, IDraxPaginateResult} from "@drax/common-share";
|
|
2
|
-
|
|
3
|
-
interface ICrudRepository<T,C,U>{
|
|
4
|
-
paginate(options: IDraxPaginateOptions): Promise<IDraxPaginateResult<T>>
|
|
5
|
-
create(input: C): Promise<T>
|
|
6
|
-
update(id: string, input: U): Promise<T>
|
|
7
|
-
delete(id: string): Promise<any>
|
|
8
|
-
|
|
9
|
-
findById?(id: string): Promise<T | null>
|
|
10
|
-
findByIds?(ids: Array<string>): Promise<T[]>
|
|
11
|
-
findOneBy?(field: string, value: any): Promise<T | null>
|
|
12
|
-
findBy?(field: string, value: any): Promise<T[]>
|
|
13
|
-
fetchAll?(): Promise<T[]>
|
|
14
|
-
search?(value: any, limit ?: number): Promise<T[]>
|
|
15
|
-
}
|
|
16
|
-
export type { ICrudRepository }
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import type { IDraxPaginateOptions, IDraxPaginateResult } from "@drax/common-share";
|
|
2
|
-
interface ICrudRepository<T, C, U> {
|
|
3
|
-
paginate(options: IDraxPaginateOptions): Promise<IDraxPaginateResult<T>>;
|
|
4
|
-
create(input: C): Promise<T>;
|
|
5
|
-
update(id: string, input: U): Promise<T>;
|
|
6
|
-
delete(id: string): Promise<any>;
|
|
7
|
-
findById?(id: string): Promise<T | null>;
|
|
8
|
-
findByIds?(ids: Array<string>): Promise<T[]>;
|
|
9
|
-
findOneBy?(field: string, value: any): Promise<T | null>;
|
|
10
|
-
findBy?(field: string, value: any): Promise<T[]>;
|
|
11
|
-
fetchAll?(): Promise<T[]>;
|
|
12
|
-
search?(value: any, limit?: number): Promise<T[]>;
|
|
13
|
-
}
|
|
14
|
-
export type { ICrudRepository };
|
|
15
|
-
//# sourceMappingURL=ICrudRepository.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ICrudRepository.d.ts","sourceRoot":"","sources":["../../src/interfaces/ICrudRepository.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,oBAAoB,EAAE,mBAAmB,EAAC,MAAM,oBAAoB,CAAC;AAElF,UAAU,eAAe,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC;IAC3B,QAAQ,CAAC,OAAO,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAA;IACxE,MAAM,CAAC,KAAK,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAA;IAC5B,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAA;IACxC,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,CAAA;IAEhC,QAAQ,CAAC,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,CAAA;IACxC,SAAS,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC,CAAA;IAC5C,SAAS,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,CAAA;IACxD,MAAM,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC,CAAA;IAChD,QAAQ,CAAC,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,CAAA;IACzB,MAAM,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,KAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC,CAAA;CACrD;AACD,YAAY,EAAE,eAAe,EAAE,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"IEntityPermission.d.ts","sourceRoot":"","sources":["../../src/interfaces/IEntityPermission.ts"],"names":[],"mappings":"AAAA,UAAU,iBAAiB;IACvB,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,MAAM,CAAA;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;CACxB;AAED,YAAY,EAAE,iBAAiB,EAAE,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"IEntityRepository.d.ts","sourceRoot":"","sources":["../../src/interfaces/IEntityRepository.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,oBAAoB,CAAC;AAClD,UAAU,iBAAiB,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAE,SAAQ,SAAS,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC;CAE1D;AACD,YAAY,EAAE,iBAAiB,EAAE,CAAA"}
|