frgen 0.1.3 → 0.1.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.
- package/lib/main.js +1 -1
- package/lib/make_controller.js +1 -1
- package/lib/make_crud.js +1 -1
- package/lib/make_model.js +1 -1
- package/lib/make_resource.js +1 -1
- package/package.json +1 -1
package/lib/main.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),r=require("./utils.js"),a=require("./make_model.js"),t=require("./make_resource.js"),n=require("./make_controller.js"),s=require("./make_crud.js"),c=e.toArray(process.argv);c[0],c[1];var o=c[2],i=c[3],u=c[4],l=c.slice(5);o||(console.error("action undefined."),process.exit(1));var
|
|
2
|
+
"use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),r=require("./utils.js"),a=require("./make_model.js"),t=require("./make_resource.js"),n=require("./make_controller.js"),s=require("./make_crud.js"),c=e.toArray(process.argv);c[0],c[1];var o=c[2],i=c[3],u=c[4],l=c.slice(5);o||(console.error("action undefined."),process.exit(1));var f="default",p="public",k=!1;if(l.length>0){var m,v=e.createForOfIteratorHelper(l);try{for(v.s();!(m=v.n()).done;){var x=m.value.split("="),d=e.slicedToArray(x,2),b=d[0],h=d[1];"--schema"===b&&(p=h),"--path"===b&&(f=h),"--orm"===b&&"prisma"===h&&(k=!0)}}catch(e){v.e(e)}finally{v.f()}}if("make:crud"===o){var y=e.toArray(process.argv);y[0],y[1],y[2];var g=y.slice(3);if(g.length>0){var j,q=e.createForOfIteratorHelper(g);try{for(q.s();!(j=q.n()).done;){var _=j.value.split("="),A=e.slicedToArray(_,2),H=A[0],T=A[1];"--schema"===H&&(p=T),"--orm"===H&&"prisma"===T&&(k=!0)}}catch(e){q.e(e)}finally{q.f()}}}(function(){var c=e.asyncToGenerator(e.regeneratorRuntime().mark((function c(){var l,m;return e.regeneratorRuntime().wrap((function(c){for(;;)switch(c.prev=c.next){case 0:return c.next=2,r.loadConfig();case 2:return l=c.sent,m=require("knex")(e.objectSpread2({},l)),c.prev=4,c.next=7,r.checkDatabaseConnection(m);case 7:if("make:model"!==o){c.next=12;break}return c.next=10,a(i,u,m,p);case 10:c.next=25;break;case 12:if("make:resource"!==o){c.next=17;break}return c.next=15,t(i,u,m,p);case 15:c.next=25;break;case 17:if("make:controller"!==o){c.next=22;break}return c.next=20,n(i,u,f,m,p,k);case 20:c.next=25;break;case 22:if("make:crud"!==o){c.next=25;break}return c.next=25,s(f,m,p,k);case 25:c.next=31;break;case 27:c.prev=27,c.t0=c.catch(4),console.log(c.t0),process.exit(1);case 31:return c.prev=31,m.destroy(),c.finish(31);case 34:case"end":return c.stop()}}),c,null,[[4,27,31,34]])})));return function(){return c.apply(this,arguments)}})()();
|
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
|
|
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,F,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 const model = await handleDelete(+req.params.id)\n res.json(new ').concat(y,"Resource(model, true));\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 return model;\n '),j=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));'),F='\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(j,"\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,F,(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;
|
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"),a=require("./make_resource.js"),n=require("./utils.js"),
|
|
2
|
+
"use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),r=require("./make_controller.js"),t=require("./make_model.js"),a=require("./make_resource.js"),n=require("./utils.js"),o=function(){var o=e.asyncToGenerator(e.regeneratorRuntime().mark((function o(s,c){var i,l,u,m,p,h,f,_,v,b,g=arguments;return e.regeneratorRuntime().wrap((function(o){for(;;)switch(o.prev=o.next){case 0:return i=g.length>2&&void 0!==g[2]?g[2]:"public",l=g.length>3&&void 0!==g[3]&&g[3],o.prev=2,o.next=5,c.select("*").from("information_schema.tables").whereNotIn("table_schema",["information_schema","pg_catalog"]).whereNotIn("table_name",["migrations","migrations_lock","_prisma_migrations"]).where("table_type","BASE TABLE").where("table_schema",i);case 5:u=o.sent,console.log("Schema",i),m=e.createForOfIteratorHelper(u),o.prev=8,m.s();case 10:if((p=m.n()).done){o.next=25;break}if(h=p.value,f=h.table_name,_=n.capitalize(n.toCamelCase(n.removePluralSuffix(f))),v="".concat(_,"Resource"),b="".concat(_,"Controller"),l){o.next=19;break}return o.next=19,t(_,f,c,i);case 19:return o.next=21,a(v,f,c,i);case 21:return o.next=23,r(b,f,s,c,i,l);case 23:o.next=10;break;case 25:o.next=30;break;case 27:o.prev=27,o.t0=o.catch(8),m.e(o.t0);case 30:return o.prev=30,m.f(),o.finish(30);case 33:o.next=38;break;case 35:o.prev=35,o.t1=o.catch(2),console.log(o.t1);case 38:return o.prev=38,o.finish(38);case 40:case"end":return o.stop()}}),o,null,[[2,35,38,40],[8,27,30,33]])})));return function(e,r){return o.apply(this,arguments)}}();module.exports=o;
|
package/lib/make_model.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),a=require("path"),t=require("./utils.js");function r(e,n){return c.apply(this,arguments)}function c(){return(c=e.asyncToGenerator(e.regeneratorRuntime().mark((function n(a,r){var c,o,i;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=3,r.select("tc.table_name","kcu.column_name","ccu.table_name as foreign_table_name","ccu.column_name as foreign_column_name").from("information_schema.table_constraints as tc").join("information_schema.key_column_usage as kcu","tc.constraint_name","kcu.constraint_name").join("information_schema.constraint_column_usage as ccu","ccu.constraint_name","tc.constraint_name").where("tc.constraint_type","FOREIGN KEY").andWhere("tc.table_name",a);case 3:return c=e.sent,e.next=6,r.select("tc.table_name","kcu.column_name","ccu.table_name as foreign_table_name","ccu.column_name as foreign_column_name").from("information_schema.table_constraints as tc").join("information_schema.key_column_usage as kcu","tc.constraint_name","kcu.constraint_name").join("information_schema.constraint_column_usage as ccu","ccu.constraint_name","tc.constraint_name").where("tc.constraint_type","FOREIGN KEY").andWhere("ccu.table_name",a);case 6:return o=e.sent,i={},c.forEach((function(e){var n=e.foreign_table_name;i[t.toCamelCase(t.removePluralSuffix(n))]={relation:"BelongsToOneRelation",relatedTable:e.foreign_table_name,foreignKey:e.column_name,localKey:e.foreign_column_name}})),o.forEach((function(e){var n=e.table_name;i[t.toCamelCase(t.removePluralSuffix(n))]={relation:"HasOneRelation",relatedTable:e.table_name,foreignKey:e.foreign_column_name,localKey:e.column_name},i[t.toCamelCase(n)]={relation:"HasManyRelation",relatedTable:e.table_name,foreignKey:e.foreign_column_name,localKey:e.column_name}})),e.abrupt("return",i);case 11:case"end":return e.stop()}}),n)})))).apply(this,arguments)}function o(n){return Array.from(new Set(Object.entries(n).map((function(n){var a=e.slicedToArray(n,2);a[0];var r=a[1].relatedTable;return"import ".concat(t.capitalize(t.toCamelCase(t.removePluralSuffix(r)))," from './").concat(t.capitalize(t.toCamelCase(t.removePluralSuffix(r))),"';")})))).join("\n")}function i(n,a){var r=Object.entries(n).map((function(n){var r=e.slicedToArray(n,2),c=r[0],o=r[1],i=o.relation,l=o.relatedTable,s=o.foreignKey,m=o.localKey;return"\n ".concat(c,": {\n relation: Model.").concat(i,",\n modelClass: ").concat(t.capitalize(t.toCamelCase(t.removePluralSuffix(l))),",\n join: {\n ").concat("ManyToManyRelation"===i?"\n from: '".concat(m,"',\n through: {\n from: '").concat(s,"',\n to: '").concat(s,"'\n },\n to: '").concat(m,"'"):"\n from: '".concat(a,".").concat(s,"',\n to: '").concat(l,".").concat(m,"'"),"\n }\n }")})).join(",");return"\nstatic get relationMappings() {\nreturn {".concat(r,"\n};\n}")}var l=function(){var c=e.asyncToGenerator(e.regeneratorRuntime().mark((function c(l,s,m){var u,_,f,p,b,d,g,h,y,v,x,C,j=arguments;return e.regeneratorRuntime().wrap((function(c){for(;;)switch(c.prev=c.next){case 0:return u=j.length>3&&void 0!==j[3]?j[3]:"public",c.prev=1,l||(console.error("class name undefined"),process.exit(1)),s||(console.error("table name undefined"),process.exit(1)),_="".concat(l,".ts"),f=a.join(process.cwd(),"src","app","model",_),c.next=8,m.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:l.toLowerCase()+"s").where("table_schema",u);case 8:return p=c.sent,b=Object.fromEntries(p.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=12,r(s,m,u);case 12:d=c.sent,g=Object.entries(b).map((function(n){var a,r=e.slicedToArray(n,2),c=r[0],o=r[1],i=t.toCamelCase(c),l=(a=o.type,["integer","bigint","smallint","tinyint","numeric","decimal","float"].includes(a)?"number":["varchar","text","string","char","character varying","uuid"].includes(a)?"string":["boolean"].includes(a)?"boolean":["date","datetime","timestamp","timestamp with time zone"].includes(a)?"Date":"any");return" public ".concat(i,": ").concat(l,";")})).join("\n"),h='\n static get tableName() {\n return "'.concat(l.toLowerCase(),'s";\n }\n '),s&&(h='\n static get tableName() {\n return "'.concat(s,'";\n }\n ')),y=d?o(d):"",v=d?i(d,s):"",x='\n import Model from "@lib/Model";\n import { snakeCaseMappers } from "objection";\n '.concat(y,"\n \n export default class ").concat(l," extends Model {\n \n ").concat(g,"\n \n ").concat(h,'\n \n static get idColumn() {\n return "id";\n }\n \n static get columnNameMappers() {\n return snakeCaseMappers();\n }\n \n ').concat(v,"\n }"),C=a.dirname(f),n.existsSync(C)||n.mkdirSync(C,{recursive:!0}),n.writeFile(f,x,(function(e){e?console.error("
|
|
2
|
+
"use strict";var e=require("./_virtual/_rollupPluginBabelHelpers.js"),n=require("fs"),a=require("path"),t=require("./utils.js");function r(e,n){return c.apply(this,arguments)}function c(){return(c=e.asyncToGenerator(e.regeneratorRuntime().mark((function n(a,r){var c,o,i;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=3,r.select("tc.table_name","kcu.column_name","ccu.table_name as foreign_table_name","ccu.column_name as foreign_column_name").from("information_schema.table_constraints as tc").join("information_schema.key_column_usage as kcu","tc.constraint_name","kcu.constraint_name").join("information_schema.constraint_column_usage as ccu","ccu.constraint_name","tc.constraint_name").where("tc.constraint_type","FOREIGN KEY").andWhere("tc.table_name",a);case 3:return c=e.sent,e.next=6,r.select("tc.table_name","kcu.column_name","ccu.table_name as foreign_table_name","ccu.column_name as foreign_column_name").from("information_schema.table_constraints as tc").join("information_schema.key_column_usage as kcu","tc.constraint_name","kcu.constraint_name").join("information_schema.constraint_column_usage as ccu","ccu.constraint_name","tc.constraint_name").where("tc.constraint_type","FOREIGN KEY").andWhere("ccu.table_name",a);case 6:return o=e.sent,i={},c.forEach((function(e){var n=e.foreign_table_name;i[t.toCamelCase(t.removePluralSuffix(n))]={relation:"BelongsToOneRelation",relatedTable:e.foreign_table_name,foreignKey:e.column_name,localKey:e.foreign_column_name}})),o.forEach((function(e){var n=e.table_name;i[t.toCamelCase(t.removePluralSuffix(n))]={relation:"HasOneRelation",relatedTable:e.table_name,foreignKey:e.foreign_column_name,localKey:e.column_name},i[t.toCamelCase(n)]={relation:"HasManyRelation",relatedTable:e.table_name,foreignKey:e.foreign_column_name,localKey:e.column_name}})),e.abrupt("return",i);case 11:case"end":return e.stop()}}),n)})))).apply(this,arguments)}function o(n){return Array.from(new Set(Object.entries(n).map((function(n){var a=e.slicedToArray(n,2);a[0];var r=a[1].relatedTable;return"import ".concat(t.capitalize(t.toCamelCase(t.removePluralSuffix(r)))," from './").concat(t.capitalize(t.toCamelCase(t.removePluralSuffix(r))),"';")})))).join("\n")}function i(n,a){var r=Object.entries(n).map((function(n){var r=e.slicedToArray(n,2),c=r[0],o=r[1],i=o.relation,l=o.relatedTable,s=o.foreignKey,m=o.localKey;return"\n ".concat(c,": {\n relation: Model.").concat(i,",\n modelClass: ").concat(t.capitalize(t.toCamelCase(t.removePluralSuffix(l))),",\n join: {\n ").concat("ManyToManyRelation"===i?"\n from: '".concat(m,"',\n through: {\n from: '").concat(s,"',\n to: '").concat(s,"'\n },\n to: '").concat(m,"'"):"\n from: '".concat(a,".").concat(s,"',\n to: '").concat(l,".").concat(m,"'"),"\n }\n }")})).join(",");return"\nstatic get relationMappings() {\nreturn {".concat(r,"\n};\n}")}var l=function(){var c=e.asyncToGenerator(e.regeneratorRuntime().mark((function c(l,s,m){var u,_,f,p,b,d,g,h,y,v,x,C,j=arguments;return e.regeneratorRuntime().wrap((function(c){for(;;)switch(c.prev=c.next){case 0:return u=j.length>3&&void 0!==j[3]?j[3]:"public",c.prev=1,l||(console.error("class name undefined"),process.exit(1)),s||(console.error("table name undefined"),process.exit(1)),_="".concat(l,".ts"),f=a.join(process.cwd(),"src","app","model",_),c.next=8,m.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:l.toLowerCase()+"s").where("table_schema",u);case 8:return p=c.sent,b=Object.fromEntries(p.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=12,r(s,m,u);case 12:d=c.sent,g=Object.entries(b).map((function(n){var a,r=e.slicedToArray(n,2),c=r[0],o=r[1],i=t.toCamelCase(c),l=(a=o.type,["integer","bigint","smallint","tinyint","numeric","decimal","float"].includes(a)?"number":["varchar","text","string","char","character varying","uuid"].includes(a)?"string":["boolean"].includes(a)?"boolean":["date","datetime","timestamp","timestamp with time zone"].includes(a)?"Date":"any");return" public ".concat(i,": ").concat(l,";")})).join("\n"),h='\n static get tableName() {\n return "'.concat(l.toLowerCase(),'s";\n }\n '),s&&(h='\n static get tableName() {\n return "'.concat(s,'";\n }\n ')),y=d?o(d):"",v=d?i(d,s):"",x='\n import Model from "@lib/Model";\n import { snakeCaseMappers } from "objection";\n '.concat(y,"\n \n export default class ").concat(l," extends Model {\n \n ").concat(g,"\n \n ").concat(h,'\n \n static get idColumn() {\n return "id";\n }\n \n static get columnNameMappers() {\n return snakeCaseMappers();\n }\n \n ').concat(v,"\n }"),C=a.dirname(f),n.existsSync(C)||n.mkdirSync(C,{recursive:!0}),n.writeFile(f,x,(function(e){e?console.error("err::",e):console.log("File ".concat(_," has been created"))})),c.next=27;break;case 24:c.prev=24,c.t0=c.catch(1),console.error("err::",c.t0);case 27:return c.prev=27,c.finish(27);case 29:case"end":return c.stop()}}),c,null,[[1,24,27,29]])})));return function(e,n,a){return c.apply(this,arguments)}}();module.exports=l;
|
package/lib/make_resource.js
CHANGED
|
@@ -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"),a=function(){var a=e.asyncToGenerator(e.regeneratorRuntime().mark((function a(c,o,
|
|
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,m,p,f,d,_,h=arguments;return e.regeneratorRuntime().wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return u=h.length>3&&void 0!==h[3]?h[3]:"public",e.prev=1,c||(console.error("class name undefined"),process.exit(1)),o||(console.error("table name undefined"),process.exit(1)),l="".concat(c.replace("Resource",""),"Resource.ts"),i=n.join(process.cwd(),"src","app","http","resource",l),e.next=8,s.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",o).where("table_schema",u);case 8:m=e.sent,p=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}]}))),f=Object.keys(p).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"),d='\nimport Resource from "frexp/lib/Resource";\n\nexport default class '.concat(c," extends Resource {\n toArray() {\n return {\n").concat(f,"\n };\n }\n}"),_=n.dirname(i),r.existsSync(_)||r.mkdirSync(_,{recursive:!0}),r.writeFile(i,d,(function(e){e?console.error("err:",e):console.log("File ".concat(l," has been created"))})),e.next=20;break;case 17:e.prev=17,e.t0=e.catch(1),console.error("err::",e.t0);case 20:return e.prev=20,e.finish(20);case 22:case"end":return e.stop()}}),a,null,[[1,17,20,22]])})));return function(e,r,n){return a.apply(this,arguments)}}();module.exports=a;
|