├── .gitignore ├── README.md ├── dist ├── demo.js ├── index.js ├── loader.js └── normalizer.js ├── package-lock.json ├── package.json ├── src ├── demo.ts ├── index.ts ├── loader.ts └── normalizer.ts └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | *.log 2 | /typings 3 | /node_modules 4 | /test/artillery*.json 5 | !/dist/.gitkeep 6 | 7 | # Elastic Beanstalk Files 8 | .ebignore 9 | .elasticbeanstalk/* 10 | !.elasticbeanstalk/*.cfg.yml 11 | !.elasticbeanstalk/*.global.yml 12 | 13 | /models/ 14 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # A simple data normalizer to be used with neural networks 2 | 3 | As my grandfather used to say (probably), **neural networks** are dumb. When they're born and when you need to train them just to see how all the magic works, its a pain in the... neck. 4 | 5 | This is library **convert datasets of human data** into **arrays of bits** understandable for neurons (duh). 6 | 7 | *Disclaimer*: 8 | This script was made when i tested the awesome [synaptic.js](https://github.com/cazala/synaptic) neural network library and might not suit all sorts of inputs. Its mainly meant to be able to quickly have test data from example given around the web for neural networks input. 9 | 10 | ## Cut the crap, show me how to 11 | 12 | Consider this. I'm trying to plug a neural network into my Arduino Connected Garden and i've got the following data. I want my network to know when or when not to water my plants on its own (whatever the units are for now). 13 | 14 | ```json 15 | { "soilhumidity": 500, "airtemp": 32, "airhum": 18, "water": true, "plants": ["tomatoes", "potatoes"] }, 16 | { "soilhumidity": 1050, "airtemp": 40, "airhum": 21, "water": true, "plants": ["potatoes", "asparagus"] }, 17 | { "soilhumidity": 300, "airtemp": 100, "airhum": 90, "water": false, "plants": ["asparagus", "tomatoes"] }, 18 | { "soilhumidity": 950, "airtemp": 103, "airhum": 26, "water": true, "plants": ["asparagus", "asparagus"] }, 19 | { "soilhumidity": 1050, "airtemp": 8, "airhum": 26, "water": true, "plants": ["tomatoes", "tomatoes"] }, 20 | { "soilhumidity": 1050, "airtemp": 56, "airhum": 26, "water": true, "plants": ["potatoes", "french fries"] }, 21 | ``` 22 | 23 | In the end, my output is "should i water the plants?": `water: true` and the rest are my inputs. Let's do this. 24 | 25 | ```ts 26 | const normalizer = new Normalizer(sampleData); 27 | 28 | // setting required options and normalize the data 29 | normalizer.setOutputProperties(['water']); 30 | normalizer.normalize(); 31 | 32 | // find useful information about your data 33 | // to pass to your neural network 34 | const nbrInputs = normalizer.getInputLength(); 35 | const nbrOutputs = normalizer.getOutputLength(); 36 | 37 | const metadata = normalizer.getDatasetMetaData(); 38 | const inputs = normalizer.getBinaryInputDataset(); 39 | const outputs = normalizer.getBinaryOutputDataset(); 40 | 41 | console.log(metadata); 42 | console.log(inputs); 43 | console.log(outputs); 44 | ``` 45 | 46 | There you should have all useful information to give to your network. You know the **number if inputs** and **outputs**, you get **~~binarized(?) dataset suitable for neural networks**, and event some *metadata* about your data. 47 | 48 | ``` 49 | $ (console output) 50 | { soilhum: { type: 'number', min: 300, max: 1050, distinctValues: null }, 51 | airtemp: { type: 'number', min: 8, max: 103, distinctValues: null }, 52 | airhum: { type: 'number', min: 18, max: 90, distinctValues: null }, 53 | water: { type: 'boolean', min: 0, max: 1, distinctValues: null }, 54 | plants: 55 | { type: 'array', 56 | min: null, 57 | max: null, 58 | distinctValues: [ 'tomatoes', 'potatoes', 'asparagus', 'french fries' ] } } 59 | 60 | [ [ 0.266667, 0.252632, 0, 1, 1, 0, 0 ], 61 | [ 1, 0.336842, 0.041667, 0, 1, 1, 0 ], 62 | [ 0, 0.968421, 1, 1, 0, 1, 0 ], 63 | [ 0.866667, 1, 0.111111, 0, 0, 1, 0 ], 64 | [ 1, 0, 0.111111, 1, 0, 0, 0 ], 65 | [ 1, 0.505263, 0.111111, 0, 1, 0, 1 ] ] 66 | 67 | [ [ 1 ], [ 1 ], [ 0 ], [ 1 ], [ 1 ], [ 1 ] ] 68 | ``` 69 | 70 | ## Why metadata ? 71 | 72 | Consider a real example where you actually started to understand what are neural networks and start implementing it. You realize the biggest challenge is data formatting. When you **activate Alfred** with you data (i always call my network Alfred) 73 | you realize you also need to **normalize the new data input** as well. 74 | 75 | So you need to save metadata information that you got earlier (mins, maxes, ets) so that our data normalizer here converts the new inputs to the same scales! (this implies training data MUST contain min and maxes values at some point). 76 | 77 | Then on new unkown input you just have to recall the normalizer one thing: *metadata of known values* range. 78 | 79 | ``` 80 | const normalizer = new Normalizer(newData); 81 | 82 | normalizer 83 | .setDatasetMetaData(networkObject.metadata) 84 | .setOutputProperties(['water']); 85 | 86 | const input = normalizer.getBinaryInputDataset()[0]; 87 | 88 | // and activate your neural network with data ! (see index.ts for an example using synaptic) 89 | ``` 90 | -------------------------------------------------------------------------------- /dist/demo.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | Object.defineProperty(exports, "__esModule", { value: true }); 3 | var normalizer_1 = require("./normalizer"); 4 | var sampleData = [ 5 | { "soilhum": 500, "airtemp": 32, "airhum": 18, "water": true, "plants": ["tomatoes", "potatoes"], "tempSpan": [34, 54] }, 6 | { "soilhum": 1050, "airtemp": 40, "airhum": 21, "water": true, "plants": ["potatoes", "asparagus"], "tempSpan": [24, 14] }, 7 | { "soilhum": 300, "airtemp": 100, "airhum": 90, "water": false, "plants": ["asparagus", "tomatoes"], "tempSpan": [56, 4] }, 8 | { "soilhum": 950, "airtemp": 103, "airhum": 26, "water": true, "plants": ["asparagus", "asparagus"], "tempSpan": [123, 2] }, 9 | { "soilhum": 1050, "airtemp": 8, "airhum": 26, "water": true, "plants": ["tomatoes", "tomatoes"], "tempSpan": [67, 12] }, 10 | { "soilhum": 1050, "airtemp": 56, "airhum": 26, "water": true, "plants": ["potatoes", "french fries"], "tempSpan": [8, 45.8] }, 11 | ]; 12 | var normalizer = new normalizer_1.Normalizer(sampleData); 13 | normalizer.setOutputProperties(['isExpert']); 14 | normalizer.normalize(); 15 | var nbrInputs = normalizer.getInputLength(); 16 | var nbrOutputs = normalizer.getOutputLength(); 17 | var metadata = normalizer.getDatasetMetaData(); 18 | var inputs = normalizer.getBinaryInputDataset(); 19 | var outputs = normalizer.getBinaryOutputDataset(); 20 | console.log('\n', '\x1b[37m\x1b[46m', 'METADATA:', '\x1b[0m'); 21 | console.log(metadata); 22 | console.log('\n', '\x1b[37m\x1b[42m', 'INPUT:', '\x1b[0m'); 23 | console.log(inputs); 24 | console.log('\n', '\x1b[37m\x1b[44m', 'OUTPUT:', '\x1b[0m'); 25 | console.log(outputs); 26 | -------------------------------------------------------------------------------- /dist/index.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | function __export(m) { 3 | for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; 4 | } 5 | Object.defineProperty(exports, "__esModule", { value: true }); 6 | __export(require("./loader")); 7 | __export(require("./normalizer")); 8 | -------------------------------------------------------------------------------- /dist/loader.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | Object.defineProperty(exports, "__esModule", { value: true }); 3 | var fs = require("fs"); 4 | var Loader = (function () { 5 | function Loader() { 6 | } 7 | Loader.prototype.setDataDir = function (dir) { 8 | this.dir = dir; 9 | return this; 10 | }; 11 | Loader.prototype.fromJsonFile = function (filename) { 12 | this.filename = filename; 13 | var path = (this.dir + "/" + filename).replace('//', '/'); 14 | var data = fs.readFileSync(path, 'utf8'); 15 | return JSON.parse(data); 16 | }; 17 | Loader.prototype.fromCsvFile = function (filepath) { 18 | }; 19 | Loader.prototype.getTrainedData = function () { 20 | var filename = "trained_" + this.filename; 21 | var filepath = (this.dir + "/" + filename).replace('//', '/'); 22 | var data = fs.readFileSync(filepath, 'utf8'); 23 | return JSON.parse(data); 24 | }; 25 | Loader.prototype.saveTrainedData = function (data) { 26 | var filename = "trained_" + this.filename; 27 | var filepath = (this.dir + "/" + filename).replace('//', '/'); 28 | if (typeof data !== 'string') { 29 | data = JSON.stringify(data); 30 | } 31 | fs.writeFileSync(filepath, data); 32 | }; 33 | Loader.prototype.dataIsTrained = function () { 34 | var filename = "trained_" + this.filename; 35 | var filepath = (this.dir + "/" + filename).replace('//', '/'); 36 | return fs.existsSync(filepath); 37 | }; 38 | return Loader; 39 | }()); 40 | exports.Loader = Loader; 41 | -------------------------------------------------------------------------------- /dist/normalizer.js: -------------------------------------------------------------------------------- 1 | "use strict"; 2 | Object.defineProperty(exports, "__esModule", { value: true }); 3 | function isArray(input) { 4 | return (Object.prototype.toString.call(input) === '[object Array]') ? true : false; 5 | } 6 | var Normalizer = (function () { 7 | function Normalizer(data) { 8 | if (data === void 0) { data = []; } 9 | this.dataset = []; 10 | this.datasetMeta = null; 11 | this.binaryInput = []; 12 | this.binaryOutput = []; 13 | this.outputProperties = []; 14 | this.dataset = data; 15 | if (true !== Array.isArray(data)) { 16 | throw new Error('\x1b[37m\x1b[44mNormalizer input data should be an array of rows: [{...}, {...}]\x1b[0m'); 17 | } 18 | if (this.dataset.length <= 0) { 19 | throw new Error("\u001B[37m\u001B[44mNormalizer input data shouldn't be empty\u001B[0m"); 20 | } 21 | if (Object.keys(this.dataset[0]).length <= 0) { 22 | throw new Error("\u001B[37m\u001B[44mNormalizer input data rows has to contain some properties (only 1st row is checked)\u001B[0m"); 23 | } 24 | } 25 | Normalizer.prototype.getOutputLength = function () { 26 | return this.outputProperties.length; 27 | }; 28 | Normalizer.prototype.getOutputProperties = function () { 29 | return this.outputProperties; 30 | }; 31 | Normalizer.prototype.getInputLength = function () { 32 | return this.binaryInput[0].length; 33 | }; 34 | Normalizer.prototype.getBinaryInputDataset = function () { 35 | return this.binaryInput; 36 | }; 37 | Normalizer.prototype.getBinaryOutputDataset = function () { 38 | return this.binaryOutput; 39 | }; 40 | Normalizer.prototype.getDatasetMetaData = function () { 41 | return this.datasetMeta; 42 | }; 43 | Normalizer.prototype.setDatasetMetaData = function (metadata) { 44 | this.datasetMeta = metadata; 45 | return this; 46 | }; 47 | Normalizer.prototype.convertOutput = function () { 48 | var metadata = this.datasetMeta; 49 | }; 50 | Normalizer.prototype.normalize = function () { 51 | this.datasetMeta = (this.datasetMeta === null) ? this.analyzeMetaData() : this.datasetMeta; 52 | var binaryInput = []; 53 | var binaryOutput = []; 54 | for (var i in this.dataset) { 55 | var row = this.dataset[i]; 56 | var index = 0; 57 | var inputBits = []; 58 | var outputBits = []; 59 | for (var prop in row) { 60 | var bitsArr = void 0; 61 | var value = row[prop]; 62 | var meta = this.datasetMeta[prop]; 63 | switch (meta.type) { 64 | case 'number': 65 | bitsArr = [this.numToBit(meta.min, meta.max, value)]; 66 | break; 67 | case 'boolean': 68 | bitsArr = [this.boolToBit(value)]; 69 | break; 70 | case 'string': 71 | bitsArr = this.strToBitsArr(meta.distinctValues, value); 72 | break; 73 | case 'array': 74 | bitsArr = this.arrToBitsArr(meta.distinctValues, value); 75 | break; 76 | default: 77 | break; 78 | } 79 | if (this.outputProperties.indexOf(prop) > -1) { 80 | outputBits = outputBits.concat(bitsArr); 81 | } 82 | else { 83 | inputBits = inputBits.concat(bitsArr); 84 | } 85 | index++; 86 | } 87 | if (inputBits.length > 0) { 88 | this.binaryInput.push(inputBits); 89 | } 90 | if (outputBits.length > 0) { 91 | this.binaryOutput.push(outputBits); 92 | } 93 | } 94 | }; 95 | Normalizer.prototype.analyzeMetaData = function () { 96 | var firstRow = this.dataset[0]; 97 | var distinctProps = this.distinctProps(firstRow); 98 | var distinctTypes = this.distinctTypes(firstRow); 99 | var metadata = {}; 100 | var bitDataset = []; 101 | for (var _i = 0, distinctProps_1 = distinctProps; _i < distinctProps_1.length; _i++) { 102 | var prop = distinctProps_1[_i]; 103 | var type = distinctTypes[prop]; 104 | metadata[prop] = { 105 | type: type, 106 | min: null, 107 | max: null, 108 | distinctValues: null, 109 | }; 110 | switch (type) { 111 | case 'number': 112 | var minMax = this.getMinMax(prop, this.dataset); 113 | metadata[prop].min = minMax[0]; 114 | metadata[prop].max = minMax[1]; 115 | break; 116 | case 'boolean': 117 | metadata[prop].min = 0; 118 | metadata[prop].max = 1; 119 | break; 120 | case 'string': 121 | var distinctStrVals = this.getDistinctVals(prop, this.dataset); 122 | metadata[prop].distinctValues = distinctStrVals; 123 | break; 124 | case 'array': 125 | var arrMinMax = this.get2DimArrayMinMax(prop, this.dataset); 126 | var distinctArrVals = this.getDistinctArrayVals(prop, this.dataset); 127 | metadata[prop].min = arrMinMax[0]; 128 | metadata[prop].max = arrMinMax[1]; 129 | metadata[prop].distinctValues = distinctArrVals; 130 | break; 131 | } 132 | } 133 | return metadata; 134 | }; 135 | Normalizer.prototype.setOutputProperties = function (props) { 136 | this.outputProperties = props; 137 | return this; 138 | }; 139 | Normalizer.prototype.getMinMax = function (prop, data) { 140 | var min = null; 141 | var max = null; 142 | for (var i in data) { 143 | var val = data[i][prop]; 144 | if (min === null || val < min) { 145 | min = val; 146 | } 147 | if (max === null || val > max) { 148 | max = val; 149 | } 150 | } 151 | return [min, max]; 152 | }; 153 | Normalizer.prototype.getFlatArrMinMax = function (arr) { 154 | var min = null; 155 | var max = null; 156 | if (typeof arr[0] === 'string') { 157 | return [min, max]; 158 | } 159 | for (var i in arr) { 160 | if (typeof arr[i] !== 'number') { 161 | continue; 162 | } 163 | var val = parseFloat(arr[i]); 164 | if (min === null || val < min) { 165 | min = val; 166 | } 167 | if (max === null || val > max) { 168 | max = val; 169 | } 170 | } 171 | return [min, max]; 172 | }; 173 | Normalizer.prototype.get2DimArrayMinMax = function (prop, data) { 174 | var min = null; 175 | var max = null; 176 | var mins = []; 177 | var maxs = []; 178 | for (var _i = 0, data_1 = data; _i < data_1.length; _i++) { 179 | var row = data_1[_i]; 180 | var arr = row[prop]; 181 | var minMax = this.getFlatArrMinMax(arr); 182 | mins.push(minMax[0]); 183 | maxs.push(minMax[1]); 184 | } 185 | min = this.getFlatArrMinMax(mins)[0]; 186 | max = this.getFlatArrMinMax(maxs)[1]; 187 | return [min, max]; 188 | }; 189 | Normalizer.prototype.getDistinctVals = function (property, data) { 190 | var count = 0; 191 | var distinctValues = []; 192 | for (var _i = 0, data_2 = data; _i < data_2.length; _i++) { 193 | var row = data_2[_i]; 194 | var val = row[property]; 195 | if (distinctValues.indexOf(val) === -1) { 196 | distinctValues.push(val); 197 | } 198 | } 199 | return distinctValues; 200 | }; 201 | Normalizer.prototype.getDistinctArrayVals = function (property, data) { 202 | var count = 0; 203 | var distinctValues = []; 204 | for (var _i = 0, data_3 = data; _i < data_3.length; _i++) { 205 | var row = data_3[_i]; 206 | var arrVal = row[property]; 207 | for (var _a = 0, arrVal_1 = arrVal; _a < arrVal_1.length; _a++) { 208 | var val = arrVal_1[_a]; 209 | if (distinctValues.indexOf(val) === -1) { 210 | distinctValues.push(val); 211 | } 212 | } 213 | } 214 | return distinctValues; 215 | }; 216 | Normalizer.prototype.numToBit = function (min, max, value) { 217 | var num = (value - min) / (max - min); 218 | return Number((num).toFixed(6)); 219 | }; 220 | Normalizer.prototype.boolToBit = function (val) { 221 | return +val; 222 | }; 223 | Normalizer.prototype.strToBitsArr = function (distinctValues, val) { 224 | var bitArr = new Array(distinctValues.length); 225 | bitArr.fill(0); 226 | for (var i in distinctValues) { 227 | if (val === distinctValues[i]) { 228 | bitArr[i] = 1; 229 | } 230 | } 231 | return bitArr; 232 | }; 233 | Normalizer.prototype.arrToBitsArr = function (distinctValues, vals) { 234 | var bitArr = new Array(distinctValues.length); 235 | bitArr.fill(0); 236 | for (var j in vals) { 237 | var val = vals[j]; 238 | var idx = distinctValues.indexOf(val); 239 | bitArr[idx] = 1; 240 | } 241 | return bitArr; 242 | }; 243 | Normalizer.prototype.distinctProps = function (row) { 244 | return Object.keys(row); 245 | }; 246 | Normalizer.prototype.distinctTypes = function (row) { 247 | var distinctTypes = {}; 248 | for (var prop in row) { 249 | var value = row[prop]; 250 | if (typeof value === 'object' && isArray(value)) { 251 | distinctTypes[prop] = 'array'; 252 | } 253 | else if (typeof value === 'object') { 254 | distinctTypes[prop] = 'object'; 255 | } 256 | else { 257 | distinctTypes[prop] = typeof (value); 258 | } 259 | } 260 | return distinctTypes; 261 | }; 262 | Normalizer.prototype.getRow1stValue = function (row) { 263 | return row[Object.keys(row)[0]]; 264 | }; 265 | return Normalizer; 266 | }()); 267 | exports.Normalizer = Normalizer; 268 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "neural-data-normalizer", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/node": { 8 | "version": "7.0.43", 9 | "resolved": "https://registry.npmjs.org/@types/node/-/node-7.0.43.tgz", 10 | "integrity": "sha512-7scYwwfHNppXvH/9JzakbVxk0o0QUILVk1Lv64GRaxwPuGpnF1QBiwdvhDpLcymb8BpomQL3KYoWKq3wUdDMhQ==", 11 | "dev": true 12 | }, 13 | "abbrev": { 14 | "version": "1.1.0", 15 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.0.tgz", 16 | "integrity": "sha1-0FVMIlZjbi9W58LlrRg/hZQo2B8=", 17 | "dev": true 18 | }, 19 | "ansi-align": { 20 | "version": "2.0.0", 21 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-2.0.0.tgz", 22 | "integrity": "sha1-w2rsy6VjuJzrVW82kPCx2eNUf38=", 23 | "dev": true, 24 | "requires": { 25 | "string-width": "^2.0.0" 26 | } 27 | }, 28 | "ansi-regex": { 29 | "version": "3.0.0", 30 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 31 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 32 | "dev": true 33 | }, 34 | "ansi-styles": { 35 | "version": "3.2.0", 36 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 37 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 38 | "dev": true, 39 | "requires": { 40 | "color-convert": "^1.9.0" 41 | } 42 | }, 43 | "anymatch": { 44 | "version": "1.3.2", 45 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", 46 | "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", 47 | "dev": true, 48 | "requires": { 49 | "micromatch": "^2.1.5", 50 | "normalize-path": "^2.0.0" 51 | } 52 | }, 53 | "argumentum": { 54 | "version": "0.6.0", 55 | "resolved": "https://registry.npmjs.org/argumentum/-/argumentum-0.6.0.tgz", 56 | "integrity": "sha1-vl8al3N9556XWQKf7rEr4n2WPVA=", 57 | "dev": true 58 | }, 59 | "arr-diff": { 60 | "version": "2.0.0", 61 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 62 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 63 | "dev": true, 64 | "requires": { 65 | "arr-flatten": "^1.0.1" 66 | } 67 | }, 68 | "arr-flatten": { 69 | "version": "1.1.0", 70 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 71 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 72 | "dev": true 73 | }, 74 | "array-unique": { 75 | "version": "0.2.1", 76 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 77 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", 78 | "dev": true 79 | }, 80 | "arrify": { 81 | "version": "1.0.1", 82 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 83 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 84 | "dev": true 85 | }, 86 | "async-each": { 87 | "version": "1.0.1", 88 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", 89 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", 90 | "dev": true 91 | }, 92 | "balanced-match": { 93 | "version": "1.0.0", 94 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 95 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 96 | "dev": true 97 | }, 98 | "binary-extensions": { 99 | "version": "1.10.0", 100 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.10.0.tgz", 101 | "integrity": "sha1-muuabF6IY4qtFx4Wf1kAq+JINdA=", 102 | "dev": true 103 | }, 104 | "boxen": { 105 | "version": "1.2.1", 106 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-1.2.1.tgz", 107 | "integrity": "sha1-DxHn/jRO25OXl3/BPt5/ZNlWSB0=", 108 | "dev": true, 109 | "requires": { 110 | "ansi-align": "^2.0.0", 111 | "camelcase": "^4.0.0", 112 | "chalk": "^2.0.1", 113 | "cli-boxes": "^1.0.0", 114 | "string-width": "^2.0.0", 115 | "term-size": "^1.2.0", 116 | "widest-line": "^1.0.0" 117 | }, 118 | "dependencies": { 119 | "chalk": { 120 | "version": "2.1.0", 121 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.1.0.tgz", 122 | "integrity": "sha512-LUHGS/dge4ujbXMJrnihYMcL4AoOweGnw9Tp3kQuqy1Kx5c1qKjqvMJZ6nVJPMWJtKCTN72ZogH3oeSO9g9rXQ==", 123 | "dev": true, 124 | "requires": { 125 | "ansi-styles": "^3.1.0", 126 | "escape-string-regexp": "^1.0.5", 127 | "supports-color": "^4.0.0" 128 | } 129 | } 130 | } 131 | }, 132 | "brace-expansion": { 133 | "version": "1.1.8", 134 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 135 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 136 | "dev": true, 137 | "requires": { 138 | "balanced-match": "^1.0.0", 139 | "concat-map": "0.0.1" 140 | } 141 | }, 142 | "braces": { 143 | "version": "1.8.5", 144 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 145 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 146 | "dev": true, 147 | "requires": { 148 | "expand-range": "^1.8.1", 149 | "preserve": "^0.2.0", 150 | "repeat-element": "^1.1.2" 151 | } 152 | }, 153 | "camelcase": { 154 | "version": "4.1.0", 155 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 156 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", 157 | "dev": true 158 | }, 159 | "capture-stack-trace": { 160 | "version": "1.0.0", 161 | "resolved": "https://registry.npmjs.org/capture-stack-trace/-/capture-stack-trace-1.0.0.tgz", 162 | "integrity": "sha1-Sm+gc5nCa7pH8LJJa00PtAjFVQ0=", 163 | "dev": true 164 | }, 165 | "chalk": { 166 | "version": "1.1.3", 167 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 168 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 169 | "dev": true, 170 | "requires": { 171 | "ansi-styles": "^2.2.1", 172 | "escape-string-regexp": "^1.0.2", 173 | "has-ansi": "^2.0.0", 174 | "strip-ansi": "^3.0.0", 175 | "supports-color": "^2.0.0" 176 | }, 177 | "dependencies": { 178 | "ansi-regex": { 179 | "version": "2.1.1", 180 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 181 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 182 | "dev": true 183 | }, 184 | "ansi-styles": { 185 | "version": "2.2.1", 186 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 187 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 188 | "dev": true 189 | }, 190 | "strip-ansi": { 191 | "version": "3.0.1", 192 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 193 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 194 | "dev": true, 195 | "requires": { 196 | "ansi-regex": "^2.0.0" 197 | } 198 | }, 199 | "supports-color": { 200 | "version": "2.0.0", 201 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 202 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 203 | "dev": true 204 | } 205 | } 206 | }, 207 | "chokidar": { 208 | "version": "1.7.0", 209 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", 210 | "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", 211 | "dev": true, 212 | "requires": { 213 | "anymatch": "^1.3.0", 214 | "async-each": "^1.0.0", 215 | "fsevents": "^1.0.0", 216 | "glob-parent": "^2.0.0", 217 | "inherits": "^2.0.1", 218 | "is-binary-path": "^1.0.0", 219 | "is-glob": "^2.0.0", 220 | "path-is-absolute": "^1.0.0", 221 | "readdirp": "^2.0.0" 222 | } 223 | }, 224 | "cli-boxes": { 225 | "version": "1.0.0", 226 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-1.0.0.tgz", 227 | "integrity": "sha1-T6kXw+WclKAEzWH47lCdplFocUM=", 228 | "dev": true 229 | }, 230 | "code-point-at": { 231 | "version": "1.1.0", 232 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 233 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 234 | "dev": true 235 | }, 236 | "color-convert": { 237 | "version": "1.9.0", 238 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.0.tgz", 239 | "integrity": "sha1-Gsz5fdc5uYO/mU1W/sj5WFNkG3o=", 240 | "dev": true, 241 | "requires": { 242 | "color-name": "^1.1.1" 243 | } 244 | }, 245 | "color-name": { 246 | "version": "1.1.3", 247 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 248 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 249 | "dev": true 250 | }, 251 | "concat-map": { 252 | "version": "0.0.1", 253 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 254 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 255 | "dev": true 256 | }, 257 | "configstore": { 258 | "version": "3.1.1", 259 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-3.1.1.tgz", 260 | "integrity": "sha512-5oNkD/L++l0O6xGXxb1EWS7SivtjfGQlRyxJsYgE0Z495/L81e2h4/d3r969hoPXuFItzNOKMtsXgYG4c7dYvw==", 261 | "dev": true, 262 | "requires": { 263 | "dot-prop": "^4.1.0", 264 | "graceful-fs": "^4.1.2", 265 | "make-dir": "^1.0.0", 266 | "unique-string": "^1.0.0", 267 | "write-file-atomic": "^2.0.0", 268 | "xdg-basedir": "^3.0.0" 269 | } 270 | }, 271 | "core-util-is": { 272 | "version": "1.0.2", 273 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 274 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 275 | "dev": true 276 | }, 277 | "create-error-class": { 278 | "version": "3.0.2", 279 | "resolved": "https://registry.npmjs.org/create-error-class/-/create-error-class-3.0.2.tgz", 280 | "integrity": "sha1-Br56vvlHo/FKMP1hBnHUAbyot7Y=", 281 | "dev": true, 282 | "requires": { 283 | "capture-stack-trace": "^1.0.0" 284 | } 285 | }, 286 | "cross-spawn": { 287 | "version": "5.1.0", 288 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 289 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 290 | "dev": true, 291 | "requires": { 292 | "lru-cache": "^4.0.1", 293 | "shebang-command": "^1.2.0", 294 | "which": "^1.2.9" 295 | } 296 | }, 297 | "crypto-random-string": { 298 | "version": "1.0.0", 299 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-1.0.0.tgz", 300 | "integrity": "sha1-ojD2T1aDEOFJgAmUB5DsmVRbyn4=", 301 | "dev": true 302 | }, 303 | "debug": { 304 | "version": "2.6.8", 305 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", 306 | "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", 307 | "dev": true, 308 | "requires": { 309 | "ms": "2.0.0" 310 | } 311 | }, 312 | "deep-extend": { 313 | "version": "0.4.2", 314 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.4.2.tgz", 315 | "integrity": "sha1-SLaZwn4zS/ifEIkr5DL25MfTSn8=", 316 | "dev": true 317 | }, 318 | "diff": { 319 | "version": "3.3.1", 320 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.3.1.tgz", 321 | "integrity": "sha512-MKPHZDMB0o6yHyDryUOScqZibp914ksXwAMYMTHj6KO8UeKsRYNJD3oNCKjTqZon+V488P7N/HzXF8t7ZR95ww==", 322 | "dev": true 323 | }, 324 | "dot-prop": { 325 | "version": "4.2.0", 326 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-4.2.0.tgz", 327 | "integrity": "sha512-tUMXrxlExSW6U2EXiiKGSBVdYgtV8qlHL+C10TsW4PURY/ic+eaysnSkwB4kA/mBlCyy/IKDJ+Lc3wbWeaXtuQ==", 328 | "dev": true, 329 | "requires": { 330 | "is-obj": "^1.0.0" 331 | } 332 | }, 333 | "duplexer": { 334 | "version": "0.1.1", 335 | "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", 336 | "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=", 337 | "dev": true 338 | }, 339 | "duplexer3": { 340 | "version": "0.1.4", 341 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 342 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 343 | "dev": true 344 | }, 345 | "es6-promise": { 346 | "version": "3.3.1", 347 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz", 348 | "integrity": "sha1-oIzd6EzNvzTQJ6FFG8kdS80ophM=", 349 | "dev": true 350 | }, 351 | "escape-string-regexp": { 352 | "version": "1.0.5", 353 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 354 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 355 | "dev": true 356 | }, 357 | "event-stream": { 358 | "version": "3.3.4", 359 | "resolved": "https://registry.npmjs.org/event-stream/-/event-stream-3.3.4.tgz", 360 | "integrity": "sha1-SrTJoPWlTbkzi0w02Gv86PSzVXE=", 361 | "dev": true, 362 | "requires": { 363 | "duplexer": "~0.1.1", 364 | "from": "~0", 365 | "map-stream": "~0.1.0", 366 | "pause-stream": "0.0.11", 367 | "split": "0.3", 368 | "stream-combiner": "~0.0.4", 369 | "through": "~2.3.1" 370 | } 371 | }, 372 | "execa": { 373 | "version": "0.7.0", 374 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.7.0.tgz", 375 | "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", 376 | "dev": true, 377 | "requires": { 378 | "cross-spawn": "^5.0.1", 379 | "get-stream": "^3.0.0", 380 | "is-stream": "^1.1.0", 381 | "npm-run-path": "^2.0.0", 382 | "p-finally": "^1.0.0", 383 | "signal-exit": "^3.0.0", 384 | "strip-eof": "^1.0.0" 385 | } 386 | }, 387 | "expand-brackets": { 388 | "version": "0.1.5", 389 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 390 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 391 | "dev": true, 392 | "requires": { 393 | "is-posix-bracket": "^0.1.0" 394 | } 395 | }, 396 | "expand-range": { 397 | "version": "1.8.2", 398 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 399 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 400 | "dev": true, 401 | "requires": { 402 | "fill-range": "^2.1.0" 403 | } 404 | }, 405 | "extglob": { 406 | "version": "0.3.2", 407 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 408 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 409 | "dev": true, 410 | "requires": { 411 | "is-extglob": "^1.0.0" 412 | } 413 | }, 414 | "filename-regex": { 415 | "version": "2.0.1", 416 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 417 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", 418 | "dev": true 419 | }, 420 | "fill-range": { 421 | "version": "2.2.3", 422 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", 423 | "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", 424 | "dev": true, 425 | "requires": { 426 | "is-number": "^2.1.0", 427 | "isobject": "^2.0.0", 428 | "randomatic": "^1.1.3", 429 | "repeat-element": "^1.1.2", 430 | "repeat-string": "^1.5.2" 431 | } 432 | }, 433 | "for-in": { 434 | "version": "1.0.2", 435 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 436 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 437 | "dev": true 438 | }, 439 | "for-own": { 440 | "version": "0.1.5", 441 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 442 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 443 | "dev": true, 444 | "requires": { 445 | "for-in": "^1.0.1" 446 | } 447 | }, 448 | "from": { 449 | "version": "0.1.7", 450 | "resolved": "https://registry.npmjs.org/from/-/from-0.1.7.tgz", 451 | "integrity": "sha1-g8YK/Fi5xWmXAH7Rp2izqzA6RP4=", 452 | "dev": true 453 | }, 454 | "fsevents": { 455 | "version": "1.1.2", 456 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.1.2.tgz", 457 | "integrity": "sha512-Sn44E5wQW4bTHXvQmvSHwqbuiXtduD6Rrjm2ZtUEGbyrig+nUH3t/QD4M4/ZXViY556TBpRgZkHLDx3JxPwxiw==", 458 | "dev": true, 459 | "optional": true, 460 | "requires": { 461 | "nan": "^2.3.0", 462 | "node-pre-gyp": "^0.6.36" 463 | }, 464 | "dependencies": { 465 | "abbrev": { 466 | "version": "1.1.0", 467 | "bundled": true, 468 | "dev": true, 469 | "optional": true 470 | }, 471 | "ajv": { 472 | "version": "4.11.8", 473 | "bundled": true, 474 | "dev": true, 475 | "optional": true, 476 | "requires": { 477 | "co": "^4.6.0", 478 | "json-stable-stringify": "^1.0.1" 479 | } 480 | }, 481 | "ansi-regex": { 482 | "version": "2.1.1", 483 | "bundled": true, 484 | "dev": true 485 | }, 486 | "aproba": { 487 | "version": "1.1.1", 488 | "bundled": true, 489 | "dev": true, 490 | "optional": true 491 | }, 492 | "are-we-there-yet": { 493 | "version": "1.1.4", 494 | "bundled": true, 495 | "dev": true, 496 | "optional": true, 497 | "requires": { 498 | "delegates": "^1.0.0", 499 | "readable-stream": "^2.0.6" 500 | } 501 | }, 502 | "asn1": { 503 | "version": "0.2.3", 504 | "bundled": true, 505 | "dev": true, 506 | "optional": true 507 | }, 508 | "assert-plus": { 509 | "version": "0.2.0", 510 | "bundled": true, 511 | "dev": true, 512 | "optional": true 513 | }, 514 | "asynckit": { 515 | "version": "0.4.0", 516 | "bundled": true, 517 | "dev": true, 518 | "optional": true 519 | }, 520 | "aws-sign2": { 521 | "version": "0.6.0", 522 | "bundled": true, 523 | "dev": true, 524 | "optional": true 525 | }, 526 | "aws4": { 527 | "version": "1.6.0", 528 | "bundled": true, 529 | "dev": true, 530 | "optional": true 531 | }, 532 | "balanced-match": { 533 | "version": "0.4.2", 534 | "bundled": true, 535 | "dev": true 536 | }, 537 | "bcrypt-pbkdf": { 538 | "version": "1.0.1", 539 | "bundled": true, 540 | "dev": true, 541 | "optional": true, 542 | "requires": { 543 | "tweetnacl": "^0.14.3" 544 | } 545 | }, 546 | "block-stream": { 547 | "version": "0.0.9", 548 | "bundled": true, 549 | "dev": true, 550 | "requires": { 551 | "inherits": "~2.0.0" 552 | } 553 | }, 554 | "boom": { 555 | "version": "2.10.1", 556 | "bundled": true, 557 | "dev": true, 558 | "requires": { 559 | "hoek": "2.x.x" 560 | } 561 | }, 562 | "brace-expansion": { 563 | "version": "1.1.7", 564 | "bundled": true, 565 | "dev": true, 566 | "requires": { 567 | "balanced-match": "^0.4.1", 568 | "concat-map": "0.0.1" 569 | } 570 | }, 571 | "buffer-shims": { 572 | "version": "1.0.0", 573 | "bundled": true, 574 | "dev": true 575 | }, 576 | "caseless": { 577 | "version": "0.12.0", 578 | "bundled": true, 579 | "dev": true, 580 | "optional": true 581 | }, 582 | "co": { 583 | "version": "4.6.0", 584 | "bundled": true, 585 | "dev": true, 586 | "optional": true 587 | }, 588 | "code-point-at": { 589 | "version": "1.1.0", 590 | "bundled": true, 591 | "dev": true 592 | }, 593 | "combined-stream": { 594 | "version": "1.0.5", 595 | "bundled": true, 596 | "dev": true, 597 | "requires": { 598 | "delayed-stream": "~1.0.0" 599 | } 600 | }, 601 | "concat-map": { 602 | "version": "0.0.1", 603 | "bundled": true, 604 | "dev": true 605 | }, 606 | "console-control-strings": { 607 | "version": "1.1.0", 608 | "bundled": true, 609 | "dev": true 610 | }, 611 | "core-util-is": { 612 | "version": "1.0.2", 613 | "bundled": true, 614 | "dev": true 615 | }, 616 | "cryptiles": { 617 | "version": "2.0.5", 618 | "bundled": true, 619 | "dev": true, 620 | "optional": true, 621 | "requires": { 622 | "boom": "2.x.x" 623 | } 624 | }, 625 | "dashdash": { 626 | "version": "1.14.1", 627 | "bundled": true, 628 | "dev": true, 629 | "optional": true, 630 | "requires": { 631 | "assert-plus": "^1.0.0" 632 | }, 633 | "dependencies": { 634 | "assert-plus": { 635 | "version": "1.0.0", 636 | "bundled": true, 637 | "dev": true, 638 | "optional": true 639 | } 640 | } 641 | }, 642 | "debug": { 643 | "version": "2.6.8", 644 | "bundled": true, 645 | "dev": true, 646 | "optional": true, 647 | "requires": { 648 | "ms": "2.0.0" 649 | } 650 | }, 651 | "deep-extend": { 652 | "version": "0.4.2", 653 | "bundled": true, 654 | "dev": true, 655 | "optional": true 656 | }, 657 | "delayed-stream": { 658 | "version": "1.0.0", 659 | "bundled": true, 660 | "dev": true 661 | }, 662 | "delegates": { 663 | "version": "1.0.0", 664 | "bundled": true, 665 | "dev": true, 666 | "optional": true 667 | }, 668 | "ecc-jsbn": { 669 | "version": "0.1.1", 670 | "bundled": true, 671 | "dev": true, 672 | "optional": true, 673 | "requires": { 674 | "jsbn": "~0.1.0" 675 | } 676 | }, 677 | "extend": { 678 | "version": "3.0.1", 679 | "bundled": true, 680 | "dev": true, 681 | "optional": true 682 | }, 683 | "extsprintf": { 684 | "version": "1.0.2", 685 | "bundled": true, 686 | "dev": true 687 | }, 688 | "forever-agent": { 689 | "version": "0.6.1", 690 | "bundled": true, 691 | "dev": true, 692 | "optional": true 693 | }, 694 | "form-data": { 695 | "version": "2.1.4", 696 | "bundled": true, 697 | "dev": true, 698 | "optional": true, 699 | "requires": { 700 | "asynckit": "^0.4.0", 701 | "combined-stream": "^1.0.5", 702 | "mime-types": "^2.1.12" 703 | } 704 | }, 705 | "fs.realpath": { 706 | "version": "1.0.0", 707 | "bundled": true, 708 | "dev": true 709 | }, 710 | "fstream": { 711 | "version": "1.0.11", 712 | "bundled": true, 713 | "dev": true, 714 | "requires": { 715 | "graceful-fs": "^4.1.2", 716 | "inherits": "~2.0.0", 717 | "mkdirp": ">=0.5 0", 718 | "rimraf": "2" 719 | } 720 | }, 721 | "fstream-ignore": { 722 | "version": "1.0.5", 723 | "bundled": true, 724 | "dev": true, 725 | "optional": true, 726 | "requires": { 727 | "fstream": "^1.0.0", 728 | "inherits": "2", 729 | "minimatch": "^3.0.0" 730 | } 731 | }, 732 | "gauge": { 733 | "version": "2.7.4", 734 | "bundled": true, 735 | "dev": true, 736 | "optional": true, 737 | "requires": { 738 | "aproba": "^1.0.3", 739 | "console-control-strings": "^1.0.0", 740 | "has-unicode": "^2.0.0", 741 | "object-assign": "^4.1.0", 742 | "signal-exit": "^3.0.0", 743 | "string-width": "^1.0.1", 744 | "strip-ansi": "^3.0.1", 745 | "wide-align": "^1.1.0" 746 | } 747 | }, 748 | "getpass": { 749 | "version": "0.1.7", 750 | "bundled": true, 751 | "dev": true, 752 | "optional": true, 753 | "requires": { 754 | "assert-plus": "^1.0.0" 755 | }, 756 | "dependencies": { 757 | "assert-plus": { 758 | "version": "1.0.0", 759 | "bundled": true, 760 | "dev": true, 761 | "optional": true 762 | } 763 | } 764 | }, 765 | "glob": { 766 | "version": "7.1.2", 767 | "bundled": true, 768 | "dev": true, 769 | "requires": { 770 | "fs.realpath": "^1.0.0", 771 | "inflight": "^1.0.4", 772 | "inherits": "2", 773 | "minimatch": "^3.0.4", 774 | "once": "^1.3.0", 775 | "path-is-absolute": "^1.0.0" 776 | } 777 | }, 778 | "graceful-fs": { 779 | "version": "4.1.11", 780 | "bundled": true, 781 | "dev": true 782 | }, 783 | "har-schema": { 784 | "version": "1.0.5", 785 | "bundled": true, 786 | "dev": true, 787 | "optional": true 788 | }, 789 | "har-validator": { 790 | "version": "4.2.1", 791 | "bundled": true, 792 | "dev": true, 793 | "optional": true, 794 | "requires": { 795 | "ajv": "^4.9.1", 796 | "har-schema": "^1.0.5" 797 | } 798 | }, 799 | "has-unicode": { 800 | "version": "2.0.1", 801 | "bundled": true, 802 | "dev": true, 803 | "optional": true 804 | }, 805 | "hawk": { 806 | "version": "3.1.3", 807 | "bundled": true, 808 | "dev": true, 809 | "optional": true, 810 | "requires": { 811 | "boom": "2.x.x", 812 | "cryptiles": "2.x.x", 813 | "hoek": "2.x.x", 814 | "sntp": "1.x.x" 815 | } 816 | }, 817 | "hoek": { 818 | "version": "2.16.3", 819 | "bundled": true, 820 | "dev": true 821 | }, 822 | "http-signature": { 823 | "version": "1.1.1", 824 | "bundled": true, 825 | "dev": true, 826 | "optional": true, 827 | "requires": { 828 | "assert-plus": "^0.2.0", 829 | "jsprim": "^1.2.2", 830 | "sshpk": "^1.7.0" 831 | } 832 | }, 833 | "inflight": { 834 | "version": "1.0.6", 835 | "bundled": true, 836 | "dev": true, 837 | "requires": { 838 | "once": "^1.3.0", 839 | "wrappy": "1" 840 | } 841 | }, 842 | "inherits": { 843 | "version": "2.0.3", 844 | "bundled": true, 845 | "dev": true 846 | }, 847 | "ini": { 848 | "version": "1.3.4", 849 | "bundled": true, 850 | "dev": true, 851 | "optional": true 852 | }, 853 | "is-fullwidth-code-point": { 854 | "version": "1.0.0", 855 | "bundled": true, 856 | "dev": true, 857 | "requires": { 858 | "number-is-nan": "^1.0.0" 859 | } 860 | }, 861 | "is-typedarray": { 862 | "version": "1.0.0", 863 | "bundled": true, 864 | "dev": true, 865 | "optional": true 866 | }, 867 | "isarray": { 868 | "version": "1.0.0", 869 | "bundled": true, 870 | "dev": true 871 | }, 872 | "isstream": { 873 | "version": "0.1.2", 874 | "bundled": true, 875 | "dev": true, 876 | "optional": true 877 | }, 878 | "jodid25519": { 879 | "version": "1.0.2", 880 | "bundled": true, 881 | "dev": true, 882 | "optional": true, 883 | "requires": { 884 | "jsbn": "~0.1.0" 885 | } 886 | }, 887 | "jsbn": { 888 | "version": "0.1.1", 889 | "bundled": true, 890 | "dev": true, 891 | "optional": true 892 | }, 893 | "json-schema": { 894 | "version": "0.2.3", 895 | "bundled": true, 896 | "dev": true, 897 | "optional": true 898 | }, 899 | "json-stable-stringify": { 900 | "version": "1.0.1", 901 | "bundled": true, 902 | "dev": true, 903 | "optional": true, 904 | "requires": { 905 | "jsonify": "~0.0.0" 906 | } 907 | }, 908 | "json-stringify-safe": { 909 | "version": "5.0.1", 910 | "bundled": true, 911 | "dev": true, 912 | "optional": true 913 | }, 914 | "jsonify": { 915 | "version": "0.0.0", 916 | "bundled": true, 917 | "dev": true, 918 | "optional": true 919 | }, 920 | "jsprim": { 921 | "version": "1.4.0", 922 | "bundled": true, 923 | "dev": true, 924 | "optional": true, 925 | "requires": { 926 | "assert-plus": "1.0.0", 927 | "extsprintf": "1.0.2", 928 | "json-schema": "0.2.3", 929 | "verror": "1.3.6" 930 | }, 931 | "dependencies": { 932 | "assert-plus": { 933 | "version": "1.0.0", 934 | "bundled": true, 935 | "dev": true, 936 | "optional": true 937 | } 938 | } 939 | }, 940 | "mime-db": { 941 | "version": "1.27.0", 942 | "bundled": true, 943 | "dev": true 944 | }, 945 | "mime-types": { 946 | "version": "2.1.15", 947 | "bundled": true, 948 | "dev": true, 949 | "requires": { 950 | "mime-db": "~1.27.0" 951 | } 952 | }, 953 | "minimatch": { 954 | "version": "3.0.4", 955 | "bundled": true, 956 | "dev": true, 957 | "requires": { 958 | "brace-expansion": "^1.1.7" 959 | } 960 | }, 961 | "minimist": { 962 | "version": "0.0.8", 963 | "bundled": true, 964 | "dev": true 965 | }, 966 | "mkdirp": { 967 | "version": "0.5.1", 968 | "bundled": true, 969 | "dev": true, 970 | "requires": { 971 | "minimist": "0.0.8" 972 | } 973 | }, 974 | "ms": { 975 | "version": "2.0.0", 976 | "bundled": true, 977 | "dev": true, 978 | "optional": true 979 | }, 980 | "node-pre-gyp": { 981 | "version": "0.6.36", 982 | "bundled": true, 983 | "dev": true, 984 | "optional": true, 985 | "requires": { 986 | "mkdirp": "^0.5.1", 987 | "nopt": "^4.0.1", 988 | "npmlog": "^4.0.2", 989 | "rc": "^1.1.7", 990 | "request": "^2.81.0", 991 | "rimraf": "^2.6.1", 992 | "semver": "^5.3.0", 993 | "tar": "^2.2.1", 994 | "tar-pack": "^3.4.0" 995 | } 996 | }, 997 | "nopt": { 998 | "version": "4.0.1", 999 | "bundled": true, 1000 | "dev": true, 1001 | "optional": true, 1002 | "requires": { 1003 | "abbrev": "1", 1004 | "osenv": "^0.1.4" 1005 | } 1006 | }, 1007 | "npmlog": { 1008 | "version": "4.1.0", 1009 | "bundled": true, 1010 | "dev": true, 1011 | "optional": true, 1012 | "requires": { 1013 | "are-we-there-yet": "~1.1.2", 1014 | "console-control-strings": "~1.1.0", 1015 | "gauge": "~2.7.3", 1016 | "set-blocking": "~2.0.0" 1017 | } 1018 | }, 1019 | "number-is-nan": { 1020 | "version": "1.0.1", 1021 | "bundled": true, 1022 | "dev": true 1023 | }, 1024 | "oauth-sign": { 1025 | "version": "0.8.2", 1026 | "bundled": true, 1027 | "dev": true, 1028 | "optional": true 1029 | }, 1030 | "object-assign": { 1031 | "version": "4.1.1", 1032 | "bundled": true, 1033 | "dev": true, 1034 | "optional": true 1035 | }, 1036 | "once": { 1037 | "version": "1.4.0", 1038 | "bundled": true, 1039 | "dev": true, 1040 | "requires": { 1041 | "wrappy": "1" 1042 | } 1043 | }, 1044 | "os-homedir": { 1045 | "version": "1.0.2", 1046 | "bundled": true, 1047 | "dev": true, 1048 | "optional": true 1049 | }, 1050 | "os-tmpdir": { 1051 | "version": "1.0.2", 1052 | "bundled": true, 1053 | "dev": true, 1054 | "optional": true 1055 | }, 1056 | "osenv": { 1057 | "version": "0.1.4", 1058 | "bundled": true, 1059 | "dev": true, 1060 | "optional": true, 1061 | "requires": { 1062 | "os-homedir": "^1.0.0", 1063 | "os-tmpdir": "^1.0.0" 1064 | } 1065 | }, 1066 | "path-is-absolute": { 1067 | "version": "1.0.1", 1068 | "bundled": true, 1069 | "dev": true 1070 | }, 1071 | "performance-now": { 1072 | "version": "0.2.0", 1073 | "bundled": true, 1074 | "dev": true, 1075 | "optional": true 1076 | }, 1077 | "process-nextick-args": { 1078 | "version": "1.0.7", 1079 | "bundled": true, 1080 | "dev": true 1081 | }, 1082 | "punycode": { 1083 | "version": "1.4.1", 1084 | "bundled": true, 1085 | "dev": true, 1086 | "optional": true 1087 | }, 1088 | "qs": { 1089 | "version": "6.4.0", 1090 | "bundled": true, 1091 | "dev": true, 1092 | "optional": true 1093 | }, 1094 | "rc": { 1095 | "version": "1.2.1", 1096 | "bundled": true, 1097 | "dev": true, 1098 | "optional": true, 1099 | "requires": { 1100 | "deep-extend": "~0.4.0", 1101 | "ini": "~1.3.0", 1102 | "minimist": "^1.2.0", 1103 | "strip-json-comments": "~2.0.1" 1104 | }, 1105 | "dependencies": { 1106 | "minimist": { 1107 | "version": "1.2.0", 1108 | "bundled": true, 1109 | "dev": true, 1110 | "optional": true 1111 | } 1112 | } 1113 | }, 1114 | "readable-stream": { 1115 | "version": "2.2.9", 1116 | "bundled": true, 1117 | "dev": true, 1118 | "requires": { 1119 | "buffer-shims": "~1.0.0", 1120 | "core-util-is": "~1.0.0", 1121 | "inherits": "~2.0.1", 1122 | "isarray": "~1.0.0", 1123 | "process-nextick-args": "~1.0.6", 1124 | "string_decoder": "~1.0.0", 1125 | "util-deprecate": "~1.0.1" 1126 | } 1127 | }, 1128 | "request": { 1129 | "version": "2.81.0", 1130 | "bundled": true, 1131 | "dev": true, 1132 | "optional": true, 1133 | "requires": { 1134 | "aws-sign2": "~0.6.0", 1135 | "aws4": "^1.2.1", 1136 | "caseless": "~0.12.0", 1137 | "combined-stream": "~1.0.5", 1138 | "extend": "~3.0.0", 1139 | "forever-agent": "~0.6.1", 1140 | "form-data": "~2.1.1", 1141 | "har-validator": "~4.2.1", 1142 | "hawk": "~3.1.3", 1143 | "http-signature": "~1.1.0", 1144 | "is-typedarray": "~1.0.0", 1145 | "isstream": "~0.1.2", 1146 | "json-stringify-safe": "~5.0.1", 1147 | "mime-types": "~2.1.7", 1148 | "oauth-sign": "~0.8.1", 1149 | "performance-now": "^0.2.0", 1150 | "qs": "~6.4.0", 1151 | "safe-buffer": "^5.0.1", 1152 | "stringstream": "~0.0.4", 1153 | "tough-cookie": "~2.3.0", 1154 | "tunnel-agent": "^0.6.0", 1155 | "uuid": "^3.0.0" 1156 | } 1157 | }, 1158 | "rimraf": { 1159 | "version": "2.6.1", 1160 | "bundled": true, 1161 | "dev": true, 1162 | "requires": { 1163 | "glob": "^7.0.5" 1164 | } 1165 | }, 1166 | "safe-buffer": { 1167 | "version": "5.0.1", 1168 | "bundled": true, 1169 | "dev": true 1170 | }, 1171 | "semver": { 1172 | "version": "5.3.0", 1173 | "bundled": true, 1174 | "dev": true, 1175 | "optional": true 1176 | }, 1177 | "set-blocking": { 1178 | "version": "2.0.0", 1179 | "bundled": true, 1180 | "dev": true, 1181 | "optional": true 1182 | }, 1183 | "signal-exit": { 1184 | "version": "3.0.2", 1185 | "bundled": true, 1186 | "dev": true, 1187 | "optional": true 1188 | }, 1189 | "sntp": { 1190 | "version": "1.0.9", 1191 | "bundled": true, 1192 | "dev": true, 1193 | "optional": true, 1194 | "requires": { 1195 | "hoek": "2.x.x" 1196 | } 1197 | }, 1198 | "sshpk": { 1199 | "version": "1.13.0", 1200 | "bundled": true, 1201 | "dev": true, 1202 | "optional": true, 1203 | "requires": { 1204 | "asn1": "~0.2.3", 1205 | "assert-plus": "^1.0.0", 1206 | "bcrypt-pbkdf": "^1.0.0", 1207 | "dashdash": "^1.12.0", 1208 | "ecc-jsbn": "~0.1.1", 1209 | "getpass": "^0.1.1", 1210 | "jodid25519": "^1.0.0", 1211 | "jsbn": "~0.1.0", 1212 | "tweetnacl": "~0.14.0" 1213 | }, 1214 | "dependencies": { 1215 | "assert-plus": { 1216 | "version": "1.0.0", 1217 | "bundled": true, 1218 | "dev": true, 1219 | "optional": true 1220 | } 1221 | } 1222 | }, 1223 | "string-width": { 1224 | "version": "1.0.2", 1225 | "bundled": true, 1226 | "dev": true, 1227 | "requires": { 1228 | "code-point-at": "^1.0.0", 1229 | "is-fullwidth-code-point": "^1.0.0", 1230 | "strip-ansi": "^3.0.0" 1231 | } 1232 | }, 1233 | "string_decoder": { 1234 | "version": "1.0.1", 1235 | "bundled": true, 1236 | "dev": true, 1237 | "requires": { 1238 | "safe-buffer": "^5.0.1" 1239 | } 1240 | }, 1241 | "stringstream": { 1242 | "version": "0.0.5", 1243 | "bundled": true, 1244 | "dev": true, 1245 | "optional": true 1246 | }, 1247 | "strip-ansi": { 1248 | "version": "3.0.1", 1249 | "bundled": true, 1250 | "dev": true, 1251 | "requires": { 1252 | "ansi-regex": "^2.0.0" 1253 | } 1254 | }, 1255 | "strip-json-comments": { 1256 | "version": "2.0.1", 1257 | "bundled": true, 1258 | "dev": true, 1259 | "optional": true 1260 | }, 1261 | "tar": { 1262 | "version": "2.2.1", 1263 | "bundled": true, 1264 | "dev": true, 1265 | "requires": { 1266 | "block-stream": "*", 1267 | "fstream": "^1.0.2", 1268 | "inherits": "2" 1269 | } 1270 | }, 1271 | "tar-pack": { 1272 | "version": "3.4.0", 1273 | "bundled": true, 1274 | "dev": true, 1275 | "optional": true, 1276 | "requires": { 1277 | "debug": "^2.2.0", 1278 | "fstream": "^1.0.10", 1279 | "fstream-ignore": "^1.0.5", 1280 | "once": "^1.3.3", 1281 | "readable-stream": "^2.1.4", 1282 | "rimraf": "^2.5.1", 1283 | "tar": "^2.2.1", 1284 | "uid-number": "^0.0.6" 1285 | } 1286 | }, 1287 | "tough-cookie": { 1288 | "version": "2.3.2", 1289 | "bundled": true, 1290 | "dev": true, 1291 | "optional": true, 1292 | "requires": { 1293 | "punycode": "^1.4.1" 1294 | } 1295 | }, 1296 | "tunnel-agent": { 1297 | "version": "0.6.0", 1298 | "bundled": true, 1299 | "dev": true, 1300 | "optional": true, 1301 | "requires": { 1302 | "safe-buffer": "^5.0.1" 1303 | } 1304 | }, 1305 | "tweetnacl": { 1306 | "version": "0.14.5", 1307 | "bundled": true, 1308 | "dev": true, 1309 | "optional": true 1310 | }, 1311 | "uid-number": { 1312 | "version": "0.0.6", 1313 | "bundled": true, 1314 | "dev": true, 1315 | "optional": true 1316 | }, 1317 | "util-deprecate": { 1318 | "version": "1.0.2", 1319 | "bundled": true, 1320 | "dev": true 1321 | }, 1322 | "uuid": { 1323 | "version": "3.0.1", 1324 | "bundled": true, 1325 | "dev": true, 1326 | "optional": true 1327 | }, 1328 | "verror": { 1329 | "version": "1.3.6", 1330 | "bundled": true, 1331 | "dev": true, 1332 | "optional": true, 1333 | "requires": { 1334 | "extsprintf": "1.0.2" 1335 | } 1336 | }, 1337 | "wide-align": { 1338 | "version": "1.1.2", 1339 | "bundled": true, 1340 | "dev": true, 1341 | "optional": true, 1342 | "requires": { 1343 | "string-width": "^1.0.2" 1344 | } 1345 | }, 1346 | "wrappy": { 1347 | "version": "1.0.2", 1348 | "bundled": true, 1349 | "dev": true 1350 | } 1351 | } 1352 | }, 1353 | "get-stream": { 1354 | "version": "3.0.0", 1355 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 1356 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", 1357 | "dev": true 1358 | }, 1359 | "glob-base": { 1360 | "version": "0.3.0", 1361 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 1362 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 1363 | "dev": true, 1364 | "requires": { 1365 | "glob-parent": "^2.0.0", 1366 | "is-glob": "^2.0.0" 1367 | } 1368 | }, 1369 | "glob-parent": { 1370 | "version": "2.0.0", 1371 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 1372 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 1373 | "dev": true, 1374 | "requires": { 1375 | "is-glob": "^2.0.0" 1376 | } 1377 | }, 1378 | "got": { 1379 | "version": "6.7.1", 1380 | "resolved": "https://registry.npmjs.org/got/-/got-6.7.1.tgz", 1381 | "integrity": "sha1-JAzQV4WpoY5WHcG0S0HHY+8ejbA=", 1382 | "dev": true, 1383 | "requires": { 1384 | "create-error-class": "^3.0.0", 1385 | "duplexer3": "^0.1.4", 1386 | "get-stream": "^3.0.0", 1387 | "is-redirect": "^1.0.0", 1388 | "is-retry-allowed": "^1.0.0", 1389 | "is-stream": "^1.0.0", 1390 | "lowercase-keys": "^1.0.0", 1391 | "safe-buffer": "^5.0.1", 1392 | "timed-out": "^4.0.0", 1393 | "unzip-response": "^2.0.1", 1394 | "url-parse-lax": "^1.0.0" 1395 | } 1396 | }, 1397 | "graceful-fs": { 1398 | "version": "4.1.11", 1399 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 1400 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 1401 | "dev": true 1402 | }, 1403 | "has-ansi": { 1404 | "version": "2.0.0", 1405 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 1406 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 1407 | "dev": true, 1408 | "requires": { 1409 | "ansi-regex": "^2.0.0" 1410 | }, 1411 | "dependencies": { 1412 | "ansi-regex": { 1413 | "version": "2.1.1", 1414 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 1415 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 1416 | "dev": true 1417 | } 1418 | } 1419 | }, 1420 | "has-flag": { 1421 | "version": "2.0.0", 1422 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 1423 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 1424 | "dev": true 1425 | }, 1426 | "ignore-by-default": { 1427 | "version": "1.0.1", 1428 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1429 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1430 | "dev": true 1431 | }, 1432 | "import-lazy": { 1433 | "version": "2.1.0", 1434 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 1435 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 1436 | "dev": true 1437 | }, 1438 | "imurmurhash": { 1439 | "version": "0.1.4", 1440 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1441 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1442 | "dev": true 1443 | }, 1444 | "inherits": { 1445 | "version": "2.0.3", 1446 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1447 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1448 | "dev": true 1449 | }, 1450 | "ini": { 1451 | "version": "1.3.4", 1452 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.4.tgz", 1453 | "integrity": "sha1-BTfLedr1m1mhpRff9wbIbsA5Fi4=", 1454 | "dev": true 1455 | }, 1456 | "is-binary-path": { 1457 | "version": "1.0.1", 1458 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 1459 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 1460 | "dev": true, 1461 | "requires": { 1462 | "binary-extensions": "^1.0.0" 1463 | } 1464 | }, 1465 | "is-buffer": { 1466 | "version": "1.1.5", 1467 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.5.tgz", 1468 | "integrity": "sha1-Hzsm72E7IUuIy8ojzGwB2Hlh7sw=", 1469 | "dev": true 1470 | }, 1471 | "is-dotfile": { 1472 | "version": "1.0.3", 1473 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 1474 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", 1475 | "dev": true 1476 | }, 1477 | "is-equal-shallow": { 1478 | "version": "0.1.3", 1479 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 1480 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 1481 | "dev": true, 1482 | "requires": { 1483 | "is-primitive": "^2.0.0" 1484 | } 1485 | }, 1486 | "is-extendable": { 1487 | "version": "0.1.1", 1488 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1489 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1490 | "dev": true 1491 | }, 1492 | "is-extglob": { 1493 | "version": "1.0.0", 1494 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 1495 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 1496 | "dev": true 1497 | }, 1498 | "is-fullwidth-code-point": { 1499 | "version": "2.0.0", 1500 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1501 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1502 | "dev": true 1503 | }, 1504 | "is-glob": { 1505 | "version": "2.0.1", 1506 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 1507 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 1508 | "dev": true, 1509 | "requires": { 1510 | "is-extglob": "^1.0.0" 1511 | } 1512 | }, 1513 | "is-npm": { 1514 | "version": "1.0.0", 1515 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-1.0.0.tgz", 1516 | "integrity": "sha1-8vtjpl5JBbQGyGBydloaTceTufQ=", 1517 | "dev": true 1518 | }, 1519 | "is-number": { 1520 | "version": "2.1.0", 1521 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 1522 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 1523 | "dev": true, 1524 | "requires": { 1525 | "kind-of": "^3.0.2" 1526 | } 1527 | }, 1528 | "is-obj": { 1529 | "version": "1.0.1", 1530 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", 1531 | "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=", 1532 | "dev": true 1533 | }, 1534 | "is-posix-bracket": { 1535 | "version": "0.1.1", 1536 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 1537 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", 1538 | "dev": true 1539 | }, 1540 | "is-primitive": { 1541 | "version": "2.0.0", 1542 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 1543 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", 1544 | "dev": true 1545 | }, 1546 | "is-redirect": { 1547 | "version": "1.0.0", 1548 | "resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz", 1549 | "integrity": "sha1-HQPd7VO9jbDzDCbk+V02/HyH3CQ=", 1550 | "dev": true 1551 | }, 1552 | "is-retry-allowed": { 1553 | "version": "1.1.0", 1554 | "resolved": "https://registry.npmjs.org/is-retry-allowed/-/is-retry-allowed-1.1.0.tgz", 1555 | "integrity": "sha1-EaBgVotnM5REAz0BJaYaINVk+zQ=", 1556 | "dev": true 1557 | }, 1558 | "is-stream": { 1559 | "version": "1.1.0", 1560 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1561 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 1562 | "dev": true 1563 | }, 1564 | "isarray": { 1565 | "version": "1.0.0", 1566 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1567 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1568 | "dev": true 1569 | }, 1570 | "isexe": { 1571 | "version": "2.0.0", 1572 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1573 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1574 | "dev": true 1575 | }, 1576 | "isobject": { 1577 | "version": "2.1.0", 1578 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 1579 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 1580 | "dev": true, 1581 | "requires": { 1582 | "isarray": "1.0.0" 1583 | } 1584 | }, 1585 | "kind-of": { 1586 | "version": "3.2.2", 1587 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1588 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1589 | "dev": true, 1590 | "requires": { 1591 | "is-buffer": "^1.1.5" 1592 | } 1593 | }, 1594 | "latest-version": { 1595 | "version": "3.1.0", 1596 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-3.1.0.tgz", 1597 | "integrity": "sha1-ogU4P+oyKzO1rjsYq+4NwvNW7hU=", 1598 | "dev": true, 1599 | "requires": { 1600 | "package-json": "^4.0.0" 1601 | } 1602 | }, 1603 | "lodash._baseassign": { 1604 | "version": "3.2.0", 1605 | "resolved": "https://registry.npmjs.org/lodash._baseassign/-/lodash._baseassign-3.2.0.tgz", 1606 | "integrity": "sha1-jDigmVAPIVrQnlnxci/QxSv+Ck4=", 1607 | "dev": true, 1608 | "requires": { 1609 | "lodash._basecopy": "^3.0.0", 1610 | "lodash.keys": "^3.0.0" 1611 | } 1612 | }, 1613 | "lodash._basecopy": { 1614 | "version": "3.0.1", 1615 | "resolved": "https://registry.npmjs.org/lodash._basecopy/-/lodash._basecopy-3.0.1.tgz", 1616 | "integrity": "sha1-jaDmqHbPNEwK2KVIghEd08XHyjY=", 1617 | "dev": true 1618 | }, 1619 | "lodash._bindcallback": { 1620 | "version": "3.0.1", 1621 | "resolved": "https://registry.npmjs.org/lodash._bindcallback/-/lodash._bindcallback-3.0.1.tgz", 1622 | "integrity": "sha1-5THCdkTPi1epnhftlbNcdIeJOS4=", 1623 | "dev": true 1624 | }, 1625 | "lodash._createassigner": { 1626 | "version": "3.1.1", 1627 | "resolved": "https://registry.npmjs.org/lodash._createassigner/-/lodash._createassigner-3.1.1.tgz", 1628 | "integrity": "sha1-g4pbri/aymOsIt7o4Z+k5taXCxE=", 1629 | "dev": true, 1630 | "requires": { 1631 | "lodash._bindcallback": "^3.0.0", 1632 | "lodash._isiterateecall": "^3.0.0", 1633 | "lodash.restparam": "^3.0.0" 1634 | } 1635 | }, 1636 | "lodash._getnative": { 1637 | "version": "3.9.1", 1638 | "resolved": "https://registry.npmjs.org/lodash._getnative/-/lodash._getnative-3.9.1.tgz", 1639 | "integrity": "sha1-VwvH3t5G1hzc3mh9ZdPuy6o6r/U=", 1640 | "dev": true 1641 | }, 1642 | "lodash._isiterateecall": { 1643 | "version": "3.0.9", 1644 | "resolved": "https://registry.npmjs.org/lodash._isiterateecall/-/lodash._isiterateecall-3.0.9.tgz", 1645 | "integrity": "sha1-UgOte6Ql+uhCRg5pbbnPPmqsBXw=", 1646 | "dev": true 1647 | }, 1648 | "lodash.assign": { 1649 | "version": "3.2.0", 1650 | "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-3.2.0.tgz", 1651 | "integrity": "sha1-POnwI0tLIiPilrj6CsH+6OvKZPo=", 1652 | "dev": true, 1653 | "requires": { 1654 | "lodash._baseassign": "^3.0.0", 1655 | "lodash._createassigner": "^3.0.0", 1656 | "lodash.keys": "^3.0.0" 1657 | } 1658 | }, 1659 | "lodash.defaults": { 1660 | "version": "3.1.2", 1661 | "resolved": "https://registry.npmjs.org/lodash.defaults/-/lodash.defaults-3.1.2.tgz", 1662 | "integrity": "sha1-xzCLGNv4vJNy1wGnNJPGEZK9Liw=", 1663 | "dev": true, 1664 | "requires": { 1665 | "lodash.assign": "^3.0.0", 1666 | "lodash.restparam": "^3.0.0" 1667 | } 1668 | }, 1669 | "lodash.isarguments": { 1670 | "version": "3.1.0", 1671 | "resolved": "https://registry.npmjs.org/lodash.isarguments/-/lodash.isarguments-3.1.0.tgz", 1672 | "integrity": "sha1-L1c9hcaiQon/AGY7SRwdM4/zRYo=", 1673 | "dev": true 1674 | }, 1675 | "lodash.isarray": { 1676 | "version": "3.0.4", 1677 | "resolved": "https://registry.npmjs.org/lodash.isarray/-/lodash.isarray-3.0.4.tgz", 1678 | "integrity": "sha1-eeTriMNqgSKvhvhEqpvNhRtfu1U=", 1679 | "dev": true 1680 | }, 1681 | "lodash.keys": { 1682 | "version": "3.1.2", 1683 | "resolved": "https://registry.npmjs.org/lodash.keys/-/lodash.keys-3.1.2.tgz", 1684 | "integrity": "sha1-TbwEcrFWvlCgsoaFXRvQsMZWCYo=", 1685 | "dev": true, 1686 | "requires": { 1687 | "lodash._getnative": "^3.0.0", 1688 | "lodash.isarguments": "^3.0.0", 1689 | "lodash.isarray": "^3.0.0" 1690 | } 1691 | }, 1692 | "lodash.restparam": { 1693 | "version": "3.6.1", 1694 | "resolved": "https://registry.npmjs.org/lodash.restparam/-/lodash.restparam-3.6.1.tgz", 1695 | "integrity": "sha1-k2pOMJ7zMKdkXtQUWYbIWuWyCAU=", 1696 | "dev": true 1697 | }, 1698 | "lowercase-keys": { 1699 | "version": "1.0.0", 1700 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.0.tgz", 1701 | "integrity": "sha1-TjNms55/VFfjXxMkvfb4jQv8cwY=", 1702 | "dev": true 1703 | }, 1704 | "lru-cache": { 1705 | "version": "4.1.1", 1706 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", 1707 | "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", 1708 | "dev": true, 1709 | "requires": { 1710 | "pseudomap": "^1.0.2", 1711 | "yallist": "^2.1.2" 1712 | } 1713 | }, 1714 | "make-dir": { 1715 | "version": "1.0.0", 1716 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.0.0.tgz", 1717 | "integrity": "sha1-l6ARdR6R3YfPre9Ygy67BJNt6Xg=", 1718 | "dev": true, 1719 | "requires": { 1720 | "pify": "^2.3.0" 1721 | } 1722 | }, 1723 | "make-error": { 1724 | "version": "1.3.0", 1725 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.0.tgz", 1726 | "integrity": "sha1-Uq06M5zPEM5itAQLcI/nByRLi5Y=", 1727 | "dev": true 1728 | }, 1729 | "map-stream": { 1730 | "version": "0.1.0", 1731 | "resolved": "https://registry.npmjs.org/map-stream/-/map-stream-0.1.0.tgz", 1732 | "integrity": "sha1-5WqpTEyAVaFkBKBnS3jyFffI4ZQ=", 1733 | "dev": true 1734 | }, 1735 | "micromatch": { 1736 | "version": "2.3.11", 1737 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 1738 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 1739 | "dev": true, 1740 | "requires": { 1741 | "arr-diff": "^2.0.0", 1742 | "array-unique": "^0.2.1", 1743 | "braces": "^1.8.2", 1744 | "expand-brackets": "^0.1.4", 1745 | "extglob": "^0.3.1", 1746 | "filename-regex": "^2.0.0", 1747 | "is-extglob": "^1.0.0", 1748 | "is-glob": "^2.0.1", 1749 | "kind-of": "^3.0.2", 1750 | "normalize-path": "^2.0.1", 1751 | "object.omit": "^2.0.0", 1752 | "parse-glob": "^3.0.4", 1753 | "regex-cache": "^0.4.2" 1754 | } 1755 | }, 1756 | "minimatch": { 1757 | "version": "3.0.4", 1758 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1759 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1760 | "dev": true, 1761 | "requires": { 1762 | "brace-expansion": "^1.1.7" 1763 | } 1764 | }, 1765 | "minimist": { 1766 | "version": "1.2.0", 1767 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1768 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1769 | "dev": true 1770 | }, 1771 | "mkdirp": { 1772 | "version": "0.5.1", 1773 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1774 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1775 | "dev": true, 1776 | "requires": { 1777 | "minimist": "0.0.8" 1778 | }, 1779 | "dependencies": { 1780 | "minimist": { 1781 | "version": "0.0.8", 1782 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1783 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1784 | "dev": true 1785 | } 1786 | } 1787 | }, 1788 | "ms": { 1789 | "version": "2.0.0", 1790 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1791 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1792 | "dev": true 1793 | }, 1794 | "nan": { 1795 | "version": "2.7.0", 1796 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.7.0.tgz", 1797 | "integrity": "sha1-2Vv3IeyHfgjbJ27T/G63j5CDrUY=", 1798 | "dev": true, 1799 | "optional": true 1800 | }, 1801 | "ncp": { 1802 | "version": "0.2.6", 1803 | "resolved": "https://registry.npmjs.org/ncp/-/ncp-0.2.6.tgz", 1804 | "integrity": "sha1-h/WnWH41RU6l+XeiF45uvqturwE=", 1805 | "dev": true 1806 | }, 1807 | "nodemon": { 1808 | "version": "1.12.0", 1809 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-1.12.0.tgz", 1810 | "integrity": "sha1-5ThUindzQKGfhVxPCHt+Uoqj/to=", 1811 | "dev": true, 1812 | "requires": { 1813 | "chokidar": "^1.7.0", 1814 | "debug": "^2.6.8", 1815 | "es6-promise": "^3.3.1", 1816 | "ignore-by-default": "^1.0.1", 1817 | "lodash.defaults": "^3.1.2", 1818 | "minimatch": "^3.0.4", 1819 | "ps-tree": "^1.1.0", 1820 | "touch": "^3.1.0", 1821 | "undefsafe": "0.0.3", 1822 | "update-notifier": "^2.2.0" 1823 | } 1824 | }, 1825 | "nopt": { 1826 | "version": "1.0.10", 1827 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1828 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1829 | "dev": true, 1830 | "requires": { 1831 | "abbrev": "1" 1832 | } 1833 | }, 1834 | "normalize-path": { 1835 | "version": "2.1.1", 1836 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1837 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1838 | "dev": true, 1839 | "requires": { 1840 | "remove-trailing-separator": "^1.0.1" 1841 | } 1842 | }, 1843 | "npm-run-path": { 1844 | "version": "2.0.2", 1845 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1846 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1847 | "dev": true, 1848 | "requires": { 1849 | "path-key": "^2.0.0" 1850 | } 1851 | }, 1852 | "number-is-nan": { 1853 | "version": "1.0.1", 1854 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1855 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 1856 | "dev": true 1857 | }, 1858 | "object.omit": { 1859 | "version": "2.0.1", 1860 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 1861 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 1862 | "dev": true, 1863 | "requires": { 1864 | "for-own": "^0.1.4", 1865 | "is-extendable": "^0.1.1" 1866 | } 1867 | }, 1868 | "p-finally": { 1869 | "version": "1.0.0", 1870 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1871 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 1872 | "dev": true 1873 | }, 1874 | "package-json": { 1875 | "version": "4.0.1", 1876 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-4.0.1.tgz", 1877 | "integrity": "sha1-iGmgQBJTZhxMTKPabCEh7VVfXu0=", 1878 | "dev": true, 1879 | "requires": { 1880 | "got": "^6.7.1", 1881 | "registry-auth-token": "^3.0.1", 1882 | "registry-url": "^3.0.3", 1883 | "semver": "^5.1.0" 1884 | } 1885 | }, 1886 | "parse-glob": { 1887 | "version": "3.0.4", 1888 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 1889 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 1890 | "dev": true, 1891 | "requires": { 1892 | "glob-base": "^0.3.0", 1893 | "is-dotfile": "^1.0.0", 1894 | "is-extglob": "^1.0.0", 1895 | "is-glob": "^2.0.0" 1896 | } 1897 | }, 1898 | "path-is-absolute": { 1899 | "version": "1.0.1", 1900 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1901 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1902 | "dev": true 1903 | }, 1904 | "path-key": { 1905 | "version": "2.0.1", 1906 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1907 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1908 | "dev": true 1909 | }, 1910 | "pause-stream": { 1911 | "version": "0.0.11", 1912 | "resolved": "https://registry.npmjs.org/pause-stream/-/pause-stream-0.0.11.tgz", 1913 | "integrity": "sha1-/lo0sMvOErWqaitAPuLnO2AvFEU=", 1914 | "dev": true, 1915 | "requires": { 1916 | "through": "~2.3" 1917 | } 1918 | }, 1919 | "pify": { 1920 | "version": "2.3.0", 1921 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1922 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1923 | "dev": true 1924 | }, 1925 | "prepend-http": { 1926 | "version": "1.0.4", 1927 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", 1928 | "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", 1929 | "dev": true 1930 | }, 1931 | "preserve": { 1932 | "version": "0.2.0", 1933 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 1934 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", 1935 | "dev": true 1936 | }, 1937 | "process-nextick-args": { 1938 | "version": "1.0.7", 1939 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 1940 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", 1941 | "dev": true 1942 | }, 1943 | "ps-tree": { 1944 | "version": "1.1.0", 1945 | "resolved": "https://registry.npmjs.org/ps-tree/-/ps-tree-1.1.0.tgz", 1946 | "integrity": "sha1-tCGyQUDWID8e08dplrRCewjowBQ=", 1947 | "dev": true, 1948 | "requires": { 1949 | "event-stream": "~3.3.0" 1950 | } 1951 | }, 1952 | "pseudomap": { 1953 | "version": "1.0.2", 1954 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1955 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 1956 | "dev": true 1957 | }, 1958 | "randomatic": { 1959 | "version": "1.1.7", 1960 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", 1961 | "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", 1962 | "dev": true, 1963 | "requires": { 1964 | "is-number": "^3.0.0", 1965 | "kind-of": "^4.0.0" 1966 | }, 1967 | "dependencies": { 1968 | "is-number": { 1969 | "version": "3.0.0", 1970 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 1971 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 1972 | "dev": true, 1973 | "requires": { 1974 | "kind-of": "^3.0.2" 1975 | }, 1976 | "dependencies": { 1977 | "kind-of": { 1978 | "version": "3.2.2", 1979 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1980 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1981 | "dev": true, 1982 | "requires": { 1983 | "is-buffer": "^1.1.5" 1984 | } 1985 | } 1986 | } 1987 | }, 1988 | "kind-of": { 1989 | "version": "4.0.0", 1990 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 1991 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 1992 | "dev": true, 1993 | "requires": { 1994 | "is-buffer": "^1.1.5" 1995 | } 1996 | } 1997 | } 1998 | }, 1999 | "rc": { 2000 | "version": "1.2.1", 2001 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.1.tgz", 2002 | "integrity": "sha1-LgPo5C7kULjLPc5lvhv4l04d/ZU=", 2003 | "dev": true, 2004 | "requires": { 2005 | "deep-extend": "~0.4.0", 2006 | "ini": "~1.3.0", 2007 | "minimist": "^1.2.0", 2008 | "strip-json-comments": "~2.0.1" 2009 | } 2010 | }, 2011 | "readable-stream": { 2012 | "version": "2.3.3", 2013 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 2014 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 2015 | "dev": true, 2016 | "requires": { 2017 | "core-util-is": "~1.0.0", 2018 | "inherits": "~2.0.3", 2019 | "isarray": "~1.0.0", 2020 | "process-nextick-args": "~1.0.6", 2021 | "safe-buffer": "~5.1.1", 2022 | "string_decoder": "~1.0.3", 2023 | "util-deprecate": "~1.0.1" 2024 | } 2025 | }, 2026 | "readdirp": { 2027 | "version": "2.1.0", 2028 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", 2029 | "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", 2030 | "dev": true, 2031 | "requires": { 2032 | "graceful-fs": "^4.1.2", 2033 | "minimatch": "^3.0.2", 2034 | "readable-stream": "^2.0.2", 2035 | "set-immediate-shim": "^1.0.1" 2036 | } 2037 | }, 2038 | "regex-cache": { 2039 | "version": "0.4.4", 2040 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 2041 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 2042 | "dev": true, 2043 | "requires": { 2044 | "is-equal-shallow": "^0.1.3" 2045 | } 2046 | }, 2047 | "registry-auth-token": { 2048 | "version": "3.3.1", 2049 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-3.3.1.tgz", 2050 | "integrity": "sha1-+w0yie4Nmtosu1KvXf5mywcNMAY=", 2051 | "dev": true, 2052 | "requires": { 2053 | "rc": "^1.1.6", 2054 | "safe-buffer": "^5.0.1" 2055 | } 2056 | }, 2057 | "registry-url": { 2058 | "version": "3.1.0", 2059 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-3.1.0.tgz", 2060 | "integrity": "sha1-PU74cPc93h138M+aOBQyRE4XSUI=", 2061 | "dev": true, 2062 | "requires": { 2063 | "rc": "^1.0.1" 2064 | } 2065 | }, 2066 | "remove-trailing-separator": { 2067 | "version": "1.1.0", 2068 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2069 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2070 | "dev": true 2071 | }, 2072 | "repeat-element": { 2073 | "version": "1.1.2", 2074 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 2075 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", 2076 | "dev": true 2077 | }, 2078 | "repeat-string": { 2079 | "version": "1.6.1", 2080 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2081 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2082 | "dev": true 2083 | }, 2084 | "safe-buffer": { 2085 | "version": "5.1.1", 2086 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 2087 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", 2088 | "dev": true 2089 | }, 2090 | "semver": { 2091 | "version": "5.4.1", 2092 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", 2093 | "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==", 2094 | "dev": true 2095 | }, 2096 | "semver-diff": { 2097 | "version": "2.1.0", 2098 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-2.1.0.tgz", 2099 | "integrity": "sha1-S7uEN8jTfksM8aaP1ybsbWRdbTY=", 2100 | "dev": true, 2101 | "requires": { 2102 | "semver": "^5.0.3" 2103 | } 2104 | }, 2105 | "set-immediate-shim": { 2106 | "version": "1.0.1", 2107 | "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", 2108 | "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", 2109 | "dev": true 2110 | }, 2111 | "shebang-command": { 2112 | "version": "1.2.0", 2113 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2114 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2115 | "dev": true, 2116 | "requires": { 2117 | "shebang-regex": "^1.0.0" 2118 | } 2119 | }, 2120 | "shebang-regex": { 2121 | "version": "1.0.0", 2122 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2123 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2124 | "dev": true 2125 | }, 2126 | "signal-exit": { 2127 | "version": "3.0.2", 2128 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2129 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2130 | "dev": true 2131 | }, 2132 | "source-map": { 2133 | "version": "0.5.7", 2134 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2135 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2136 | "dev": true 2137 | }, 2138 | "source-map-support": { 2139 | "version": "0.4.17", 2140 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.17.tgz", 2141 | "integrity": "sha512-30c1Ch8FSjV0FwC253iftbbj0dU/OXoSg1LAEGZJUlGgjTNj6cu+DVqJWWIZJY5RXLWV4eFtR+4ouo0VIOYOTg==", 2142 | "dev": true, 2143 | "requires": { 2144 | "source-map": "^0.5.6" 2145 | } 2146 | }, 2147 | "split": { 2148 | "version": "0.3.3", 2149 | "resolved": "https://registry.npmjs.org/split/-/split-0.3.3.tgz", 2150 | "integrity": "sha1-zQ7qXmOiEd//frDwkcQTPi0N0o8=", 2151 | "dev": true, 2152 | "requires": { 2153 | "through": "2" 2154 | } 2155 | }, 2156 | "stream-combiner": { 2157 | "version": "0.0.4", 2158 | "resolved": "https://registry.npmjs.org/stream-combiner/-/stream-combiner-0.0.4.tgz", 2159 | "integrity": "sha1-TV5DPBhSYd3mI8o/RMWGvPXErRQ=", 2160 | "dev": true, 2161 | "requires": { 2162 | "duplexer": "~0.1.1" 2163 | } 2164 | }, 2165 | "string-width": { 2166 | "version": "2.1.1", 2167 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2168 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2169 | "dev": true, 2170 | "requires": { 2171 | "is-fullwidth-code-point": "^2.0.0", 2172 | "strip-ansi": "^4.0.0" 2173 | } 2174 | }, 2175 | "string_decoder": { 2176 | "version": "1.0.3", 2177 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 2178 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 2179 | "dev": true, 2180 | "requires": { 2181 | "safe-buffer": "~5.1.0" 2182 | } 2183 | }, 2184 | "strip-ansi": { 2185 | "version": "4.0.0", 2186 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2187 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2188 | "dev": true, 2189 | "requires": { 2190 | "ansi-regex": "^3.0.0" 2191 | } 2192 | }, 2193 | "strip-bom": { 2194 | "version": "3.0.0", 2195 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2196 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2197 | "dev": true 2198 | }, 2199 | "strip-eof": { 2200 | "version": "1.0.0", 2201 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 2202 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 2203 | "dev": true 2204 | }, 2205 | "strip-json-comments": { 2206 | "version": "2.0.1", 2207 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2208 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2209 | "dev": true 2210 | }, 2211 | "supports-color": { 2212 | "version": "4.4.0", 2213 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.4.0.tgz", 2214 | "integrity": "sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ==", 2215 | "dev": true, 2216 | "requires": { 2217 | "has-flag": "^2.0.0" 2218 | } 2219 | }, 2220 | "synaptic": { 2221 | "version": "1.1.4", 2222 | "resolved": "https://registry.npmjs.org/synaptic/-/synaptic-1.1.4.tgz", 2223 | "integrity": "sha512-JFtU98VDFI0uBTowgySo+UUEkc7rSVHaxx9D6dR5BK6u81G7uAxcp32Gi2SHciLpFbvJVd1Pfz7aqSNQO4EH9Q==" 2224 | }, 2225 | "term-size": { 2226 | "version": "1.2.0", 2227 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-1.2.0.tgz", 2228 | "integrity": "sha1-RYuDiH8oj8Vtb/+/rSYuJmOO+mk=", 2229 | "dev": true, 2230 | "requires": { 2231 | "execa": "^0.7.0" 2232 | } 2233 | }, 2234 | "through": { 2235 | "version": "2.3.8", 2236 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2237 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2238 | "dev": true 2239 | }, 2240 | "timed-out": { 2241 | "version": "4.0.1", 2242 | "resolved": "https://registry.npmjs.org/timed-out/-/timed-out-4.0.1.tgz", 2243 | "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=", 2244 | "dev": true 2245 | }, 2246 | "touch": { 2247 | "version": "3.1.0", 2248 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2249 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2250 | "dev": true, 2251 | "requires": { 2252 | "nopt": "~1.0.10" 2253 | } 2254 | }, 2255 | "ts-node": { 2256 | "version": "3.3.0", 2257 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-3.3.0.tgz", 2258 | "integrity": "sha1-wTxqMCTjC+EYDdUwOPwgkonUv2k=", 2259 | "dev": true, 2260 | "requires": { 2261 | "arrify": "^1.0.0", 2262 | "chalk": "^2.0.0", 2263 | "diff": "^3.1.0", 2264 | "make-error": "^1.1.1", 2265 | "minimist": "^1.2.0", 2266 | "mkdirp": "^0.5.1", 2267 | "source-map-support": "^0.4.0", 2268 | "tsconfig": "^6.0.0", 2269 | "v8flags": "^3.0.0", 2270 | "yn": "^2.0.0" 2271 | }, 2272 | "dependencies": { 2273 | "chalk": { 2274 | "version": "2.1.0", 2275 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.1.0.tgz", 2276 | "integrity": "sha512-LUHGS/dge4ujbXMJrnihYMcL4AoOweGnw9Tp3kQuqy1Kx5c1qKjqvMJZ6nVJPMWJtKCTN72ZogH3oeSO9g9rXQ==", 2277 | "dev": true, 2278 | "requires": { 2279 | "ansi-styles": "^3.1.0", 2280 | "escape-string-regexp": "^1.0.5", 2281 | "supports-color": "^4.0.0" 2282 | } 2283 | } 2284 | } 2285 | }, 2286 | "tsconfig": { 2287 | "version": "6.0.0", 2288 | "resolved": "https://registry.npmjs.org/tsconfig/-/tsconfig-6.0.0.tgz", 2289 | "integrity": "sha1-aw6DdgA9evGGT434+J3QBZ/80DI=", 2290 | "dev": true, 2291 | "requires": { 2292 | "strip-bom": "^3.0.0", 2293 | "strip-json-comments": "^2.0.0" 2294 | } 2295 | }, 2296 | "typescript": { 2297 | "version": "2.5.2", 2298 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-2.5.2.tgz", 2299 | "integrity": "sha1-A4qV99m7tCCxvzW6MdTFwd0//jQ=", 2300 | "dev": true 2301 | }, 2302 | "typescript-watcher": { 2303 | "version": "0.0.4", 2304 | "resolved": "https://registry.npmjs.org/typescript-watcher/-/typescript-watcher-0.0.4.tgz", 2305 | "integrity": "sha1-z2Sb+60/K/rI40PWC4PTc4fh1+M=", 2306 | "dev": true, 2307 | "requires": { 2308 | "argumentum": "0.6.0", 2309 | "chokidar": "0.4.0", 2310 | "mkdirp": "0.3.4", 2311 | "ncp": "0.2.6", 2312 | "typescript": "0.8.0", 2313 | "typescript-wrapper": "0.8.0" 2314 | }, 2315 | "dependencies": { 2316 | "chokidar": { 2317 | "version": "0.4.0", 2318 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-0.4.0.tgz", 2319 | "integrity": "sha1-TYFkyCiLkwti5/FRWjfhRjKdJtM=", 2320 | "dev": true 2321 | }, 2322 | "mkdirp": { 2323 | "version": "0.3.4", 2324 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.4.tgz", 2325 | "integrity": "sha1-+MgdITtymaAx8ZOlfXUqF9L2x9g=", 2326 | "dev": true 2327 | }, 2328 | "typescript": { 2329 | "version": "0.8.0", 2330 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-0.8.0.tgz", 2331 | "integrity": "sha1-4XJdDr1Hbu1sOP2gf99pQuDyKgo=", 2332 | "dev": true 2333 | } 2334 | } 2335 | }, 2336 | "typescript-wrapper": { 2337 | "version": "0.8.0", 2338 | "resolved": "https://registry.npmjs.org/typescript-wrapper/-/typescript-wrapper-0.8.0.tgz", 2339 | "integrity": "sha1-QihLrMymbALBAdrGa+ZJVD+vroc=", 2340 | "dev": true, 2341 | "requires": { 2342 | "typescript": "0.8.0" 2343 | }, 2344 | "dependencies": { 2345 | "typescript": { 2346 | "version": "0.8.0", 2347 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-0.8.0.tgz", 2348 | "integrity": "sha1-4XJdDr1Hbu1sOP2gf99pQuDyKgo=", 2349 | "dev": true 2350 | } 2351 | } 2352 | }, 2353 | "undefsafe": { 2354 | "version": "0.0.3", 2355 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-0.0.3.tgz", 2356 | "integrity": "sha1-7Mo6A+VrmvFzhbqsgSrIO5lKli8=", 2357 | "dev": true 2358 | }, 2359 | "unique-string": { 2360 | "version": "1.0.0", 2361 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-1.0.0.tgz", 2362 | "integrity": "sha1-nhBXzKhRq7kzmPizOuGHuZyuwRo=", 2363 | "dev": true, 2364 | "requires": { 2365 | "crypto-random-string": "^1.0.0" 2366 | } 2367 | }, 2368 | "unzip-response": { 2369 | "version": "2.0.1", 2370 | "resolved": "https://registry.npmjs.org/unzip-response/-/unzip-response-2.0.1.tgz", 2371 | "integrity": "sha1-0vD3N9FrBhXnKmk17QQhRXLVb5c=", 2372 | "dev": true 2373 | }, 2374 | "update-notifier": { 2375 | "version": "2.2.0", 2376 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-2.2.0.tgz", 2377 | "integrity": "sha1-G1g3z5DAc22IYncytmHBOPht5y8=", 2378 | "dev": true, 2379 | "requires": { 2380 | "boxen": "^1.0.0", 2381 | "chalk": "^1.0.0", 2382 | "configstore": "^3.0.0", 2383 | "import-lazy": "^2.1.0", 2384 | "is-npm": "^1.0.0", 2385 | "latest-version": "^3.0.0", 2386 | "semver-diff": "^2.0.0", 2387 | "xdg-basedir": "^3.0.0" 2388 | } 2389 | }, 2390 | "url-parse-lax": { 2391 | "version": "1.0.0", 2392 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-1.0.0.tgz", 2393 | "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=", 2394 | "dev": true, 2395 | "requires": { 2396 | "prepend-http": "^1.0.1" 2397 | } 2398 | }, 2399 | "user-home": { 2400 | "version": "1.1.1", 2401 | "resolved": "https://registry.npmjs.org/user-home/-/user-home-1.1.1.tgz", 2402 | "integrity": "sha1-K1viOjK2Onyd640PKNSFcko98ZA=", 2403 | "dev": true 2404 | }, 2405 | "util-deprecate": { 2406 | "version": "1.0.2", 2407 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2408 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2409 | "dev": true 2410 | }, 2411 | "v8flags": { 2412 | "version": "3.0.0", 2413 | "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.0.0.tgz", 2414 | "integrity": "sha512-AGl+C+4qpeSu2g3JxCD/mGFFOs/vVZ3XREkD3ibQXEqr4Y4zgIrPWW124/IKJFHOIVFIoH8miWrLf0o84HYjwA==", 2415 | "dev": true, 2416 | "requires": { 2417 | "user-home": "^1.1.1" 2418 | } 2419 | }, 2420 | "which": { 2421 | "version": "1.3.0", 2422 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 2423 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 2424 | "dev": true, 2425 | "requires": { 2426 | "isexe": "^2.0.0" 2427 | } 2428 | }, 2429 | "widest-line": { 2430 | "version": "1.0.0", 2431 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-1.0.0.tgz", 2432 | "integrity": "sha1-DAnIXCqUaD0Nfq+O4JfVZL8OEFw=", 2433 | "dev": true, 2434 | "requires": { 2435 | "string-width": "^1.0.1" 2436 | }, 2437 | "dependencies": { 2438 | "ansi-regex": { 2439 | "version": "2.1.1", 2440 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 2441 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 2442 | "dev": true 2443 | }, 2444 | "is-fullwidth-code-point": { 2445 | "version": "1.0.0", 2446 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 2447 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 2448 | "dev": true, 2449 | "requires": { 2450 | "number-is-nan": "^1.0.0" 2451 | } 2452 | }, 2453 | "string-width": { 2454 | "version": "1.0.2", 2455 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 2456 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 2457 | "dev": true, 2458 | "requires": { 2459 | "code-point-at": "^1.0.0", 2460 | "is-fullwidth-code-point": "^1.0.0", 2461 | "strip-ansi": "^3.0.0" 2462 | } 2463 | }, 2464 | "strip-ansi": { 2465 | "version": "3.0.1", 2466 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2467 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2468 | "dev": true, 2469 | "requires": { 2470 | "ansi-regex": "^2.0.0" 2471 | } 2472 | } 2473 | } 2474 | }, 2475 | "write-file-atomic": { 2476 | "version": "2.3.0", 2477 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.3.0.tgz", 2478 | "integrity": "sha512-xuPeK4OdjWqtfi59ylvVL0Yn35SF3zgcAcv7rBPFHVaEapaDr4GdGgm3j7ckTwH9wHL7fGmgfAnb0+THrHb8tA==", 2479 | "dev": true, 2480 | "requires": { 2481 | "graceful-fs": "^4.1.11", 2482 | "imurmurhash": "^0.1.4", 2483 | "signal-exit": "^3.0.2" 2484 | } 2485 | }, 2486 | "xdg-basedir": { 2487 | "version": "3.0.0", 2488 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-3.0.0.tgz", 2489 | "integrity": "sha1-SWsswQnsqNus/i3HK2A8F8WHCtQ=", 2490 | "dev": true 2491 | }, 2492 | "yallist": { 2493 | "version": "2.1.2", 2494 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 2495 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 2496 | "dev": true 2497 | }, 2498 | "yn": { 2499 | "version": "2.0.0", 2500 | "resolved": "https://registry.npmjs.org/yn/-/yn-2.0.0.tgz", 2501 | "integrity": "sha1-5a2ryKz0CPY4X8dklWhMiOavaJo=", 2502 | "dev": true 2503 | } 2504 | } 2505 | } 2506 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "neural-data-normalizer", 3 | "version": "1.1.0", 4 | "description": "Data to bits normalization helpers script to use with neural network.", 5 | "repository": "https://github.com/adadgio/neural-data-normalizer", 6 | "main": "dist/index.js", 7 | "engines": { 8 | "node": ">=6.0.0" 9 | }, 10 | "scripts": { 11 | "start": "node ./dist/index.js", 12 | "test": "node dist/demo.js", 13 | "watch": "npm run build:live", 14 | "build:live": "tsc --watch", 15 | "build": "tsc" 16 | }, 17 | "keywords": [ 18 | "node", 19 | "typescript", 20 | "Neural networks", 21 | "Synaptic.js", 22 | "Data manipulation" 23 | ], 24 | "author": "Romain Bruckert", 25 | "license": "ISC", 26 | "devDependencies": { 27 | "@types/node": "^7.0.0", 28 | "nodemon": "^1.11.0", 29 | "ts-node": "^3.1.0", 30 | "typescript": "^2.4.1", 31 | "typescript-watcher": "^0.0.4" 32 | }, 33 | "dependencies": { 34 | "synaptic": "^1.1.4" 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /src/demo.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Test and examples. 3 | * Notes: does only work if inputs and outputs rows are 4 | * always of the same length. You cant ommit one field in sampleData[2] for instance. 5 | * NULL and empty values are not really handled and can cause bugs, but i guess 6 | * its probably your job to normalize that data before ? 7 | * 8 | * @author Romain Bruckert 9 | */ 10 | import { RowInput, Normalizer } from './normalizer'; 11 | 12 | const sampleData: Array = [ 13 | { "soilhum": 500, "airtemp": 32, "airhum": 18, "water": true, "plants": ["tomatoes", "potatoes"], "tempSpan": [34, 54] }, 14 | { "soilhum": 1050, "airtemp": 40, "airhum": 21, "water": true, "plants": ["potatoes", "asparagus"], "tempSpan": [24, 14] }, 15 | { "soilhum": 300, "airtemp": 100, "airhum": 90, "water": false, "plants": ["asparagus", "tomatoes"], "tempSpan": [56, 4] }, 16 | { "soilhum": 950, "airtemp": 103, "airhum": 26, "water": true, "plants": ["asparagus", "asparagus"], "tempSpan": [123, 2] }, 17 | { "soilhum": 1050, "airtemp": 8, "airhum": 26, "water": true, "plants": ["tomatoes", "tomatoes"], "tempSpan": [67, 12] }, 18 | { "soilhum": 1050, "airtemp": 56, "airhum": 26, "water": true, "plants": ["potatoes", "french fries"], "tempSpan": [8, 45.8] }, 19 | ]; 20 | 21 | const normalizer = new Normalizer(sampleData) 22 | 23 | // setting required options and normalize the data 24 | normalizer.setOutputProperties(['isExpert']) 25 | normalizer.normalize() 26 | 27 | // find useful information about your data 28 | // to pass to your neural network 29 | // check input and output lenghtes 30 | const nbrInputs = normalizer.getInputLength() 31 | const nbrOutputs = normalizer.getOutputLength() 32 | 33 | const metadata = normalizer.getDatasetMetaData() 34 | const inputs = normalizer.getBinaryInputDataset() 35 | const outputs = normalizer.getBinaryOutputDataset() 36 | 37 | console.log('\n', '\x1b[37m\x1b[46m', 'METADATA:', '\x1b[0m') 38 | console.log(metadata) 39 | console.log('\n', '\x1b[37m\x1b[42m', 'INPUT:', '\x1b[0m') 40 | console.log(inputs) 41 | console.log('\n', '\x1b[37m\x1b[44m', 'OUTPUT:', '\x1b[0m') 42 | console.log(outputs) 43 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * @author Romain Bruckert 3 | */ 4 | export * from './loader' 5 | export * from './normalizer' 6 | -------------------------------------------------------------------------------- /src/loader.ts: -------------------------------------------------------------------------------- 1 | import * as fs from 'fs' 2 | 3 | /** 4 | * Load data from local file(s) 5 | * 6 | * @author Romain Bruckert 7 | */ 8 | export class Loader 9 | { 10 | dir: string; 11 | filename: string 12 | 13 | setDataDir(dir: string) 14 | { 15 | this.dir = dir 16 | 17 | return this 18 | } 19 | 20 | fromJsonFile(filename: string) 21 | { 22 | this.filename = filename 23 | 24 | let path = `${this.dir}/${filename}`.replace('//', '/') 25 | let data = fs.readFileSync(path, 'utf8') 26 | 27 | return JSON.parse(data) 28 | } 29 | 30 | fromCsvFile(filepath: string) 31 | { 32 | // @TODO 33 | } 34 | 35 | getTrainedData() 36 | { 37 | const filename = `trained_${this.filename}` 38 | const filepath = `${this.dir}/${filename}`.replace('//', '/') 39 | 40 | const data: string = fs.readFileSync(filepath, 'utf8') 41 | 42 | return JSON.parse(data) 43 | } 44 | 45 | saveTrainedData(data: any) 46 | { 47 | const filename = `trained_${this.filename}` 48 | const filepath = `${this.dir}/${filename}`.replace('//', '/') 49 | 50 | if (typeof data !== 'string') { 51 | data = JSON.stringify(data) 52 | } 53 | 54 | fs.writeFileSync(filepath, data) 55 | } 56 | 57 | dataIsTrained() 58 | { 59 | let filename = `trained_${this.filename}` 60 | let filepath = `${this.dir}/${filename}`.replace('//', '/') 61 | 62 | return fs.existsSync(filepath) 63 | } 64 | } 65 | -------------------------------------------------------------------------------- /src/normalizer.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Convert any input data to bits representation. 3 | * 4 | * @author Romain Bruckert 5 | */ 6 | export type RowInput = { 7 | [prop: string]: string|number|Array|boolean; 8 | }; 9 | 10 | function isArray(input: any) 11 | { 12 | return ( Object.prototype.toString.call(input) === '[object Array]' ) ? true : false; 13 | } 14 | 15 | export class Normalizer 16 | { 17 | private dataset: Array = []; 18 | private datasetMeta: any = null; // training meta data (ranges, min, max, etc) 19 | private binaryInput: Array> = []; 20 | private binaryOutput: Array = []; 21 | private outputProperties: Array = []; 22 | 23 | constructor(data: Array = []) 24 | { 25 | this.dataset = data; 26 | 27 | // prevent empty data input 28 | if (true !== Array.isArray(data)) { 29 | throw new Error('\x1b[37m\x1b[44mNormalizer input data should be an array of rows: [{...}, {...}]\x1b[0m') 30 | } 31 | 32 | // prevent empty data input 33 | if (this.dataset.length <= 0 ) { 34 | throw new Error(`\x1b[37m\x1b[44mNormalizer input data shouldn't be empty\x1b[0m`); 35 | } 36 | 37 | // prevent data rows to contain no properties 38 | if (Object.keys(this.dataset[0]).length <= 0) { 39 | throw new Error(`\x1b[37m\x1b[44mNormalizer input data rows has to contain some properties (only 1st row is checked)\x1b[0m`); 40 | } 41 | } 42 | 43 | getOutputLength() 44 | { 45 | return this.outputProperties.length; 46 | } 47 | 48 | getOutputProperties() 49 | { 50 | return this.outputProperties; 51 | } 52 | 53 | getInputLength() 54 | { 55 | return this.binaryInput[0].length; 56 | } 57 | 58 | getBinaryInputDataset() 59 | { 60 | return this.binaryInput; 61 | } 62 | 63 | getBinaryOutputDataset() 64 | { 65 | return this.binaryOutput; 66 | } 67 | 68 | getDatasetMetaData() 69 | { 70 | return this.datasetMeta; 71 | } 72 | 73 | setDatasetMetaData(metadata: any) 74 | { 75 | this.datasetMeta = metadata; 76 | return this; 77 | } 78 | 79 | convertOutput() 80 | { 81 | const metadata = this.datasetMeta; 82 | } 83 | 84 | normalize() 85 | { 86 | this.datasetMeta = (this.datasetMeta === null) ? this.analyzeMetaData() : this.datasetMeta; 87 | 88 | // now loop through data and convert any data to bits 89 | // depending on data type and known settings of metadata 90 | let binaryInput: Array = []; 91 | let binaryOutput: Array = []; 92 | 93 | for (let i in this.dataset) { 94 | const row = this.dataset[i]; 95 | 96 | let index: number = 0; 97 | let inputBits: any = []; 98 | let outputBits: any = []; 99 | 100 | for (let prop in row) { 101 | // skip output properties, they are not in the input dataset 102 | // start turning all data into bits! 103 | let bitsArr: any; 104 | 105 | const value: any = row[prop]; 106 | const meta = this.datasetMeta[prop]; 107 | 108 | switch (meta.type) { 109 | case 'number': 110 | bitsArr = [this.numToBit(meta.min, meta.max, value)]; // scalar to array of 1 length 111 | break; 112 | case 'boolean': 113 | bitsArr = [this.boolToBit(value)]; // scalar to array of 1 length 114 | break; 115 | case 'string': 116 | bitsArr = this.strToBitsArr(meta.distinctValues, value); 117 | break; 118 | case 'array': 119 | bitsArr = this.arrToBitsArr(meta.distinctValues, value); 120 | break; 121 | default: 122 | 123 | break; 124 | } 125 | 126 | if (this.outputProperties.indexOf(prop) > -1) { 127 | outputBits = outputBits.concat(bitsArr); 128 | } else { 129 | inputBits = inputBits.concat(bitsArr); 130 | } 131 | 132 | index++; 133 | } 134 | 135 | if (inputBits.length > 0) { this.binaryInput.push(inputBits) } 136 | if (outputBits.length > 0) { this.binaryOutput.push(outputBits) } 137 | } 138 | 139 | } 140 | 141 | analyzeMetaData(): any 142 | { 143 | // at this point we know that data is not an empty array and 144 | // that the first row contains at least one property (the others should as well) 145 | 146 | // depending on each data row property, find the values data type using only the first row 147 | const firstRow = this.dataset[0]; 148 | const distinctProps = this.distinctProps(firstRow); 149 | const distinctTypes = this.distinctTypes(firstRow); 150 | 151 | let metadata = {}; 152 | let bitDataset = []; 153 | 154 | for (let prop of distinctProps) { 155 | const type = distinctTypes[prop]; 156 | 157 | metadata[prop] = { 158 | type: type, 159 | min: null, 160 | max: null, 161 | distinctValues: null, 162 | }; 163 | 164 | switch (type) { 165 | case 'number': 166 | // data will be normalize with a number between 0 and 1 167 | const minMax = this.getMinMax(prop, this.dataset); 168 | metadata[prop].min = minMax[0]; 169 | metadata[prop].max = minMax[1]; 170 | break; 171 | case 'boolean': 172 | // data is a simple 0 or 1 bit 173 | metadata[prop].min = 0; 174 | metadata[prop].max = 1; 175 | break; 176 | case 'string': 177 | // data will be normalize in an array of bits which length is equivalent 178 | // to the total number of distinct string values of the whole dataset 179 | const distinctStrVals = this.getDistinctVals(prop, this.dataset); 180 | metadata[prop].distinctValues = distinctStrVals; 181 | break; 182 | case 'array': 183 | const arrMinMax: any = this.get2DimArrayMinMax(prop, this.dataset); 184 | const distinctArrVals = this.getDistinctArrayVals(prop, this.dataset); 185 | 186 | metadata[prop].min = arrMinMax[0] 187 | metadata[prop].max = arrMinMax[1] 188 | metadata[prop].distinctValues = distinctArrVals; 189 | break; 190 | } 191 | } 192 | 193 | return metadata; 194 | } 195 | 196 | setOutputProperties(props: Array) 197 | { 198 | this.outputProperties = props; 199 | return this; 200 | } 201 | 202 | getMinMax(prop: string, data: Array) 203 | { 204 | let min: number = null 205 | let max: number = null 206 | 207 | for (let i in data) { 208 | let val: any = data[i][prop] 209 | 210 | if (min === null || val < min) { min = val } 211 | if (max === null || val > max) { max = val } 212 | } 213 | 214 | return [min, max] 215 | } 216 | 217 | getFlatArrMinMax(arr: Array) 218 | { 219 | let min: number = null 220 | let max: number = null 221 | 222 | if (typeof arr[0] === 'string') { 223 | return [min, max] 224 | } 225 | 226 | for (let i in arr) { 227 | if (typeof arr[i] !== 'number') { continue } 228 | let val: number = parseFloat(arr[i]) 229 | 230 | if (min === null || val < min) { min = val } 231 | if (max === null || val > max) { max = val } 232 | } 233 | 234 | return [min, max] 235 | } 236 | 237 | get2DimArrayMinMax(prop: string, data: any) 238 | { 239 | let min: number = null 240 | let max: number = null 241 | 242 | let mins: Array = [] 243 | let maxs: Array = [] 244 | 245 | for(let row of data) { 246 | const arr = row[prop] // this is itself a 1 dim array 247 | 248 | let minMax = this.getFlatArrMinMax(arr) 249 | 250 | mins.push(minMax[0]) 251 | maxs.push(minMax[1]) 252 | } 253 | 254 | min = this.getFlatArrMinMax(mins)[0] 255 | max = this.getFlatArrMinMax(maxs)[1] 256 | 257 | return [min, max] 258 | } 259 | 260 | getDistinctVals(property: string, data: Array) 261 | { 262 | let count = 0; 263 | let distinctValues = []; 264 | 265 | for(let row of data) { 266 | const val = row[property]; 267 | 268 | if (distinctValues.indexOf(val) === -1) { 269 | distinctValues.push(val) 270 | } 271 | } 272 | 273 | return distinctValues 274 | } 275 | 276 | getDistinctArrayVals(property: string, data: Array) 277 | { 278 | let count = 0; 279 | let distinctValues = []; 280 | 281 | for(let row of data) { 282 | const arrVal: any = row[property]; 283 | 284 | for (let val of arrVal) { 285 | if (distinctValues.indexOf(val) === -1) { 286 | distinctValues.push(val); 287 | } 288 | } 289 | } 290 | 291 | return distinctValues; 292 | } 293 | 294 | numToBit(min: number, max: number, value: number): number 295 | { 296 | const num = (value - min) / (max - min); 297 | return Number((num).toFixed(6)); 298 | } 299 | 300 | boolToBit(val: boolean) 301 | { 302 | return + val; 303 | } 304 | 305 | /** 306 | * Turns discint values into unique array of bits to represent them all. 307 | * For example if we have distinct data values of [ 500, 1050, 300, 950 ] 308 | * will will need a 4 length array of bits to represent them all. 309 | * The 1st value will be [0,0,0,1], the second [0,0,1,0]... and so on. 310 | * The methor 311 | */ 312 | strToBitsArr(distinctValues: any, val: string) 313 | { 314 | let bitArr = new Array(distinctValues.length); 315 | bitArr.fill(0); 316 | 317 | for (let i in distinctValues) { 318 | if (val === distinctValues[i]) { 319 | bitArr[i] = 1; 320 | } 321 | } 322 | 323 | return bitArr; 324 | } 325 | 326 | arrToBitsArr(distinctValues: any, vals: any) 327 | { 328 | let bitArr = new Array(distinctValues.length); 329 | bitArr.fill(0); 330 | 331 | for (let j in vals) { 332 | const val = vals[j]; 333 | let idx = distinctValues.indexOf(val); 334 | bitArr[idx] = 1; 335 | } 336 | 337 | return bitArr; 338 | } 339 | 340 | distinctProps(row: RowInput) 341 | { 342 | return Object.keys(row); 343 | } 344 | 345 | distinctTypes(row: RowInput) 346 | { 347 | let distinctTypes = {}; 348 | 349 | for (let prop in row) { 350 | const value = row[prop]; 351 | 352 | // also check for "real" array or object type 353 | if (typeof value === 'object' && isArray(value)) { 354 | distinctTypes[prop] = 'array'; 355 | } else if (typeof value === 'object') { 356 | distinctTypes[prop] = 'object'; 357 | } else { 358 | distinctTypes[prop] = typeof(value); 359 | } 360 | } 361 | 362 | return distinctTypes; 363 | } 364 | 365 | getRow1stValue(row: RowInput) 366 | { 367 | return row[Object.keys(row)[0]]; 368 | } 369 | } 370 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compileOnSave": true, 3 | "compilerOptions": { 4 | "outDir": "dist", 5 | "module": "commonjs", 6 | "target": "es5", 7 | "lib": ["es6", "es2015.promise"], 8 | "sourceMap": false, 9 | "moduleResolution": "node", 10 | "experimentalDecorators": true, 11 | "emitDecoratorMetadata": true, 12 | "removeComments": true, 13 | "noImplicitAny": false, 14 | "rootDir": "src" 15 | }, 16 | "exclude": [ 17 | "dist", 18 | "node_modules" 19 | ], 20 | "include": [ 21 | "src/**/*.ts" 22 | ] 23 | } 24 | --------------------------------------------------------------------------------