Comparing version 0.3.7 to 1.0.0
270
lib/index.js
@@ -1,134 +0,221 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; | ||
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); } | ||
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); | ||
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); } | ||
var _objectPath = require('object-path'); | ||
function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); } | ||
var _objectPath2 = _interopRequireDefault(_objectPath); | ||
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } } | ||
var _cryptoExtra = require('crypto-extra'); | ||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } | ||
var _cryptoExtra2 = _interopRequireDefault(_cryptoExtra); | ||
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } | ||
var _deepAssign = require('deep-assign'); | ||
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } | ||
var _deepAssign2 = _interopRequireDefault(_deepAssign); | ||
var format = require('format-util'); | ||
var _types = require('./components/types'); | ||
var superagent = require('superagent'); | ||
var _types2 = _interopRequireDefault(_types); | ||
var parseErr = require('parse-err'); | ||
var _intrinsics = require('./components/intrinsics'); | ||
var safeStringify = require('fast-safe-stringify'); // <https://lacke.mn/reduce-your-bundle-js-file-size/> | ||
// <https://github.com/lodash/babel-plugin-lodash/issues/221> | ||
var _intrinsics2 = _interopRequireDefault(_intrinsics); | ||
var _pseudos = require('./components/pseudos'); | ||
var isError = require('lodash/isError'); | ||
var _pseudos2 = _interopRequireDefault(_pseudos); | ||
var isObject = require('lodash/isObject'); | ||
var _apply = require('./components/apply'); | ||
var isString = require('lodash/isString'); | ||
var _apply2 = _interopRequireDefault(_apply); | ||
var includes = require('lodash/includes'); | ||
var _emit = require('./utils/emit'); | ||
var omit = require('lodash/omit'); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var isEmpty = require('lodash/isEmpty'); | ||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } | ||
var isPlainObject = require('lodash/isPlainObject'); | ||
var Axe = function () { | ||
var isUndefined = require('lodash/isUndefined'); | ||
var isNull = require('lodash/isNull'); // add retry logic to superagent | ||
require('superagent-retry')(superagent); // eslint-disable-next-line import/no-unassigned-import | ||
require('console-polyfill'); // these are known as "placeholder tokens", see this link for more info: | ||
// <https://nodejs.org/api/util.html#util_util_format_format_args> | ||
// | ||
// since they aren't exposed (or don't seem to be) by node (at least not yet) | ||
// we just define an array that contains them for now | ||
// <https://github.com/nodejs/node/issues/17601> | ||
var tokens = ['%s', '%d', '%i', '%f', '%j', '%o', '%O', '%%']; | ||
var levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal']; | ||
var endpoint = 'https://api.cabinjs.com'; | ||
var Axe = | ||
/*#__PURE__*/ | ||
function () { | ||
function Axe() { | ||
var _this = this; | ||
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; | ||
var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; | ||
_classCallCheck(this, Axe); | ||
this._name = opts.name || 'axe-' + _cryptoExtra2.default.randomString(15, '0123456789'); | ||
if (!opts.name) { | ||
(0, _emit.warn)('Stacks with generated names cannot be updated! Provide your own name to remedy this.'); | ||
} | ||
this.config = Object.assign({ | ||
key: '', | ||
endpoint: endpoint, | ||
headers: {}, | ||
timeout: 5000, | ||
retry: 3, | ||
showStack: true, | ||
showMeta: false, | ||
silent: false, | ||
logger: console, | ||
levels: ['info', 'warn', 'error', 'fatal'], | ||
capture: true | ||
}, config); // we could have used `auto-bind` but it's not compiled for browser | ||
this._params = opts.params || {}; | ||
this.envParam = opts.envParam !== undefined ? opts.envParam : true; | ||
this.hiddenParams = opts.hiddenParams !== undefined ? opts.hiddenParams : true; | ||
this.log = this.log.bind(this); // bind helper functions for each log level | ||
if (opts.appendEnv) { | ||
if (process.env.NODE_ENV) { | ||
this.baseName = this._name; | ||
this._name += '--' + process.env.NODE_ENV; | ||
} else { | ||
(0, _emit.warn)('"appendEnv" is set to true, but environment was not found!'); | ||
} | ||
} | ||
levels.forEach(function (level) { | ||
_this[level] = function () { | ||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { | ||
args[_key] = arguments[_key]; | ||
} | ||
this._stack = { | ||
Mappings: {}, | ||
Conditions: {}, | ||
Resources: {}, | ||
Outputs: {}, | ||
Parameters: {} | ||
}; | ||
return _this.log.apply(_this, _toConsumableArray([level].concat([].slice.call(args)))); | ||
}; | ||
}); // aliases | ||
this.addMapping = function (data) { | ||
return _this._add('Mappings', data); | ||
}; | ||
this.addCondition = function (data) { | ||
return _this._add('Conditions', data); | ||
}; | ||
this.addResource = function (data) { | ||
return _this._add('Resources', data); | ||
}; | ||
this.addOutput = function (data) { | ||
return _this._add('Outputs', data); | ||
}; | ||
this.err = this.error; | ||
this.warning = this.warn; | ||
} // eslint-disable-next-line complexity | ||
this.apply = _apply2.default; | ||
} | ||
_createClass(Axe, [{ | ||
key: '_add', | ||
value: function _add(type, data) { | ||
key: "log", | ||
value: function log(level, message) { | ||
var _this2 = this; | ||
if (typeof data === 'function') { | ||
data = data(this); | ||
var meta = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; | ||
for (var _len2 = arguments.length, args = new Array(_len2 > 3 ? _len2 - 3 : 0), _key2 = 3; _key2 < _len2; _key2++) { | ||
args[_key2 - 3] = arguments[_key2]; | ||
} | ||
if (Array.isArray(data)) { | ||
data = data.filter(Boolean); | ||
var originalArgs = [level, message, meta].concat(_toConsumableArray([].slice.call(args))); | ||
var config = this.config; | ||
var modifier = 0; | ||
if (level === 'warning') level = 'warn'; | ||
if (level === 'err') level = 'error'; | ||
return data.forEach(function (i) { | ||
return _this2._add(type, i); | ||
}); | ||
} | ||
if (isError(level)) { | ||
meta = message; | ||
message = level; | ||
level = 'error'; | ||
} else if (!isString(level) || !includes(levels, level)) { | ||
meta = message; | ||
message = level; | ||
level = 'info'; | ||
modifier = -1; | ||
} // if there are four or more args | ||
// then infer to use util.format on everything | ||
var key = Object.keys(data)[0]; | ||
if (this._stack[type][key]) { | ||
throw new Error('Duplicate ' + type.toLowerCase() + ' ID was found: ' + key); | ||
if (arguments.length >= 4 + modifier) { | ||
message = format.apply(void 0, _toConsumableArray(originalArgs.slice(1 + modifier))); | ||
meta = {}; | ||
} else if (arguments.length === 3 + modifier && isString(message) && tokens.some(function (t) { | ||
return includes(message, t); | ||
})) { | ||
// otherwise if there are three args and if the `message` contains | ||
// a placeholder token (e.g. '%s' or '%d' - see above `tokens` variable) | ||
// then we can infer that the `meta` arg passed is used for formatting | ||
message = format(message, meta); | ||
meta = {}; | ||
} else if (!isError(message)) { | ||
if (isError(meta)) { | ||
meta = { | ||
err: parseErr(meta) | ||
}; | ||
} else if (!isPlainObject(meta) && !isUndefined(meta) && !isNull(meta)) { | ||
// if the `meta` variable passed was not an Object then convert it | ||
message = format(message, meta); | ||
meta = {}; | ||
} else if (!isString(message)) { | ||
// if the message is not a string then we should run `util.format` on it | ||
// assuming we're formatting it like it was another argument | ||
// (as opposed to using something like fast-json-stringify) | ||
message = format(message); | ||
} | ||
} | ||
if (type === 'Resources') { | ||
(function () { | ||
var tags = _objectPath2.default.get(data[key], 'Properties.Tags'); | ||
if (tags && !Array.isArray(tags)) { | ||
data[key].Properties.Tags = Object.keys(tags).map(function (tag) { | ||
return { | ||
Key: tag, | ||
Value: tags[tag] | ||
}; | ||
}); | ||
if (!isPlainObject(meta)) meta = {}; | ||
var err; | ||
if (isError(message)) { | ||
err = message; | ||
if (!isObject(meta.err)) meta.err = parseErr(err); | ||
var _message = message; | ||
message = _message.message; | ||
} // set default level on meta | ||
meta.level = level; // set the body used for returning with and sending logs | ||
// (and also remove circular references) | ||
var body = safeStringify({ | ||
message: message, | ||
meta: meta | ||
}); // send to Cabin or other logging service here the `message` and `meta` | ||
if (config.capture && includes(config.levels, level) && (!isError(err) || !err._captureFailed)) { | ||
// if the user didn't specify a key | ||
// and they are using the default endpoint | ||
// then we should throw an error to them | ||
if (config.endpoint === endpoint && !config.key) throw new Error("Please provide your Cabin API key as `new Axe({ key: 'YOUR-CABIN-API-KEY' })`.\nVisit <https://cabinjs.com> to sign up for free!\nHide this message with `new Axe({ capture: false })`."); // capture the log over HTTP | ||
var req = superagent.post(config.endpoint).timeout(config.timeout); // basic auth (e.g. Cabin API key) | ||
if (config.key) req.auth(config.key); // set headers if any | ||
if (!isEmpty(config.headers)) req.set(config.headers); | ||
req.retry(config.retry).send(body).end(function (err) { | ||
if (err) { | ||
err._captureFailed = true; | ||
_this2.config.logger.error(err); | ||
} | ||
})(); | ||
} | ||
}); | ||
} // Suppress logs if it was silent | ||
(0, _deepAssign2.default)(this._stack[type], data); | ||
if (config.silent) return body; // if there was meta information then output it | ||
var omitted = omit(meta, ['level', 'err']); // fatal should use error (e.g. in browser) | ||
if (level === 'fatal') level = 'error'; // if we didn't pass a level as a method | ||
// (e.g. console.info), then we should still | ||
// use the logger's `log` method to output | ||
if (modifier === -1) level = 'log'; // show stack trace if necessary (along with any metadata) | ||
if (level === 'error' && isError(err) && config.showStack) { | ||
if (!config.showMeta || isEmpty(omitted)) this.config.logger.error(err);else this.config.logger.error(err, omitted); | ||
} else if (!config.showMeta || isEmpty(omitted)) { | ||
this.config.logger[level](message); | ||
} else { | ||
this.config.logger[level](message, omitted); | ||
} // return the parsed body in case we need it | ||
return body; | ||
} | ||
}, { | ||
key: 'toJSON', | ||
value: function toJSON(pretty) { | ||
return pretty ? JSON.stringify(this._stack, null, 2) : JSON.stringify(this._stack); | ||
} | ||
}]); | ||
@@ -139,4 +226,3 @@ | ||
module.exports = _extends({ | ||
Stack: Axe | ||
}, _types2.default, _intrinsics2.default, _pseudos2.default); | ||
module.exports = Axe; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["format","require","superagent","parseErr","safeStringify","isError","isObject","isString","includes","omit","isEmpty","isPlainObject","isUndefined","isNull","tokens","levels","endpoint","Axe","config","Object","assign","key","headers","timeout","retry","showStack","showMeta","silent","logger","console","capture","log","bind","forEach","level","args","concat","slice","call","err","error","warning","warn","message","meta","originalArgs","modifier","arguments","length","some","t","body","_captureFailed","Error","req","post","auth","set","send","end","omitted","module","exports"],"mappings":"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","sourcesContent":["const format = require('format-util');\nconst superagent = require('superagent');\nconst parseErr = require('parse-err');\nconst safeStringify = require('fast-safe-stringify');\n// <https://lacke.mn/reduce-your-bundle-js-file-size/>\n// <https://github.com/lodash/babel-plugin-lodash/issues/221>\nconst isError = require('lodash/isError');\nconst isObject = require('lodash/isObject');\nconst isString = require('lodash/isString');\nconst includes = require('lodash/includes');\nconst omit = require('lodash/omit');\nconst isEmpty = require('lodash/isEmpty');\nconst isPlainObject = require('lodash/isPlainObject');\nconst isUndefined = require('lodash/isUndefined');\nconst isNull = require('lodash/isNull');\n\n// add retry logic to superagent\nrequire('superagent-retry')(superagent);\n\n// eslint-disable-next-line import/no-unassigned-import\nrequire('console-polyfill');\n\n// these are known as \"placeholder tokens\", see this link for more info:\n// <https://nodejs.org/api/util.html#util_util_format_format_args>\n//\n// since they aren't exposed (or don't seem to be) by node (at least not yet)\n// we just define an array that contains them for now\n// <https://github.com/nodejs/node/issues/17601>\nconst tokens = ['%s', '%d', '%i', '%f', '%j', '%o', '%O', '%%'];\nconst levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal'];\nconst endpoint = 'https://api.cabinjs.com';\n\nclass Axe {\n  constructor(config = {}) {\n    this.config = Object.assign(\n      {\n        key: '',\n        endpoint,\n        headers: {},\n        timeout: 5000,\n        retry: 3,\n        showStack: true,\n        showMeta: false,\n        silent: false,\n        logger: console,\n        levels: ['info', 'warn', 'error', 'fatal'],\n        capture: true\n      },\n      config\n    );\n\n    // we could have used `auto-bind` but it's not compiled for browser\n    this.log = this.log.bind(this);\n\n    // bind helper functions for each log level\n    levels.forEach(level => {\n      this[level] = (...args) =>\n        this.log(...[level].concat([].slice.call(args)));\n    });\n\n    // aliases\n    this.err = this.error;\n    this.warning = this.warn;\n  }\n\n  // eslint-disable-next-line complexity\n  log(level, message, meta = {}, ...args) {\n    const originalArgs = [level, message, meta, ...[].slice.call(args)];\n    const { config } = this;\n    let modifier = 0;\n\n    if (level === 'warning') level = 'warn';\n    if (level === 'err') level = 'error';\n\n    if (isError(level)) {\n      meta = message;\n      message = level;\n      level = 'error';\n    } else if (!isString(level) || !includes(levels, level)) {\n      meta = message;\n      message = level;\n      level = 'info';\n      modifier = -1;\n    }\n\n    // if there are four or more args\n    // then infer to use util.format on everything\n    if (arguments.length >= 4 + modifier) {\n      message = format(...originalArgs.slice(1 + modifier));\n      meta = {};\n    } else if (\n      arguments.length === 3 + modifier &&\n      isString(message) &&\n      tokens.some(t => includes(message, t))\n    ) {\n      // otherwise if there are three args and if the `message` contains\n      // a placeholder token (e.g. '%s' or '%d' - see above `tokens` variable)\n      // then we can infer that the `meta` arg passed is used for formatting\n      message = format(message, meta);\n      meta = {};\n    } else if (!isError(message)) {\n      if (isError(meta)) {\n        meta = { err: parseErr(meta) };\n      } else if (!isPlainObject(meta) && !isUndefined(meta) && !isNull(meta)) {\n        // if the `meta` variable passed was not an Object then convert it\n        message = format(message, meta);\n        meta = {};\n      } else if (!isString(message)) {\n        // if the message is not a string then we should run `util.format` on it\n        // assuming we're formatting it like it was another argument\n        // (as opposed to using something like fast-json-stringify)\n        message = format(message);\n      }\n    }\n\n    if (!isPlainObject(meta)) meta = {};\n\n    let err;\n    if (isError(message)) {\n      err = message;\n      if (!isObject(meta.err)) meta.err = parseErr(err);\n      ({ message } = message);\n    }\n\n    // set default level on meta\n    meta.level = level;\n\n    // set the body used for returning with and sending logs\n    // (and also remove circular references)\n    const body = safeStringify({ message, meta });\n\n    // send to Cabin or other logging service here the `message` and `meta`\n    if (\n      config.capture &&\n      includes(config.levels, level) &&\n      (!isError(err) || !err._captureFailed)\n    ) {\n      // if the user didn't specify a key\n      // and they are using the default endpoint\n      // then we should throw an error to them\n      if (config.endpoint === endpoint && !config.key)\n        throw new Error(\n          \"Please provide your Cabin API key as `new Axe({ key: 'YOUR-CABIN-API-KEY' })`.\\nVisit <https://cabinjs.com> to sign up for free!\\nHide this message with `new Axe({ capture: false })`.\"\n        );\n\n      // capture the log over HTTP\n      const req = superagent.post(config.endpoint).timeout(config.timeout);\n\n      // basic auth (e.g. Cabin API key)\n      if (config.key) req.auth(config.key);\n\n      // set headers if any\n      if (!isEmpty(config.headers)) req.set(config.headers);\n\n      req\n        .retry(config.retry)\n        .send(body)\n        .end(err => {\n          if (err) {\n            err._captureFailed = true;\n            this.config.logger.error(err);\n          }\n        });\n    }\n\n    // Suppress logs if it was silent\n    if (config.silent) return body;\n\n    // if there was meta information then output it\n    const omitted = omit(meta, ['level', 'err']);\n\n    // fatal should use error (e.g. in browser)\n    if (level === 'fatal') level = 'error';\n\n    // if we didn't pass a level as a method\n    // (e.g. console.info), then we should still\n    // use the logger's `log` method to output\n    if (modifier === -1) level = 'log';\n\n    // show stack trace if necessary (along with any metadata)\n    if (level === 'error' && isError(err) && config.showStack) {\n      if (!config.showMeta || isEmpty(omitted)) this.config.logger.error(err);\n      else this.config.logger.error(err, omitted);\n    } else if (!config.showMeta || isEmpty(omitted)) {\n      this.config.logger[level](message);\n    } else {\n      this.config.logger[level](message, omitted);\n    }\n\n    // return the parsed body in case we need it\n    return body;\n  }\n}\n\nmodule.exports = Axe;\n"]} |
223
package.json
{ | ||
"name": "axe", | ||
"version": "0.3.7", | ||
"description": "Create AWS infrastructure with Javascript", | ||
"author": "Jason Maurer", | ||
"license": "MIT", | ||
"homepage": "https://github.com/jsonmaur/axe#readme", | ||
"repository": { | ||
"type": "git", | ||
"url": "git+https://github.com/jsonmaur/axe.git" | ||
"description": "Logging add-on to send logs over HTTP to your server in Node and Browser environments. Works with any logger! Chop up your logs consistently! Made for Cabin and Lad.", | ||
"version": "1.0.0", | ||
"author": "Nick Baugh <niftylettuce@gmail.com> (http://niftylettuce.com)", | ||
"ava": { | ||
"serial": true | ||
}, | ||
"bugs": { | ||
"url": "https://github.com/cabinjs/axe/issues" | ||
}, | ||
"contributors": [ | ||
"Nick Baugh <niftylettuce@gmail.com> (http://niftylettuce.com)", | ||
"Alexis Tyler <xo@wvvw.me> (https://wvvw.me/)" | ||
], | ||
"dependencies": { | ||
"console-polyfill": "^0.3.0", | ||
"fast-safe-stringify": "^2.0.4", | ||
"format-util": "^1.0.3", | ||
"lodash": "^4.17.10", | ||
"parse-err": "^0.0.2", | ||
"superagent": "^3.8.3", | ||
"superagent-retry": "^0.6.0" | ||
}, | ||
"devDependencies": { | ||
"@babel/cli": "^7.0.0-beta.51", | ||
"@babel/core": "^7.0.0-beta.51", | ||
"@babel/preset-env": "^7.0.0-beta.51", | ||
"ava": "^1.0.0-beta.6", | ||
"babelify": "^9.0.0", | ||
"browserify": "^16.2.2", | ||
"caniuse-lite": "^1.0.30000856", | ||
"codecov": "^3.0.2", | ||
"cross-env": "^5.2.0", | ||
"eslint": "^5.0.0", | ||
"eslint-config-prettier": "^2.9.0", | ||
"eslint-plugin-compat": "^2.4.0", | ||
"eslint-plugin-prettier": "^2.6.0", | ||
"express": "^4.16.3", | ||
"husky": "^0.14.3", | ||
"jsdom": "^11.11.0", | ||
"koa": "^2.5.1", | ||
"lint-staged": "^7.2.0", | ||
"nyc": "^12.0.2", | ||
"prettier": "^1.13.5", | ||
"remark-cli": "^5.0.0", | ||
"remark-preset-github": "^0.0.8", | ||
"rimraf": "^2.6.2", | ||
"sinon": "^6.0.0", | ||
"tinyify": "^2.4.3", | ||
"xo": "^0.21.1" | ||
}, | ||
"engines": { | ||
"node": ">=4" | ||
"node": ">=6.4" | ||
}, | ||
"files": [ | ||
"lib", | ||
"dist" | ||
], | ||
"homepage": "https://github.com/cabinjs/axe", | ||
"keywords": [ | ||
"airbrake", | ||
"analytic", | ||
"analytics", | ||
"api", | ||
"axe", | ||
"aws", | ||
"amazon web services", | ||
"hosting", | ||
"cloudformation", | ||
"stack", | ||
"infra", | ||
"infrastructure", | ||
"devops", | ||
"server" | ||
"bugsnag", | ||
"bunyan", | ||
"cabin", | ||
"cabinjs", | ||
"chalk", | ||
"color", | ||
"colored", | ||
"connect", | ||
"console", | ||
"express", | ||
"hackable", | ||
"hapi", | ||
"koa", | ||
"lad", | ||
"ladjs", | ||
"lass", | ||
"log", | ||
"logger", | ||
"logging", | ||
"loggly", | ||
"middleware", | ||
"official", | ||
"raven", | ||
"sentry", | ||
"signale", | ||
"timber", | ||
"transport", | ||
"winston", | ||
"wrapper" | ||
], | ||
"files": [ | ||
"bin/", | ||
"lib/", | ||
"license", | ||
"readme.md" | ||
], | ||
"license": "MIT", | ||
"lint-staged": { | ||
"*.{js,jsx,mjs,ts,tsx,css,less,scss,json,graphql}": [ | ||
"prettier --write --single-quote --trailing-comma none", | ||
"git add" | ||
], | ||
"*.md": [ | ||
"remark . -qfo", | ||
"git add" | ||
] | ||
}, | ||
"main": "lib/index.js", | ||
"bin": { | ||
"axe": "bin/axe" | ||
"remarkConfig": { | ||
"plugins": [ | ||
"preset-github" | ||
] | ||
}, | ||
"repository": { | ||
"type": "git", | ||
"url": "https://github.com/cabinjs/axe" | ||
}, | ||
"scripts": { | ||
"test:lint": "standard --verbose | snazzy", | ||
"test:unit": "mocha 'src/**/*.test.js' -R dot -r babel-register -r babel-polyfill", | ||
"test": "npm-run-all test:*", | ||
"prebuild": "rm -rf lib", | ||
"build": "babel src -d lib --no-comments --ignore '*.test.js'", | ||
"watch": "npm run build -- -w", | ||
"prepublish": "npm run build" | ||
"ava": "cross-env NODE_ENV=test ava", | ||
"browserify": "browserify src/index.js -o dist/axe.js -s Axe -d -t babelify", | ||
"build": "npm run build:clean && npm run build:lib && npm run build:dist", | ||
"build:clean": "rimraf lib dist", | ||
"build:dist": "npm run browserify && npm run minify", | ||
"build:lib": "babel src --out-dir lib", | ||
"coverage": "nyc report --reporter=text-lcov > coverage.lcov && codecov", | ||
"lint": "xo && remark . -qfo && eslint lib && eslint dist", | ||
"minify": "cross-env NODE_ENV=production browserify src/index.js -o dist/axe.min.js -s Axe -d -t babelify -p tinyify", | ||
"nyc": "cross-env NODE_ENV=test nyc ava", | ||
"precommit": "lint-staged && npm test", | ||
"test": "npm run build && npm run lint && npm run ava", | ||
"test-coverage": "npm run build && npm run lint && npm run nyc" | ||
}, | ||
"dependencies": { | ||
"aws-sdk": "2.6.12", | ||
"chalk": "1.1.3", | ||
"crypto-extra": "0.4.0", | ||
"deep-assign": "2.0.0", | ||
"minimist": "1.2.0", | ||
"object-path": "0.11.2" | ||
}, | ||
"devDependencies": { | ||
"babel-cli": "6.18.0", | ||
"babel-plugin-transform-object-rest-spread": "6.16.0", | ||
"babel-polyfill": "6.16.0", | ||
"babel-preset-latest": "6.16.0", | ||
"babel-register": "6.18.0", | ||
"chai": "3.5.0", | ||
"mocha": "3.1.2", | ||
"npm-run-all": "3.1.1", | ||
"pre-commit": "1.1.3", | ||
"proxyquire": "1.7.10", | ||
"sinon": "1.17.6", | ||
"snazzy": "5.0.0", | ||
"standard": "8.5.0" | ||
}, | ||
"standard": { | ||
"globals": [ | ||
"describe", | ||
"it" | ||
] | ||
}, | ||
"babel": { | ||
"presets": [ | ||
"latest" | ||
"unpkg": "dist/axe.min.js", | ||
"xo": { | ||
"extends": "prettier", | ||
"plugins": [ | ||
"prettier" | ||
], | ||
"plugins": [ | ||
"transform-object-rest-spread" | ||
"parserOptions": { | ||
"sourceType": "script" | ||
}, | ||
"rules": { | ||
"prettier/prettier": [ | ||
"error", | ||
{ | ||
"singleQuote": true, | ||
"bracketSpacing": true, | ||
"trailingComma": "none" | ||
} | ||
], | ||
"max-len": [ | ||
"error", | ||
{ | ||
"code": 80, | ||
"ignoreUrls": true | ||
} | ||
], | ||
"capitalized-comments": "off", | ||
"camelcase": "off", | ||
"no-warning-comments": "off" | ||
}, | ||
"space": true, | ||
"ignore": [ | ||
"config.js" | ||
] | ||
}, | ||
"precommit": [ | ||
"test:lint" | ||
] | ||
} | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
Uses eval
Supply chain riskPackage uses dynamic code execution (e.g., eval()), which is a dangerous practice. This can prevent the code from running in certain environments and increases the risk that the code may contain exploits or malicious behavior.
Found 1 instance in 1 package
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Dynamic require
Supply chain riskDynamic require can indicate the package is performing dangerous or unsafe dynamic code execution.
Found 1 instance in 1 package
Environment variable access
Supply chain riskPackage accesses environment variables, which may be a sign of credential stuffing or data theft.
Found 1 instance in 1 package
No bug tracker
MaintenancePackage does not have a linked bug tracker in package.json.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
No website
QualityPackage does not have a website.
Found 1 instance in 1 package
1006723
7585
0
0
287
2
7
26
6
3
+ Addedconsole-polyfill@^0.3.0
+ Addedfast-safe-stringify@^2.0.4
+ Addedformat-util@^1.0.3
+ Addedlodash@^4.17.10
+ Addedparse-err@^0.0.2
+ Addedsuperagent@^3.8.3
+ Addedsuperagent-retry@^0.6.0
+ Addedasynckit@0.4.0(transitive)
+ Addedcall-bind@1.0.7(transitive)
+ Addedcombined-stream@1.0.8(transitive)
+ Addedcomponent-emitter@1.3.1(transitive)
+ Addedconsole-polyfill@0.3.0(transitive)
+ Addedcookiejar@2.1.4(transitive)
+ Addedcore-util-is@1.0.3(transitive)
+ Addeddebug@3.2.7(transitive)
+ Addeddefine-data-property@1.1.4(transitive)
+ Addeddelayed-stream@1.0.0(transitive)
+ Addedes-define-property@1.0.0(transitive)
+ Addedes-errors@1.3.0(transitive)
+ Addedextend@3.0.2(transitive)
+ Addedfast-safe-stringify@2.1.1(transitive)
+ Addedform-data@2.5.1(transitive)
+ Addedformat-util@1.0.5(transitive)
+ Addedformidable@1.2.6(transitive)
+ Addedfunction-bind@1.1.2(transitive)
+ Addedget-intrinsic@1.2.4(transitive)
+ Addedgopd@1.0.1(transitive)
+ Addedhas-property-descriptors@1.0.2(transitive)
+ Addedhas-proto@1.0.3(transitive)
+ Addedhas-symbols@1.0.3(transitive)
+ Addedhasown@2.0.2(transitive)
+ Addedinherits@2.0.4(transitive)
+ Addedlodash@4.17.21(transitive)
+ Addedmethods@1.1.2(transitive)
+ Addedmime@1.6.0(transitive)
+ Addedmime-db@1.52.0(transitive)
+ Addedmime-types@2.1.35(transitive)
+ Addedms@2.1.3(transitive)
+ Addedobject-inspect@1.13.2(transitive)
+ Addedparse-err@0.0.2(transitive)
+ Addedprocess-nextick-args@2.0.1(transitive)
+ Addedqs@6.13.0(transitive)
+ Addedreadable-stream@2.3.8(transitive)
+ Addedsafe-buffer@5.1.2(transitive)
+ Addedset-function-length@1.2.2(transitive)
+ Addedside-channel@1.0.6(transitive)
+ Addedstring_decoder@1.1.1(transitive)
+ Addedsuperagent@3.8.3(transitive)
+ Addedsuperagent-retry@0.6.0(transitive)
+ Addedutil-deprecate@1.0.2(transitive)
- Removedaws-sdk@2.6.12
- Removedchalk@1.1.3
- Removedcrypto-extra@0.4.0
- Removeddeep-assign@2.0.0
- Removedminimist@1.2.0
- Removedobject-path@0.11.2
- Removedansi-regex@2.1.1(transitive)
- Removedansi-styles@2.2.1(transitive)
- Removedaws-sdk@2.6.12(transitive)
- Removedbase64-js@1.5.1(transitive)
- Removedbuffer@4.9.1(transitive)
- Removedchalk@1.1.3(transitive)
- Removedcrypto-browserify@1.0.9(transitive)
- Removedcrypto-extra@0.4.0(transitive)
- Removeddeep-assign@2.0.0(transitive)
- Removedescape-string-regexp@1.0.5(transitive)
- Removedhas-ansi@2.0.0(transitive)
- Removedieee754@1.2.1(transitive)
- Removedis-obj@1.0.1(transitive)
- Removedjmespath@0.15.0(transitive)
- Removedlodash@3.5.0(transitive)
- Removedminimist@1.2.0(transitive)
- Removedobject-path@0.11.2(transitive)
- Removedpunycode@1.3.2(transitive)
- Removedquerystring@0.2.0(transitive)
- Removedsax@1.1.5(transitive)
- Removedstrip-ansi@3.0.1(transitive)
- Removedsupports-color@2.0.0(transitive)
- Removedurl@0.10.3(transitive)
- Removedxml2js@0.4.15(transitive)
- Removedxmlbuilder@2.6.2(transitive)