Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

lambda-serverless-api

Package Overview
Dependencies
Maintainers
1
Versions
396
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

lambda-serverless-api - npm Package Compare versions

Comparing version 1.12.6 to 1.12.7

42

lib/api.js
const xor = require('lodash.xor');
const get = require('lodash.get');
const Rollbar = require('lambda-rollbar');
const Limiter = require('lambda-rate-limiter');
const yaml = require("yaml-boost");
const param = require("./param");
const response = require("./response");
const swagger = require("./swagger");
const Find = require("./util/find");

@@ -14,2 +22,3 @@

const receivedRequestMethod = get(event, 'httpMethod');
if (receivedRequestMethod !== expectedRequestMethod) {

@@ -20,3 +29,5 @@ throw response.ApiError(`Request Method "${expectedRequestMethod}" expected.`, 400, 99004, {

}
let body;
try {

@@ -29,3 +40,6 @@ body = JSON.parse(get(event, 'body', '{}'));

}
const eventParsed = Object.assign({}, event, { body });
const eventParsed = Object.assign({}, event, {
body
});
return Promise.resolve(params.map(p => p.get(eventParsed)));

@@ -45,2 +59,3 @@ };

}
if (resp instanceof response.ApiResponseClass) {

@@ -53,2 +68,3 @@ return {

}
throw err;

@@ -66,16 +82,11 @@ };

}
if (params.filter(p => p.position === 'path').some(p => request.indexOf(`{${p.name}}`) === -1)) {
throw new Error("Path Parameter not defined in given path.");
}
endpoints[request] = params;
return rollbar
.wrap((event, context, rb) => limiter
.check(limit, get(event, 'requestContext.identity.sourceIp'))
.catch(() => {
throw response.ApiError("Rate limit exceeded.", 429);
})
.then(() => parse(request, params, event))
.then(paramsOut => handler(paramsOut, context, rb))
.then(payload => generateResponse(null, payload, rb))
.catch(err => generateResponse(err, null, rb)));
return rollbar.wrap((event, context, rb) => limiter.check(limit, get(event, 'requestContext.identity.sourceIp')).catch(() => {
throw response.ApiError("Rate limit exceeded.", 429);
}).then(() => parse(request, params, event)).then(paramsOut => handler(paramsOut, context, rb)).then(payload => generateResponse(null, payload, rb)).catch(err => generateResponse(err, null, rb)));
};

@@ -86,8 +97,4 @@

const swaggerData = yaml.load(swaggerFile);
const serverlessRequests = Find(["functions.*.events.*.http"])(serverlessData)
.map(k => get(serverlessData, k)).map(e => `${e.method.toUpperCase()} ${e.path}`);
const swaggerRequests = Find(["paths.*.*"])(swaggerData)
.map(k => k.split(".")).map(e => `${e[2].toUpperCase()} ${e[1].substring(1)}`);
const serverlessRequests = Find(["functions.*.events.*.http"])(serverlessData).map(k => get(serverlessData, k)).map(e => `${e.method.toUpperCase()} ${e.path}`);
const swaggerRequests = Find(["paths.*.*"])(swaggerData).map(k => k.split(".")).map(e => `${e[2].toUpperCase()} ${e[1].substring(1)}`);
return xor(serverlessRequests, swaggerRequests);

