@andrewcaires/express 1.1.10 → 1.2.0

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/dist/index.cjs.js CHANGED
@@ -1,7 +1,7 @@
1
1
  /*!
2
- * @andrewcaires/express v1.1.10
2
+ * @andrewcaires/express v1.2.0
3
3
  * Decorators for express
4
4
  * (c) 2024 Andrew Caires
5
5
  * @license: MIT
6
6
  */
7
- "use strict";var e=require("@andrewcaires/node"),t=require("@andrewcaires/utils.js"),s=require("cookie-parser"),r=require("cors"),o=require("express"),i=require("express-session"),n=require("fs"),a=require("http"),p=require("https"),h=require("net"),_=require("path"),E=require("multer");function d(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(s){if("default"!==s){var r=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(t,s,r.get?r:{enumerable:!0,get:function(){return e[s]}})}})),t.default=e,Object.freeze(t)}var u=d(a),c=d(p);function l(e,t,s,r){return new(s||(s=Promise))((function(o,i){function n(e){try{p(r.next(e))}catch(e){i(e)}}function a(e){try{p(r.throw(e))}catch(e){i(e)}}function p(e){var t;e.done?o(e.value):(t=e.value,t instanceof s?t:new s((function(e){e(t)}))).then(n,a)}p((r=r.apply(e,t||[])).next())}))}"function"==typeof SuppressedError&&SuppressedError;class T{}T.CONTINUE=100,T.SWITCHING_PROTOCOLS=101,T.PROCESSING=102,T.OK=200,T.CREATED=201,T.ACCEPTED=202,T.NON_AUTHORITATIVE_INFORMATION=203,T.NO_CONTENT=204,T.RESET_CONTENT=205,T.PARTIAL_CONTENT=206,T.MULTI_STATUS=207,T.ALREADY_REPORTED=208,T.IM_USED=226,T.MULTIPLE_CHOICES=300,T.MOVED_PERMANENTLY=301,T.FOUND=302,T.SEE_OTHER=303,T.NOT_MODIFIED=304,T.USE_PROXY=305,T.TEMPORARY_REDIRECT=307,T.PERMANENT_REDIRECT=308,T.BAD_REQUEST=400,T.UNAUTHORIZED=401,T.PAYMENT_REQUIRED=402,T.FORBIDDEN=403,T.NOT_FOUND=404,T.METHOD_NOT_ALLOWED=405,T.NOT_ACCEPTABLE=406,T.PROXY_AUTHENTICATION_REQUIRED=407,T.REQUEST_TIMEOUT=408,T.CONFLICT=409,T.GONE=410,T.LENGTH_REQUIRED=411,T.PRECONDITION_FAILED=412,T.PAYLOAD_TOO_LARGE=413,T.REQUEST_URI_TOO_LONG=414,T.UNSUPPORTED_MEDIA_TYPE=415,T.REQUESTED_RANGE_NOT_SATISFIABLE=416,T.EXPECTATION_FAILED=417,T.IM_A_TEAPOT=418,T.MISDIRECTED_REQUEST=421,T.UNPROCESSABLE_ENTITY=422,T.LOCKED=423,T.FAILED_DEPENDENCY=424,T.UPGRADE_REQUIRED=426,T.PRECONDITION_REQUIRED=428,T.TOO_MANY_REQUESTS=429,T.REQUEST_HEADER_FIELDS_TOO_LARGE=431,T.CONNECTION_CLOSED_WITHOUT_RESPONSE=444,T.UNAVAILABLE_FOR_LEGAL_REASONS=451,T.CLIENT_CLOSED_REQUEST=499,T.INTERNAL_SERVER_ERROR=500,T.NOT_IMPLEMENTED=501,T.BAD_GATEWAY=502,T.SERVICE_UNAVAILABLE=503,T.GATEWAY_TIMEOUT=504,T.HTTP_VERSION_NOT_SUPPORTED=505,T.VARIANT_ALSO_NEGOCIATES=506,T.INSUFFICIENT_STORAGE=507,T.LOOP_DETECTED=508,T.NOT_EXTENDED=510,T.NETWORK_AUTHENTICATION_REQUIRED=511,T.NETWORK_CONNECTION_TIMEOUT_ERROR=599;class O{constructor(e,t,s,r){this.req=e,this.res=t,this.next=s,this.controller=r}close(e){this.res.headersSent||this.res.json(e||this.storage)}destroy(e){var t;e&&this.error(e.message),null===(t=this.res.socket)||void 0===t||t.destroy(e)}error(e){this.send(T.INTERNAL_SERVER_ERROR,{message:e})}file(e){this.res.headersSent||(this.status(T.OK),this.res.sendFile(_.resolve(e)))}json(e){this.send(T.OK,e)}notFound(e){this.send(T.NOT_FOUND,{message:e})}prepare(e,t){this.res.headersSent||(this.status(e),this.storage=t)}send(e,t){this.res.headersSent||(this.status(e),this.res.json(t))}status(e){return e&&this.res.status(e),this.res.statusCode}success(e){this.send(T.OK,{message:e})}unauthorized(e){this.send(T.UNAUTHORIZED,{message:e})}validation(e){this.send(T.BAD_REQUEST,{message:e})}}const R=t.cache(),x=(e,s,r)=>{t.isObject(s)&&(s=s.constructor);const o=R(s);return o[e]||(o[e]=r),o[e]};var A,N;exports.MetadataKeys=void 0,(A=exports.MetadataKeys||(exports.MetadataKeys={})).EXTENDS="__extends__",A.MIDDLEWARE="__middleware__",A.PARAMETERS="__parameters__",A.PATH="__path__",A.ROUTERS="__routers__",exports.Methods=void 0,(N=exports.Methods||(exports.Methods={})).ALL="all",N.GET="get",N.POST="post",N.PUT="put",N.HEAD="head",N.DELETE="delete",N.OPTIONS="options",N.PATCH="patch";class I extends t.EventEmitter{get instance(){return this._app}get router(){return this._router}get server(){return this._server}constructor(e,a){var p;super(),this._app=o(),this._options={},this._default={cross:!1,hybrid:!1,path:"/",port:3e3,session:{secret:"yoursecret",resave:!0,saveUninitialized:!1,cookie:{maxAge:864e5}}},this._router=o.Router(),this._controllers=o.Router(),this._options=t.merge(Object.assign({},this._default),Object.assign({},a)),this._app.use(o.json(this._options.json)),this._app.disable("x-powered-by"),this._app.use(o.urlencoded({extended:!0})),this._options.cross&&this._app.use(r(t.isObject(this._options.cross)?this._options.cross:{}));const h=this._options.cookie;this._app.use(s(null==h?void 0:h.secret,null==h?void 0:h.options)),this._app.use(i(this._options.session)),this.init(),this._app.use(this._router);const E=(null===(p=this._options.path)||void 0===p?void 0:p.length)?this._options.path:"/";if(this._app.use(E,this._controllers),this._app.all(E+"/*",((e,t)=>{this._options.redirect?t.redirect(this._options.redirect):(t.status(T.NOT_FOUND),t.json({message:"Invalid API"}))})),this._options.public){const e=_.resolve(this._options.public);n.existsSync(e)&&this._app.use(o.static(e)),this._app.get("*",((t,s)=>{n.existsSync(e)?s.sendFile(e+"/index.html"):this._options.notfound?s.redirect(this._options.notfound):(s.status(T.NOT_FOUND),s.json({message:'File "index.html" not found'}))}))}e.forEach((e=>{const s=o.Router(),r=this._middlewares(e),i=this._parameters(e);this._extends(e).forEach((e=>{r.push(...this._middlewares(e)),i.push(...this._parameters(e))})),this._routers(e).forEach((o=>{const n=o.propertyKey.toString();if(t.isFunction(e[n])){if(!t.isFunction(s[o.method]))return this._notFound(o.method);const a=this._handles(e,n,r,i);return s[o.method](o.path,...a,((s,r,o)=>l(this,void 0,void 0,(function*(){const a=new O(s,r,o,e),p=this._args(a,this._indexes(n,i)),h=yield e[n](...p);a.close(t.isArray(h)||t.isObject(h)?h:void 0)}))))}this._notFound(`${e.name}.${n}`)})),this._extends(e).forEach((o=>{this._routers(o).forEach((o=>{const n=o.propertyKey.toString();if(t.isFunction(e[n])){if(!t.isFunction(s[o.method]))return this._notFound(o.method);const a=this._handles(e,n,r,i);return s[o.method](o.path,...a,((s,r,o)=>l(this,void 0,void 0,(function*(){const a=new O(s,r,o,e),p=this._args(a,this._indexes(n,i)),h=yield e[n](...p);a.close(t.isArray(h)||t.isObject(h)?h:void 0)}))))}this._notFound(`${e.constructor.name}.${n}`)}))})),this._controllers.use(this._path(e),s)}))}init(){}error(t,s){e.Log.error(t)}log(t,s){e.Log.info(t)}_args(e,t,s){const r=[],o={ctx:e,key:"",app:this,argument:s};return t.forEach((e=>{r[e.parameterIndex]=e.callback(Object.assign(Object.assign({},o),{key:e.key}))})),r}_handles(e,s,r,o){return r.filter((e=>e.propertyKey==s)).map((s=>{if(t.isFunction(e[s.method])){const r=this._indexes(s.method,o);return(o,i,n)=>l(this,void 0,void 0,(function*(){const a=new O(o,i,n,e),p=t.isFunction(s.argument)?s.argument(a):s.argument,h=yield e[s.method](...this._args(a,r,p));(t.isArray(h)||t.isObject(h))&&a.close(h)}))}this._notFound(s.method)})).filter(t.isFunction)}_extends(e){return x(exports.MetadataKeys.EXTENDS,e,[]).reduce(((e,t)=>(e.push(t,...this._extends(t)),e)),[]).filter(((e,t,s)=>s.indexOf(e)===t))}_indexes(e,t){return t.filter((t=>t.propertyKey==e))}_middlewares(e){return[...x(exports.MetadataKeys.MIDDLEWARE,e,[])].reverse()}_notFound(e){this.error(new Error(`Router "${e}" not found`),"express")}_parameters(e){return x(exports.MetadataKeys.PARAMETERS,e,[])}_path(e){return x(exports.MetadataKeys.PATH,e,"/")}_port(e){return`Server listening on port ${e}`}_routers(e){return x(exports.MetadataKeys.ROUTERS,e,[])}listen(){return l(this,void 0,void 0,(function*(){if(this._options.cert&&this._options.key||(this._server=u.createServer(this._app),this._server.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express")))),!this._server){const e=u.createServer(((e,t)=>{const s=80==this._options.port?":80":"";t.writeHead(T.MOVED_PERMANENTLY,{Location:`https://${e.headers.host}${s}${e.url}`}),t.end()})),t=c.createServer({key:this._options.key,cert:this._options.cert},this._app);if(this._options.hybrid){new h.Server((s=>{s.once("data",(r=>{s.pause(),s.unshift(r),(22===r[0]?t:e).emit("connection",s),process.nextTick((()=>s.resume()))}))})).listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=t}this._server||(443==this._options.port&&e.listen(80,(()=>this.log(this._port(80),"express"))),t.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=t)}}))}}const S=e=>t=>(s,r)=>{x(exports.MetadataKeys.ROUTERS,s,[]).push({method:e,path:(null==t?void 0:t.length)?t:"/",propertyKey:r})},y=S(exports.Methods.ALL),D=S(exports.Methods.GET),f=S(exports.Methods.POST),m=S(exports.Methods.PUT),v=S(exports.Methods.DELETE),M=S(exports.Methods.PATCH),U=S(exports.Methods.HEAD),g=S(exports.Methods.OPTIONS),P=e=>t=>(s,r,o)=>{x(exports.MetadataKeys.PARAMETERS,s,[]).push({callback:e,key:t,propertyKey:r,parameterIndex:o})},L=(e,s)=>t.isUndefined(s)?e:e[s],C=P((({app:e})=>e)),F=P((({argument:e})=>e)),K=P((({ctx:e,key:t})=>L(e.req.body,t))),b=P((({ctx:e,key:t})=>L(e.req.cookies,t))),j=P((({ctx:e})=>e)),k=P((({ctx:e})=>t.toArray(e.req.files))),H=P((({ctx:e,key:t})=>L(e.req.headers,t))),q=P((({ctx:e,key:t})=>L(e.req.params,t))),w=P((({ctx:e,key:t})=>L(e.req.query,t))),G=P((({ctx:e})=>e.req.session));class Q{static file(e,s){const r=t.uuidv4()+"."+s;return n.existsSync(_.join(e,r))?Q.file(e,s):r}static middleware(e,t){const s=Q._cache(t);s.upload||(s.upload=Q.multer(t)),s.upload(e.req,e.res,(t=>{if(t)return e.destroy(t);e.next()}))}static multer(e){const t=(null==e?void 0:e.path)||"./",s=E.diskStorage({destination:(e,s,r)=>r(null,t),filename:(e,s,r)=>l(this,void 0,void 0,(function*(){return r(null,Q.file(t,s.originalname.split(".").pop()||"bin"))}))}),r=(null==e?void 0:e.types)||[];return E({storage:s,fileFilter(e,t,s){return l(this,void 0,void 0,(function*(){if(r.length){const e=t.originalname.split(".").pop()||"bin";return-1!=r.indexOf(t.mimetype)||-1!=r.indexOf(e)?s(null,!0):s(new Error("File not allowed"))}return s(null,!0)}))},limits:{fileSize:1e6*((null==e?void 0:e.size)||5)}}).array((null==e?void 0:e.field)||"field",(null==e?void 0:e.count)||1)}}Q._cache=t.cache(),exports.All=y,exports.App=C,exports.Application=I,exports.Argument=F,exports.Body=K,exports.Context=O,exports.Controller=e=>t=>{x(exports.MetadataKeys.PATH,t,(null==e?void 0:e.length)?e:"/")},exports.Cookies=b,exports.Ctx=j,exports.Delete=v,exports.Extends=e=>t=>{x(exports.MetadataKeys.EXTENDS,t,[]).push(e)},exports.Files=k,exports.Get=D,exports.Head=U,exports.Headers=H,exports.Metadata=x,exports.Middleware=(e,t)=>(s,r)=>{x(exports.MetadataKeys.MIDDLEWARE,s,[]).push({method:e,argument:t,propertyKey:r})},exports.Options=g,exports.Params=q,exports.Patch=M,exports.Post=f,exports.Put=m,exports.Query=w,exports.Session=G,exports.Status=T,exports.Upload=Q,exports.methodFactory=S,exports.parameterFactory=P;
7
+ "use strict";var e=require("@andrewcaires/node"),t=require("@andrewcaires/utils.js"),s=require("compression"),r=require("cookie-parser"),o=require("cors"),i=require("express"),n=require("express-session"),a=require("fs"),p=require("http"),h=require("https"),E=require("net"),u=require("path"),d=require("request-ip"),_=require("multer");function c(e){var t=Object.create(null);return e&&Object.keys(e).forEach((function(s){if("default"!==s){var r=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(t,s,r.get?r:{enumerable:!0,get:function(){return e[s]}})}})),t.default=e,Object.freeze(t)}var l=c(p),T=c(h);function O(e,t,s,r){return new(s||(s=Promise))((function(o,i){function n(e){try{p(r.next(e))}catch(e){i(e)}}function a(e){try{p(r.throw(e))}catch(e){i(e)}}function p(e){var t;e.done?o(e.value):(t=e.value,t instanceof s?t:new s((function(e){e(t)}))).then(n,a)}p((r=r.apply(e,t||[])).next())}))}"function"==typeof SuppressedError&&SuppressedError;class R{}R.CONTINUE=100,R.SWITCHING_PROTOCOLS=101,R.PROCESSING=102,R.OK=200,R.CREATED=201,R.ACCEPTED=202,R.NON_AUTHORITATIVE_INFORMATION=203,R.NO_CONTENT=204,R.RESET_CONTENT=205,R.PARTIAL_CONTENT=206,R.MULTI_STATUS=207,R.ALREADY_REPORTED=208,R.IM_USED=226,R.MULTIPLE_CHOICES=300,R.MOVED_PERMANENTLY=301,R.FOUND=302,R.SEE_OTHER=303,R.NOT_MODIFIED=304,R.USE_PROXY=305,R.TEMPORARY_REDIRECT=307,R.PERMANENT_REDIRECT=308,R.BAD_REQUEST=400,R.UNAUTHORIZED=401,R.PAYMENT_REQUIRED=402,R.FORBIDDEN=403,R.NOT_FOUND=404,R.METHOD_NOT_ALLOWED=405,R.NOT_ACCEPTABLE=406,R.PROXY_AUTHENTICATION_REQUIRED=407,R.REQUEST_TIMEOUT=408,R.CONFLICT=409,R.GONE=410,R.LENGTH_REQUIRED=411,R.PRECONDITION_FAILED=412,R.PAYLOAD_TOO_LARGE=413,R.REQUEST_URI_TOO_LONG=414,R.UNSUPPORTED_MEDIA_TYPE=415,R.REQUESTED_RANGE_NOT_SATISFIABLE=416,R.EXPECTATION_FAILED=417,R.IM_A_TEAPOT=418,R.MISDIRECTED_REQUEST=421,R.UNPROCESSABLE_ENTITY=422,R.LOCKED=423,R.FAILED_DEPENDENCY=424,R.UPGRADE_REQUIRED=426,R.PRECONDITION_REQUIRED=428,R.TOO_MANY_REQUESTS=429,R.REQUEST_HEADER_FIELDS_TOO_LARGE=431,R.CONNECTION_CLOSED_WITHOUT_RESPONSE=444,R.UNAVAILABLE_FOR_LEGAL_REASONS=451,R.CLIENT_CLOSED_REQUEST=499,R.INTERNAL_SERVER_ERROR=500,R.NOT_IMPLEMENTED=501,R.BAD_GATEWAY=502,R.SERVICE_UNAVAILABLE=503,R.GATEWAY_TIMEOUT=504,R.HTTP_VERSION_NOT_SUPPORTED=505,R.VARIANT_ALSO_NEGOCIATES=506,R.INSUFFICIENT_STORAGE=507,R.LOOP_DETECTED=508,R.NOT_EXTENDED=510,R.NETWORK_AUTHENTICATION_REQUIRED=511,R.NETWORK_CONNECTION_TIMEOUT_ERROR=599;class N{constructor(e,t,s,r){this.req=e,this.res=t,this.next=s,this.controller=r}close(e){this.res.headersSent||this.res.json(e||this.storage)}destroy(e){var t;e&&this.error(e.message),null===(t=this.res.socket)||void 0===t||t.destroy(e)}error(e){this.send(R.INTERNAL_SERVER_ERROR,{message:e})}file(e){this.res.headersSent||(this.status(R.OK),this.res.sendFile(u.resolve(e)))}ip(){return d.getClientIp(this.req)||"0.0.0.0"}json(e){this.send(R.OK,e)}notFound(e){this.send(R.NOT_FOUND,{message:e})}prepare(e,t){this.res.headersSent||(this.status(e),this.storage=t)}send(e,t){this.res.headersSent||(this.status(e),this.res.json(t))}status(e){return e&&this.res.status(e),this.res.statusCode}success(e){this.send(R.OK,{message:e})}unauthorized(e){this.send(R.UNAUTHORIZED,{message:e})}validation(e){this.send(R.BAD_REQUEST,{message:e})}}class A{static extends(t){return e.Metadata(A.EXTENDS,t,[])}static middleware(t){return e.Metadata(A.MIDDLEWARE,t,[])}static parameters(t){return e.Metadata(A.PARAMETERS,t,[])}static path(t,s){return e.Metadata(A.PATH,t,s)}static routers(t){return e.Metadata(A.ROUTERS,t,[])}}A.EXTENDS=Symbol(),A.MIDDLEWARE=Symbol(),A.PARAMETERS=Symbol(),A.PATH=Symbol(),A.ROUTERS=Symbol();class x extends t.EventEmitter{get instance(){return this._app}get router(){return this._router}get server(){return this._server}constructor(e,p){var h;super(),this._app=i(),this._options={},this._default={cross:!1,hybrid:!1,path:"/",port:3e3,session:{secret:"yoursecret",resave:!0,saveUninitialized:!1,cookie:{maxAge:864e5}}},this._router=i.Router(),this._controllers=i.Router(),this._options=t.merge(Object.assign({},this._default),Object.assign({},p)),this._app.use(i.json(this._options.json)),this._app.disable("x-powered-by"),this._app.use(i.urlencoded({extended:!0})),this._options.cross&&this._app.use(o(t.isObject(this._options.cross)?this._options.cross:{}));const E=this._options.cookie;this._app.use(s()),this._app.use(r(null==E?void 0:E.secret,null==E?void 0:E.options)),this._app.use(n(this._options.session)),this.init(),this._app.use(this._router);const d=(null===(h=this._options.path)||void 0===h?void 0:h.length)?this._options.path:"/";if(this._app.use(d,this._controllers),this._app.all(d+"/*",((e,t)=>{this._options.redirect?t.redirect(this._options.redirect):(t.status(R.NOT_FOUND),t.json({message:"Invalid API"}))})),this._options.public){const e=u.resolve(this._options.public);a.existsSync(e)&&this._app.use(i.static(e)),this._app.get("*",((t,s)=>{a.existsSync(e)?s.sendFile(e+"/index.html"):this._options.notfound?s.redirect(this._options.notfound):(s.status(R.NOT_FOUND),s.json({message:'File "index.html" not found'}))}))}else this._app.all("*",((e,t)=>{this._options.redirect?t.redirect(this._options.redirect):(t.status(R.NOT_FOUND),t.json({message:"Invalid API"}))}));e.forEach((e=>{const s=i.Router(),r=this._middlewares(e),o=A.parameters(e);this._extends(e).forEach((e=>{r.push(...this._middlewares(e)),o.push(...A.parameters(e))})),A.routers(e).forEach((i=>{const n=i.propertyKey.toString();if(t.isFunction(e[n])){if(!t.isFunction(s[i.method]))return this._notFound(i.method);const a=this._handles(e,n,r,o);return s[i.method](i.path,...a,((s,r,i)=>O(this,void 0,void 0,(function*(){const a=new N(s,r,i,e),p=this._args(a,this._indexes(n,o)),h=yield e[n](...p);a.close(t.isArray(h)||t.isObject(h)?h:void 0)}))))}this._notFound(`${e.name}.${n}`)})),this._extends(e).forEach((i=>{A.routers(i).forEach((i=>{const n=i.propertyKey.toString();if(t.isFunction(e[n])){if(!t.isFunction(s[i.method]))return this._notFound(i.method);const a=this._handles(e,n,r,o);return s[i.method](i.path,...a,((s,r,i)=>O(this,void 0,void 0,(function*(){const a=new N(s,r,i,e),p=this._args(a,this._indexes(n,o)),h=yield e[n](...p);a.close(t.isArray(h)||t.isObject(h)?h:void 0)}))))}this._notFound(`${e.constructor.name}.${n}`)}))})),this._controllers.use(A.path(e,"/"),s)}))}init(){}error(t,s){e.Log.error(t)}log(t,s){e.Log.info(t)}_args(e,t,s){const r=[],o={ctx:e,key:"",app:this,argument:s};return t.forEach((e=>{r[e.parameterIndex]=e.callback(Object.assign(Object.assign({},o),{key:e.key}))})),r}_handles(e,s,r,o){return r.filter((e=>e.propertyKey==s)).map((s=>{if(t.isFunction(e[s.method])){const r=this._indexes(s.method,o);return(o,i,n)=>O(this,void 0,void 0,(function*(){const a=new N(o,i,n,e),p=t.isFunction(s.argument)?s.argument(a):s.argument,h=yield e[s.method](...this._args(a,r,p));(t.isArray(h)||t.isObject(h))&&a.close(h)}))}this._notFound(s.method)})).filter(t.isFunction)}_extends(e){return A.extends(e).reduce(((e,t)=>(e.push(t,...this._extends(t)),e)),[]).filter(((e,t,s)=>s.indexOf(e)===t))}_indexes(e,t){return t.filter((t=>t.propertyKey==e))}_middlewares(e){return[...A.middleware(e)].reverse()}_notFound(e){this.error(new Error(`Router "${e}" not found`),"express")}_port(e){return`Server listening on port ${e}`}listen(){return O(this,void 0,void 0,(function*(){if(this._options.cert&&this._options.key||(this._server=l.createServer(this._app),this._server.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express")))),!this._server){const e=l.createServer(((e,t)=>{const s=80==this._options.port?":80":"";t.writeHead(R.MOVED_PERMANENTLY,{Location:`https://${e.headers.host}${s}${e.url}`}),t.end()})),t=T.createServer({key:this._options.key,cert:this._options.cert},this._app);if(this._options.hybrid){new E.Server((s=>{s.once("data",(r=>{s.pause(),s.unshift(r),(22===r[0]?t:e).emit("connection",s),process.nextTick((()=>s.resume()))}))})).listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=t}this._server||(443==this._options.port&&e.listen(80,(()=>this.log(this._port(80),"express"))),t.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=t)}}))}}var I;exports.Methods=void 0,(I=exports.Methods||(exports.Methods={})).ALL="all",I.GET="get",I.POST="post",I.PUT="put",I.HEAD="head",I.DELETE="delete",I.OPTIONS="options",I.PATCH="patch";const S=e=>t=>(s,r)=>{A.routers(s).push({method:e,path:(null==t?void 0:t.length)?t:"/",propertyKey:r})},m=S(exports.Methods.ALL),D=S(exports.Methods.DELETE),f=S(exports.Methods.GET),y=S(exports.Methods.HEAD),v=S(exports.Methods.OPTIONS),g=S(exports.Methods.PATCH),U=S(exports.Methods.POST),P=S(exports.Methods.PUT),L=e=>t=>(s,r,o)=>{A.parameters(s).push({callback:e,key:t,propertyKey:r,parameterIndex:o})},C=L((({app:e})=>e)),M=L((({argument:e})=>e)),F=(e,s)=>t.isUndefined(s)?e:e[s],b=L((({ctx:e,key:t})=>F(e.req.body,t))),q=L((({ctx:e,key:t})=>F(e.req.cookies,t))),j=L((({ctx:e})=>e)),k=L((({ctx:e})=>t.toArray(e.req.files))),w=L((({ctx:e,key:t})=>F(e.req.headers,t))),H=L((({ctx:e,key:t})=>F(e.req.params,t))),G=L((({ctx:e,key:t})=>F(e.req.query,t))),Q=L((({ctx:e})=>e.req.session));class K{static file(e,s){const r=t.uuidv4()+"."+s;return a.existsSync(u.join(e,r))?K.file(e,s):r}static middleware(e,t){const s=K._cache(t);s.upload||(s.upload=K.multer(t)),s.upload(e.req,e.res,(t=>{if(t)return e.destroy(t);e.next()}))}static multer(e){const t=(null==e?void 0:e.path)||"./",s=_.diskStorage({destination:(e,s,r)=>r(null,t),filename:(e,s,r)=>O(this,void 0,void 0,(function*(){return r(null,K.file(t,s.originalname.split(".").pop()||"bin"))}))}),r=(null==e?void 0:e.types)||[];return _({storage:s,fileFilter(e,t,s){return O(this,void 0,void 0,(function*(){if(r.length){const e=t.originalname.split(".").pop()||"bin";return-1!=r.indexOf(t.mimetype)||-1!=r.indexOf(e)?s(null,!0):s(new Error("File not allowed"))}return s(null,!0)}))},limits:{fileSize:1e6*((null==e?void 0:e.size)||5)}}).array((null==e?void 0:e.field)||"field",(null==e?void 0:e.count)||1)}}K._cache=t.cache(),exports.All=m,exports.App=C,exports.Application=x,exports.Argument=M,exports.Body=b,exports.Context=N,exports.Controller=e=>t=>{A.path(t,(null==e?void 0:e.length)?e:"/")},exports.Cookies=q,exports.Ctx=j,exports.Delete=D,exports.Extends=e=>t=>{A.extends(t).push(e)},exports.Files=k,exports.Get=f,exports.Head=y,exports.Headers=w,exports.Metadata=A,exports.Middleware=(e,t)=>(s,r)=>{A.middleware(s).push({method:e,argument:t,propertyKey:r})},exports.Options=v,exports.Params=H,exports.Patch=g,exports.Post=U,exports.Put=P,exports.Query=G,exports.Session=Q,exports.Status=R,exports.Upload=K,exports.methodFactory=S,exports.parameterFactory=L;
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * @andrewcaires/express v1.1.10
2
+ * @andrewcaires/express v1.2.0
3
3
  * Decorators for express
4
4
  * (c) 2024 Andrew Caires
5
5
  * @license: MIT
@@ -24,6 +24,7 @@ declare class Context<T = any> {
24
24
  destroy(error?: Error): void;
25
25
  error(message: string): void;
26
26
  file(path: string): void;
27
+ ip(): string;
27
28
  json(value?: TypeObjectAny | Array<TypeObjectAny>): void;
28
29
  notFound(message: string): void;
29
30
  prepare(status: number, value: TypeObjectAny | Array<TypeObjectAny>): void;
@@ -120,14 +121,6 @@ interface IUpload {
120
121
  types?: Array<string>;
121
122
  }
122
123
 
123
- declare enum MetadataKeys {
124
- EXTENDS = "__extends__",
125
- MIDDLEWARE = "__middleware__",
126
- PARAMETERS = "__parameters__",
127
- PATH = "__path__",
128
- ROUTERS = "__routers__"
129
- }
130
-
131
124
  declare class Application extends EventEmitter {
132
125
  private readonly _app;
133
126
  private _server?;
@@ -148,10 +141,7 @@ declare class Application extends EventEmitter {
148
141
  private _indexes;
149
142
  private _middlewares;
150
143
  private _notFound;
151
- private _parameters;
152
- private _path;
153
144
  private _port;
154
- private _routers;
155
145
  listen(): Promise<void>;
156
146
  }
157
147
 
@@ -159,31 +149,60 @@ declare const Controller: (path?: string) => ClassDecorator;
159
149
 
160
150
  declare const Extends: (type: any) => ClassDecorator;
161
151
 
162
- declare const methodFactory: (method: Methods) => (path?: string) => MethodDecorator;
163
152
  declare const All: (path?: string) => MethodDecorator;
164
- declare const Get: (path?: string) => MethodDecorator;
165
- declare const Post: (path?: string) => MethodDecorator;
166
- declare const Put: (path?: string) => MethodDecorator;
153
+
167
154
  declare const Delete: (path?: string) => MethodDecorator;
168
- declare const Patch: (path?: string) => MethodDecorator;
155
+
156
+ declare const Get: (path?: string) => MethodDecorator;
157
+
169
158
  declare const Head: (path?: string) => MethodDecorator;
170
- declare const Options: (path?: string) => MethodDecorator;
159
+
160
+ declare const methodFactory: (method: Methods) => (path?: string) => MethodDecorator;
171
161
 
172
162
  declare const Middleware: (method: string, argument?: any) => MethodDecorator;
173
163
 
174
- declare const parameterFactory: (callback: TypeCallbackFunction) => (key?: string) => ParameterDecorator;
164
+ declare const Options: (path?: string) => MethodDecorator;
165
+
166
+ declare const Patch: (path?: string) => MethodDecorator;
167
+
168
+ declare const Post: (path?: string) => MethodDecorator;
169
+
170
+ declare const Put: (path?: string) => MethodDecorator;
171
+
175
172
  declare const App: (key?: string) => ParameterDecorator;
173
+
176
174
  declare const Argument: (key?: string) => ParameterDecorator;
175
+
177
176
  declare const Body: (key?: string) => ParameterDecorator;
177
+
178
178
  declare const Cookies: (key?: string) => ParameterDecorator;
179
+
179
180
  declare const Ctx: (key?: string) => ParameterDecorator;
181
+
180
182
  declare const Files: (key?: string) => ParameterDecorator;
183
+
181
184
  declare const Headers: (key?: string) => ParameterDecorator;
185
+
186
+ declare const parameterFactory: (callback: TypeCallbackFunction) => (key?: string) => ParameterDecorator;
187
+
182
188
  declare const Params: (key?: string) => ParameterDecorator;
189
+
183
190
  declare const Query: (key?: string) => ParameterDecorator;
191
+
184
192
  declare const Session: (key?: string) => ParameterDecorator;
185
193
 
186
- declare const Metadata: <T = any>(metadataKey: MetadataKeys, target: any, metadataValue: T) => T;
194
+ declare class Metadata {
195
+ static readonly EXTENDS: unique symbol;
196
+ static readonly MIDDLEWARE: unique symbol;
197
+ static readonly PARAMETERS: unique symbol;
198
+ static readonly PATH: unique symbol;
199
+ static readonly ROUTERS: unique symbol;
200
+ static extends(target: any): Array<object>;
201
+ static middleware(target: any): Array<IMiddlewares>;
202
+ static parameters(target: any): Array<IParameter>;
203
+ static path(target: any, value: string): string;
204
+ static routers(target: any): Array<IRouter>;
205
+ }
187
206
 
188
207
  declare class Status {
189
208
  static readonly CONTINUE = 100;
@@ -258,4 +277,4 @@ declare class Upload {
258
277
  private static multer;
259
278
  }
260
279
 
261
- export { All, App, Application, Argument, Body, Context, Controller, Cookies, Ctx, Delete, Extends, Files, Get, Head, Headers, type IArgs, type ICookie, type IFile, type IMiddlewares, type IOptions, type IParameter, type IRouter, type IStore, type IUpload, Metadata, MetadataKeys, Methods, Middleware, Options, Params, Patch, Post, Put, Query, Session, Status, Upload, methodFactory, parameterFactory };
280
+ export { All, App, Application, Argument, Body, Context, Controller, Cookies, Ctx, Delete, Extends, Files, Get, Head, Headers, type IArgs, type ICookie, type IFile, type IMiddlewares, type IOptions, type IParameter, type IRouter, type IStore, type IUpload, Metadata, Methods, Middleware, Options, Params, Patch, Post, Put, Query, Session, Status, Upload, methodFactory, parameterFactory };
package/dist/index.esm.js CHANGED
@@ -1,7 +1,7 @@
1
1
  /*!
2
- * @andrewcaires/express v1.1.10
2
+ * @andrewcaires/express v1.2.0
3
3
  * Decorators for express
4
4
  * (c) 2024 Andrew Caires
5
5
  * @license: MIT
6
6
  */
7
- import{Log as t}from"@andrewcaires/node";import{cache as e,isObject as s,EventEmitter as r,merge as i,isFunction as o,isArray as n,toArray as _,isUndefined as h,uuidv4 as E}from"@andrewcaires/utils.js";import p from"cookie-parser";import a from"cors";import u,{Router as d,json as c,urlencoded as T}from"express";import l from"express-session";import{existsSync as O}from"fs";import*as R from"http";import*as N from"https";import{Server as A}from"net";import{resolve as m,join as I}from"path";import f from"multer";function S(t,e,s,r){return new(s||(s=Promise))((function(i,o){function n(t){try{h(r.next(t))}catch(t){o(t)}}function _(t){try{h(r.throw(t))}catch(t){o(t)}}function h(t){var e;t.done?i(t.value):(e=t.value,e instanceof s?e:new s((function(t){t(e)}))).then(n,_)}h((r=r.apply(t,e||[])).next())}))}"function"==typeof SuppressedError&&SuppressedError;class D{}D.CONTINUE=100,D.SWITCHING_PROTOCOLS=101,D.PROCESSING=102,D.OK=200,D.CREATED=201,D.ACCEPTED=202,D.NON_AUTHORITATIVE_INFORMATION=203,D.NO_CONTENT=204,D.RESET_CONTENT=205,D.PARTIAL_CONTENT=206,D.MULTI_STATUS=207,D.ALREADY_REPORTED=208,D.IM_USED=226,D.MULTIPLE_CHOICES=300,D.MOVED_PERMANENTLY=301,D.FOUND=302,D.SEE_OTHER=303,D.NOT_MODIFIED=304,D.USE_PROXY=305,D.TEMPORARY_REDIRECT=307,D.PERMANENT_REDIRECT=308,D.BAD_REQUEST=400,D.UNAUTHORIZED=401,D.PAYMENT_REQUIRED=402,D.FORBIDDEN=403,D.NOT_FOUND=404,D.METHOD_NOT_ALLOWED=405,D.NOT_ACCEPTABLE=406,D.PROXY_AUTHENTICATION_REQUIRED=407,D.REQUEST_TIMEOUT=408,D.CONFLICT=409,D.GONE=410,D.LENGTH_REQUIRED=411,D.PRECONDITION_FAILED=412,D.PAYLOAD_TOO_LARGE=413,D.REQUEST_URI_TOO_LONG=414,D.UNSUPPORTED_MEDIA_TYPE=415,D.REQUESTED_RANGE_NOT_SATISFIABLE=416,D.EXPECTATION_FAILED=417,D.IM_A_TEAPOT=418,D.MISDIRECTED_REQUEST=421,D.UNPROCESSABLE_ENTITY=422,D.LOCKED=423,D.FAILED_DEPENDENCY=424,D.UPGRADE_REQUIRED=426,D.PRECONDITION_REQUIRED=428,D.TOO_MANY_REQUESTS=429,D.REQUEST_HEADER_FIELDS_TOO_LARGE=431,D.CONNECTION_CLOSED_WITHOUT_RESPONSE=444,D.UNAVAILABLE_FOR_LEGAL_REASONS=451,D.CLIENT_CLOSED_REQUEST=499,D.INTERNAL_SERVER_ERROR=500,D.NOT_IMPLEMENTED=501,D.BAD_GATEWAY=502,D.SERVICE_UNAVAILABLE=503,D.GATEWAY_TIMEOUT=504,D.HTTP_VERSION_NOT_SUPPORTED=505,D.VARIANT_ALSO_NEGOCIATES=506,D.INSUFFICIENT_STORAGE=507,D.LOOP_DETECTED=508,D.NOT_EXTENDED=510,D.NETWORK_AUTHENTICATION_REQUIRED=511,D.NETWORK_CONNECTION_TIMEOUT_ERROR=599;class U{constructor(t,e,s,r){this.req=t,this.res=e,this.next=s,this.controller=r}close(t){this.res.headersSent||this.res.json(t||this.storage)}destroy(t){var e;t&&this.error(t.message),null===(e=this.res.socket)||void 0===e||e.destroy(t)}error(t){this.send(D.INTERNAL_SERVER_ERROR,{message:t})}file(t){this.res.headersSent||(this.status(D.OK),this.res.sendFile(m(t)))}json(t){this.send(D.OK,t)}notFound(t){this.send(D.NOT_FOUND,{message:t})}prepare(t,e){this.res.headersSent||(this.status(t),this.storage=e)}send(t,e){this.res.headersSent||(this.status(t),this.res.json(e))}status(t){return t&&this.res.status(t),this.res.statusCode}success(t){this.send(D.OK,{message:t})}unauthorized(t){this.send(D.UNAUTHORIZED,{message:t})}validation(t){this.send(D.BAD_REQUEST,{message:t})}}const v=e(),L=(t,e,r)=>{s(e)&&(e=e.constructor);const i=v(e);return i[t]||(i[t]=r),i[t]};var P,g;!function(t){t.EXTENDS="__extends__",t.MIDDLEWARE="__middleware__",t.PARAMETERS="__parameters__",t.PATH="__path__",t.ROUTERS="__routers__"}(P||(P={})),function(t){t.ALL="all",t.GET="get",t.POST="post",t.PUT="put",t.HEAD="head",t.DELETE="delete",t.OPTIONS="options",t.PATCH="patch"}(g||(g={}));class y extends r{get instance(){return this._app}get router(){return this._router}get server(){return this._server}constructor(t,e){var r;super(),this._app=u(),this._options={},this._default={cross:!1,hybrid:!1,path:"/",port:3e3,session:{secret:"yoursecret",resave:!0,saveUninitialized:!1,cookie:{maxAge:864e5}}},this._router=d(),this._controllers=d(),this._options=i(Object.assign({},this._default),Object.assign({},e)),this._app.use(c(this._options.json)),this._app.disable("x-powered-by"),this._app.use(T({extended:!0})),this._options.cross&&this._app.use(a(s(this._options.cross)?this._options.cross:{}));const _=this._options.cookie;this._app.use(p(null==_?void 0:_.secret,null==_?void 0:_.options)),this._app.use(l(this._options.session)),this.init(),this._app.use(this._router);const h=(null===(r=this._options.path)||void 0===r?void 0:r.length)?this._options.path:"/";if(this._app.use(h,this._controllers),this._app.all(h+"/*",((t,e)=>{this._options.redirect?e.redirect(this._options.redirect):(e.status(D.NOT_FOUND),e.json({message:"Invalid API"}))})),this._options.public){const t=m(this._options.public);O(t)&&this._app.use(u.static(t)),this._app.get("*",((e,s)=>{O(t)?s.sendFile(t+"/index.html"):this._options.notfound?s.redirect(this._options.notfound):(s.status(D.NOT_FOUND),s.json({message:'File "index.html" not found'}))}))}t.forEach((t=>{const e=d(),r=this._middlewares(t),i=this._parameters(t);this._extends(t).forEach((t=>{r.push(...this._middlewares(t)),i.push(...this._parameters(t))})),this._routers(t).forEach((_=>{const h=_.propertyKey.toString();if(o(t[h])){if(!o(e[_.method]))return this._notFound(_.method);const E=this._handles(t,h,r,i);return e[_.method](_.path,...E,((e,r,o)=>S(this,void 0,void 0,(function*(){const _=new U(e,r,o,t),E=this._args(_,this._indexes(h,i)),p=yield t[h](...E);_.close(n(p)||s(p)?p:void 0)}))))}this._notFound(`${t.name}.${h}`)})),this._extends(t).forEach((_=>{this._routers(_).forEach((_=>{const h=_.propertyKey.toString();if(o(t[h])){if(!o(e[_.method]))return this._notFound(_.method);const E=this._handles(t,h,r,i);return e[_.method](_.path,...E,((e,r,o)=>S(this,void 0,void 0,(function*(){const _=new U(e,r,o,t),E=this._args(_,this._indexes(h,i)),p=yield t[h](...E);_.close(n(p)||s(p)?p:void 0)}))))}this._notFound(`${t.constructor.name}.${h}`)}))})),this._controllers.use(this._path(t),e)}))}init(){}error(e,s){t.error(e)}log(e,s){t.info(e)}_args(t,e,s){const r=[],i={ctx:t,key:"",app:this,argument:s};return e.forEach((t=>{r[t.parameterIndex]=t.callback(Object.assign(Object.assign({},i),{key:t.key}))})),r}_handles(t,e,r,i){return r.filter((t=>t.propertyKey==e)).map((e=>{if(o(t[e.method])){const r=this._indexes(e.method,i);return(i,_,h)=>S(this,void 0,void 0,(function*(){const E=new U(i,_,h,t),p=o(e.argument)?e.argument(E):e.argument,a=yield t[e.method](...this._args(E,r,p));(n(a)||s(a))&&E.close(a)}))}this._notFound(e.method)})).filter(o)}_extends(t){return L(P.EXTENDS,t,[]).reduce(((t,e)=>(t.push(e,...this._extends(e)),t)),[]).filter(((t,e,s)=>s.indexOf(t)===e))}_indexes(t,e){return e.filter((e=>e.propertyKey==t))}_middlewares(t){return[...L(P.MIDDLEWARE,t,[])].reverse()}_notFound(t){this.error(new Error(`Router "${t}" not found`),"express")}_parameters(t){return L(P.PARAMETERS,t,[])}_path(t){return L(P.PATH,t,"/")}_port(t){return`Server listening on port ${t}`}_routers(t){return L(P.ROUTERS,t,[])}listen(){return S(this,void 0,void 0,(function*(){if(this._options.cert&&this._options.key||(this._server=R.createServer(this._app),this._server.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express")))),!this._server){const t=R.createServer(((t,e)=>{const s=80==this._options.port?":80":"";e.writeHead(D.MOVED_PERMANENTLY,{Location:`https://${t.headers.host}${s}${t.url}`}),e.end()})),e=N.createServer({key:this._options.key,cert:this._options.cert},this._app);if(this._options.hybrid){new A((s=>{s.once("data",(r=>{s.pause(),s.unshift(r),(22===r[0]?e:t).emit("connection",s),process.nextTick((()=>s.resume()))}))})).listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=e}this._server||(443==this._options.port&&t.listen(80,(()=>this.log(this._port(80),"express"))),e.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=e)}}))}}const x=t=>e=>{L(P.PATH,e,(null==t?void 0:t.length)?t:"/")},C=t=>e=>{L(P.EXTENDS,e,[]).push(t)},F=t=>e=>(s,r)=>{L(P.ROUTERS,s,[]).push({method:t,path:(null==e?void 0:e.length)?e:"/",propertyKey:r})},M=F(g.ALL),k=F(g.GET),H=F(g.POST),w=F(g.PUT),G=F(g.DELETE),b=F(g.PATCH),Q=F(g.HEAD),K=F(g.OPTIONS),Y=(t,e)=>(s,r)=>{L(P.MIDDLEWARE,s,[]).push({method:t,argument:e,propertyKey:r})},j=t=>e=>(s,r,i)=>{L(P.PARAMETERS,s,[]).push({callback:t,key:e,propertyKey:r,parameterIndex:i})},q=(t,e)=>h(e)?t:t[e],V=j((({app:t})=>t)),W=j((({argument:t})=>t)),B=j((({ctx:t,key:e})=>q(t.req.body,e))),$=j((({ctx:t,key:e})=>q(t.req.cookies,e))),X=j((({ctx:t})=>t)),z=j((({ctx:t})=>_(t.req.files))),Z=j((({ctx:t,key:e})=>q(t.req.headers,e))),J=j((({ctx:t,key:e})=>q(t.req.params,e))),tt=j((({ctx:t,key:e})=>q(t.req.query,e))),et=j((({ctx:t})=>t.req.session));class st{static file(t,e){const s=E()+"."+e;return O(I(t,s))?st.file(t,e):s}static middleware(t,e){const s=st._cache(e);s.upload||(s.upload=st.multer(e)),s.upload(t.req,t.res,(e=>{if(e)return t.destroy(e);t.next()}))}static multer(t){const e=(null==t?void 0:t.path)||"./",s=f.diskStorage({destination:(t,s,r)=>r(null,e),filename:(t,s,r)=>S(this,void 0,void 0,(function*(){return r(null,st.file(e,s.originalname.split(".").pop()||"bin"))}))}),r=(null==t?void 0:t.types)||[];return f({storage:s,fileFilter(t,e,s){return S(this,void 0,void 0,(function*(){if(r.length){const t=e.originalname.split(".").pop()||"bin";return-1!=r.indexOf(e.mimetype)||-1!=r.indexOf(t)?s(null,!0):s(new Error("File not allowed"))}return s(null,!0)}))},limits:{fileSize:1e6*((null==t?void 0:t.size)||5)}}).array((null==t?void 0:t.field)||"field",(null==t?void 0:t.count)||1)}}st._cache=e();export{M as All,V as App,y as Application,W as Argument,B as Body,U as Context,x as Controller,$ as Cookies,X as Ctx,G as Delete,C as Extends,z as Files,k as Get,Q as Head,Z as Headers,L as Metadata,P as MetadataKeys,g as Methods,Y as Middleware,K as Options,J as Params,b as Patch,H as Post,w as Put,tt as Query,et as Session,D as Status,st as Upload,F as methodFactory,j as parameterFactory};
7
+ import{Metadata as t,Log as e}from"@andrewcaires/node";import{EventEmitter as s,merge as r,isObject as i,isFunction as o,isArray as n,isUndefined as h,toArray as a,cache as E,uuidv4 as p}from"@andrewcaires/utils.js";import _ from"compression";import d from"cookie-parser";import u from"cors";import l,{Router as c,json as T,urlencoded as O}from"express";import m from"express-session";import{existsSync as R}from"fs";import*as N from"http";import*as A from"https";import{Server as I}from"net";import{resolve as f,join as S}from"path";import{getClientIp as D}from"request-ip";import U from"multer";function v(t,e,s,r){return new(s||(s=Promise))((function(i,o){function n(t){try{a(r.next(t))}catch(t){o(t)}}function h(t){try{a(r.throw(t))}catch(t){o(t)}}function a(t){var e;t.done?i(t.value):(e=t.value,e instanceof s?e:new s((function(t){t(e)}))).then(n,h)}a((r=r.apply(t,e||[])).next())}))}"function"==typeof SuppressedError&&SuppressedError;class y{}y.CONTINUE=100,y.SWITCHING_PROTOCOLS=101,y.PROCESSING=102,y.OK=200,y.CREATED=201,y.ACCEPTED=202,y.NON_AUTHORITATIVE_INFORMATION=203,y.NO_CONTENT=204,y.RESET_CONTENT=205,y.PARTIAL_CONTENT=206,y.MULTI_STATUS=207,y.ALREADY_REPORTED=208,y.IM_USED=226,y.MULTIPLE_CHOICES=300,y.MOVED_PERMANENTLY=301,y.FOUND=302,y.SEE_OTHER=303,y.NOT_MODIFIED=304,y.USE_PROXY=305,y.TEMPORARY_REDIRECT=307,y.PERMANENT_REDIRECT=308,y.BAD_REQUEST=400,y.UNAUTHORIZED=401,y.PAYMENT_REQUIRED=402,y.FORBIDDEN=403,y.NOT_FOUND=404,y.METHOD_NOT_ALLOWED=405,y.NOT_ACCEPTABLE=406,y.PROXY_AUTHENTICATION_REQUIRED=407,y.REQUEST_TIMEOUT=408,y.CONFLICT=409,y.GONE=410,y.LENGTH_REQUIRED=411,y.PRECONDITION_FAILED=412,y.PAYLOAD_TOO_LARGE=413,y.REQUEST_URI_TOO_LONG=414,y.UNSUPPORTED_MEDIA_TYPE=415,y.REQUESTED_RANGE_NOT_SATISFIABLE=416,y.EXPECTATION_FAILED=417,y.IM_A_TEAPOT=418,y.MISDIRECTED_REQUEST=421,y.UNPROCESSABLE_ENTITY=422,y.LOCKED=423,y.FAILED_DEPENDENCY=424,y.UPGRADE_REQUIRED=426,y.PRECONDITION_REQUIRED=428,y.TOO_MANY_REQUESTS=429,y.REQUEST_HEADER_FIELDS_TOO_LARGE=431,y.CONNECTION_CLOSED_WITHOUT_RESPONSE=444,y.UNAVAILABLE_FOR_LEGAL_REASONS=451,y.CLIENT_CLOSED_REQUEST=499,y.INTERNAL_SERVER_ERROR=500,y.NOT_IMPLEMENTED=501,y.BAD_GATEWAY=502,y.SERVICE_UNAVAILABLE=503,y.GATEWAY_TIMEOUT=504,y.HTTP_VERSION_NOT_SUPPORTED=505,y.VARIANT_ALSO_NEGOCIATES=506,y.INSUFFICIENT_STORAGE=507,y.LOOP_DETECTED=508,y.NOT_EXTENDED=510,y.NETWORK_AUTHENTICATION_REQUIRED=511,y.NETWORK_CONNECTION_TIMEOUT_ERROR=599;class g{constructor(t,e,s,r){this.req=t,this.res=e,this.next=s,this.controller=r}close(t){this.res.headersSent||this.res.json(t||this.storage)}destroy(t){var e;t&&this.error(t.message),null===(e=this.res.socket)||void 0===e||e.destroy(t)}error(t){this.send(y.INTERNAL_SERVER_ERROR,{message:t})}file(t){this.res.headersSent||(this.status(y.OK),this.res.sendFile(f(t)))}ip(){return D(this.req)||"0.0.0.0"}json(t){this.send(y.OK,t)}notFound(t){this.send(y.NOT_FOUND,{message:t})}prepare(t,e){this.res.headersSent||(this.status(t),this.storage=e)}send(t,e){this.res.headersSent||(this.status(t),this.res.json(e))}status(t){return t&&this.res.status(t),this.res.statusCode}success(t){this.send(y.OK,{message:t})}unauthorized(t){this.send(y.UNAUTHORIZED,{message:t})}validation(t){this.send(y.BAD_REQUEST,{message:t})}}class L{static extends(e){return t(L.EXTENDS,e,[])}static middleware(e){return t(L.MIDDLEWARE,e,[])}static parameters(e){return t(L.PARAMETERS,e,[])}static path(e,s){return t(L.PATH,e,s)}static routers(e){return t(L.ROUTERS,e,[])}}L.EXTENDS=Symbol(),L.MIDDLEWARE=Symbol(),L.PARAMETERS=Symbol(),L.PATH=Symbol(),L.ROUTERS=Symbol();class P extends s{get instance(){return this._app}get router(){return this._router}get server(){return this._server}constructor(t,e){var s;super(),this._app=l(),this._options={},this._default={cross:!1,hybrid:!1,path:"/",port:3e3,session:{secret:"yoursecret",resave:!0,saveUninitialized:!1,cookie:{maxAge:864e5}}},this._router=c(),this._controllers=c(),this._options=r(Object.assign({},this._default),Object.assign({},e)),this._app.use(T(this._options.json)),this._app.disable("x-powered-by"),this._app.use(O({extended:!0})),this._options.cross&&this._app.use(u(i(this._options.cross)?this._options.cross:{}));const h=this._options.cookie;this._app.use(_()),this._app.use(d(null==h?void 0:h.secret,null==h?void 0:h.options)),this._app.use(m(this._options.session)),this.init(),this._app.use(this._router);const a=(null===(s=this._options.path)||void 0===s?void 0:s.length)?this._options.path:"/";if(this._app.use(a,this._controllers),this._app.all(a+"/*",((t,e)=>{this._options.redirect?e.redirect(this._options.redirect):(e.status(y.NOT_FOUND),e.json({message:"Invalid API"}))})),this._options.public){const t=f(this._options.public);R(t)&&this._app.use(l.static(t)),this._app.get("*",((e,s)=>{R(t)?s.sendFile(t+"/index.html"):this._options.notfound?s.redirect(this._options.notfound):(s.status(y.NOT_FOUND),s.json({message:'File "index.html" not found'}))}))}else this._app.all("*",((t,e)=>{this._options.redirect?e.redirect(this._options.redirect):(e.status(y.NOT_FOUND),e.json({message:"Invalid API"}))}));t.forEach((t=>{const e=c(),s=this._middlewares(t),r=L.parameters(t);this._extends(t).forEach((t=>{s.push(...this._middlewares(t)),r.push(...L.parameters(t))})),L.routers(t).forEach((h=>{const a=h.propertyKey.toString();if(o(t[a])){if(!o(e[h.method]))return this._notFound(h.method);const E=this._handles(t,a,s,r);return e[h.method](h.path,...E,((e,s,o)=>v(this,void 0,void 0,(function*(){const h=new g(e,s,o,t),E=this._args(h,this._indexes(a,r)),p=yield t[a](...E);h.close(n(p)||i(p)?p:void 0)}))))}this._notFound(`${t.name}.${a}`)})),this._extends(t).forEach((h=>{L.routers(h).forEach((h=>{const a=h.propertyKey.toString();if(o(t[a])){if(!o(e[h.method]))return this._notFound(h.method);const E=this._handles(t,a,s,r);return e[h.method](h.path,...E,((e,s,o)=>v(this,void 0,void 0,(function*(){const h=new g(e,s,o,t),E=this._args(h,this._indexes(a,r)),p=yield t[a](...E);h.close(n(p)||i(p)?p:void 0)}))))}this._notFound(`${t.constructor.name}.${a}`)}))})),this._controllers.use(L.path(t,"/"),e)}))}init(){}error(t,s){e.error(t)}log(t,s){e.info(t)}_args(t,e,s){const r=[],i={ctx:t,key:"",app:this,argument:s};return e.forEach((t=>{r[t.parameterIndex]=t.callback(Object.assign(Object.assign({},i),{key:t.key}))})),r}_handles(t,e,s,r){return s.filter((t=>t.propertyKey==e)).map((e=>{if(o(t[e.method])){const s=this._indexes(e.method,r);return(r,h,a)=>v(this,void 0,void 0,(function*(){const E=new g(r,h,a,t),p=o(e.argument)?e.argument(E):e.argument,_=yield t[e.method](...this._args(E,s,p));(n(_)||i(_))&&E.close(_)}))}this._notFound(e.method)})).filter(o)}_extends(t){return L.extends(t).reduce(((t,e)=>(t.push(e,...this._extends(e)),t)),[]).filter(((t,e,s)=>s.indexOf(t)===e))}_indexes(t,e){return e.filter((e=>e.propertyKey==t))}_middlewares(t){return[...L.middleware(t)].reverse()}_notFound(t){this.error(new Error(`Router "${t}" not found`),"express")}_port(t){return`Server listening on port ${t}`}listen(){return v(this,void 0,void 0,(function*(){if(this._options.cert&&this._options.key||(this._server=N.createServer(this._app),this._server.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express")))),!this._server){const t=N.createServer(((t,e)=>{const s=80==this._options.port?":80":"";e.writeHead(y.MOVED_PERMANENTLY,{Location:`https://${t.headers.host}${s}${t.url}`}),e.end()})),e=A.createServer({key:this._options.key,cert:this._options.cert},this._app);if(this._options.hybrid){new I((s=>{s.once("data",(r=>{s.pause(),s.unshift(r),(22===r[0]?e:t).emit("connection",s),process.nextTick((()=>s.resume()))}))})).listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=e}this._server||(443==this._options.port&&t.listen(80,(()=>this.log(this._port(80),"express"))),e.listen(this._options.port,(()=>this.log(this._port(this._options.port),"express"))),this._server=e)}}))}}const x=t=>e=>{L.path(e,(null==t?void 0:t.length)?t:"/")},C=t=>e=>{L.extends(e).push(t)};var F;!function(t){t.ALL="all",t.GET="get",t.POST="post",t.PUT="put",t.HEAD="head",t.DELETE="delete",t.OPTIONS="options",t.PATCH="patch"}(F||(F={}));const M=t=>e=>(s,r)=>{L.routers(s).push({method:t,path:(null==e?void 0:e.length)?e:"/",propertyKey:r})},k=M(F.ALL),w=M(F.DELETE),b=M(F.GET),H=M(F.HEAD),G=(t,e)=>(s,r)=>{L.middleware(s).push({method:t,argument:e,propertyKey:r})},Q=M(F.OPTIONS),K=M(F.PATCH),Y=M(F.POST),j=M(F.PUT),q=t=>e=>(s,r,i)=>{L.parameters(s).push({callback:t,key:e,propertyKey:r,parameterIndex:i})},V=q((({app:t})=>t)),B=q((({argument:t})=>t)),W=(t,e)=>h(e)?t:t[e],$=q((({ctx:t,key:e})=>W(t.req.body,e))),X=q((({ctx:t,key:e})=>W(t.req.cookies,e))),z=q((({ctx:t})=>t)),Z=q((({ctx:t})=>a(t.req.files))),J=q((({ctx:t,key:e})=>W(t.req.headers,e))),tt=q((({ctx:t,key:e})=>W(t.req.params,e))),et=q((({ctx:t,key:e})=>W(t.req.query,e))),st=q((({ctx:t})=>t.req.session));class rt{static file(t,e){const s=p()+"."+e;return R(S(t,s))?rt.file(t,e):s}static middleware(t,e){const s=rt._cache(e);s.upload||(s.upload=rt.multer(e)),s.upload(t.req,t.res,(e=>{if(e)return t.destroy(e);t.next()}))}static multer(t){const e=(null==t?void 0:t.path)||"./",s=U.diskStorage({destination:(t,s,r)=>r(null,e),filename:(t,s,r)=>v(this,void 0,void 0,(function*(){return r(null,rt.file(e,s.originalname.split(".").pop()||"bin"))}))}),r=(null==t?void 0:t.types)||[];return U({storage:s,fileFilter(t,e,s){return v(this,void 0,void 0,(function*(){if(r.length){const t=e.originalname.split(".").pop()||"bin";return-1!=r.indexOf(e.mimetype)||-1!=r.indexOf(t)?s(null,!0):s(new Error("File not allowed"))}return s(null,!0)}))},limits:{fileSize:1e6*((null==t?void 0:t.size)||5)}}).array((null==t?void 0:t.field)||"field",(null==t?void 0:t.count)||1)}}rt._cache=E();export{k as All,V as App,P as Application,B as Argument,$ as Body,g as Context,x as Controller,X as Cookies,z as Ctx,w as Delete,C as Extends,Z as Files,b as Get,H as Head,J as Headers,L as Metadata,F as Methods,G as Middleware,Q as Options,tt as Params,K as Patch,Y as Post,j as Put,et as Query,st as Session,y as Status,rt as Upload,M as methodFactory,q as parameterFactory};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@andrewcaires/express",
3
- "version": "1.1.10",
3
+ "version": "1.2.0",
4
4
  "description": "Decorators for express",
5
5
  "main": "./dist/index.cjs.js",
6
6
  "types": "./dist/index.d.ts",
@@ -18,8 +18,8 @@
18
18
  "dist"
19
19
  ],
20
20
  "scripts": {
21
- "build": "rollup --bundleConfigAsCjs -c rollup.config.js",
22
- "dev": "ts-node-dev ./src/dev.ts"
21
+ "dev": "tsx-dev --watch --clear ./src/dev.ts",
22
+ "build": "rollup --bundleConfigAsCjs -c rollup.config.js"
23
23
  },
24
24
  "repository": {
25
25
  "type": "git",
@@ -35,27 +35,31 @@
35
35
  },
36
36
  "homepage": "https://github.com/andrewcaires/npm/tree/main/api#readme",
37
37
  "dependencies": {
38
- "@andrewcaires/node": "^1.1.1",
39
- "@andrewcaires/utils.js": "^0.3.1",
40
- "cookie-parser": "^1.4.6",
38
+ "@andrewcaires/node": "^1.2.0",
39
+ "@andrewcaires/utils.js": "^0.4.0",
40
+ "compression": "^1.7.4",
41
+ "cookie-parser": "^1.4.7",
41
42
  "cors": "^2.8.5",
42
- "express": "^4.19.2",
43
- "express-session": "^1.18.0",
44
- "multer": "^1.4.5-lts.1"
43
+ "express": "^4.21.1",
44
+ "express-session": "^1.18.1",
45
+ "multer": "^1.4.5-lts.1",
46
+ "request-ip": "^3.3.0"
45
47
  },
46
48
  "devDependencies": {
47
- "@rollup/plugin-commonjs": "^26.0.1",
49
+ "@rollup/plugin-commonjs": "^28.0.0",
48
50
  "@rollup/plugin-terser": "^0.4.4",
49
- "@rollup/plugin-typescript": "^11.1.6",
51
+ "@rollup/plugin-typescript": "^12.1.0",
52
+ "@types/compression": "^1.7.5",
50
53
  "@types/cookie-parser": "^1.4.7",
51
54
  "@types/cors": "^2.8.17",
52
- "@types/express": "^4.17.21",
55
+ "@types/express": "^5.0.0",
53
56
  "@types/express-session": "^1.18.0",
54
- "@types/multer": "^1.4.11",
55
- "@types/node": "^20.14.5",
56
- "eslint": "^9.5.0",
57
+ "@types/multer": "^1.4.12",
58
+ "@types/node": "^22.7.5",
59
+ "@types/request-ip": "^0.0.41",
60
+ "eslint": "^9.12.0",
57
61
  "rollup-plugin-dts": "^6.1.1",
58
- "tslib": "^2.6.3",
59
- "typescript-eslint": "^8.0.0-alpha.30"
62
+ "tslib": "^2.7.0",
63
+ "typescript-eslint": "^8.8.1"
60
64
  }
61
65
  }