├── .coveralls.yml ├── .eslintrc.js ├── .gitattributes ├── .gitignore ├── .solcover.js ├── .solhint.json ├── .travis.yml ├── LICENSE ├── README.md ├── contracts ├── MedianOracle.sol ├── lib │ └── Select.sol └── mocks │ └── SelectMock.sol ├── migrations ├── .gitkeep └── deployments │ └── .gitignore ├── package-lock.json ├── package.json ├── scripts ├── pre-commit.sh ├── setup-ci.sh └── test.sh ├── test └── unit │ ├── gas_cost.js │ ├── median_oracle.js │ └── select.js ├── truffle.js └── util └── blockchain_caller.js /.coveralls.yml: -------------------------------------------------------------------------------- 1 | service_name: travis-pro 2 | repo_token: Pu8sTLhoNpJLHPYmRxmaSfcFfqXYDto6n 3 | -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | "extends": ["google", "standard", "plugin:prettier/recommended", "mocha"], 3 | "env": { 4 | "mocha": true, 5 | "node": true, 6 | "es6": true, 7 | }, 8 | "parserOptions": { 9 | "ecmaVersion": 8, 10 | }, 11 | "globals": { 12 | "artifacts": true, 13 | "assert": true, 14 | "contract": true, 15 | "expect": true, 16 | "Promise": true, 17 | "web3": true, 18 | }, 19 | "plugins": ["prettier", "spellcheck", "chai-friendly"], 20 | "rules": { 21 | "prettier/prettier": 0, 22 | "require-jsdoc": 0, 23 | "semi": [2, "always"], 24 | "prefer-const": 2, 25 | "no-unused-expressions": 0, 26 | "chai-friendly/no-unused-expressions": 2, 27 | "spellcheck/spell-checker": [ 28 | 2, 29 | { 30 | "comments": true, 31 | "strings": true, 32 | "identifiers": true, 33 | "lang": "en_US", 34 | "skipWords": [ 35 | // misc 36 | "deployer", "http", "https", "github", "chai", "argv", "evm", 37 | "jsonrpc", "timestamp", "uint256", "erc20", "bignumber", "lodash", 38 | "arg", "npm", "seedrandom", "eql", "sinon", "yaml", "posix", "promisify", 39 | "passcode", "geth", "rpc", "rpcmsg","stdev", "stochasm", "aggregator", 40 | "whitelist", "ethereum", "npx", "testrpc", "solc", "whitelisted", 41 | 42 | // shorthand 43 | "eth", "args", "util", "utils", "msg", "prev", "bal", 44 | "init", "params", "mul", "async", "vals", "fns", "addrs", 45 | "fns", "num", "dev", "pre","abi", "gte","rnd", "chk", "bals", "lte", 46 | "addr", 47 | 48 | // project-specific 49 | "rebase", "gons", "frg", "rng", "blockchain", "minlot", 50 | "redemptions", "rebased", "ganache", "ethclient", 51 | "bytecode", "Binance", 52 | 53 | // names 54 | "nithin", "naguib" 55 | ], 56 | "skipIfMatch": [ 57 | "http(s)?://[^s]*", 58 | "Sha3", 59 | "0x*", 60 | ], 61 | "minLength": 3 62 | } 63 | ], 64 | }, 65 | }; 66 | -------------------------------------------------------------------------------- /.gitattributes: -------------------------------------------------------------------------------- 1 | *.sol linguist-language=Solidity 2 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Generated files 2 | build 3 | dist 4 | 5 | ### Emacs ## 6 | *~ 7 | \#*\# 8 | .\#* 9 | 10 | # 11 | # Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio and WebStorm 12 | # Reference: https://intellij-support.jetbrains.com/hc/en-us/articles/206544839 13 | # 14 | 15 | # User-specific stuff: 16 | .idea/**/workspace.xml 17 | .idea/**/tasks.xml 18 | .idea/dictionaries 19 | 20 | # Sensitive or high-churn files: 21 | .idea/**/dataSources/ 22 | .idea/**/dataSources.ids 23 | .idea/**/dataSources.local.xml 24 | .idea/**/sqlDataSources.xml 25 | .idea/**/dynamic.xml 26 | .idea/**/uiDesigner.xml 27 | 28 | # Gradle: 29 | .idea/**/gradle.xml 30 | .idea/**/libraries 31 | 32 | # CMake 33 | cmake-build-debug/ 34 | cmake-build-release/ 35 | 36 | # Mongo Explorer plugin: 37 | .idea/**/mongoSettings.xml 38 | 39 | ## File-based project format: 40 | *.iws 41 | 42 | ## Plugin-specific files: 43 | 44 | # IntelliJ 45 | out/ 46 | 47 | # mpeltonen/sbt-idea plugin 48 | .idea_modules/ 49 | 50 | # JIRA plugin 51 | atlassian-ide-plugin.xml 52 | 53 | # Cursive Clojure plugin 54 | .idea/replstate.xml 55 | 56 | # Crashlytics plugin (for Android Studio and IntelliJ) 57 | com_crashlytics_export_strings.xml 58 | crashlytics.properties 59 | crashlytics-build.properties 60 | fabric.properties 61 | 62 | # NodeJS dependencies 63 | node_modules/* 64 | 65 | # ES-Lint 66 | .eslintcache 67 | 68 | # Solidity-Coverage 69 | allFiredEvents 70 | scTopics 71 | scDebugLog 72 | coverage.json 73 | coverage/ 74 | coverageEnv/ 75 | -------------------------------------------------------------------------------- /.solcover.js: -------------------------------------------------------------------------------- 1 | const _require = require('app-root-path').require; 2 | const config = _require('/truffle.js').networks.testrpcCoverage; 3 | 4 | module.exports = { 5 | host: config.host, 6 | network_id: config.network_id, 7 | port: config.port, 8 | gas: config.gas, 9 | gasPrice: config.gasPrice, 10 | norpc: true, 11 | testCommand: 'npx truffle test ./test/unit/*.js', 12 | compileCommand: 'npx truffle compile', 13 | }; 14 | -------------------------------------------------------------------------------- /.solhint.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "solhint:default", 3 | "rules": { 4 | "not-rely-on-time": [false], 5 | "indent": ["warn", 4] 6 | } 7 | } -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | dist: trusty 2 | sudo: required 3 | language: node_js 4 | node_js: 5 | - "8" 6 | cache: 7 | directories: 8 | - node_modules 9 | - $(npm config get prefix)/bin/ganache-cli 10 | before_install: 11 | - npm install -g npm@6.4.1 # Locking npm to 6.4.1 12 | - npm install -g npx 13 | script: 14 | - ./scripts/setup-ci.sh 15 | - npm run lint 16 | - npm run test 17 | - npx frg-coverage 18 | after_success: 19 | - cat coverage/lcov.info | npx coveralls 20 | notifications: 21 | email: 22 | - dev-support@ampleforth.org 23 | slack: fragmentsorg:2bN0L0FCZZ0illBRyPucRZkV 24 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 Fragments, Inc. 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Market Oracle 2 | 3 | [![Build Status](https://travis-ci.com/ampleforth/market-oracle.svg?token=xxNsLhLrTiyG3pc78i5v&branch=master)](https://travis-ci.com/ampleforth/market-oracle)   4 | [![Coverage Status](https://coveralls.io/repos/github/frgprotocol/market-oracle/badge.svg?branch=master&t=K8tHT9)](https://coveralls.io/github/frgprotocol/market-oracle?branch=master) 5 | 6 | 7 | This repository is a collection of [Ethereum smart contracts](http://ampleforth.org/docs) that enable aggregation of offchain market information from multiple sources. 8 | 9 | 10 | ## Table of Contents 11 | 12 | - [Install](#install) 13 | - [Testing](#testing) 14 | - [Contribute](#contribute) 15 | - [License](#license) 16 | 17 | 18 | ## Install 19 | 20 | ```bash 21 | # Install project dependencies 22 | npm install 23 | 24 | # Install ethereum local blockchain(s) and associated dependencies 25 | npx setup-local-chains 26 | ``` 27 | 28 | ## Testing 29 | 30 | ``` bash 31 | # You can use the following command to start a local blockchain instance 32 | npx start-chain [ganacheUnitTest|gethUnitTest] 33 | 34 | # Run all unit tests 35 | npm test 36 | 37 | # Run unit tests in isolation 38 | npx truffle --network ganacheUnitTest test test/unit/market_source.js 39 | ``` 40 | 41 | ## Contribute 42 | 43 | To report bugs within this package, please create an issue in this repository. 44 | When submitting code ensure that it is free of lint errors and has 100% test coverage. 45 | 46 | ``` bash 47 | # Lint code 48 | npm run lint 49 | 50 | # View code coverage 51 | npm run coverage 52 | ``` 53 | 54 | ## License 55 | 56 | [MIT (c) 2018 Fragments, Inc.](./LICENSE) 57 | -------------------------------------------------------------------------------- /contracts/MedianOracle.sol: -------------------------------------------------------------------------------- 1 | pragma solidity 0.4.24; 2 | 3 | import "openzeppelin-solidity/contracts/math/SafeMath.sol"; 4 | import "openzeppelin-solidity/contracts/ownership/Ownable.sol"; 5 | 6 | import "./lib/Select.sol"; 7 | 8 | 9 | interface IOracle { 10 | function getData() external returns (uint256, bool); 11 | } 12 | 13 | 14 | /** 15 | * @title Median Oracle 16 | * 17 | * @notice Provides a value onchain that's aggregated from a whitelisted set of 18 | * providers. 19 | */ 20 | contract MedianOracle is Ownable, IOracle { 21 | using SafeMath for uint256; 22 | 23 | struct Report { 24 | uint256 timestamp; 25 | uint256 payload; 26 | } 27 | 28 | // Addresses of providers authorized to push reports. 29 | address[] public providers; 30 | 31 | // Reports indexed by provider address. Report[0].timestamp > 0 32 | // indicates provider existence. 33 | mapping (address => Report[2]) public providerReports; 34 | 35 | event ProviderAdded(address provider); 36 | event ProviderRemoved(address provider); 37 | event ReportTimestampOutOfRange(address provider); 38 | event ProviderReportPushed(address indexed provider, uint256 payload, uint256 timestamp); 39 | 40 | // The number of seconds after which the report is deemed expired. 41 | uint256 public reportExpirationTimeSec; 42 | 43 | // The number of seconds since reporting that has to pass before a report 44 | // is usable. 45 | uint256 public reportDelaySec; 46 | 47 | // The minimum number of providers with valid reports to consider the 48 | // aggregate report valid. 49 | uint256 public minimumProviders = 1; 50 | 51 | // Timestamp of 1 is used to mark uninitialized and invalidated data. 52 | // This is needed so that timestamp of 1 is always considered expired. 53 | uint256 private constant MAX_REPORT_EXPIRATION_TIME = 520 weeks; 54 | 55 | /** 56 | * @param reportExpirationTimeSec_ The number of seconds after which the 57 | * report is deemed expired. 58 | * @param reportDelaySec_ The number of seconds since reporting that has to 59 | * pass before a report is usable 60 | * @param minimumProviders_ The minimum number of providers with valid 61 | * reports to consider the aggregate report valid. 62 | */ 63 | constructor(uint256 reportExpirationTimeSec_, 64 | uint256 reportDelaySec_, 65 | uint256 minimumProviders_) 66 | public 67 | { 68 | require(reportExpirationTimeSec_ <= MAX_REPORT_EXPIRATION_TIME); 69 | require(minimumProviders_ > 0); 70 | reportExpirationTimeSec = reportExpirationTimeSec_; 71 | reportDelaySec = reportDelaySec_; 72 | minimumProviders = minimumProviders_; 73 | } 74 | 75 | /** 76 | * @notice Sets the report expiration period. 77 | * @param reportExpirationTimeSec_ The number of seconds after which the 78 | * report is deemed expired. 79 | */ 80 | function setReportExpirationTimeSec(uint256 reportExpirationTimeSec_) 81 | external 82 | onlyOwner 83 | { 84 | require(reportExpirationTimeSec_ <= MAX_REPORT_EXPIRATION_TIME); 85 | reportExpirationTimeSec = reportExpirationTimeSec_; 86 | } 87 | 88 | /** 89 | * @notice Sets the time period since reporting that has to pass before a 90 | * report is usable. 91 | * @param reportDelaySec_ The new delay period in seconds. 92 | */ 93 | function setReportDelaySec(uint256 reportDelaySec_) 94 | external 95 | onlyOwner 96 | { 97 | reportDelaySec = reportDelaySec_; 98 | } 99 | 100 | /** 101 | * @notice Sets the minimum number of providers with valid reports to 102 | * consider the aggregate report valid. 103 | * @param minimumProviders_ The new minimum number of providers. 104 | */ 105 | function setMinimumProviders(uint256 minimumProviders_) 106 | external 107 | onlyOwner 108 | { 109 | require(minimumProviders_ > 0); 110 | minimumProviders = minimumProviders_; 111 | } 112 | 113 | /** 114 | * @notice Pushes a report for the calling provider. 115 | * @param payload is expected to be 18 decimal fixed point number. 116 | */ 117 | function pushReport(uint256 payload) external 118 | { 119 | address providerAddress = msg.sender; 120 | Report[2] storage reports = providerReports[providerAddress]; 121 | uint256[2] memory timestamps = [reports[0].timestamp, reports[1].timestamp]; 122 | 123 | require(timestamps[0] > 0); 124 | 125 | uint8 index_recent = timestamps[0] >= timestamps[1] ? 0 : 1; 126 | uint8 index_past = 1 - index_recent; 127 | 128 | // Check that the push is not too soon after the last one. 129 | require(timestamps[index_recent].add(reportDelaySec) <= now); 130 | 131 | reports[index_past].timestamp = now; 132 | reports[index_past].payload = payload; 133 | 134 | emit ProviderReportPushed(providerAddress, payload, now); 135 | } 136 | 137 | /** 138 | * @notice Invalidates the reports of the calling provider. 139 | */ 140 | function purgeReports() external 141 | { 142 | address providerAddress = msg.sender; 143 | require (providerReports[providerAddress][0].timestamp > 0); 144 | providerReports[providerAddress][0].timestamp=1; 145 | providerReports[providerAddress][1].timestamp=1; 146 | } 147 | 148 | /** 149 | * @notice Computes median of provider reports whose timestamps are in the 150 | * valid timestamp range. 151 | * @return AggregatedValue: Median of providers reported values. 152 | * valid: Boolean indicating an aggregated value was computed successfully. 153 | */ 154 | function getData() 155 | external 156 | returns (uint256, bool) 157 | { 158 | uint256 reportsCount = providers.length; 159 | uint256[] memory validReports = new uint256[](reportsCount); 160 | uint256 size = 0; 161 | uint256 minValidTimestamp = now.sub(reportExpirationTimeSec); 162 | uint256 maxValidTimestamp = now.sub(reportDelaySec); 163 | 164 | for (uint256 i = 0; i < reportsCount; i++) { 165 | address providerAddress = providers[i]; 166 | Report[2] memory reports = providerReports[providerAddress]; 167 | 168 | uint8 index_recent = reports[0].timestamp >= reports[1].timestamp ? 0 : 1; 169 | uint8 index_past = 1 - index_recent; 170 | uint256 reportTimestampRecent = reports[index_recent].timestamp; 171 | if (reportTimestampRecent > maxValidTimestamp) { 172 | // Recent report is too recent. 173 | uint256 reportTimestampPast = providerReports[providerAddress][index_past].timestamp; 174 | if (reportTimestampPast < minValidTimestamp) { 175 | // Past report is too old. 176 | emit ReportTimestampOutOfRange(providerAddress); 177 | } else if (reportTimestampPast > maxValidTimestamp) { 178 | // Past report is too recent. 179 | emit ReportTimestampOutOfRange(providerAddress); 180 | } else { 181 | // Using past report. 182 | validReports[size++] = providerReports[providerAddress][index_past].payload; 183 | } 184 | } else { 185 | // Recent report is not too recent. 186 | if (reportTimestampRecent < minValidTimestamp) { 187 | // Recent report is too old. 188 | emit ReportTimestampOutOfRange(providerAddress); 189 | } else { 190 | // Using recent report. 191 | validReports[size++] = providerReports[providerAddress][index_recent].payload; 192 | } 193 | } 194 | } 195 | 196 | if (size < minimumProviders) { 197 | return (0, false); 198 | } 199 | 200 | return (Select.computeMedian(validReports, size), true); 201 | } 202 | 203 | /** 204 | * @notice Authorizes a provider. 205 | * @param provider Address of the provider. 206 | */ 207 | function addProvider(address provider) 208 | external 209 | onlyOwner 210 | { 211 | require(providerReports[provider][0].timestamp == 0); 212 | providers.push(provider); 213 | providerReports[provider][0].timestamp = 1; 214 | emit ProviderAdded(provider); 215 | } 216 | 217 | /** 218 | * @notice Revokes provider authorization. 219 | * @param provider Address of the provider. 220 | */ 221 | function removeProvider(address provider) 222 | external 223 | onlyOwner 224 | { 225 | delete providerReports[provider]; 226 | for (uint256 i = 0; i < providers.length; i++) { 227 | if (providers[i] == provider) { 228 | if (i + 1 != providers.length) { 229 | providers[i] = providers[providers.length-1]; 230 | } 231 | providers.length--; 232 | emit ProviderRemoved(provider); 233 | break; 234 | } 235 | } 236 | } 237 | 238 | /** 239 | * @return The number of authorized providers. 240 | */ 241 | function providersSize() 242 | external 243 | view 244 | returns (uint256) 245 | { 246 | return providers.length; 247 | } 248 | } 249 | -------------------------------------------------------------------------------- /contracts/lib/Select.sol: -------------------------------------------------------------------------------- 1 | pragma solidity ^0.4.24; 2 | import "openzeppelin-solidity/contracts/math/SafeMath.sol"; 3 | 4 | /** 5 | * @title Select 6 | * @dev Median Selection Library 7 | */ 8 | library Select { 9 | using SafeMath for uint256; 10 | 11 | /** 12 | * @dev Sorts the input array up to the denoted size, and returns the median. 13 | * @param array Input array to compute its median. 14 | * @param size Number of elements in array to compute the median for. 15 | * @return Median of array. 16 | */ 17 | function computeMedian(uint256[] array, uint256 size) 18 | internal 19 | pure 20 | returns (uint256) 21 | { 22 | require(size > 0 && array.length >= size); 23 | for (uint256 i = 1; i < size; i++) { 24 | for (uint256 j = i; j > 0 && array[j-1] > array[j]; j--) { 25 | uint256 tmp = array[j]; 26 | array[j] = array[j-1]; 27 | array[j-1] = tmp; 28 | } 29 | } 30 | if (size % 2 == 1) { 31 | return array[size / 2]; 32 | } else { 33 | return array[size / 2].add(array[size / 2 - 1]) / 2; 34 | } 35 | } 36 | } 37 | -------------------------------------------------------------------------------- /contracts/mocks/SelectMock.sol: -------------------------------------------------------------------------------- 1 | pragma solidity 0.4.24; 2 | 3 | import "../lib/Select.sol"; 4 | 5 | contract Mock { 6 | event ReturnValueUInt256(uint256 val); 7 | } 8 | 9 | contract SelectMock is Mock{ 10 | function computeMedian(uint256[] data, uint256 size) external returns (uint256) 11 | { 12 | uint256 result = Select.computeMedian(data, size); 13 | emit ReturnValueUInt256(result); 14 | return result; 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /migrations/.gitkeep: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/ampleforth/market-oracle/5e7fd1506784f074748ab6bd5df740ca2227b14f/migrations/.gitkeep -------------------------------------------------------------------------------- /migrations/deployments/.gitignore: -------------------------------------------------------------------------------- 1 | *.yaml 2 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "market-oracle", 3 | "version": "0.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.0.0", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", 10 | "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", 11 | "requires": { 12 | "@babel/highlight": "7.0.0" 13 | } 14 | }, 15 | "@babel/highlight": { 16 | "version": "7.0.0", 17 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", 18 | "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", 19 | "requires": { 20 | "chalk": "2.4.1", 21 | "esutils": "2.0.2", 22 | "js-tokens": "4.0.0" 23 | }, 24 | "dependencies": { 25 | "js-tokens": { 26 | "version": "4.0.0", 27 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 28 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 29 | } 30 | } 31 | }, 32 | "abbrev": { 33 | "version": "1.0.9", 34 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.0.9.tgz", 35 | "integrity": "sha1-kbR5JYinc4wl813W9jdSovh3YTU=", 36 | "dev": true 37 | }, 38 | "acorn": { 39 | "version": "5.7.3", 40 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.7.3.tgz", 41 | "integrity": "sha512-T/zvzYRfbVojPWahDsE5evJdHb3oJoQfFbsrKM7w5Zcs++Tr257tia3BmMP8XYVjp1S9RZXQMh7gao96BlqZOw==", 42 | "dev": true 43 | }, 44 | "acorn-jsx": { 45 | "version": "3.0.1", 46 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-3.0.1.tgz", 47 | "integrity": "sha1-r9+UiPsezvyDSPb7IvRk4ypYs2s=", 48 | "dev": true, 49 | "requires": { 50 | "acorn": "3.3.0" 51 | }, 52 | "dependencies": { 53 | "acorn": { 54 | "version": "3.3.0", 55 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", 56 | "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", 57 | "dev": true 58 | } 59 | } 60 | }, 61 | "aes-js": { 62 | "version": "3.1.2", 63 | "resolved": "https://registry.npmjs.org/aes-js/-/aes-js-3.1.2.tgz", 64 | "integrity": "sha512-e5pEa2kBnBOgR4Y/p20pskXI74UEz7de8ZGVo58asOtvSVG5YAbJeELPZxOmt+Bnz3rX753YKhfIn4X4l1PPRQ==" 65 | }, 66 | "ajv": { 67 | "version": "6.6.1", 68 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.6.1.tgz", 69 | "integrity": "sha512-ZoJjft5B+EJBjUyu9C9Hc0OZyPZSSlOF+plzouTrg6UlA8f+e/n8NIgBFG/9tppJtpPWfthHakK7juJdNDODww==", 70 | "requires": { 71 | "fast-deep-equal": "2.0.1", 72 | "fast-json-stable-stringify": "2.0.0", 73 | "json-schema-traverse": "0.4.1", 74 | "uri-js": "4.2.2" 75 | } 76 | }, 77 | "ajv-keywords": { 78 | "version": "2.1.1", 79 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-2.1.1.tgz", 80 | "integrity": "sha1-YXmX/F9gV2iUxDX5QNgZ4TW4B2I=", 81 | "dev": true 82 | }, 83 | "amdefine": { 84 | "version": "1.0.1", 85 | "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", 86 | "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", 87 | "dev": true, 88 | "optional": true 89 | }, 90 | "ansi-escapes": { 91 | "version": "3.1.0", 92 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", 93 | "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", 94 | "dev": true 95 | }, 96 | "ansi-regex": { 97 | "version": "2.1.1", 98 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 99 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 100 | }, 101 | "ansi-styles": { 102 | "version": "2.2.1", 103 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 104 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 105 | "dev": true 106 | }, 107 | "antlr4": { 108 | "version": "4.7.1", 109 | "resolved": "https://registry.npmjs.org/antlr4/-/antlr4-4.7.1.tgz", 110 | "integrity": "sha512-haHyTW7Y9joE5MVs37P2lNYfU2RWBLfcRDD8OWldcdZm5TiCE91B5Xl1oWSwiDUSd4rlExpt2pu1fksYQjRBYQ==" 111 | }, 112 | "app-root-path": { 113 | "version": "2.1.0", 114 | "resolved": "https://registry.npmjs.org/app-root-path/-/app-root-path-2.1.0.tgz", 115 | "integrity": "sha1-mL9lmTJ+zqGZMJhm6BQDaP0uZGo=" 116 | }, 117 | "argparse": { 118 | "version": "1.0.10", 119 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 120 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 121 | "requires": { 122 | "sprintf-js": "~1.0.2" 123 | } 124 | }, 125 | "asn1": { 126 | "version": "0.2.4", 127 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 128 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 129 | "dev": true, 130 | "requires": { 131 | "safer-buffer": "2.1.2" 132 | } 133 | }, 134 | "assert-plus": { 135 | "version": "1.0.0", 136 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 137 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 138 | "dev": true 139 | }, 140 | "assertion-error": { 141 | "version": "1.1.0", 142 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 143 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 144 | "dev": true 145 | }, 146 | "astral-regex": { 147 | "version": "1.0.0", 148 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 149 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==" 150 | }, 151 | "async": { 152 | "version": "1.5.2", 153 | "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", 154 | "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", 155 | "dev": true 156 | }, 157 | "asynckit": { 158 | "version": "0.4.0", 159 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 160 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 161 | "dev": true 162 | }, 163 | "aws-sign2": { 164 | "version": "0.7.0", 165 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 166 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 167 | "dev": true 168 | }, 169 | "aws4": { 170 | "version": "1.8.0", 171 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.8.0.tgz", 172 | "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==", 173 | "dev": true 174 | }, 175 | "babel-code-frame": { 176 | "version": "6.26.0", 177 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 178 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 179 | "dev": true, 180 | "requires": { 181 | "chalk": "1.1.3", 182 | "esutils": "2.0.2", 183 | "js-tokens": "3.0.2" 184 | }, 185 | "dependencies": { 186 | "chalk": { 187 | "version": "1.1.3", 188 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 189 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 190 | "dev": true, 191 | "requires": { 192 | "ansi-styles": "2.2.1", 193 | "escape-string-regexp": "1.0.5", 194 | "has-ansi": "2.0.0", 195 | "strip-ansi": "3.0.1", 196 | "supports-color": "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 | "balanced-match": { 208 | "version": "1.0.0", 209 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 210 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 211 | }, 212 | "base-x": { 213 | "version": "3.0.5", 214 | "resolved": "https://registry.npmjs.org/base-x/-/base-x-3.0.5.tgz", 215 | "integrity": "sha512-C3picSgzPSLE+jW3tcBzJoGwitOtazb5B+5YmAxZm2ybmTi9LNgAtDO/jjVEBZwHoXmDBZ9m/IELj3elJVRBcA==", 216 | "requires": { 217 | "safe-buffer": "5.1.2" 218 | } 219 | }, 220 | "bcrypt-pbkdf": { 221 | "version": "1.0.2", 222 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 223 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 224 | "dev": true, 225 | "requires": { 226 | "tweetnacl": "0.14.5" 227 | } 228 | }, 229 | "bignumber.js": { 230 | "version": "git+https://github.com/debris/bignumber.js.git#94d7146671b9719e00a09c29b01a691bc85048c2", 231 | "from": "git+https://github.com/debris/bignumber.js.git#94d7146671b9719e00a09c29b01a691bc85048c2", 232 | "dev": true 233 | }, 234 | "bindings": { 235 | "version": "1.5.0", 236 | "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", 237 | "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", 238 | "requires": { 239 | "file-uri-to-path": "1.0.0" 240 | } 241 | }, 242 | "bip39": { 243 | "version": "2.6.0", 244 | "resolved": "https://registry.npmjs.org/bip39/-/bip39-2.6.0.tgz", 245 | "integrity": "sha512-RrnQRG2EgEoqO24ea+Q/fftuPUZLmrEM3qNhhGsA3PbaXaCW791LTzPuVyx/VprXQcTbPJ3K3UeTna8ZnVl2sg==", 246 | "requires": { 247 | "create-hash": "1.2.0", 248 | "pbkdf2": "3.0.17", 249 | "randombytes": "2.1.0", 250 | "safe-buffer": "5.1.2", 251 | "unorm": "1.5.0" 252 | } 253 | }, 254 | "bip66": { 255 | "version": "1.1.5", 256 | "resolved": "https://registry.npmjs.org/bip66/-/bip66-1.1.5.tgz", 257 | "integrity": "sha1-AfqHSHhcpwlV1QESF9GzE5lpyiI=", 258 | "requires": { 259 | "safe-buffer": "5.1.2" 260 | } 261 | }, 262 | "bn.js": { 263 | "version": "4.11.8", 264 | "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.8.tgz", 265 | "integrity": "sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA==" 266 | }, 267 | "brace-expansion": { 268 | "version": "1.1.11", 269 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 270 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 271 | "requires": { 272 | "balanced-match": "1.0.0", 273 | "concat-map": "0.0.1" 274 | } 275 | }, 276 | "brorand": { 277 | "version": "1.1.0", 278 | "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", 279 | "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=" 280 | }, 281 | "browser-stdout": { 282 | "version": "1.3.0", 283 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.0.tgz", 284 | "integrity": "sha1-81HTKWnTL6XXpVZxVCY9korjvR8=" 285 | }, 286 | "browserify-aes": { 287 | "version": "1.2.0", 288 | "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", 289 | "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", 290 | "requires": { 291 | "buffer-xor": "1.0.3", 292 | "cipher-base": "1.0.4", 293 | "create-hash": "1.2.0", 294 | "evp_bytestokey": "1.0.3", 295 | "inherits": "2.0.3", 296 | "safe-buffer": "5.1.2" 297 | } 298 | }, 299 | "browserify-sha3": { 300 | "version": "0.0.1", 301 | "resolved": "https://registry.npmjs.org/browserify-sha3/-/browserify-sha3-0.0.1.tgz", 302 | "integrity": "sha1-P/NKMAbvFcD7NWflQbkaI0ASPRE=", 303 | "dev": true, 304 | "requires": { 305 | "js-sha3": "0.3.1" 306 | } 307 | }, 308 | "bs58": { 309 | "version": "4.0.1", 310 | "resolved": "https://registry.npmjs.org/bs58/-/bs58-4.0.1.tgz", 311 | "integrity": "sha1-vhYedsNU9veIrkBx9j806MTwpCo=", 312 | "requires": { 313 | "base-x": "3.0.5" 314 | } 315 | }, 316 | "bs58check": { 317 | "version": "2.1.2", 318 | "resolved": "https://registry.npmjs.org/bs58check/-/bs58check-2.1.2.tgz", 319 | "integrity": "sha512-0TS1jicxdU09dwJMNZtVAfzPi6Q6QeN0pM1Fkzrjn+XYHvzMKPU3pHVpva+769iNVSfIYWf7LJ6WR+BuuMf8cA==", 320 | "requires": { 321 | "bs58": "4.0.1", 322 | "create-hash": "1.2.0", 323 | "safe-buffer": "5.1.2" 324 | } 325 | }, 326 | "buffer-from": { 327 | "version": "1.1.1", 328 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 329 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 330 | "dev": true 331 | }, 332 | "buffer-xor": { 333 | "version": "1.0.3", 334 | "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", 335 | "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=" 336 | }, 337 | "builtin-modules": { 338 | "version": "1.1.1", 339 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 340 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=" 341 | }, 342 | "caller-callsite": { 343 | "version": "2.0.0", 344 | "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", 345 | "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", 346 | "requires": { 347 | "callsites": "2.0.0" 348 | }, 349 | "dependencies": { 350 | "callsites": { 351 | "version": "2.0.0", 352 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", 353 | "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=" 354 | } 355 | } 356 | }, 357 | "caller-path": { 358 | "version": "0.1.0", 359 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", 360 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", 361 | "dev": true, 362 | "requires": { 363 | "callsites": "0.2.0" 364 | } 365 | }, 366 | "callsites": { 367 | "version": "0.2.0", 368 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", 369 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", 370 | "dev": true 371 | }, 372 | "camelcase": { 373 | "version": "3.0.0", 374 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", 375 | "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=" 376 | }, 377 | "caseless": { 378 | "version": "0.12.0", 379 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 380 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 381 | "dev": true 382 | }, 383 | "chai": { 384 | "version": "4.2.0", 385 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", 386 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", 387 | "dev": true, 388 | "requires": { 389 | "assertion-error": "1.1.0", 390 | "check-error": "1.0.2", 391 | "deep-eql": "3.0.1", 392 | "get-func-name": "2.0.0", 393 | "pathval": "1.1.0", 394 | "type-detect": "4.0.8" 395 | } 396 | }, 397 | "chai-bignumber": { 398 | "version": "2.0.2", 399 | "resolved": "https://registry.npmjs.org/chai-bignumber/-/chai-bignumber-2.0.2.tgz", 400 | "integrity": "sha512-BIdRNjRaoRj4bMsZLKbIZPMNKqmwnzNiyxqBYDSs6dFOCs9w8OHPuUE8e1bH60i1IhOzT0NjLtCD+lKEWB1KTQ==", 401 | "dev": true 402 | }, 403 | "chalk": { 404 | "version": "2.4.1", 405 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 406 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 407 | "requires": { 408 | "ansi-styles": "3.2.1", 409 | "escape-string-regexp": "1.0.5", 410 | "supports-color": "5.5.0" 411 | }, 412 | "dependencies": { 413 | "ansi-styles": { 414 | "version": "3.2.1", 415 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 416 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 417 | "requires": { 418 | "color-convert": "1.9.3" 419 | } 420 | }, 421 | "has-flag": { 422 | "version": "3.0.0", 423 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 424 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 425 | }, 426 | "supports-color": { 427 | "version": "5.5.0", 428 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 429 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 430 | "requires": { 431 | "has-flag": "3.0.0" 432 | } 433 | } 434 | } 435 | }, 436 | "chardet": { 437 | "version": "0.4.2", 438 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.4.2.tgz", 439 | "integrity": "sha1-tUc7M9yXxCTl2Y3IfVXU2KKci/I=", 440 | "dev": true 441 | }, 442 | "check-error": { 443 | "version": "1.0.2", 444 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 445 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 446 | "dev": true 447 | }, 448 | "cipher-base": { 449 | "version": "1.0.4", 450 | "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", 451 | "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", 452 | "requires": { 453 | "inherits": "2.0.3", 454 | "safe-buffer": "5.1.2" 455 | } 456 | }, 457 | "circular-json": { 458 | "version": "0.3.3", 459 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", 460 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", 461 | "dev": true 462 | }, 463 | "cli-cursor": { 464 | "version": "2.1.0", 465 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 466 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 467 | "requires": { 468 | "restore-cursor": "2.0.0" 469 | } 470 | }, 471 | "cli-width": { 472 | "version": "2.2.0", 473 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 474 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=" 475 | }, 476 | "cliui": { 477 | "version": "3.2.0", 478 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", 479 | "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", 480 | "requires": { 481 | "string-width": "1.0.2", 482 | "strip-ansi": "3.0.1", 483 | "wrap-ansi": "2.1.0" 484 | } 485 | }, 486 | "co": { 487 | "version": "4.6.0", 488 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 489 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 490 | "dev": true 491 | }, 492 | "code-point-at": { 493 | "version": "1.1.0", 494 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 495 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 496 | }, 497 | "coinstring": { 498 | "version": "2.3.0", 499 | "resolved": "https://registry.npmjs.org/coinstring/-/coinstring-2.3.0.tgz", 500 | "integrity": "sha1-zbYzY6lhUCQEolr7gsLibV/2J6Q=", 501 | "requires": { 502 | "bs58": "2.0.1", 503 | "create-hash": "1.2.0" 504 | }, 505 | "dependencies": { 506 | "bs58": { 507 | "version": "2.0.1", 508 | "resolved": "https://registry.npmjs.org/bs58/-/bs58-2.0.1.tgz", 509 | "integrity": "sha1-VZCNWPGYKrogCPob7Y+RmYopv40=" 510 | } 511 | } 512 | }, 513 | "color-convert": { 514 | "version": "1.9.3", 515 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 516 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 517 | "requires": { 518 | "color-name": "1.1.3" 519 | } 520 | }, 521 | "color-name": { 522 | "version": "1.1.3", 523 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 524 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 525 | }, 526 | "combined-stream": { 527 | "version": "1.0.7", 528 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", 529 | "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", 530 | "dev": true, 531 | "requires": { 532 | "delayed-stream": "1.0.0" 533 | } 534 | }, 535 | "commander": { 536 | "version": "2.11.0", 537 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 538 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==" 539 | }, 540 | "concat-map": { 541 | "version": "0.0.1", 542 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 543 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 544 | }, 545 | "concat-stream": { 546 | "version": "1.6.2", 547 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 548 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 549 | "dev": true, 550 | "requires": { 551 | "buffer-from": "1.1.1", 552 | "inherits": "2.0.3", 553 | "readable-stream": "2.3.6", 554 | "typedarray": "0.0.6" 555 | } 556 | }, 557 | "contains-path": { 558 | "version": "0.1.0", 559 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 560 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 561 | "dev": true 562 | }, 563 | "core-util-is": { 564 | "version": "1.0.2", 565 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 566 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 567 | "dev": true 568 | }, 569 | "cosmiconfig": { 570 | "version": "5.1.0", 571 | "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.1.0.tgz", 572 | "integrity": "sha512-kCNPvthka8gvLtzAxQXvWo4FxqRB+ftRZyPZNuab5ngvM9Y7yw7hbEysglptLgpkGX9nAOKTBVkHUAe8xtYR6Q==", 573 | "requires": { 574 | "import-fresh": "2.0.0", 575 | "is-directory": "0.3.1", 576 | "js-yaml": "3.12.0", 577 | "lodash.get": "4.4.2", 578 | "parse-json": "4.0.0" 579 | }, 580 | "dependencies": { 581 | "js-yaml": { 582 | "version": "3.12.0", 583 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 584 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 585 | "requires": { 586 | "argparse": "^1.0.7", 587 | "esprima": "^4.0.0" 588 | } 589 | }, 590 | "parse-json": { 591 | "version": "4.0.0", 592 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 593 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 594 | "requires": { 595 | "error-ex": "1.3.2", 596 | "json-parse-better-errors": "1.0.2" 597 | } 598 | } 599 | } 600 | }, 601 | "coveralls": { 602 | "version": "3.0.2", 603 | "resolved": "https://registry.npmjs.org/coveralls/-/coveralls-3.0.2.tgz", 604 | "integrity": "sha512-Tv0LKe/MkBOilH2v7WBiTBdudg2ChfGbdXafc/s330djpF3zKOmuehTeRwjXWc7pzfj9FrDUTA7tEx6Div8NFw==", 605 | "dev": true, 606 | "requires": { 607 | "growl": "1.10.3", 608 | "js-yaml": "3.12.0", 609 | "lcov-parse": "0.0.10", 610 | "log-driver": "1.2.7", 611 | "minimist": "1.2.0", 612 | "request": "2.88.0" 613 | }, 614 | "dependencies": { 615 | "js-yaml": { 616 | "version": "3.12.0", 617 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 618 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 619 | "dev": true, 620 | "requires": { 621 | "argparse": "^1.0.7", 622 | "esprima": "^4.0.0" 623 | } 624 | }, 625 | "minimist": { 626 | "version": "1.2.0", 627 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 628 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 629 | "dev": true 630 | } 631 | } 632 | }, 633 | "create-hash": { 634 | "version": "1.2.0", 635 | "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", 636 | "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", 637 | "requires": { 638 | "cipher-base": "1.0.4", 639 | "inherits": "2.0.3", 640 | "md5.js": "1.3.5", 641 | "ripemd160": "2.0.2", 642 | "sha.js": "2.4.11" 643 | } 644 | }, 645 | "create-hmac": { 646 | "version": "1.1.7", 647 | "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", 648 | "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", 649 | "requires": { 650 | "cipher-base": "1.0.4", 651 | "create-hash": "1.2.0", 652 | "inherits": "2.0.3", 653 | "ripemd160": "2.0.2", 654 | "safe-buffer": "5.1.2", 655 | "sha.js": "2.4.11" 656 | } 657 | }, 658 | "cross-spawn": { 659 | "version": "5.1.0", 660 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 661 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 662 | "dev": true, 663 | "requires": { 664 | "lru-cache": "4.1.5", 665 | "shebang-command": "1.2.0", 666 | "which": "1.3.1" 667 | } 668 | }, 669 | "crypto-js": { 670 | "version": "3.1.8", 671 | "resolved": "https://registry.npmjs.org/crypto-js/-/crypto-js-3.1.8.tgz", 672 | "integrity": "sha1-cV8HC/YBTyrpkqmLOSkli3E/CNU=", 673 | "dev": true 674 | }, 675 | "d": { 676 | "version": "1.0.0", 677 | "resolved": "http://registry.npmjs.org/d/-/d-1.0.0.tgz", 678 | "integrity": "sha1-dUu1v+VUUdpppYuU1F9MWwRi1Y8=", 679 | "dev": true, 680 | "requires": { 681 | "es5-ext": "0.10.46" 682 | } 683 | }, 684 | "dashdash": { 685 | "version": "1.14.1", 686 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 687 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 688 | "dev": true, 689 | "requires": { 690 | "assert-plus": "1.0.0" 691 | } 692 | }, 693 | "death": { 694 | "version": "1.1.0", 695 | "resolved": "https://registry.npmjs.org/death/-/death-1.1.0.tgz", 696 | "integrity": "sha1-AaqcQB7dknUFFEcLgmY5DGbGcxg=", 697 | "dev": true 698 | }, 699 | "debug": { 700 | "version": "3.1.0", 701 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 702 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 703 | "requires": { 704 | "ms": "2.0.0" 705 | } 706 | }, 707 | "decamelize": { 708 | "version": "1.2.0", 709 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 710 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 711 | }, 712 | "deep-eql": { 713 | "version": "3.0.1", 714 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 715 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 716 | "dev": true, 717 | "requires": { 718 | "type-detect": "4.0.8" 719 | } 720 | }, 721 | "deep-is": { 722 | "version": "0.1.3", 723 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 724 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" 725 | }, 726 | "delayed-stream": { 727 | "version": "1.0.0", 728 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 729 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 730 | "dev": true 731 | }, 732 | "diff": { 733 | "version": "3.3.1", 734 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.3.1.tgz", 735 | "integrity": "sha512-MKPHZDMB0o6yHyDryUOScqZibp914ksXwAMYMTHj6KO8UeKsRYNJD3oNCKjTqZon+V488P7N/HzXF8t7ZR95ww==" 736 | }, 737 | "doctrine": { 738 | "version": "2.1.0", 739 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 740 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 741 | "dev": true, 742 | "requires": { 743 | "esutils": "2.0.2" 744 | } 745 | }, 746 | "drbg.js": { 747 | "version": "1.0.1", 748 | "resolved": "https://registry.npmjs.org/drbg.js/-/drbg.js-1.0.1.tgz", 749 | "integrity": "sha1-Pja2xCs3BDgjzbwzLVjzHiRFSAs=", 750 | "requires": { 751 | "browserify-aes": "1.2.0", 752 | "create-hash": "1.2.0", 753 | "create-hmac": "1.1.7" 754 | } 755 | }, 756 | "ecc-jsbn": { 757 | "version": "0.1.2", 758 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 759 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 760 | "dev": true, 761 | "requires": { 762 | "jsbn": "0.1.1", 763 | "safer-buffer": "2.1.2" 764 | } 765 | }, 766 | "elliptic": { 767 | "version": "6.4.1", 768 | "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.4.1.tgz", 769 | "integrity": "sha512-BsXLz5sqX8OHcsh7CqBMztyXARmGQ3LWPtGjJi6DiJHq5C/qvi9P3OqgswKSDftbu8+IoI/QDTAm2fFnQ9SZSQ==", 770 | "requires": { 771 | "bn.js": "^4.4.0", 772 | "brorand": "^1.0.1", 773 | "hash.js": "^1.0.0", 774 | "hmac-drbg": "^1.0.0", 775 | "inherits": "^2.0.1", 776 | "minimalistic-assert": "^1.0.0", 777 | "minimalistic-crypto-utils": "^1.0.0" 778 | } 779 | }, 780 | "emoji-regex": { 781 | "version": "7.0.3", 782 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 783 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 784 | }, 785 | "error-ex": { 786 | "version": "1.3.2", 787 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 788 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 789 | "requires": { 790 | "is-arrayish": "0.2.1" 791 | } 792 | }, 793 | "es5-ext": { 794 | "version": "0.10.46", 795 | "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.46.tgz", 796 | "integrity": "sha512-24XxRvJXNFwEMpJb3nOkiRJKRoupmjYmOPVlI65Qy2SrtxwOTB+g6ODjBKOtwEHbYrhWRty9xxOWLNdClT2djw==", 797 | "dev": true, 798 | "requires": { 799 | "es6-iterator": "2.0.3", 800 | "es6-symbol": "3.1.1", 801 | "next-tick": "1.0.0" 802 | } 803 | }, 804 | "es6-iterator": { 805 | "version": "2.0.3", 806 | "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", 807 | "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", 808 | "dev": true, 809 | "requires": { 810 | "d": "1.0.0", 811 | "es5-ext": "0.10.46", 812 | "es6-symbol": "3.1.1" 813 | } 814 | }, 815 | "es6-map": { 816 | "version": "0.1.5", 817 | "resolved": "https://registry.npmjs.org/es6-map/-/es6-map-0.1.5.tgz", 818 | "integrity": "sha1-kTbgUD3MBqMBaQ8LsU/042TpSfA=", 819 | "dev": true, 820 | "requires": { 821 | "d": "1.0.0", 822 | "es5-ext": "0.10.46", 823 | "es6-iterator": "2.0.3", 824 | "es6-set": "0.1.5", 825 | "es6-symbol": "3.1.1", 826 | "event-emitter": "0.3.5" 827 | } 828 | }, 829 | "es6-set": { 830 | "version": "0.1.5", 831 | "resolved": "https://registry.npmjs.org/es6-set/-/es6-set-0.1.5.tgz", 832 | "integrity": "sha1-0rPsXU2ADO2BjbU40ol02wpzzLE=", 833 | "dev": true, 834 | "requires": { 835 | "d": "1.0.0", 836 | "es5-ext": "0.10.46", 837 | "es6-iterator": "2.0.3", 838 | "es6-symbol": "3.1.1", 839 | "event-emitter": "0.3.5" 840 | } 841 | }, 842 | "es6-symbol": { 843 | "version": "3.1.1", 844 | "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.1.tgz", 845 | "integrity": "sha1-vwDvT9q2uhtG7Le2KbTH7VcVzHc=", 846 | "dev": true, 847 | "requires": { 848 | "d": "1.0.0", 849 | "es5-ext": "0.10.46" 850 | } 851 | }, 852 | "escape-string-regexp": { 853 | "version": "1.0.5", 854 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 855 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 856 | }, 857 | "escodegen": { 858 | "version": "1.8.1", 859 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.8.1.tgz", 860 | "integrity": "sha1-WltTr0aTEQvrsIZ6o0MN07cKEBg=", 861 | "dev": true, 862 | "requires": { 863 | "esprima": "2.7.3", 864 | "estraverse": "1.9.3", 865 | "esutils": "2.0.2", 866 | "optionator": "0.8.2", 867 | "source-map": "0.2.0" 868 | }, 869 | "dependencies": { 870 | "esprima": { 871 | "version": "2.7.3", 872 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", 873 | "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", 874 | "dev": true 875 | }, 876 | "estraverse": { 877 | "version": "1.9.3", 878 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-1.9.3.tgz", 879 | "integrity": "sha1-r2fy3JIlgkFZUJJgkaQAXSnJu0Q=", 880 | "dev": true 881 | }, 882 | "source-map": { 883 | "version": "0.2.0", 884 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.2.0.tgz", 885 | "integrity": "sha1-2rc/vPwrqBm03gO9b26qSBZLP50=", 886 | "dev": true, 887 | "optional": true, 888 | "requires": { 889 | "amdefine": "1.0.1" 890 | } 891 | } 892 | } 893 | }, 894 | "eslint": { 895 | "version": "4.19.1", 896 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-4.19.1.tgz", 897 | "integrity": "sha512-bT3/1x1EbZB7phzYu7vCr1v3ONuzDtX8WjuM9c0iYxe+cq+pwcKEoQjl7zd3RpC6YOLgnSy3cTN58M2jcoPDIQ==", 898 | "dev": true, 899 | "requires": { 900 | "ajv": "5.5.2", 901 | "babel-code-frame": "6.26.0", 902 | "chalk": "2.4.1", 903 | "concat-stream": "1.6.2", 904 | "cross-spawn": "5.1.0", 905 | "debug": "3.1.0", 906 | "doctrine": "2.1.0", 907 | "eslint-scope": "3.7.3", 908 | "eslint-visitor-keys": "1.0.0", 909 | "espree": "3.5.4", 910 | "esquery": "1.0.1", 911 | "esutils": "2.0.2", 912 | "file-entry-cache": "2.0.0", 913 | "functional-red-black-tree": "1.0.1", 914 | "glob": "7.1.2", 915 | "globals": "11.9.0", 916 | "ignore": "3.3.10", 917 | "imurmurhash": "0.1.4", 918 | "inquirer": "3.3.0", 919 | "is-resolvable": "1.1.0", 920 | "js-yaml": "3.12.0", 921 | "json-stable-stringify-without-jsonify": "1.0.1", 922 | "levn": "0.3.0", 923 | "lodash": "4.17.11", 924 | "minimatch": "3.0.4", 925 | "mkdirp": "0.5.1", 926 | "natural-compare": "1.4.0", 927 | "optionator": "0.8.2", 928 | "path-is-inside": "1.0.2", 929 | "pluralize": "7.0.0", 930 | "progress": "2.0.3", 931 | "regexpp": "1.1.0", 932 | "require-uncached": "1.0.3", 933 | "semver": "5.6.0", 934 | "strip-ansi": "4.0.0", 935 | "strip-json-comments": "2.0.1", 936 | "table": "4.0.2", 937 | "text-table": "0.2.0" 938 | }, 939 | "dependencies": { 940 | "ajv": { 941 | "version": "5.5.2", 942 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", 943 | "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", 944 | "dev": true, 945 | "requires": { 946 | "co": "4.6.0", 947 | "fast-deep-equal": "1.1.0", 948 | "fast-json-stable-stringify": "2.0.0", 949 | "json-schema-traverse": "0.3.1" 950 | } 951 | }, 952 | "ansi-regex": { 953 | "version": "3.0.0", 954 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 955 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 956 | "dev": true 957 | }, 958 | "fast-deep-equal": { 959 | "version": "1.1.0", 960 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", 961 | "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=", 962 | "dev": true 963 | }, 964 | "js-yaml": { 965 | "version": "3.12.0", 966 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 967 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 968 | "dev": true, 969 | "requires": { 970 | "argparse": "^1.0.7", 971 | "esprima": "^4.0.0" 972 | } 973 | }, 974 | "json-schema-traverse": { 975 | "version": "0.3.1", 976 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 977 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", 978 | "dev": true 979 | }, 980 | "strip-ansi": { 981 | "version": "4.0.0", 982 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 983 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 984 | "dev": true, 985 | "requires": { 986 | "ansi-regex": "3.0.0" 987 | } 988 | } 989 | } 990 | }, 991 | "eslint-config-google": { 992 | "version": "0.9.1", 993 | "resolved": "https://registry.npmjs.org/eslint-config-google/-/eslint-config-google-0.9.1.tgz", 994 | "integrity": "sha512-5A83D+lH0PA81QMESKbLJd/a3ic8tPZtwUmqNrxMRo54nfFaUvtt89q/+icQ+fd66c2xQHn0KyFkzJDoAUfpZA==", 995 | "dev": true 996 | }, 997 | "eslint-config-mocha": { 998 | "version": "0.0.0", 999 | "resolved": "https://registry.npmjs.org/eslint-config-mocha/-/eslint-config-mocha-0.0.0.tgz", 1000 | "integrity": "sha1-QJsDThiVDUTFsSccltJTYznc+2k=", 1001 | "dev": true, 1002 | "requires": { 1003 | "lodash.mergewith": "4.6.1" 1004 | } 1005 | }, 1006 | "eslint-config-prettier": { 1007 | "version": "2.10.0", 1008 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-2.10.0.tgz", 1009 | "integrity": "sha512-Mhl90VLucfBuhmcWBgbUNtgBiK955iCDK1+aHAz7QfDQF6wuzWZ6JjihZ3ejJoGlJWIuko7xLqNm8BA5uenKhA==", 1010 | "dev": true, 1011 | "requires": { 1012 | "get-stdin": "5.0.1" 1013 | } 1014 | }, 1015 | "eslint-config-standard": { 1016 | "version": "5.3.5", 1017 | "resolved": "http://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-5.3.5.tgz", 1018 | "integrity": "sha1-K0K7XJ8ASbhSeGjhCcNO4isT3PY=", 1019 | "dev": true 1020 | }, 1021 | "eslint-import-resolver-node": { 1022 | "version": "0.2.3", 1023 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.2.3.tgz", 1024 | "integrity": "sha1-Wt2BBujJKNssuiMrzZ76hG49oWw=", 1025 | "dev": true, 1026 | "requires": { 1027 | "debug": "2.6.9", 1028 | "object-assign": "4.1.1", 1029 | "resolve": "1.8.1" 1030 | }, 1031 | "dependencies": { 1032 | "debug": { 1033 | "version": "2.6.9", 1034 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1035 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1036 | "dev": true, 1037 | "requires": { 1038 | "ms": "2.0.0" 1039 | } 1040 | } 1041 | } 1042 | }, 1043 | "eslint-plugin-chai-friendly": { 1044 | "version": "0.4.1", 1045 | "resolved": "https://registry.npmjs.org/eslint-plugin-chai-friendly/-/eslint-plugin-chai-friendly-0.4.1.tgz", 1046 | "integrity": "sha512-hkpLN7VVoGGsofZjUhcQ+sufC3FgqMJwD0DvAcRfxY1tVRyQyVsqpaKnToPHJQOrRo0FQ0fSEDwW2gr4rsNdGA==", 1047 | "dev": true 1048 | }, 1049 | "eslint-plugin-import": { 1050 | "version": "1.16.0", 1051 | "resolved": "http://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-1.16.0.tgz", 1052 | "integrity": "sha1-svoH68xTUE0PKkR3WC7Iv/GHG58=", 1053 | "dev": true, 1054 | "requires": { 1055 | "builtin-modules": "1.1.1", 1056 | "contains-path": "0.1.0", 1057 | "debug": "2.6.9", 1058 | "doctrine": "1.3.0", 1059 | "es6-map": "0.1.5", 1060 | "es6-set": "0.1.5", 1061 | "eslint-import-resolver-node": "0.2.3", 1062 | "has": "1.0.3", 1063 | "lodash.cond": "4.5.2", 1064 | "lodash.endswith": "4.2.1", 1065 | "lodash.find": "4.6.0", 1066 | "lodash.findindex": "4.6.0", 1067 | "minimatch": "3.0.4", 1068 | "object-assign": "4.1.1", 1069 | "pkg-dir": "1.0.0", 1070 | "pkg-up": "1.0.0" 1071 | }, 1072 | "dependencies": { 1073 | "debug": { 1074 | "version": "2.6.9", 1075 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1076 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1077 | "dev": true, 1078 | "requires": { 1079 | "ms": "2.0.0" 1080 | } 1081 | }, 1082 | "doctrine": { 1083 | "version": "1.3.0", 1084 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.3.0.tgz", 1085 | "integrity": "sha1-E+dWgrVVGEJCdvfBc3g0Vu+RPSY=", 1086 | "dev": true, 1087 | "requires": { 1088 | "esutils": "2.0.2", 1089 | "isarray": "1.0.0" 1090 | } 1091 | } 1092 | } 1093 | }, 1094 | "eslint-plugin-mocha-only": { 1095 | "version": "0.0.3", 1096 | "resolved": "https://registry.npmjs.org/eslint-plugin-mocha-only/-/eslint-plugin-mocha-only-0.0.3.tgz", 1097 | "integrity": "sha1-8dEoTPIrefVOwf35iAye8FE5wkA=", 1098 | "dev": true 1099 | }, 1100 | "eslint-plugin-prettier": { 1101 | "version": "2.7.0", 1102 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-2.7.0.tgz", 1103 | "integrity": "sha512-CStQYJgALoQBw3FsBzH0VOVDRnJ/ZimUlpLm226U8qgqYJfPOY/CPK6wyRInMxh73HSKg5wyRwdS4BVYYHwokA==", 1104 | "dev": true, 1105 | "requires": { 1106 | "fast-diff": "1.2.0", 1107 | "jest-docblock": "21.2.0" 1108 | } 1109 | }, 1110 | "eslint-plugin-promise": { 1111 | "version": "1.3.2", 1112 | "resolved": "http://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-1.3.2.tgz", 1113 | "integrity": "sha1-/OMy1vX/UjIApTdwSGPsPCQiunw=", 1114 | "dev": true 1115 | }, 1116 | "eslint-plugin-spellcheck": { 1117 | "version": "0.0.10", 1118 | "resolved": "http://registry.npmjs.org/eslint-plugin-spellcheck/-/eslint-plugin-spellcheck-0.0.10.tgz", 1119 | "integrity": "sha512-8Ci0JQukizTUei/pUdzMgth9DTIMgpLBk3dOGbX+iKe2St10/qR9ppHuf021LJZdqmLhDKmg/wmPjCCT4ZSpKg==", 1120 | "dev": true, 1121 | "requires": { 1122 | "globals": "11.9.0", 1123 | "hunspell-spellchecker": "1.0.2", 1124 | "lodash": "4.17.11" 1125 | } 1126 | }, 1127 | "eslint-plugin-standard": { 1128 | "version": "1.3.3", 1129 | "resolved": "http://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-1.3.3.tgz", 1130 | "integrity": "sha1-owhUUVI0MedvQJxwy4+U4yvw7H8=", 1131 | "dev": true 1132 | }, 1133 | "eslint-scope": { 1134 | "version": "3.7.3", 1135 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.3.tgz", 1136 | "integrity": "sha512-W+B0SvF4gamyCTmUc+uITPY0989iXVfKvhwtmJocTaYoc/3khEHmEmvfY/Gn9HA9VV75jrQECsHizkNw1b68FA==", 1137 | "dev": true, 1138 | "requires": { 1139 | "esrecurse": "4.2.1", 1140 | "estraverse": "4.2.0" 1141 | } 1142 | }, 1143 | "eslint-utils": { 1144 | "version": "1.3.1", 1145 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", 1146 | "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==" 1147 | }, 1148 | "eslint-visitor-keys": { 1149 | "version": "1.0.0", 1150 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 1151 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==" 1152 | }, 1153 | "espree": { 1154 | "version": "3.5.4", 1155 | "resolved": "https://registry.npmjs.org/espree/-/espree-3.5.4.tgz", 1156 | "integrity": "sha512-yAcIQxtmMiB/jL32dzEp2enBeidsB7xWPLNiw3IIkpVds1P+h7qF9YwJq1yUNzp2OKXgAprs4F61ih66UsoD1A==", 1157 | "dev": true, 1158 | "requires": { 1159 | "acorn": "5.7.3", 1160 | "acorn-jsx": "3.0.1" 1161 | } 1162 | }, 1163 | "esprima": { 1164 | "version": "4.0.1", 1165 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1166 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" 1167 | }, 1168 | "esquery": { 1169 | "version": "1.0.1", 1170 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 1171 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 1172 | "requires": { 1173 | "estraverse": "4.2.0" 1174 | } 1175 | }, 1176 | "esrecurse": { 1177 | "version": "4.2.1", 1178 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 1179 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 1180 | "requires": { 1181 | "estraverse": "4.2.0" 1182 | } 1183 | }, 1184 | "estraverse": { 1185 | "version": "4.2.0", 1186 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 1187 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=" 1188 | }, 1189 | "esutils": { 1190 | "version": "2.0.2", 1191 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 1192 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=" 1193 | }, 1194 | "ethereumjs-testrpc-sc": { 1195 | "version": "6.1.6", 1196 | "resolved": "https://registry.npmjs.org/ethereumjs-testrpc-sc/-/ethereumjs-testrpc-sc-6.1.6.tgz", 1197 | "integrity": "sha512-iv2qiGBFgk9mn5Nq2enX8dG5WQ7Lk+FCqpnxfPfH4Ns8KLPwttmNOy264nh3SXDJJvcQwz/XnlLteDQVILotbg==", 1198 | "dev": true, 1199 | "requires": { 1200 | "source-map-support": "0.5.9" 1201 | } 1202 | }, 1203 | "ethereumjs-util": { 1204 | "version": "6.1.0", 1205 | "resolved": "https://registry.npmjs.org/ethereumjs-util/-/ethereumjs-util-6.1.0.tgz", 1206 | "integrity": "sha512-URESKMFbDeJxnAxPppnk2fN6Y3BIatn9fwn76Lm8bQlt+s52TpG8dN9M66MLPuRAiAOIqL3dfwqWJf0sd0fL0Q==", 1207 | "requires": { 1208 | "bn.js": "4.11.8", 1209 | "create-hash": "1.2.0", 1210 | "ethjs-util": "0.1.6", 1211 | "keccak": "1.4.0", 1212 | "rlp": "2.2.3", 1213 | "safe-buffer": "5.1.2", 1214 | "secp256k1": "3.6.2" 1215 | } 1216 | }, 1217 | "ethereumjs-wallet": { 1218 | "version": "0.6.3", 1219 | "resolved": "https://registry.npmjs.org/ethereumjs-wallet/-/ethereumjs-wallet-0.6.3.tgz", 1220 | "integrity": "sha512-qiXPiZOsStem+Dj/CQHbn5qex+FVkuPmGH7SvSnA9F3tdRDt8dLMyvIj3+U05QzVZNPYh4HXEdnzoYI4dZkr9w==", 1221 | "requires": { 1222 | "aes-js": "3.1.2", 1223 | "bs58check": "2.1.2", 1224 | "ethereumjs-util": "6.1.0", 1225 | "hdkey": "1.1.1", 1226 | "randombytes": "2.1.0", 1227 | "safe-buffer": "5.1.2", 1228 | "scrypt.js": "0.3.0", 1229 | "utf8": "3.0.0", 1230 | "uuid": "3.3.2" 1231 | } 1232 | }, 1233 | "ethjs-util": { 1234 | "version": "0.1.6", 1235 | "resolved": "https://registry.npmjs.org/ethjs-util/-/ethjs-util-0.1.6.tgz", 1236 | "integrity": "sha512-CUnVOQq7gSpDHZVVrQW8ExxUETWrnrvXYvYz55wOU8Uj4VCgw56XC2B/fVqQN+f7gmrnRHSLVnFAwsCuNwji8w==", 1237 | "requires": { 1238 | "is-hex-prefixed": "1.0.0", 1239 | "strip-hex-prefix": "1.0.0" 1240 | } 1241 | }, 1242 | "event-emitter": { 1243 | "version": "0.3.5", 1244 | "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", 1245 | "integrity": "sha1-34xp7vFkeSPHFXuc6DhAYQsCzDk=", 1246 | "dev": true, 1247 | "requires": { 1248 | "d": "1.0.0", 1249 | "es5-ext": "0.10.46" 1250 | } 1251 | }, 1252 | "evp_bytestokey": { 1253 | "version": "1.0.3", 1254 | "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", 1255 | "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", 1256 | "requires": { 1257 | "md5.js": "1.3.5", 1258 | "safe-buffer": "5.1.2" 1259 | } 1260 | }, 1261 | "extend": { 1262 | "version": "3.0.2", 1263 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 1264 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 1265 | "dev": true 1266 | }, 1267 | "external-editor": { 1268 | "version": "2.2.0", 1269 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-2.2.0.tgz", 1270 | "integrity": "sha512-bSn6gvGxKt+b7+6TKEv1ZycHleA7aHhRHyAqJyp5pbUFuYYNIzpZnQDk7AsYckyWdEnTeAnay0aCy2aV6iTk9A==", 1271 | "dev": true, 1272 | "requires": { 1273 | "chardet": "0.4.2", 1274 | "iconv-lite": "0.4.24", 1275 | "tmp": "0.0.33" 1276 | } 1277 | }, 1278 | "extsprintf": { 1279 | "version": "1.3.0", 1280 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 1281 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 1282 | "dev": true 1283 | }, 1284 | "fast-deep-equal": { 1285 | "version": "2.0.1", 1286 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 1287 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=" 1288 | }, 1289 | "fast-diff": { 1290 | "version": "1.2.0", 1291 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 1292 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==" 1293 | }, 1294 | "fast-json-stable-stringify": { 1295 | "version": "2.0.0", 1296 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 1297 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=" 1298 | }, 1299 | "fast-levenshtein": { 1300 | "version": "2.0.6", 1301 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1302 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" 1303 | }, 1304 | "figures": { 1305 | "version": "2.0.0", 1306 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 1307 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 1308 | "requires": { 1309 | "escape-string-regexp": "1.0.5" 1310 | } 1311 | }, 1312 | "file-entry-cache": { 1313 | "version": "2.0.0", 1314 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", 1315 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", 1316 | "dev": true, 1317 | "requires": { 1318 | "flat-cache": "1.3.4", 1319 | "object-assign": "4.1.1" 1320 | } 1321 | }, 1322 | "file-uri-to-path": { 1323 | "version": "1.0.0", 1324 | "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", 1325 | "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==" 1326 | }, 1327 | "find-up": { 1328 | "version": "1.1.2", 1329 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 1330 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 1331 | "requires": { 1332 | "path-exists": "2.1.0", 1333 | "pinkie-promise": "2.0.1" 1334 | } 1335 | }, 1336 | "flat-cache": { 1337 | "version": "1.3.4", 1338 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.4.tgz", 1339 | "integrity": "sha512-VwyB3Lkgacfik2vhqR4uv2rvebqmDvFu4jlN/C1RzWoJEo8I7z4Q404oiqYCkq41mni8EzQnm95emU9seckwtg==", 1340 | "dev": true, 1341 | "requires": { 1342 | "circular-json": "0.3.3", 1343 | "graceful-fs": "4.1.15", 1344 | "rimraf": "2.6.2", 1345 | "write": "0.2.1" 1346 | } 1347 | }, 1348 | "flatted": { 1349 | "version": "2.0.0", 1350 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", 1351 | "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==" 1352 | }, 1353 | "forever-agent": { 1354 | "version": "0.6.1", 1355 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 1356 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 1357 | "dev": true 1358 | }, 1359 | "form-data": { 1360 | "version": "2.3.3", 1361 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 1362 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 1363 | "dev": true, 1364 | "requires": { 1365 | "asynckit": "0.4.0", 1366 | "combined-stream": "1.0.7", 1367 | "mime-types": "2.1.21" 1368 | } 1369 | }, 1370 | "frg-ethereum-runners": { 1371 | "version": "git+https://github.com/ampleforth/frg-ethereum-runners.git#15c028c4981aa8b9b6aa681ab9aab7be9efa203d", 1372 | "from": "git+https://github.com/ampleforth/frg-ethereum-runners.git#15c028c4981aa8b9b6aa681ab9aab7be9efa203d", 1373 | "requires": { 1374 | "app-root-path": "2.1.0", 1375 | "bip39": "2.6.0", 1376 | "ethereumjs-wallet": "0.6.3" 1377 | } 1378 | }, 1379 | "fs-extra": { 1380 | "version": "0.30.0", 1381 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-0.30.0.tgz", 1382 | "integrity": "sha1-8jP/zAjU2n1DLapEl3aYnbHfk/A=", 1383 | "requires": { 1384 | "graceful-fs": "4.1.15", 1385 | "jsonfile": "2.4.0", 1386 | "klaw": "1.3.1", 1387 | "path-is-absolute": "1.0.1", 1388 | "rimraf": "2.6.2" 1389 | } 1390 | }, 1391 | "fs.realpath": { 1392 | "version": "1.0.0", 1393 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1394 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 1395 | }, 1396 | "function-bind": { 1397 | "version": "1.1.1", 1398 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1399 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1400 | "dev": true 1401 | }, 1402 | "functional-red-black-tree": { 1403 | "version": "1.0.1", 1404 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1405 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=" 1406 | }, 1407 | "get-caller-file": { 1408 | "version": "1.0.3", 1409 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", 1410 | "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==" 1411 | }, 1412 | "get-func-name": { 1413 | "version": "2.0.0", 1414 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 1415 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 1416 | "dev": true 1417 | }, 1418 | "get-stdin": { 1419 | "version": "5.0.1", 1420 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-5.0.1.tgz", 1421 | "integrity": "sha1-Ei4WFZHiH/TFJTAwVpPyDmOTo5g=", 1422 | "dev": true 1423 | }, 1424 | "getpass": { 1425 | "version": "0.1.7", 1426 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 1427 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 1428 | "dev": true, 1429 | "requires": { 1430 | "assert-plus": "1.0.0" 1431 | } 1432 | }, 1433 | "glob": { 1434 | "version": "7.1.2", 1435 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 1436 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 1437 | "requires": { 1438 | "fs.realpath": "1.0.0", 1439 | "inflight": "1.0.6", 1440 | "inherits": "2.0.3", 1441 | "minimatch": "3.0.4", 1442 | "once": "1.4.0", 1443 | "path-is-absolute": "1.0.1" 1444 | } 1445 | }, 1446 | "globals": { 1447 | "version": "11.9.0", 1448 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.9.0.tgz", 1449 | "integrity": "sha512-5cJVtyXWH8PiJPVLZzzoIizXx944O4OmRro5MWKx5fT4MgcN7OfaMutPeaTdJCCURwbWdhhcCWcKIffPnmTzBg==" 1450 | }, 1451 | "graceful-fs": { 1452 | "version": "4.1.15", 1453 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 1454 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==" 1455 | }, 1456 | "growl": { 1457 | "version": "1.10.3", 1458 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.3.tgz", 1459 | "integrity": "sha512-hKlsbA5Vu3xsh1Cg3J7jSmX/WaW6A5oBeqzM88oNbCRQFz+zUaXm6yxS4RVytp1scBoJzSYl4YAEOQIt6O8V1Q==" 1460 | }, 1461 | "handlebars": { 1462 | "version": "4.0.12", 1463 | "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.0.12.tgz", 1464 | "integrity": "sha512-RhmTekP+FZL+XNhwS1Wf+bTTZpdLougwt5pcgA1tuz6Jcx0fpH/7z0qd71RKnZHBCxIRBHfBOnio4gViPemNzA==", 1465 | "dev": true, 1466 | "requires": { 1467 | "async": "2.6.1", 1468 | "optimist": "0.6.1", 1469 | "source-map": "0.6.1", 1470 | "uglify-js": "3.4.9" 1471 | }, 1472 | "dependencies": { 1473 | "async": { 1474 | "version": "2.6.1", 1475 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.1.tgz", 1476 | "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==", 1477 | "dev": true, 1478 | "requires": { 1479 | "lodash": "4.17.11" 1480 | } 1481 | } 1482 | } 1483 | }, 1484 | "har-schema": { 1485 | "version": "2.0.0", 1486 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 1487 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 1488 | "dev": true 1489 | }, 1490 | "har-validator": { 1491 | "version": "5.1.3", 1492 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 1493 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 1494 | "dev": true, 1495 | "requires": { 1496 | "ajv": "6.6.1", 1497 | "har-schema": "2.0.0" 1498 | } 1499 | }, 1500 | "has": { 1501 | "version": "1.0.3", 1502 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1503 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1504 | "dev": true, 1505 | "requires": { 1506 | "function-bind": "1.1.1" 1507 | } 1508 | }, 1509 | "has-ansi": { 1510 | "version": "2.0.0", 1511 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 1512 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 1513 | "dev": true, 1514 | "requires": { 1515 | "ansi-regex": "2.1.1" 1516 | } 1517 | }, 1518 | "has-flag": { 1519 | "version": "2.0.0", 1520 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 1521 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=" 1522 | }, 1523 | "hash-base": { 1524 | "version": "3.0.4", 1525 | "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.0.4.tgz", 1526 | "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=", 1527 | "requires": { 1528 | "inherits": "2.0.3", 1529 | "safe-buffer": "5.1.2" 1530 | } 1531 | }, 1532 | "hash.js": { 1533 | "version": "1.1.7", 1534 | "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", 1535 | "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", 1536 | "requires": { 1537 | "inherits": "2.0.3", 1538 | "minimalistic-assert": "1.0.1" 1539 | } 1540 | }, 1541 | "hdkey": { 1542 | "version": "1.1.1", 1543 | "resolved": "https://registry.npmjs.org/hdkey/-/hdkey-1.1.1.tgz", 1544 | "integrity": "sha512-DvHZ5OuavsfWs5yfVJZestsnc3wzPvLWNk6c2nRUfo6X+OtxypGt20vDDf7Ba+MJzjL3KS1og2nw2eBbLCOUTA==", 1545 | "requires": { 1546 | "coinstring": "2.3.0", 1547 | "safe-buffer": "5.1.2", 1548 | "secp256k1": "3.6.2" 1549 | } 1550 | }, 1551 | "he": { 1552 | "version": "1.1.1", 1553 | "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", 1554 | "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=" 1555 | }, 1556 | "hmac-drbg": { 1557 | "version": "1.0.1", 1558 | "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", 1559 | "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", 1560 | "requires": { 1561 | "hash.js": "1.1.7", 1562 | "minimalistic-assert": "1.0.1", 1563 | "minimalistic-crypto-utils": "1.0.1" 1564 | } 1565 | }, 1566 | "hosted-git-info": { 1567 | "version": "2.7.1", 1568 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 1569 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==" 1570 | }, 1571 | "http-signature": { 1572 | "version": "1.2.0", 1573 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 1574 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 1575 | "dev": true, 1576 | "requires": { 1577 | "assert-plus": "1.0.0", 1578 | "jsprim": "1.4.1", 1579 | "sshpk": "1.15.2" 1580 | } 1581 | }, 1582 | "hunspell-spellchecker": { 1583 | "version": "1.0.2", 1584 | "resolved": "https://registry.npmjs.org/hunspell-spellchecker/-/hunspell-spellchecker-1.0.2.tgz", 1585 | "integrity": "sha1-oQsL0voAplq2Kkxrc0zkltMYkQ4=", 1586 | "dev": true 1587 | }, 1588 | "iconv-lite": { 1589 | "version": "0.4.24", 1590 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1591 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1592 | "requires": { 1593 | "safer-buffer": "2.1.2" 1594 | } 1595 | }, 1596 | "ignore": { 1597 | "version": "3.3.10", 1598 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", 1599 | "integrity": "sha512-Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug==", 1600 | "dev": true 1601 | }, 1602 | "import-fresh": { 1603 | "version": "2.0.0", 1604 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", 1605 | "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", 1606 | "requires": { 1607 | "caller-path": "2.0.0", 1608 | "resolve-from": "3.0.0" 1609 | }, 1610 | "dependencies": { 1611 | "caller-path": { 1612 | "version": "2.0.0", 1613 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", 1614 | "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", 1615 | "requires": { 1616 | "caller-callsite": "2.0.0" 1617 | } 1618 | }, 1619 | "resolve-from": { 1620 | "version": "3.0.0", 1621 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", 1622 | "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=" 1623 | } 1624 | } 1625 | }, 1626 | "imurmurhash": { 1627 | "version": "0.1.4", 1628 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1629 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 1630 | }, 1631 | "inflight": { 1632 | "version": "1.0.6", 1633 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1634 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1635 | "requires": { 1636 | "once": "1.4.0", 1637 | "wrappy": "1.0.2" 1638 | } 1639 | }, 1640 | "inherits": { 1641 | "version": "2.0.3", 1642 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1643 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1644 | }, 1645 | "inquirer": { 1646 | "version": "3.3.0", 1647 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-3.3.0.tgz", 1648 | "integrity": "sha512-h+xtnyk4EwKvFWHrUYsWErEVR+igKtLdchu+o0Z1RL7VU/jVMFbYir2bp6bAj8efFNxWqHX0dIss6fJQ+/+qeQ==", 1649 | "dev": true, 1650 | "requires": { 1651 | "ansi-escapes": "3.1.0", 1652 | "chalk": "2.4.1", 1653 | "cli-cursor": "2.1.0", 1654 | "cli-width": "2.2.0", 1655 | "external-editor": "2.2.0", 1656 | "figures": "2.0.0", 1657 | "lodash": "4.17.11", 1658 | "mute-stream": "0.0.7", 1659 | "run-async": "2.3.0", 1660 | "rx-lite": "4.0.8", 1661 | "rx-lite-aggregates": "4.0.8", 1662 | "string-width": "2.1.1", 1663 | "strip-ansi": "4.0.0", 1664 | "through": "2.3.8" 1665 | }, 1666 | "dependencies": { 1667 | "ansi-regex": { 1668 | "version": "3.0.0", 1669 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1670 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1671 | "dev": true 1672 | }, 1673 | "is-fullwidth-code-point": { 1674 | "version": "2.0.0", 1675 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1676 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1677 | "dev": true 1678 | }, 1679 | "string-width": { 1680 | "version": "2.1.1", 1681 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1682 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1683 | "dev": true, 1684 | "requires": { 1685 | "is-fullwidth-code-point": "2.0.0", 1686 | "strip-ansi": "4.0.0" 1687 | } 1688 | }, 1689 | "strip-ansi": { 1690 | "version": "4.0.0", 1691 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1692 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1693 | "dev": true, 1694 | "requires": { 1695 | "ansi-regex": "3.0.0" 1696 | } 1697 | } 1698 | } 1699 | }, 1700 | "interpret": { 1701 | "version": "1.1.0", 1702 | "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.1.0.tgz", 1703 | "integrity": "sha1-ftGxQQxqDg94z5XTuEQMY/eLhhQ=", 1704 | "dev": true 1705 | }, 1706 | "invert-kv": { 1707 | "version": "1.0.0", 1708 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", 1709 | "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=" 1710 | }, 1711 | "is-arrayish": { 1712 | "version": "0.2.1", 1713 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1714 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" 1715 | }, 1716 | "is-builtin-module": { 1717 | "version": "1.0.0", 1718 | "resolved": "http://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 1719 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 1720 | "requires": { 1721 | "builtin-modules": "1.1.1" 1722 | } 1723 | }, 1724 | "is-directory": { 1725 | "version": "0.3.1", 1726 | "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", 1727 | "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=" 1728 | }, 1729 | "is-fullwidth-code-point": { 1730 | "version": "1.0.0", 1731 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1732 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1733 | "requires": { 1734 | "number-is-nan": "1.0.1" 1735 | } 1736 | }, 1737 | "is-hex-prefixed": { 1738 | "version": "1.0.0", 1739 | "resolved": "https://registry.npmjs.org/is-hex-prefixed/-/is-hex-prefixed-1.0.0.tgz", 1740 | "integrity": "sha1-fY035q135dEnFIkTxXPggtd39VQ=" 1741 | }, 1742 | "is-promise": { 1743 | "version": "2.1.0", 1744 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1745 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" 1746 | }, 1747 | "is-resolvable": { 1748 | "version": "1.1.0", 1749 | "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", 1750 | "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", 1751 | "dev": true 1752 | }, 1753 | "is-typedarray": { 1754 | "version": "1.0.0", 1755 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1756 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1757 | "dev": true 1758 | }, 1759 | "is-utf8": { 1760 | "version": "0.2.1", 1761 | "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", 1762 | "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=" 1763 | }, 1764 | "isarray": { 1765 | "version": "1.0.0", 1766 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1767 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1768 | "dev": true 1769 | }, 1770 | "isexe": { 1771 | "version": "2.0.0", 1772 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1773 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 1774 | }, 1775 | "isstream": { 1776 | "version": "0.1.2", 1777 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1778 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 1779 | "dev": true 1780 | }, 1781 | "istanbul": { 1782 | "version": "0.4.5", 1783 | "resolved": "https://registry.npmjs.org/istanbul/-/istanbul-0.4.5.tgz", 1784 | "integrity": "sha1-ZcfXPUxNqE1POsMQuRj7C4Azczs=", 1785 | "dev": true, 1786 | "requires": { 1787 | "abbrev": "1.0.9", 1788 | "async": "1.5.2", 1789 | "escodegen": "1.8.1", 1790 | "esprima": "2.7.3", 1791 | "glob": "5.0.15", 1792 | "handlebars": "4.0.12", 1793 | "js-yaml": "3.12.0", 1794 | "mkdirp": "0.5.1", 1795 | "nopt": "3.0.6", 1796 | "once": "1.4.0", 1797 | "resolve": "1.1.7", 1798 | "supports-color": "3.2.3", 1799 | "which": "1.3.1", 1800 | "wordwrap": "1.0.0" 1801 | }, 1802 | "dependencies": { 1803 | "esprima": { 1804 | "version": "2.7.3", 1805 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", 1806 | "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", 1807 | "dev": true 1808 | }, 1809 | "glob": { 1810 | "version": "5.0.15", 1811 | "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", 1812 | "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", 1813 | "dev": true, 1814 | "requires": { 1815 | "inflight": "1.0.6", 1816 | "inherits": "2.0.3", 1817 | "minimatch": "3.0.4", 1818 | "once": "1.4.0", 1819 | "path-is-absolute": "1.0.1" 1820 | } 1821 | }, 1822 | "has-flag": { 1823 | "version": "1.0.0", 1824 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-1.0.0.tgz", 1825 | "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", 1826 | "dev": true 1827 | }, 1828 | "js-yaml": { 1829 | "version": "3.12.0", 1830 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 1831 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 1832 | "dev": true, 1833 | "requires": { 1834 | "argparse": "^1.0.7", 1835 | "esprima": "^4.0.0" 1836 | }, 1837 | "dependencies": { 1838 | "esprima": { 1839 | "version": "4.0.1", 1840 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1841 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1842 | "dev": true 1843 | } 1844 | } 1845 | }, 1846 | "resolve": { 1847 | "version": "1.1.7", 1848 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", 1849 | "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", 1850 | "dev": true 1851 | }, 1852 | "supports-color": { 1853 | "version": "3.2.3", 1854 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", 1855 | "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", 1856 | "dev": true, 1857 | "requires": { 1858 | "has-flag": "1.0.0" 1859 | } 1860 | } 1861 | } 1862 | }, 1863 | "jest-docblock": { 1864 | "version": "21.2.0", 1865 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-21.2.0.tgz", 1866 | "integrity": "sha512-5IZ7sY9dBAYSV+YjQ0Ovb540Ku7AO9Z5o2Cg789xj167iQuZ2cG+z0f3Uct6WeYLbU6aQiM2pCs7sZ+4dotydw==", 1867 | "dev": true 1868 | }, 1869 | "js-sha3": { 1870 | "version": "0.3.1", 1871 | "resolved": "https://registry.npmjs.org/js-sha3/-/js-sha3-0.3.1.tgz", 1872 | "integrity": "sha1-hhIoAhQvCChQKg0d7h2V4lO7AkM=", 1873 | "dev": true 1874 | }, 1875 | "js-tokens": { 1876 | "version": "3.0.2", 1877 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 1878 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", 1879 | "dev": true 1880 | }, 1881 | "js-yaml": { 1882 | "version": "3.13.1", 1883 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1884 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1885 | "requires": { 1886 | "argparse": "^1.0.7", 1887 | "esprima": "^4.0.0" 1888 | } 1889 | }, 1890 | "jsbn": { 1891 | "version": "0.1.1", 1892 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1893 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1894 | "dev": true 1895 | }, 1896 | "json-parse-better-errors": { 1897 | "version": "1.0.2", 1898 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1899 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==" 1900 | }, 1901 | "json-schema": { 1902 | "version": "0.2.3", 1903 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 1904 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 1905 | "dev": true 1906 | }, 1907 | "json-schema-traverse": { 1908 | "version": "0.4.1", 1909 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1910 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 1911 | }, 1912 | "json-stable-stringify-without-jsonify": { 1913 | "version": "1.0.1", 1914 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1915 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=" 1916 | }, 1917 | "json-stringify-safe": { 1918 | "version": "5.0.1", 1919 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 1920 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 1921 | "dev": true 1922 | }, 1923 | "jsonfile": { 1924 | "version": "2.4.0", 1925 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz", 1926 | "integrity": "sha1-NzaitCi4e72gzIO1P6PWM6NcKug=", 1927 | "requires": { 1928 | "graceful-fs": "4.1.15" 1929 | } 1930 | }, 1931 | "jsprim": { 1932 | "version": "1.4.1", 1933 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 1934 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 1935 | "dev": true, 1936 | "requires": { 1937 | "assert-plus": "1.0.0", 1938 | "extsprintf": "1.3.0", 1939 | "json-schema": "0.2.3", 1940 | "verror": "1.10.0" 1941 | } 1942 | }, 1943 | "keccak": { 1944 | "version": "1.4.0", 1945 | "resolved": "https://registry.npmjs.org/keccak/-/keccak-1.4.0.tgz", 1946 | "integrity": "sha512-eZVaCpblK5formjPjeTBik7TAg+pqnDrMHIffSvi9Lh7PQgM1+hSzakUeZFCk9DVVG0dacZJuaz2ntwlzZUIBw==", 1947 | "requires": { 1948 | "bindings": "1.5.0", 1949 | "inherits": "2.0.3", 1950 | "nan": "2.13.2", 1951 | "safe-buffer": "5.1.2" 1952 | } 1953 | }, 1954 | "keccakjs": { 1955 | "version": "0.2.1", 1956 | "resolved": "https://registry.npmjs.org/keccakjs/-/keccakjs-0.2.1.tgz", 1957 | "integrity": "sha1-HWM6+QfvMFu/ny+mFtVsRFYd+k0=", 1958 | "dev": true, 1959 | "requires": { 1960 | "browserify-sha3": "0.0.1", 1961 | "sha3": "1.2.2" 1962 | } 1963 | }, 1964 | "klaw": { 1965 | "version": "1.3.1", 1966 | "resolved": "https://registry.npmjs.org/klaw/-/klaw-1.3.1.tgz", 1967 | "integrity": "sha1-QIhDO0azsbolnXh4XY6W9zugJDk=", 1968 | "requires": { 1969 | "graceful-fs": "4.1.15" 1970 | } 1971 | }, 1972 | "lcid": { 1973 | "version": "1.0.0", 1974 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", 1975 | "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", 1976 | "requires": { 1977 | "invert-kv": "1.0.0" 1978 | } 1979 | }, 1980 | "lcov-parse": { 1981 | "version": "0.0.10", 1982 | "resolved": "https://registry.npmjs.org/lcov-parse/-/lcov-parse-0.0.10.tgz", 1983 | "integrity": "sha1-GwuP+ayceIklBYK3C3ExXZ2m2aM=", 1984 | "dev": true 1985 | }, 1986 | "levn": { 1987 | "version": "0.3.0", 1988 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1989 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1990 | "requires": { 1991 | "prelude-ls": "1.1.2", 1992 | "type-check": "0.3.2" 1993 | } 1994 | }, 1995 | "load-json-file": { 1996 | "version": "1.1.0", 1997 | "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", 1998 | "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", 1999 | "requires": { 2000 | "graceful-fs": "4.1.15", 2001 | "parse-json": "2.2.0", 2002 | "pify": "2.3.0", 2003 | "pinkie-promise": "2.0.1", 2004 | "strip-bom": "2.0.0" 2005 | } 2006 | }, 2007 | "lodash": { 2008 | "version": "4.17.11", 2009 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 2010 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" 2011 | }, 2012 | "lodash.assign": { 2013 | "version": "4.2.0", 2014 | "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-4.2.0.tgz", 2015 | "integrity": "sha1-DZnzzNem0mHRm9rrkkUAXShYCOc=" 2016 | }, 2017 | "lodash.cond": { 2018 | "version": "4.5.2", 2019 | "resolved": "https://registry.npmjs.org/lodash.cond/-/lodash.cond-4.5.2.tgz", 2020 | "integrity": "sha1-9HGh2khr5g9quVXRcRVSPdHSVdU=", 2021 | "dev": true 2022 | }, 2023 | "lodash.endswith": { 2024 | "version": "4.2.1", 2025 | "resolved": "https://registry.npmjs.org/lodash.endswith/-/lodash.endswith-4.2.1.tgz", 2026 | "integrity": "sha1-/tWawXOO0+I27dcGTsRWRIs3vAk=", 2027 | "dev": true 2028 | }, 2029 | "lodash.find": { 2030 | "version": "4.6.0", 2031 | "resolved": "https://registry.npmjs.org/lodash.find/-/lodash.find-4.6.0.tgz", 2032 | "integrity": "sha1-ywcE1Hq3F4n/oN6Ll92Sb7iLE7E=", 2033 | "dev": true 2034 | }, 2035 | "lodash.findindex": { 2036 | "version": "4.6.0", 2037 | "resolved": "https://registry.npmjs.org/lodash.findindex/-/lodash.findindex-4.6.0.tgz", 2038 | "integrity": "sha1-oyRd7mH7m24GJLU1ElYku2nBEQY=", 2039 | "dev": true 2040 | }, 2041 | "lodash.get": { 2042 | "version": "4.4.2", 2043 | "resolved": "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz", 2044 | "integrity": "sha1-LRd/ZS+jHpObRDjVNBSZ36OCXpk=" 2045 | }, 2046 | "lodash.mergewith": { 2047 | "version": "4.6.1", 2048 | "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.1.tgz", 2049 | "integrity": "sha512-eWw5r+PYICtEBgrBE5hhlT6aAa75f411bgDz/ZL2KZqYV03USvucsxcHUIlGTDTECs1eunpI7HOV7U+WLDvNdQ==", 2050 | "dev": true 2051 | }, 2052 | "log-driver": { 2053 | "version": "1.2.7", 2054 | "resolved": "https://registry.npmjs.org/log-driver/-/log-driver-1.2.7.tgz", 2055 | "integrity": "sha512-U7KCmLdqsGHBLeWqYlFA0V0Sl6P08EE1ZrmA9cxjUE0WVqT9qnyVDPz1kzpFEP0jdJuFnasWIfSd7fsaNXkpbg==", 2056 | "dev": true 2057 | }, 2058 | "lru-cache": { 2059 | "version": "4.1.5", 2060 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 2061 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 2062 | "dev": true, 2063 | "requires": { 2064 | "pseudomap": "1.0.2", 2065 | "yallist": "2.1.2" 2066 | } 2067 | }, 2068 | "md5.js": { 2069 | "version": "1.3.5", 2070 | "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", 2071 | "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", 2072 | "requires": { 2073 | "hash-base": "3.0.4", 2074 | "inherits": "2.0.3", 2075 | "safe-buffer": "5.1.2" 2076 | } 2077 | }, 2078 | "memorystream": { 2079 | "version": "0.3.1", 2080 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 2081 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=" 2082 | }, 2083 | "mime-db": { 2084 | "version": "1.37.0", 2085 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz", 2086 | "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg==", 2087 | "dev": true 2088 | }, 2089 | "mime-types": { 2090 | "version": "2.1.21", 2091 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz", 2092 | "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==", 2093 | "dev": true, 2094 | "requires": { 2095 | "mime-db": "1.37.0" 2096 | } 2097 | }, 2098 | "mimic-fn": { 2099 | "version": "1.2.0", 2100 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 2101 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==" 2102 | }, 2103 | "minimalistic-assert": { 2104 | "version": "1.0.1", 2105 | "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", 2106 | "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==" 2107 | }, 2108 | "minimalistic-crypto-utils": { 2109 | "version": "1.0.1", 2110 | "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", 2111 | "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=" 2112 | }, 2113 | "minimatch": { 2114 | "version": "3.0.4", 2115 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2116 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2117 | "requires": { 2118 | "brace-expansion": "1.1.11" 2119 | } 2120 | }, 2121 | "minimist": { 2122 | "version": "0.0.8", 2123 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 2124 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 2125 | }, 2126 | "mkdirp": { 2127 | "version": "0.5.1", 2128 | "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 2129 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 2130 | "requires": { 2131 | "minimist": "0.0.8" 2132 | } 2133 | }, 2134 | "mocha": { 2135 | "version": "4.1.0", 2136 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-4.1.0.tgz", 2137 | "integrity": "sha512-0RVnjg1HJsXY2YFDoTNzcc1NKhYuXKRrBAG2gDygmJJA136Cs2QlRliZG1mA0ap7cuaT30mw16luAeln+4RiNA==", 2138 | "requires": { 2139 | "browser-stdout": "1.3.0", 2140 | "commander": "2.11.0", 2141 | "debug": "3.1.0", 2142 | "diff": "3.3.1", 2143 | "escape-string-regexp": "1.0.5", 2144 | "glob": "7.1.2", 2145 | "growl": "1.10.3", 2146 | "he": "1.1.1", 2147 | "mkdirp": "0.5.1", 2148 | "supports-color": "4.4.0" 2149 | } 2150 | }, 2151 | "ms": { 2152 | "version": "2.0.0", 2153 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2154 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2155 | }, 2156 | "mute-stream": { 2157 | "version": "0.0.7", 2158 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 2159 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=" 2160 | }, 2161 | "nan": { 2162 | "version": "2.13.2", 2163 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.13.2.tgz", 2164 | "integrity": "sha512-TghvYc72wlMGMVMluVo9WRJc0mB8KxxF/gZ4YYFy7V2ZQX9l7rgbPg7vjS9mt6U5HXODVFVI2bOduCzwOMv/lw==" 2165 | }, 2166 | "natural-compare": { 2167 | "version": "1.4.0", 2168 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2169 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=" 2170 | }, 2171 | "next-tick": { 2172 | "version": "1.0.0", 2173 | "resolved": "http://registry.npmjs.org/next-tick/-/next-tick-1.0.0.tgz", 2174 | "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=", 2175 | "dev": true 2176 | }, 2177 | "nice-try": { 2178 | "version": "1.0.5", 2179 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 2180 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" 2181 | }, 2182 | "nopt": { 2183 | "version": "3.0.6", 2184 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", 2185 | "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", 2186 | "dev": true, 2187 | "requires": { 2188 | "abbrev": "1.0.9" 2189 | } 2190 | }, 2191 | "normalize-package-data": { 2192 | "version": "2.4.0", 2193 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 2194 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 2195 | "requires": { 2196 | "hosted-git-info": "2.7.1", 2197 | "is-builtin-module": "1.0.0", 2198 | "semver": "5.6.0", 2199 | "validate-npm-package-license": "3.0.4" 2200 | } 2201 | }, 2202 | "number-is-nan": { 2203 | "version": "1.0.1", 2204 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 2205 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 2206 | }, 2207 | "oauth-sign": { 2208 | "version": "0.9.0", 2209 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 2210 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 2211 | "dev": true 2212 | }, 2213 | "object-assign": { 2214 | "version": "4.1.1", 2215 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2216 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 2217 | "dev": true 2218 | }, 2219 | "once": { 2220 | "version": "1.4.0", 2221 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2222 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2223 | "requires": { 2224 | "wrappy": "1.0.2" 2225 | } 2226 | }, 2227 | "onetime": { 2228 | "version": "2.0.1", 2229 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 2230 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 2231 | "requires": { 2232 | "mimic-fn": "1.2.0" 2233 | } 2234 | }, 2235 | "openzeppelin-solidity": { 2236 | "version": "2.0.0", 2237 | "resolved": "https://registry.npmjs.org/openzeppelin-solidity/-/openzeppelin-solidity-2.0.0.tgz", 2238 | "integrity": "sha512-SolpxQFArtiYnlSNg3dZ9sz0WVlKtPqSOcJkXRllaZp4+Lpfqz3vxF0yoh7g75TszKPyadqoJmU7+GM/vwh9SA==" 2239 | }, 2240 | "optimist": { 2241 | "version": "0.6.1", 2242 | "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz", 2243 | "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=", 2244 | "dev": true, 2245 | "requires": { 2246 | "minimist": "0.0.8", 2247 | "wordwrap": "0.0.3" 2248 | }, 2249 | "dependencies": { 2250 | "wordwrap": { 2251 | "version": "0.0.3", 2252 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", 2253 | "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", 2254 | "dev": true 2255 | } 2256 | } 2257 | }, 2258 | "optionator": { 2259 | "version": "0.8.2", 2260 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 2261 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 2262 | "requires": { 2263 | "deep-is": "0.1.3", 2264 | "fast-levenshtein": "2.0.6", 2265 | "levn": "0.3.0", 2266 | "prelude-ls": "1.1.2", 2267 | "type-check": "0.3.2", 2268 | "wordwrap": "1.0.0" 2269 | } 2270 | }, 2271 | "original-require": { 2272 | "version": "1.0.1", 2273 | "resolved": "https://registry.npmjs.org/original-require/-/original-require-1.0.1.tgz", 2274 | "integrity": "sha1-DxMEcVhM0zURxew4yNWSE/msXiA=" 2275 | }, 2276 | "os-locale": { 2277 | "version": "1.4.0", 2278 | "resolved": "http://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", 2279 | "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=", 2280 | "requires": { 2281 | "lcid": "1.0.0" 2282 | } 2283 | }, 2284 | "os-shim": { 2285 | "version": "0.1.3", 2286 | "resolved": "https://registry.npmjs.org/os-shim/-/os-shim-0.1.3.tgz", 2287 | "integrity": "sha1-a2LDeRz3kJ6jXtRuF2WLtBfLORc=", 2288 | "dev": true 2289 | }, 2290 | "os-tmpdir": { 2291 | "version": "1.0.2", 2292 | "resolved": "http://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2293 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 2294 | }, 2295 | "parent-module": { 2296 | "version": "1.0.0", 2297 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.0.tgz", 2298 | "integrity": "sha512-8Mf5juOMmiE4FcmzYc4IaiS9L3+9paz2KOiXzkRviCP6aDmN49Hz6EMWz0lGNp9pX80GvvAuLADtyGfW/Em3TA==", 2299 | "requires": { 2300 | "callsites": "3.0.0" 2301 | }, 2302 | "dependencies": { 2303 | "callsites": { 2304 | "version": "3.0.0", 2305 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.0.0.tgz", 2306 | "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==" 2307 | } 2308 | } 2309 | }, 2310 | "parse-json": { 2311 | "version": "2.2.0", 2312 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 2313 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 2314 | "requires": { 2315 | "error-ex": "1.3.2" 2316 | } 2317 | }, 2318 | "path-exists": { 2319 | "version": "2.1.0", 2320 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 2321 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 2322 | "requires": { 2323 | "pinkie-promise": "2.0.1" 2324 | } 2325 | }, 2326 | "path-is-absolute": { 2327 | "version": "1.0.1", 2328 | "resolved": "http://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2329 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 2330 | }, 2331 | "path-is-inside": { 2332 | "version": "1.0.2", 2333 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 2334 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=" 2335 | }, 2336 | "path-key": { 2337 | "version": "2.0.1", 2338 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2339 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 2340 | }, 2341 | "path-parse": { 2342 | "version": "1.0.6", 2343 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2344 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 2345 | "dev": true 2346 | }, 2347 | "path-type": { 2348 | "version": "1.1.0", 2349 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", 2350 | "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", 2351 | "requires": { 2352 | "graceful-fs": "4.1.15", 2353 | "pify": "2.3.0", 2354 | "pinkie-promise": "2.0.1" 2355 | } 2356 | }, 2357 | "pathval": { 2358 | "version": "1.1.0", 2359 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz", 2360 | "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=", 2361 | "dev": true 2362 | }, 2363 | "pbkdf2": { 2364 | "version": "3.0.17", 2365 | "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.0.17.tgz", 2366 | "integrity": "sha512-U/il5MsrZp7mGg3mSQfn742na2T+1/vHDCG5/iTI3X9MKUuYUZVLQhyRsg06mCgDBTd57TxzgZt7P+fYfjRLtA==", 2367 | "requires": { 2368 | "create-hash": "1.2.0", 2369 | "create-hmac": "1.1.7", 2370 | "ripemd160": "2.0.2", 2371 | "safe-buffer": "5.1.2", 2372 | "sha.js": "2.4.11" 2373 | } 2374 | }, 2375 | "pegjs": { 2376 | "version": "0.10.0", 2377 | "resolved": "http://registry.npmjs.org/pegjs/-/pegjs-0.10.0.tgz", 2378 | "integrity": "sha1-z4uvrm7d/0tafvsYUmnqr0YQ3b0=", 2379 | "dev": true 2380 | }, 2381 | "performance-now": { 2382 | "version": "2.1.0", 2383 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 2384 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 2385 | "dev": true 2386 | }, 2387 | "pify": { 2388 | "version": "2.3.0", 2389 | "resolved": "http://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 2390 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" 2391 | }, 2392 | "pinkie": { 2393 | "version": "2.0.4", 2394 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 2395 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=" 2396 | }, 2397 | "pinkie-promise": { 2398 | "version": "2.0.1", 2399 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 2400 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 2401 | "requires": { 2402 | "pinkie": "2.0.4" 2403 | } 2404 | }, 2405 | "pkg-dir": { 2406 | "version": "1.0.0", 2407 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", 2408 | "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", 2409 | "dev": true, 2410 | "requires": { 2411 | "find-up": "1.1.2" 2412 | } 2413 | }, 2414 | "pkg-up": { 2415 | "version": "1.0.0", 2416 | "resolved": "https://registry.npmjs.org/pkg-up/-/pkg-up-1.0.0.tgz", 2417 | "integrity": "sha1-Pgj7RhUlxEIWJKM7n35tCvWwWiY=", 2418 | "dev": true, 2419 | "requires": { 2420 | "find-up": "1.1.2" 2421 | } 2422 | }, 2423 | "pluralize": { 2424 | "version": "7.0.0", 2425 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", 2426 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", 2427 | "dev": true 2428 | }, 2429 | "pre-commit": { 2430 | "version": "1.2.2", 2431 | "resolved": "https://registry.npmjs.org/pre-commit/-/pre-commit-1.2.2.tgz", 2432 | "integrity": "sha1-287g7p3nI15X95xW186UZBpp7sY=", 2433 | "dev": true, 2434 | "requires": { 2435 | "cross-spawn": "5.1.0", 2436 | "spawn-sync": "1.0.15", 2437 | "which": "1.2.14" 2438 | }, 2439 | "dependencies": { 2440 | "which": { 2441 | "version": "1.2.14", 2442 | "resolved": "https://registry.npmjs.org/which/-/which-1.2.14.tgz", 2443 | "integrity": "sha1-mofEN48D6CfOyvGs31bHNsAcFOU=", 2444 | "dev": true, 2445 | "requires": { 2446 | "isexe": "2.0.0" 2447 | } 2448 | } 2449 | } 2450 | }, 2451 | "prelude-ls": { 2452 | "version": "1.1.2", 2453 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2454 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" 2455 | }, 2456 | "prettier": { 2457 | "version": "1.15.3", 2458 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.15.3.tgz", 2459 | "integrity": "sha512-gAU9AGAPMaKb3NNSUUuhhFAS7SCO4ALTN4nRIn6PJ075Qd28Yn2Ig2ahEJWdJwJmlEBTUfC7mMUSFy8MwsOCfg==" 2460 | }, 2461 | "process-nextick-args": { 2462 | "version": "2.0.0", 2463 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 2464 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 2465 | "dev": true 2466 | }, 2467 | "progress": { 2468 | "version": "2.0.3", 2469 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2470 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==" 2471 | }, 2472 | "pseudomap": { 2473 | "version": "1.0.2", 2474 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2475 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 2476 | "dev": true 2477 | }, 2478 | "psl": { 2479 | "version": "1.1.29", 2480 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz", 2481 | "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==", 2482 | "dev": true 2483 | }, 2484 | "punycode": { 2485 | "version": "2.1.1", 2486 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2487 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" 2488 | }, 2489 | "qs": { 2490 | "version": "6.5.2", 2491 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 2492 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 2493 | "dev": true 2494 | }, 2495 | "randombytes": { 2496 | "version": "2.1.0", 2497 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2498 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2499 | "requires": { 2500 | "safe-buffer": "5.1.2" 2501 | } 2502 | }, 2503 | "read-pkg": { 2504 | "version": "1.1.0", 2505 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", 2506 | "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", 2507 | "requires": { 2508 | "load-json-file": "1.1.0", 2509 | "normalize-package-data": "2.4.0", 2510 | "path-type": "1.1.0" 2511 | } 2512 | }, 2513 | "read-pkg-up": { 2514 | "version": "1.0.1", 2515 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", 2516 | "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=", 2517 | "requires": { 2518 | "find-up": "1.1.2", 2519 | "read-pkg": "1.1.0" 2520 | } 2521 | }, 2522 | "readable-stream": { 2523 | "version": "2.3.6", 2524 | "resolved": "http://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2525 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2526 | "dev": true, 2527 | "requires": { 2528 | "core-util-is": "1.0.2", 2529 | "inherits": "2.0.3", 2530 | "isarray": "1.0.0", 2531 | "process-nextick-args": "2.0.0", 2532 | "safe-buffer": "5.1.2", 2533 | "string_decoder": "1.1.1", 2534 | "util-deprecate": "1.0.2" 2535 | } 2536 | }, 2537 | "rechoir": { 2538 | "version": "0.6.2", 2539 | "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", 2540 | "integrity": "sha1-hSBLVNuoLVdC4oyWdW70OvUOM4Q=", 2541 | "dev": true, 2542 | "requires": { 2543 | "resolve": "1.8.1" 2544 | } 2545 | }, 2546 | "regexpp": { 2547 | "version": "1.1.0", 2548 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-1.1.0.tgz", 2549 | "integrity": "sha512-LOPw8FpgdQF9etWMaAfG/WRthIdXJGYp4mJ2Jgn/2lpkbod9jPn0t9UqN7AxBOKNfzRbYyVfgc7Vk4t/MpnXgw==", 2550 | "dev": true 2551 | }, 2552 | "req-cwd": { 2553 | "version": "1.0.1", 2554 | "resolved": "http://registry.npmjs.org/req-cwd/-/req-cwd-1.0.1.tgz", 2555 | "integrity": "sha1-DXOurpJm5penj3l2AZZ352rPD/8=", 2556 | "dev": true, 2557 | "requires": { 2558 | "req-from": "1.0.1" 2559 | } 2560 | }, 2561 | "req-from": { 2562 | "version": "1.0.1", 2563 | "resolved": "http://registry.npmjs.org/req-from/-/req-from-1.0.1.tgz", 2564 | "integrity": "sha1-v4HaUUeUfTLRO5R9wSpYrUWHNQ4=", 2565 | "dev": true, 2566 | "requires": { 2567 | "resolve-from": "2.0.0" 2568 | }, 2569 | "dependencies": { 2570 | "resolve-from": { 2571 | "version": "2.0.0", 2572 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 2573 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=", 2574 | "dev": true 2575 | } 2576 | } 2577 | }, 2578 | "request": { 2579 | "version": "2.88.0", 2580 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 2581 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 2582 | "dev": true, 2583 | "requires": { 2584 | "aws-sign2": "0.7.0", 2585 | "aws4": "1.8.0", 2586 | "caseless": "0.12.0", 2587 | "combined-stream": "1.0.7", 2588 | "extend": "3.0.2", 2589 | "forever-agent": "0.6.1", 2590 | "form-data": "2.3.3", 2591 | "har-validator": "5.1.3", 2592 | "http-signature": "1.2.0", 2593 | "is-typedarray": "1.0.0", 2594 | "isstream": "0.1.2", 2595 | "json-stringify-safe": "5.0.1", 2596 | "mime-types": "2.1.21", 2597 | "oauth-sign": "0.9.0", 2598 | "performance-now": "2.1.0", 2599 | "qs": "6.5.2", 2600 | "safe-buffer": "5.1.2", 2601 | "tough-cookie": "2.4.3", 2602 | "tunnel-agent": "0.6.0", 2603 | "uuid": "3.3.2" 2604 | } 2605 | }, 2606 | "require-directory": { 2607 | "version": "2.1.1", 2608 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2609 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" 2610 | }, 2611 | "require-main-filename": { 2612 | "version": "1.0.1", 2613 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", 2614 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=" 2615 | }, 2616 | "require-uncached": { 2617 | "version": "1.0.3", 2618 | "resolved": "http://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", 2619 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", 2620 | "dev": true, 2621 | "requires": { 2622 | "caller-path": "0.1.0", 2623 | "resolve-from": "1.0.1" 2624 | } 2625 | }, 2626 | "resolve": { 2627 | "version": "1.8.1", 2628 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.8.1.tgz", 2629 | "integrity": "sha512-AicPrAC7Qu1JxPCZ9ZgCZlY35QgFnNqc+0LtbRNxnVw4TXvjQ72wnuL9JQcEBgXkI9JM8MsT9kaQoHcpCRJOYA==", 2630 | "dev": true, 2631 | "requires": { 2632 | "path-parse": "1.0.6" 2633 | } 2634 | }, 2635 | "resolve-from": { 2636 | "version": "1.0.1", 2637 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", 2638 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", 2639 | "dev": true 2640 | }, 2641 | "restore-cursor": { 2642 | "version": "2.0.0", 2643 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 2644 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 2645 | "requires": { 2646 | "onetime": "2.0.1", 2647 | "signal-exit": "3.0.2" 2648 | } 2649 | }, 2650 | "rimraf": { 2651 | "version": "2.6.2", 2652 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 2653 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 2654 | "requires": { 2655 | "glob": "7.1.2" 2656 | } 2657 | }, 2658 | "ripemd160": { 2659 | "version": "2.0.2", 2660 | "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", 2661 | "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", 2662 | "requires": { 2663 | "hash-base": "3.0.4", 2664 | "inherits": "2.0.3" 2665 | } 2666 | }, 2667 | "rlp": { 2668 | "version": "2.2.3", 2669 | "resolved": "https://registry.npmjs.org/rlp/-/rlp-2.2.3.tgz", 2670 | "integrity": "sha512-l6YVrI7+d2vpW6D6rS05x2Xrmq8oW7v3pieZOJKBEdjuTF4Kz/iwk55Zyh1Zaz+KOB2kC8+2jZlp2u9L4tTzCQ==", 2671 | "requires": { 2672 | "bn.js": "4.11.8", 2673 | "safe-buffer": "5.1.2" 2674 | } 2675 | }, 2676 | "run-async": { 2677 | "version": "2.3.0", 2678 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 2679 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 2680 | "requires": { 2681 | "is-promise": "2.1.0" 2682 | } 2683 | }, 2684 | "rx-lite": { 2685 | "version": "4.0.8", 2686 | "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-4.0.8.tgz", 2687 | "integrity": "sha1-Cx4Rr4vESDbwSmQH6S2kJGe3lEQ=", 2688 | "dev": true 2689 | }, 2690 | "rx-lite-aggregates": { 2691 | "version": "4.0.8", 2692 | "resolved": "https://registry.npmjs.org/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz", 2693 | "integrity": "sha1-dTuHqJoRyVRnxKwWJsTvxOBcZ74=", 2694 | "dev": true, 2695 | "requires": { 2696 | "rx-lite": "4.0.8" 2697 | } 2698 | }, 2699 | "rxjs": { 2700 | "version": "6.4.0", 2701 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.4.0.tgz", 2702 | "integrity": "sha512-Z9Yfa11F6B9Sg/BK9MnqnQ+aQYicPLtilXBp2yUtDt2JRCE0h26d33EnfO3ZxoNxG0T92OUucP3Ct7cpfkdFfw==", 2703 | "requires": { 2704 | "tslib": "1.9.3" 2705 | } 2706 | }, 2707 | "safe-buffer": { 2708 | "version": "5.1.2", 2709 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2710 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2711 | }, 2712 | "safer-buffer": { 2713 | "version": "2.1.2", 2714 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2715 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2716 | }, 2717 | "scrypt": { 2718 | "version": "6.0.3", 2719 | "resolved": "https://registry.npmjs.org/scrypt/-/scrypt-6.0.3.tgz", 2720 | "integrity": "sha1-BOAUpWgrU/pQwtXM4WfXGcBthw0=", 2721 | "optional": true, 2722 | "requires": { 2723 | "nan": "2.13.2" 2724 | } 2725 | }, 2726 | "scrypt.js": { 2727 | "version": "0.3.0", 2728 | "resolved": "https://registry.npmjs.org/scrypt.js/-/scrypt.js-0.3.0.tgz", 2729 | "integrity": "sha512-42LTc1nyFsyv/o0gcHtDztrn+aqpkaCNt5Qh7ATBZfhEZU7IC/0oT/qbBH+uRNoAPvs2fwiOId68FDEoSRA8/A==", 2730 | "requires": { 2731 | "scrypt": "6.0.3", 2732 | "scryptsy": "1.2.1" 2733 | } 2734 | }, 2735 | "scryptsy": { 2736 | "version": "1.2.1", 2737 | "resolved": "https://registry.npmjs.org/scryptsy/-/scryptsy-1.2.1.tgz", 2738 | "integrity": "sha1-oyJfpLJST4AnAHYeKFW987LZIWM=", 2739 | "requires": { 2740 | "pbkdf2": "3.0.17" 2741 | } 2742 | }, 2743 | "secp256k1": { 2744 | "version": "3.6.2", 2745 | "resolved": "https://registry.npmjs.org/secp256k1/-/secp256k1-3.6.2.tgz", 2746 | "integrity": "sha512-90nYt7yb0LmI4A2jJs1grglkTAXrBwxYAjP9bpeKjvJKOjG2fOeH/YI/lchDMIvjrOasd5QXwvV2jwN168xNng==", 2747 | "requires": { 2748 | "bindings": "1.5.0", 2749 | "bip66": "1.1.5", 2750 | "bn.js": "4.11.8", 2751 | "create-hash": "1.2.0", 2752 | "drbg.js": "1.0.1", 2753 | "elliptic": "6.4.1", 2754 | "nan": "2.13.2", 2755 | "safe-buffer": "5.1.2" 2756 | } 2757 | }, 2758 | "semver": { 2759 | "version": "5.6.0", 2760 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 2761 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==" 2762 | }, 2763 | "set-blocking": { 2764 | "version": "2.0.0", 2765 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 2766 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 2767 | }, 2768 | "sha.js": { 2769 | "version": "2.4.11", 2770 | "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", 2771 | "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", 2772 | "requires": { 2773 | "inherits": "2.0.3", 2774 | "safe-buffer": "5.1.2" 2775 | } 2776 | }, 2777 | "sha3": { 2778 | "version": "1.2.2", 2779 | "resolved": "https://registry.npmjs.org/sha3/-/sha3-1.2.2.tgz", 2780 | "integrity": "sha1-pmxQmN5MJbyIM27ItIF9AFvKe6k=", 2781 | "dev": true, 2782 | "requires": { 2783 | "nan": "2.10.0" 2784 | }, 2785 | "dependencies": { 2786 | "nan": { 2787 | "version": "2.10.0", 2788 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz", 2789 | "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", 2790 | "dev": true 2791 | } 2792 | } 2793 | }, 2794 | "shebang-command": { 2795 | "version": "1.2.0", 2796 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2797 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2798 | "requires": { 2799 | "shebang-regex": "1.0.0" 2800 | } 2801 | }, 2802 | "shebang-regex": { 2803 | "version": "1.0.0", 2804 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2805 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 2806 | }, 2807 | "shelljs": { 2808 | "version": "0.7.8", 2809 | "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.7.8.tgz", 2810 | "integrity": "sha1-3svPh0sNHl+3LhSxZKloMEjprLM=", 2811 | "dev": true, 2812 | "requires": { 2813 | "glob": "7.1.2", 2814 | "interpret": "1.1.0", 2815 | "rechoir": "0.6.2" 2816 | } 2817 | }, 2818 | "signal-exit": { 2819 | "version": "3.0.2", 2820 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2821 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 2822 | }, 2823 | "slice-ansi": { 2824 | "version": "1.0.0", 2825 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", 2826 | "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", 2827 | "dev": true, 2828 | "requires": { 2829 | "is-fullwidth-code-point": "2.0.0" 2830 | }, 2831 | "dependencies": { 2832 | "is-fullwidth-code-point": { 2833 | "version": "2.0.0", 2834 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2835 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2836 | "dev": true 2837 | } 2838 | } 2839 | }, 2840 | "sol-explore": { 2841 | "version": "1.6.2", 2842 | "resolved": "https://registry.npmjs.org/sol-explore/-/sol-explore-1.6.2.tgz", 2843 | "integrity": "sha1-Q66MQZ/TrAVqBfip0fsQIs1B7MI=", 2844 | "dev": true 2845 | }, 2846 | "solhint": { 2847 | "version": "2.0.0", 2848 | "resolved": "https://registry.npmjs.org/solhint/-/solhint-2.0.0.tgz", 2849 | "integrity": "sha512-K1QW6an/MSYEsR4KfM07xu1kIsV7WroH5fLosP+KMN76hoVHqYDrRr7rFEkjX63HGxYHqS7tzGcE2veIVINKyw==", 2850 | "requires": { 2851 | "ajv": "6.6.1", 2852 | "antlr4": "4.7.1", 2853 | "commander": "2.18.0", 2854 | "cosmiconfig": "5.1.0", 2855 | "eslint": "5.15.3", 2856 | "fast-diff": "1.2.0", 2857 | "glob": "7.1.3", 2858 | "ignore": "4.0.6", 2859 | "js-yaml": "3.12.0", 2860 | "lodash": "4.17.11", 2861 | "prettier": "1.15.3" 2862 | }, 2863 | "dependencies": { 2864 | "acorn": { 2865 | "version": "6.1.1", 2866 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", 2867 | "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==" 2868 | }, 2869 | "acorn-jsx": { 2870 | "version": "5.0.1", 2871 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 2872 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==" 2873 | }, 2874 | "ansi-escapes": { 2875 | "version": "3.2.0", 2876 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 2877 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==" 2878 | }, 2879 | "ansi-regex": { 2880 | "version": "3.0.0", 2881 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 2882 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 2883 | }, 2884 | "ansi-styles": { 2885 | "version": "3.2.1", 2886 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2887 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2888 | "requires": { 2889 | "color-convert": "1.9.3" 2890 | } 2891 | }, 2892 | "chardet": { 2893 | "version": "0.7.0", 2894 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 2895 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==" 2896 | }, 2897 | "commander": { 2898 | "version": "2.18.0", 2899 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.18.0.tgz", 2900 | "integrity": "sha512-6CYPa+JP2ftfRU2qkDK+UTVeQYosOg/2GbcjIcKPHfinyOLPVGXu/ovN86RP49Re5ndJK1N0kuiidFFuepc4ZQ==" 2901 | }, 2902 | "cross-spawn": { 2903 | "version": "6.0.5", 2904 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 2905 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 2906 | "requires": { 2907 | "nice-try": "1.0.5", 2908 | "path-key": "2.0.1", 2909 | "semver": "5.6.0", 2910 | "shebang-command": "1.2.0", 2911 | "which": "1.3.1" 2912 | } 2913 | }, 2914 | "debug": { 2915 | "version": "4.1.1", 2916 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 2917 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 2918 | "requires": { 2919 | "ms": "2.1.1" 2920 | } 2921 | }, 2922 | "doctrine": { 2923 | "version": "3.0.0", 2924 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2925 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2926 | "requires": { 2927 | "esutils": "2.0.2" 2928 | } 2929 | }, 2930 | "eslint": { 2931 | "version": "5.15.3", 2932 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.15.3.tgz", 2933 | "integrity": "sha512-vMGi0PjCHSokZxE0NLp2VneGw5sio7SSiDNgIUn2tC0XkWJRNOIoHIg3CliLVfXnJsiHxGAYrkw0PieAu8+KYQ==", 2934 | "requires": { 2935 | "@babel/code-frame": "7.0.0", 2936 | "ajv": "6.10.0", 2937 | "chalk": "2.4.1", 2938 | "cross-spawn": "6.0.5", 2939 | "debug": "4.1.1", 2940 | "doctrine": "3.0.0", 2941 | "eslint-scope": "4.0.3", 2942 | "eslint-utils": "1.3.1", 2943 | "eslint-visitor-keys": "1.0.0", 2944 | "espree": "5.0.1", 2945 | "esquery": "1.0.1", 2946 | "esutils": "2.0.2", 2947 | "file-entry-cache": "5.0.1", 2948 | "functional-red-black-tree": "1.0.1", 2949 | "glob": "7.1.3", 2950 | "globals": "11.9.0", 2951 | "ignore": "4.0.6", 2952 | "import-fresh": "3.0.0", 2953 | "imurmurhash": "0.1.4", 2954 | "inquirer": "6.2.2", 2955 | "js-yaml": "3.12.0", 2956 | "json-stable-stringify-without-jsonify": "1.0.1", 2957 | "levn": "0.3.0", 2958 | "lodash": "4.17.11", 2959 | "minimatch": "3.0.4", 2960 | "mkdirp": "0.5.1", 2961 | "natural-compare": "1.4.0", 2962 | "optionator": "0.8.2", 2963 | "path-is-inside": "1.0.2", 2964 | "progress": "2.0.3", 2965 | "regexpp": "2.0.1", 2966 | "semver": "5.6.0", 2967 | "strip-ansi": "4.0.0", 2968 | "strip-json-comments": "2.0.1", 2969 | "table": "5.2.3", 2970 | "text-table": "0.2.0" 2971 | }, 2972 | "dependencies": { 2973 | "ajv": { 2974 | "version": "6.10.0", 2975 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 2976 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 2977 | "requires": { 2978 | "fast-deep-equal": "2.0.1", 2979 | "fast-json-stable-stringify": "2.0.0", 2980 | "json-schema-traverse": "0.4.1", 2981 | "uri-js": "4.2.2" 2982 | } 2983 | } 2984 | } 2985 | }, 2986 | "eslint-scope": { 2987 | "version": "4.0.3", 2988 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", 2989 | "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", 2990 | "requires": { 2991 | "esrecurse": "4.2.1", 2992 | "estraverse": "4.2.0" 2993 | } 2994 | }, 2995 | "espree": { 2996 | "version": "5.0.1", 2997 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", 2998 | "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", 2999 | "requires": { 3000 | "acorn": "6.1.1", 3001 | "acorn-jsx": "5.0.1", 3002 | "eslint-visitor-keys": "1.0.0" 3003 | } 3004 | }, 3005 | "external-editor": { 3006 | "version": "3.0.3", 3007 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 3008 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 3009 | "requires": { 3010 | "chardet": "0.7.0", 3011 | "iconv-lite": "0.4.24", 3012 | "tmp": "0.0.33" 3013 | } 3014 | }, 3015 | "file-entry-cache": { 3016 | "version": "5.0.1", 3017 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 3018 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 3019 | "requires": { 3020 | "flat-cache": "2.0.1" 3021 | } 3022 | }, 3023 | "flat-cache": { 3024 | "version": "2.0.1", 3025 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 3026 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 3027 | "requires": { 3028 | "flatted": "2.0.0", 3029 | "rimraf": "2.6.3", 3030 | "write": "1.0.3" 3031 | } 3032 | }, 3033 | "glob": { 3034 | "version": "7.1.3", 3035 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 3036 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 3037 | "requires": { 3038 | "fs.realpath": "1.0.0", 3039 | "inflight": "1.0.6", 3040 | "inherits": "2.0.3", 3041 | "minimatch": "3.0.4", 3042 | "once": "1.4.0", 3043 | "path-is-absolute": "1.0.1" 3044 | } 3045 | }, 3046 | "has-flag": { 3047 | "version": "3.0.0", 3048 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 3049 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 3050 | }, 3051 | "ignore": { 3052 | "version": "4.0.6", 3053 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 3054 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==" 3055 | }, 3056 | "import-fresh": { 3057 | "version": "3.0.0", 3058 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", 3059 | "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", 3060 | "requires": { 3061 | "parent-module": "1.0.0", 3062 | "resolve-from": "4.0.0" 3063 | } 3064 | }, 3065 | "inquirer": { 3066 | "version": "6.2.2", 3067 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.2.tgz", 3068 | "integrity": "sha512-Z2rREiXA6cHRR9KBOarR3WuLlFzlIfAEIiB45ll5SSadMg7WqOh1MKEjjndfuH5ewXdixWCxqnVfGOQzPeiztA==", 3069 | "requires": { 3070 | "ansi-escapes": "3.2.0", 3071 | "chalk": "2.4.2", 3072 | "cli-cursor": "2.1.0", 3073 | "cli-width": "2.2.0", 3074 | "external-editor": "3.0.3", 3075 | "figures": "2.0.0", 3076 | "lodash": "4.17.11", 3077 | "mute-stream": "0.0.7", 3078 | "run-async": "2.3.0", 3079 | "rxjs": "6.4.0", 3080 | "string-width": "2.1.1", 3081 | "strip-ansi": "5.2.0", 3082 | "through": "2.3.8" 3083 | }, 3084 | "dependencies": { 3085 | "ansi-regex": { 3086 | "version": "4.1.0", 3087 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 3088 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" 3089 | }, 3090 | "chalk": { 3091 | "version": "2.4.2", 3092 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 3093 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 3094 | "requires": { 3095 | "ansi-styles": "3.2.1", 3096 | "escape-string-regexp": "1.0.5", 3097 | "supports-color": "5.5.0" 3098 | } 3099 | }, 3100 | "strip-ansi": { 3101 | "version": "5.2.0", 3102 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 3103 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 3104 | "requires": { 3105 | "ansi-regex": "4.1.0" 3106 | } 3107 | } 3108 | } 3109 | }, 3110 | "is-fullwidth-code-point": { 3111 | "version": "2.0.0", 3112 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3113 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 3114 | }, 3115 | "js-yaml": { 3116 | "version": "3.12.0", 3117 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 3118 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 3119 | "requires": { 3120 | "argparse": "^1.0.7", 3121 | "esprima": "^4.0.0" 3122 | } 3123 | }, 3124 | "ms": { 3125 | "version": "2.1.1", 3126 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 3127 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 3128 | }, 3129 | "regexpp": { 3130 | "version": "2.0.1", 3131 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 3132 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==" 3133 | }, 3134 | "resolve-from": { 3135 | "version": "4.0.0", 3136 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3137 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" 3138 | }, 3139 | "rimraf": { 3140 | "version": "2.6.3", 3141 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 3142 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 3143 | "requires": { 3144 | "glob": "7.1.3" 3145 | } 3146 | }, 3147 | "slice-ansi": { 3148 | "version": "2.1.0", 3149 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 3150 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 3151 | "requires": { 3152 | "ansi-styles": "3.2.1", 3153 | "astral-regex": "1.0.0", 3154 | "is-fullwidth-code-point": "2.0.0" 3155 | } 3156 | }, 3157 | "string-width": { 3158 | "version": "2.1.1", 3159 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3160 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3161 | "requires": { 3162 | "is-fullwidth-code-point": "2.0.0", 3163 | "strip-ansi": "4.0.0" 3164 | } 3165 | }, 3166 | "strip-ansi": { 3167 | "version": "4.0.0", 3168 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3169 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3170 | "requires": { 3171 | "ansi-regex": "3.0.0" 3172 | } 3173 | }, 3174 | "supports-color": { 3175 | "version": "5.5.0", 3176 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3177 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3178 | "requires": { 3179 | "has-flag": "3.0.0" 3180 | } 3181 | }, 3182 | "table": { 3183 | "version": "5.2.3", 3184 | "resolved": "https://registry.npmjs.org/table/-/table-5.2.3.tgz", 3185 | "integrity": "sha512-N2RsDAMvDLvYwFcwbPyF3VmVSSkuF+G1e+8inhBLtHpvwXGw4QRPEZhihQNeEN0i1up6/f6ObCJXNdlRG3YVyQ==", 3186 | "requires": { 3187 | "ajv": "6.10.0", 3188 | "lodash": "4.17.11", 3189 | "slice-ansi": "2.1.0", 3190 | "string-width": "3.1.0" 3191 | }, 3192 | "dependencies": { 3193 | "ajv": { 3194 | "version": "6.10.0", 3195 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 3196 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 3197 | "requires": { 3198 | "fast-deep-equal": "2.0.1", 3199 | "fast-json-stable-stringify": "2.0.0", 3200 | "json-schema-traverse": "0.4.1", 3201 | "uri-js": "4.2.2" 3202 | } 3203 | }, 3204 | "ansi-regex": { 3205 | "version": "4.1.0", 3206 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 3207 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" 3208 | }, 3209 | "string-width": { 3210 | "version": "3.1.0", 3211 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3212 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3213 | "requires": { 3214 | "emoji-regex": "7.0.3", 3215 | "is-fullwidth-code-point": "2.0.0", 3216 | "strip-ansi": "5.2.0" 3217 | } 3218 | }, 3219 | "strip-ansi": { 3220 | "version": "5.2.0", 3221 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 3222 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 3223 | "requires": { 3224 | "ansi-regex": "4.1.0" 3225 | } 3226 | } 3227 | } 3228 | }, 3229 | "write": { 3230 | "version": "1.0.3", 3231 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 3232 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 3233 | "requires": { 3234 | "mkdirp": "0.5.1" 3235 | } 3236 | } 3237 | } 3238 | }, 3239 | "solidity-coverage": { 3240 | "version": "0.5.8", 3241 | "resolved": "https://registry.npmjs.org/solidity-coverage/-/solidity-coverage-0.5.8.tgz", 3242 | "integrity": "sha512-DPx3hZCQwOWF6KXvQz4Dhtjz3QTxXpjx1J2m5KdrxHGNb7FhMO1LX7iaAdolnTq3L1gQlPUJ5TbK3spPtuI9FA==", 3243 | "dev": true, 3244 | "requires": { 3245 | "death": "1.1.0", 3246 | "ethereumjs-testrpc-sc": "6.1.6", 3247 | "istanbul": "0.4.5", 3248 | "keccakjs": "0.2.1", 3249 | "req-cwd": "1.0.1", 3250 | "shelljs": "0.7.8", 3251 | "sol-explore": "1.6.2", 3252 | "solidity-parser-sc": "0.4.11", 3253 | "tree-kill": "1.2.1", 3254 | "web3": "0.18.4" 3255 | } 3256 | }, 3257 | "solidity-parser-sc": { 3258 | "version": "0.4.11", 3259 | "resolved": "https://registry.npmjs.org/solidity-parser-sc/-/solidity-parser-sc-0.4.11.tgz", 3260 | "integrity": "sha512-1kV5iC7m3CtMDfmHaVNwz2saSGQVIuF16rIxU417Al38MVCWHMQQ5vT6cmLsNwDe60S74auobWij9vNawSeOyw==", 3261 | "dev": true, 3262 | "requires": { 3263 | "mocha": "4.1.0", 3264 | "pegjs": "0.10.0", 3265 | "yargs": "4.8.1" 3266 | } 3267 | }, 3268 | "source-map": { 3269 | "version": "0.6.1", 3270 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3271 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3272 | "dev": true 3273 | }, 3274 | "source-map-support": { 3275 | "version": "0.5.9", 3276 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.9.tgz", 3277 | "integrity": "sha512-gR6Rw4MvUlYy83vP0vxoVNzM6t8MUXqNuRsuBmBHQDu1Fh6X015FrLdgoDKcNdkwGubozq0P4N0Q37UyFVr1EA==", 3278 | "dev": true, 3279 | "requires": { 3280 | "buffer-from": "1.1.1", 3281 | "source-map": "0.6.1" 3282 | } 3283 | }, 3284 | "spawn-sync": { 3285 | "version": "1.0.15", 3286 | "resolved": "https://registry.npmjs.org/spawn-sync/-/spawn-sync-1.0.15.tgz", 3287 | "integrity": "sha1-sAeZVX63+wyDdsKdROih6mfldHY=", 3288 | "dev": true, 3289 | "requires": { 3290 | "concat-stream": "1.6.2", 3291 | "os-shim": "0.1.3" 3292 | } 3293 | }, 3294 | "spdx-correct": { 3295 | "version": "3.1.0", 3296 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 3297 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 3298 | "requires": { 3299 | "spdx-expression-parse": "3.0.0", 3300 | "spdx-license-ids": "3.0.2" 3301 | } 3302 | }, 3303 | "spdx-exceptions": { 3304 | "version": "2.2.0", 3305 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 3306 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==" 3307 | }, 3308 | "spdx-expression-parse": { 3309 | "version": "3.0.0", 3310 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 3311 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 3312 | "requires": { 3313 | "spdx-exceptions": "2.2.0", 3314 | "spdx-license-ids": "3.0.2" 3315 | } 3316 | }, 3317 | "spdx-license-ids": { 3318 | "version": "3.0.2", 3319 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.2.tgz", 3320 | "integrity": "sha512-qky9CVt0lVIECkEsYbNILVnPvycuEBkXoMFLRWsREkomQLevYhtRKC+R91a5TOAQ3bCMjikRwhyaRqj1VYatYg==" 3321 | }, 3322 | "sprintf-js": { 3323 | "version": "1.0.3", 3324 | "resolved": "http://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3325 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" 3326 | }, 3327 | "sshpk": { 3328 | "version": "1.15.2", 3329 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.15.2.tgz", 3330 | "integrity": "sha512-Ra/OXQtuh0/enyl4ETZAfTaeksa6BXks5ZcjpSUNrjBr0DvrJKX+1fsKDPpT9TBXgHAFsa4510aNVgI8g/+SzA==", 3331 | "dev": true, 3332 | "requires": { 3333 | "asn1": "0.2.4", 3334 | "assert-plus": "1.0.0", 3335 | "bcrypt-pbkdf": "1.0.2", 3336 | "dashdash": "1.14.1", 3337 | "ecc-jsbn": "0.1.2", 3338 | "getpass": "0.1.7", 3339 | "jsbn": "0.1.1", 3340 | "safer-buffer": "2.1.2", 3341 | "tweetnacl": "0.14.5" 3342 | } 3343 | }, 3344 | "string-width": { 3345 | "version": "1.0.2", 3346 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 3347 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 3348 | "requires": { 3349 | "code-point-at": "1.1.0", 3350 | "is-fullwidth-code-point": "1.0.0", 3351 | "strip-ansi": "3.0.1" 3352 | } 3353 | }, 3354 | "string_decoder": { 3355 | "version": "1.1.1", 3356 | "resolved": "http://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3357 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3358 | "dev": true, 3359 | "requires": { 3360 | "safe-buffer": "5.1.2" 3361 | } 3362 | }, 3363 | "strip-ansi": { 3364 | "version": "3.0.1", 3365 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 3366 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 3367 | "requires": { 3368 | "ansi-regex": "2.1.1" 3369 | } 3370 | }, 3371 | "strip-bom": { 3372 | "version": "2.0.0", 3373 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", 3374 | "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", 3375 | "requires": { 3376 | "is-utf8": "0.2.1" 3377 | } 3378 | }, 3379 | "strip-hex-prefix": { 3380 | "version": "1.0.0", 3381 | "resolved": "https://registry.npmjs.org/strip-hex-prefix/-/strip-hex-prefix-1.0.0.tgz", 3382 | "integrity": "sha1-DF8VX+8RUTczd96du1iNoFUA428=", 3383 | "requires": { 3384 | "is-hex-prefixed": "1.0.0" 3385 | } 3386 | }, 3387 | "strip-json-comments": { 3388 | "version": "2.0.1", 3389 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 3390 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=" 3391 | }, 3392 | "supports-color": { 3393 | "version": "4.4.0", 3394 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.4.0.tgz", 3395 | "integrity": "sha512-rKC3+DyXWgK0ZLKwmRsrkyHVZAjNkfzeehuFWdGGcqGDTZFH73+RH6S/RDAAxl9GusSjZSUWYLmT9N5pzXFOXQ==", 3396 | "requires": { 3397 | "has-flag": "2.0.0" 3398 | } 3399 | }, 3400 | "table": { 3401 | "version": "4.0.2", 3402 | "resolved": "https://registry.npmjs.org/table/-/table-4.0.2.tgz", 3403 | "integrity": "sha512-UUkEAPdSGxtRpiV9ozJ5cMTtYiqz7Ni1OGqLXRCynrvzdtR1p+cfOWe2RJLwvUG8hNanaSRjecIqwOjqeatDsA==", 3404 | "dev": true, 3405 | "requires": { 3406 | "ajv": "5.5.2", 3407 | "ajv-keywords": "2.1.1", 3408 | "chalk": "2.4.1", 3409 | "lodash": "4.17.11", 3410 | "slice-ansi": "1.0.0", 3411 | "string-width": "2.1.1" 3412 | }, 3413 | "dependencies": { 3414 | "ajv": { 3415 | "version": "5.5.2", 3416 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", 3417 | "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", 3418 | "dev": true, 3419 | "requires": { 3420 | "co": "4.6.0", 3421 | "fast-deep-equal": "1.1.0", 3422 | "fast-json-stable-stringify": "2.0.0", 3423 | "json-schema-traverse": "0.3.1" 3424 | } 3425 | }, 3426 | "ansi-regex": { 3427 | "version": "3.0.0", 3428 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 3429 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 3430 | "dev": true 3431 | }, 3432 | "fast-deep-equal": { 3433 | "version": "1.1.0", 3434 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", 3435 | "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=", 3436 | "dev": true 3437 | }, 3438 | "is-fullwidth-code-point": { 3439 | "version": "2.0.0", 3440 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 3441 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 3442 | "dev": true 3443 | }, 3444 | "json-schema-traverse": { 3445 | "version": "0.3.1", 3446 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 3447 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", 3448 | "dev": true 3449 | }, 3450 | "string-width": { 3451 | "version": "2.1.1", 3452 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3453 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3454 | "dev": true, 3455 | "requires": { 3456 | "is-fullwidth-code-point": "2.0.0", 3457 | "strip-ansi": "4.0.0" 3458 | } 3459 | }, 3460 | "strip-ansi": { 3461 | "version": "4.0.0", 3462 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3463 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3464 | "dev": true, 3465 | "requires": { 3466 | "ansi-regex": "3.0.0" 3467 | } 3468 | } 3469 | } 3470 | }, 3471 | "text-table": { 3472 | "version": "0.2.0", 3473 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3474 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=" 3475 | }, 3476 | "through": { 3477 | "version": "2.3.8", 3478 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", 3479 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" 3480 | }, 3481 | "tmp": { 3482 | "version": "0.0.33", 3483 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 3484 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 3485 | "requires": { 3486 | "os-tmpdir": "1.0.2" 3487 | } 3488 | }, 3489 | "tough-cookie": { 3490 | "version": "2.4.3", 3491 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 3492 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 3493 | "dev": true, 3494 | "requires": { 3495 | "psl": "1.1.29", 3496 | "punycode": "1.4.1" 3497 | }, 3498 | "dependencies": { 3499 | "punycode": { 3500 | "version": "1.4.1", 3501 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 3502 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 3503 | "dev": true 3504 | } 3505 | } 3506 | }, 3507 | "tree-kill": { 3508 | "version": "1.2.1", 3509 | "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.1.tgz", 3510 | "integrity": "sha512-4hjqbObwlh2dLyW4tcz0Ymw0ggoaVDMveUB9w8kFSQScdRLo0gxO9J7WFcUBo+W3C1TLdFIEwNOWebgZZ0RH9Q==", 3511 | "dev": true 3512 | }, 3513 | "truffle": { 3514 | "version": "4.1.14", 3515 | "resolved": "https://registry.npmjs.org/truffle/-/truffle-4.1.14.tgz", 3516 | "integrity": "sha512-e7tTLvKP3bN9dE7MagfWyFjy4ZgoEGbeujECy1me1ENBzbj/aO/+45gs72qsL3+3IkCNNcWNOJjjrm8BYZZNNg==", 3517 | "requires": { 3518 | "mocha": "4.1.0", 3519 | "original-require": "1.0.1", 3520 | "solc": "0.4.24" 3521 | }, 3522 | "dependencies": { 3523 | "require-from-string": { 3524 | "version": "1.2.1", 3525 | "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-1.2.1.tgz", 3526 | "integrity": "sha1-UpyczvJzgK3+yaL5ZbZJu+5jZBg=" 3527 | }, 3528 | "solc": { 3529 | "version": "0.4.24", 3530 | "resolved": "https://registry.npmjs.org/solc/-/solc-0.4.24.tgz", 3531 | "integrity": "sha512-2xd7Cf1HeVwrIb6Bu1cwY2/TaLRodrppCq3l7rhLimFQgmxptXhTC3+/wesVLpB09F1A2kZgvbMOgH7wvhFnBQ==", 3532 | "requires": { 3533 | "fs-extra": "0.30.0", 3534 | "memorystream": "0.3.1", 3535 | "require-from-string": "1.2.1", 3536 | "semver": "5.6.0", 3537 | "yargs": "4.8.1" 3538 | } 3539 | } 3540 | } 3541 | }, 3542 | "tslib": { 3543 | "version": "1.9.3", 3544 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 3545 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==" 3546 | }, 3547 | "tunnel-agent": { 3548 | "version": "0.6.0", 3549 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 3550 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 3551 | "dev": true, 3552 | "requires": { 3553 | "safe-buffer": "5.1.2" 3554 | } 3555 | }, 3556 | "tweetnacl": { 3557 | "version": "0.14.5", 3558 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 3559 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 3560 | "dev": true 3561 | }, 3562 | "type-check": { 3563 | "version": "0.3.2", 3564 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 3565 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 3566 | "requires": { 3567 | "prelude-ls": "1.1.2" 3568 | } 3569 | }, 3570 | "type-detect": { 3571 | "version": "4.0.8", 3572 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3573 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3574 | "dev": true 3575 | }, 3576 | "typedarray": { 3577 | "version": "0.0.6", 3578 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 3579 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 3580 | "dev": true 3581 | }, 3582 | "uglify-js": { 3583 | "version": "3.4.9", 3584 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.4.9.tgz", 3585 | "integrity": "sha512-8CJsbKOtEbnJsTyv6LE6m6ZKniqMiFWmm9sRbopbkGs3gMPPfd3Fh8iIA4Ykv5MgaTbqHr4BaoGLJLZNhsrW1Q==", 3586 | "dev": true, 3587 | "optional": true, 3588 | "requires": { 3589 | "commander": "2.17.1", 3590 | "source-map": "0.6.1" 3591 | }, 3592 | "dependencies": { 3593 | "commander": { 3594 | "version": "2.17.1", 3595 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", 3596 | "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==", 3597 | "dev": true, 3598 | "optional": true 3599 | } 3600 | } 3601 | }, 3602 | "unorm": { 3603 | "version": "1.5.0", 3604 | "resolved": "https://registry.npmjs.org/unorm/-/unorm-1.5.0.tgz", 3605 | "integrity": "sha512-sMfSWoiRaXXeDZSXC+YRZ23H4xchQpwxjpw1tmfR+kgbBCaOgln4NI0LXejJIhnBuKINrB3WRn+ZI8IWssirVw==" 3606 | }, 3607 | "uri-js": { 3608 | "version": "4.2.2", 3609 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 3610 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 3611 | "requires": { 3612 | "punycode": "2.1.1" 3613 | } 3614 | }, 3615 | "utf8": { 3616 | "version": "3.0.0", 3617 | "resolved": "https://registry.npmjs.org/utf8/-/utf8-3.0.0.tgz", 3618 | "integrity": "sha512-E8VjFIQ/TyQgp+TZfS6l8yp/xWppSAHzidGiRrqe4bK4XP9pTRyKFgGJpO3SN7zdX4DeomTrwaseCHovfpFcqQ==" 3619 | }, 3620 | "util-deprecate": { 3621 | "version": "1.0.2", 3622 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3623 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 3624 | "dev": true 3625 | }, 3626 | "uuid": { 3627 | "version": "3.3.2", 3628 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", 3629 | "integrity": "sha512-yXJmeNaw3DnnKAOKJE51sL/ZaYfWJRl1pK9dr19YFCu0ObS231AB1/LbqTKRAQ5kw8A90rA6fr4riOUpTZvQZA==" 3630 | }, 3631 | "validate-npm-package-license": { 3632 | "version": "3.0.4", 3633 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 3634 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 3635 | "requires": { 3636 | "spdx-correct": "3.1.0", 3637 | "spdx-expression-parse": "3.0.0" 3638 | } 3639 | }, 3640 | "verror": { 3641 | "version": "1.10.0", 3642 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 3643 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 3644 | "dev": true, 3645 | "requires": { 3646 | "assert-plus": "1.0.0", 3647 | "core-util-is": "1.0.2", 3648 | "extsprintf": "1.3.0" 3649 | } 3650 | }, 3651 | "web3": { 3652 | "version": "0.18.4", 3653 | "resolved": "https://registry.npmjs.org/web3/-/web3-0.18.4.tgz", 3654 | "integrity": "sha1-gewXhBRUkfLqqJVbMcBgSeB8Xn0=", 3655 | "dev": true, 3656 | "requires": { 3657 | "bignumber.js": "git+https://github.com/debris/bignumber.js.git#94d7146671b9719e00a09c29b01a691bc85048c2", 3658 | "crypto-js": "3.1.8", 3659 | "utf8": "2.1.2", 3660 | "xhr2": "0.1.4", 3661 | "xmlhttprequest": "1.8.0" 3662 | }, 3663 | "dependencies": { 3664 | "utf8": { 3665 | "version": "2.1.2", 3666 | "resolved": "https://registry.npmjs.org/utf8/-/utf8-2.1.2.tgz", 3667 | "integrity": "sha1-H6DZJw6b6FDZsFAn9jUZv0ZFfZY=", 3668 | "dev": true 3669 | } 3670 | } 3671 | }, 3672 | "which": { 3673 | "version": "1.3.1", 3674 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3675 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3676 | "requires": { 3677 | "isexe": "2.0.0" 3678 | } 3679 | }, 3680 | "which-module": { 3681 | "version": "1.0.0", 3682 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz", 3683 | "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8=" 3684 | }, 3685 | "window-size": { 3686 | "version": "0.2.0", 3687 | "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.2.0.tgz", 3688 | "integrity": "sha1-tDFbtCFKPXBY6+7okuE/ok2YsHU=" 3689 | }, 3690 | "wordwrap": { 3691 | "version": "1.0.0", 3692 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 3693 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=" 3694 | }, 3695 | "wrap-ansi": { 3696 | "version": "2.1.0", 3697 | "resolved": "http://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 3698 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 3699 | "requires": { 3700 | "string-width": "1.0.2", 3701 | "strip-ansi": "3.0.1" 3702 | } 3703 | }, 3704 | "wrappy": { 3705 | "version": "1.0.2", 3706 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3707 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 3708 | }, 3709 | "write": { 3710 | "version": "0.2.1", 3711 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", 3712 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", 3713 | "dev": true, 3714 | "requires": { 3715 | "mkdirp": "0.5.1" 3716 | } 3717 | }, 3718 | "xhr2": { 3719 | "version": "0.1.4", 3720 | "resolved": "https://registry.npmjs.org/xhr2/-/xhr2-0.1.4.tgz", 3721 | "integrity": "sha1-f4dliEdxbbUCYyOBL4GMras4el8=", 3722 | "dev": true 3723 | }, 3724 | "xmlhttprequest": { 3725 | "version": "1.8.0", 3726 | "resolved": "https://registry.npmjs.org/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz", 3727 | "integrity": "sha1-Z/4HXFwk/vOfnWX197f+dRcZaPw=", 3728 | "dev": true 3729 | }, 3730 | "y18n": { 3731 | "version": "3.2.1", 3732 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", 3733 | "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=" 3734 | }, 3735 | "yallist": { 3736 | "version": "2.1.2", 3737 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3738 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 3739 | "dev": true 3740 | }, 3741 | "yargs": { 3742 | "version": "4.8.1", 3743 | "resolved": "http://registry.npmjs.org/yargs/-/yargs-4.8.1.tgz", 3744 | "integrity": "sha1-wMQpJMpKqmsObaFznfshZDn53cA=", 3745 | "requires": { 3746 | "cliui": "3.2.0", 3747 | "decamelize": "1.2.0", 3748 | "get-caller-file": "1.0.3", 3749 | "lodash.assign": "4.2.0", 3750 | "os-locale": "1.4.0", 3751 | "read-pkg-up": "1.0.1", 3752 | "require-directory": "2.1.1", 3753 | "require-main-filename": "1.0.1", 3754 | "set-blocking": "2.0.0", 3755 | "string-width": "1.0.2", 3756 | "which-module": "1.0.0", 3757 | "window-size": "0.2.0", 3758 | "y18n": "3.2.1", 3759 | "yargs-parser": "2.4.1" 3760 | } 3761 | }, 3762 | "yargs-parser": { 3763 | "version": "2.4.1", 3764 | "resolved": "http://registry.npmjs.org/yargs-parser/-/yargs-parser-2.4.1.tgz", 3765 | "integrity": "sha1-hVaN488VD/SfpRgl8DqMiA3cxcQ=", 3766 | "requires": { 3767 | "camelcase": "3.0.0", 3768 | "lodash.assign": "4.2.0" 3769 | } 3770 | } 3771 | } 3772 | } 3773 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "market-oracle", 3 | "version": "0.0.1", 4 | "description": "Ethereum smart contracts to aggregate exchange rates from various sources", 5 | "keywords": [ 6 | "ethereum", 7 | "smart-contracts", 8 | "solidity" 9 | ], 10 | "homepage": "https://github.com/ampleforth/market-oracle#readme", 11 | "bugs": { 12 | "url": "https://github.com/ampleforth/market-oracle/issues" 13 | }, 14 | "repository": { 15 | "type": "git", 16 | "url": "git+https://github.com/ampleforth/market-oracle.git" 17 | }, 18 | "license": "ISC", 19 | "author": "dev-support@ampleforth.org", 20 | "scripts": { 21 | "coverage": "npx frg-coverage", 22 | "precommit": "./scripts/pre-commit.sh", 23 | "lint": "npx eslint ./migrations ./scripts ./test ./unit *.js --cache --fix && npx solhint ./contracts/*.sol", 24 | "test": "./scripts/test.sh" 25 | }, 26 | "pre-commit": { 27 | "run": [ 28 | "precommit", 29 | "lint" 30 | ] 31 | }, 32 | "dependencies": { 33 | "app-root-path": "~2.1.0", 34 | "frg-ethereum-runners": "https://github.com/ampleforth/frg-ethereum-runners.git", 35 | "js-yaml": "~3.13.1", 36 | "openzeppelin-solidity": "~2.0.0", 37 | "solhint": "^2.0.0", 38 | "truffle": "4.1.14" 39 | }, 40 | "devDependencies": { 41 | "chai": "^4.1.2", 42 | "chai-bignumber": "^2.0.2", 43 | "coveralls": "^3.0.2", 44 | "eslint": "^4.19.1", 45 | "eslint-config-google": "^0.9.1", 46 | "eslint-config-mocha": "0.0.0", 47 | "eslint-config-prettier": "^2.9.0", 48 | "eslint-config-standard": "^5.3.5", 49 | "eslint-plugin-chai-friendly": "^0.4.1", 50 | "eslint-plugin-import": "^1.16.0", 51 | "eslint-plugin-mocha-only": "0.0.3", 52 | "eslint-plugin-prettier": "^2.6.0", 53 | "eslint-plugin-promise": "^1.3.2", 54 | "eslint-plugin-spellcheck": "0.0.10", 55 | "eslint-plugin-standard": "^1.3.3", 56 | "pre-commit": "^1.2.2", 57 | "prettier": "^1.12.1", 58 | "solidity-coverage": "0.5.8" 59 | } 60 | } 61 | -------------------------------------------------------------------------------- /scripts/pre-commit.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | require_clean_work_tree () { 3 | # Update the index 4 | git update-index -q --ignore-submodules --refresh 5 | err=0 6 | 7 | # Disallow unstaged changes in the working tree 8 | if ! git diff-files --quiet --ignore-submodules -- 9 | then 10 | echo >&2 "cannot commit: you have unstaged changes." 11 | git diff-files --name-status -r --ignore-submodules -- >&2 12 | err=1 13 | fi 14 | if [ $err = 1 ] 15 | then 16 | echo >&2 "Please commit or stash them." 17 | exit 1 18 | fi 19 | } 20 | 21 | require_clean_work_tree 22 | exit 0 23 | -------------------------------------------------------------------------------- /scripts/setup-ci.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env bash 2 | npx setup-local-chains "lite" 3 | -------------------------------------------------------------------------------- /scripts/test.sh: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env bash 2 | DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd ) 3 | PROJECT_DIR=$DIR/../ 4 | 5 | # Exit script as soon as a command fails. 6 | set -o errexit 7 | 8 | process-pid(){ 9 | lsof -t -i:$1 10 | } 11 | 12 | run-unit-tests(){ 13 | npx truffle --network $1 test $PROJECT_DIR/test/unit/*.js 14 | } 15 | 16 | run-all-tests(){ 17 | read REF PORT < <(npx get-network-config $1) 18 | 19 | if [ $(process-pid $PORT) ] 20 | then 21 | REFRESH=0 22 | else 23 | REFRESH=1 24 | echo "------Start blockchain(s)" 25 | npx start-chain $1 26 | fi 27 | 28 | echo "------Running unit tests" 29 | run-unit-tests $1 30 | 31 | cleanup(){ 32 | if [ "$REFRESH" == "1" ] 33 | then 34 | npx stop-chain $1 35 | fi 36 | } 37 | trap cleanup EXIT 38 | } 39 | 40 | run-all-tests "ganacheUnitTest" 41 | 42 | exit 0 43 | -------------------------------------------------------------------------------- /test/unit/gas_cost.js: -------------------------------------------------------------------------------- 1 | // TODO(naguib): Fail tests if gas utilization changes 2 | const MedianOracle = artifacts.require('MedianOracle'); 3 | 4 | const _require = require('app-root-path').require; 5 | const BlockchainCaller = _require('/util/blockchain_caller'); 6 | const chain = new BlockchainCaller(web3); 7 | 8 | require('chai') 9 | .use(require('chai-bignumber')(web3.BigNumber)) 10 | .should(); 11 | 12 | let oracle; 13 | 14 | async function setupContractsAndAccounts (accounts) { 15 | oracle = await MedianOracle.new(60, 10, 1); 16 | } 17 | 18 | // TODO(naguib): Fail if gas utilization changes. 19 | contract('MedianOracle:GasTests', async function (accounts) { 20 | before(async function () { 21 | await setupContractsAndAccounts(accounts); 22 | const count = 9; 23 | const list = Array.from({length: count}, () => Math.floor(Math.random() * 10 ** 18)); 24 | 25 | for (let i = 0; i < count; i++) { 26 | await oracle.addProvider(accounts[i + 1], { from: accounts[0] }); 27 | const r = await oracle.pushReport(list[i], { from: accounts[i + 1] }); 28 | console.log('Initial pushReport() gas:', r.receipt.gasUsed); 29 | } 30 | await chain.waitForSomeTime(10); 31 | for (let i = 0; i < count; i++) { 32 | const r = await oracle.pushReport(list[i] + 1, { from: accounts[i + 1] }); 33 | console.log('Update pushReport() gas:', r.receipt.gasUsed); 34 | } 35 | }); 36 | 37 | describe('when the sources are live', function () { 38 | it('should calculate the combined market rate and volume', async function () { 39 | const r = await oracle.getData(); 40 | console.log('getData() gas:', r.receipt.gasUsed); 41 | }); 42 | }); 43 | }); 44 | -------------------------------------------------------------------------------- /test/unit/median_oracle.js: -------------------------------------------------------------------------------- 1 | // TODO(naguib): Add gas usage checks 2 | const MedianOracle = artifacts.require('MedianOracle'); 3 | 4 | const _require = require('app-root-path').require; 5 | const BlockchainCaller = _require('/util/blockchain_caller'); 6 | const chain = new BlockchainCaller(web3); 7 | 8 | require('chai') 9 | .use(require('chai-bignumber')(web3.BigNumber)) 10 | .should(); 11 | 12 | let oracle, deployer, A, B, C, D, r; 13 | 14 | async function setupContractsAndAccounts (accounts) { 15 | deployer = accounts[0]; 16 | A = accounts[1]; 17 | B = accounts[2]; 18 | C = accounts[3]; 19 | D = accounts[4]; 20 | oracle = await MedianOracle.new(60, 10, 1); 21 | } 22 | 23 | contract('MedianOracle:constructor', async function (accounts) { 24 | before(async function () { 25 | await setupContractsAndAccounts(accounts); 26 | }); 27 | 28 | it('should fail if a parameter is invalid', async function () { 29 | expect(await chain.isEthException(oracle = await MedianOracle.new(60, 10, 1))).to.be.false; 30 | expect(await chain.isEthException(MedianOracle.new(60, 10, 0))).to.be.true; 31 | expect(await chain.isEthException(MedianOracle.new(60 * 60 * 24 * 365 * 11, 10, 1))).to.be.true; 32 | expect(await chain.isEthException(oracle.setReportExpirationTimeSec(60 * 60 * 24 * 365 * 11))).to.be.true; 33 | }); 34 | }); 35 | 36 | contract('MedianOracle:providersSize', async function (accounts) { 37 | before(async function () { 38 | await setupContractsAndAccounts(accounts); 39 | }); 40 | 41 | it('should return the number of sources added to the whitelist', async function () { 42 | await oracle.addProvider(A); 43 | await oracle.addProvider(B); 44 | await oracle.addProvider(C); 45 | (await oracle.providersSize.call()).should.be.bignumber.eq(3); 46 | }); 47 | }); 48 | 49 | contract('MedianOracle:addProvider', async function (accounts) { 50 | describe('when successful', function () { 51 | before(async function () { 52 | await setupContractsAndAccounts(accounts); 53 | (await oracle.providersSize.call()).should.be.bignumber.eq(0); 54 | r = await oracle.addProvider(A); 55 | }); 56 | 57 | it('should emit SourceAdded message', async function () { 58 | const logs = r.logs; 59 | const event = logs[0]; 60 | expect(event.event).to.eq('ProviderAdded'); 61 | expect(event.args.provider).to.eq(A); 62 | }); 63 | it('should add source to the whitelist', async function () { 64 | (await oracle.providersSize.call()).should.be.bignumber.eq(1); 65 | }); 66 | it('should not add an existing source to the whitelist', async function () { 67 | expect(await chain.isEthException(oracle.addProvider(A, { from: deployer }))).to.be.true; 68 | }); 69 | }); 70 | }); 71 | 72 | contract('MedianOracle:pushReport', async function (accounts) { 73 | before(async function () { 74 | await setupContractsAndAccounts(accounts); 75 | }); 76 | it('should only push from authorized source', async function () { 77 | expect(await chain.isEthException(oracle.pushReport(1000000000000000000, { from: A }))).to.be.true; 78 | oracle.addProvider(A, { from: deployer }); 79 | r = await oracle.pushReport(1000000000000000000, { from: A }); 80 | // should fail if reportDelaySec did not pass since the previous push 81 | expect(await chain.isEthException(oracle.pushReport(1000000000000000000, { from: A }))).to.be.true; 82 | }); 83 | it('should emit ProviderReportPushed message', async function () { 84 | const logs = r.logs; 85 | const event = logs[0]; 86 | expect(event.event).to.eq('ProviderReportPushed'); 87 | expect(event.args.provider).to.eq(A); 88 | event.args.payload.should.be.bignumber.eq(1000000000000000000); 89 | const block = await chain.web3.eth.getBlock(logs[0].blockNumber); 90 | event.args.timestamp.should.be.bignumber.eq(block.timestamp); 91 | }); 92 | }); 93 | 94 | contract('MedianOracle:addProvider:accessControl', async function (accounts) { 95 | before(async function () { 96 | await setupContractsAndAccounts(accounts); 97 | }); 98 | 99 | it('should be callable by owner', async function () { 100 | expect( 101 | await chain.isEthException(oracle.addProvider(A, { from: deployer })) 102 | ).to.be.false; 103 | }); 104 | 105 | it('should NOT be callable by non-owner', async function () { 106 | expect( 107 | await chain.isEthException(oracle.addProvider(A, { from: B })) 108 | ).to.be.true; 109 | }); 110 | }); 111 | 112 | contract('MedianOracle:removeProvider', async function (accounts) { 113 | describe('when source is part of the whitelist', () => { 114 | before(async function () { 115 | await setupContractsAndAccounts(accounts); 116 | await oracle.addProvider(A); 117 | await oracle.addProvider(B); 118 | await oracle.addProvider(C); 119 | await oracle.addProvider(D); 120 | (await oracle.providersSize.call()).should.be.bignumber.eq(4); 121 | r = await oracle.removeProvider(B); 122 | }); 123 | it('should emit SourceRemoved message', async function () { 124 | const logs = r.logs; 125 | const event = logs[0]; 126 | expect(event.event).to.eq('ProviderRemoved'); 127 | expect(event.args.provider).to.eq(B); 128 | }); 129 | it('should remove source from the whitelist', async function () { 130 | (await oracle.providersSize.call()).should.be.bignumber.eq(3); 131 | expect( 132 | await chain.isEthException(oracle.pushReport(1000000000000000000, { from: B })) 133 | ).to.be.true; 134 | await oracle.pushReport(1000000000000000000, { from: D }); 135 | }); 136 | }); 137 | }); 138 | 139 | contract('MedianOracle:removeProvider', async function (accounts) { 140 | beforeEach(async function () { 141 | await setupContractsAndAccounts(accounts); 142 | await oracle.addProvider(A); 143 | await oracle.addProvider(B); 144 | await oracle.addProvider(C); 145 | await oracle.addProvider(D); 146 | (await oracle.providersSize.call()).should.be.bignumber.eq(4); 147 | }); 148 | it('Remove last element', async function () { 149 | r = await oracle.removeProvider(D); 150 | (await oracle.providersSize.call()).should.be.bignumber.eq(3); 151 | expect(await oracle.providers.call(0)).to.eq(A); 152 | expect(await oracle.providers.call(1)).to.eq(B); 153 | expect(await oracle.providers.call(2)).to.eq(C); 154 | }); 155 | 156 | it('Remove middle element', async function () { 157 | r = await oracle.removeProvider(B); 158 | (await oracle.providersSize.call()).should.be.bignumber.eq(3); 159 | expect(await oracle.providers.call(0)).to.eq(A); 160 | expect(await oracle.providers.call(1)).to.eq(D); 161 | expect(await oracle.providers.call(2)).to.eq(C); 162 | }); 163 | 164 | it('Remove only element', async function () { 165 | r = await oracle.removeProvider(A); 166 | r = await oracle.removeProvider(B); 167 | r = await oracle.removeProvider(C); 168 | (await oracle.providersSize.call()).should.be.bignumber.eq(1); 169 | expect(await oracle.providers.call(0)).to.eq(D); 170 | r = await oracle.removeProvider(D); 171 | (await oracle.providersSize.call()).should.be.bignumber.eq(0); 172 | }); 173 | }); 174 | 175 | contract('MedianOracle:removeProvider', async function (accounts) { 176 | it('when source is NOT part of the whitelist', async function () { 177 | await setupContractsAndAccounts(accounts); 178 | await oracle.addProvider(A); 179 | await oracle.addProvider(B); 180 | (await oracle.providersSize.call()).should.be.bignumber.eq(2); 181 | await oracle.removeProvider(C, { from: deployer }); 182 | (await oracle.providersSize.call()).should.be.bignumber.eq(2); 183 | expect(await oracle.providers.call(0)).to.eq(A); 184 | expect(await oracle.providers.call(1)).to.eq(B); 185 | }); 186 | }); 187 | 188 | contract('MedianOracle:removeProvider:accessControl', async function (accounts) { 189 | before(async function () { 190 | await setupContractsAndAccounts(accounts); 191 | await oracle.addProvider(A); 192 | }); 193 | 194 | it('should be callable by owner', async function () { 195 | expect( 196 | await chain.isEthException(oracle.removeProvider(A, { from: deployer })) 197 | ).to.be.false; 198 | }); 199 | 200 | it('should NOT be callable by non-owner', async function () { 201 | expect( 202 | await chain.isEthException(oracle.removeProvider(A, { from: A })) 203 | ).to.be.true; 204 | }); 205 | }); 206 | 207 | contract('MedianOracle:getData', async function (accounts) { 208 | before(async function () { 209 | await setupContractsAndAccounts(accounts); 210 | await oracle.addProvider(A); 211 | await oracle.addProvider(B); 212 | await oracle.addProvider(C); 213 | await oracle.addProvider(D); 214 | 215 | await oracle.pushReport(1000000000000000000, { from: D }); 216 | await oracle.pushReport(1041000000000000000, { from: B }); 217 | await oracle.pushReport(1053200000000000000, { from: A }); 218 | await oracle.pushReport(2041000000000000000, { from: C }); 219 | await chain.waitForSomeTime(10); 220 | }); 221 | 222 | describe('when the reports are valid', function () { 223 | it('should calculate the combined market rate and volume', async function () { 224 | const resp = await oracle.getData.call(); 225 | expect(resp[1]).to.be.true; 226 | resp[0].should.be.bignumber.eq(1047100000000000000); 227 | }); 228 | }); 229 | }); 230 | 231 | contract('MedianOracle:getData', async function (accounts) { 232 | describe('when one of reports has expired', function () { 233 | before(async function () { 234 | await setupContractsAndAccounts(accounts); 235 | await oracle.addProvider(A); 236 | await oracle.addProvider(B); 237 | await oracle.addProvider(C); 238 | await oracle.addProvider(D); 239 | oracle.setReportExpirationTimeSec(40); 240 | await oracle.pushReport(2041000000000000000, { from: C }); 241 | await chain.waitForSomeTime(41); 242 | await oracle.pushReport(1041000000000000000, { from: B }); 243 | await oracle.pushReport(1000000000000000000, { from: D }); 244 | await oracle.pushReport(1053200000000000000, { from: A }); 245 | await chain.waitForSomeTime(10); 246 | }); 247 | 248 | it('should emit ReportTimestampOutOfRange message', async function () { 249 | const resp = await oracle.getData(); 250 | const logs = resp.logs; 251 | const event = logs[0]; 252 | expect(event.event).to.eq('ReportTimestampOutOfRange'); 253 | expect(event.args.provider).to.eq(C); 254 | }); 255 | it('should calculate the exchange rate', async function () { 256 | const resp = await oracle.getData.call(); 257 | expect(resp[1]).to.be.true; 258 | resp[0].should.be.bignumber.eq(1041000000000000000); 259 | }); 260 | }); 261 | }); 262 | 263 | contract('MedianOracle:getData', async function (accounts) { 264 | describe('when one of the reports is too recent', function () { 265 | before(async function () { 266 | await setupContractsAndAccounts(accounts); 267 | await oracle.addProvider(A); 268 | await oracle.addProvider(B); 269 | await oracle.addProvider(C); 270 | await oracle.addProvider(D); 271 | 272 | await oracle.pushReport(2041000000000000000, { from: C }); 273 | await oracle.pushReport(1000000000000000000, { from: D }); 274 | await oracle.pushReport(1053200000000000000, { from: A }); 275 | await chain.waitForSomeTime(10); 276 | await oracle.pushReport(1041000000000000000, { from: B }); 277 | }); 278 | 279 | it('should emit ReportTimestampOutOfRange message', async function () { 280 | const resp = await oracle.getData(); 281 | const logs = resp.logs; 282 | const event = logs[0]; 283 | expect(event.event).to.eq('ReportTimestampOutOfRange'); 284 | expect(event.args.provider).to.eq(B); 285 | }); 286 | it('should calculate the exchange rate', async function () { 287 | const resp = await oracle.getData.call(); 288 | expect(resp[1]).to.be.true; 289 | resp[0].should.be.bignumber.eq(1053200000000000000); 290 | }); 291 | }); 292 | }); 293 | 294 | contract('MedianOracle:getData', async function (accounts) { 295 | describe('when not enough providers are valid', function () { 296 | before(async function () { 297 | await setupContractsAndAccounts(accounts); 298 | await oracle.addProvider(A); 299 | await oracle.addProvider(B); 300 | await oracle.addProvider(C); 301 | await oracle.addProvider(D); 302 | expect(await chain.isEthException(oracle.setMinimumProviders(0))).to.be.true; 303 | await oracle.setMinimumProviders(4); 304 | 305 | await oracle.pushReport(2041000000000000000, { from: C }); 306 | await oracle.pushReport(1000000000000000000, { from: D }); 307 | await oracle.pushReport(1053200000000000000, { from: A }); 308 | await chain.waitForSomeTime(10); 309 | await oracle.pushReport(1041000000000000000, { from: B }); 310 | }); 311 | 312 | it('should emit ReportTimestampOutOfRange message', async function () { 313 | const resp = await oracle.getData(); 314 | const logs = resp.logs; 315 | const event = logs[0]; 316 | expect(event.event).to.eq('ReportTimestampOutOfRange'); 317 | expect(event.args.provider).to.eq(B); 318 | }); 319 | it('should not have a valid result', async function () { 320 | const resp = await oracle.getData.call(); 321 | expect(resp[1]).to.be.false; 322 | resp[0].should.be.bignumber.eq(0); 323 | }); 324 | }); 325 | }); 326 | 327 | contract('MedianOracle:getData', async function (accounts) { 328 | describe('when all reports have expired', function () { 329 | before(async function () { 330 | await setupContractsAndAccounts(accounts); 331 | await oracle.addProvider(A); 332 | await oracle.addProvider(B); 333 | await oracle.pushReport(1053200000000000000, { from: A }); 334 | await oracle.pushReport(1041000000000000000, { from: B }); 335 | await chain.waitForSomeTime(61); 336 | }); 337 | 338 | it('should emit 2 ReportTimestampOutOfRange messages', async function () { 339 | const resp = await oracle.getData(); 340 | const logs = resp.logs; 341 | let event = logs[0]; 342 | expect(event.event).to.eq('ReportTimestampOutOfRange'); 343 | expect(event.args.provider).to.eq(A); 344 | 345 | event = logs[1]; 346 | expect(event.event).to.eq('ReportTimestampOutOfRange'); 347 | expect(event.args.provider).to.eq(B); 348 | }); 349 | it('should return false and 0', async function () { 350 | const resp = await oracle.getData.call(); 351 | expect(resp[1]).to.be.false; 352 | resp[0].should.be.bignumber.eq(0); 353 | }); 354 | }); 355 | }); 356 | 357 | contract('MedianOracle:getData', async function (accounts) { 358 | before(async function () { 359 | await setupContractsAndAccounts(accounts); 360 | await oracle.addProvider(A); 361 | 362 | await oracle.pushReport(1100000000000000000, { from: A }); 363 | await chain.waitForSomeTime(61); 364 | await oracle.pushReport(1200000000000000000, { from: A }); 365 | }); 366 | 367 | describe('when recent is too recent and past is too old', function () { 368 | it('should emit ReportTimestampOutOfRange message', async function () { 369 | const resp = await oracle.getData(); 370 | const logs = resp.logs; 371 | const event = logs[0]; 372 | expect(event.event).to.eq('ReportTimestampOutOfRange'); 373 | expect(event.args.provider).to.eq(A); 374 | }); 375 | 376 | it('should fail', async function () { 377 | const resp = await oracle.getData.call(); 378 | expect(resp[1]).to.be.false; 379 | }); 380 | }); 381 | }); 382 | 383 | contract('MedianOracle:getData', async function (accounts) { 384 | before(async function () { 385 | await setupContractsAndAccounts(accounts); 386 | await oracle.addProvider(A); 387 | 388 | await oracle.pushReport(1100000000000000000, { from: A }); 389 | await chain.waitForSomeTime(10); 390 | await oracle.pushReport(1200000000000000000, { from: A }); 391 | await chain.waitForSomeTime(1); 392 | oracle.setReportDelaySec(30); 393 | }); 394 | 395 | describe('when recent is too recent and past is too recent', function () { 396 | it('should emit ReportTimestampOutOfRange message', async function () { 397 | const resp = await oracle.getData(); 398 | const logs = resp.logs; 399 | const event = logs[0]; 400 | expect(event.event).to.eq('ReportTimestampOutOfRange'); 401 | expect(event.args.provider).to.eq(A); 402 | }); 403 | 404 | it('should fail', async function () { 405 | const resp = await oracle.getData.call(); 406 | expect(resp[1]).to.be.false; 407 | }); 408 | }); 409 | }); 410 | 411 | contract('MedianOracle:getData', async function (accounts) { 412 | before(async function () { 413 | await setupContractsAndAccounts(accounts); 414 | await oracle.addProvider(A); 415 | 416 | await oracle.pushReport(1100000000000000000, { from: A }); 417 | await chain.waitForSomeTime(30); 418 | await oracle.pushReport(1200000000000000000, { from: A }); 419 | await chain.waitForSomeTime(4); 420 | }); 421 | 422 | describe('when recent is too recent and past is valid', function () { 423 | it('should succeeded', async function () { 424 | const resp = await oracle.getData.call(); 425 | expect(resp[1]).to.be.true; 426 | resp[0].should.be.bignumber.eq(1100000000000000000); 427 | }); 428 | }); 429 | }); 430 | 431 | contract('MedianOracle:getData', async function (accounts) { 432 | before(async function () { 433 | await setupContractsAndAccounts(accounts); 434 | await oracle.addProvider(A); 435 | 436 | await oracle.pushReport(1100000000000000000, { from: A }); 437 | await chain.waitForSomeTime(30); 438 | await oracle.pushReport(1200000000000000000, { from: A }); 439 | await chain.waitForSomeTime(10); 440 | }); 441 | 442 | describe('when recent is not too recent nor too old', function () { 443 | it('should succeed', async function () { 444 | const resp = await oracle.getData.call(); 445 | expect(resp[1]).to.be.true; 446 | resp[0].should.be.bignumber.eq(1200000000000000000); 447 | }); 448 | }); 449 | }); 450 | 451 | contract('MedianOracle:getData', async function (accounts) { 452 | before(async function () { 453 | await setupContractsAndAccounts(accounts); 454 | await oracle.addProvider(A); 455 | 456 | await oracle.pushReport(1100000000000000000, { from: A }); 457 | await chain.waitForSomeTime(30); 458 | await oracle.pushReport(1200000000000000000, { from: A }); 459 | await chain.waitForSomeTime(80); 460 | }); 461 | 462 | describe('when recent is not too recent but too old', function () { 463 | it('should fail', async function () { 464 | const resp = await oracle.getData.call(); 465 | expect(resp[1]).to.be.false; 466 | }); 467 | }); 468 | }); 469 | 470 | contract('MedianOracle:PurgeReports', async function (accounts) { 471 | before(async function () { 472 | await setupContractsAndAccounts(accounts); 473 | await oracle.addProvider(A); 474 | 475 | await oracle.pushReport(1100000000000000000, { from: A }); 476 | await chain.waitForSomeTime(20); 477 | await oracle.pushReport(1200000000000000000, { from: A }); 478 | await chain.waitForSomeTime(20); 479 | await oracle.purgeReports({ from: A }); 480 | }); 481 | 482 | it('data not available after purge', async function () { 483 | const resp = await oracle.getData.call(); 484 | expect(resp[1]).to.be.false; 485 | }); 486 | it('data available after another report', async function () { 487 | await oracle.pushReport(1300000000000000000, { from: A }); 488 | await chain.waitForSomeTime(20); 489 | const resp = await oracle.getData.call(); 490 | expect(resp[1]).to.be.true; 491 | resp[0].should.be.bignumber.eq(1300000000000000000); 492 | }); 493 | 494 | it('cannot purge a non-whitelisted provider', async function () { 495 | expect(await chain.isEthException(oracle.purgeReports({ from: B }))).to.be.true; 496 | expect(await chain.isEthException(oracle.purgeReports({ from: A }))).to.be.false; 497 | await oracle.removeProvider(A); 498 | expect(await chain.isEthException(oracle.purgeReports({ from: A }))).to.be.true; 499 | }); 500 | }); 501 | -------------------------------------------------------------------------------- /test/unit/select.js: -------------------------------------------------------------------------------- 1 | const SelectMock = artifacts.require('SelectMock'); 2 | 3 | const BigNumber = web3.BigNumber; 4 | const _require = require('app-root-path').require; 5 | const BlockchainCaller = _require('/util/blockchain_caller'); 6 | const chain = new BlockchainCaller(web3); 7 | 8 | require('chai') 9 | .use(require('chai-bignumber')(BigNumber)) 10 | .should(); 11 | 12 | contract('Select', () => { 13 | let select; 14 | 15 | beforeEach(async function () { 16 | select = await SelectMock.new(); 17 | }); 18 | 19 | async function returnVal (tx) { 20 | return (await tx).logs[0].args.val; 21 | } 22 | 23 | describe('Select:computeMedian', function () { 24 | it('median of 1', async function () { 25 | const a = new BigNumber(5678); 26 | (await returnVal(select.computeMedian([a], 1))).should.be.bignumber.eq(a); 27 | }); 28 | it('median of 2', async function () { 29 | const list = [new BigNumber(10000), new BigNumber(30000)]; 30 | (await returnVal(select.computeMedian(list, 2))).should.be.bignumber.eq(20000); 31 | }); 32 | it('median of 3', async function () { 33 | const list = [new BigNumber(10000), new BigNumber(30000), new BigNumber(21000)]; 34 | (await returnVal(select.computeMedian(list, 3))).should.be.bignumber.eq(21000); 35 | }); 36 | it('median of odd sized list', async function () { 37 | const count = 15; 38 | const list = Array.from({length: count}, () => Math.floor(Math.random() * 10 ** 18)); 39 | const result = await returnVal(select.computeMedian(list, count)); 40 | list.sort((a, b) => b - a); 41 | const median = new BigNumber(list[Math.floor(count / 2)].toString()); 42 | result.should.be.bignumber.eq(median); 43 | }); 44 | it('median of even sized list', async function () { 45 | const count = 20; 46 | const list = Array.from({length: count}, () => Math.floor(Math.random() * 10 ** 18)); 47 | const result = await returnVal(select.computeMedian(list, count)); 48 | list.sort((a, b) => b - a); 49 | let median = new BigNumber(list[Math.floor(count / 2)].toString()); 50 | median = median.add(new BigNumber(list[Math.floor(count / 2) - 1].toString())); 51 | median = median.div(2); 52 | result.should.be.bignumber.eq(median); 53 | }); 54 | it('not enough elements in array', async function () { 55 | expect(await chain.isEthException(select.computeMedian([1], 2))).to.be.true; 56 | }); 57 | it('median of empty list', async function () { 58 | expect(await chain.isEthException(select.computeMedian([], 1))).to.be.true; 59 | }); 60 | it('median of list of size 0', async function () { 61 | expect(await chain.isEthException(select.computeMedian([10000], 0))).to.be.true; 62 | }); 63 | }); 64 | }); 65 | -------------------------------------------------------------------------------- /truffle.js: -------------------------------------------------------------------------------- 1 | const connectionConfig = require('frg-ethereum-runners/config/network_config.json'); 2 | 3 | module.exports = { 4 | networks: { 5 | ganacheUnitTest: connectionConfig.ganacheUnitTest, 6 | gethUnitTest: connectionConfig.gethUnitTest, 7 | testrpcCoverage: connectionConfig.testrpcCoverage 8 | }, 9 | mocha: { 10 | enableTimeouts: false 11 | }, 12 | compilers: { 13 | solc: { 14 | version: '0.4.24' 15 | } 16 | } 17 | }; 18 | -------------------------------------------------------------------------------- /util/blockchain_caller.js: -------------------------------------------------------------------------------- 1 | // A wrapper on top of web3 to help interact with an underlying blockchain 2 | // This is where blockchain specific interaction logic goes 3 | class BlockchainCaller { 4 | constructor (web3) { 5 | this._web3 = web3; 6 | } 7 | get web3 () { 8 | return this._web3; 9 | } 10 | rpcmsg (method, params = []) { 11 | const id = Date.now(); 12 | return { 13 | jsonrpc: '2.0', 14 | method: method, 15 | params: params, 16 | 'id': id 17 | }; 18 | } 19 | } 20 | 21 | BlockchainCaller.prototype.sendRawToBlockchain = function (method, params) { 22 | return new Promise((resolve, reject) => { 23 | this.web3.currentProvider.sendAsync(this.rpcmsg(method, params), function (e, r) { 24 | if (e) reject(e); 25 | resolve(r); 26 | }); 27 | }); 28 | }; 29 | 30 | BlockchainCaller.prototype.waitForSomeTime = async function (durationInSec) { 31 | try { 32 | await this.sendRawToBlockchain('evm_increaseTime', [durationInSec]); 33 | } catch (e) { 34 | return new Promise((resolve, reject) => { 35 | setTimeout(() => resolve(), durationInSec * 1000); 36 | }); 37 | } 38 | }; 39 | 40 | BlockchainCaller.prototype.getUserAccounts = async function () { 41 | const accounts = await this.sendRawToBlockchain('eth_accounts'); 42 | return accounts.result; 43 | }; 44 | 45 | BlockchainCaller.prototype.getBlockGasLimit = async function () { 46 | const block = await this.web3.eth.getBlock('latest'); 47 | return block.gasLimit; 48 | }; 49 | 50 | BlockchainCaller.prototype.getTransactionMetrics = async function (hash) { 51 | const txR = await this.web3.eth.getTransactionReceipt(hash); 52 | const tx = await this.web3.eth.getTransaction(hash); 53 | return { 54 | gasUsed: txR.gasUsed, 55 | gasPrice: tx.gasPrice, 56 | byteCodeSize: (tx.input.length * 4 / 8) 57 | }; 58 | }; 59 | 60 | /* 61 | Inspired loosely by Openzeppelin's assertRevert. 62 | https://github.com/OpenZeppelin/openzeppelin-solidity/blob/master/test/helpers/assertRevert.js 63 | */ 64 | BlockchainCaller.prototype.isEthException = async function (promise) { 65 | let msg = 'No Exception'; 66 | try { 67 | await promise; 68 | } catch (e) { 69 | msg = e.message; 70 | } 71 | return msg.includes('VM Exception while processing transaction: revert') || 72 | msg.includes('VM Exception while processing transaction: invalid opcode') || 73 | msg.includes('exited with an error (status 0)') 74 | }; 75 | 76 | module.exports = BlockchainCaller; 77 | --------------------------------------------------------------------------------