@@ -109,1 +116,2 @@ };

};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/api.js"],"names":["xor","require","get","Rollbar","Limiter","yaml","param","response","swagger","Find","parse","request","params","event","expectedRequestMethod","split","receivedRequestMethod","ApiError","value","body","JSON","e","eventParsed","Object","assign","Promise","resolve","map","p","generateResponse","err","resp","rb","ApiErrorClass","warning","then","statusCode","stringify","message","messageId","context","ApiResponseClass","payload","headers","module","exports","options","endpoints","rollbar","limiter","wrap","limit","handler","startsWith","filter","position","length","Error","some","indexOf","name","check","catch","paramsOut","generateDifference","swaggerFile","serverlessFile","serverlessVars","serverlessData","load","swaggerData","serverlessRequests","k","method","toUpperCase","path","swaggerRequests","substring","generateSwagger","existing","ApiResponse","JsonResponse","Str","Email","RegEx","Bool"],"mappings":"AAAA,MAAMA,MAAMC,QAAQ,YAAR,CAAZ;;AACA,MAAMC,MAAMD,QAAQ,YAAR,CAAZ;;AACA,MAAME,UAAUF,QAAQ,gBAAR,CAAhB;;AACA,MAAMG,UAAUH,QAAQ,qBAAR,CAAhB;;AACA,MAAMI,OAAOJ,QAAQ,YAAR,CAAb;;AACA,MAAMK,QAAQL,QAAQ,SAAR,CAAd;;AACA,MAAMM,WAAWN,QAAQ,YAAR,CAAjB;;AACA,MAAMO,UAAUP,QAAQ,WAAR,CAAhB;;AACA,MAAMQ,OAAOR,QAAQ,aAAR,CAAb;;AAEA,MAAMS,QAAQ,CAACC,OAAD,EAAUC,MAAV,EAAkBC,KAAlB,KAA4B;AACxC,QAAMC,wBAAwBH,QAAQI,KAAR,CAAc,GAAd,EAAmB,CAAnB,CAA9B;AACA,QAAMC,wBAAwBd,IAAIW,KAAJ,EAAW,YAAX,CAA9B;;AACA,MAAIG,0BAA0BF,qBAA9B,EAAqD;AACnD,UAAMP,SAASU,QAAT,CAAmB,mBAAkBH,qBAAsB,aAA3D,EAAyE,GAAzE,EAA8E,KAA9E,EAAqF;AACzFI,aAAOF;AADkF,KAArF,CAAN;AAGD;;AACD,MAAIG,IAAJ;;AACA,MAAI;AACFA,WAAOC,KAAKV,KAAL,CAAWR,IAAIW,KAAJ,EAAW,MAAX,EAAmB,IAAnB,CAAX,CAAP;AACD,GAFD,CAEE,OAAOQ,CAAP,EAAU;AACV,UAAMd,SAASU,QAAT,CAAkB,6BAAlB,EAAiD,GAAjD,EAAsD,KAAtD,EAA6D;AACjEC,aAAOhB,IAAIW,KAAJ,EAAW,MAAX;AAD0D,KAA7D,CAAN;AAGD;;AACD,QAAMS,cAAcC,OAAOC,MAAP,CAAc,EAAd,EAAkBX,KAAlB,EAAyB;AAAEM;AAAF,GAAzB,CAApB;AACA,SAAOM,QAAQC,OAAR,CAAgBd,OAAOe,GAAP,CAAWC,KAAKA,EAAE1B,GAAF,CAAMoB,WAAN,CAAhB,CAAhB,CAAP;AACD,CAlBD;;AAoBA,MAAMO,mBAAmB,CAACC,GAAD,EAAMC,IAAN,EAAYC,EAAZ,KAAmB;AAC1C,MAAIF,eAAevB,SAAS0B,aAA5B,EAA2C;AACzC,WAAOD,GAAGE,OAAH,CAAWJ,GAAX,EAAgBK,IAAhB,CAAqB,OAAO;AACjCC,kBAAYN,IAAIM,UADiB;AAEjCjB,YAAMC,KAAKiB,SAAL,CAAe;AACnBC,iBAASR,IAAIQ,OADM;AAEnBC,mBAAWT,IAAIS,SAFI;AAGnBC,iBAASV,IAAIU;AAHM,OAAf;AAF2B,KAAP,CAArB,CAAP;AAQD;;AACD,MAAIT,gBAAgBxB,SAASkC,gBAA7B,EAA+C;AAC7C,WAAO;AACLL,kBAAYL,KAAKK,UADZ;AAELjB,YAAMY,KAAKW,OAFN;AAGLC,eAASZ,KAAKY;AAHT,KAAP;AAKD;;AACD,QAAMb,GAAN;AACD,CAnBD;;AAqBAc,OAAOC,OAAP,GAAiB,CAACC,UAAU,EAAX,KAAkB;AACjC,QAAMC,YAAY,EAAlB;AACA,QAAMC,UAAU7C,QAAQD,IAAI4C,OAAJ,EAAa,SAAb,EAAwB,EAAxB,CAAR,CAAhB;AACA,QAAMG,UAAU7C,QAAQF,IAAI4C,OAAJ,EAAa,SAAb,EAAwB,EAAxB,CAAR,CAAhB;;AAEA,QAAMI,OAAO,CAACvC,OAAD,EAAUC,MAAV,EAAkBuC,KAAlB,EAAyBC,OAAzB,KAAqC;AAChD,QAAIzC,QAAQ0C,UAAR,CAAmB,MAAnB,KAA8BzC,OAAO0C,MAAP,CAAc1B,KAAKA,EAAE2B,QAAF,KAAe,MAAlC,EAA0CC,MAA1C,KAAqD,CAAvF,EAA0F;AACxF,YAAM,IAAIC,KAAJ,CAAU,+CAAV,CAAN;AACD;;AACD,QAAI7C,OAAO0C,MAAP,CAAc1B,KAAKA,EAAE2B,QAAF,KAAe,MAAlC,EAA0CG,IAA1C,CAA+C9B,KAAKjB,QAAQgD,OAAR,CAAiB,IAAG/B,EAAEgC,IAAK,GAA3B,MAAmC,CAAC,CAAxF,CAAJ,EAAgG;AAC9F,YAAM,IAAIH,KAAJ,CAAU,2CAAV,CAAN;AACD;;AACDV,cAAUpC,OAAV,IAAqBC,MAArB;AACA,WAAOoC,QACJE,IADI,CACC,CAACrC,KAAD,EAAQ2B,OAAR,EAAiBR,EAAjB,KAAwBiB,QAC3BY,KAD2B,CACrBV,KADqB,EACdjD,IAAIW,KAAJ,EAAW,kCAAX,CADc,EAE3BiD,KAF2B,CAErB,MAAM;AACX,YAAMvD,SAASU,QAAT,CAAkB,sBAAlB,EAA0C,GAA1C,CAAN;AACD,KAJ2B,EAK3BkB,IAL2B,CAKtB,MAAMzB,MAAMC,OAAN,EAAeC,MAAf,EAAuBC,KAAvB,CALgB,EAM3BsB,IAN2B,CAMtB4B,aAAaX,QAAQW,SAAR,EAAmBvB,OAAnB,EAA4BR,EAA5B,CANS,EAO3BG,IAP2B,CAOtBO,WAAWb,iBAAiB,IAAjB,EAAuBa,OAAvB,EAAgCV,EAAhC,CAPW,EAQ3B8B,KAR2B,CAQrBhC,OAAOD,iBAAiBC,GAAjB,EAAsB,IAAtB,EAA4BE,EAA5B,CARc,CADzB,CAAP;AAUD,GAlBD;;AAoBA,QAAMgC,qBAAqB,CAACC,WAAD,EAAcC,cAAd,EAA8BC,cAA9B,KAAiD;AAC1E,UAAMC,iBAAiB/D,KAAKgE,IAAL,CAAUH,cAAV,EAA0BC,cAA1B,CAAvB;AACA,UAAMG,cAAcjE,KAAKgE,IAAL,CAAUJ,WAAV,CAApB;AAEA,UAAMM,qBAAqB9D,KAAK,CAAC,2BAAD,CAAL,EAAoC2D,cAApC,EACxBzC,GADwB,CACpB6C,KAAKtE,IAAIkE,cAAJ,EAAoBI,CAApB,CADe,EACS7C,GADT,CACaN,KAAM,GAAEA,EAAEoD,MAAF,CAASC,WAAT,EAAuB,IAAGrD,EAAEsD,IAAK,EADtD,CAA3B;AAEA,UAAMC,kBAAkBnE,KAAK,CAAC,WAAD,CAAL,EAAoB6D,WAApB,EACrB3C,GADqB,CACjB6C,KAAKA,EAAEzD,KAAF,CAAQ,GAAR,CADY,EACEY,GADF,CACMN,KAAM,GAAEA,EAAE,CAAF,EAAKqD,WAAL,EAAmB,IAAGrD,EAAE,CAAF,EAAKwD,SAAL,CAAe,CAAf,CAAkB,EADtD,CAAxB;AAGA,WAAO7E,IAAIuE,kBAAJ,EAAwBK,eAAxB,CAAP;AACD,GAVD;;AAYA,SAAO;AACL1B,QADK;AAEL4B,qBAAiB,CAACC,WAAW,EAAZ,KAAmBvE,QAAQuC,SAAR,EAAmBgC,QAAnB,CAF/B;AAGLf,sBAHK;AAIL/C,cAAUV,SAASU,QAJd;AAKL+D,iBAAazE,SAASyE,WALjB;AAMLC,kBAAc1E,SAAS0E,YANlB;AAOLC,SAAK5E,MAAM4E,GAPN;AAQLC,WAAO7E,MAAM6E,KARR;AASLC,WAAO9E,MAAM8E,KATR;AAULC,UAAM/E,MAAM+E;AAVP,GAAP;AAYD,CAjDD","file":"api.js","sourcesContent":["const xor = require('lodash.xor');\nconst get = require('lodash.get');\nconst Rollbar = require('lambda-rollbar');\nconst Limiter = require('lambda-rate-limiter');\nconst yaml = require(\"yaml-boost\");\nconst param = require(\"./param\");\nconst response = require(\"./response\");\nconst swagger = require(\"./swagger\");\nconst Find = require(\"./util/find\");\n\nconst parse = (request, params, event) => {\n  const expectedRequestMethod = request.split(\" \")[0];\n  const receivedRequestMethod = get(event, 'httpMethod');\n  if (receivedRequestMethod !== expectedRequestMethod) {\n    throw response.ApiError(`Request Method \"${expectedRequestMethod}\" expected.`, 400, 99004, {\n      value: receivedRequestMethod\n    });\n  }\n  let body;\n  try {\n    body = JSON.parse(get(event, 'body', '{}'));\n  } catch (e) {\n    throw response.ApiError(\"Invalid Json Body detected.\", 400, 99001, {\n      value: get(event, 'body')\n    });\n  }\n  const eventParsed = Object.assign({}, event, { body });\n  return Promise.resolve(params.map(p => p.get(eventParsed)));\n};\n\nconst generateResponse = (err, resp, rb) => {\n  if (err instanceof response.ApiErrorClass) {\n    return rb.warning(err).then(() => ({\n      statusCode: err.statusCode,\n      body: JSON.stringify({\n        message: err.message,\n        messageId: err.messageId,\n        context: err.context\n      })\n    }));\n  }\n  if (resp instanceof response.ApiResponseClass) {\n    return {\n      statusCode: resp.statusCode,\n      body: resp.payload,\n      headers: resp.headers\n    };\n  }\n  throw err;\n};\n\nmodule.exports = (options = {}) => {\n  const endpoints = {};\n  const rollbar = Rollbar(get(options, 'rollbar', {}));\n  const limiter = Limiter(get(options, 'limiter', {}));\n\n  const wrap = (request, params, limit, handler) => {\n    if (request.startsWith(\"GET \") && params.filter(p => p.position === 'json').length !== 0) {\n      throw new Error(\"Can not use JSON parameter with GET requests.\");\n    }\n    if (params.filter(p => p.position === 'path').some(p => request.indexOf(`{${p.name}}`) === -1)) {\n      throw new Error(\"Path Parameter not defined in given path.\");\n    }\n    endpoints[request] = params;\n    return rollbar\n      .wrap((event, context, rb) => limiter\n        .check(limit, get(event, 'requestContext.identity.sourceIp'))\n        .catch(() => {\n          throw response.ApiError(\"Rate limit exceeded.\", 429);\n        })\n        .then(() => parse(request, params, event))\n        .then(paramsOut => handler(paramsOut, context, rb))\n        .then(payload => generateResponse(null, payload, rb))\n        .catch(err => generateResponse(err, null, rb)));\n  };\n\n  const generateDifference = (swaggerFile, serverlessFile, serverlessVars) => {\n    const serverlessData = yaml.load(serverlessFile, serverlessVars);\n    const swaggerData = yaml.load(swaggerFile);\n\n    const serverlessRequests = Find([\"functions.*.events.*.http\"])(serverlessData)\n      .map(k => get(serverlessData, k)).map(e => `${e.method.toUpperCase()} ${e.path}`);\n    const swaggerRequests = Find([\"paths.*.*\"])(swaggerData)\n      .map(k => k.split(\".\")).map(e => `${e[2].toUpperCase()} ${e[1].substring(1)}`);\n\n    return xor(serverlessRequests, swaggerRequests);\n  };\n\n  return {\n    wrap,\n    generateSwagger: (existing = {}) => swagger(endpoints, existing),\n    generateDifference,\n    ApiError: response.ApiError,\n    ApiResponse: response.ApiResponse,\n    JsonResponse: response.JsonResponse,\n    Str: param.Str,\n    Email: param.Email,\n    RegEx: param.RegEx,\n    Bool: param.Bool\n  };\n};\n"]}
const get = require("lodash.get");
const response = require("./response");

