Socket
Socket
Sign inDemoInstall

axe

Package Overview
Dependencies
Maintainers
1
Versions
103
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

axe - npm Package Compare versions

Comparing version 0.3.7 to 1.0.0

dist/axe.js

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"]}
{
"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"
]
}
}
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