@comasoft/nestjs 0.1.52 → 0.1.53

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);
@@ -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.53",
4
4
  "description": "",
5
5
  "private": false,
6
6
  "exports": {