@@ -17,2 +18,3 @@

}
this.name = name;

@@ -22,5 +24,5 @@ this.position = position;

this.type = null;
}
} // eslint-disable-next-line class-methods-use-this
// eslint-disable-next-line class-methods-use-this
validate(value) {

@@ -32,2 +34,3 @@ return true;

const result = get(event, `${positionMapping[this.position]}.${this.name}`);
if (result === undefined) {

@@ -42,4 +45,6 @@ if (this.required) {

}
return result;
}
}

@@ -55,8 +60,12 @@

let valid = super.validate(value);
if (!(typeof value === 'string' || value instanceof String)) {
valid = false;
}
return valid;
}
}
module.exports.Str = (...args) => new Str(...args);

@@ -72,8 +81,12 @@

let valid = super.validate(value);
if (!value.match(this.regex)) {
valid = false;
}
return valid;
}
}
module.exports.RegEx = (...args) => new RegEx(...args);

@@ -85,3 +98,5 @@

}
}
module.exports.Email = (...args) => new Email(...args);

@@ -98,3 +113,6 @@

}
}
module.exports.Bool = (...args) => new Bool(...args);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wYXJhbS5qcyJdLCJuYW1lcyI6WyJnZXQiLCJyZXF1aXJlIiwicmVzcG9uc2UiLCJwb3NpdGlvbk1hcHBpbmciLCJxdWVyeSIsImpzb24iLCJwYXRoIiwiaGVhZGVyIiwiY29udGV4dCIsIlBhcmFtIiwiY29uc3RydWN0b3IiLCJuYW1lIiwicG9zaXRpb24iLCJyZXF1aXJlZCIsIk9iamVjdCIsImtleXMiLCJpbmRleE9mIiwiRXJyb3IiLCJqb2luIiwidHlwZSIsInZhbGlkYXRlIiwidmFsdWUiLCJldmVudCIsInJlc3VsdCIsInVuZGVmaW5lZCIsIkFwaUVycm9yIiwiU3RyIiwiYXJncyIsInZhbGlkIiwiU3RyaW5nIiwibW9kdWxlIiwiZXhwb3J0cyIsIlJlZ0V4IiwicmVnZXgiLCJtYXRjaCIsIkVtYWlsIiwiQm9vbCJdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTUEsTUFBTUMsUUFBUSxZQUFSLENBQVo7O0FBQ0EsTUFBTUMsV0FBV0QsUUFBUSxZQUFSLENBQWpCOztBQUVBLE1BQU1FLGtCQUFrQjtBQUN0QkMsU0FBTyx1QkFEZTtBQUV0QkMsUUFBTSxNQUZnQjtBQUd0QkMsUUFBTSxnQkFIZ0I7QUFJdEJDLFVBQVEsU0FKYztBQUt0QkMsV0FBUztBQUxhLENBQXhCOztBQVFBLE1BQU1DLEtBQU4sQ0FBWTtBQUNWQyxjQUFZQyxJQUFaLEVBQWtCQyxXQUFXLE9BQTdCLEVBQXNDQyxXQUFXLElBQWpELEVBQXVEO0FBQ3JELFFBQUlDLE9BQU9DLElBQVAsQ0FBWVosZUFBWixFQUE2QmEsT0FBN0IsQ0FBcUNKLFFBQXJDLE1BQW1ELENBQUMsQ0FBeEQsRUFBMkQ7QUFDekQsWUFBTSxJQUFJSyxLQUFKLENBQVcsMENBQXlDSCxPQUFPQyxJQUFQLENBQVlaLGVBQVosRUFBNkJlLElBQTdCLENBQWtDLElBQWxDLENBQXdDLEVBQTVGLENBQU47QUFDRDs7QUFDRCxTQUFLUCxJQUFMLEdBQVlBLElBQVo7QUFDQSxTQUFLQyxRQUFMLEdBQWdCQSxRQUFo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QUFDRDs7QUFFRDNCLE1BQUlzQixLQUFKLEVBQVc7QUFDVCxVQUFNQyxTQUFTLE1BQU12QixHQUFOLENBQVVzQixLQUFWLENBQWY7QUFDQSxXQUFPLENBQUMsR0FBRCxFQUFNLE1BQU4sRUFBY04sT0FBZCxDQUFzQk8sTUFBdEIsTUFBa0MsQ0FBQyxDQUExQztBQUNEOztBQVJzQjs7QUFVekJPLE9BQU9DLE9BQVAsQ0FBZUssSUFBZixHQUFzQixDQUFDLEdBQUdULElBQUosS0FBYSxJQUFJUyxJQUFKLENBQVMsR0FBR1QsSUFBWixDQUFuQyIsImZpbGUiOiJwYXJhbS5qcyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGdldCA9IHJlcXVpcmUoXCJsb2Rhc2guZ2V0XCIpO1xuY29uc3QgcmVzcG9uc2UgPSByZXF1aXJlKFwiLi9yZXNwb25zZVwiKTtcblxuY29uc3QgcG9zaXRpb25NYXBwaW5nID0ge1xuICBxdWVyeTogXCJxdWVyeVN0cmluZ1BhcmFtZXRlcnNcIixcbiAganNvbjogXCJib2R5XCIsXG4gIHBhdGg6IFwicGF0aFBhcmFtZXRlcnNcIixcbiAgaGVhZGVyOiBcImhlYWRlcnNcIixcbiAgY29udGV4dDogXCJyZXF1ZXN0Q29udGV4dFwiXG59O1xuXG5jbGFzcyBQYXJhbSB7XG4gIGNvbnN0cnVjdG9yKG5hbWUsIHBvc2l0aW9uID0gJ3F1ZXJ5JywgcmVxdWlyZWQgPSB0cnVlKSB7XG4gICAgaWYgKE9iamVjdC5rZXlzKHBvc2l0aW9uTWFwcGluZykuaW5kZXhPZihwb3NpdGlvbikgPT09IC0xKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFBhcmFtZXRlciBQb3NpdGlvbiBuZWVkcyB0byBiZSBvbmUgb2Y6ICR7T2JqZWN0LmtleXMocG9zaXRpb25NYXBwaW5nKS5qb2luKFwiLCBcIil9YCk7XG4gICAgfVxuICAgIHRoaXMubmFtZSA9IG5hbWU7XG4gICAgdGhpcy5wb3NpdGlvbiA9IHBvc2l0aW9uO1xuICAgIHRoaXMucmVxdWlyZWQgPSByZXF1aXJlZDtcbiAgICB0aGlzLnR5cGUgPSBudWxsO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGNsYXNzLW1ldGhvZHMtdXNlLXRoaXNcbiAgdmFsaWRhdGUodmFsdWUpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGdldChldmVudCkge1xuICAgIGNvbnN0IHJlc3VsdCA9IGdldChldmVudCwgYCR7cG9zaXRpb25NYXBwaW5nW3RoaXMucG9zaXRpb25dfS4ke3RoaXMubmFtZX1gKTtcbiAgICBpZiAocmVzdWx0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgIGlmICh0aGlzLnJlcXVpcmVkKSB7XG4gICAgICAgIHRocm93IHJlc3BvbnNlLkFwaUVycm9yKGBSZXF1aXJlZCAke3RoaXMucG9zaXRpb259LVBhcmFtZXRlciBcIiR7dGhpcy5uYW1lfVwiIG1pc3NpbmcuYCwgNDAwLCA5OTAwMik7XG4gICAgICB9XG4gICAgfSBlbHNlIGlmICghdGhpcy52YWxpZGF0ZShyZXN1bHQpKSB7XG4gICAgICB0aHJvdyByZXNwb25zZS5BcGlFcnJvcihgSW52YWxpZCBWYWx1ZSBmb3IgJHt0aGlzLnBvc2l0aW9ufS1QYXJhbWV0ZXIgXCIke3RoaXMubmFtZX1cIiBwcm92aWRlZC5gLCA0MDAsIDk5MDAzLCB7XG4gICAgICAgIHZhbHVlOiByZXN1bHRcbiAgICAgIH0pO1xuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9XG59XG5cbmNsYXNzIFN0ciBleHRlbmRzIFBhcmFtIHtcbiAgY29uc3RydWN0b3IoLi4uYXJncykge1xuICAgIHN1cGVyKC4uLmFyZ3MpO1xuICAgIHRoaXMudHlwZSA9IFwic3RyaW5nXCI7XG4gIH1cblxuICB2YWxpZGF0ZSh2YWx1ZSkge1xuICAgIGxldCB2YWxpZCA9IHN1cGVyLnZhbGlkYXRlKHZhbHVlKTtcbiAgICBpZiAoISh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnIHx8IHZhbHVlIGluc3RhbmNlb2YgU3RyaW5nKSkge1xuICAgICAgdmFsaWQgPSBmYWxzZTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbGlkO1xuICB9XG59XG5tb2R1bGUuZXhwb3J0cy5TdHIgPSAoLi4uYXJncykgPT4gbmV3IFN0ciguLi5hcmdzKTtcblxuY2xhc3MgUmVnRXggZXh0ZW5kcyBTdHIge1xuICBjb25zdHJ1Y3RvcihuYW1lLCByZWdleCwgLi4uYXJncykge1xuICAgIHN1cGVyKG5hbWUsIC4uLmFyZ3MpO1xuICAgIHRoaXMucmVnZXggPSByZWdleDtcbiAgfVxuXG4gIHZhbGlkYXRlKHZhbHVlKSB7XG4gICAgbGV0IHZhbGlkID0gc3VwZXIudmFsaWRhdGUodmFsdWUpO1xuICAgIGlmICghdmFsdWUubWF0Y2godGhpcy5yZWdleCkpIHtcbiAgICAgIHZhbGlkID0gZmFsc2U7XG4gICAgfVxuICAgIHJldHVybiB2YWxpZDtcbiAgfVxufVxubW9kdWxlLmV4cG9ydHMuUmVnRXggPSAoLi4uYXJncykgPT4gbmV3IFJlZ0V4KC4uLmFyZ3MpO1xuXG5jbGFzcyBFbWFpbCBleHRlbmRzIFJlZ0V4IHtcbiAgY29uc3RydWN0b3IobmFtZSwgLi4uYXJncykge1xuICAgIHN1cGVyKG5hbWUsIC9eW0EtWmEtejAtOS5fJSstXStAW0EtWmEtejAtOS4tXStcXC5bQS1aYS16XXsyLH0kLywgLi4uYXJncyk7XG4gIH1cbn1cbm1vZHVsZS5leHBvcnRzLkVtYWlsID0gKC4uLmFyZ3MpID0+IG5ldyBFbWFpbCguLi5hcmdzKTtcblxuY2xhc3MgQm9vbCBleHRlbmRzIFJlZ0V4IHtcbiAgY29uc3RydWN0b3IobmFtZSwgLi4uYXJncykge1xuICAgIHN1cGVyKG5hbWUsIC9eKDB8MXx0cnVlfGZhbHNlKSQvLCAuLi5hcmdzKTtcbiAgfVxuXG4gIGdldChldmVudCkge1xuICAgIGNvbnN0IHJlc3VsdCA9IHN1cGVyLmdldChldmVudCk7XG4gICAgcmV0dXJuIFtcIjFcIiwgXCJ0cnVlXCJdLmluZGV4T2YocmVzdWx0KSAhPT0gLTE7XG4gIH1cbn1cbm1vZHVsZS5leHBvcnRzLkJvb2wgPSAoLi4uYXJncykgPT4gbmV3IEJvb2woLi4uYXJncyk7XG4iXX0=

