frgen 0.1.5 → 0.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/make_controller.js +1 -1
- package/package.json +1 -1
package/lib/make_controller.js
CHANGED
|
@@ -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(e,n){var t=n.type,a=n.nullable,o=["yup"],c=["integer","bigint","smallint","tinyint","numeric","decimal","float"].includes(t),s=["varchar","text","string","char","character varying","uuid","date","datetime","timestamp","timestamp with time zone"].includes(t),i=["boolean"].includes(t);return c?o.push("number()"):s?o.push("string()"):i?o.push("boolean()"):o.push("mixed()"),a?o.push("optional()"):o.push("required()"),o.push("label('".concat(e.replaceAll("_"," "),"')")),"".concat(r.toCamelCase(e),":").concat(o.join("."))}var o=function(){var o=e.asyncToGenerator(e.regeneratorRuntime().mark((function o(c,s,i,l){var u,d,p,m,y,h,f,x,w,g,q,b,v,R,_,j,
|
|
2
|
+
"use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),t=require("path"),r=require("./utils.js");function a(e,n){var t=n.type,a=n.nullable,o=["yup"],c=["integer","bigint","smallint","tinyint","numeric","decimal","float"].includes(t),s=["varchar","text","string","char","character varying","uuid","date","datetime","timestamp","timestamp with time zone"].includes(t),i=["boolean"].includes(t);return c?o.push("number()"):s?o.push("string()"):i?o.push("boolean()"):o.push("mixed()"),a?o.push("optional()"):o.push("required()"),o.push("label('".concat(e.replaceAll("_"," "),"')")),"".concat(r.toCamelCase(e),":").concat(o.join("."))}var o=function(){var o=e.asyncToGenerator(e.regeneratorRuntime().mark((function o(c,s,i,l){var u,d,p,m,y,h,f,x,w,g,q,b,v,R,_,F,j,C,P,A=arguments;return e.regeneratorRuntime().wrap((function(o){for(;;)switch(o.prev=o.next){case 0:return u=A.length>4&&void 0!==A[4]?A[4]:"public",d=A.length>5&&void 0!==A[5]&&A[5],o.prev=2,c||(console.error("class name undefined"),process.exit(1)),s||(console.error("table name undefined"),process.exit(1)),p="".concat(c,".ts"),m=t.join(process.cwd(),"src","app","http","controller",p),i&&"default"!==i&&("/"!==i.charAt(i.length-1)&&(i+="/"),m=t.join(process.cwd(),"src",i,p)),y=c.replace(/Controller$/,""),h=t.join(process.cwd(),"src","app","http","service","".concat(y,"Service.ts")),o.next=12,l.select("table_name","column_name","column_default","is_nullable","data_type","character_maximum_length").from("information_schema.columns").whereRaw("table_catalog = current_database()").where("table_name",null!=s?s:y+"s").where("table_schema",u);case 12:f=o.sent,x=Object.fromEntries(f.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}]}))),w="",g="",Object.keys(x).length&&(q=Object.entries(x).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),o=t[0],c=t[1];return[r.toCamelCase(o),a(o,c)]})),g="\n const validated = await req.validation((yup) => yup.object({\n ".concat(q.map((function(n){var t=e.slicedToArray(n,2);return t[0],t[1]})).join(",\n"),"\n }));\n "),w="\n const validated = await req.validation((yup) => yup.object({\n ".concat(q.filter((function(n){return"id"!==e.slicedToArray(n,1)[0]})).map((function(n){var t=e.slicedToArray(n,2);return t[0],t[1]})).join(",\n"),"\n }));\n ")),b='\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(y,'Service";\nimport ').concat(y,'Resource from "@resource/').concat(y,'Resource";\n\n@Controller("/').concat(r.toKebabCase(y),'")\nexport class ').concat(c,' {\n\n @Get("/")\n async index(req: Request, res: Response, next: NextFunction){\n try {\n const results = await getPaginate(req);\n res.json(').concat(y,'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(y,'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(w,"\n const model = await handleCreate(").concat(""===w?"req.body":"validated",");\n res.json(new ").concat(y,'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(g,"\n const model = await handleUpdate(").concat(""===g?"req.body":"validated",");\n res.json(new ").concat(y,'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'),v=y.toLowerCase(),R=d?"return prisma.".concat(v,".update({where: {id: +!id}, data: payload})"):"\n const model = await ".concat(y,'.query().findById(id);\n if (!model) {\n throw new NotFoundException("').concat(y,'");\n }\n await model.$query().updateAndFetch(payload);\n return model;\n '),_=d?"return prisma.".concat(v,".delete({where: {id}})"):" \n const model = await ".concat(y,'.query().findById(id);\n if (!model) {\n throw new NotFoundException("').concat(y,'");\n }\n await model.$query().delete();\n '),F=d?"\n const count = await prisma.".concat(v,".count();\n const results = await prisma.").concat(v,'.findMany({ take: +req.getQuery("perPage", 10), skip: +req.getQuery("page", 0) })\n return { total: count, data: results };\n '):"return ".concat(y,'.query().page(req.getQuery("page", 0), req.getQuery("perPage", 10));'),j='\n import { Request } from "express";\n '.concat(d?"import { Prisma } from '@prisma/client';":"","\n").concat(d?'import prisma from "@config/db";':"import ".concat(y,' from "@model/').concat(y,'";'),'\nimport NotFoundException from "@exception/NotFoundException";\n\n export const getPaginate = ').concat(d?"async":""," (req: Request) => {\n ").concat(F,"\n };\n\n export const getDetail = async (id:number) => {\n const model = await ").concat(d?"prisma.".concat(v,".findFirst({where : {id}})"):"".concat(y,".query().findById(id)"),';\n if (!model) {\n throw new NotFoundException("').concat(y,'")\n }\n return model;\n };\n\n export const handleCreate = (payload:').concat(d?"Prisma.".concat(y,"UncheckedCreateInput"):"any",") => {\n return ").concat(d?"prisma.".concat(v,".create({ data: payload })"):"".concat(y,".query().insertAndFetch(payload)"),";\n };\n\n export const handleUpdate = ").concat(d?"":"async"," ({id, ...payload}:").concat(d?"Prisma.".concat(y,"UncheckedUpdateInput"):"any",") => {\n ").concat(R,"\n };\n\n export const handleDelete = ").concat(d?"":"async"," (id:number) => {\n ").concat(_,"\n };\n"),C=t.dirname(m),n.existsSync(C)||n.mkdirSync(C,{recursive:!0}),P=t.dirname(h),n.existsSync(P)||n.mkdirSync(P,{recursive:!0}),n.writeFile(m,b,(function(e){e?console.error("err: ",e):console.log("File ".concat(p," has been created"))})),n.writeFile(h,j,(function(e){e?console.error("err: ",e):console.log("File ".concat(y,"Service.ts has been "))})),o.next=34;break;case 31:o.prev=31,o.t0=o.catch(2),console.error("err::",o.t0);case 34:return o.prev=34,o.finish(34);case 36:case"end":return o.stop()}}),o,null,[[2,31,34,36]])})));return function(e,n,t,r){return o.apply(this,arguments)}}();module.exports=o;
|