├── adaptor ├── node.json ├── index.js ├── package.json ├── spec.js ├── server.js └── package-lock.json ├── Dockerfile ├── entrypoint.sh ├── iota-get-account-schema.json ├── .gitignore └── README.md /adaptor/node.json: -------------------------------------------------------------------------------- 1 | { 2 | "host": "http://node.lukaseder.de", 3 | "port": 14265 4 | } -------------------------------------------------------------------------------- /adaptor/index.js: -------------------------------------------------------------------------------- 1 | const app = require('./server'); 2 | 3 | var listener = app.listen(8081, function() { 4 | console.log("IOTA External Adaptor Listening on: ", listener.address().address + listener.address().port); 5 | }); -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:9.4.0 2 | 3 | ADD adaptor/ /opt/adaptor/ 4 | 5 | ADD entrypoint.sh /entrypoint.sh 6 | RUN chmod 0700 /entrypoint.sh 7 | 8 | RUN cd /opt/adaptor/ && npm install 9 | 10 | EXPOSE 8081 11 | 12 | ENTRYPOINT "/entrypoint.sh" 13 | -------------------------------------------------------------------------------- /entrypoint.sh: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | # Create a node config json file 4 | cd /opt/adaptor 5 | touch node.json 6 | echo "{ 7 | 8 | \"host\": \"$HOST\", 9 | 10 | \"port\": $PORT 11 | 12 | }" > node.json 13 | 14 | # Run the adaptor 15 | node index.js 16 | -------------------------------------------------------------------------------- /adaptor/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "iota-clea", 3 | "version": "1.0.0", 4 | "description": "IOTA External Adaptor for ChainLink\"", 5 | "main": "server.js", 6 | "scripts": { 7 | "test": "mocha -R spec spec.js" 8 | }, 9 | "keywords": [ 10 | "LINK" 11 | ], 12 | "author": "Jonny Huxtable", 13 | "license": "ISC", 14 | "dependencies": { 15 | "body-parser": "^1.18.2", 16 | "cookie-parser": "^1.4.3", 17 | "express": "^4.16.2", 18 | "iota.lib.js": "^0.4.7", 19 | "multer": "^1.3.0" 20 | }, 21 | "devDependencies": { 22 | "chai": "^4.1.2", 23 | "supertest": "^3.0.0" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /iota-get-account-schema.json: -------------------------------------------------------------------------------- 1 | { 2 | "config": { 3 | "properties": { 4 | "seed": { 5 | "description": "Non tryte seed string.", 6 | "type": "string" 7 | } 8 | }, 9 | "required": [ 10 | "seed" 11 | ], 12 | "type": "object" 13 | }, 14 | "input": { 15 | "properties": { 16 | "_value": { 17 | "description": "Input parameters are not used by this adapter.", 18 | "type": "string" 19 | } 20 | }, 21 | "required": [], 22 | "type": "object" 23 | }, 24 | "output": { 25 | "properties": { 26 | "value": { 27 | "description": "The value parsed out of the JSON API.", 28 | "type": "string" 29 | } 30 | }, 31 | "required": [ 32 | "value" 33 | ], 34 | "type": "object" 35 | } 36 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Created by https://www.gitignore.io/api/node 2 | 3 | ### Node ### 4 | # Logs 5 | logs 6 | *.log 7 | npm-debug.log* 8 | yarn-debug.log* 9 | yarn-error.log* 10 | 11 | # Runtime data 12 | pids 13 | *.pid 14 | *.seed 15 | *.pid.lock 16 | 17 | # Directory for instrumented libs generated by jscoverage/JSCover 18 | lib-cov 19 | 20 | # Coverage directory used by tools like istanbul 21 | coverage 22 | 23 | # nyc test coverage 24 | .nyc_output 25 | 26 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 27 | .grunt 28 | 29 | # Bower dependency directory (https://bower.io/) 30 | bower_components 31 | 32 | # node-waf configuration 33 | .lock-wscript 34 | 35 | # Compiled binary addons (http://nodejs.org/api/addons.html) 36 | build/Release 37 | 38 | # Dependency directories 39 | node_modules/ 40 | jspm_packages/ 41 | 42 | # Typescript v1 declaration files 43 | typings/ 44 | 45 | # Optional npm cache directory 46 | .npm 47 | 48 | # Optional eslint cache 49 | .eslintcache 50 | 51 | # Optional REPL history 52 | .node_repl_history 53 | 54 | # Output of 'npm pack' 55 | *.tgz 56 | 57 | # Yarn Integrity file 58 | .yarn-integrity 59 | 60 | # dotenv environment variables file 61 | .env -------------------------------------------------------------------------------- /adaptor/spec.js: -------------------------------------------------------------------------------- 1 | const request = require('supertest'); 2 | const app = require('./server'); 3 | const expect = require('chai').expect; 4 | 5 | var server; 6 | 7 | describe('IOTA External Adaptor', function () { 8 | 9 | this.timeout(5000); 10 | 11 | before(function() { 12 | server = app.listen(3000); 13 | }); 14 | 15 | after(function () { 16 | server.close(); 17 | }); 18 | 19 | it('responds to /', function testSlash(done) { 20 | request(app) 21 | .get('/') 22 | .expect(200, done); 23 | }); 24 | 25 | it('responds to /account-data', function testInfo(done) { 26 | request(app) 27 | .get('/account-data') 28 | .query({ "seed": "VGMQDIPUZGUMRSWC9GODSXHCSMVTGLASTKWPHLETZPQJUHGBGBQRMZMFRVRRLPNRSUFXPRMPFRLGGZSCZ" }) 29 | .expect(200) 30 | .end(function(err, res) { 31 | expect(res.body.latestAddress).to.be.a('string'); 32 | expect(res.body.balance).to.equal(0); 33 | done(); 34 | }); 35 | }); 36 | 37 | it('responds to /info', function testInfo(done) { 38 | request(app) 39 | .get('/info') 40 | .expect(200) 41 | .end(function(err, res) { 42 | expect(res.statusCode).to.equal(200); 43 | expect(res.body.appName).to.equal("IRI"); 44 | done(); 45 | }); 46 | }); 47 | 48 | it('responds to /transaction-object', function testInfo(done) { 49 | request(app) 50 | .get('/transaction-object') 51 | .query({ "transactions": "FXRLFGBUPYASKWPSAEXLHAMZYOBITVCCWAFDWMJCFRKT9D9VBRXOAMHSIODDTJ9UVUVPSRFKQAWFA9999" }) 52 | .expect(200) 53 | .end(function(err, res) { 54 | expect(res.body[0].hash).to.be.a('string'); 55 | done(); 56 | }); 57 | }); 58 | 59 | it('responds to /transaction-object-query', function testInfo(done) { 60 | request(app) 61 | .get('/transaction-object-query') 62 | .query({ "bundles": "EWGITWCAJJXTZRCHENSTBXCJFFCSGKRIIGFFACNWVESNIHOFFJBR9UBVHBSBATRRJADWZN9HDHKAYNKYD" }) 63 | .expect(200) 64 | .end(function(err, res) { 65 | expect(res.body).to.be.a('array'); 66 | done(); 67 | }); 68 | }); 69 | 70 | it('404 everything else', function testPath(done) { 71 | request(app) 72 | .get('/foo/bar') 73 | .expect(404, done); 74 | }); 75 | }); -------------------------------------------------------------------------------- /adaptor/server.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs'); 2 | 3 | const express = require('express'); 4 | const IOTA = require('iota.lib.js'); 5 | 6 | const app = express(); 7 | 8 | module.exports = app; 9 | 10 | var iota = new IOTA(JSON.parse(fs.readFileSync('node.json').toString())); 11 | 12 | function throwError(res, statusCode, message) { 13 | res.status(statusCode).send({ error: message }); 14 | } 15 | 16 | function throwInvalidRequest(res) { 17 | throwError(res, 400, "Invalid request!"); 18 | } 19 | 20 | app.get('/account-data', function(req, res) { 21 | trytesSeed = iota.utils.toTrytes(req.query.seed); 22 | iota.api.getAccountData(trytesSeed, function(error, response) { 23 | if (error) { 24 | console.error(error); 25 | throwInvalidRequest(res); 26 | } else { 27 | res.send(response); 28 | } 29 | }); 30 | }); 31 | 32 | app.get('/broadcast-and-store', function(req, res) { 33 | trytes = req.query.trytes.split(","); 34 | iota.api.broadcastAndStore(trytes, function(error, response) { 35 | if (error) { 36 | console.error(error); 37 | throwInvalidRequest(res); 38 | } else { 39 | res.send(response); 40 | } 41 | }); 42 | }); 43 | 44 | app.get('/send-trytes', function(req, res) { 45 | try { 46 | trytes = req.query.trytes.split(","); 47 | depth = parseInt(req.query.depth); 48 | minWeightMagnitude = parseInt(req.query.minWeightMagnitude); 49 | } catch (error) { 50 | console.error(error); 51 | throwInvalidRequest(res); 52 | } 53 | iota.api.sendTrytes(trytes, depth, minWeightMagnitude, function(error, response) { 54 | if (error) { 55 | console.error(error); 56 | throwInvalidRequest(res); 57 | } else { 58 | res.send(response); 59 | } 60 | }); 61 | }); 62 | 63 | app.get('/transaction-object', function(req, res) { 64 | transactions = req.query.transactions.split(","); 65 | iota.api.getTransactionsObjects(transactions, function(error, response) { 66 | if (error) { 67 | console.error(error); 68 | throwInvalidRequest(res); 69 | } else { 70 | res.send(response); 71 | } 72 | }); 73 | }); 74 | 75 | app.get('/transaction-object-query', function(req, res) { 76 | var searchValues = {}; 77 | searchValues.bundles = (req.query.bundles != undefined) ? req.query.bundles.split(",") : []; 78 | searchValues.addresses = (req.query.addresses != undefined) ? req.query.addresses.split(",") : []; 79 | searchValues.tags = (req.query.tags != undefined) ? req.query.tags.split(",") : []; 80 | searchValues.approvees = (req.query.approvees != undefined) ? req.query.approvees.split(",") : []; 81 | 82 | iota.api.findTransactionObjects(searchValues, function(error, response) { 83 | if (error) { 84 | console.error(error); 85 | throwInvalidRequest(res); 86 | } else { 87 | res.send(response); 88 | } 89 | }); 90 | }); 91 | 92 | app.get('/info', function(req, res) { 93 | iota.api.getNodeInfo(function(error, response) { 94 | if (error) { 95 | console.error(error); 96 | throwError(res, 500, "Request to IOTA node failed!"); 97 | } else { 98 | res.send(response); 99 | } 100 | }); 101 | }); 102 | 103 | app.get('/', function (req, res) { 104 | res.send(""); 105 | }); -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # IOTA CL Adaptor 2 | This adaptor is a base IOTA adaptor for Chainlink using the [iota.lib.js](https://github.com/iotaledger/iota.lib.js) library and [ExpressJS](https://expressjs.com/). 3 | 4 | ## Dependencies 5 | To be able to run this external adaptor, you need [Docker](docker.com) installed. 6 | 7 | ## Run the Adaptor 8 | This adaptor is published on the public docker hub, so you just need to run the two following commands: 9 | ```bash 10 | docker pull linkpoolio/iota-cl-ea 11 | docker run -t -p 8081:8081 -e HOST= -e PORT= linkpoolio/iota-cl-ea 12 | ``` 13 | To find a IOTA node, use the public directory found [here](https://iotanode.host/) 14 | 15 | ## Verify Adaptor 16 | To ensure that the adaptor is working properly, the following call: 17 | 18 | > http://localhost:8081/info 19 | 20 | Should result in something similar to the following: 21 | ```json 22 | { 23 | "appName": "IRI", 24 | "appVersion": "1.4.2.1", 25 | "jreAvailableProcessors": 8, 26 | "jreFreeMemory": 108582056, 27 | "jreVersion": "1.8.0_161", 28 | "jreMaxMemory": 7635730432, 29 | "jreTotalMemory": 1186463744, 30 | "latestMilestone": "AINWVKSNTXZTMCXGEZIVOYOWUKHUIWOSCFOFAVUXBLULAAGOYOBSFHRPNLGLUYXJN9PLKNCX9KEWZ9999", 31 | "latestMilestoneIndex": 340297, 32 | "latestSolidSubtangleMilestone": "AINWVKSNTXZTMCXGEZIVOYOWUKHUIWOSCFOFAVUXBLULAAGOYOBSFHRPNLGLUYXJN9PLKNCX9KEWZ9999", 33 | "latestSolidSubtangleMilestoneIndex": 340297, 34 | "neighbors": 40, 35 | "packetsQueueSize": 0, 36 | "time": 1517440111272, 37 | "tips": 9796, 38 | "transactionsToRequest": 7, 39 | "duration": 0 40 | } 41 | ``` 42 | 43 | ## API Specification 44 | Currently, the API supports the following IOTA API queries: 45 | * broadcastAndStore 46 | * findTransactionObjects 47 | * getTransactionsObjects 48 | * getAccountData 49 | * getNodeInfo 50 | * sendTrytes 51 | 52 | ### /transaction-object-query 53 | **IOTA API Function:** findTransactionObjects 54 | 55 | Perform a transaction search based on the query parameters below. 56 | 57 | **GET Params:** 58 | 59 | Param | Description 60 | --- | --- 61 | bundles | Comma seperated list of bundle hashes 62 | addresses | Comma seperated list of addresses 63 | tags | Comma serperated list of transaction tags (27 trytes length) 64 | approvees | Comma seperated list of approvees 65 | 66 | ### /transaction-object 67 | **IOTA API Function:** findTransactionObjects 68 | 69 | Get transaction objects based on the transaction hashes. 70 | 71 | **GET Params:** 72 | 73 | Param | Description 74 | --- | --- 75 | transcations | Comma seperated list of transaction hashes 76 | 77 | ### /account-data 78 | **IOTA API Function:** getAccountData 79 | 80 | Get account data by given account seed. 81 | 82 | **GET Params:** 83 | 84 | Param | Description 85 | --- | --- 86 | seed | Account seed, non-tryte 87 | 88 | ### /broadcast-and-store 89 | **IOTA API Function:** broadcastAndStore 90 | 91 | Broadcast and store trytes. 92 | 93 | **GET Params:** 94 | 95 | Param | Description 96 | --- | --- 97 | trytes | Comma seperated list of trytes. 98 | 99 | ### /send-trytes 100 | **IOTA API Function:** sendTrytes 101 | 102 | Attach to trianges, then broadcast and store. 103 | 104 | **GET Params:** 105 | 106 | Param | Description 107 | --- | --- 108 | trytes | Comma seperated list of trytes. 109 | depth | `int` 110 | minWeightMagnitude | `int` 111 | 112 | ### /info 113 | **IOTA API Function:** getNodeInfo 114 | 115 | Get the current nodes information. 116 | 117 | ## Development 118 | To run the external adaptor, clone the repo and run the following commands: 119 | ```bash 120 | npm install 121 | node index.js 122 | ``` 123 | You should then see the following: 124 | 125 | > IOTA External Adaptor Listening on: ::8081 126 | 127 | To run the unit tests, run the following: 128 | ```bash 129 | npm install -g 130 | npm test 131 | ``` 132 | 133 | Which should give the following output: 134 | ``` 135 | IOTA External Adaptor 136 | ✓ responds to / 137 | ✓ responds to /account-data (2558ms) 138 | ✓ responds to /info (98ms) 139 | ✓ responds to /transaction-object (147ms) 140 | ✓ responds to /transaction-object-query (191ms) 141 | ✓ 404 everything else 142 | ``` 143 | 144 | 145 | ## Contributions 146 | If anyone has any recommendation on what IOTA API calls to support, or wants to contribute and add more themselves, please do! 147 | 148 | Created by the [LinkPool](http://linkpool.io) Team -------------------------------------------------------------------------------- /adaptor/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "iota-clea", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "accepts": { 8 | "version": "1.3.4", 9 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.4.tgz", 10 | "integrity": "sha1-hiRnWMfdbSGmR0/whKR0DsBesh8=", 11 | "requires": { 12 | "mime-types": "2.1.17", 13 | "negotiator": "0.6.1" 14 | } 15 | }, 16 | "append-field": { 17 | "version": "0.1.0", 18 | "resolved": "https://registry.npmjs.org/append-field/-/append-field-0.1.0.tgz", 19 | "integrity": "sha1-bdxY+gg8e8VF08WZWygwzCNm1Eo=" 20 | }, 21 | "array-flatten": { 22 | "version": "1.1.1", 23 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 24 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 25 | }, 26 | "assertion-error": { 27 | "version": "1.1.0", 28 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 29 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 30 | "dev": true 31 | }, 32 | "async": { 33 | "version": "2.6.0", 34 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.0.tgz", 35 | "integrity": "sha512-xAfGg1/NTLBBKlHFmnd7PlmUW9KhVQIUuSrYem9xzFUZy13ScvtyGGejaae9iAVRiRq9+Cx7DPFaAAhCpyxyPw==", 36 | "requires": { 37 | "lodash": "4.17.4" 38 | } 39 | }, 40 | "asynckit": { 41 | "version": "0.4.0", 42 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 43 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 44 | "dev": true 45 | }, 46 | "bignumber.js": { 47 | "version": "4.1.0", 48 | "resolved": "https://registry.npmjs.org/bignumber.js/-/bignumber.js-4.1.0.tgz", 49 | "integrity": "sha512-eJzYkFYy9L4JzXsbymsFn3p54D+llV27oTQ+ziJG7WFRheJcNZilgVXMG0LoZtlQSKBsJdWtLFqOD0u+U0jZKA==" 50 | }, 51 | "body-parser": { 52 | "version": "1.18.2", 53 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.2.tgz", 54 | "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=", 55 | "requires": { 56 | "bytes": "3.0.0", 57 | "content-type": "1.0.4", 58 | "debug": "2.6.9", 59 | "depd": "1.1.2", 60 | "http-errors": "1.6.2", 61 | "iconv-lite": "0.4.19", 62 | "on-finished": "2.3.0", 63 | "qs": "6.5.1", 64 | "raw-body": "2.3.2", 65 | "type-is": "1.6.15" 66 | } 67 | }, 68 | "busboy": { 69 | "version": "0.2.14", 70 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-0.2.14.tgz", 71 | "integrity": "sha1-bCpiLvz0fFe7vh4qnDetNseSVFM=", 72 | "requires": { 73 | "dicer": "0.2.5", 74 | "readable-stream": "1.1.14" 75 | } 76 | }, 77 | "bytes": { 78 | "version": "3.0.0", 79 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 80 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 81 | }, 82 | "chai": { 83 | "version": "4.1.2", 84 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.1.2.tgz", 85 | "integrity": "sha1-D2RYS6ZC8PKs4oBiefTwbKI61zw=", 86 | "dev": true, 87 | "requires": { 88 | "assertion-error": "1.1.0", 89 | "check-error": "1.0.2", 90 | "deep-eql": "3.0.1", 91 | "get-func-name": "2.0.0", 92 | "pathval": "1.1.0", 93 | "type-detect": "4.0.8" 94 | } 95 | }, 96 | "check-error": { 97 | "version": "1.0.2", 98 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 99 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 100 | "dev": true 101 | }, 102 | "combined-stream": { 103 | "version": "1.0.5", 104 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 105 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 106 | "dev": true, 107 | "requires": { 108 | "delayed-stream": "1.0.0" 109 | } 110 | }, 111 | "component-emitter": { 112 | "version": "1.2.1", 113 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 114 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", 115 | "dev": true 116 | }, 117 | "concat-stream": { 118 | "version": "1.6.0", 119 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.0.tgz", 120 | "integrity": "sha1-CqxmL9Ur54lk1VMvaUeE5wEQrPc=", 121 | "requires": { 122 | "inherits": "2.0.3", 123 | "readable-stream": "2.3.3", 124 | "typedarray": "0.0.6" 125 | }, 126 | "dependencies": { 127 | "isarray": { 128 | "version": "1.0.0", 129 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 130 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 131 | }, 132 | "readable-stream": { 133 | "version": "2.3.3", 134 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 135 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 136 | "requires": { 137 | "core-util-is": "1.0.2", 138 | "inherits": "2.0.3", 139 | "isarray": "1.0.0", 140 | "process-nextick-args": "1.0.7", 141 | "safe-buffer": "5.1.1", 142 | "string_decoder": "1.0.3", 143 | "util-deprecate": "1.0.2" 144 | } 145 | }, 146 | "string_decoder": { 147 | "version": "1.0.3", 148 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 149 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 150 | "requires": { 151 | "safe-buffer": "5.1.1" 152 | } 153 | } 154 | } 155 | }, 156 | "content-disposition": { 157 | "version": "0.5.2", 158 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 159 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 160 | }, 161 | "content-type": { 162 | "version": "1.0.4", 163 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 164 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 165 | }, 166 | "cookie": { 167 | "version": "0.3.1", 168 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 169 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 170 | }, 171 | "cookie-parser": { 172 | "version": "1.4.3", 173 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.3.tgz", 174 | "integrity": "sha1-D+MfoZ0AC5X0qt8fU/3CuKIDuqU=", 175 | "requires": { 176 | "cookie": "0.3.1", 177 | "cookie-signature": "1.0.6" 178 | } 179 | }, 180 | "cookie-signature": { 181 | "version": "1.0.6", 182 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 183 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 184 | }, 185 | "cookiejar": { 186 | "version": "2.1.1", 187 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.1.tgz", 188 | "integrity": "sha1-Qa1XsbVVlR7BcUEqgZQrHoIA00o=", 189 | "dev": true 190 | }, 191 | "core-util-is": { 192 | "version": "1.0.2", 193 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 194 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 195 | }, 196 | "crypto-js": { 197 | "version": "3.1.9-1", 198 | "resolved": "https://registry.npmjs.org/crypto-js/-/crypto-js-3.1.9-1.tgz", 199 | "integrity": "sha1-/aGedh/Ad+Af+/3G6f38WeiAbNg=" 200 | }, 201 | "debug": { 202 | "version": "2.6.9", 203 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 204 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 205 | "requires": { 206 | "ms": "2.0.0" 207 | } 208 | }, 209 | "deep-eql": { 210 | "version": "3.0.1", 211 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 212 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 213 | "dev": true, 214 | "requires": { 215 | "type-detect": "4.0.8" 216 | } 217 | }, 218 | "delayed-stream": { 219 | "version": "1.0.0", 220 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 221 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 222 | "dev": true 223 | }, 224 | "depd": { 225 | "version": "1.1.2", 226 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 227 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 228 | }, 229 | "destroy": { 230 | "version": "1.0.4", 231 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 232 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 233 | }, 234 | "dicer": { 235 | "version": "0.2.5", 236 | "resolved": "https://registry.npmjs.org/dicer/-/dicer-0.2.5.tgz", 237 | "integrity": "sha1-WZbAhrszIYyBLAkL3cCc0S+stw8=", 238 | "requires": { 239 | "readable-stream": "1.1.14", 240 | "streamsearch": "0.1.2" 241 | } 242 | }, 243 | "ee-first": { 244 | "version": "1.1.1", 245 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 246 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 247 | }, 248 | "encodeurl": { 249 | "version": "1.0.2", 250 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 251 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 252 | }, 253 | "escape-html": { 254 | "version": "1.0.3", 255 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 256 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 257 | }, 258 | "etag": { 259 | "version": "1.8.1", 260 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 261 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 262 | }, 263 | "express": { 264 | "version": "4.16.2", 265 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.2.tgz", 266 | "integrity": "sha1-41xt/i1kt9ygpc1PIXgb4ymeB2w=", 267 | "requires": { 268 | "accepts": "1.3.4", 269 | "array-flatten": "1.1.1", 270 | "body-parser": "1.18.2", 271 | "content-disposition": "0.5.2", 272 | "content-type": "1.0.4", 273 | "cookie": "0.3.1", 274 | "cookie-signature": "1.0.6", 275 | "debug": "2.6.9", 276 | "depd": "1.1.2", 277 | "encodeurl": "1.0.2", 278 | "escape-html": "1.0.3", 279 | "etag": "1.8.1", 280 | "finalhandler": "1.1.0", 281 | "fresh": "0.5.2", 282 | "merge-descriptors": "1.0.1", 283 | "methods": "1.1.2", 284 | "on-finished": "2.3.0", 285 | "parseurl": "1.3.2", 286 | "path-to-regexp": "0.1.7", 287 | "proxy-addr": "2.0.2", 288 | "qs": "6.5.1", 289 | "range-parser": "1.2.0", 290 | "safe-buffer": "5.1.1", 291 | "send": "0.16.1", 292 | "serve-static": "1.13.1", 293 | "setprototypeof": "1.1.0", 294 | "statuses": "1.3.1", 295 | "type-is": "1.6.15", 296 | "utils-merge": "1.0.1", 297 | "vary": "1.1.2" 298 | } 299 | }, 300 | "extend": { 301 | "version": "3.0.1", 302 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 303 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=", 304 | "dev": true 305 | }, 306 | "finalhandler": { 307 | "version": "1.1.0", 308 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.0.tgz", 309 | "integrity": "sha1-zgtoVbRYU+eRsvzGgARtiCU91/U=", 310 | "requires": { 311 | "debug": "2.6.9", 312 | "encodeurl": "1.0.2", 313 | "escape-html": "1.0.3", 314 | "on-finished": "2.3.0", 315 | "parseurl": "1.3.2", 316 | "statuses": "1.3.1", 317 | "unpipe": "1.0.0" 318 | } 319 | }, 320 | "form-data": { 321 | "version": "2.3.1", 322 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", 323 | "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", 324 | "dev": true, 325 | "requires": { 326 | "asynckit": "0.4.0", 327 | "combined-stream": "1.0.5", 328 | "mime-types": "2.1.17" 329 | } 330 | }, 331 | "formidable": { 332 | "version": "1.1.1", 333 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.1.1.tgz", 334 | "integrity": "sha1-lriIb3w8NQi5Mta9cMTTqI818ak=", 335 | "dev": true 336 | }, 337 | "forwarded": { 338 | "version": "0.1.2", 339 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 340 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 341 | }, 342 | "fresh": { 343 | "version": "0.5.2", 344 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 345 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 346 | }, 347 | "get-func-name": { 348 | "version": "2.0.0", 349 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 350 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 351 | "dev": true 352 | }, 353 | "http-errors": { 354 | "version": "1.6.2", 355 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz", 356 | "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=", 357 | "requires": { 358 | "depd": "1.1.1", 359 | "inherits": "2.0.3", 360 | "setprototypeof": "1.0.3", 361 | "statuses": "1.3.1" 362 | }, 363 | "dependencies": { 364 | "depd": { 365 | "version": "1.1.1", 366 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz", 367 | "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=" 368 | }, 369 | "setprototypeof": { 370 | "version": "1.0.3", 371 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", 372 | "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=" 373 | } 374 | } 375 | }, 376 | "iconv-lite": { 377 | "version": "0.4.19", 378 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 379 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==" 380 | }, 381 | "inherits": { 382 | "version": "2.0.3", 383 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 384 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 385 | }, 386 | "iota.lib.js": { 387 | "version": "0.4.7", 388 | "resolved": "https://registry.npmjs.org/iota.lib.js/-/iota.lib.js-0.4.7.tgz", 389 | "integrity": "sha1-wq8aeIa4sOI5pLVLXKqd0jnC1+s=", 390 | "requires": { 391 | "async": "2.6.0", 392 | "bignumber.js": "4.1.0", 393 | "crypto-js": "3.1.9-1", 394 | "xmlhttprequest": "1.8.0" 395 | } 396 | }, 397 | "ipaddr.js": { 398 | "version": "1.5.2", 399 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.5.2.tgz", 400 | "integrity": "sha1-1LUFvemUaYfM8PxY2QEP+WB+P6A=" 401 | }, 402 | "isarray": { 403 | "version": "0.0.1", 404 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 405 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 406 | }, 407 | "lodash": { 408 | "version": "4.17.4", 409 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 410 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" 411 | }, 412 | "media-typer": { 413 | "version": "0.3.0", 414 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 415 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 416 | }, 417 | "merge-descriptors": { 418 | "version": "1.0.1", 419 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 420 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 421 | }, 422 | "methods": { 423 | "version": "1.1.2", 424 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 425 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 426 | }, 427 | "mime": { 428 | "version": "1.4.1", 429 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 430 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" 431 | }, 432 | "mime-db": { 433 | "version": "1.30.0", 434 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", 435 | "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=" 436 | }, 437 | "mime-types": { 438 | "version": "2.1.17", 439 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", 440 | "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", 441 | "requires": { 442 | "mime-db": "1.30.0" 443 | } 444 | }, 445 | "minimist": { 446 | "version": "0.0.8", 447 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 448 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 449 | }, 450 | "mkdirp": { 451 | "version": "0.5.1", 452 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 453 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 454 | "requires": { 455 | "minimist": "0.0.8" 456 | } 457 | }, 458 | "ms": { 459 | "version": "2.0.0", 460 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 461 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 462 | }, 463 | "multer": { 464 | "version": "1.3.0", 465 | "resolved": "https://registry.npmjs.org/multer/-/multer-1.3.0.tgz", 466 | "integrity": "sha1-CSsmcPaEb6SRSWXvyM+Uwg/sbNI=", 467 | "requires": { 468 | "append-field": "0.1.0", 469 | "busboy": "0.2.14", 470 | "concat-stream": "1.6.0", 471 | "mkdirp": "0.5.1", 472 | "object-assign": "3.0.0", 473 | "on-finished": "2.3.0", 474 | "type-is": "1.6.15", 475 | "xtend": "4.0.1" 476 | } 477 | }, 478 | "negotiator": { 479 | "version": "0.6.1", 480 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 481 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 482 | }, 483 | "object-assign": { 484 | "version": "3.0.0", 485 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-3.0.0.tgz", 486 | "integrity": "sha1-m+3VygiXlJvKR+f/QIBi1Un1h/I=" 487 | }, 488 | "on-finished": { 489 | "version": "2.3.0", 490 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 491 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 492 | "requires": { 493 | "ee-first": "1.1.1" 494 | } 495 | }, 496 | "parseurl": { 497 | "version": "1.3.2", 498 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 499 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 500 | }, 501 | "path-to-regexp": { 502 | "version": "0.1.7", 503 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 504 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 505 | }, 506 | "pathval": { 507 | "version": "1.1.0", 508 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz", 509 | "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=", 510 | "dev": true 511 | }, 512 | "process-nextick-args": { 513 | "version": "1.0.7", 514 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 515 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" 516 | }, 517 | "proxy-addr": { 518 | "version": "2.0.2", 519 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.2.tgz", 520 | "integrity": "sha1-ZXFQT0e7mI7IGAJT+F3X4UlSvew=", 521 | "requires": { 522 | "forwarded": "0.1.2", 523 | "ipaddr.js": "1.5.2" 524 | } 525 | }, 526 | "qs": { 527 | "version": "6.5.1", 528 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 529 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==" 530 | }, 531 | "range-parser": { 532 | "version": "1.2.0", 533 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 534 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 535 | }, 536 | "raw-body": { 537 | "version": "2.3.2", 538 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.2.tgz", 539 | "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=", 540 | "requires": { 541 | "bytes": "3.0.0", 542 | "http-errors": "1.6.2", 543 | "iconv-lite": "0.4.19", 544 | "unpipe": "1.0.0" 545 | } 546 | }, 547 | "readable-stream": { 548 | "version": "1.1.14", 549 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz", 550 | "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=", 551 | "requires": { 552 | "core-util-is": "1.0.2", 553 | "inherits": "2.0.3", 554 | "isarray": "0.0.1", 555 | "string_decoder": "0.10.31" 556 | } 557 | }, 558 | "safe-buffer": { 559 | "version": "5.1.1", 560 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 561 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" 562 | }, 563 | "send": { 564 | "version": "0.16.1", 565 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.1.tgz", 566 | "integrity": "sha512-ElCLJdJIKPk6ux/Hocwhk7NFHpI3pVm/IZOYWqUmoxcgeyM+MpxHHKhb8QmlJDX1pU6WrgaHBkVNm73Sv7uc2A==", 567 | "requires": { 568 | "debug": "2.6.9", 569 | "depd": "1.1.2", 570 | "destroy": "1.0.4", 571 | "encodeurl": "1.0.2", 572 | "escape-html": "1.0.3", 573 | "etag": "1.8.1", 574 | "fresh": "0.5.2", 575 | "http-errors": "1.6.2", 576 | "mime": "1.4.1", 577 | "ms": "2.0.0", 578 | "on-finished": "2.3.0", 579 | "range-parser": "1.2.0", 580 | "statuses": "1.3.1" 581 | } 582 | }, 583 | "serve-static": { 584 | "version": "1.13.1", 585 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.1.tgz", 586 | "integrity": "sha512-hSMUZrsPa/I09VYFJwa627JJkNs0NrfL1Uzuup+GqHfToR2KcsXFymXSV90hoyw3M+msjFuQly+YzIH/q0MGlQ==", 587 | "requires": { 588 | "encodeurl": "1.0.2", 589 | "escape-html": "1.0.3", 590 | "parseurl": "1.3.2", 591 | "send": "0.16.1" 592 | } 593 | }, 594 | "setprototypeof": { 595 | "version": "1.1.0", 596 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 597 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 598 | }, 599 | "statuses": { 600 | "version": "1.3.1", 601 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", 602 | "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=" 603 | }, 604 | "streamsearch": { 605 | "version": "0.1.2", 606 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-0.1.2.tgz", 607 | "integrity": "sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo=" 608 | }, 609 | "string_decoder": { 610 | "version": "0.10.31", 611 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", 612 | "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=" 613 | }, 614 | "superagent": { 615 | "version": "3.8.2", 616 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-3.8.2.tgz", 617 | "integrity": "sha512-gVH4QfYHcY3P0f/BZzavLreHW3T1v7hG9B+hpMQotGQqurOvhv87GcMCd6LWySmBuf+BDR44TQd0aISjVHLeNQ==", 618 | "dev": true, 619 | "requires": { 620 | "component-emitter": "1.2.1", 621 | "cookiejar": "2.1.1", 622 | "debug": "3.1.0", 623 | "extend": "3.0.1", 624 | "form-data": "2.3.1", 625 | "formidable": "1.1.1", 626 | "methods": "1.1.2", 627 | "mime": "1.4.1", 628 | "qs": "6.5.1", 629 | "readable-stream": "2.3.3" 630 | }, 631 | "dependencies": { 632 | "debug": { 633 | "version": "3.1.0", 634 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 635 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 636 | "dev": true, 637 | "requires": { 638 | "ms": "2.0.0" 639 | } 640 | }, 641 | "isarray": { 642 | "version": "1.0.0", 643 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 644 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 645 | "dev": true 646 | }, 647 | "readable-stream": { 648 | "version": "2.3.3", 649 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 650 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 651 | "dev": true, 652 | "requires": { 653 | "core-util-is": "1.0.2", 654 | "inherits": "2.0.3", 655 | "isarray": "1.0.0", 656 | "process-nextick-args": "1.0.7", 657 | "safe-buffer": "5.1.1", 658 | "string_decoder": "1.0.3", 659 | "util-deprecate": "1.0.2" 660 | } 661 | }, 662 | "string_decoder": { 663 | "version": "1.0.3", 664 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 665 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 666 | "dev": true, 667 | "requires": { 668 | "safe-buffer": "5.1.1" 669 | } 670 | } 671 | } 672 | }, 673 | "supertest": { 674 | "version": "3.0.0", 675 | "resolved": "https://registry.npmjs.org/supertest/-/supertest-3.0.0.tgz", 676 | "integrity": "sha1-jUu2j9GDDuBwM7HFpamkAhyWUpY=", 677 | "dev": true, 678 | "requires": { 679 | "methods": "1.1.2", 680 | "superagent": "3.8.2" 681 | } 682 | }, 683 | "type-detect": { 684 | "version": "4.0.8", 685 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 686 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 687 | "dev": true 688 | }, 689 | "type-is": { 690 | "version": "1.6.15", 691 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz", 692 | "integrity": "sha1-yrEPtJCeRByChC6v4a1kbIGARBA=", 693 | "requires": { 694 | "media-typer": "0.3.0", 695 | "mime-types": "2.1.17" 696 | } 697 | }, 698 | "typedarray": { 699 | "version": "0.0.6", 700 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 701 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" 702 | }, 703 | "unpipe": { 704 | "version": "1.0.0", 705 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 706 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 707 | }, 708 | "util-deprecate": { 709 | "version": "1.0.2", 710 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 711 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 712 | }, 713 | "utils-merge": { 714 | "version": "1.0.1", 715 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 716 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 717 | }, 718 | "vary": { 719 | "version": "1.1.2", 720 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 721 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 722 | }, 723 | "xmlhttprequest": { 724 | "version": "1.8.0", 725 | "resolved": "https://registry.npmjs.org/xmlhttprequest/-/xmlhttprequest-1.8.0.tgz", 726 | "integrity": "sha1-Z/4HXFwk/vOfnWX197f+dRcZaPw=" 727 | }, 728 | "xtend": { 729 | "version": "4.0.1", 730 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 731 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=" 732 | } 733 | } 734 | } 735 | --------------------------------------------------------------------------------