@@ -10,4 +10,7 @@ class ApiError extends Error {

}
}
module.exports.ApiErrorClass = ApiError;
module.exports.ApiError = (...args) => new ApiError(...args);

@@ -21,8 +24,10 @@

}
}
module.exports.ApiResponseClass = ApiResponse;
module.exports.ApiResponse = (...args) => new ApiResponse(...args);
// --------------------------
module.exports.ApiResponse = (...args) => new ApiResponse(...args); // --------------------------
class JsonResponse extends ApiResponse {

@@ -32,3 +37,6 @@ constructor(payload, ...args) {

}
}
module.exports.JsonResponse = (...args) => new JsonResponse(...args);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yZXNwb25zZS5qcyJdLCJuYW1lcyI6WyJBcGlFcnJvciIsIkVycm9yIiwiY29uc3RydWN0b3IiLCJtZXNzYWdlIiwic3RhdHVzQ29kZSIsIm1lc3NhZ2VJZCIsInVuZGVmaW5lZCIsImNvbnRleHQiLCJuYW1lIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJtb2R1bGUiLCJleHBvcnRzIiwiQXBpRXJyb3JDbGFzcyIsImFyZ3MiLCJBcGlSZXNwb25zZSIsInBheWxvYWQiLCJoZWFkZXJzIiwiQXBpUmVzcG9uc2VDbGFzcyIsIkpzb25SZXNwb25zZSIsIkpTT04iLCJzdHJpbmdpZnkiXSwibWFwcGluZ3MiOiJBQUFBLE1BQU1BLFFBQU4sU0FBdUJDLEtBQXZCLENBQTZCO0FBQzNCQyxjQUFZQyxPQUFaLEVBQXFCQyxhQUFhLEdBQWxDLEVBQXVDQyxZQUFZQyxTQUFuRCxFQUE4REMsVUFBVUQsU0FBeEUsRUFBbUY7QUFDakYsVUFBTUgsT0FBTjtBQUNBLFNBQUtLLElBQUwsR0FBWSxLQUFLTixXQUFMLENBQWlCTSxJQUE3QjtBQUNBUCxVQUFNUSxpQkFBTixDQUF3QixJQUF4QixFQUE4QixLQUFLUCxXQUFuQztBQUNBLFNBQUtFLFVBQUwsR0FBa0JBLFVBQWxCO0FBQ0EsU0FBS0MsU0FBTCxHQUFpQkEsU0FBakI7QUFDQSxTQUFLRSxPQUFMLEdBQWVBLE9BQWY7QUFDRDs7QUFSMEI7O0FBVTdCRyxPQUFPQyxPQUFQLENBQWVDLGFBQWYsR0FBK0JaLFFBQS9COztBQUNBVSxPQUFPQyxPQUFQLENBQWVYLFFBQWYsR0FBMEIsQ0FBQyxHQUFHYSxJQUFKLEtBQWEsSUFBSWIsUUFBSixDQUFhLEdBQUdhLElBQWhCLENBQXZDOztBQUVBLE1BQU1DLFdBQU4sQ0FBa0I7QUFDaEJaLGNBQVlhLE9BQVosRUFBcUJYLGFBQWEsR0FBbEMsRUFBdUNZLFVBQVUsRUFBakQsRUFBcUQ7QUFDbkQsU0FBS0QsT0FBTCxHQUFlQSxPQUFmO0FBQ0EsU0FBS1gsVUFBTCxHQUFrQkEsVUFBbEI7QUFDQSxTQUFLWSxPQUFMLEdBQWVBLE9BQWY7QUFDRDs7QUFMZTs7QUFPbEJOLE9BQU9DLE9BQVAsQ0FBZU0sZ0JBQWYsR0FBa0NILFdBQWxDOztBQUNBSixPQUFPQyxPQUFQLENBQWVHLFdBQWYsR0FBNkIsQ0FBQyxHQUFHRCxJQUFKLEtBQWEsSUFBSUMsV0FBSixDQUFnQixHQUFHRCxJQUFuQixDQUExQyxDLENBRUE7OztBQUVBLE1BQU1LLFlBQU4sU0FBMkJKLFdBQTNCLENBQXVDO0FBQ3JDWixjQUFZYSxPQUFaLEVBQXFCLEdBQUdGLElBQXhCLEVBQThCO0FBQzVCLFVBQU1NLEtBQUtDLFNBQUwsQ0FBZUwsT0FBZixDQUFOLEVBQStCLEdBQUdGLElBQWxDO0FBQ0Q7O0FBSG9DOztBQUt2Q0gsT0FBT0MsT0FBUCxDQUFlTyxZQUFmLEdBQThCLENBQUMsR0FBR0wsSUFBSixLQUFhLElBQUlLLFlBQUosQ0FBaUIsR0FBR0wsSUFBcEIsQ0FBM0MiLCJmaWxlIjoicmVzcG9uc2UuanMiLCJzb3VyY2VzQ29udGVudCI6WyJjbGFzcyBBcGlFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZSwgc3RhdHVzQ29kZSA9IDQwMCwgbWVzc2FnZUlkID0gdW5kZWZpbmVkLCBjb250ZXh0ID0gdW5kZWZpbmVkKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gdGhpcy5jb25zdHJ1Y3Rvci5uYW1lO1xuICAgIEVycm9yLmNhcHR1cmVTdGFja1RyYWNlKHRoaXMsIHRoaXMuY29uc3RydWN0b3IpO1xuICAgIHRoaXMuc3RhdHVzQ29kZSA9IHN0YXR1c0NvZGU7XG4gICAgdGhpcy5tZXNzYWdlSWQgPSBtZXNzYWdlSWQ7XG4gICAgdGhpcy5jb250ZXh0ID0gY29udGV4dDtcbiAgfVxufVxubW9kdWxlLmV4cG9ydHMuQXBpRXJyb3JDbGFzcyA9IEFwaUVycm9yO1xubW9kdWxlLmV4cG9ydHMuQXBpRXJyb3IgPSAoLi4uYXJncykgPT4gbmV3IEFwaUVycm9yKC4uLmFyZ3MpO1xuXG5jbGFzcyBBcGlSZXNwb25zZSB7XG4gIGNvbnN0cnVjdG9yKHBheWxvYWQsIHN0YXR1c0NvZGUgPSAyMDAsIGhlYWRlcnMgPSB7fSkge1xuICAgIHRoaXMucGF5bG9hZCA9IHBheWxvYWQ7XG4gICAgdGhpcy5zdGF0dXNDb2RlID0gc3RhdHVzQ29kZTtcbiAgICB0aGlzLmhlYWRlcnMgPSBoZWFkZXJzO1xuICB9XG59XG5tb2R1bGUuZXhwb3J0cy5BcGlSZXNwb25zZUNsYXNzID0gQXBpUmVzcG9uc2U7XG5tb2R1bGUuZXhwb3J0cy5BcGlSZXNwb25zZSA9ICguLi5hcmdzKSA9PiBuZXcgQXBpUmVzcG9uc2UoLi4uYXJncyk7XG5cbi8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG5cbmNsYXNzIEpzb25SZXNwb25zZSBleHRlbmRzIEFwaVJlc3BvbnNlIHtcbiAgY29uc3RydWN0b3IocGF5bG9hZCwgLi4uYXJncykge1xuICAgIHN1cGVyKEpTT04uc3RyaW5naWZ5KHBheWxvYWQpLCAuLi5hcmdzKTtcbiAgfVxufVxubW9kdWxlLmV4cG9ydHMuSnNvblJlc3BvbnNlID0gKC4uLmFyZ3MpID0+IG5ldyBKc29uUmVzcG9uc2UoLi4uYXJncyk7XG4iXX0=
const SwaggerParser = require('swagger-parser');
const merge = require("./util/merge")([
"swagger",
"produces",
"paths.*.*.parameters",
"paths.*.*.consumes"
], [
"paths.*.*.description"
]);
const merge = require("./util/merge")(["swagger", "produces", "paths.*.*.parameters", "paths.*.*.consumes"], ["paths.*.*.description"]);

