@comasoft/nestjs 0.1.42 → 0.1.44
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 +2 -0
- package/dist/category/category.service.d.ts +6 -3
- package/dist/category/category.service.js +1 -1
- package/dist/database/entities/logs-audit.entity.js +1 -1
- package/dist/enums.common.d.ts +2 -1
- package/dist/enums.common.js +1 -1
- package/dist/notifications/services/email.service.js +1 -1
- package/dist/notifications/services/slack.service.d.ts +11 -1
- package/dist/notifications/services/slack.service.js +1 -1
- package/dist/services/file.service.d.ts +4 -4
- package/dist/services/file.service.js +1 -1
- package/dist/utils/pagination-qb.utils.js +1 -1
- package/package.json +1 -2
package/README.md
CHANGED
|
@@ -1,9 +1,12 @@
|
|
|
1
|
-
import { Repository } from 'typeorm';
|
|
1
|
+
import { DataSource, Repository } from 'typeorm';
|
|
2
2
|
import { Category } from '../database/entities';
|
|
3
3
|
import { CreateCategoryBaseDto, ResponseCategoriesBaseDto, ResponseCategoryBaseDto, UpdateCategoryBaseDto, UpdateCategorySortBaseDto } from './dto';
|
|
4
4
|
export declare class CategoryService {
|
|
5
|
-
|
|
6
|
-
|
|
5
|
+
protected readonly repository: Repository<Category>;
|
|
6
|
+
protected readonly dataSource: DataSource;
|
|
7
|
+
constructor(repository: Repository<Category>, dataSource: DataSource);
|
|
8
|
+
protected validateCategoryLimit(type: string): Promise<void>;
|
|
9
|
+
protected checkCategoryUsage(id: number): Promise<void>;
|
|
7
10
|
create(body: CreateCategoryBaseDto): Promise<ResponseCategoryBaseDto<string>>;
|
|
8
11
|
findAll(type: string): Promise<ResponseCategoriesBaseDto<string>>;
|
|
9
12
|
findOne(id: number): Promise<ResponseCategoryBaseDto<string>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e=this&&this.__decorate||function(e,t,o
|
|
1
|
+
var e=this&&this.__decorate||function(e,t,i,o){var r,n=arguments.length,s=n<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,i):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,i,o);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(s=(n<3?r(s):n>3?r(t,i,s):r(t,i))||s);return n>3&&s&&Object.defineProperty(t,i,s),s},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)},i=this&&this.__param||function(e,t){return function(i,o){t(i,o,e)}},o=this&&this.__awaiter||function(e,t,i,o){return new(i||(i=Promise))(function(r,n){function fulfilled(e){try{step(o.next(e))}catch(e){n(e)}}function rejected(e){try{step(o.throw(e))}catch(e){n(e)}}function step(e){e.done?r(e.value):function adopt(e){return e instanceof i?e:new i(function(t){t(e)})}(e.value).then(fulfilled,rejected)}step((o=o.apply(e,t||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.CategoryService=void 0;const r=require("@nestjs/common"),n=require("@nestjs/typeorm"),s=require("class-transformer"),a=require("typeorm"),d=require("../database/entities"),c=require("../shared/error-codes"),p=require("./dto");let u=class CategoryService{constructor(e,t){this.repository=e,this.dataSource=t}validateCategoryLimit(e){return o(this,void 0,void 0,function*(){throw new r.BadRequestException("validateCategoryLimit must be implemented in app service")})}checkCategoryUsage(e){return o(this,void 0,void 0,function*(){throw new r.BadRequestException("checkCategoryUsage must be implemented in app service")})}create(e){return o(this,void 0,void 0,function*(){const{type:t,name:i,description:o,slug:n}=e;yield this.validateCategoryLimit(t);if(yield this.repository.findOne({where:{type:t,name:i}}))throw new r.ConflictException({message:"Category name already exists",error_code:c.ErrorCode.CATEGORY_NAME_ALREADY_EXISTS});const a=(yield this.repository.count({where:{type:t}}))+1,d=yield this.repository.save(Object.assign(Object.assign({},e),{sort:a}));return(0,s.plainToClass)(p.ResponseCategoryBaseDto,d)})}findAll(e){return o(this,void 0,void 0,function*(){const t=yield this.repository.find({where:{type:e},order:{sort:"ASC"}});return(0,s.plainToClass)(p.ResponseCategoriesBaseDto,{items:t})})}findOne(e){return o(this,void 0,void 0,function*(){const t=yield this.repository.findOne({where:{id:e}});if(!t)throw new r.NotFoundException(`Category with ID ${e} not found`);return(0,s.plainToClass)(p.ResponseCategoryBaseDto,t)})}update(e,t){return o(this,void 0,void 0,function*(){const i=yield this.repository.findOne({where:{id:e}});if(!i)throw new r.NotFoundException(`Category with ID ${e} not found`);if(yield this.repository.findOne({where:{type:i.type,name:t.name,id:(0,a.Not)(e)}}))throw new r.ConflictException({message:"Category name already exists",error_code:c.ErrorCode.CATEGORY_NAME_ALREADY_EXISTS});yield this.repository.update(e,t);const o=yield this.repository.findOne({where:{id:e}});return(0,s.plainToClass)(p.ResponseCategoryBaseDto,o)})}remove(e){return o(this,void 0,void 0,function*(){if(!(yield this.repository.findOne({where:{id:e}})))throw new r.NotFoundException(`Category with ID ${e} not found`);yield this.checkCategoryUsage(e),yield this.repository.update(e,{is_active:!1,deleted_at:new Date})})}updateSort(e){return o(this,void 0,void 0,function*(){const{items:t,type:i}=e,o=yield this.repository.find({where:{type:i}});if(o.length!==t.length)throw new r.BadRequestException("Invalid items ids provided");const n=o.map(e=>{var i;return Object.assign(Object.assign({},e),{sort:(null===(i=t.find(t=>t.id===e.id))||void 0===i?void 0:i.sort)||e.sort})});yield this.repository.save(n)})}};exports.CategoryService=u,exports.CategoryService=u=e([(0,r.Injectable)(),i(0,(0,n.InjectRepository)(d.Category)),t("design:paramtypes",[a.Repository,a.DataSource])],u);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e=this&&this.__decorate||function(e,t,o,n){var r
|
|
1
|
+
var e=this&&this.__decorate||function(e,t,o,n){var i,r=arguments.length,d=r<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,o):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)d=Reflect.decorate(e,t,o,n);else for(var l=e.length-1;l>=0;l--)(i=e[l])&&(d=(r<3?i(d):r>3?i(t,o,d):i(t,o))||d);return r>3&&d&&Object.defineProperty(t,o,d),d},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)};Object.defineProperty(exports,"__esModule",{value:!0}),exports.LogsAudit=void 0;const o=require("typeorm"),n=require("../../enums.common");let i=class LogsAudit{};exports.LogsAudit=i,e([(0,o.PrimaryGeneratedColumn)(),t("design:type",Number)],i.prototype,"id",void 0),e([(0,o.Column)("char",{length:21}),t("design:type",String)],i.prototype,"uid",void 0),e([(0,o.Column)("varchar",{length:255}),t("design:type",String)],i.prototype,"name",void 0),e([(0,o.Column)("varchar",{length:50,nullable:!0}),t("design:type",String)],i.prototype,"entity",void 0),e([(0,o.Column)("int",{nullable:!0,comment:"-1: all, 0: none"}),t("design:type",Number)],i.prototype,"entity_id",void 0),e([(0,o.Column)("enum",{enum:n.AUDIT_ACTION,nullable:!0}),t("design:type",String)],i.prototype,"action",void 0),e([(0,o.Column)("int"),t("design:type",Number)],i.prototype,"user_id",void 0),e([(0,o.Column)("jsonb",{nullable:!0}),t("design:type",Object)],i.prototype,"changes",void 0),e([(0,o.Column)("varchar",{length:45,nullable:!0}),t("design:type",String)],i.prototype,"ip_address",void 0),e([(0,o.Column)("varchar",{length:255,nullable:!0}),t("design:type",String)],i.prototype,"user_agent",void 0),e([(0,o.Column)("varchar",{length:255,nullable:!0}),t("design:type",String)],i.prototype,"description",void 0),e([(0,o.Column)("timestamptz"),t("design:type",Date)],i.prototype,"occurred_at",void 0),e([(0,o.CreateDateColumn)({type:"timestamptz"}),t("design:type",Date)],i.prototype,"created_at",void 0),exports.LogsAudit=i=e([(0,o.Entity)("logs_audit"),(0,o.Index)(["uid"]),(0,o.Index)(["name","entity_id"]),(0,o.Index)(["user_id","name","entity_id"])],i);
|
package/dist/enums.common.d.ts
CHANGED
package/dist/enums.common.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var e,t,
|
|
1
|
+
var e,o,t,n,E,p,i;Object.defineProperty(exports,"__esModule",{value:!0}),exports.LIKE_TYPE=exports.NOTIFICATION_STATUS=exports.FILE_STATUS=exports.AUDIT_ACTION=exports.DEVICE_TYPE=exports.MIME_TYPE=exports.FILE_TYPE=void 0,function(e){e.IMAGE="IMAGE",e.VIDEO="VIDEO",e.DOCUMENT="DOCUMENT",e.AUDIO="AUDIO",e.OTHER="OTHER"}(e||(exports.FILE_TYPE=e={})),function(e){e.JPEG="image/jpeg",e.PNG="image/png",e.GIF="image/gif",e.PDF="application/pdf",e.DOC="application/msword",e.DOCX="application/vnd.openxmlformats-officedocument.wordprocessingml.document",e.XLS="application/vnd.ms-excel",e.XLSX="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",e.PPT="application/vnd.ms-powerpoint",e.PPTX="application/vnd.openxmlformats-officedocument.presentationml.presentation",e.TXT="text/plain",e.HTML="text/html",e.CSV="text/csv"}(o||(exports.MIME_TYPE=o={})),function(e){e.ANDROID="android",e.IOS="ios",e.PC="pc",e.MAC="mac",e.OTHER="other"}(t||(exports.DEVICE_TYPE=t={})),function(e){e.CREATE="create",e.READ="read",e.UPDATE="update",e.DELETE="delete",e.DOWNLOAD="download"}(n||(exports.AUDIT_ACTION=n={})),function(e){e.PENDING="pending",e.COMPLETED="completed",e.FAILED="failed",e.DELETED="deleted"}(E||(exports.FILE_STATUS=E={})),function(e){e.PENDING="pending",e.SENT="sent",e.READ="read",e.FAILED="failed"}(p||(exports.NOTIFICATION_STATUS=p={})),function(e){e.LIKE="like",e.DISLIKE="dislike",e.NONE="none"}(i||(exports.LIKE_TYPE=i={}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e=this&&this.__decorate||function(e,t,i,n){var s,
|
|
1
|
+
var e=this&&this.__decorate||function(e,t,i,n){var s,o=arguments.length,c=o<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,i):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)c=Reflect.decorate(e,t,i,n);else for(var r=e.length-1;r>=0;r--)(s=e[r])&&(c=(o<3?s(c):o>3?s(t,i,c):s(t,i))||c);return o>3&&c&&Object.defineProperty(t,i,c),c},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)},i=this&&this.__awaiter||function(e,t,i,n){return new(i||(i=Promise))(function(s,o){function fulfilled(e){try{step(n.next(e))}catch(e){o(e)}}function rejected(e){try{step(n.throw(e))}catch(e){o(e)}}function step(e){e.done?s(e.value):function adopt(e){return e instanceof i?e:new i(function(t){t(e)})}(e.value).then(fulfilled,rejected)}step((n=n.apply(e,t||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.EmailService=void 0;const n=require("@aws-sdk/client-ses"),s=require("@nestjs/common"),o=require("@nestjs/config");let c=class EmailService{constructor(e){this.configService=e,"aws"===this.configService.get("EMAIL_PROVIDER")&&(this.sesClient=new n.SESClient({region:this.configService.get("AWS_REGION"),credentials:{accessKeyId:this.configService.get("AWS_ACCESS_KEY_ID"),secretAccessKey:this.configService.get("AWS_SECRET_ACCESS_KEY")}}))}send(e){return i(this,void 0,void 0,function*(){const t=this.configService.get("EMAIL_PROVIDER");if(!t||!this.configService.get("EMAIL_FROM"))throw new Error("EMAIL_PROVIDER or EMAIL_FROM is not set");return"aws"===t?this.sendAws(e):[]})}sendAws(e){return i(this,void 0,void 0,function*(){if("production"===process.env.NODE_ENV){console.log("sendAws",e);for(const t of e){const e=new n.SendEmailCommand({Source:this.configService.get("EMAIL_NOREPLY_SOURCE"),Destination:{ToAddresses:[t.recipient]},Message:{Subject:{Data:t.subject,Charset:"UTF-8"},Body:{Html:{Data:t.text,Charset:"UTF-8"}}}}),i=yield this.sesClient.send(e);console.log(i)}}else console.log("sendAws",e)})}};exports.EmailService=c,exports.EmailService=c=e([(0,s.Injectable)(),t("design:paramtypes",[o.ConfigService])],c);
|
|
@@ -2,5 +2,15 @@ import { ConfigService } from '@nestjs/config';
|
|
|
2
2
|
export declare class SlackService {
|
|
3
3
|
private readonly configService;
|
|
4
4
|
constructor(configService: ConfigService);
|
|
5
|
-
send(channel: string, message: string): Promise<
|
|
5
|
+
send(channel: string, message: string): Promise<{
|
|
6
|
+
channel: string;
|
|
7
|
+
success: boolean;
|
|
8
|
+
message: string;
|
|
9
|
+
status: string;
|
|
10
|
+
} | {
|
|
11
|
+
channel: string;
|
|
12
|
+
success: boolean;
|
|
13
|
+
status: string;
|
|
14
|
+
message?: undefined;
|
|
15
|
+
}>;
|
|
6
16
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e=this&&this.__decorate||function(e,t,n,c){var r
|
|
1
|
+
var e=this&&this.__decorate||function(e,t,n,c){var o,r=arguments.length,i=r<3?t:null===c?c=Object.getOwnPropertyDescriptor(t,n):c;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,c);else for(var s=e.length-1;s>=0;s--)(o=e[s])&&(i=(r<3?o(i):r>3?o(t,n,i):o(t,n))||i);return r>3&&i&&Object.defineProperty(t,n,i),i},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)},n=this&&this.__awaiter||function(e,t,n,c){return new(n||(n=Promise))(function(o,r){function fulfilled(e){try{step(c.next(e))}catch(e){r(e)}}function rejected(e){try{step(c.throw(e))}catch(e){r(e)}}function step(e){e.done?o(e.value):function adopt(e){return e instanceof n?e:new n(function(t){t(e)})}(e.value).then(fulfilled,rejected)}step((c=c.apply(e,t||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.SlackService=void 0;const c=require("@nestjs/common"),o=require("@nestjs/config");let r=class SlackService{constructor(e){this.configService=e}send(e,t){return n(this,void 0,void 0,function*(){if(!this.configService.get("SLACK_WEBHOOK_URL"))throw new Error("SLACK_CHANNEL or SLACK_WEBHOOK_URL is not set");const n=yield fetch(this.configService.get("SLACK_WEBHOOK_URL"),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({text:t})});return n.ok?{channel:e,success:!0,status:"sent"}:{channel:e,success:!1,message:n.statusText,status:"sent"}})}};exports.SlackService=r,exports.SlackService=r=e([(0,c.Injectable)(),t("design:paramtypes",[o.ConfigService])],r);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { DataSource, EntityManager } from 'typeorm';
|
|
2
2
|
import { S3Service } from '../aws/aws-s3.service';
|
|
3
|
-
import { FILE_STATUS } from '../enums.common';
|
|
4
3
|
import { File } from '../database/entities';
|
|
4
|
+
import { FILE_STATUS } from '../enums.common';
|
|
5
5
|
interface FileInput {
|
|
6
6
|
original_name: string;
|
|
7
7
|
file_name: string;
|
|
@@ -35,7 +35,7 @@ export declare class FileService {
|
|
|
35
35
|
target_id: number;
|
|
36
36
|
group_number?: number;
|
|
37
37
|
}): Promise<File[]>;
|
|
38
|
-
createPending({ target, user_id, files, manager, group_number
|
|
38
|
+
createPending({ target, user_id, files, manager, group_number }: CreateFileInput): Promise<({
|
|
39
39
|
sort: number;
|
|
40
40
|
group_number: number;
|
|
41
41
|
original_name: string;
|
|
@@ -49,7 +49,7 @@ export declare class FileService {
|
|
|
49
49
|
target_id: number;
|
|
50
50
|
user_id: number;
|
|
51
51
|
} & File)[]>;
|
|
52
|
-
statusCompleted({ target, target_id, user_id, file_ids, manager
|
|
53
|
-
softDelete({ target, target_id, user_id, delete_file_ids, manager
|
|
52
|
+
statusCompleted({ target, target_id, user_id, file_ids, manager }: StatusCompletedInput): Promise<void>;
|
|
53
|
+
softDelete({ target, target_id, user_id, delete_file_ids, manager }: SoftDeleteInput): Promise<void>;
|
|
54
54
|
}
|
|
55
55
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e=this&&this.__decorate||function(e,t,r,i){var n,s=arguments.length,a=s<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,r,i);else for(var o=e.length-1;o>=0;o--)(n=e[o])&&(a=(s<3?n(a):s>3?n(t,r,a):n(t,r))||a);return s>3&&a&&Object.defineProperty(t,r,a),a},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)},r=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}},i=this&&this.__awaiter||function(e,t,r,i){return new(r||(r=Promise))(function(n,s){function fulfilled(e){try{step(i.next(e))}catch(e){s(e)}}function rejected(e){try{step(i.throw(e))}catch(e){s(e)}}function step(e){e.done?n(e.value):function adopt(e){return e instanceof r?e:new r(function(t){t(e)})}(e.value).then(fulfilled,rejected)}step((i=i.apply(e,t||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.FileService=void 0;const n=require("@nestjs/common"),s=require("typeorm"),a=require("../aws/aws-s3.service"),o=require("../
|
|
1
|
+
var e=this&&this.__decorate||function(e,t,r,i){var n,s=arguments.length,a=s<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)a=Reflect.decorate(e,t,r,i);else for(var o=e.length-1;o>=0;o--)(n=e[o])&&(a=(s<3?n(a):s>3?n(t,r,a):n(t,r))||a);return s>3&&a&&Object.defineProperty(t,r,a),a},t=this&&this.__metadata||function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)},r=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}},i=this&&this.__awaiter||function(e,t,r,i){return new(r||(r=Promise))(function(n,s){function fulfilled(e){try{step(i.next(e))}catch(e){s(e)}}function rejected(e){try{step(i.throw(e))}catch(e){s(e)}}function step(e){e.done?n(e.value):function adopt(e){return e instanceof r?e:new r(function(t){t(e)})}(e.value).then(fulfilled,rejected)}step((i=i.apply(e,t||[])).next())})};Object.defineProperty(exports,"__esModule",{value:!0}),exports.FileService=void 0;const n=require("@nestjs/common"),s=require("typeorm"),a=require("../aws/aws-s3.service"),o=require("../database/entities"),c=require("../enums.common");let u=class FileService{constructor(e,t){this.dataSource=e,this.s3Service=t}findAll(e){return i(this,arguments,void 0,function*({target:e,target_id:t,group_number:r}){return this.dataSource.getRepository(o.File).find({where:{target:e,target_id:t,group_number:r}})})}createPending(e){return i(this,arguments,void 0,function*({target:e,user_id:t,files:r,manager:i,group_number:n}){const s=i?i.getRepository(o.File):this.dataSource.getRepository(o.File),a=yield s.save(r.map((r,i)=>{var s;return Object.assign(Object.assign({status:c.FILE_STATUS.PENDING,target:e,target_id:0,user_id:t},r),{sort:null!==(s=r.sort)&&void 0!==s?s:i+1,group_number:n})}));return a})}statusCompleted(e){return i(this,arguments,void 0,function*({target:e,target_id:t,user_id:r,file_ids:i,manager:n}){const a=n?n.getRepository(o.File):this.dataSource.getRepository(o.File);yield a.update({target:e,id:(0,s.In)(i)},{status:c.FILE_STATUS.COMPLETED,target_id:t})})}softDelete(e){return i(this,arguments,void 0,function*({target:e,target_id:t,user_id:r,delete_file_ids:i,manager:n}){const a=n?n.getRepository(o.File):this.dataSource.getRepository(o.File),u=yield a.find({where:{target:e,user_id:r,target_id:t,id:(0,s.In)(i)}});yield this.s3Service.deleteObjectsByKeys(u.map(e=>this.s3Service.getFileKey(e))),yield a.update({id:(0,s.In)(u.map(e=>e.id))},{status:c.FILE_STATUS.DELETED,deleted_at:new Date,is_active:!1})})}};exports.FileService=u,exports.FileService=u=e([(0,n.Injectable)(),r(1,(0,n.Inject)((0,n.forwardRef)(()=>a.S3Service))),t("design:paramtypes",[s.DataSource,a.S3Service])],u);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
function validateAndParseDate(e){if(!/^\d{8}T\d{6}Z$/.test(e))throw new Error("Invalid date format. Use YYYYMMDDTHHMMSSZ (e.g., 20250122T150000Z)");const n=e.substring(0,4),t=e.substring(4,6),r=e.substring(6,8),a=e.substring(9,11),i=e.substring(11,13),s=e.substring(13,15),l=new Date(`${n}-${t}-${r}T${a}:${i}:${s}Z`);if(isNaN(l.getTime()))throw new Error("Invalid date");return l}Object.defineProperty(exports,"__esModule",{value:!0}),exports.applyFiltersAndSorting=function applyFiltersAndSorting(n,t){const{_keyword:r,_group:a,_sort:i,aliasName:s="a",keywordFields:l=["name"],groupFields:o=[]}=t;return function applyKeywordFilter(e,n,t,r){if(n){const a=r.map(e=>`${t}.${e} LIKE :keyword`);e.andWhere(`(${a.join(" OR ")})`,{keyword
|
|
1
|
+
function validateAndParseDate(e){if(!/^\d{8}T\d{6}Z$/.test(e))throw new Error("Invalid date format. Use YYYYMMDDTHHMMSSZ (e.g., 20250122T150000Z)");const n=e.substring(0,4),t=e.substring(4,6),r=e.substring(6,8),a=e.substring(9,11),i=e.substring(11,13),s=e.substring(13,15),l=new Date(`${n}-${t}-${r}T${a}:${i}:${s}Z`);if(isNaN(l.getTime()))throw new Error("Invalid date");return l}Object.defineProperty(exports,"__esModule",{value:!0}),exports.applyFiltersAndSorting=function applyFiltersAndSorting(n,t){const{_keyword:r,_group:a,_sort:i,aliasName:s="a",keywordFields:l=["name"],groupFields:o=[]}=t;return function applyKeywordFilter(e,n,t,r){if(n){const a=r.map(e=>`${t}.${e} LIKE :keyword`);e.andWhere(`(${a.join(" OR ")})`,{keyword:`${n}`})}}(n,r,s,l),function applyGroupFilter(n,t,r,a){if(!t)return;if(0===a.length)return;const i=t.split("|");if(i.some(e=>{const[n]=e.split("-");return!a.includes(n)}))throw new Error("Invalid field detected in group filter");const s=[],l={};i.forEach((n,t)=>{const[a,i]=n.split(/-(.+)/),o=a.includes(".")?a:`${r}.${a}`;let $;$=i.includes("__")?a.includes("_at")||a.includes("_date")?e.handleDateRange(o,i,t):e.handleNumberRange(o,i,t):e.handleEquals(o,i,t),$.condition&&(s.push($.condition),Object.assign(l,$.parameters))}),s.length>0&&n.andWhere(`(${s.join(" AND ")})`,l)}(n,a,s,o),function applySorting(e,n,t){if(n){n.split("|").forEach((n,r)=>{const[a,i]=n.split("-"),s=i.toUpperCase();if("ASC"!==s&&"DESC"!==s)throw new Error(`Invalid sort order: ${i}`);0===r?e.orderBy(`${t}.${a}`,s):e.addOrderBy(`${t}.${a}`,s)})}else{Object.keys(e.expressionMap.orderBys).length>0||e.orderBy(`${t}.id`,"DESC")}}(n,i,s),n};const e={handleEquals:(e,n,t)=>({condition:`${e} = :${e}${t}`,parameters:{[`${e}${t}`]:n}}),handleNumberRange(e,n,t){const[r,a]=n.split("__").map(e=>""===e?null:Number(e)),i=[],s={};return null!==r&&null!==a?(i.push(`${e} BETWEEN :${e}Min${t} AND :${e}Max${t}`),s[`${e}Min${t}`]=r,s[`${e}Max${t}`]=a):null!==r?(i.push(`${e} >= :${e}Min${t}`),s[`${e}Min${t}`]=r):null!==a&&(i.push(`${e} <= :${e}Max${t}`),s[`${e}Max${t}`]=a),{condition:i.join(" AND "),parameters:s}},handleDateRange(e,n,t){const[r,a]=n.split("__").map(e=>""===e?null:e),i=[],s={};return null!==r&&null!==a?(i.push(`${e} BETWEEN :${e}Min${t} AND :${e}Max${t}`),s[`${e}Min${t}`]=validateAndParseDate(r),s[`${e}Max${t}`]=validateAndParseDate(a)):null!==r?(i.push(`${e} >= :${e}Min${t}`),s[`${e}Min${t}`]=validateAndParseDate(r)):null!==a&&(i.push(`${e} <= :${e}Max${t}`),s[`${e}Max${t}`]=validateAndParseDate(a)),{condition:i.join(" AND "),parameters:s}}};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@comasoft/nestjs",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.44",
|
|
4
4
|
"description": "",
|
|
5
5
|
"private": false,
|
|
6
6
|
"exports": {
|
|
@@ -22,7 +22,6 @@
|
|
|
22
22
|
},
|
|
23
23
|
"scripts": {
|
|
24
24
|
"build": "tsc -p tsconfig.build.json",
|
|
25
|
-
"uglify": "find dist -name '*.js' -exec terser {} --compress --mangle --keep-fnames --module -o {};",
|
|
26
25
|
"lint": "eslint 'lib/**/*.ts' --fix,",
|
|
27
26
|
"prepublish:npm": "npm run build",
|
|
28
27
|
"publish:npm": "npm publish --access public",
|