frgen 0.3.3 → 0.3.5

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,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),r=require("path"),t=require("./utils.js"),o=require("./make_resource.js"),a=require("./make_validation.js"),c=require("./make_service.js"),s=function(){var s=e.asyncToGenerator(e.regeneratorRuntime().mark((function s(i,l,u,d){var p,m,x,v,h,q,f,R,y,w,C,g,S,j,P=arguments;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return p=P.length>4&&void 0!==P[4]?P[4]:"public",m=P.length>5&&void 0!==P[5]&&P[5],e.prev=2,i||(console.error("class name undefined"),process.exit(1)),l||(console.error("table name undefined"),process.exit(1)),x=i.replace(/Controller$/,""),v=t.capitalize(t.toCamelCase(t.removePluralSuffix(l))),h=t.capitalize(t.toCamelCase(t.removePluralSuffix(l))),q=x,f=t.capitalize(t.toCamelCase(t.removePluralSuffix(l))),R=t.toCamelCase(t.removePluralSuffix(l)),y="".concat(q,"Controller.ts"),w=r.join(process.cwd(),"src","app","http","controller",y),u&&"default"!==u&&("/"!==u.charAt(u.length-1)&&(u+="/"),w=r.join(process.cwd(),"src",u,y)),C="\n const validated = await req.validation(".concat(R,"Schema, {\n context: { method: req.method },\n });\n "),g="\n const validated = await req.validation(".concat(R,"Schema);\n "),S='\nimport { NextFunction, Request, Response } from "express";\nimport { Controller, Get, Post, Put, Delete } from "frexp/lib/Decorator";\nimport { getPaginate, getDetail, handleCreate, handleUpdate, handleDelete} from "@service/'.concat(h,'Service";\nimport ').concat(v,'Resource from "@resource/').concat(v,'Resource";\nimport { ').concat(R,'Schema } from "@validation/').concat(f,'Validation";\n\n@Controller("/').concat(t.toKebabCase(x),'")\nexport class ').concat(q,'Controller {\n\n @Get("/")\n async index(req: Request, res: Response, next: NextFunction){\n try {\n const results = await getPaginate(req);\n res.json(').concat(v,'Resource.paginate(results));\n } catch (error) {\n next(error);\n }\n };\n\n @Get("/:id")\n async view(req: Request, res: Response, next: NextFunction){\n try {\n const model = await getDetail(+req.params.id)\n res.json(new ').concat(v,'Resource(model, true));\n } catch (error) {\n next(error);\n }\n };\n\n @Post("/")\n async create(req: Request, res: Response, next: NextFunction){\n try {\n ').concat(g,"\n const model = await handleCreate(").concat(""===g?"req.body":"validated",");\n res.json(new ").concat(v,'Resource(model, true));\n } catch (error) {\n next(error);\n }\n };\n\n @Put("/")\n async update(req: Request, res: Response, next: NextFunction){\n try {\n ').concat(C,"\n const model = await handleUpdate(").concat(""===C?"req.body":"validated",");\n res.json(new ").concat(v,'Resource(model, true));\n } catch (error) {\n next(error);\n }\n };\n\n @Delete("/:id")\n async destroy(req: Request, res: Response, next: NextFunction){\n try {\n await handleDelete(+req.params.id)\n res.sendStatus(204);\n } catch (error) {\n next(error);\n }\n };\n}\n'),j=r.dirname(w),n.existsSync(j)||n.mkdirSync(j,{recursive:!0}),n.writeFile(w,S,(function(e){e?console.error("err: ",e):console.log("File ".concat(y," has been created"))})),e.next=22,o("".concat(v,"Resource"),l,d,p);case 22:return e.next=24,a("".concat(f,"Validation"),l,d,p);case 24:return e.next=26,c("".concat(h,"Service"),l,void 0,m);case 26:e.next=31;break;case 28:e.prev=28,e.t0=e.catch(2),console.error("err::",e.t0);case 31:return e.prev=31,e.finish(31);case 33:case"end":return e.stop()}}),s,null,[[2,28,31,33]])})));return function(e,n,r,t){return s.apply(this,arguments)}}();module.exports=s;
2
+ "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),r=require("path"),t=require("./utils.js"),o=require("./make_resource.js"),a=require("./make_validation.js"),c=require("./make_service.js"),s=function(){var s=e.asyncToGenerator(e.regeneratorRuntime().mark((function s(i,l,u,d){var m,p,x,v,h,q,f,R,C,y,w,g,j,P,b=arguments;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return m=b.length>4&&void 0!==b[4]?b[4]:"public",p=b.length>5&&void 0!==b[5]&&b[5],e.prev=2,i||(console.error("class name undefined"),process.exit(1)),l||(console.error("table name undefined"),process.exit(1)),x=i.replace(/Controller$/,"").replace(/\.controller/i,""),v=t.capitalize(t.toCamelCase(t.removePluralSuffix(l))),h=t.toCamelCase(t.removePluralSuffix(l)),q=x,f=t.toCamelCase(t.removePluralSuffix(l)),R=t.toCamelCase(t.removePluralSuffix(l)),C="".concat(t.toCamelCase(q),".controller.ts"),y=r.join(process.cwd(),"src","app","http","controller",C),u&&"default"!==u&&("/"!==u.charAt(u.length-1)&&(u+="/"),y=r.join(process.cwd(),"src",u,C)),w="\n const validated = await req.validation(".concat(R,"Schema, {\n context: { method: req.method },\n });\n "),g="\n const validated = await req.validation(".concat(R,"Schema);\n "),j='\nimport { NextFunction, Request, Response } from "express";\nimport { Controller, Get, Post, Put, Delete } from "frexp/lib/Decorator";\nimport { getPaginate, getDetail, handleCreate, handleUpdate, handleDelete} from "@service/'.concat(h,'.service";\nimport ').concat(v,'Resource from "@resource/').concat(t.toCamelCase(v),'.resource";\nimport { ').concat(R,'Schema } from "@validation/').concat(f,'.validation";\n\n@Controller("/').concat(t.toKebabCase(x),'")\nexport class ').concat(q,'Controller {\n\n @Get("/")\n async index(req: Request, res: Response, next: NextFunction){\n try {\n const results = await getPaginate(req.query);\n res.json(').concat(v,'Resource.paginate(results));\n } catch (error) {\n next(error);\n }\n };\n\n @Get("/:id")\n async view(req: Request, res: Response, next: NextFunction){\n try {\n const model = await getDetail(+req.params.id)\n res.json(new ').concat(v,'Resource(model, true));\n } catch (error) {\n next(error);\n }\n };\n\n @Post("/")\n async create(req: Request, res: Response, next: NextFunction){\n try {\n ').concat(g,"\n const model = await handleCreate(").concat(""===g?"req.body":"validated",");\n res.json(new ").concat(v,'Resource(model, true));\n } catch (error) {\n next(error);\n }\n };\n\n @Put("/")\n async update(req: Request, res: Response, next: NextFunction){\n try {\n ').concat(w,"\n const model = await handleUpdate(").concat(""===w?"req.body":"validated",");\n res.json(new ").concat(v,'Resource(model, true));\n } catch (error) {\n next(error);\n }\n };\n\n @Delete("/:id")\n async destroy(req: Request, res: Response, next: NextFunction){\n try {\n await handleDelete(+req.params.id)\n res.sendStatus(204);\n } catch (error) {\n next(error);\n }\n };\n}\n'),P=r.dirname(y),n.existsSync(P)||n.mkdirSync(P,{recursive:!0}),n.writeFile(y,j,(function(e){e?console.error("err: ",e):console.log("File ".concat(C," has been created"))})),e.next=22,o("".concat(v,"Resource"),l,d,m);case 22:return e.next=24,a("".concat(f,".validation"),l,d,m);case 24:return e.next=26,c("".concat(h,".service"),l,void 0,p);case 26:e.next=31;break;case 28:e.prev=28,e.t0=e.catch(2),console.error("err::",e.t0);case 31:return e.prev=31,e.finish(31);case 33:case"end":return e.stop()}}),s,null,[[2,28,31,33]])})));return function(e,n,r,t){return s.apply(this,arguments)}}();module.exports=s;
package/lib/make_crud.js CHANGED
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),r=require("./make_controller.js"),t=require("./make_model.js"),n=require("./utils.js"),a=function(){var a=e.asyncToGenerator(e.regeneratorRuntime().mark((function a(s,c){var u,l,o,i,p,v,f,x,m,b=arguments;return e.regeneratorRuntime().wrap((function(a){for(;;)switch(a.prev=a.next){case 0:return u=b.length>2&&void 0!==b[2]?b[2]:"public",l=b.length>3&&void 0!==b[3]&&b[3],a.prev=2,a.next=5,n.getTables(c,u);case 5:o=a.sent,i=e.createForOfIteratorHelper(o),a.prev=7,i.s();case 9:if((p=i.n()).done){a.next=21;break}if(v=p.value,f=v.table_name,x=n.capitalize(n.toCamelCase(n.removePluralSuffix(f))),m="".concat(x,"Controller"),l){a.next=17;break}return a.next=17,t(x,f,c,u);case 17:return a.next=19,r(m,f,s,c,u,l);case 19:a.next=9;break;case 21:a.next=26;break;case 23:a.prev=23,a.t0=a.catch(7),i.e(a.t0);case 26:return a.prev=26,i.f(),a.finish(26);case 29:a.next=34;break;case 31:a.prev=31,a.t1=a.catch(2),console.log(a.t1);case 34:return a.prev=34,a.finish(34);case 36:case"end":return a.stop()}}),a,null,[[2,31,34,36],[7,23,26,29]])})));return function(e,r){return a.apply(this,arguments)}}();module.exports=a;
2
+ "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),r=require("./make_controller.js"),t=require("./make_model.js"),a=require("./utils.js"),n=function(){var n=e.asyncToGenerator(e.regeneratorRuntime().mark((function n(s,c){var l,u,o,i,p,v,f,m,x,b=arguments;return e.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return l=b.length>2&&void 0!==b[2]?b[2]:"public",u=b.length>3&&void 0!==b[3]&&b[3],n.prev=2,n.next=5,a.getTables(c,l);case 5:o=n.sent,i=e.createForOfIteratorHelper(o),n.prev=7,i.s();case 9:if((p=i.n()).done){n.next=21;break}if(v=p.value,f=v.table_name,m=a.capitalize(a.toCamelCase(a.removePluralSuffix(v.table_name))),x="".concat(m,"Controller"),u){n.next=17;break}return n.next=17,t(m,f,c,l);case 17:return n.next=19,r(x,f,s,c,l,u);case 19:n.next=9;break;case 21:n.next=26;break;case 23:n.prev=23,n.t0=n.catch(7),i.e(n.t0);case 26:return n.prev=26,i.f(),n.finish(26);case 29:n.next=34;break;case 31:n.prev=31,n.t1=n.catch(2),console.log(n.t1);case 34:return n.prev=34,n.finish(34);case 36:case"end":return n.stop()}}),n,null,[[2,31,34,36],[7,23,26,29]])})));return function(e,r){return n.apply(this,arguments)}}();module.exports=n;
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),r=require("fs"),n=require("path"),t=require("./utils.js"),c=function(){var c=e.asyncToGenerator(e.regeneratorRuntime().mark((function c(a,o,s){var u,i,l,p,m,f,d,h,x,b=arguments;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return u=b.length>3&&void 0!==b[3]?b[3]:"public",e.prev=1,a||(console.error("class name undefined"),process.exit(1)),o||(console.error("table name undefined"),process.exit(1)),i=a.replace("Resource",""),l="".concat(i,"Resource.ts"),p=n.join(process.cwd(),"src","app","http","resource",l),e.next=9,t.getTableColumns(s,o,u);case 9:m=e.sent,f=Object.fromEntries(m.map((function(e){return[e.column_name,{defaultValue:e.column_default,type:e.data_type,maxLength:e.character_maximum_length,nullable:"YES"===e.is_nullable}]}))),d=Object.keys(f).filter((function(e){return"created_at"!==e&&"updated_at"!==e})).map((function(e){return"".concat(t.toCamelCase(e),": this.").concat(t.toCamelCase(e))})).join(",\n"),h='\nimport Resource from "frexp/lib/Resource";\n\nexport default class '.concat(i,"Resource extends Resource {\n toArray() {\n return {\n").concat(d,"\n };\n }\n}"),x=n.dirname(p),r.existsSync(x)||r.mkdirSync(x,{recursive:!0}),r.writeFile(p,h,(function(e){e?console.error("err:",e):console.log("File ".concat(l," has been created"))})),e.next=21;break;case 18:e.prev=18,e.t0=e.catch(1),console.error("err::",e.t0);case 21:return e.prev=21,e.finish(21);case 23:case"end":return e.stop()}}),c,null,[[1,18,21,23]])})));return function(e,r,n){return c.apply(this,arguments)}}();module.exports=c;
2
+ "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),r=require("fs"),n=require("path"),t=require("./utils.js"),a=function(){var a=e.asyncToGenerator(e.regeneratorRuntime().mark((function a(c,o,s){var u,l,i,p,m,f,d,h,x,b=arguments;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return u=b.length>3&&void 0!==b[3]?b[3]:"public",e.prev=1,c||(console.error("class name undefined"),process.exit(1)),o||(console.error("table name undefined"),process.exit(1)),l=c.replace(/Resource$/,"").replace(/\.resource/i,""),i="".concat(t.toCamelCase(l),".resource.ts"),p=n.join(process.cwd(),"src","app","http","resource",i),e.next=9,t.getTableColumns(s,o,u);case 9:m=e.sent,f=Object.fromEntries(m.map((function(e){return[e.column_name,{defaultValue:e.column_default,type:e.data_type,maxLength:e.character_maximum_length,nullable:"YES"===e.is_nullable}]}))),d=Object.keys(f).filter((function(e){return"created_at"!==e&&"updated_at"!==e})).map((function(e){return"".concat(t.toCamelCase(e),": this.").concat(t.toCamelCase(e))})).join(",\n"),h='\nimport Resource from "frexp/lib/Resource";\n\nexport default class '.concat(l,"Resource extends Resource {\n toArray() {\n return {\n").concat(d,"\n };\n }\n}"),x=n.dirname(p),r.existsSync(x)||r.mkdirSync(x,{recursive:!0}),r.writeFile(p,h,(function(e){e?console.error("err:",e):console.log("File ".concat(i," has been created"))})),e.next=21;break;case 18:e.prev=18,e.t0=e.catch(1),console.error("err::",e.t0);case 21:return e.prev=21,e.finish(21);case 23:case"end":return e.stop()}}),a,null,[[1,18,21,23]])})));return function(e,r,n){return a.apply(this,arguments)}}();module.exports=a;
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),t=require("path"),r=require("./utils.js"),o=function(){var o=e.asyncToGenerator(e.regeneratorRuntime().mark((function o(a,c,i){var s,d,u,l,p,m,y,f,h,w,g,x=arguments;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:s=x.length>3&&void 0!==x[3]&&x[3];try{a||(console.error("class name undefined"),process.exit(1)),c||(console.error("table name undefined"),process.exit(1)),d=r.capitalize(r.toCamelCase(r.removePluralSuffix(c))),u=a.replace(/Service$/,""),l=r.toCamelCase(r.removePluralSuffix(c)),p=t.join(process.cwd(),"src","app","http","service","".concat(a,".ts")),i&&"default"!==i&&("/"!==i.charAt(i.length-1)&&(i+="/"),p=t.join(process.cwd(),"src",i,"".concat(a,".ts"))),m=l,y=s?"return prisma.".concat(m,".update({where: {id: +id!}, data: payload})"):"\n const model = await ".concat(d,'.query().findById(id);\n if (!model) {\n throw new NotFoundException("').concat(d,'");\n }\n await model.$query().updateAndFetch(payload);\n return model;\n '),f=s?"return prisma.".concat(m,".delete({where: {id}})"):" \n const model = await ".concat(d,'.query().findById(id);\n if (!model) {\n throw new NotFoundException("').concat(d,'");\n }\n await model.$query().delete();\n '),h=s?"\n const count = await prisma.".concat(m,".count();\n const results = await prisma.").concat(m,'.findMany({ take: +req.getQuery("perPage", 10), skip: +req.getQuery("page", 0) })\n return { total: count, data: results };\n '):"return ".concat(d,'.query().page(req.getQuery("page", 0), req.getQuery("perPage", 10));'),w='\n import { Request } from "express";\n'.concat(s?'import prisma from "@config/db";':"import ".concat(d,' from "@model/').concat(d,'";'),'\nimport NotFoundException from "@exception/NotFoundException";\nimport { ').concat(u,'Schema } from "@validation/').concat(u,'Validation";\n\n export const getPaginate = ').concat(s?"async":""," (req: Request) => {\n ").concat(h,"\n };\n\n export const getDetail = async (id:number) => {\n const model = await ").concat(s?"prisma.".concat(m,".findFirst({where : {id}})"):"".concat(d,".query().findById(id)"),';\n if (!model) {\n throw new NotFoundException("').concat(d,'")\n }\n return model;\n };\n\n export const handleCreate = (payload:').concat(u,"Schema) => {\n return ").concat(s?"prisma.".concat(m,".create({ data: payload })"):"".concat(d,".query().insertAndFetch(payload)"),";\n };\n\n export const handleUpdate = ").concat(s?"":"async"," ({id, ...payload}:").concat(u,"Schema) => {\n ").concat(y,"\n };\n\n export const handleDelete = ").concat(s?"":"async"," (id:number) => {\n ").concat(f,"\n };\n"),g=t.dirname(p),n.existsSync(g)||n.mkdirSync(g,{recursive:!0}),n.writeFile(p,w,(function(e){e?console.error("err: ",e):console.log("File ".concat(a,".ts has been "))}))}catch(e){console.error("err::",e)}case 2:case"end":return e.stop()}}),o)})));return function(e,n,t){return o.apply(this,arguments)}}();module.exports=o;
2
+ "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),t=require("path"),a=require("./utils.js"),o=function(){var o=e.asyncToGenerator(e.regeneratorRuntime().mark((function o(r,c,i){var s,d,l,u,p,m,y,f,h,w,x,g=arguments;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:s=g.length>3&&void 0!==g[3]&&g[3];try{r||(console.error("class name undefined"),process.exit(1)),c||(console.error("table name undefined"),process.exit(1)),d=a.capitalize(a.toCamelCase(a.removePluralSuffix(c))),l=r.replace(/Service$/,"").replace(/\.service/i,""),u=a.toCamelCase(a.removePluralSuffix(c)),p=t.join(process.cwd(),"src","app","http","service","".concat(r,".ts")),i&&"default"!==i&&("/"!==i.charAt(i.length-1)&&(i+="/"),p=t.join(process.cwd(),"src",i,"".concat(r,".ts"))),m=u,y=s?"return prisma.".concat(m,".update({where: {id: +id!}, data: payload})"):"\n const model = await ".concat(d,'.query().findById(id);\n if (!model) {\n throw new NotFoundException("').concat(d,'");\n }\n await model.$query().updateAndFetch(payload);\n return model;\n '),f=s?"return prisma.".concat(m,".delete({where: {id}})"):" \n const model = await ".concat(d,'.query().findById(id);\n if (!model) {\n throw new NotFoundException("').concat(d,'");\n }\n await model.$query().delete();\n '),h=s?"\n const count = await prisma.".concat(m,".count();\n const results = await prisma.").concat(m,".findMany({ take: +(qs.take ?? 10), skip: +(qs.skip ?? 0) })\n return { total: count, data: results };\n "):"return ".concat(d,'.query().page(req.getQuery("page", 0), req.getQuery("perPage", 10));'),w="\n".concat(s?'import prisma from "@config/db";':"import ".concat(d,' from "@model/').concat(d,'";'),'\nimport NotFoundException from "@exception/notFound.exception";\nimport { ').concat(a.capitalize(l),'Schema } from "@validation/').concat(a.toCamelCase(l),'.validation";\n\n export const getPaginate = ').concat(s?"async":""," (qs: Record<string, any>) => {\n ").concat(h,"\n };\n\n export const getDetail = async (id:number) => {\n const model = await ").concat(s?"prisma.".concat(m,".findFirst({where : {id}})"):"".concat(d,".query().findById(id)"),';\n if (!model) {\n throw new NotFoundException("').concat(d,'")\n }\n return model;\n };\n\n export const handleCreate = (payload:').concat(a.capitalize(l),"Schema) => {\n return ").concat(s?"prisma.".concat(m,".create({ data: payload })"):"".concat(d,".query().insertAndFetch(payload)"),";\n };\n\n export const handleUpdate = ").concat(s?"":"async"," ({id, ...payload}:").concat(a.capitalize(l),"Schema) => {\n ").concat(y,"\n };\n\n export const handleDelete = ").concat(s?"":"async"," (id:number) => {\n ").concat(f,"\n };\n"),x=t.dirname(p),n.existsSync(x)||n.mkdirSync(x,{recursive:!0}),n.writeFile(p,w,(function(e){e?console.error("err: ",e):console.log("File ".concat(r,".ts has been "))}))}catch(e){console.error("err::",e)}case 2:case"end":return e.stop()}}),o)})));return function(e,n,t){return o.apply(this,arguments)}}();module.exports=o;
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),t=require("path"),r=require("./utils.js");function a(n,t){var a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:[],c=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],i=t.type,o=t.nullable,u=t.defaultValue,s=["y"],l=["integer","bigint","smallint","tinyint","numeric","decimal","float"].includes(i),m=["varchar","text","string","char","character varying","uuid","date","datetime","timestamp","timestamp with time zone"].includes(i),p=["boolean"].includes(i);l?s.push("number()"):m?s.push("string()"):p?s.push("boolean()"):s.push("mixed()");var d=a.includes(n);o?s.push("optional()"):d?s.push('when("$method", {\n is: (method) => method === "PUT",\n then: (schema) => schema.required(),\n otherwise: (schema) => schema.notRequired(),\n })'):s.push("required()");var h=c.map((function(e){return e.column_name})).includes(n);if(h){var f=c.find((function(e){return e.column_name===n}));f&&s.push("oneOf(Object.values(".concat(f.enum_name,"))"))}var v=["CURRENT_TIMESTAMP"].includes(u);if(u&&!v&&!d){var y;if(l)y=parseInt(u);else if(h){var b=c.find((function(e){return e.column_name===n}));b&&(y="".concat(b.enum_name,".").concat(r.extractEnumValue(u)))}else y=p?u:"'".concat(u,"'");void 0!==e.typeof(y)&&s.push("default(".concat(y,")"))}return s.push("label('".concat(n.replaceAll("_"," "),"')")),"".concat(r.toCamelCase(n),":").concat(s.join("."))}var c=function(){var c=e.asyncToGenerator(e.regeneratorRuntime().mark((function c(i,o,u){var s,l,m,p,d,h,f,v,y,b,g,_,x,T=arguments;return e.regeneratorRuntime().wrap((function(c){for(;;)switch(c.prev=c.next){case 0:return s=T.length>3&&void 0!==T[3]?T[3]:"public",c.prev=1,i||(console.error("valiation name undefined"),process.exit(1)),o||(console.error("table name undefined"),process.exit(1)),l="".concat(i,".ts"),m=t.join(process.cwd(),"src","app","http","validation",l),p=r.toCamelCase(r.removePluralSuffix(o)),c.next=9,r.getTableColumns(u,o,s);case 9:return d=c.sent,h=Object.fromEntries(d.map((function(e){return[e.column_name,{defaultValue:e.column_default,type:e.data_type,maxLength:e.character_maximum_length,nullable:"YES"===e.is_nullable}]}))),c.next=13,r.getPrimaryKeys(u,o,s);case 13:return f=c.sent,c.next=16,r.getEnumFieldsAndValues(u,o,s);case 16:v=c.sent,y=Object.entries(h).filter((function(n){var t=e.slicedToArray(n,1)[0];return!["created_at","updated_at","createdAt","updatedAt"].includes(t)})).map((function(n){var t=e.slicedToArray(n,2),c=t[0],i=t[1];return[r.toCamelCase(c),a(c,i,f,v)]})),b="",v.length&&(g=v.map((function(e){return e.enum_name})).join(","),b="import { ".concat(g,' } from "@prisma/client";')),_='\n import * as yup from "yup";\n '.concat(b,"\n\n export const ").concat(p,"Schema = (y:typeof yup) => y.object().shape({\n ").concat(y.map((function(n){var t=e.slicedToArray(n,2);return t[0],t[1]})).join(",\n"),"\n });\n\n export type ").concat(r.capitalize(p),"Schema = yup.InferType<ReturnType<typeof ").concat(p,"Schema>>;\n "),x=t.dirname(m),n.existsSync(x)||n.mkdirSync(x,{recursive:!0}),n.writeFile(m,_,(function(e){e?console.error("err: ",e):console.log("File ".concat(l," has been created"))})),c.next=29;break;case 26:c.prev=26,c.t0=c.catch(1),console.error("err:",c.t0);case 29:return c.prev=29,c.finish(29);case 31:case"end":return c.stop()}}),c,null,[[1,26,29,31]])})));return function(e,n,t){return c.apply(this,arguments)}}();module.exports=c;
2
+ "use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),t=require("path"),r=require("./utils.js");function a(n,t){var a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:[],c=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],u=t.type,o=t.nullable,i=t.defaultValue,s=["y"],l=["integer","bigint","smallint","tinyint","numeric","decimal","float"].includes(u),m=["varchar","text","string","char","character varying","uuid","date","datetime","timestamp","timestamp with time zone"].includes(u),p=["boolean"].includes(u);l?s.push("number()"):m?s.push("string()"):p?s.push("boolean()"):s.push("mixed()");var d=a.includes(n);o?(s.push("optional()"),s.push("nullable()")):d?s.push('when("$method", {\n is: (method) => method === "PUT",\n then: (schema) => schema.required(),\n otherwise: (schema) => schema.notRequired(),\n })'):s.push("required()");var h=c.map((function(e){return e.column_name})).includes(n);if(h){var f=c.find((function(e){return e.column_name===n}));f&&s.push("oneOf(Object.values(".concat(f.enum_name,"))"))}var v=["CURRENT_TIMESTAMP"].includes(i);if(i&&!v&&!d){var y;if(l)y=parseInt(i);else if(h){var b=c.find((function(e){return e.column_name===n}));b&&(y="".concat(b.enum_name,".").concat(r.extractEnumValue(i)))}else y=p?i:"'".concat(i,"'");void 0!==e.typeof(y)&&s.push("default(".concat(y,")"))}return s.push("label('".concat(n.replaceAll("_"," "),"')")),"".concat(r.toCamelCase(n),":").concat(s.join("."))}var c=function(){var c=e.asyncToGenerator(e.regeneratorRuntime().mark((function c(u,o,i){var s,l,m,p,d,h,f,v,y,b,g,_,x,T=arguments;return e.regeneratorRuntime().wrap((function(c){for(;;)switch(c.prev=c.next){case 0:return s=T.length>3&&void 0!==T[3]?T[3]:"public",c.prev=1,u||(console.error("valiation name undefined"),process.exit(1)),o||(console.error("table name undefined"),process.exit(1)),l="".concat(u,".ts"),m=t.join(process.cwd(),"src","app","http","validation",l),p=r.toCamelCase(r.removePluralSuffix(o)),c.next=9,r.getTableColumns(i,o,s);case 9:return d=c.sent,h=Object.fromEntries(d.map((function(e){return[e.column_name,{defaultValue:e.column_default,type:e.data_type,maxLength:e.character_maximum_length,nullable:"YES"===e.is_nullable}]}))),c.next=13,r.getPrimaryKeys(i,o,s);case 13:return f=c.sent,c.next=16,r.getEnumFieldsAndValues(i,o,s);case 16:v=c.sent,y=Object.entries(h).filter((function(n){var t=e.slicedToArray(n,1)[0];return!["created_at","updated_at","createdAt","updatedAt"].includes(t)})).map((function(n){var t=e.slicedToArray(n,2),c=t[0],u=t[1];return[r.toCamelCase(c),a(c,u,f,v)]})),b="",v.length&&(g=v.map((function(e){return e.enum_name})).join(","),b="import { ".concat(g,' } from "@generated/prisma";')),_='\n import * as yup from "yup";\n '.concat(b,"\n\n export const ").concat(p,"Schema = (y:typeof yup) => y.object().shape({\n ").concat(y.map((function(n){var t=e.slicedToArray(n,2);return t[0],t[1]})).join(",\n"),"\n });\n\n export type ").concat(r.capitalize(p),"Schema = yup.InferType<ReturnType<typeof ").concat(p,"Schema>>;\n "),x=t.dirname(m),n.existsSync(x)||n.mkdirSync(x,{recursive:!0}),n.writeFile(m,_,(function(e){e?console.error("err: ",e):console.log("File ".concat(l," has been created"))})),c.next=29;break;case 26:c.prev=26,c.t0=c.catch(1),console.error("err:",c.t0);case 29:return c.prev=29,c.finish(29);case 31:case"end":return c.stop()}}),c,null,[[1,26,29,31]])})));return function(e,n,t){return c.apply(this,arguments)}}();module.exports=c;
package/lib/utils.js CHANGED
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var n=require("./_virtual/_rollupPluginBabelHelpers.js");require("path");var e=function(n){return n.toLowerCase().replace(/[-_\s]+(.)?/g,(function(n,e){return e?e.toUpperCase():""}))},t=function(n){var e={children:"child",men:"man",women:"woman",mice:"mouse",geese:"goose",feet:"foot",teeth:"tooth",people:"person",data:"datum",criteria:"criterion",fungi:"fungus",nuclei:"nucleus",cacti:"cactus"};return e[n.toLowerCase()]?e[n.toLowerCase()]:/(ies)$/.test(n)?n.replace(/ies$/,"y"):/(ves)$/.test(n)?n.replace(/ves$/,"f"):/(oes|xes|ses|shes|ches|zes)$/.test(n)?n.replace(/(oes|xes|ses|shes|ches|zes)$/,""):/(s)$/.test(n)&&!/(ss)$/.test(n)?n.replace(/s$/,""):n},a=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t){return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.prev=0,n.next=3,t.query("SELECT 1");case 3:console.log("Connection success"),n.next=10;break;case 6:n.prev=6,n.t0=n.catch(0),console.error("Gagal terhubung ke database:",n.t0),process.exit(1);case 10:case"end":return n.stop()}}),e,null,[[0,6]])})));return function(n){return e.apply(this,arguments)}}(),r=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a){var r,c,o,s=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return r=s.length>2&&void 0!==s[2]?s[2]:"public",n.prev=1,"\n SELECT \n *\n FROM information_schema.columns\n WHERE table_catalog = current_database()\n AND table_name = $1\n AND table_schema = $2\n ",n.next=5,t.query("\n SELECT \n *\n FROM information_schema.columns\n WHERE table_catalog = current_database()\n AND table_name = $1\n AND table_schema = $2\n ",[a,r]);case 5:return c=n.sent,o=c.rows,n.abrupt("return",o);case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Gagal mengambil informasi tabel:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n,t){return e.apply(this,arguments)}}(),c=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a){var r,c,o,s=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return r=s.length>2&&void 0!==s[2]?s[2]:"public",n.prev=1,"\n SELECT a.attname as column_name\n FROM pg_index i\n JOIN pg_attribute a ON a.attrelid = i.indrelid AND a.attnum = ANY(i.indkey)\n JOIN pg_class c ON c.oid = i.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE i.indisprimary = true\n AND c.relname = $1\n AND n.nspname = $2\n ",n.next=5,t.query("\n SELECT a.attname as column_name\n FROM pg_index i\n JOIN pg_attribute a ON a.attrelid = i.indrelid AND a.attnum = ANY(i.indkey)\n JOIN pg_class c ON c.oid = i.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE i.indisprimary = true\n AND c.relname = $1\n AND n.nspname = $2\n ",[a,r]);case 5:return c=n.sent,o=c.rows,n.abrupt("return",o.map((function(n){return n.column_name})));case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Error fetching primary keys:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n,t){return e.apply(this,arguments)}}(),o=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a){var r,c,o,s,u,i=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return r=i.length>2&&void 0!==i[2]?i[2]:"public",n.prev=1,"\n SELECT column_name, udt_name\n FROM information_schema.columns\n WHERE table_schema = $1\n AND table_name = $2\n AND data_type = 'USER-DEFINED'\n ",n.next=5,t.query("\n SELECT column_name, udt_name\n FROM information_schema.columns\n WHERE table_schema = $1\n AND table_name = $2\n AND data_type = 'USER-DEFINED'\n ",[r,a]);case 5:if(0!==(c=n.sent).rows.length){n.next=8;break}return n.abrupt("return",[]);case 8:return o=c.rows.map((function(n){return n.udt_name})),"\n SELECT t.typname as enum_name, e.enumlabel as value\n FROM pg_type t\n JOIN pg_enum e ON t.oid = e.enumtypid\n JOIN pg_namespace n ON n.oid = t.typnamespace\n WHERE t.typname = ANY($1)\n ORDER BY t.typname, e.enumsortorder\n ",n.next=12,t.query("\n SELECT t.typname as enum_name, e.enumlabel as value\n FROM pg_type t\n JOIN pg_enum e ON t.oid = e.enumtypid\n JOIN pg_namespace n ON n.oid = t.typnamespace\n WHERE t.typname = ANY($1)\n ORDER BY t.typname, e.enumsortorder\n ",[o]);case 12:return s=n.sent,u=s.rows.reduce((function(n,e){return n[e.enum_name]||(n[e.enum_name]=[]),n[e.enum_name].push(e.value),n}),{}),n.abrupt("return",c.rows.map((function(n){return{column_name:n.column_name,enum_name:n.udt_name,values:u[n.udt_name]||[]}})));case 17:throw n.prev=17,n.t0=n.catch(1),console.error("Error fetching ENUM fields:",n.t0),n.t0;case 21:case"end":return n.stop()}}),e,null,[[1,17]])})));return function(n,t){return e.apply(this,arguments)}}(),s=function(){var a=n.asyncToGenerator(n.regeneratorRuntime().mark((function a(r,c){var o,s,i,m,l,_,p,f,E,g,b,h=arguments;return n.regeneratorRuntime().wrap((function(a){for(;;)switch(a.prev=a.next){case 0:return o=h.length>2&&void 0!==h[2]?h[2]:"public",a.prev=1,"\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND tc.table_name = $1\n AND tc.table_schema = $2\n ",a.next=5,r.query("\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND tc.table_name = $1\n AND tc.table_schema = $2\n ",[c,o]);case 5:return s=a.sent,i=s.rows,"\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND ccu.table_name = $1\n AND tc.table_schema = $2\n ",a.next=10,r.query("\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND ccu.table_name = $1\n AND tc.table_schema = $2\n ",[c,o]);case 10:m=a.sent,l=m.rows,_={},i.forEach((function(n){var a=e(t(n.foreign_table_name));_[a]={relation:"BelongsToOneRelation",relatedTable:n.foreign_table_name,foreignKey:n.column_name,localKey:n.foreign_column_name}})),p=n.createForOfIteratorHelper(l),a.prev=15,p.s();case 17:if((f=p.n()).done){a.next=26;break}return E=f.value,g=e(t(E.table_name)),a.next=22,u(r,E.table_name,E.column_name,o);case 22:b=a.sent,_[g]={relation:b?"HasOneRelation":"HasManyRelation",relatedTable:E.table_name,foreignKey:E.foreign_column_name,localKey:E.column_name};case 24:a.next=17;break;case 26:a.next=31;break;case 28:a.prev=28,a.t0=a.catch(15),p.e(a.t0);case 31:return a.prev=31,p.f(),a.finish(31);case 34:return a.abrupt("return",_);case 37:throw a.prev=37,a.t1=a.catch(1),console.error("Error fetching table relations:",a.t1),a.t1;case 41:case"end":return a.stop()}}),a,null,[[1,37],[15,28,31,34]])})));return function(n,e){return a.apply(this,arguments)}}(),u=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a,r){var c,o,s,u=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return c=u.length>3&&void 0!==u[3]?u[3]:"public",n.prev=1,"\n SELECT tc.constraint_type\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.constraint_column_usage AS ccu \n ON tc.constraint_name = ccu.constraint_name\n WHERE tc.table_name = $1\n AND ccu.column_name = $2\n AND tc.constraint_type = 'UNIQUE'\n AND tc.table_schema = $3\n ",n.next=5,t.query("\n SELECT tc.constraint_type\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.constraint_column_usage AS ccu \n ON tc.constraint_name = ccu.constraint_name\n WHERE tc.table_name = $1\n AND ccu.column_name = $2\n AND tc.constraint_type = 'UNIQUE'\n AND tc.table_schema = $3\n ",[a,r,c]);case 5:return o=n.sent,s=o.rows,n.abrupt("return",s.length>0);case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Error checking unique constraint:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n,t,a){return e.apply(this,arguments)}}(),i=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t){var a,r,c,o=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return a=o.length>1&&void 0!==o[1]?o[1]:"public",n.prev=1,"\n SELECT *\n FROM information_schema.tables\n WHERE table_schema = $1\n AND table_schema NOT IN ('information_schema', 'pg_catalog')\n AND table_name NOT IN ('migrations', 'migrations_lock', '_prisma_migrations')\n AND table_type = 'BASE TABLE'\n ",n.next=5,t.query("\n SELECT *\n FROM information_schema.tables\n WHERE table_schema = $1\n AND table_schema NOT IN ('information_schema', 'pg_catalog')\n AND table_name NOT IN ('migrations', 'migrations_lock', '_prisma_migrations')\n AND table_type = 'BASE TABLE'\n ",[a]);case 5:return r=n.sent,c=r.rows,n.abrupt("return",c);case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Error fetching tables:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n){return e.apply(this,arguments)}}();exports.capitalize=function(n){return n.charAt(0).toUpperCase()+n.slice(1)},exports.checkDatabaseConnection=a,exports.extractEnumValue=function(n){if(!n)return null;var e=n.match(/^'(.+?)'::/);return e?e[1]:n},exports.getEnumFieldsAndValues=o,exports.getPrimaryKeys=c,exports.getTableColumns=r,exports.getTableRelations=s,exports.getTables=i,exports.isUniqueConstraint=u,exports.removePluralSuffix=t,exports.toCamelCase=e,exports.toKebabCase=function(n){return n.replace(/([a-z0-9])([A-Z])/g,"$1-$2").replace(/_/g,"-").toLowerCase()};
2
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var n=require("./_virtual/_rollupPluginBabelHelpers.js");require("path");var e=function(n){return n.replace(/([a-z])([A-Z])/g,"$1 $2").toLowerCase().replace(/[-_\s]+(.)?/g,(function(n,e){return e?e.toUpperCase():""}))},t=function(n){var e={children:"child",men:"man",women:"woman",mice:"mouse",geese:"goose",feet:"foot",teeth:"tooth",people:"person",data:"datum",criteria:"criterion",fungi:"fungus",nuclei:"nucleus",cacti:"cactus"};return e[n.toLowerCase()]?e[n.toLowerCase()]:/(ies)$/.test(n)?n.replace(/ies$/,"y"):/(ves)$/.test(n)?n.replace(/ves$/,"f"):/(oes|xes|ses|shes|ches|zes)$/.test(n)?n.replace(/(oes|xes|ses|shes|ches|zes)$/,""):/(s)$/.test(n)&&!/(ss)$/.test(n)?n.replace(/s$/,""):n},a=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t){return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.prev=0,n.next=3,t.query("SELECT 1");case 3:console.log("Connection success"),n.next=10;break;case 6:n.prev=6,n.t0=n.catch(0),console.error("Gagal terhubung ke database:",n.t0),process.exit(1);case 10:case"end":return n.stop()}}),e,null,[[0,6]])})));return function(n){return e.apply(this,arguments)}}(),r=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a){var r,c,o,s=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return r=s.length>2&&void 0!==s[2]?s[2]:"public",n.prev=1,"\n SELECT \n *\n FROM information_schema.columns\n WHERE table_catalog = current_database()\n AND table_name = $1\n AND table_schema = $2\n ",n.next=5,t.query("\n SELECT \n *\n FROM information_schema.columns\n WHERE table_catalog = current_database()\n AND table_name = $1\n AND table_schema = $2\n ",[a,r]);case 5:return c=n.sent,o=c.rows,n.abrupt("return",o);case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Gagal mengambil informasi tabel:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n,t){return e.apply(this,arguments)}}(),c=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a){var r,c,o,s=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return r=s.length>2&&void 0!==s[2]?s[2]:"public",n.prev=1,"\n SELECT a.attname as column_name\n FROM pg_index i\n JOIN pg_attribute a ON a.attrelid = i.indrelid AND a.attnum = ANY(i.indkey)\n JOIN pg_class c ON c.oid = i.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE i.indisprimary = true\n AND c.relname = $1\n AND n.nspname = $2\n ",n.next=5,t.query("\n SELECT a.attname as column_name\n FROM pg_index i\n JOIN pg_attribute a ON a.attrelid = i.indrelid AND a.attnum = ANY(i.indkey)\n JOIN pg_class c ON c.oid = i.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE i.indisprimary = true\n AND c.relname = $1\n AND n.nspname = $2\n ",[a,r]);case 5:return c=n.sent,o=c.rows,n.abrupt("return",o.map((function(n){return n.column_name})));case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Error fetching primary keys:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n,t){return e.apply(this,arguments)}}(),o=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a){var r,c,o,s,u,i=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return r=i.length>2&&void 0!==i[2]?i[2]:"public",n.prev=1,"\n SELECT column_name, udt_name\n FROM information_schema.columns\n WHERE table_schema = $1\n AND table_name = $2\n AND data_type = 'USER-DEFINED'\n ",n.next=5,t.query("\n SELECT column_name, udt_name\n FROM information_schema.columns\n WHERE table_schema = $1\n AND table_name = $2\n AND data_type = 'USER-DEFINED'\n ",[r,a]);case 5:if(0!==(c=n.sent).rows.length){n.next=8;break}return n.abrupt("return",[]);case 8:return o=c.rows.map((function(n){return n.udt_name})),"\n SELECT t.typname as enum_name, e.enumlabel as value\n FROM pg_type t\n JOIN pg_enum e ON t.oid = e.enumtypid\n JOIN pg_namespace n ON n.oid = t.typnamespace\n WHERE t.typname = ANY($1)\n ORDER BY t.typname, e.enumsortorder\n ",n.next=12,t.query("\n SELECT t.typname as enum_name, e.enumlabel as value\n FROM pg_type t\n JOIN pg_enum e ON t.oid = e.enumtypid\n JOIN pg_namespace n ON n.oid = t.typnamespace\n WHERE t.typname = ANY($1)\n ORDER BY t.typname, e.enumsortorder\n ",[o]);case 12:return s=n.sent,u=s.rows.reduce((function(n,e){return n[e.enum_name]||(n[e.enum_name]=[]),n[e.enum_name].push(e.value),n}),{}),n.abrupt("return",c.rows.map((function(n){return{column_name:n.column_name,enum_name:n.udt_name,values:u[n.udt_name]||[]}})));case 17:throw n.prev=17,n.t0=n.catch(1),console.error("Error fetching ENUM fields:",n.t0),n.t0;case 21:case"end":return n.stop()}}),e,null,[[1,17]])})));return function(n,t){return e.apply(this,arguments)}}(),s=function(){var a=n.asyncToGenerator(n.regeneratorRuntime().mark((function a(r,c){var o,s,i,m,l,_,p,f,g,E,b,h=arguments;return n.regeneratorRuntime().wrap((function(a){for(;;)switch(a.prev=a.next){case 0:return o=h.length>2&&void 0!==h[2]?h[2]:"public",a.prev=1,"\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND tc.table_name = $1\n AND tc.table_schema = $2\n ",a.next=5,r.query("\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND tc.table_name = $1\n AND tc.table_schema = $2\n ",[c,o]);case 5:return s=a.sent,i=s.rows,"\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND ccu.table_name = $1\n AND tc.table_schema = $2\n ",a.next=10,r.query("\n SELECT \n tc.table_name,\n kcu.column_name,\n ccu.table_name AS foreign_table_name,\n ccu.column_name AS foreign_column_name\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.key_column_usage AS kcu \n ON tc.constraint_name = kcu.constraint_name\n JOIN information_schema.constraint_column_usage AS ccu \n ON ccu.constraint_name = tc.constraint_name\n WHERE tc.constraint_type = 'FOREIGN KEY'\n AND ccu.table_name = $1\n AND tc.table_schema = $2\n ",[c,o]);case 10:m=a.sent,l=m.rows,_={},i.forEach((function(n){var a=e(t(n.foreign_table_name));_[a]={relation:"BelongsToOneRelation",relatedTable:n.foreign_table_name,foreignKey:n.column_name,localKey:n.foreign_column_name}})),p=n.createForOfIteratorHelper(l),a.prev=15,p.s();case 17:if((f=p.n()).done){a.next=26;break}return g=f.value,E=e(t(g.table_name)),a.next=22,u(r,g.table_name,g.column_name,o);case 22:b=a.sent,_[E]={relation:b?"HasOneRelation":"HasManyRelation",relatedTable:g.table_name,foreignKey:g.foreign_column_name,localKey:g.column_name};case 24:a.next=17;break;case 26:a.next=31;break;case 28:a.prev=28,a.t0=a.catch(15),p.e(a.t0);case 31:return a.prev=31,p.f(),a.finish(31);case 34:return a.abrupt("return",_);case 37:throw a.prev=37,a.t1=a.catch(1),console.error("Error fetching table relations:",a.t1),a.t1;case 41:case"end":return a.stop()}}),a,null,[[1,37],[15,28,31,34]])})));return function(n,e){return a.apply(this,arguments)}}(),u=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t,a,r){var c,o,s,u=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return c=u.length>3&&void 0!==u[3]?u[3]:"public",n.prev=1,"\n SELECT tc.constraint_type\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.constraint_column_usage AS ccu \n ON tc.constraint_name = ccu.constraint_name\n WHERE tc.table_name = $1\n AND ccu.column_name = $2\n AND tc.constraint_type = 'UNIQUE'\n AND tc.table_schema = $3\n ",n.next=5,t.query("\n SELECT tc.constraint_type\n FROM information_schema.table_constraints AS tc\n JOIN information_schema.constraint_column_usage AS ccu \n ON tc.constraint_name = ccu.constraint_name\n WHERE tc.table_name = $1\n AND ccu.column_name = $2\n AND tc.constraint_type = 'UNIQUE'\n AND tc.table_schema = $3\n ",[a,r,c]);case 5:return o=n.sent,s=o.rows,n.abrupt("return",s.length>0);case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Error checking unique constraint:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n,t,a){return e.apply(this,arguments)}}(),i=function(){var e=n.asyncToGenerator(n.regeneratorRuntime().mark((function e(t){var a,r,c,o=arguments;return n.regeneratorRuntime().wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return a=o.length>1&&void 0!==o[1]?o[1]:"public",n.prev=1,"\n SELECT *\n FROM information_schema.tables\n WHERE table_schema = $1\n AND table_schema NOT IN ('information_schema', 'pg_catalog')\n AND table_name NOT IN ('migrations', 'migrations_lock', '_prisma_migrations')\n AND table_type = 'BASE TABLE'\n ",n.next=5,t.query("\n SELECT *\n FROM information_schema.tables\n WHERE table_schema = $1\n AND table_schema NOT IN ('information_schema', 'pg_catalog')\n AND table_name NOT IN ('migrations', 'migrations_lock', '_prisma_migrations')\n AND table_type = 'BASE TABLE'\n ",[a]);case 5:return r=n.sent,c=r.rows,n.abrupt("return",c);case 10:throw n.prev=10,n.t0=n.catch(1),console.error("Error fetching tables:",n.t0),n.t0;case 14:case"end":return n.stop()}}),e,null,[[1,10]])})));return function(n){return e.apply(this,arguments)}}();exports.capitalize=function(n){return n.charAt(0).toUpperCase()+n.slice(1)},exports.checkDatabaseConnection=a,exports.extractEnumValue=function(n){if(!n)return null;var e=n.match(/^'(.+?)'::/);return e?e[1]:n},exports.getEnumFieldsAndValues=o,exports.getPrimaryKeys=c,exports.getTableColumns=r,exports.getTableRelations=s,exports.getTables=i,exports.isUniqueConstraint=u,exports.removePluralSuffix=t,exports.toCamelCase=e,exports.toKebabCase=function(n){return n.replace(/([a-z0-9])([A-Z])/g,"$1-$2").replace(/_/g,"-").toLowerCase()};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "frgen",
3
- "version": "0.3.3",
3
+ "version": "0.3.5",
4
4
  "description": "helper generator",
5
5
  "main": "lib/",
6
6
  "types": "lib/index.d.ts",