@@ -22,18 +15,14 @@ module.exports = (endpoints, existing) => {

};
Object.keys(endpoints).forEach((request) => {
const parameters = endpoints[request]
.filter(p => ["json", "context"].indexOf(p.position) === -1)
.map(p => Object.assign(
{
name: p.name,
required: p.required,
type: p.type,
format: p.constructor.name,
in: p.position
},
p.regex === undefined ? {} : { pattern: p.regex.toString() }
));
Object.keys(endpoints).forEach(request => {
const parameters = endpoints[request].filter(p => ["json", "context"].indexOf(p.position) === -1).map(p => Object.assign({
name: p.name,
required: p.required,
type: p.type,
format: p.constructor.name,
in: p.position
}, p.regex === undefined ? {} : {
pattern: p.regex.toString()
}));
const jsonParams = endpoints[request].filter(p => p.position === "json");
const jsonParams = endpoints[request]
.filter(p => p.position === "json");
if (jsonParams.length !== 0) {

@@ -47,9 +36,8 @@ parameters.push({

properties: jsonParams.reduce((prev, p) => Object.assign(prev, {
[p.name]: Object.assign(
{
type: p.type,
format: p.constructor.name
},
p.regex === undefined ? {} : { pattern: p.regex.toString() }
)
[p.name]: Object.assign({
type: p.type,
format: p.constructor.name
}, p.regex === undefined ? {} : {
pattern: p.regex.toString()
})
}), {})

@@ -61,5 +49,4 @@ }

const description = [];
const contextParams = endpoints[request]
.filter(p => p.position === "context")
.map(p => p.name);
const contextParams = endpoints[request].filter(p => p.position === "context").map(p => p.name);
if (contextParams.length !== 0) {

@@ -82,3 +69,2 @@ description.push(`Internally contexts are used: ${contextParams.join(", ")}`);

});
const result = JSON.parse(JSON.stringify(existing));

@@ -88,1 +74,2 @@ merge(result, data);

};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9zd2FnZ2VyLmpzIl0sIm5hbWVzIjpbIlN3YWdnZXJQYXJzZXIiLCJyZXF1aXJlIiwibWVyZ2UiLCJtb2R1bGUiLCJleHBvcnRzIiwiZW5kcG9pbnRzIiwiZXhpc3RpbmciLCJkYXRhIiwic3dhZ2dlciIsInByb2R1Y2VzIiwiaW5mbyIsInRpdGxlIiwidmVyc2lvbiIsInBhdGhzIiwiT2JqZWN0Iiwia2V5cyIsImZvckVhY2giLCJyZXF1ZXN0IiwicGFyYW1ldGVycyIsImZpbHRlciIsInAiLCJpbmRleE9mIiwicG9zaXRpb24iLCJtYXAiLCJhc3NpZ24iLCJuYW1lIiwicmVxdWlyZWQiLCJ0eXBlIiwiZm9ybWF0IiwiY29uc3RydWN0b3IiLCJpbiIsInJlZ2V4IiwidW5kZWZpbmVkIiwicGF0dGVybiIsInRvU3RyaW5nIiwianNvblBhcmFtcyIsImxlbmd0aCIsInB1c2giLCJzY2hlbWEiLCJwcm9wZXJ0aWVzIiwicmVkdWNlIiwicHJldiIsImRlc2NyaXB0aW9uIiwiY29udGV4dFBhcmFtcyIsImpvaW4iLCJzcGxpdCIsInRvTG93ZXJDYXNlIiwiY29uc3VtZXMiLCJyZXNwb25zZXMiLCJkZWZhdWx0IiwicmVzdWx0IiwiSlNPTiIsInBhcnNlIiwic3RyaW5naWZ5IiwidmFsaWRhdGUiXSwibWFwcGluZ3MiOiJBQUFBLE1BQU1BLGdCQUFnQkMsUUFBUSxnQkFBUixDQUF0Qjs7QUFFQSxNQUFNQyxRQUFRRCxRQUFRLGNBQVIsRUFBd0IsQ0FDcEMsU0FEb0MsRUFFcEMsVUFGb0MsRUFHcEMsc0JBSG9DLEVBSXBDLG9CQUpvQyxDQUF4QixFQUtYLENBQ0QsdUJBREMsQ0FMVyxDQUFkOztBQVNBRSxPQUFPQyxPQUFQLEdBQWlCLENBQUNDLFNBQUQsRUFBWUMsUUFBWixLQUF5QjtBQUN4QyxRQUFNQyxPQUFPO0FBQ1hDLGFBQVMsS0FERTtBQUVYQyxjQUFVLENBQUMsa0JBQUQsQ0FGQztBQUdYQyxVQUFNO0FBQ0pDLGFBQU8sVUFESDtBQUVKQyxl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QyxJQUFkO0FBQ0EsU0FBT1AsY0FBY3NELFFBQWQsQ0FBdUJKLE1BQXZCLENBQVA7QUFDRCxDQXZFRCIsImZpbGUiOiJzd2FnZ2VyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgU3dhZ2dlclBhcnNlciA9IHJlcXVpcmUoJ3N3YWdnZXItcGFyc2VyJyk7XG5cbmNvbnN0IG1lcmdlID0gcmVxdWlyZShcIi4vdXRpbC9tZXJnZVwiKShbXG4gIFwic3dhZ2dlclwiLFxuICBcInByb2R1Y2VzXCIsXG4gIFwicGF0aHMuKi4qLnBhcmFtZXRlcnNcIixcbiAgXCJwYXRocy4qLiouY29uc3VtZXNcIlxuXSwgW1xuICBcInBhdGhzLiouKi5kZXNjcmlwdGlvblwiXG5dKTtcblxubW9kdWxlLmV4cG9ydHMgPSAoZW5kcG9pbnRzLCBleGlzdGluZykgPT4ge1xuICBjb25zdCBkYXRhID0ge1xuICAgIHN3YWdnZXI6IFwiMi4wXCIsXG4gICAgcHJvZHVjZXM6IFtcImFwcGxpY2F0aW9uL2pzb25cIl0sXG4gICAgaW5mbzoge1xuICAgICAgdGl0bGU6IFwiQXBpIE5hbWVcIixcbiAgICAgIHZlcnNpb246IFwiMC4wLjFcIlxuICAgIH0sXG4gICAgcGF0aHM6IHt9XG4gIH07XG4gIE9iamVjdC5rZXlzKGVuZHBvaW50cykuZm9yRWFjaCgocmVxdWVzdCkgPT4ge1xuICAgIGNvbnN0IHBhcmFtZXRlcnMgPSBlbmRwb2ludHNbcmVxdWVzdF1cbiAgICAgIC5maWx0ZXIocCA9PiBbXCJqc29uXCIsIFwiY29udGV4dFwiXS5pbmRleE9mKHAucG9zaXRpb24pID09PSAtMSlcbiAgICAgIC5tYXAocCA9PiBPYmplY3QuYXNzaWduKFxuICAgICAgICB7XG4gICAgICAgICAgbmFtZTogcC5uYW1lLFxuICAgICAgICAgIHJlcXVpcmVkOiBwLnJlcXVpcmVkLFxuICAgICAgICAgIHR5cGU6IHAudHlwZSxcbiAgICAgICAgICBmb3JtYXQ6IHAuY29uc3RydWN0b3IubmFtZSxcbiAgICAgICAgICBpbjogcC5wb3NpdGlvblxuICAgICAgICB9LFxuICAgICAgICBwLnJlZ2V4ID09PSB1bmRlZmluZWQgPyB7fSA6IHsgcGF0dGVybjogcC5yZWdleC50b1N0cmluZygpIH1cbiAgICAgICkpO1xuXG4gICAgY29uc3QganNvblBhcmFtcyA9IGVuZHBvaW50c1tyZXF1ZXN0XVxuICAgICAgLmZpbHRlcihwID0+IHAucG9zaXRpb24gPT09IFwianNvblwiKTtcbiAgICBpZiAoanNvblBhcmFtcy5sZW5ndGggIT09IDApIHtcbiAgICAgIHBhcmFtZXRlcnMucHVzaCh7XG4gICAgICAgIGluOiBcImJvZHlcIixcbiAgICAgICAgbmFtZTogXCJib2R5UGFyYW1EYXRhXCIsXG4gICAgICAgIHNjaGVtYToge1xuICAgICAgICAgIHR5cGU6IFwib2JqZWN0XCIsXG4gICAgICAgICAgcmVxdWlyZWQ6IGpzb25QYXJhbXMuZmlsdGVyKHAgPT4gcC5yZXF1aXJlZCkubWFwKHAgPT4gcC5uYW1lKSxcbiAgICAgICAgICBwcm9wZXJ0aWVzOiBqc29uUGFyYW1zLnJlZHVjZSgocHJldiwgcCkgPT4gT2JqZWN0LmFzc2lnbihwcmV2LCB7XG4gICAgICAgICAgICBbcC5uYW1lXTogT2JqZWN0LmFzc2lnbihcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIHR5cGU6IHAudHlwZSxcbiAgICAgICAgICAgICAgICBmb3JtYXQ6IHAuY29uc3RydWN0b3IubmFtZVxuICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICBwLnJlZ2V4ID09PSB1bmRlZmluZWQgPyB7fSA6IHsgcGF0dGVybjogcC5yZWdleC50b1N0cmluZygpIH1cbiAgICAgICAgICAgIClcbiAgICAgICAgICB9KSwge30pXG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGNvbnN0IGRlc2NyaXB0aW9uID0gW107XG4gICAgY29uc3QgY29udGV4dFBhcmFtcyA9IGVuZHBvaW50c1tyZXF1ZXN0XVxuICAgICAgLmZpbHRlcihwID0+IHAucG9zaXRpb24gPT09IFwiY29udGV4dFwiKVxuICAgICAgLm1hcChwID0+IHAubmFtZSk7XG4gICAgaWYgKGNvbnRleHRQYXJhbXMubGVuZ3RoICE9PSAwKSB7XG4gICAgICBkZXNjcmlwdGlvbi5wdXNoKGBJbnRlcm5hbGx5IGNvbnRleHRzIGFyZSB1c2VkOiAke2NvbnRleHRQYXJhbXMuam9pbihcIiwgXCIpfWApO1xuICAgIH1cblxuICAgIGRhdGEucGF0aHNbYC8ke3JlcXVlc3Quc3BsaXQoXCIgXCIpWzFdfWBdID0ge1xuICAgICAgW3JlcXVlc3Quc3BsaXQoXCIgXCIpWzBdLnRvTG93ZXJDYXNlKCldOiB7XG4gICAgICAgIGNvbnN1bWVzOiBbXCJhcHBsaWNhdGlvbi9qc29uXCJdLFxuICAgICAgICBkZXNjcmlwdGlvbjogZGVzY3JpcHRpb24uam9pbihcIlxcblwiKSxcbiAgICAgICAgcGFyYW1ldGVycyxcbiAgICAgICAgcmVzcG9uc2VzOiB7XG4gICAgICAgICAgZGVmYXVsdDoge1xuICAgICAgICAgICAgZGVzY3JpcHRpb246IFwiVW5leHBlY3RlZCBFcnJvclwiXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfSk7XG5cbiAgY29uc3QgcmVzdWx0ID0gSlNPTi5wYXJzZShKU09OLnN0cmluZ2lmeShleGlzdGluZykpO1xuICBtZXJnZShyZXN1bHQsIGRhdGEpO1xuICByZXR1cm4gU3dhZ2dlclBhcnNlci52YWxpZGF0ZShyZXN1bHQpO1xufTtcbiJdfQ==

@@ -1,2 +0,2 @@

module.exports = (needles) => {
module.exports = needles => {
const compiledSearch = needles.map(n => new RegExp(`^${n.replace(/\./g, "\\.").replace(/\*/g, "[^.]+?")}$`));

@@ -7,5 +7,7 @@

const selector = hierarchy.join(".");
if (compiledSearch.some(search => selector.match(search))) {
result.push(selector);
}
if (haystack instanceof Object) {

@@ -17,3 +19,3 @@ if (Array.isArray(haystack)) {

} else {
Object.keys(haystack).forEach((key) => {
Object.keys(haystack).forEach(key => {
result.push(...find(haystack[key], hierarchy.concat([key])));

@@ -23,2 +25,3 @@ });

}
return result;

@@ -29,1 +32,2 @@ };

};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsL2ZpbmQuanMiXSwibmFtZXMiOlsibW9kdWxlIiwiZXhwb3J0cyIsIm5lZWRsZXMiLCJjb21waWxlZFNlYXJjaCIsIm1hcCIsIm4iLCJSZWdFeHAiLCJyZXBsYWNlIiwiZmluZCIsImhheXN0YWNrIiwiaGllcmFyY2h5IiwicmVzdWx0Iiwic2VsZWN0b3IiLCJqb2luIiwic29tZSIsInNlYXJjaCIsIm1hdGNoIiwicHVzaCIsIk9iamVjdCIsIkFycmF5IiwiaXNBcnJheSIsImkiLCJsZW5ndGgiLCJjb25jYXQiLCJrZXlzIiwiZm9yRWFjaCIsImtleSJdLCJtYXBwaW5ncyI6IkFBQUFBLE9BQU9DLE9BQVAsR0FBa0JDLE9BQUQsSUFBYTtBQUM1QixRQUFNQyxpQkFBaUJELFFBQVFFLEdBQVIsQ0FBWUMsS0FBSyxJQUFJQyxNQUFKLENBQVksSUFBR0QsRUFBRUUsT0FBRixDQUFVLEtBQVYsRUFBaUIsS0FBakIsRUFBd0JBLE9BQXhCLENBQWdDLEtBQWhDLEVBQXVDLFFBQXZDLENBQWlELEdBQWhFLENBQWpCLENBQXZCOztBQUVBLFFBQU1DLE9BQU8sQ0FBQ0MsUUFBRCxFQUFXQyxZQUFZLEVBQXZCLEtBQThCO0FBQ3pDLFVBQU1DLFNBQVMsRUFBZjtBQUNBLFVBQU1DLFdBQVdGLFVBQVVHLElBQVYsQ0FBZSxHQUFmLENBQWpCOztBQUNBLFFBQUlWLGVBQWVXLElBQWYsQ0FBb0JDLFVBQVVILFNBQVNJLEtBQVQsQ0FBZUQsTUFBZixDQUE5QixDQUFKLEVBQTJEO0FBQ3pESixhQUFPTSxJQUFQLENBQVlMLFFBQVo7QUFDRDs7QUFDRCxRQUFJSCxvQkFBb0JTLE1BQXhCLEVBQWdDO0FBQzlCLFVBQUlDLE1BQU1DLE9BQU4sQ0FBY1gsUUFBZCxDQUFKLEVBQTZCO0FBQzNCLGFBQUssSUFBSVksSUFBSSxDQUFiLEVBQWdCQSxJQUFJWixTQUFTYSxNQUE3QixFQUFxQ0QsS0FBSyxDQUExQyxFQUE2QztBQUMzQ1YsaUJBQU9NLElBQVAsQ0FBWSxHQUFHVCxLQUFLQyxTQUFTWSxDQUFULENBQUwsRUFBa0JYLFVBQVVhLE1BQVYsQ0FBaUIsQ0FBQ0YsQ0FBRCxDQUFqQixDQUFsQixDQUFmO0FBQ0Q7QUFDRixPQUpELE1BSU87QUFDTEgsZUFBT00sSUFBUCxDQUFZZixRQUFaLEVBQXNCZ0IsT0FBdEIsQ0FBK0JDLEdBQUQsSUFBUztBQUNyQ2YsaUJBQU9NLElBQVAsQ0FBWSxHQUFHVCxLQUFLQyxTQUFTaUIsR0FBVCxDQUFMLEVBQW9CaEIsVUFBVWEsTUFBVixDQUFpQixDQUFDRyxHQUFELENBQWpCLENBQXBCLENBQWY7QUFDRCxTQUZEO0FBR0Q7QUFDRjs7QUFDRCxXQUFPZixNQUFQO0FBQ0QsR0FsQkQ7O0FBb0JBLFNBQU9ILElBQVA7QUFDRCxDQXhCRCIsImZpbGUiOiJmaW5kLmpzIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHMgPSAobmVlZGxlcykgPT4ge1xuICBjb25zdCBjb21waWxlZFNlYXJjaCA9IG5lZWRsZXMubWFwKG4gPT4gbmV3IFJlZ0V4cChgXiR7bi5yZXBsYWNlKC9cXC4vZywgXCJcXFxcLlwiKS5yZXBsYWNlKC9cXCovZywgXCJbXi5dKz9cIil9JGApKTtcblxuICBjb25zdCBmaW5kID0gKGhheXN0YWNrLCBoaWVyYXJjaHkgPSBbXSkgPT4ge1xuICAgIGNvbnN0IHJlc3VsdCA9IFtdO1xuICAgIGNvbnN0IHNlbGVjdG9yID0gaGllcmFyY2h5LmpvaW4oXCIuXCIpO1xuICAgIGlmIChjb21waWxlZFNlYXJjaC5zb21lKHNlYXJjaCA9PiBzZWxlY3Rvci5tYXRjaChzZWFyY2gpKSkge1xuICAgICAgcmVzdWx0LnB1c2goc2VsZWN0b3IpO1xuICAgIH1cbiAgICBpZiAoaGF5c3RhY2sgaW5zdGFuY2VvZiBPYmplY3QpIHtcbiAgICAgIGlmIChBcnJheS5pc0FycmF5KGhheXN0YWNrKSkge1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IGhheXN0YWNrLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICAgICAgcmVzdWx0LnB1c2goLi4uZmluZChoYXlzdGFja1tpXSwgaGllcmFyY2h5LmNvbmNhdChbaV0pKSk7XG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIE9iamVjdC5rZXlzKGhheXN0YWNrKS5mb3JFYWNoKChrZXkpID0+IHtcbiAgICAgICAgICByZXN1bHQucHVzaCguLi5maW5kKGhheXN0YWNrW2tleV0sIGhpZXJhcmNoeS5jb25jYXQoW2tleV0pKSk7XG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9O1xuXG4gIHJldHVybiBmaW5kO1xufTtcbiJdfQ==
const get = require("lodash.get");
const set = require("lodash.set");
const defaultsdeep = require("lodash.defaultsdeep");
const Find = require("./find");

@@ -9,9 +12,9 @@

const findContains = Find(contains);
return (target, data) => {
defaultsdeep(target, data);
findExact(data).forEach(m => set(target, m, get(data, m)));
findContains(data).forEach((m) => {
findContains(data).forEach(m => {
const current = get(target, m);
const shouldContain = get(data, m);
if ((current || "").indexOf(shouldContain) === -1) {

@@ -23,1 +26,2 @@ set(target, m, [current, shouldContain].filter(e => e !== undefined).join("\n"));

};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsL21lcmdlLmpzIl0sIm5hbWVzIjpbImdldCIsInJlcXVpcmUiLCJzZXQiLCJkZWZhdWx0c2RlZXAiLCJGaW5kIiwibW9kdWxlIiwiZXhwb3J0cyIsImV4YWN0IiwiY29udGFpbnMiLCJmaW5kRXhhY3QiLCJmaW5kQ29udGFpbnMiLCJ0YXJnZXQiLCJkYXRhIiwiZm9yRWFjaCIsIm0iLCJjdXJyZW50Iiwic2hvdWxkQ29udGFpbiIsImluZGV4T2YiLCJmaWx0ZXIiLCJlIiwidW5kZWZpbmVkIiwiam9pbiJdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTUEsTUFBTUMsUUFBUSxZQUFSLENBQVo7O0FBQ0EsTUFBTUMsTUFBTUQsUUFBUSxZQUFSLENBQVo7O0FBQ0EsTUFBTUUsZUFBZUYsUUFBUSxxQkFBUixDQUFyQjs7QUFDQSxNQUFNRyxPQUFPSCxRQUFRLFFBQVIsQ0FBYjs7QUFFQUksT0FBT0MsT0FBUCxHQUFpQixDQUFDQyxLQUFELEVBQVFDLFFBQVIsS0FBcUI7QUFDcEMsUUFBTUMsWUFBWUwsS0FBS0csS0FBTCxDQUFsQjtBQUNBLFFBQU1HLGVBQWVOLEtBQUtJLFFBQUwsQ0FBckI7QUFFQSxTQUFPLENBQUNHLE1BQUQsRUFBU0MsSUFBVCxLQUFrQjtBQUN2QlQsaUJBQWFRLE1BQWIsRUFBcUJDLElBQXJCO0FBQ0FILGNBQVVHLElBQVYsRUFBZ0JDLE9BQWhCLENBQXdCQyxLQUFLWixJQUFJUyxNQUFKLEVBQVlHLENBQVosRUFBZWQsSUFBSVksSUFBSixFQUFVRSxDQUFWLENBQWYsQ0FBN0I7QUFDQUosaUJBQWFFLElBQWIsRUFBbUJDLE9BQW5CLENBQTRCQyxDQUFELElBQU87QUFDaEMsWUFBTUMsVUFBVWYsSUFBSVcsTUFBSixFQUFZRyxDQUFaLENBQWhCO0FBQ0EsWUFBTUUsZ0JBQWdCaEIsSUFBSVksSUFBSixFQUFVRSxDQUFWLENBQXRCOztBQUNBLFVBQUksQ0FBQ0MsV0FBVyxFQUFaLEVBQWdCRSxPQUFoQixDQUF3QkQsYUFBeEIsTUFBMkMsQ0FBQyxDQUFoRCxFQUFtRDtBQUNqRGQsWUFBSVMsTUFBSixFQUFZRyxDQUFaLEVBQWUsQ0FBQ0MsT0FBRCxFQUFVQyxhQUFWLEVBQXlCRSxNQUF6QixDQUFnQ0MsS0FBS0EsTUFBTUMsU0FBM0MsRUFBc0RDLElBQXRELENBQTJELElBQTNELENBQWY7QUFDRDtBQUNGLEtBTkQ7QUFPRCxHQVZEO0FBV0QsQ0FmRCIsImZpbGUiOiJtZXJnZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGdldCA9IHJlcXVpcmUoXCJsb2Rhc2guZ2V0XCIpO1xuY29uc3Qgc2V0ID0gcmVxdWlyZShcImxvZGFzaC5zZXRcIik7XG5jb25zdCBkZWZhdWx0c2RlZXAgPSByZXF1aXJlKFwibG9kYXNoLmRlZmF1bHRzZGVlcFwiKTtcbmNvbnN0IEZpbmQgPSByZXF1aXJlKFwiLi9maW5kXCIpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IChleGFjdCwgY29udGFpbnMpID0+IHtcbiAgY29uc3QgZmluZEV4YWN0ID0gRmluZChleGFjdCk7XG4gIGNvbnN0IGZpbmRDb250YWlucyA9IEZpbmQoY29udGFpbnMpO1xuXG4gIHJldHVybiAodGFyZ2V0LCBkYXRhKSA9PiB7XG4gICAgZGVmYXVsdHNkZWVwKHRhcmdldCwgZGF0YSk7XG4gICAgZmluZEV4YWN0KGRhdGEpLmZvckVhY2gobSA9PiBzZXQodGFyZ2V0LCBtLCBnZXQoZGF0YSwgbSkpKTtcbiAgICBmaW5kQ29udGFpbnMoZGF0YSkuZm9yRWFjaCgobSkgPT4ge1xuICAgICAgY29uc3QgY3VycmVudCA9IGdldCh0YXJnZXQsIG0pO1xuICAgICAgY29uc3Qgc2hvdWxkQ29udGFpbiA9IGdldChkYXRhLCBtKTtcbiAgICAgIGlmICgoY3VycmVudCB8fCBcIlwiKS5pbmRleE9mKHNob3VsZENvbnRhaW4pID09PSAtMSkge1xuICAgICAgICBzZXQodGFyZ2V0LCBtLCBbY3VycmVudCwgc2hvdWxkQ29udGFpbl0uZmlsdGVyKGUgPT4gZSAhPT0gdW5kZWZpbmVkKS5qb2luKFwiXFxuXCIpKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfTtcbn07XG4iXX0=

@@ -20,11 +20,17 @@ {

"lambda-tdd": "1.11.15",
"js-gardener": "1.15.0",
"js-gardener": "1.16.0",
"nyc": "11.6.0",
"semantic-release": "15.1.5"
"semantic-release": "15.1.5",
"babel-cli": "7.0.0-beta.3"
},
"version": "1.12.6",
"version": "1.12.7",
"scripts": {
"test": "node gardener && nyc mocha --recursive",
"test": "npm run clean && npm run gardener && npm run test-simple",
"coveralls": "node ./node_modules/coveralls/bin/coveralls.js < ./coverage/lcov.info",
"semantic-release": "semantic-release"
"semantic-release": "npm run clean-build && semantic-release",
"clean": "rm -rf lib",
"build": "npx babel src --out-dir lib --source-maps inline --copy-files --include-dotfiles",
"clean-build": "npm run clean && npm run build",
"test-simple": "nyc mocha --recursive",
"gardener": "node gardener"
},

@@ -80,3 +86,4 @@ "homepage": "https://github.com/simlu/lambda-serverless-api#readme",

"coverage/*",
"flow-typed/*"
"flow-typed/*",
"lib/*"
],

@@ -83,0 +90,0 @@ "reporter": [

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc