@comasoft/nestjs 0.1.52 → 0.1.54

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.
@@ -1 +1 @@
1
- Object.defineProperty(exports,"__esModule",{value:!0}),exports.MAX_FILE_SIZE=exports.ALLOWED_MIME_TYPES=exports.IMAGE_PROCESSOR_CONFIG=void 0,exports.IMAGE_PROCESSOR_CONFIG={sizes:{small:{width:150,height:150,quality:80},medium:{width:300,height:300,quality:85},large:{width:800,height:800,quality:90}},outputFormat:"webp"},exports.ALLOWED_MIME_TYPES=["image/jpeg","image/png","image/webp"],exports.MAX_FILE_SIZE=10485760;
1
+ Object.defineProperty(exports,"__esModule",{value:!0}),exports.MAX_FILE_SIZE=exports.ALLOWED_MIME_TYPES=exports.IMAGE_PROCESSOR_CONFIG=void 0,exports.IMAGE_PROCESSOR_CONFIG={sizes:{small:{width:150,height:150,quality:80},medium:{width:300,height:300,quality:85},large:{width:800,height:800,quality:90}},outputFormat:"webp"},exports.ALLOWED_MIME_TYPES=["image/jpeg","image/png","image/webp"],exports.MAX_FILE_SIZE=52428800;
@@ -1 +1 @@
1
- var e=this&&this.__decorate||function(e,t,i,n){var o,r=arguments.length,d=r<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,i):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)d=Reflect.decorate(e,t,i,n);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(d=(r<3?o(d):r>3?o(t,i,d):o(t,i))||d);return r>3&&d&&Object.defineProperty(t,i,d),d},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,n){t(i,n,e)}},n=this&&this.__awaiter||function(e,t,i,n){return new(i||(i=Promise))(function(o,r){function fulfilled(e){try{step(n.next(e))}catch(e){r(e)}}function rejected(e){try{step(n.throw(e))}catch(e){r(e)}}function step(e){e.done?o(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.CommentService=void 0;const o=require("@nestjs/common"),r=require("@nestjs/typeorm"),d=require("class-transformer"),a=require("typeorm"),s=require("../database/entities"),m=require("../utils"),c=require("./dto");let u=class CommentService{constructor(e,t){this.repository=e,this.dataSource=t}resolveTargetId(e,t,i){return n(this,void 0,void 0,function*(){if(t)return t;if(!i)throw new o.BadRequestException("Either target_id or target_uid is required");throw new o.BadRequestException("resolveTargetId must be implemented in app service")})}updateTargetCommentCount(e,t,i,r){return n(this,void 0,void 0,function*(){throw new o.BadRequestException("updateTargetCommentCount must be implemented in app service")})}calculateTreeStructure(e,t,i){return n(this,void 0,void 0,function*(){if(i){const n=yield this.repository.findOne({where:{id:i,target:e,target_id:t,deleted_at:null}});if(!n)throw new o.NotFoundException("Parent comment not found");const r=yield this.repository.createQueryBuilder("comments").select("MAX(comments.sort)","maxSort").where("comments.target = :target",{target:e}).andWhere("comments.target_id = :target_id",{target_id:t}).andWhere("comments.group_id = :group_id",{group_id:n.group_id}).andWhere("comments.deleted_at IS NULL").getRawOne();return{group_id:n.group_id,depth:n.depth+1,sort:((null==r?void 0:r.maxSort)||0)+1}}{const i=yield this.repository.createQueryBuilder("comments").select("MAX(comments.sort)","maxSort").where("comments.target = :target",{target:e}).andWhere("comments.target_id = :target_id",{target_id:t}).andWhere("comments.parent_id IS NULL").andWhere("comments.deleted_at IS NULL").getRawOne();return{group_id:0,depth:0,sort:((null==i?void 0:i.maxSort)||0)+1}}})}create(e,t){return n(this,void 0,void 0,function*(){const{target:i,target_id:o,target_uid:r,parent_id:a,content:m,meta:u}=t,l=yield this.resolveTargetId(i,o,r),p=yield this.calculateTreeStructure(i,l,a),_=yield this.dataSource.transaction(t=>n(this,void 0,void 0,function*(){const n=yield t.save(s.Comment,Object.assign(Object.assign({target:i,target_id:l,parent_id:a},p),{user_id:e,content:m,meta:u}));return a||(yield t.update(s.Comment,n.id,{group_id:n.id})),a&&(yield t.increment(s.Comment,{id:a},"cnt_replies",1)),yield this.updateTargetCommentCount(t,i,l,1),yield t.findOne(s.Comment,{where:{id:n.id}})}));return(0,d.plainToClass)(c.ResponseCommentBaseDto,_)})}paginateRaw(e,t,i){return n(this,void 0,void 0,function*(){const{page:n,limit:o}=t,[r,d]=yield Promise.all([e.skip((n-1)*o).take(o).getRawMany(),e.getCount()]),a=Math.ceil(d/o);return{items:r.map(i),pagination:{page:n,limit:o,count:r.length,count_total:d,count_page:a}}})}findAll(e,t,i,o){return n(this,void 0,void 0,function*(){const{_page:n,_limit:r,_keyword:a,_group:s,_sort:u}=e;let l=this.repository.createQueryBuilder("comments").leftJoin("users","user","comments.user_id = user.id").addSelect(["user.id","user.uid","user.name","user.profile_image","user.info_department","user.info_position"]).where("comments.deleted_at IS NULL");if(t&&l.andWhere("comments.target = :target",{target:t}),i||o){const e=t?yield this.resolveTargetId(t,i,o):i;l.andWhere("comments.target_id = :target_id",{target_id:e})}l=(0,m.applyFiltersAndSorting)(l,{_keyword:a,_group:s,_sort:u,keywordFields:["content"],aliasName:"comments"}),u||l.orderBy("comments.group_id","ASC").addOrderBy("comments.sort","ASC");const p=yield this.paginateRaw(l,{page:n,limit:r},e=>({id:e.comments_id,target:e.comments_target,target_id:e.comments_target_id,parent_id:e.comments_parent_id,group_id:e.comments_group_id,depth:e.comments_depth,sort:e.comments_sort,content:e.comments_content,meta:e.comments_meta,cnt_likes:e.comments_cnt_likes,cnt_replies:e.comments_cnt_replies,modified_at:e.comments_modified_at,created_at:e.comments_created_at,updated_at:e.comments_updated_at,user:{id:e.user_id,uid:e.user_uid,name:e.user_name,profile_image:e.user_profile_image,info_department:e.user_info_department,info_position:e.user_info_position}}));return(0,d.plainToClass)(c.ResponseCommentsBaseDto,p)})}update(e,t,i){return n(this,void 0,void 0,function*(){const n=yield this.repository.findOne({where:{id:t,deleted_at:null}});if(!n)throw new o.NotFoundException(`Comment with ID ${t} not found`);if(n.user_id!==e)throw new o.BadRequestException("You can only update your own comments");yield this.repository.update(t,Object.assign(Object.assign({},i),{modified_at:new Date}))})}remove(e,t){return n(this,void 0,void 0,function*(){const i=yield this.repository.findOne({where:{id:t,deleted_at:null}});if(!i)throw new o.NotFoundException(`Comment with ID ${t} not found`);if(i.user_id!==e)throw new o.BadRequestException("You can only delete your own comments");yield this.dataSource.transaction(e=>n(this,void 0,void 0,function*(){yield e.softDelete(s.Comment,t),yield e.update(s.Comment,t,{content:""}),i.parent_id&&(yield e.decrement(s.Comment,{id:i.parent_id},"cnt_replies",1)),yield this.updateTargetCommentCount(e,i.target,i.target_id,-1)}))})}};exports.CommentService=u,exports.CommentService=u=e([(0,o.Injectable)(),i(0,(0,r.InjectRepository)(s.Comment)),t("design:paramtypes",[a.Repository,a.DataSource])],u);
1
+ var e=this&&this.__decorate||function(e,t,i,n){var o,r=arguments.length,d=r<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,i):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)d=Reflect.decorate(e,t,i,n);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(d=(r<3?o(d):r>3?o(t,i,d):o(t,i))||d);return r>3&&d&&Object.defineProperty(t,i,d),d},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,n){t(i,n,e)}},n=this&&this.__awaiter||function(e,t,i,n){return new(i||(i=Promise))(function(o,r){function fulfilled(e){try{step(n.next(e))}catch(e){r(e)}}function rejected(e){try{step(n.throw(e))}catch(e){r(e)}}function step(e){e.done?o(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.CommentService=void 0;const o=require("@nestjs/common"),r=require("@nestjs/typeorm"),d=require("class-transformer"),a=require("typeorm"),s=require("../database/entities"),m=require("../utils"),c=require("./dto");let u=class CommentService{constructor(e,t){this.repository=e,this.dataSource=t}resolveTargetId(e,t,i){return n(this,void 0,void 0,function*(){if(t)return t;if(!i)throw new o.BadRequestException("Either target_id or target_uid is required");throw new o.BadRequestException("resolveTargetId must be implemented in app service")})}updateTargetCommentCount(e,t,i,r){return n(this,void 0,void 0,function*(){throw new o.BadRequestException("updateTargetCommentCount must be implemented in app service")})}calculateTreeStructure(e,t,i){return n(this,void 0,void 0,function*(){if(i){const n=yield this.repository.findOne({where:{id:i,target:e,target_id:t,deleted_at:null}});if(!n)throw new o.NotFoundException("Parent comment not found");const r=yield this.repository.createQueryBuilder("comments").select("MAX(comments.sort)","maxSort").where("comments.target = :target",{target:e}).andWhere("comments.target_id = :target_id",{target_id:t}).andWhere("comments.group_id = :group_id",{group_id:n.group_id}).andWhere("comments.deleted_at IS NULL").getRawOne();return{group_id:n.group_id,depth:n.depth+1,sort:((null==r?void 0:r.maxSort)||0)+1}}{const i=yield this.repository.createQueryBuilder("comments").select("MAX(comments.sort)","maxSort").where("comments.target = :target",{target:e}).andWhere("comments.target_id = :target_id",{target_id:t}).andWhere("comments.parent_id IS NULL").andWhere("comments.deleted_at IS NULL").getRawOne();return{group_id:0,depth:0,sort:((null==i?void 0:i.maxSort)||0)+1}}})}create(e,t){return n(this,void 0,void 0,function*(){const{target:i,target_id:o,target_uid:r,parent_id:a,content:m,meta:u}=t,l=yield this.resolveTargetId(i,o,r),p=yield this.calculateTreeStructure(i,l,a),_=yield this.dataSource.transaction(t=>n(this,void 0,void 0,function*(){const n=yield t.save(s.Comment,Object.assign(Object.assign({target:i,target_id:l,parent_id:a},p),{user_id:e,content:m,meta:u}));return a||(yield t.update(s.Comment,n.id,{group_id:n.id})),a&&(yield t.increment(s.Comment,{id:a},"cnt_replies",1)),yield this.updateTargetCommentCount(t,i,l,1),yield t.findOne(s.Comment,{where:{id:n.id}})}));return(0,d.plainToClass)(c.ResponseCommentBaseDto,_)})}paginateRaw(e,t,i){return n(this,void 0,void 0,function*(){const{page:n,limit:o}=t,[r,d]=yield Promise.all([e.skip((n-1)*o).take(o).getRawMany(),e.getCount()]),a=Math.ceil(d/o);return{items:r.map(i),pagination:{page:n,limit:o,count:r.length,count_total:d,count_page:a}}})}findAll(e,t,i,o){return n(this,void 0,void 0,function*(){const{_page:n=1,_limit:r=10,_keyword:a,_group:s,_sort:u}=e;let l=this.repository.createQueryBuilder("comments").leftJoin("users","user","comments.user_id = user.id").addSelect(["user.id","user.uid","user.name","user.profile_image","user.info_department","user.info_position"]).where("comments.deleted_at IS NULL");if(t&&l.andWhere("comments.target = :target",{target:t}),i||o){const e=t?yield this.resolveTargetId(t,i,o):i;l.andWhere("comments.target_id = :target_id",{target_id:e})}l=(0,m.applyFiltersAndSorting)(l,{_keyword:a,_group:s,_sort:u,keywordFields:["content"],aliasName:"comments"}),u||l.orderBy("comments.group_id","ASC").addOrderBy("comments.sort","ASC");const p=yield this.paginateRaw(l,{page:n,limit:r},e=>({id:e.comments_id,target:e.comments_target,target_id:e.comments_target_id,parent_id:e.comments_parent_id,group_id:e.comments_group_id,depth:e.comments_depth,sort:e.comments_sort,content:e.comments_content,meta:e.comments_meta,cnt_likes:e.comments_cnt_likes,cnt_replies:e.comments_cnt_replies,modified_at:e.comments_modified_at,created_at:e.comments_created_at,updated_at:e.comments_updated_at,user:{id:e.user_id,uid:e.user_uid,name:e.user_name,profile_image:e.user_profile_image,info_department:e.user_info_department,info_position:e.user_info_position}}));return(0,d.plainToClass)(c.ResponseCommentsBaseDto,p)})}update(e,t,i){return n(this,void 0,void 0,function*(){const n=yield this.repository.findOne({where:{id:t,deleted_at:null}});if(!n)throw new o.NotFoundException(`Comment with ID ${t} not found`);if(n.user_id!==e)throw new o.BadRequestException("You can only update your own comments");yield this.repository.update(t,Object.assign(Object.assign({},i),{modified_at:new Date}))})}remove(e,t){return n(this,void 0,void 0,function*(){const i=yield this.repository.findOne({where:{id:t,deleted_at:null}});if(!i)throw new o.NotFoundException(`Comment with ID ${t} not found`);if(i.user_id!==e)throw new o.BadRequestException("You can only delete your own comments");yield this.dataSource.transaction(e=>n(this,void 0,void 0,function*(){yield e.softDelete(s.Comment,t),yield e.update(s.Comment,t,{content:""}),i.parent_id&&(yield e.decrement(s.Comment,{id:i.parent_id},"cnt_replies",1)),yield this.updateTargetCommentCount(e,i.target,i.target_id,-1)}))})}};exports.CommentService=u,exports.CommentService=u=e([(0,o.Injectable)(),i(0,(0,r.InjectRepository)(s.Comment)),t("design:paramtypes",[a.Repository,a.DataSource])],u);
@@ -5,6 +5,7 @@ export declare class LogsAudit {
5
5
  name: string;
6
6
  entity: string;
7
7
  entity_id: number;
8
+ entity_ids?: string[];
8
9
  action: AUDIT_ACTION;
9
10
  user_id: number;
10
11
  changes?: Record<string, any>;
@@ -1 +1 @@
1
- var e=this&&this.__decorate||function(e,t,o,n){var i,r=arguments.length,l=r<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,o):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)l=Reflect.decorate(e,t,o,n);else for(var d=e.length-1;d>=0;d--)(i=e[d])&&(l=(r<3?i(l):r>3?i(t,o,l):i(t,o))||l);return r>3&&l&&Object.defineProperty(t,o,l),l},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)("jsonb",{nullable:!0}),t("design:type",Object)],i.prototype,"meta",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);
1
+ var e=this&&this.__decorate||function(e,t,o,n){var i,r=arguments.length,l=r<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,o):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)l=Reflect.decorate(e,t,o,n);else for(var d=e.length-1;d>=0;d--)(i=e[d])&&(l=(r<3?i(l):r>3?i(t,o,l):i(t,o))||l);return r>3&&l&&Object.defineProperty(t,o,l),l},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)("jsonb",{nullable:!0}),t("design:type",Array)],i.prototype,"entity_ids",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)("jsonb",{nullable:!0}),t("design:type",Object)],i.prototype,"meta",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);
@@ -5,6 +5,7 @@ export declare class LogsEvent {
5
5
  name: string;
6
6
  entity: string;
7
7
  entity_id: number;
8
+ entity_ids?: string[];
8
9
  action: AUDIT_ACTION;
9
10
  user_id: number;
10
11
  changes?: Record<string, any>;
@@ -1 +1 @@
1
- var e=this&&this.__decorate||function(e,t,o,n){var r,i=arguments.length,l=i<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,o):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)l=Reflect.decorate(e,t,o,n);else for(var p=e.length-1;p>=0;p--)(r=e[p])&&(l=(i<3?r(l):i>3?r(t,o,l):r(t,o))||l);return i>3&&l&&Object.defineProperty(t,o,l),l},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.LogsEvent=void 0;const o=require("typeorm"),n=require("../../enums.common");let r=class LogsEvent{};exports.LogsEvent=r,e([(0,o.PrimaryGeneratedColumn)(),t("design:type",Number)],r.prototype,"id",void 0),e([(0,o.Column)("char",{length:21}),t("design:type",String)],r.prototype,"uid",void 0),e([(0,o.Column)("varchar",{length:255}),t("design:type",String)],r.prototype,"name",void 0),e([(0,o.Column)("varchar",{length:50,nullable:!0}),t("design:type",String)],r.prototype,"entity",void 0),e([(0,o.Column)("int",{nullable:!0}),t("design:type",Number)],r.prototype,"entity_id",void 0),e([(0,o.Column)("enum",{enum:n.AUDIT_ACTION,nullable:!0}),t("design:type",String)],r.prototype,"action",void 0),e([(0,o.Column)("int",{nullable:!0}),t("design:type",Number)],r.prototype,"user_id",void 0),e([(0,o.Column)("jsonb",{nullable:!0}),t("design:type",Object)],r.prototype,"changes",void 0),e([(0,o.Column)("varchar",{length:45,nullable:!0}),t("design:type",String)],r.prototype,"ip_address",void 0),e([(0,o.Column)("varchar",{length:255,nullable:!0}),t("design:type",String)],r.prototype,"user_agent",void 0),e([(0,o.Column)("varchar",{length:255,nullable:!0}),t("design:type",String)],r.prototype,"description",void 0),e([(0,o.Column)("jsonb",{nullable:!0}),t("design:type",Object)],r.prototype,"meta",void 0),e([(0,o.Column)("timestamptz"),t("design:type",Date)],r.prototype,"occurred_at",void 0),e([(0,o.CreateDateColumn)({type:"timestamptz"}),t("design:type",Date)],r.prototype,"created_at",void 0),exports.LogsEvent=r=e([(0,o.Entity)("logs_event")],r);
1
+ var e=this&&this.__decorate||function(e,t,o,n){var r,i=arguments.length,l=i<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,o):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)l=Reflect.decorate(e,t,o,n);else for(var p=e.length-1;p>=0;p--)(r=e[p])&&(l=(i<3?r(l):i>3?r(t,o,l):r(t,o))||l);return i>3&&l&&Object.defineProperty(t,o,l),l},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.LogsEvent=void 0;const o=require("typeorm"),n=require("../../enums.common");let r=class LogsEvent{};exports.LogsEvent=r,e([(0,o.PrimaryGeneratedColumn)(),t("design:type",Number)],r.prototype,"id",void 0),e([(0,o.Column)("char",{length:21}),t("design:type",String)],r.prototype,"uid",void 0),e([(0,o.Column)("varchar",{length:255}),t("design:type",String)],r.prototype,"name",void 0),e([(0,o.Column)("varchar",{length:50,nullable:!0}),t("design:type",String)],r.prototype,"entity",void 0),e([(0,o.Column)("int",{nullable:!0}),t("design:type",Number)],r.prototype,"entity_id",void 0),e([(0,o.Column)("jsonb",{nullable:!0}),t("design:type",Array)],r.prototype,"entity_ids",void 0),e([(0,o.Column)("enum",{enum:n.AUDIT_ACTION,nullable:!0}),t("design:type",String)],r.prototype,"action",void 0),e([(0,o.Column)("int",{nullable:!0}),t("design:type",Number)],r.prototype,"user_id",void 0),e([(0,o.Column)("jsonb",{nullable:!0}),t("design:type",Object)],r.prototype,"changes",void 0),e([(0,o.Column)("varchar",{length:45,nullable:!0}),t("design:type",String)],r.prototype,"ip_address",void 0),e([(0,o.Column)("varchar",{length:255,nullable:!0}),t("design:type",String)],r.prototype,"user_agent",void 0),e([(0,o.Column)("varchar",{length:255,nullable:!0}),t("design:type",String)],r.prototype,"description",void 0),e([(0,o.Column)("jsonb",{nullable:!0}),t("design:type",Object)],r.prototype,"meta",void 0),e([(0,o.Column)("timestamptz"),t("design:type",Date)],r.prototype,"occurred_at",void 0),e([(0,o.CreateDateColumn)({type:"timestamptz"}),t("design:type",Date)],r.prototype,"created_at",void 0),exports.LogsEvent=r=e([(0,o.Entity)("logs_event")],r);
@@ -1 +1 @@
1
- var e=this&&this.__decorate||function(e,t,i,o){var n,r=arguments.length,s=r<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--)(n=e[a])&&(s=(r<3?n(s):r>3?n(t,i,s):n(t,i))||s);return r>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(n,r){function fulfilled(e){try{step(o.next(e))}catch(e){r(e)}}function rejected(e){try{step(o.throw(e))}catch(e){r(e)}}function step(e){e.done?n(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.EventStorageService=void 0;const n=require("@nestjs/common"),r=require("@nestjs/typeorm"),s=require("nanoid"),a=require("typeorm"),u=require("../../database/entities");let d=class EventStorageService{constructor(e,t,i){this.eventLogRepository=e,this.auditLogRepository=t,this.dataSource=i}store(e){return o(this,void 0,void 0,function*(){var t,i,o;const n=this.eventLogRepository.create({uid:e.uid||(0,s.nanoid)(),name:e.name,user_id:(null===(t=e.user)||void 0===t?void 0:t.user_id)||0,ip_address:null===(i=e.user)||void 0===i?void 0:i.ip_address,user_agent:null===(o=e.user)||void 0===o?void 0:o.user_agent,occurred_at:e.timestamp||new Date});yield this.eventLogRepository.save(n)})}storeAuditEvent(e){return o(this,void 0,void 0,function*(){yield this.dataSource.transaction(t=>o(this,void 0,void 0,function*(){var i,o,n;const r=t.create(u.LogsAudit,{uid:e.uid||(0,s.nanoid)(),name:e.name,user_id:(null===(i=e.user)||void 0===i?void 0:i.user_id)||0,entity:e.entity,entity_id:e.entity_id,action:e.action,changes:e.changes,ip_address:null===(o=e.user)||void 0===o?void 0:o.ip_address,user_agent:null===(n=e.user)||void 0===n?void 0:n.user_agent,occurred_at:e.timestamp||new Date});yield t.save(r)}))})}};exports.EventStorageService=d,exports.EventStorageService=d=e([(0,n.Injectable)(),i(0,(0,r.InjectRepository)(u.LogsEvent)),i(1,(0,r.InjectRepository)(u.LogsAudit)),t("design:paramtypes",[a.Repository,a.Repository,a.DataSource])],d);
1
+ var e=this&&this.__decorate||function(e,t,i,n){var o,r=arguments.length,s=r<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,i):n;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,i,n);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(s=(r<3?o(s):r>3?o(t,i,s):o(t,i))||s);return r>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,n){t(i,n,e)}},n=this&&this.__awaiter||function(e,t,i,n){return new(i||(i=Promise))(function(o,r){function fulfilled(e){try{step(n.next(e))}catch(e){r(e)}}function rejected(e){try{step(n.throw(e))}catch(e){r(e)}}function step(e){e.done?o(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.EventStorageService=void 0;const o=require("@nestjs/common"),r=require("@nestjs/typeorm"),s=require("nanoid"),a=require("typeorm"),d=require("../../database/entities");let u=class EventStorageService{constructor(e,t,i){this.eventLogRepository=e,this.auditLogRepository=t,this.dataSource=i}store(e){return n(this,void 0,void 0,function*(){var t,i,n;const o=this.eventLogRepository.create({uid:e.uid||(0,s.nanoid)(),name:e.name,user_id:(null===(t=e.user)||void 0===t?void 0:t.user_id)||0,ip_address:null===(i=e.user)||void 0===i?void 0:i.ip_address,user_agent:null===(n=e.user)||void 0===n?void 0:n.user_agent,occurred_at:e.timestamp||new Date});yield this.eventLogRepository.save(o)})}storeAuditEvent(e){return n(this,void 0,void 0,function*(){yield this.dataSource.transaction(t=>n(this,void 0,void 0,function*(){var i,n,o;const r=t.create(d.LogsAudit,{uid:e.uid||(0,s.nanoid)(),name:e.name,user_id:(null===(i=e.user)||void 0===i?void 0:i.user_id)||0,entity:e.entity,entity_id:e.entity_id,entity_ids:e.entity_ids,action:e.action,changes:e.changes,ip_address:null===(n=e.user)||void 0===n?void 0:n.ip_address,user_agent:null===(o=e.user)||void 0===o?void 0:o.user_agent,occurred_at:e.timestamp||new Date,meta:e.meta});yield t.save(r)}))})}};exports.EventStorageService=u,exports.EventStorageService=u=e([(0,o.Injectable)(),i(0,(0,r.InjectRepository)(d.LogsEvent)),i(1,(0,r.InjectRepository)(d.LogsAudit)),t("design:paramtypes",[a.Repository,a.Repository,a.DataSource])],u);
@@ -1,12 +1,14 @@
1
- import { AUDIT_ACTION } from '../../enums.common';
2
1
  import { BaseEvent } from '.';
2
+ import { AUDIT_ACTION } from '../../enums.common';
3
3
  export interface AuditEventBase<TName extends string = string> extends BaseEvent {
4
4
  readonly name: TName;
5
5
  readonly entity: string;
6
6
  readonly entity_id: number;
7
+ readonly entity_ids?: string[];
7
8
  readonly action: AUDIT_ACTION;
8
9
  readonly changes?: Record<string, {
9
10
  before: any;
10
11
  after: any;
11
12
  }>;
13
+ readonly meta?: Record<string, any>;
12
14
  }
@@ -1 +1 @@
1
- var e,t=this&&this.__decorate||function(e,t,r,o){var n,s=arguments.length,c=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,r):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)c=Reflect.decorate(e,t,r,o);else for(var i=e.length-1;i>=0;i--)(n=e[i])&&(c=(s<3?n(c):s>3?n(t,r,c):n(t,r))||c);return s>3&&c&&Object.defineProperty(t,r,c),c},r=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.HttpExceptionFilter=void 0;const o=require("@nestjs/common"),n=require("@nestjs/event-emitter");let s=e=class HttpExceptionFilter{constructor(t){this.eventEmitter=t,this.logger=new o.Logger(e.name)}catch(e,t){var r,n;const s=t.switchToHttp(),c=s.getResponse(),i=s.getRequest();o.ForbiddenException;let a=e instanceof o.HttpException?e.getStatus():o.HttpStatus.INTERNAL_SERVER_ERROR,p={};if(e instanceof o.HttpException?p=e.getResponse():(this.logger.error(`Unhandled exception: ${i.method} ${i.url}`),"TokenError"===(null==e?void 0:e.name)?(a=o.HttpStatus.UNAUTHORIZED,p={error:"Unauthorized"}):p={error:"Internal Server Error",message:"An unexpected error occurred."}),"string"==typeof p)c.status(a).json({success:!1,code:a,timestamp:(new Date).toISOString(),path:i.url,message:p});else{let e=null!==(r=p.message)&&void 0!==r?r:p.error;Array.isArray(e)&&e.length>0&&"object"==typeof e[0]&&(e=e.map(e=>e.constraints?Object.values(e.constraints):"Invalid input").flat()),c.status(a).json({success:!1,status:a,path:i.url,message:e,code:null!==(n=p.code)&&void 0!==n?n:void 0})}}};exports.HttpExceptionFilter=s,exports.HttpExceptionFilter=s=e=t([(0,o.Catch)(),r("design:paramtypes",[n.EventEmitter2])],s);
1
+ var e,t=this&&this.__decorate||function(e,t,r,o){var n,s=arguments.length,i=s<3?t:null===o?o=Object.getOwnPropertyDescriptor(t,r):o;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,o);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(i=(s<3?n(i):s>3?n(t,r,i):n(t,r))||i);return s>3&&i&&Object.defineProperty(t,r,i),i},r=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.HttpExceptionFilter=void 0;const o=require("@nestjs/common"),n=require("@nestjs/event-emitter");let s=e=class HttpExceptionFilter{constructor(t){this.eventEmitter=t,this.logger=new o.Logger(e.name)}catch(e,t){var r,n,s;const i=t.switchToHttp(),a=i.getResponse(),c=i.getRequest();o.ForbiddenException;let l=e instanceof o.HttpException?e.getStatus():o.HttpStatus.INTERNAL_SERVER_ERROR,p={};if(e instanceof o.HttpException?p=e.getResponse():(this.logger.error(`Unhandled exception: ${c.method} ${c.url}`),"TokenError"===(null==e?void 0:e.name)?(l=o.HttpStatus.UNAUTHORIZED,p={error:"Unauthorized"}):p={error:"Internal Server Error",message:"An unexpected error occurred."}),"string"==typeof p)a.status(l).json({success:!1,code:l,timestamp:(new Date).toISOString(),path:c.url,message:p});else{let e=null!==(r=p.message)&&void 0!==r?r:p.error;Array.isArray(e)&&e.length>0&&"object"==typeof e[0]&&(e=e.map(e=>e.constraints?Object.values(e.constraints):"Invalid input").flat()),a.status(l).json({success:!1,status:l,path:c.url,message:e,code:null!==(n=p.code)&&void 0!==n?n:void 0,meta:null!==(s=p.meta)&&void 0!==s?s:void 0})}}};exports.HttpExceptionFilter=s,exports.HttpExceptionFilter=s=e=t([(0,o.Catch)(),r("design:paramtypes",[n.EventEmitter2])],s);
@@ -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),r=e.substring(4,6),t=e.substring(6,8),i=e.substring(9,11),a=e.substring(11,13),s=e.substring(13,15),l=new Date(`${n}-${r}-${t}T${i}:${a}:${s}Z`);if(isNaN(l.getTime()))throw new Error("Invalid date");return l}Object.defineProperty(exports,"__esModule",{value:!0}),exports.applyFiltersAndSorting=function applyFiltersAndSorting(n,r){const{_keyword:t,_group:i,_sort:a,aliasName:s="a",keywordFields:l=["name"],groupFields:$=[]}=r;return function applyKeywordFilter(e,n,r,t){if(n){const i=[],a={};t.forEach((e,t)=>{if(e.endsWith("*")){const s=e.slice(0,-1);i.push(`${r}.${s} = :keyword${t}`),a[`keyword${t}`]=n}else i.push(`${r}.${e} LIKE :keyword${t}`),a[`keyword${t}`]=`%${n}%`}),e.andWhere(`(${i.join(" OR ")})`,a)}}(n,t,s,l),function applyGroupFilter(n,r,t,i){if(!r)return;if(0===i.length)return;const a=r.split("|");if(a.some(e=>{const[n]=e.split("-");return!i.includes(n)}))throw new Error("Invalid field detected in group filter");const s=[],l={};a.forEach((n,r)=>{const[i,a]=n.split(/-(.+)/),$=i.includes(".")?i:`${t}.${i}`;let o;o=a.includes("__")?i.includes("_at")||i.includes("_date")?e.handleDateRange($,a,r):e.handleNumberRange($,a,r):e.handleEquals($,a,r),o.condition&&(s.push(o.condition),Object.assign(l,o.parameters))}),s.length>0&&n.andWhere(`(${s.join(" AND ")})`,l)}(n,i,s,$),function applySorting(e,n,r){if(n){n.split("|").forEach((n,t)=>{const[i,a]=n.split("-"),s=a.toUpperCase();if("ASC"!==s&&"DESC"!==s)throw new Error(`Invalid sort order: ${a}`);0===t?e.orderBy(`${r}.${i}`,s):e.addOrderBy(`${r}.${i}`,s)})}else{Object.keys(e.expressionMap.orderBys).length>0||e.orderBy(`${r}.id`,"DESC")}}(n,a,s),n};const e={handleEquals(e,n,r){if(n.includes(",")){const t=n.split(",").map(e=>e.trim()).filter(e=>e);return{condition:`${e} IN (:...${e}${r})`,parameters:{[`${e}${r}`]:t}}}return{condition:`${e} = :${e}${r}`,parameters:{[`${e}${r}`]:n}}},handleNumberRange(e,n,r){const[t,i]=n.split("__").map(e=>""===e?null:Number(e)),a=[],s={};return null!==t&&null!==i?(a.push(`${e} BETWEEN :${e}Min${r} AND :${e}Max${r}`),s[`${e}Min${r}`]=t,s[`${e}Max${r}`]=i):null!==t?(a.push(`${e} >= :${e}Min${r}`),s[`${e}Min${r}`]=t):null!==i&&(a.push(`${e} <= :${e}Max${r}`),s[`${e}Max${r}`]=i),{condition:a.join(" AND "),parameters:s}},handleDateRange(e,n,r){const[t,i]=n.split("__").map(e=>""===e?null:e),a=[],s={};return null!==t&&null!==i?(a.push(`${e} BETWEEN :${e}Min${r} AND :${e}Max${r}`),s[`${e}Min${r}`]=validateAndParseDate(t),s[`${e}Max${r}`]=validateAndParseDate(i)):null!==t?(a.push(`${e} >= :${e}Min${r}`),s[`${e}Min${r}`]=validateAndParseDate(t)):null!==i&&(a.push(`${e} <= :${e}Max${r}`),s[`${e}Max${r}`]=validateAndParseDate(i)),{condition:a.join(" AND "),parameters:s}}};
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),i=e.substring(9,11),a=e.substring(11,13),s=e.substring(13,15),l=new Date(`${n}-${t}-${r}T${i}:${a}:${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:i,_sort:a,aliasName:s="a",keywordFields:l=["name"],groupFields:$=[]}=t;return function applyKeywordFilter(e,n,t,r){if(n){const i=[],a={};r.length>0&&(r.forEach((e,r)=>{if(e.endsWith("*")){const s=e.slice(0,-1);i.push(`${t}.${s} = :keyword${r}`),a[`keyword${r}`]=n}else i.push(`${t}.${e} LIKE :keyword${r}`),a[`keyword${r}`]=`%${n}%`}),e.andWhere(`(${i.join(" OR ")})`,a))}}(n,r,s,l),function applyGroupFilter(n,t,r,i){if(!t)return;if(0===i.length)return;const a=t.split("|");if(a.some(e=>{const[n]=e.split("-");return!i.includes(n)}))throw new Error("Invalid field detected in group filter");const s=[],l={};a.forEach((n,t)=>{const[i,a]=n.split(/-(.+)/),$=i.includes(".")?i:`${r}.${i}`;let o;o=a.includes("__")?i.includes("_at")||i.includes("_date")?e.handleDateRange($,a,t):e.handleNumberRange($,a,t):e.handleEquals($,a,t),o.condition&&(s.push(o.condition),Object.assign(l,o.parameters))}),s.length>0&&n.andWhere(`(${s.join(" AND ")})`,l)}(n,i,s,$),function applySorting(e,n,t){if(n){n.split("|").forEach((n,r)=>{const[i,a]=n.split("-"),s=a.toUpperCase();if("ASC"!==s&&"DESC"!==s)throw new Error(`Invalid sort order: ${a}`);0===r?e.orderBy(`${t}.${i}`,s):e.addOrderBy(`${t}.${i}`,s)})}else{Object.keys(e.expressionMap.orderBys).length>0||e.orderBy(`${t}.id`,"DESC")}}(n,a,s),n};const e={handleEquals(e,n,t){if(n.includes(",")){const r=n.split(",").map(e=>e.trim()).filter(e=>e);return{condition:`${e} IN (:...${e}${t})`,parameters:{[`${e}${t}`]:r}}}return{condition:`${e} = :${e}${t}`,parameters:{[`${e}${t}`]:n}}},handleNumberRange(e,n,t){const[r,i]=n.split("__").map(e=>""===e?null:Number(e)),a=[],s={};return null!==r&&null!==i?(a.push(`${e} BETWEEN :${e}Min${t} AND :${e}Max${t}`),s[`${e}Min${t}`]=r,s[`${e}Max${t}`]=i):null!==r?(a.push(`${e} >= :${e}Min${t}`),s[`${e}Min${t}`]=r):null!==i&&(a.push(`${e} <= :${e}Max${t}`),s[`${e}Max${t}`]=i),{condition:a.join(" AND "),parameters:s}},handleDateRange(e,n,t){const[r,i]=n.split("__").map(e=>""===e?null:e),a=[],s={};return null!==r&&null!==i?(a.push(`${e} BETWEEN :${e}Min${t} AND :${e}Max${t}`),s[`${e}Min${t}`]=validateAndParseDate(r),s[`${e}Max${t}`]=validateAndParseDate(i)):null!==r?(a.push(`${e} >= :${e}Min${t}`),s[`${e}Min${t}`]=validateAndParseDate(r)):null!==i&&(a.push(`${e} <= :${e}Max${t}`),s[`${e}Max${t}`]=validateAndParseDate(i)),{condition:a.join(" AND "),parameters:s}}};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@comasoft/nestjs",
3
- "version": "0.1.52",
3
+ "version": "0.1.54",
4
4
  "description": "",
5
5
  "private": false,
6
6
  "exports": {