├── .vscode └── launch.json ├── README.md ├── art-meetup ├── .eslintrc.js ├── .gitignore ├── _imagecache │ ├── 099a75a9d79ba8dc645ffa33f7a45833 │ ├── 1844161a7fc922bcb551182d560256c9 │ ├── 42c7b12103e6dd94f10322f604589c74 │ ├── 5d5c49a54036120dd007dc3b6ef43c28 │ ├── 624b8bf0f7f30b5715f87bd2b7ae9749 │ ├── 6abfaaa9768e2abd2c1e9289ee7e397e │ ├── 6c2e1e9b4ecce18320bb069cc4bcb1d0 │ ├── 6db7e37dc91ae5487a6d8ec3dfa8b330 │ ├── 908d2e812b327691ce9d579d6b8175a5 │ ├── 9bf895266627af3017f06dd983fca6e9 │ ├── b2ca06cb7da5ab070507bff3e7fd447e │ ├── b55eddef6572e0c12ac6141e0cc923d1 │ ├── b79e82e2213c4abfa31dc47c54ec0c66 │ ├── c865da5b9bfe1d0c58f84ca8ecc60faf │ ├── c9fb7dbd7aef275e759acad764527ff4 │ ├── ec13275f52e162a8659a6ae25faeedaf │ └── f9b4783d6f30dfc87db34ca74230eb70 ├── package-lock.json ├── package.json ├── public │ ├── css │ │ ├── error.css │ │ └── style.css │ ├── images │ │ └── misc │ │ │ └── background.jpg │ └── js │ │ └── pixgrid.js └── server │ ├── config │ └── index.js │ ├── index.js │ ├── lib │ └── CircuitBreaker.js │ ├── routes │ ├── feedback │ │ └── index.js │ ├── index.js │ └── speakers │ │ └── index.js │ ├── services │ ├── Feedback-old.js │ ├── Feedback.js │ └── Speakers.js │ └── views │ ├── error.pug │ ├── feedback │ └── index.pug │ ├── includes │ ├── artwork.pug │ ├── sidebar.pug │ └── speakerslist.pug │ ├── index.pug │ ├── layout │ ├── includes │ │ ├── header.pug │ │ └── scripts.pug │ └── index.pug │ └── speakers │ ├── detail │ └── index.pug │ └── index.pug ├── feedback-service ├── .eslintrc.js ├── .gitignore ├── bin │ └── run ├── config │ └── index.js ├── data │ └── feedback.json ├── package-lock.json ├── package.json └── server │ ├── lib │ └── Feedback.js │ └── service.js ├── service-registry ├── .eslintrc.js ├── .gitignore ├── bin │ └── run ├── config │ └── index.js ├── package-lock.json ├── package.json └── server │ ├── lib │ └── ServiceRegistry.js │ └── service.js └── speakers-service ├── .eslintrc.js ├── .gitignore ├── bin └── run ├── config └── index.js ├── data ├── images │ ├── artwork │ │ ├── santa_clause_01.jpg │ │ ├── santa_clause_01_tn.jpg │ │ ├── santa_clause_02.jpg │ │ ├── santa_clause_02_tn.jpg │ │ ├── santa_clause_03.jpg │ │ ├── santa_clause_03_tn.jpg │ │ ├── santa_clause_04.jpg │ │ ├── santa_clause_04_tn.jpg │ │ ├── wdj_01.jpg │ │ ├── wdj_01_tn.jpg │ │ ├── wdj_02.jpg │ │ ├── wdj_02_tn.jpg │ │ ├── wdj_03.jpg │ │ ├── wdj_03_tn.jpg │ │ ├── wdj_04.jpg │ │ ├── wdj_04_tn.jpg │ │ ├── wdj_05.jpg │ │ ├── wdj_05_tn.jpg │ │ ├── wdj_06.jpg │ │ ├── wdj_06_tn.jpg │ │ ├── wdj_07.jpg │ │ ├── wdj_07_tn.jpg │ │ ├── wonka_01.jpg │ │ ├── wonka_01_tn.jpg │ │ ├── wonka_02.jpg │ │ ├── wonka_02_tn.jpg │ │ ├── wonka_03.jpg │ │ ├── wonka_03_tn.jpg │ │ ├── wonka_04.jpg │ │ ├── wonka_04_tn.jpg │ │ ├── wonka_05.jpg │ │ ├── wonka_05_tn.jpg │ │ ├── wonka_06.jpg │ │ └── wonka_06_tn.jpg │ └── speakers │ │ ├── santa_clause.jpg │ │ ├── santa_clause_tn.jpg │ │ ├── wdj.jpg │ │ ├── wdj_tn.jpg │ │ ├── wonka.jpg │ │ └── wonka_tn.jpg └── speakers.json ├── package-lock.json ├── package.json └── server ├── lib └── Speakers.js └── service.js /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | { 2 | // Use IntelliSense to learn about possible attributes. 3 | // Hover to view descriptions of existing attributes. 4 | // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 5 | "version": "0.2.0", 6 | "configurations": [ 7 | { 8 | "type": "node", 9 | "request": "launch", 10 | "name": "Launch Chrome against localhost", 11 | "program": "${workspaceFolder}/bin/run" 12 | } 13 | ] 14 | } -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # NodeJS_Microservices 2 | -------------------------------------------------------------------------------- /art-meetup/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | es6: true, 5 | }, 6 | extends: 'airbnb-base', 7 | globals: { 8 | Atomics: 'readonly', 9 | SharedArrayBuffer: 'readonly', 10 | }, 11 | parserOptions: { 12 | ecmaVersion: 2018, 13 | sourceType: 'module', 14 | }, 15 | rules: { 16 | "linebreak-style": 0 17 | }, 18 | }; 19 | -------------------------------------------------------------------------------- /art-meetup/.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .env -------------------------------------------------------------------------------- /art-meetup/_imagecache/099a75a9d79ba8dc645ffa33f7a45833: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/099a75a9d79ba8dc645ffa33f7a45833 -------------------------------------------------------------------------------- /art-meetup/_imagecache/1844161a7fc922bcb551182d560256c9: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/1844161a7fc922bcb551182d560256c9 -------------------------------------------------------------------------------- /art-meetup/_imagecache/42c7b12103e6dd94f10322f604589c74: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/42c7b12103e6dd94f10322f604589c74 -------------------------------------------------------------------------------- /art-meetup/_imagecache/5d5c49a54036120dd007dc3b6ef43c28: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/5d5c49a54036120dd007dc3b6ef43c28 -------------------------------------------------------------------------------- /art-meetup/_imagecache/624b8bf0f7f30b5715f87bd2b7ae9749: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/624b8bf0f7f30b5715f87bd2b7ae9749 -------------------------------------------------------------------------------- /art-meetup/_imagecache/6abfaaa9768e2abd2c1e9289ee7e397e: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/6abfaaa9768e2abd2c1e9289ee7e397e -------------------------------------------------------------------------------- /art-meetup/_imagecache/6c2e1e9b4ecce18320bb069cc4bcb1d0: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/6c2e1e9b4ecce18320bb069cc4bcb1d0 -------------------------------------------------------------------------------- /art-meetup/_imagecache/6db7e37dc91ae5487a6d8ec3dfa8b330: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/6db7e37dc91ae5487a6d8ec3dfa8b330 -------------------------------------------------------------------------------- /art-meetup/_imagecache/908d2e812b327691ce9d579d6b8175a5: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/908d2e812b327691ce9d579d6b8175a5 -------------------------------------------------------------------------------- /art-meetup/_imagecache/9bf895266627af3017f06dd983fca6e9: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/9bf895266627af3017f06dd983fca6e9 -------------------------------------------------------------------------------- /art-meetup/_imagecache/b2ca06cb7da5ab070507bff3e7fd447e: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/b2ca06cb7da5ab070507bff3e7fd447e -------------------------------------------------------------------------------- /art-meetup/_imagecache/b55eddef6572e0c12ac6141e0cc923d1: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/b55eddef6572e0c12ac6141e0cc923d1 -------------------------------------------------------------------------------- /art-meetup/_imagecache/b79e82e2213c4abfa31dc47c54ec0c66: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/b79e82e2213c4abfa31dc47c54ec0c66 -------------------------------------------------------------------------------- /art-meetup/_imagecache/c865da5b9bfe1d0c58f84ca8ecc60faf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/c865da5b9bfe1d0c58f84ca8ecc60faf -------------------------------------------------------------------------------- /art-meetup/_imagecache/c9fb7dbd7aef275e759acad764527ff4: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/c9fb7dbd7aef275e759acad764527ff4 -------------------------------------------------------------------------------- /art-meetup/_imagecache/ec13275f52e162a8659a6ae25faeedaf: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/ec13275f52e162a8659a6ae25faeedaf -------------------------------------------------------------------------------- /art-meetup/_imagecache/f9b4783d6f30dfc87db34ca74230eb70: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/_imagecache/f9b4783d6f30dfc87db34ca74230eb70 -------------------------------------------------------------------------------- /art-meetup/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "art-meetup", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1", 8 | "start": "nodemon server" 9 | }, 10 | "keywords": [], 11 | "author": "", 12 | "license": "ISC", 13 | "dependencies": { 14 | "amqplib": "^0.6.0", 15 | "axios": "^0.19.2", 16 | "body-parser": "^1.18.3", 17 | "express": "^4.16.3", 18 | "http-errors": "^1.7.0", 19 | "nodemon": "^2.0.4", 20 | "pug": "^2.0.3" 21 | }, 22 | "devDependencies": { 23 | "eslint": "^5.15.2", 24 | "eslint-config-airbnb-base": "^13.1.0", 25 | "eslint-plugin-import": "^2.16.0" 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /art-meetup/public/css/error.css: -------------------------------------------------------------------------------- 1 | #main { 2 | height: 100vh; 3 | } -------------------------------------------------------------------------------- /art-meetup/public/css/style.css: -------------------------------------------------------------------------------- 1 | @import url(http://fonts.googleapis.com/css?family=Roboto:100, 300); 2 | 3 | body { 4 | margin: 0; 5 | padding: 0; 6 | font-size: 16px; 7 | } 8 | 9 | h1, h2, h3, h4, h5, h6 { 10 | font-family: 'Roboto', sans-serif; 11 | font-weight: 300; 12 | color: #C1343F; 13 | } 14 | 15 | p { 16 | font-family: inherit; 17 | font-weight: 100; 18 | } 19 | 20 | 21 | li { 22 | font-family: inherit; 23 | font-weight: 100; 24 | } 25 | 26 | 27 | a { 28 | color: #DD4F53; 29 | } 30 | 31 | /** Header Navigation **/ 32 | 33 | header { 34 | font-size: 2rem; 35 | } 36 | 37 | header .jumbotron { 38 | height: 40vh; 39 | margin-bottom: 0; 40 | background: url(../images/misc/background.jpg) no-repeat 100% 5%; 41 | -webkit-background-size: cover; 42 | -moz-background-size: cover; 43 | -o-background-size: cover; 44 | background-size: cover; 45 | } 46 | 47 | /** Navbar **/ 48 | 49 | header .navbar { 50 | background: #CF5565; 51 | margin-bottom: 0; 52 | border-radius: 0; 53 | font-family: "Roboto", sans-serif; 54 | font-weight: 100; 55 | } 56 | 57 | header .navbar-default { 58 | border: none; 59 | border-radius: 0; 60 | padding: 10px 0; 61 | } 62 | 63 | .navbar-inverse { 64 | border: 0; 65 | } 66 | 67 | 68 | header .navbar-brand { 69 | font-family: 'Roboto', sans-serif; 70 | font-size: 1.3em; 71 | font-weight: 300; 72 | } 73 | 74 | header .navbar-inverse .navbar-brand { 75 | color: white; 76 | } 77 | 78 | header .navbar-inverse .navbar-nav>li>a { 79 | color: white; 80 | } 81 | 82 | .maincontent { 83 | font-family: 'Roboto', sans-serif; 84 | font-size: 1.8rem; 85 | line-height: 160%; 86 | } 87 | 88 | .sidebar { 89 | font-family: 'Roboto', sans-serif; 90 | font-size: 1.8rem; 91 | line-height: 130%; 92 | } 93 | 94 | .sidebar .sidebar-title { 95 | font-size: 1.5em; 96 | } 97 | 98 | .sidebar .sidebar-body li { 99 | margin-bottom: 10px; 100 | } 101 | 102 | @media (max-width: 768px) { 103 | .sidebar { 104 | line-height: 160%; 105 | } 106 | .sidebar .sidebar-title { 107 | font-size: 2em; 108 | } 109 | } 110 | 111 | .speakerslist { 112 | font-family: 'Roboto', sans-serif; 113 | font-size: 1.8rem; 114 | line-height: 160%; 115 | } 116 | 117 | #speakerList .speakerslist-img { 118 | margin-right: 20px; 119 | } 120 | 121 | .speakerslist-title { 122 | font-size: 1.7em; 123 | } 124 | 125 | #home .speakerslist-title { 126 | font-size: 1.5em; 127 | } 128 | 129 | #speakerDetail .speakerslist-title { 130 | font-size: 2.4em; 131 | } 132 | 133 | #speakerDetail .speakerslist-img { 134 | margin: 20px 0; 135 | } 136 | 137 | .form-control { 138 | font-weight: 100; 139 | font-size: 1.7rem; 140 | } 141 | 142 | .chat-form { 143 | margin-top: 20px; 144 | font-family: "Roboto", sans-serif; 145 | font-size: 1.5rem; 146 | } 147 | 148 | .jumbotron { 149 | padding: 20px 0; 150 | background-color: #FFEB8B; 151 | } 152 | 153 | /** chat-display **/ 154 | 155 | .chat-display { 156 | min-height: 150px; 157 | max-height: 40vh; 158 | overflow: scroll; 159 | font-size: 1.2em; 160 | } 161 | 162 | .chat-display p { 163 | font-size: .9em; 164 | padding: 0 10px; 165 | } 166 | 167 | .feedback, .feedback-form-title { 168 | font-size: 2rem; 169 | } 170 | 171 | .feedback-form { 172 | margin-top: 20px; 173 | font-family: "Roboto", sans-serif; 174 | font-size: 1.5rem; 175 | } 176 | 177 | 178 | .feedback-title { 179 | font-size: 1.2em; 180 | } 181 | 182 | .feedback-form-title { 183 | font-size: 2em; 184 | } 185 | 186 | .feedback-name { 187 | font-size: .6em; 188 | font-weight: 100; 189 | } 190 | 191 | .feedback-message { 192 | font-weight: 100; 193 | font-size: .9em; 194 | line-height: 120%; 195 | margin-top: 5px; 196 | } 197 | 198 | .feedback-item { 199 | border-bottom: 1px solid gray; 200 | padding: 8px 0; 201 | } 202 | 203 | .feedback-item:last-of-type { 204 | border-bottom: none; 205 | } 206 | 207 | 208 | /** pixgrid **/ 209 | 210 | .pixgrid { 211 | cursor: pointer; 212 | margin-top: 20px; 213 | } 214 | 215 | .pixgrid img { 216 | display: block; 217 | padding: 5px; 218 | float: left; 219 | width: 33.33%; 220 | border-radius: 10px; 221 | } 222 | 223 | @media (min-width: 500px) and (max-width: 768px) { 224 | .pixgrid img { 225 | width: 20%; 226 | } 227 | } 228 | -------------------------------------------------------------------------------- /art-meetup/public/images/misc/background.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/art-meetup/public/images/misc/background.jpg -------------------------------------------------------------------------------- /art-meetup/public/js/pixgrid.js: -------------------------------------------------------------------------------- 1 | var pixGrid = function() { 2 | function centerImage(theImage) { 3 | var myDifX = (window.innerWidth - theImage.width) / 2, myDifY = (window.innerHeight - theImage.height) / 2; 4 | return theImage.style.top = myDifY + "px", theImage.style.left = myDifX + "px", 5 | theImage; 6 | } 7 | var myNode = document.querySelector(".pixgrid"); 8 | myNode.addEventListener("click", function(e) { 9 | if ("IMG" === e.target.tagName) { 10 | var myOverlay = document.createElement("div"); 11 | myOverlay.id = "overlay", document.body.appendChild(myOverlay), myOverlay.style.position = "absolute", 12 | myOverlay.style.top = 0, myOverlay.style.backgroundColor = "rgba(0,0,0,0.7)", myOverlay.style.cursor = "pointer", 13 | myOverlay.style.width = window.innerWidth + "px", myOverlay.style.height = window.innerHeight + "px", 14 | myOverlay.style.top = window.pageYOffset + "px", myOverlay.style.left = window.pageXOffset + "px"; 15 | var imageSrc = e.target.src, largeImage = document.createElement("img"); 16 | largeImage.id = "largeImage", largeImage.src = imageSrc.substr(0, imageSrc.length - 7) + ".jpg", 17 | largeImage.style.display = "block", largeImage.style.position = "absolute", largeImage.addEventListener("load", function() { 18 | this.height > window.innerHeight && (this.ratio = window.innerHeight / this.height, 19 | this.height = this.height * this.ratio, this.width = this.width * this.ratio), this.width > window.innerWidth && (this.ratio = window.innerWidth / this.width, 20 | this.height = this.height * this.ratio, this.width = this.width * this.ratio), centerImage(this), 21 | myOverlay.appendChild(largeImage); 22 | }), largeImage.addEventListener("click", function() { 23 | myOverlay && (window.removeEventListener("resize", window, !1), window.removeEventListener("scroll", window, !1), 24 | myOverlay.parentNode.removeChild(myOverlay)); 25 | }, !1), window.addEventListener("scroll", function() { 26 | myOverlay && (myOverlay.style.top = window.pageYOffset + "px", myOverlay.style.left = window.pageXOffset + "px"); 27 | }, !1), window.addEventListener("resize", function() { 28 | myOverlay && (myOverlay.style.width = window.innerWidth + "px", myOverlay.style.height = window.innerHeight + "px", 29 | myOverlay.style.top = window.pageYOffset + "px", myOverlay.style.left = window.pageXOffset + "px", 30 | centerImage(largeImage)); 31 | }, !1); 32 | } 33 | }, !1); 34 | }(); -------------------------------------------------------------------------------- /art-meetup/server/config/index.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | development: { 3 | sitename: 'Art Meetups [Development]', 4 | serviceRegistryUrl: "http://localhost:3000", 5 | serviceVersion: "1.x.x", 6 | }, 7 | production: { 8 | sitename: 'Art Meetups', 9 | serviceRegistryUrl: "http://localhost:3000", 10 | serviceVersion: "1.x.x", 11 | }, 12 | }; 13 | -------------------------------------------------------------------------------- /art-meetup/server/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const createError = require('http-errors'); 3 | const path = require('path'); 4 | const bodyParser = require('body-parser'); 5 | const configs = require('./config'); 6 | const Speakers = require('./services/Speakers'); 7 | const Feedback = require('./services/Feedback'); 8 | const routes = require('./routes'); 9 | 10 | const app = express(); 11 | 12 | const config = configs[app.get('env')]; 13 | 14 | const speakers = new Speakers(config); 15 | const feedback = new Feedback(config); 16 | 17 | app.set('view engine', 'pug'); 18 | if (app.get('env') === 'development') { 19 | app.locals.pretty = true; 20 | } 21 | app.set('views', path.join(__dirname, './views')); 22 | app.locals.title = config.sitename; 23 | 24 | 25 | app.use(express.static('public')); 26 | 27 | app.use(bodyParser.urlencoded({ extended: true })); 28 | 29 | app.get('/favicon.ico', (req, res) => res.sendStatus(204)); 30 | 31 | app.use(async (req, res, next) => { 32 | try { 33 | const names = await speakers.getNames(); 34 | res.locals.speakerNames = names; 35 | return next(); 36 | } catch (err) { 37 | return next(err); 38 | } 39 | }); 40 | 41 | app.use('/', routes({ 42 | speakers, 43 | feedback, 44 | })); 45 | 46 | app.use((req, res, next) => next(createError(404, 'File not found'))); 47 | 48 | // eslint-disable-next-line no-unused-vars 49 | app.use((err, req, res, next) => { 50 | res.locals.message = err.message; 51 | const status = err.status || 500; 52 | res.locals.status = status; 53 | res.locals.error = req.app.get('env') === 'development' ? err : {}; 54 | res.status(status); 55 | return res.render('error'); 56 | }); 57 | 58 | app.listen(3080); 59 | 60 | module.export = app; 61 | -------------------------------------------------------------------------------- /art-meetup/server/lib/CircuitBreaker.js: -------------------------------------------------------------------------------- 1 | const axios = require('axios'); 2 | 3 | class CircuitBreaker { 4 | constructor(){ 5 | this.states = {}; 6 | this.failureThreshold = 5; 7 | this.coolDownPeriod = 10; 8 | this.requestTimeout = 2; 9 | } 10 | 11 | async callService(reqOptions){ 12 | const endpoint = `${reqOptions.method}:${reqOptions.url}`; 13 | 14 | if(!this.canRequest(endpoint)) return false; 15 | 16 | reqOptions.timeout = this.requestTimeout * 1000; 17 | 18 | try{ 19 | const res = await axios(reqOptions); 20 | this.onSuccess(endpoint); 21 | return res.data; 22 | }catch(err){ 23 | this.onFailure(endpoint); 24 | return false; 25 | } 26 | } 27 | 28 | onSuccess(endpoint) { 29 | this.initState(endpoint); 30 | } 31 | 32 | onFailure(endpoint){ 33 | const state = this.states[endpoint]; 34 | state.failures +=1; 35 | if(state.failures > this.failureThreshold){ 36 | state.circuit = "OPEN"; 37 | state.nextTry = new Date() / 1000 + this.coolDownPeriod; 38 | console.log(`Alert! Circuit for ${endpoint} is in state 'OPEN'`); 39 | } 40 | } 41 | 42 | canRequest(endpoint){ 43 | if(!this.states[endpoint]) this.initState(endpoint); 44 | const state = this.states[endpoint]; 45 | if(state.circuit === 'CLOSED') return true; 46 | const now = new Date() / 1000; 47 | if(state.nextTry <= now){ 48 | state.circuit = "HALF"; 49 | return true; 50 | } 51 | 52 | return false; 53 | } 54 | 55 | initState(endpoint){ 56 | this.states[endpoint] = { 57 | failures: 0, 58 | coolDownPeriod: this.coolDownPeriod, 59 | circuit: "CLOSED", 60 | nextTry: 0 61 | } 62 | } 63 | } 64 | 65 | module.exports = CircuitBreaker; -------------------------------------------------------------------------------- /art-meetup/server/routes/feedback/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | 3 | const router = express.Router(); 4 | 5 | module.exports = (param) => { 6 | const { feedback } = param; 7 | 8 | router.get('/', async (req, res) => { 9 | try { 10 | const feedbacklist = await feedback.getList(); 11 | return res.render('feedback', { 12 | page: 'Feedback', 13 | feedbacklist, 14 | success: req.query.success, 15 | }); 16 | } catch (err) { 17 | return err; 18 | } 19 | }); 20 | 21 | router.post('/', async (req, res, next) => { 22 | try { 23 | const fbName = req.body.fbName.trim(); 24 | const fbTitle = req.body.fbTitle.trim(); 25 | const fbMessage = req.body.fbMessage.trim(); 26 | const feedbacklist = await feedback.getList(); 27 | if (!fbName || !fbTitle || !fbMessage) { 28 | return res.render('feedback', { 29 | page: 'Feedback', 30 | error: true, 31 | fbName, 32 | fbMessage, 33 | fbTitle, 34 | feedbacklist, 35 | }); 36 | } 37 | await feedback.addEntry(fbName, fbTitle, fbMessage); 38 | return res.redirect('/feedback?success=true'); 39 | } catch (err) { 40 | return next(err); 41 | } 42 | }); 43 | 44 | return router; 45 | }; 46 | -------------------------------------------------------------------------------- /art-meetup/server/routes/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | 3 | const router = express.Router(); 4 | 5 | const speakersRoute = require('./speakers'); 6 | const feedbackRoute = require('./feedback'); 7 | 8 | module.exports = (param) => { 9 | const { speakers } = param; 10 | 11 | router.get('/images/:type/:file', async (req, res, next) => { 12 | try{ 13 | const image = await speakers.getImage(`${req.params.type}/${req.params.file}`); 14 | return image.pipe(res); 15 | }catch(err){ 16 | return next(err); 17 | } 18 | }) 19 | 20 | router.get('/', async (req, res, next) => { 21 | try { 22 | const promises = []; 23 | promises.push(speakers.getListShort()); 24 | promises.push(speakers.getAllArtwork()); 25 | 26 | const results = await Promise.all(promises); 27 | 28 | return res.render('index', { 29 | page: 'Home', 30 | speakerslist: results[0], 31 | artwork: results[1], 32 | }); 33 | } catch (err) { 34 | return next(err); 35 | } 36 | }); 37 | 38 | router.use('/speakers', speakersRoute(param)); 39 | router.use('/feedback', feedbackRoute(param)); 40 | 41 | return router; 42 | }; 43 | -------------------------------------------------------------------------------- /art-meetup/server/routes/speakers/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | 3 | const router = express.Router(); 4 | 5 | module.exports = (param) => { 6 | const { speakers } = param; 7 | 8 | router.get('/', async (req, res) => { 9 | try { 10 | const promises = []; 11 | promises.push(speakers.getList()); 12 | promises.push(speakers.getAllArtwork()); 13 | 14 | const results = await Promise.all(promises); 15 | 16 | return res.render('speakers', { 17 | page: 'All Speakers', 18 | speakerslist: results[0], 19 | artwork: results[1], 20 | }); 21 | } catch (err) { 22 | return err; 23 | } 24 | }); 25 | 26 | router.get('/:name', async (req, res, next) => { 27 | try { 28 | const promises = []; 29 | promises.push(speakers.getSpeaker(req.params.name)); 30 | promises.push(speakers.getArtworkForSpeaker(req.params.name)); 31 | const results = await Promise.all(promises); 32 | 33 | if (!results[0]) { 34 | return next(); 35 | } 36 | 37 | return res.render('speakers/detail', { 38 | page: req.params.name, 39 | speaker: results[0], 40 | artwork: results[1], 41 | }); 42 | } catch (err) { 43 | return next(err); 44 | } 45 | }); 46 | 47 | return router; 48 | }; 49 | -------------------------------------------------------------------------------- /art-meetup/server/services/Feedback-old.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs'); 2 | const util = require('util'); 3 | 4 | const readFile = util.promisify(fs.readFile); 5 | const writeFile = util.promisify(fs.writeFile); 6 | 7 | class FeedbackService { 8 | constructor(datafile) { 9 | this.datafile = datafile; 10 | } 11 | 12 | async addEntry(name, title, message) { 13 | const data = await this.getData(); 14 | data.unshift({ name, title, message }); 15 | return writeFile(this.datafile, JSON.stringify(data)); 16 | } 17 | 18 | async getList() { 19 | const data = await this.getData(); 20 | return data; 21 | } 22 | 23 | async getData() { 24 | const data = await readFile(this.datafile, 'utf8'); 25 | if (!data) return []; 26 | return JSON.parse(data); 27 | } 28 | } 29 | 30 | module.exports = FeedbackService; 31 | -------------------------------------------------------------------------------- /art-meetup/server/services/Feedback.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable class-methods-use-this */ 2 | const url = require('url'); 3 | const axios = require('axios'); 4 | const crypto = require('crypto'); 5 | const amqplib = require('amqplib'); 6 | 7 | const CircuitBreaker = require('../lib/CircuitBreaker'); 8 | 9 | const circuitBreaker = new CircuitBreaker(); 10 | 11 | class FeedbackService { 12 | constructor({serviceRegistryUrl, serviceVersion}) { 13 | this.serviceRegistryUrl = serviceRegistryUrl; 14 | this.serviceVersion = serviceVersion; 15 | this.cache = {}; 16 | } 17 | 18 | async addEntry(name, title, message){ 19 | const q = 'feedback'; 20 | const conn = await amqplib.connect('amqp://localhost'); 21 | const ch = await conn.createChannel(); 22 | await ch.assertQueue(q); 23 | const qm = JSON.stringify({name, title, message}); 24 | return ch.sendToQueue(q, Buffer.from(qm, 'utf8')); 25 | } 26 | 27 | async getList() { 28 | const { ip, port } = await this.getService('feedback-service'); 29 | return this.callService({ 30 | method: 'get', 31 | url: `http://${ip}:${port}/list`, 32 | }); 33 | } 34 | 35 | async callService(reqOptions) { 36 | const parsedUrl = url.parse(reqOptions.url); 37 | const cacheKey = crypto.createHash('md5').update(reqOptions.method + parsedUrl.path).digest('hex'); 38 | 39 | const result = await circuitBreaker.callService(reqOptions); 40 | 41 | if (!result) { 42 | if (this.cache[cacheKey]) { 43 | return this.cache[cacheKey]; 44 | } 45 | return null; 46 | } 47 | 48 | this.cache[cacheKey] = result; 49 | 50 | this.cache[cacheKey] = result; 51 | return result; 52 | } 53 | 54 | async getService(servicename) { 55 | const response = await axios.get(`${this.serviceRegistryUrl}/find/${servicename}/${this.serviceVersion}`); 56 | return response.data; 57 | } 58 | } 59 | 60 | module.exports = FeedbackService; 61 | -------------------------------------------------------------------------------- /art-meetup/server/services/Speakers.js: -------------------------------------------------------------------------------- 1 | const axios = require('axios'); 2 | const url = require('url'); 3 | const crypto = require('crypto'); 4 | const fs = require('fs'); 5 | const util = require('util'); 6 | 7 | const fsexists = util.promisify(fs.exists); 8 | 9 | const CircuitBreaker = require('../lib/CircuitBreaker'); 10 | const circuitBreaker = new CircuitBreaker(); 11 | 12 | class SpeakersService { 13 | constructor({serviceRegistryUrl, serviceVersion}) { 14 | this.serviceRegistryUrl = serviceRegistryUrl; 15 | this.serviceVersion = serviceVersion; 16 | this.cache = {}; 17 | } 18 | 19 | async getImage(path) { 20 | const {ip, port} = await this.getService('speakers-service'); 21 | return this.callService({ 22 | method: 'get', 23 | responseType: 'stream', 24 | url: `http://${ip}:${port}/images/${path}` 25 | }); 26 | } 27 | 28 | async getNames() { 29 | const {ip, port} = await this.getService('speakers-service'); 30 | return this.callService({ 31 | method: 'get', 32 | url: `http://${ip}:${port}/names` 33 | }); 34 | } 35 | 36 | async getListShort() { 37 | const {ip, port} = await this.getService('speakers-service'); 38 | return this.callService({ 39 | method: 'get', 40 | url: `http://${ip}:${port}/list-short` 41 | }); 42 | } 43 | 44 | async getList() { 45 | const {ip, port} = await this.getService('speakers-service'); 46 | return this.callService({ 47 | method: 'get', 48 | url: `http://${ip}:${port}/list` 49 | }); 50 | } 51 | 52 | async getAllArtwork() { 53 | const {ip, port} = await this.getService('speakers-service'); 54 | return this.callService({ 55 | method: 'get', 56 | url: `http://${ip}:${port}/artworks` 57 | }); 58 | } 59 | 60 | async getSpeaker(shortname) { 61 | const {ip, port} = await this.getService('speakers-service'); 62 | return this.callService({ 63 | method: 'get', 64 | url: `http://${ip}:${port}/speaker/${shortname}` 65 | }); 66 | } 67 | 68 | async getArtworkForSpeaker(shortname) { 69 | const {ip, port} = await this.getService('speakers-service'); 70 | return this.callService({ 71 | method: 'get', 72 | url: `http://${ip}:${port}/artwork/${shortname}` 73 | }); 74 | } 75 | 76 | async getService(serviceName){ 77 | const res = await axios.get(`${this.serviceRegistryUrl}/find/${serviceName}/${this.serviceVersion}`); 78 | return res.data; 79 | } 80 | 81 | async callService(reqOptions){ 82 | const servicePath = url.parse(reqOptions.url).path; 83 | const cacheKey = crypto.createHash('md5').update(reqOptions.method + servicePath).digest('hex'); 84 | let cacheFile = null; 85 | 86 | if (reqOptions.responseType && reqOptions.responseType === 'stream') { 87 | cacheFile = `${__dirname}/../../_imagecache/${cacheKey}`; 88 | } 89 | 90 | const result = await circuitBreaker.callService(reqOptions); 91 | 92 | if (!result) { 93 | if (this.cache[cacheKey]) return this.cache[cacheKey]; 94 | if (cacheFile) { 95 | const exists = await fsexists(cacheFile); 96 | if (exists) return fs.createReadStream(cacheFile); 97 | } 98 | return false; 99 | } 100 | 101 | if (!cacheFile) { 102 | this.cache[cacheKey] = result; 103 | } else { 104 | const ws = fs.createWriteStream(cacheFile); 105 | result.pipe(ws); 106 | } 107 | return result; 108 | } 109 | } 110 | 111 | module.exports = SpeakersService; 112 | -------------------------------------------------------------------------------- /art-meetup/server/views/error.pug: -------------------------------------------------------------------------------- 1 | doctype html 2 | html 3 | head 4 | link#bootstrap-css(href='//maxcdn.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css',rel='stylesheet') 5 | link(rel='stylesheet', href='/css/error.css', type='text/css') 6 | script(src='//maxcdn.bootstrapcdn.com/bootstrap/4.1.1/js/bootstrap.min.js') 7 | script(src='//cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js') 8 | // ---- Include the above in your HEAD tag -------- 9 | 10 | body 11 | #main.d-flex.justify-content-center.align-items-center 12 | h1.mr-3.pr-3.align-top.border-right.inline-block.align-content-center=status 13 | .inline-block.align-middle 14 | h2#desc.font-weight-normal.lead=message 15 | if(error) 16 | pre=error.stack -------------------------------------------------------------------------------- /art-meetup/server/views/feedback/index.pug: -------------------------------------------------------------------------------- 1 | extends ../layout/index 2 | block content 3 | #feedback.container 4 | .row 5 | .col-sm-4 6 | h1.feedback-form-title Send us feedback 7 | if error 8 | .alert.alert-danger 9 | | There was an error handling your request. Did you fill out all fields? 10 | else if success 11 | .alert.alert-success 12 | | Thank you for your feedback! 13 | form.feedback-form(action='/feedback', method='POST') 14 | .form-group 15 | label(for='feedback-form-name') Name 16 | input#feedback-form-name.form-control(type='text', placeholder='Enter your name', name='fbName', value=fbName) 17 | .form-group 18 | label(for='feedback-form-title') Title 19 | input#feedback-form-title.form-control(type='text', placeholder='Title of your feedback', name='fbTitle', value=fbTitle) 20 | .form-group 21 | label(for='feedback-form-message') Message 22 | textarea#feedback-form-message.form-control(type='text', placeholder='Enter your message, then hit the submit', rows='6', name='fbMessage')=fbMessage 23 | button.btn.btn-default.pull-right(type='submit') Submit 24 | // primary 25 | aside.col-sm-8 26 | .maincontent.feedback 27 | h2.article-title Recent Feedback 28 | if !feedbacklist || !feedbacklist.length 29 | | No feedback so far! Be the first. 30 | else 31 | .feedback-messages 32 | each item in feedbacklist 33 | .feedback-item.item-list.media-list 34 | .feedback-item.media 35 | .feedback-info.media-body 36 | .feedback-head 37 | .feedback-title=item.title 38 | |   39 | small.feedback-name.label.label-info=item.name 40 | .feedback-message=item.message -------------------------------------------------------------------------------- /art-meetup/server/views/includes/artwork.pug: -------------------------------------------------------------------------------- 1 | if artwork && artwork.length 2 | h1.sidebar-title Artwork on display 3 | p.sidebar-body 4 | | While you attend the conference, head over to our gallery where you can check out some of the work from our speakers. 5 | .pixgrid.clearfix 6 | each thumb, index in artwork 7 | img(src=`/images/artwork/${thumb}`, alt=`Artwork ${index}`) -------------------------------------------------------------------------------- /art-meetup/server/views/includes/sidebar.pug: -------------------------------------------------------------------------------- 1 | aside.col-sm-4 2 | article.sidebar 3 | h1.sidebar-title Who should come? 4 | ul.sidebar-body 5 | li Anybody interested in art and the creative industry 6 | li Painters, sculptors, photographers and graphic artists 7 | li 8 | | Those interested in meeting and making a connection with others in the local art scene. 9 | // article 10 | article.sidebar 11 | include artwork -------------------------------------------------------------------------------- /art-meetup/server/views/includes/speakerslist.pug: -------------------------------------------------------------------------------- 1 | article.speakerslist.jumbotron.hidden-xs 2 | .container 3 | .row 4 | each speaker in speakerslist 5 | .col-sm-4.text-center 6 | h3.speakerslist-title=speaker.title 7 | h5.speakerslist-name 8 | | with   9 | a(href=`/speakers/${speaker.shortname}`)=speaker.name 10 | p.speakerslist-info 11 | a(href=`/speakers/${speaker.shortname}`) 12 | img.speakerslist-img.img-circle(src=`/images/speakers/${speaker.shortname}_tn.jpg`, alt=`Photo of ${speaker.name}`) -------------------------------------------------------------------------------- /art-meetup/server/views/index.pug: -------------------------------------------------------------------------------- 1 | extends layout/index 2 | block speakerslist 3 | include includes/speakerslist 4 | block content 5 | #home.container 6 | .row 7 | .col-sm-8 8 | .maincontent 9 | article.article 10 | h1.article-title Who are we? 11 | p 12 | | The Roux Academy gets thousands of submissions every year for artists interesting in participating in the CAC 13 | | exhibits, and selects approximately 200 distinct pieces of contemporary art for display in their collective 14 | | exhibit. In addition, 12 individuals are honored as Featured Artists - each being granted his or her own exhibit 15 | | hall to display entire collections or themed pieces. 16 | p 17 | | Each Featured Artist has an opportunity to speak at one of our meetups and share his or her vision, perspective, 18 | | and techniques with attendees on a more personal level than at our large conference. It is truly an honor to 19 | | be a CAC Featured Artist and many past students artists who were featured at CAC have gone on to brilliant 20 | | careers in art. 21 | // article 22 | article.article 23 | h1.article-title Get Busy! 24 | p 25 | | If you want to keep up with what's going on with the group, 26 | a(href='http://www.meetup.com/rouxmeet') join our meetup group 27 | | , 28 | a(href='http://www.twitter.com/rouxmeet') follow us on twitter 29 | | . If you're in FaceBook, you can also 30 | a(href='http://www.facebook.com/rouxmeet') join our FaceBook group 31 | | . 32 | 33 | include includes/sidebar -------------------------------------------------------------------------------- /art-meetup/server/views/layout/includes/header.pug: -------------------------------------------------------------------------------- 1 | header 2 | .jumbotron.hidden-xs 3 | // jumbotron 4 | nav.navbar.navbar-inverse 5 | .container 6 | .navbar-header 7 | button.navbar-toggle.collapsed(type='button', data-toggle='collapse', data-target='#navbar-collapse', aria-expanded='false') 8 | span.sr-only Toggle navigation 9 | span.icon-bar 10 | span.icon-bar 11 | span.icon-bar 12 | a.navbar-brand(href='/')=title 13 | #navbar-collapse.collapse.navbar-collapse 14 | ul.nav.navbar-nav.navbar-right 15 | li 16 | a(href='/') Home 17 | li 18 | a.dropdown-toggle(href='./speakers.html', data-toggle='dropdown', role='button', aria-haspopup='true', aria-expanded='false') 19 | | Speakers 20 | span.caret 21 | span 22 | ul.dropdown-menu 23 | li 24 | a(href='/speakers') All Speakers 25 | li.divider(role='separator') 26 | each speaker in speakerNames 27 | li 28 | a(href=`/speakers/${speaker.shortname}`)=speaker.name 29 | 30 | li 31 | a(href='/feedback') Feedback 32 | // nav 33 | // navbar-collapse 34 | // container -------------------------------------------------------------------------------- /art-meetup/server/views/layout/includes/scripts.pug: -------------------------------------------------------------------------------- 1 | script(src='https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js') 2 | script(src='https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js', integrity='sha384-0mSbJDEHialfmuBBQP6A4Qrprq5OVfW37PRR3j5ELqxss1yVqOtnepnHVP9aJ7xS', crossorigin='anonymous') 3 | if artwork && artwork.length 4 | script(src='/js/pixgrid.js') -------------------------------------------------------------------------------- /art-meetup/server/views/layout/index.pug: -------------------------------------------------------------------------------- 1 | doctype html 2 | html 3 | head 4 | title #{title} | #{page} 5 | link(rel='stylesheet', href='https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css', integrity='sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7', crossorigin='anonymous') 6 | link(rel='stylesheet', href='/css/style.css') 7 | meta(name='viewport', content='width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0') 8 | link(href='https://fonts.googleapis.com/css?family=Open+Sans|Roboto+Slab', rel='stylesheet', type='text/css') 9 | body 10 | include includes/header 11 | block speakerslist 12 | block content 13 | include includes/scripts 14 | -------------------------------------------------------------------------------- /art-meetup/server/views/speakers/detail/index.pug: -------------------------------------------------------------------------------- 1 | extends ../../layout/index 2 | block content 3 | #speakerDetail.container 4 | .row 5 | .col-sm-8 6 | article.speakerslist 7 | .container 8 | .row 9 | .col-sm-8 10 | h3.speakerslist-title=speaker.title 11 | h5.speakerslist-name 12 | | with  13 | a(href=`/speakers/${speaker.shortname}`)=speaker.name 14 | p.speakerslist-info 15 | a(href=`/speakers/${speaker.shortname}`) 16 | img.speakerslist-img.img-responsive.pull-left(src=`/images/speakers/${speaker.shortname}.jpg`, alt=`Photo of ${speaker.name}`) 17 | !=speaker.description 18 | // row 19 | // container 20 | // primary 21 | aside.col-sm-4 22 | article.sidebar 23 | include ../../includes/artwork -------------------------------------------------------------------------------- /art-meetup/server/views/speakers/index.pug: -------------------------------------------------------------------------------- 1 | extends ../layout/index 2 | block content 3 | #speakerList.container 4 | .row 5 | .col-sm-8 6 | article.speakerslist 7 | .container 8 | .row 9 | each speaker in speakerslist 10 | .col-sm-8 11 | h3.speakerslist-title=speaker.title 12 | h5.speakerslist-name 13 | | with   14 | a(href=`/speakers/${speaker.shortname}`)=speaker.name 15 | p.speakerslist-info 16 | a(href=`/speakers/${speaker.shortname}`) 17 | img.speakerslist-img.img-circle.pull-left(src=`/images/speakers/${speaker.shortname}_tn.jpg`, alt=`Photo of ${speaker.name}`) 18 | | #{speaker.summary} 19 | aside.col-sm-4 20 | article.sidebar 21 | include ../includes/artwork -------------------------------------------------------------------------------- /feedback-service/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | es6: true, 5 | }, 6 | extends: 'airbnb-base', 7 | globals: { 8 | Atomics: 'readonly', 9 | SharedArrayBuffer: 'readonly', 10 | }, 11 | parserOptions: { 12 | ecmaVersion: 2018, 13 | sourceType: 'module', 14 | }, 15 | rules: { 16 | "linebreak-style": 0 17 | }, 18 | }; 19 | -------------------------------------------------------------------------------- /feedback-service/.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .env -------------------------------------------------------------------------------- /feedback-service/bin/run: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | const axios = require('axios'); 4 | const http = require('http'); 5 | 6 | const config = require('../config')[process.env.NODE_ENV || 'development']; 7 | 8 | const log = config.log(); 9 | const service = require('../server/service')(config); 10 | 11 | const server = http.createServer(service); 12 | 13 | // Important - a service should not have a fixed port but should randomly choose one 14 | server.listen(process.env.PORT || 0); 15 | 16 | server.on('listening', () => { 17 | const registerService = () => axios.put(`http://localhost:3000/register/${config.name}/${config.version}/${server.address().port}`) 18 | .catch(err => log.fatal(err)); 19 | const unregisterService = () => axios.delete(`http://localhost:3000/register/${config.name}/${config.version}/${server.address().port}`) 20 | .catch(err => log.fatal(err)); 21 | 22 | registerService(); 23 | const interval = setInterval(registerService, 15 * 1000); 24 | const cleanup = async () => { 25 | let clean = false; 26 | if (!clean) { 27 | clean = true; 28 | clearInterval(interval); 29 | await unregisterService(); 30 | } 31 | }; 32 | 33 | process.on('uncaughtException', async () => { 34 | await cleanup(); 35 | process.exit(0); 36 | }); 37 | 38 | process.on('SIGINT', async () => { 39 | await cleanup(); 40 | process.exit(0); 41 | }); 42 | 43 | process.on('SIGTERM', async () => { 44 | await cleanup(); 45 | process.exit(0); 46 | }); 47 | 48 | log.info( 49 | `Hi there! I'm listening on port ${server.address().port} in ${service.get('env')} mode.`, 50 | ); 51 | }); 52 | -------------------------------------------------------------------------------- /feedback-service/config/index.js: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | 3 | const bunyan = require('bunyan'); 4 | // Load package.json 5 | const pjs = require('../package.json'); 6 | 7 | // Get some meta info from the package.json 8 | const { name, version } = pjs; 9 | 10 | // Set up a logger 11 | const getLogger = (serviceName, serviceVersion, level) => bunyan.createLogger({ name: `${serviceName}:${serviceVersion}`, level }); 12 | 13 | // Configuration options for different environments 14 | module.exports = { 15 | development: { 16 | name, 17 | version, 18 | serviceTimeout: 30, 19 | log: () => getLogger(name, version, 'debug'), 20 | data: { 21 | feedback: path.join(__dirname, '../data/feedback.json'), 22 | }, 23 | }, 24 | production: { 25 | name, 26 | version, 27 | serviceTimeout: 30, 28 | log: () => getLogger(name, version, 'info'), 29 | data: { 30 | feedback: path.join(__dirname, '../data/feedback.json'), 31 | }, 32 | }, 33 | test: { 34 | name, 35 | version, 36 | serviceTimeout: 30, 37 | log: () => getLogger(name, version, 'fatal'), 38 | data: { 39 | speakers: path.join(__dirname, '../data/speakers.json'), 40 | }, 41 | }, 42 | }; 43 | -------------------------------------------------------------------------------- /feedback-service/data/feedback.json: -------------------------------------------------------------------------------- 1 | [{"name":"wewe","title":"dfgdfgdf","message":"gdfgdfg"},{"name":"wdj queue 4","title":"queue message 4","message":"efsdfgsdfg"},{"name":"wdj queue 3","title":"queue message 3","message":"sdfgsdfg"},{"name":"wdj queue","title":"queue message 1","message":"something i queued"},{"name":"wdj","email":"wdj@gmail.com","title":"WDJ TItltw","message":"WDJ message"},{"name":"sdfg","email":"sdfg@gmail.com","title":"Home & Kitchen","message":"thids idfg kn sdfg"},{"name":"WDJ","email":"wdj@gmail.com","title":"some title","message":"this is meesagee from postman"},{"name":"wdj","email":"wdj@gmail.com","title":"some title","message":"Wdj was here"},{"name":"sdfg","email":"sdfgsdfg@gmail.com","title":"asdfgsdfg","message":"sfdghdfghdfgh"},{"name":"willy winka","email":"willy@aol.com","title":"somw tilte","message":"this is a message"},{"name":"Willy","email":"test@test2.com","title":"Final message","message":"This page is finished now"},{"name":"Willy","email":"test@test.com","title":"SPA Feedback","message":"This should now work"},{"name":"Willy","email":"test@test.com","title":"REST Title Test","message":"This was sent via REST"},{"name":"Willy","email":"test@test.com","title":"This was very nice","message":"I will come again next week!"},{"name":"Santa","email":"santa@gmail.com","title":"Best Meetup Ever","message":"I really love this meetup. Please don't let it end."},{"name":"WDJ","email":"wdj@gmail.com","title":"Meeting Time","message":"Would you consider moving the meeting time 30 minutes to about 6pm. It's tough to make it to the meetings on time right after work."},{"name":"Fred","email":"fred-jones@gmail.com","title":"Great Speaker","message":"I really enjoyed the speaker this month. Would love to hear another presentation."}] -------------------------------------------------------------------------------- /feedback-service/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "feedback-service", 3 | "version": "1.0.0", 4 | "description": "A service to read and post feedback", 5 | "scripts": { 6 | "start": "nodemon bin/run | bunyan" 7 | }, 8 | "keywords": [], 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "amqplib": "^0.6.0", 13 | "axios": "^0.18.1", 14 | "bunyan": "^1.8.12", 15 | "express": "^4.16.4" 16 | }, 17 | "devDependencies": { 18 | "chai": "^4.2.0", 19 | "chai-http": "^4.2.1", 20 | "eslint": "^5.14.1", 21 | "eslint-config-airbnb-base": "^13.1.0", 22 | "eslint-plugin-import": "^2.16.0", 23 | "nodemon": "^2.0.4" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /feedback-service/server/lib/Feedback.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs'); 2 | const util = require('util'); 3 | 4 | const readFile = util.promisify(fs.readFile); 5 | const writeFile = util.promisify(fs.writeFile); 6 | 7 | class FeedbackService { 8 | constructor(datafile) { 9 | this.datafile = datafile; 10 | } 11 | 12 | async addEntry(name, title, message) { 13 | const data = await this.getData(); 14 | data.unshift({ name, title, message }); 15 | return writeFile(this.datafile, JSON.stringify(data)); 16 | } 17 | 18 | async getList() { 19 | const data = await this.getData(); 20 | return data; 21 | } 22 | 23 | async getData() { 24 | const data = await readFile(this.datafile, 'utf8'); 25 | if (!data) return []; 26 | return JSON.parse(data); 27 | } 28 | } 29 | 30 | module.exports = FeedbackService; 31 | -------------------------------------------------------------------------------- /feedback-service/server/service.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const amqplib = require('amqplib'); 3 | 4 | const Feedback = require('./lib/Feedback'); 5 | 6 | const service = express(); 7 | 8 | module.exports = (config) => { 9 | const feedback = new Feedback(config.data.feedback); 10 | 11 | const log = config.log(); 12 | 13 | const q = 'feedback'; 14 | 15 | amqplib.connect('amqp://localhost').then(conn => conn.createChannel()) 16 | .then(ch => ch.assertQueue(q).then(() => ch.consume(q, (msg) => { 17 | if (msg !== null) { 18 | log.debug(`Got message ${msg.content.toString()}`); 19 | const qm = JSON.parse(msg.content.toString()); 20 | feedback.addEntry(qm.name, qm.title, qm.message) 21 | .then(() => ch.ack(msg)); 22 | } 23 | }))).catch(err => log.fatal(err)); 24 | 25 | // Add a request logging middleware in development mode 26 | if (service.get('env') === 'development') { 27 | service.use((req, res, next) => { 28 | log.debug(`${req.method}: ${req.url}`); 29 | return next(); 30 | }); 31 | } 32 | 33 | service.get('/list', async (req, res, next) => { 34 | console.log(`made it /list in feedback service`) 35 | try { 36 | return res.json(await feedback.getList()); 37 | } catch (err) { 38 | return next(err); 39 | } 40 | }); 41 | 42 | // eslint-disable-next-line no-unused-vars 43 | service.use((error, req, res, next) => { 44 | res.status(error.status || 500); 45 | // Log out the error to the console 46 | log.error(error); 47 | return res.json({ 48 | error: { 49 | message: error.message, 50 | }, 51 | }); 52 | }); 53 | return service; 54 | }; 55 | -------------------------------------------------------------------------------- /service-registry/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | es6: true, 5 | }, 6 | extends: 'airbnb-base', 7 | globals: { 8 | Atomics: 'readonly', 9 | SharedArrayBuffer: 'readonly', 10 | }, 11 | parserOptions: { 12 | ecmaVersion: 2018, 13 | sourceType: 'module', 14 | }, 15 | rules: { 16 | "linebreak-style": 0 17 | }, 18 | }; 19 | -------------------------------------------------------------------------------- /service-registry/.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .env -------------------------------------------------------------------------------- /service-registry/bin/run: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | const http = require('http'); 4 | 5 | const config = require('../config')[process.env.NODE_ENV || 'development']; 6 | 7 | const log = config.log(); 8 | const service = require('../server/service')(config); 9 | 10 | const server = http.createServer(service); 11 | 12 | server.listen(process.env.PORT || 3000); 13 | 14 | server.on('listening', () => { 15 | log.info( 16 | `Hi there! I'm listening on port ${server.address().port} in ${service.get('env')} mode.`, 17 | ); 18 | }); 19 | -------------------------------------------------------------------------------- /service-registry/config/index.js: -------------------------------------------------------------------------------- 1 | const bunyan = require('bunyan'); 2 | // Load package.json 3 | const pjs = require('../package.json'); 4 | 5 | // Get some meta info from the package.json 6 | const { name, version } = pjs; 7 | 8 | // Set up a logger 9 | const getLogger = (serviceName, serviceVersion, level) => bunyan.createLogger({ name: `${serviceName}:${serviceVersion}`, level }); 10 | 11 | // Configuration options for different environments 12 | module.exports = { 13 | development: { 14 | name, 15 | version, 16 | serviceTimeout: 30, 17 | log: () => getLogger(name, version, 'debug'), 18 | }, 19 | production: { 20 | name, 21 | version, 22 | serviceTimeout: 30, 23 | log: () => getLogger(name, version, 'info'), 24 | }, 25 | test: { 26 | name, 27 | version, 28 | serviceTimeout: 30, 29 | log: () => getLogger(name, version, 'fatal'), 30 | }, 31 | }; 32 | -------------------------------------------------------------------------------- /service-registry/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "service-registry", 3 | "version": "1.0.0", 4 | "description": "A generic service registry for Node.js", 5 | "scripts": { 6 | "start": "nodemon bin/run | bunyan" 7 | }, 8 | "keywords": [], 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "axios": "^0.19.2", 13 | "bunyan": "^1.8.12", 14 | "express": "^4.16.4", 15 | "semver": "^7.3.2" 16 | }, 17 | "devDependencies": { 18 | "chai": "^4.2.0", 19 | "chai-http": "^4.2.1", 20 | "eslint": "^5.14.1", 21 | "eslint-config-airbnb-base": "^13.1.0", 22 | "eslint-plugin-import": "^2.16.0", 23 | "nodemon": "^2.0.4" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /service-registry/server/lib/ServiceRegistry.js: -------------------------------------------------------------------------------- 1 | const semver = require('semver'); 2 | const service = require('../service'); 3 | 4 | class ServiceRegistry { 5 | constructor(log){ 6 | this.log = log; 7 | this.services = {}; 8 | this.timeout = 30; 9 | } 10 | 11 | get(name, version){ 12 | this.cleanup(); 13 | const serviceList = Object.values(this.services).filter(service => service.name === name && semver.satisfies(service.version, version)); 14 | 15 | return serviceList[Math.floor(Math.random() * serviceList.length)]; 16 | } 17 | 18 | register(name, version, ip, port){ 19 | this.cleanup(); 20 | const key = name+version+ip+port; 21 | 22 | if(!this.services[key]){ 23 | this.services[key] = {}; 24 | this.services[key].timestamp = Math.floor(new Date() / 1000); 25 | this.services[key].ip = ip; 26 | this.services[key].port = port; 27 | this.services[key].name = name; 28 | this.services[key].version = version; 29 | this.log.debug(`Added services ${name}, version ${version} at ${ip}:${port}`); 30 | return key; 31 | } 32 | 33 | this.services[key].timestamp = Math.floor(new Date() / 1000); 34 | this.log.debug(`Updated services ${name}, version ${version} at ${ip}:${port}`); 35 | return key; 36 | } 37 | 38 | unregister(name, version, ip, port){ 39 | const key = name+version+ip+port; 40 | delete this.services[key]; 41 | this.log.debug(`Unregistered services ${name}, version ${version} at ${ip}:${port}`); 42 | return key; 43 | } 44 | 45 | cleanup(){ 46 | const now = Math.floor(new Date() / 1000); 47 | Object.keys(this.services).forEach((key) => { 48 | if(this.services[key].timestamp + this.timeout < now){ 49 | delete this.services[key]; 50 | this.log.debug(`Removed service ${key}`); 51 | } 52 | }) 53 | } 54 | } 55 | 56 | module.exports = ServiceRegistry; -------------------------------------------------------------------------------- /service-registry/server/service.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const ServiceRegistry = require('./lib/ServiceRegistry'); 3 | 4 | const service = express(); 5 | 6 | module.exports = (config) => { 7 | const log = config.log(); 8 | const serviceRegisrty = new ServiceRegistry(log); 9 | 10 | // Add a request logging middleware in development mode 11 | if (service.get('env') === 'development') { 12 | service.use((req, res, next) => { 13 | log.debug(`${req.method}: ${req.url}`); 14 | return next(); 15 | }); 16 | } 17 | 18 | service.put('/register/:servicename/:serviceversion/:serviceport', (req, res) => { 19 | const {servicename, serviceversion, serviceport} = req.params; 20 | 21 | const serviceip = req.connection.remoteAddress.includes('::') ? `[${req.connection.remoteAddress}]` : req.connection.remoteAddress; 22 | 23 | const serviceKey = serviceRegisrty.register(servicename, serviceversion, serviceip, serviceport); 24 | 25 | return res.json({result: serviceKey}) 26 | }) 27 | 28 | service.delete('/unregister/:servicename/:serviceversion/:serviceport', (req, res) => { 29 | const {servicename, serviceversion, serviceport} = req.params; 30 | 31 | const serviceip = req.connection.remoteAddress.includes('::') ? `[${req.connection.remoteAddress}]` : req.connection.remoteAddress; 32 | 33 | const serviceKey = serviceRegisrty.unregister(servicename, serviceversion, serviceip, serviceport); 34 | 35 | return res.json({result: `Deleted ${serviceKey}`}) 36 | }) 37 | 38 | service.get('/find/:servicename/:serviceversion', (req, res) => { 39 | const {servicename, serviceversion} = req.params; 40 | const svc = serviceRegisrty.get(servicename, serviceversion); 41 | if(!svc) return res.status(404).json({result: "Service not found"}); 42 | return res.json(svc); 43 | }) 44 | 45 | // eslint-disable-next-line no-unused-vars 46 | service.use((error, req, res, next) => { 47 | res.status(error.status || 500); 48 | // Log out the error to the console 49 | log.error(error); 50 | return res.json({ 51 | error: { 52 | message: error.message, 53 | }, 54 | }); 55 | }); 56 | return service; 57 | }; 58 | -------------------------------------------------------------------------------- /speakers-service/.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | es6: true, 5 | }, 6 | extends: 'airbnb-base', 7 | globals: { 8 | Atomics: 'readonly', 9 | SharedArrayBuffer: 'readonly', 10 | }, 11 | parserOptions: { 12 | ecmaVersion: 2018, 13 | sourceType: 'module', 14 | }, 15 | rules: { 16 | "linebreak-style": 0 17 | }, 18 | }; 19 | -------------------------------------------------------------------------------- /speakers-service/.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | .env -------------------------------------------------------------------------------- /speakers-service/bin/run: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | const axios = require('axios'); 3 | const http = require('http'); 4 | 5 | const config = require('../config')[process.env.NODE_ENV || 'development']; 6 | 7 | const log = config.log(); 8 | const service = require('../server/service')(config); 9 | 10 | const server = http.createServer(service); 11 | 12 | // Important - a service should not have a fixed port but should randomly choose one 13 | server.listen(0); 14 | 15 | server.on('listening', () => { 16 | const registerService = () => axios.put(`http://localhost:3000/register/${config.name}/${config.version}/${server.address().port}`); 17 | const unregisterService = () => axios.delete(`http://localhost:3000/unregister/${config.name}/${config.version}/${server.address().port}`); 18 | 19 | registerService(); 20 | 21 | const interval = setInterval(registerService, 20 * 1000); 22 | const cleanup = async () => { 23 | clearInterval(interval); 24 | await unregisterService(); 25 | } 26 | 27 | process.on('uncaughtException', async() => { 28 | await cleanup(); 29 | process.exit(0); 30 | }); 31 | 32 | process.on('SIGINT', async() => { 33 | await cleanup(); 34 | process.exit(0); 35 | }); 36 | 37 | process.on('SIGTERM', async() => { 38 | await cleanup(); 39 | process.exit(0); 40 | }); 41 | 42 | // setTimeout(() => { 43 | // throw new Error('Something happened'); 44 | // }, 10000) 45 | 46 | log.info( 47 | `Hi there! I'm listening on port ${server.address().port} in ${service.get('env')} mode.`, 48 | ); 49 | }); 50 | -------------------------------------------------------------------------------- /speakers-service/config/index.js: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | const bunyan = require('bunyan'); 3 | // Load package.json 4 | const pjs = require('../package.json'); 5 | 6 | // Get some meta info from the package.json 7 | const { name, version } = pjs; 8 | 9 | // Set up a logger 10 | const getLogger = (serviceName, serviceVersion, level) => bunyan.createLogger({ name: `${serviceName}:${serviceVersion}`, level }); 11 | 12 | // Configuration options for different environments 13 | module.exports = { 14 | development: { 15 | name, 16 | version, 17 | serviceTimeout: 30, 18 | data: { 19 | images: path.join(__dirname, '../data/images'), 20 | speakers: path.join(__dirname, '../data/speakers.json') 21 | }, 22 | log: () => getLogger(name, version, 'debug'), 23 | }, 24 | production: { 25 | name, 26 | version, 27 | serviceTimeout: 30, 28 | data: { 29 | images: path.join(__dirname, '../data/images'), 30 | speakers: path.join(__dirname, '../data/speakers.json') 31 | }, 32 | log: () => getLogger(name, version, 'info'), 33 | }, 34 | test: { 35 | name, 36 | version, 37 | serviceTimeout: 30, 38 | data: { 39 | images: path.join(__dirname, '../data/images'), 40 | speakers: path.join(__dirname, '../data/speakers.json') 41 | }, 42 | log: () => getLogger(name, version, 'fatal'), 43 | }, 44 | }; 45 | -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_01.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_01.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_01_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_01_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_02.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_02.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_02_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_02_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_03.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_03.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_03_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_03_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_04.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_04.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/santa_clause_04_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/santa_clause_04_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_01.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_01.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_01_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_01_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_02.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_02.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_02_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_02_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_03.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_03.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_03_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_03_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_04.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_04.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_04_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_04_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_05.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_05.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_05_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_05_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_06.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_06.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_06_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_06_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_07.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_07.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wdj_07_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wdj_07_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_01.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_01.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_01_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_01_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_02.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_02.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_02_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_02_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_03.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_03.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_03_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_03_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_04.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_04.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_04_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_04_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_05.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_05.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_05_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_05_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_06.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_06.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/artwork/wonka_06_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/artwork/wonka_06_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/speakers/santa_clause.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/speakers/santa_clause.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/speakers/santa_clause_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/speakers/santa_clause_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/speakers/wdj.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/speakers/wdj.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/speakers/wdj_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/speakers/wdj_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/speakers/wonka.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/speakers/wonka.jpg -------------------------------------------------------------------------------- /speakers-service/data/images/speakers/wonka_tn.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/webdevjourneyWDJ/NodeJS_Microservices/dc14570e7141563fc5ed606c3d240cbaaa929aca/speakers-service/data/images/speakers/wonka_tn.jpg -------------------------------------------------------------------------------- /speakers-service/data/speakers.json: -------------------------------------------------------------------------------- 1 | { 2 | "speakers": [ 3 | { 4 | "title": "Art in Full Bloom", 5 | "name": "WDJ", 6 | "shortname": "wdj", 7 | "summary": "Bacon ipsum dolor amet buffalo burgdoggen ribeye turkey kevin salami ground round pastrami pork belly filet mignon strip steak venison. Salami pastrami tenderloin pig cupim strip steak landjaeger frankfurter tongue. Meatball hamburger pig picanha landjaeger,", 8 | "description": "

Doner shank sausage fatback drumstick. Ham hock chuck landjaeger pork loin, cupim bresaola capicola flank t-bone brisket pig. Turducken shankle ham hock tail chuck sausage pork buffalo tenderloin rump ham andouille tongue beef ribs. Brisket tri-tip sirloin meatball turkey shoulder pancetta. Drumstick bacon sirloin pig ground round jerky fatback kielbasa boudin buffalo biltong. T-bone tri-tip ball tip ham, pancetta jowl short loin porchetta tenderloin shankle pastrami.

", 9 | "artwork": [ 10 | "wdj_01_tn.jpg", 11 | "wdj_02_tn.jpg", 12 | "wdj_03_tn.jpg", 13 | "wdj_04_tn.jpg" 14 | ] 15 | }, 16 | { 17 | "title": "Deep Sea Wonders", 18 | "name": "Santa Clause", 19 | "shortname": "santa_clause", 20 | "summary": "Bacon ipsum dolor amet buffalo burgdoggen ribeye turkey kevin salami ground round pastrami pork belly filet mignon strip steak venison. Salami pastrami tenderloin pig cupim strip steak landjaeger frankfurter tongue. Meatball hamburger pig picanha landjaeger,", 21 | "description": "

Doner shank sausage fatback drumstick. Ham hock chuck landjaeger pork loin, cupim bresaola capicola flank t-bone brisket pig. Turducken shankle ham hock tail chuck sausage pork buffalo tenderloin rump ham andouille tongue beef ribs. Brisket tri-tip sirloin meatball turkey shoulder pancetta. Drumstick bacon sirloin pig ground round jerky fatback kielbasa boudin buffalo biltong. T-bone tri-tip ball tip ham, pancetta jowl short loin porchetta tenderloin shankle pastrami.

", 22 | "artwork": [ 23 | "santa_clause_01_tn.jpg", 24 | "santa_clause_02_tn.jpg", 25 | "santa_clause_03_tn.jpg", 26 | "santa_clause_04_tn.jpg" 27 | ] 28 | }, 29 | { 30 | "title": "The Art of Abstract", 31 | "name": "Willy Wonka", 32 | "shortname": "wonka", 33 | "summary": "Bacon ipsum dolor amet buffalo burgdoggen ribeye turkey kevin salami ground round pastrami pork belly filet mignon strip steak venison. Salami pastrami tenderloin pig cupim strip steak landjaeger frankfurter tongue. Meatball hamburger pig picanha landjaeger,", 34 | "description": "

Doner shank sausage fatback drumstick. Ham hock chuck landjaeger pork loin, cupim bresaola capicola flank t-bone brisket pig. Turducken shankle ham hock tail chuck sausage pork buffalo tenderloin rump ham andouille tongue beef ribs. Brisket tri-tip sirloin meatball turkey shoulder pancetta. Drumstick bacon sirloin pig ground round jerky fatback kielbasa boudin buffalo biltong. T-bone tri-tip ball tip ham, pancetta jowl short loin porchetta tenderloin shankle pastrami.

", 35 | "artwork": [ 36 | "wonka_01_tn.jpg", 37 | "wonka_02_tn.jpg", 38 | "wonka_03_tn.jpg", 39 | "wonka_04_tn.jpg", 40 | "wonka_05_tn.jpg", 41 | "wonka_06_tn.jpg" 42 | ] 43 | } 44 | ] 45 | } 46 | -------------------------------------------------------------------------------- /speakers-service/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "speakers-service", 3 | "version": "1.0.0", 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 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.0.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", 19 | "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@sindresorhus/is": { 28 | "version": "0.14.0", 29 | "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", 30 | "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==", 31 | "dev": true 32 | }, 33 | "@szmarczak/http-timer": { 34 | "version": "1.1.2", 35 | "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", 36 | "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", 37 | "dev": true, 38 | "requires": { 39 | "defer-to-connect": "^1.0.1" 40 | } 41 | }, 42 | "@types/chai": { 43 | "version": "4.1.7", 44 | "resolved": "https://registry.npmjs.org/@types/chai/-/chai-4.1.7.tgz", 45 | "integrity": "sha512-2Y8uPt0/jwjhQ6EiluT0XCri1Dbplr0ZxfFXUz+ye13gaqE8u5gL5ppao1JrUYr9cIip5S6MvQzBS7Kke7U9VA==", 46 | "dev": true 47 | }, 48 | "@types/color-name": { 49 | "version": "1.1.1", 50 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 51 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 52 | "dev": true 53 | }, 54 | "@types/cookiejar": { 55 | "version": "2.1.1", 56 | "resolved": "https://registry.npmjs.org/@types/cookiejar/-/cookiejar-2.1.1.tgz", 57 | "integrity": "sha512-aRnpPa7ysx3aNW60hTiCtLHlQaIFsXFCgQlpakNgDNVFzbtusSY8PwjAQgRWfSk0ekNoBjO51eQRB6upA9uuyw==", 58 | "dev": true 59 | }, 60 | "@types/node": { 61 | "version": "11.9.5", 62 | "resolved": "https://registry.npmjs.org/@types/node/-/node-11.9.5.tgz", 63 | "integrity": "sha512-vVjM0SVzgaOUpflq4GYBvCpozes8OgIIS5gVXVka+OfK3hvnkC1i93U8WiY2OtNE4XUWyyy/86Kf6e0IHTQw1Q==", 64 | "dev": true 65 | }, 66 | "@types/superagent": { 67 | "version": "3.8.7", 68 | "resolved": "https://registry.npmjs.org/@types/superagent/-/superagent-3.8.7.tgz", 69 | "integrity": "sha512-9KhCkyXv268A2nZ1Wvu7rQWM+BmdYUVkycFeNnYrUL5Zwu7o8wPQ3wBfW59dDP+wuoxw0ww8YKgTNv8j/cgscA==", 70 | "dev": true, 71 | "requires": { 72 | "@types/cookiejar": "*", 73 | "@types/node": "*" 74 | } 75 | }, 76 | "abbrev": { 77 | "version": "1.1.1", 78 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 79 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", 80 | "dev": true 81 | }, 82 | "accepts": { 83 | "version": "1.3.5", 84 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", 85 | "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", 86 | "requires": { 87 | "mime-types": "~2.1.18", 88 | "negotiator": "0.6.1" 89 | } 90 | }, 91 | "acorn": { 92 | "version": "6.4.1", 93 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.1.tgz", 94 | "integrity": "sha512-ZVA9k326Nwrj3Cj9jlh3wGFutC2ZornPNARZwsNYqQYgN0EsV2d53w5RN/co65Ohn4sUAUtb1rSUAOD6XN9idA==", 95 | "dev": true 96 | }, 97 | "acorn-jsx": { 98 | "version": "5.0.1", 99 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 100 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 101 | "dev": true 102 | }, 103 | "ajv": { 104 | "version": "6.9.2", 105 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.9.2.tgz", 106 | "integrity": "sha512-4UFy0/LgDo7Oa/+wOAlj44tp9K78u38E5/359eSrqEp1Z5PdVfimCcs7SluXMP755RUQu6d2b4AvF0R1C9RZjg==", 107 | "dev": true, 108 | "requires": { 109 | "fast-deep-equal": "^2.0.1", 110 | "fast-json-stable-stringify": "^2.0.0", 111 | "json-schema-traverse": "^0.4.1", 112 | "uri-js": "^4.2.2" 113 | } 114 | }, 115 | "ansi-align": { 116 | "version": "3.0.0", 117 | "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.0.tgz", 118 | "integrity": "sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw==", 119 | "dev": true, 120 | "requires": { 121 | "string-width": "^3.0.0" 122 | }, 123 | "dependencies": { 124 | "ansi-regex": { 125 | "version": "4.1.0", 126 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 127 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 128 | "dev": true 129 | }, 130 | "string-width": { 131 | "version": "3.1.0", 132 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 133 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 134 | "dev": true, 135 | "requires": { 136 | "emoji-regex": "^7.0.1", 137 | "is-fullwidth-code-point": "^2.0.0", 138 | "strip-ansi": "^5.1.0" 139 | } 140 | }, 141 | "strip-ansi": { 142 | "version": "5.2.0", 143 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 144 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 145 | "dev": true, 146 | "requires": { 147 | "ansi-regex": "^4.1.0" 148 | } 149 | } 150 | } 151 | }, 152 | "ansi-escapes": { 153 | "version": "3.2.0", 154 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 155 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 156 | "dev": true 157 | }, 158 | "ansi-regex": { 159 | "version": "3.0.0", 160 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 161 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 162 | "dev": true 163 | }, 164 | "ansi-styles": { 165 | "version": "3.2.1", 166 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 167 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 168 | "dev": true, 169 | "requires": { 170 | "color-convert": "^1.9.0" 171 | } 172 | }, 173 | "anymatch": { 174 | "version": "3.1.1", 175 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 176 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 177 | "dev": true, 178 | "requires": { 179 | "normalize-path": "^3.0.0", 180 | "picomatch": "^2.0.4" 181 | } 182 | }, 183 | "argparse": { 184 | "version": "1.0.10", 185 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 186 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 187 | "dev": true, 188 | "requires": { 189 | "sprintf-js": "~1.0.2" 190 | } 191 | }, 192 | "array-flatten": { 193 | "version": "1.1.1", 194 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 195 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 196 | }, 197 | "assertion-error": { 198 | "version": "1.1.0", 199 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 200 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 201 | "dev": true 202 | }, 203 | "astral-regex": { 204 | "version": "1.0.0", 205 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 206 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 207 | "dev": true 208 | }, 209 | "asynckit": { 210 | "version": "0.4.0", 211 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 212 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 213 | "dev": true 214 | }, 215 | "axios": { 216 | "version": "0.19.2", 217 | "resolved": "https://registry.npmjs.org/axios/-/axios-0.19.2.tgz", 218 | "integrity": "sha512-fjgm5MvRHLhx+osE2xoekY70AhARk3a6hkN+3Io1jc00jtquGvxYlKlsFUhmUET0V5te6CcZI7lcv2Ym61mjHA==", 219 | "requires": { 220 | "follow-redirects": "1.5.10" 221 | } 222 | }, 223 | "balanced-match": { 224 | "version": "1.0.0", 225 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 226 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 227 | }, 228 | "binary-extensions": { 229 | "version": "2.1.0", 230 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz", 231 | "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==", 232 | "dev": true 233 | }, 234 | "body-parser": { 235 | "version": "1.18.3", 236 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz", 237 | "integrity": "sha1-WykhmP/dVTs6DyDe0FkrlWlVyLQ=", 238 | "requires": { 239 | "bytes": "3.0.0", 240 | "content-type": "~1.0.4", 241 | "debug": "2.6.9", 242 | "depd": "~1.1.2", 243 | "http-errors": "~1.6.3", 244 | "iconv-lite": "0.4.23", 245 | "on-finished": "~2.3.0", 246 | "qs": "6.5.2", 247 | "raw-body": "2.3.3", 248 | "type-is": "~1.6.16" 249 | } 250 | }, 251 | "boxen": { 252 | "version": "4.2.0", 253 | "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz", 254 | "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==", 255 | "dev": true, 256 | "requires": { 257 | "ansi-align": "^3.0.0", 258 | "camelcase": "^5.3.1", 259 | "chalk": "^3.0.0", 260 | "cli-boxes": "^2.2.0", 261 | "string-width": "^4.1.0", 262 | "term-size": "^2.1.0", 263 | "type-fest": "^0.8.1", 264 | "widest-line": "^3.1.0" 265 | }, 266 | "dependencies": { 267 | "ansi-regex": { 268 | "version": "5.0.0", 269 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 270 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 271 | "dev": true 272 | }, 273 | "ansi-styles": { 274 | "version": "4.2.1", 275 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 276 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 277 | "dev": true, 278 | "requires": { 279 | "@types/color-name": "^1.1.1", 280 | "color-convert": "^2.0.1" 281 | } 282 | }, 283 | "chalk": { 284 | "version": "3.0.0", 285 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 286 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 287 | "dev": true, 288 | "requires": { 289 | "ansi-styles": "^4.1.0", 290 | "supports-color": "^7.1.0" 291 | } 292 | }, 293 | "color-convert": { 294 | "version": "2.0.1", 295 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 296 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 297 | "dev": true, 298 | "requires": { 299 | "color-name": "~1.1.4" 300 | } 301 | }, 302 | "color-name": { 303 | "version": "1.1.4", 304 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 305 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 306 | "dev": true 307 | }, 308 | "emoji-regex": { 309 | "version": "8.0.0", 310 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 311 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 312 | "dev": true 313 | }, 314 | "has-flag": { 315 | "version": "4.0.0", 316 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 317 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 318 | "dev": true 319 | }, 320 | "is-fullwidth-code-point": { 321 | "version": "3.0.0", 322 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 323 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 324 | "dev": true 325 | }, 326 | "string-width": { 327 | "version": "4.2.0", 328 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 329 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 330 | "dev": true, 331 | "requires": { 332 | "emoji-regex": "^8.0.0", 333 | "is-fullwidth-code-point": "^3.0.0", 334 | "strip-ansi": "^6.0.0" 335 | } 336 | }, 337 | "strip-ansi": { 338 | "version": "6.0.0", 339 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 340 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 341 | "dev": true, 342 | "requires": { 343 | "ansi-regex": "^5.0.0" 344 | } 345 | }, 346 | "supports-color": { 347 | "version": "7.1.0", 348 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 349 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 350 | "dev": true, 351 | "requires": { 352 | "has-flag": "^4.0.0" 353 | } 354 | } 355 | } 356 | }, 357 | "brace-expansion": { 358 | "version": "1.1.11", 359 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 360 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 361 | "requires": { 362 | "balanced-match": "^1.0.0", 363 | "concat-map": "0.0.1" 364 | } 365 | }, 366 | "braces": { 367 | "version": "3.0.2", 368 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 369 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 370 | "dev": true, 371 | "requires": { 372 | "fill-range": "^7.0.1" 373 | } 374 | }, 375 | "bunyan": { 376 | "version": "1.8.12", 377 | "resolved": "https://registry.npmjs.org/bunyan/-/bunyan-1.8.12.tgz", 378 | "integrity": "sha1-8VDw9nSKvdcq6uhPBEA74u8RN5c=", 379 | "requires": { 380 | "dtrace-provider": "~0.8", 381 | "moment": "^2.10.6", 382 | "mv": "~2", 383 | "safe-json-stringify": "~1" 384 | } 385 | }, 386 | "bytes": { 387 | "version": "3.0.0", 388 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 389 | "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" 390 | }, 391 | "cacheable-request": { 392 | "version": "6.1.0", 393 | "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", 394 | "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", 395 | "dev": true, 396 | "requires": { 397 | "clone-response": "^1.0.2", 398 | "get-stream": "^5.1.0", 399 | "http-cache-semantics": "^4.0.0", 400 | "keyv": "^3.0.0", 401 | "lowercase-keys": "^2.0.0", 402 | "normalize-url": "^4.1.0", 403 | "responselike": "^1.0.2" 404 | }, 405 | "dependencies": { 406 | "get-stream": { 407 | "version": "5.1.0", 408 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.1.0.tgz", 409 | "integrity": "sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw==", 410 | "dev": true, 411 | "requires": { 412 | "pump": "^3.0.0" 413 | } 414 | }, 415 | "lowercase-keys": { 416 | "version": "2.0.0", 417 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", 418 | "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", 419 | "dev": true 420 | } 421 | } 422 | }, 423 | "callsites": { 424 | "version": "3.0.0", 425 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.0.0.tgz", 426 | "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==", 427 | "dev": true 428 | }, 429 | "camelcase": { 430 | "version": "5.3.1", 431 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 432 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 433 | "dev": true 434 | }, 435 | "chai": { 436 | "version": "4.2.0", 437 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", 438 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", 439 | "dev": true, 440 | "requires": { 441 | "assertion-error": "^1.1.0", 442 | "check-error": "^1.0.2", 443 | "deep-eql": "^3.0.1", 444 | "get-func-name": "^2.0.0", 445 | "pathval": "^1.1.0", 446 | "type-detect": "^4.0.5" 447 | } 448 | }, 449 | "chai-http": { 450 | "version": "4.2.1", 451 | "resolved": "https://registry.npmjs.org/chai-http/-/chai-http-4.2.1.tgz", 452 | "integrity": "sha512-S2Ezy5uSVuOYleeXppfUKtTU/xbHCZyKkwjheNJ/76SGFTUPDpDkkpVdPNgC3sAO1Ap5J5LJ+/rXdLG8EGhCDA==", 453 | "dev": true, 454 | "requires": { 455 | "@types/chai": "4", 456 | "@types/superagent": "^3.8.3", 457 | "cookiejar": "^2.1.1", 458 | "is-ip": "^2.0.0", 459 | "methods": "^1.1.2", 460 | "qs": "^6.5.1", 461 | "superagent": "^3.7.0" 462 | } 463 | }, 464 | "chalk": { 465 | "version": "2.4.2", 466 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 467 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 468 | "dev": true, 469 | "requires": { 470 | "ansi-styles": "^3.2.1", 471 | "escape-string-regexp": "^1.0.5", 472 | "supports-color": "^5.3.0" 473 | } 474 | }, 475 | "chardet": { 476 | "version": "0.7.0", 477 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 478 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 479 | "dev": true 480 | }, 481 | "check-error": { 482 | "version": "1.0.2", 483 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 484 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 485 | "dev": true 486 | }, 487 | "chokidar": { 488 | "version": "3.4.1", 489 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.4.1.tgz", 490 | "integrity": "sha512-TQTJyr2stihpC4Sya9hs2Xh+O2wf+igjL36Y75xx2WdHuiICcn/XJza46Jwt0eT5hVpQOzo3FpY3cj3RVYLX0g==", 491 | "dev": true, 492 | "requires": { 493 | "anymatch": "~3.1.1", 494 | "braces": "~3.0.2", 495 | "fsevents": "~2.1.2", 496 | "glob-parent": "~5.1.0", 497 | "is-binary-path": "~2.1.0", 498 | "is-glob": "~4.0.1", 499 | "normalize-path": "~3.0.0", 500 | "readdirp": "~3.4.0" 501 | } 502 | }, 503 | "ci-info": { 504 | "version": "2.0.0", 505 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", 506 | "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", 507 | "dev": true 508 | }, 509 | "cli-boxes": { 510 | "version": "2.2.0", 511 | "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.0.tgz", 512 | "integrity": "sha512-gpaBrMAizVEANOpfZp/EEUixTXDyGt7DFzdK5hU+UbWt/J0lB0w20ncZj59Z9a93xHb9u12zF5BS6i9RKbtg4w==", 513 | "dev": true 514 | }, 515 | "cli-cursor": { 516 | "version": "2.1.0", 517 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 518 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 519 | "dev": true, 520 | "requires": { 521 | "restore-cursor": "^2.0.0" 522 | } 523 | }, 524 | "cli-width": { 525 | "version": "2.2.0", 526 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 527 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 528 | "dev": true 529 | }, 530 | "clone-response": { 531 | "version": "1.0.2", 532 | "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.2.tgz", 533 | "integrity": "sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws=", 534 | "dev": true, 535 | "requires": { 536 | "mimic-response": "^1.0.0" 537 | } 538 | }, 539 | "color-convert": { 540 | "version": "1.9.3", 541 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 542 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 543 | "dev": true, 544 | "requires": { 545 | "color-name": "1.1.3" 546 | } 547 | }, 548 | "color-name": { 549 | "version": "1.1.3", 550 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 551 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 552 | "dev": true 553 | }, 554 | "combined-stream": { 555 | "version": "1.0.7", 556 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", 557 | "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", 558 | "dev": true, 559 | "requires": { 560 | "delayed-stream": "~1.0.0" 561 | } 562 | }, 563 | "component-emitter": { 564 | "version": "1.2.1", 565 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 566 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", 567 | "dev": true 568 | }, 569 | "concat-map": { 570 | "version": "0.0.1", 571 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 572 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 573 | }, 574 | "configstore": { 575 | "version": "5.0.1", 576 | "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", 577 | "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", 578 | "dev": true, 579 | "requires": { 580 | "dot-prop": "^5.2.0", 581 | "graceful-fs": "^4.1.2", 582 | "make-dir": "^3.0.0", 583 | "unique-string": "^2.0.0", 584 | "write-file-atomic": "^3.0.0", 585 | "xdg-basedir": "^4.0.0" 586 | } 587 | }, 588 | "contains-path": { 589 | "version": "0.1.0", 590 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 591 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 592 | "dev": true 593 | }, 594 | "content-disposition": { 595 | "version": "0.5.2", 596 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 597 | "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=" 598 | }, 599 | "content-type": { 600 | "version": "1.0.4", 601 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 602 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 603 | }, 604 | "cookie": { 605 | "version": "0.3.1", 606 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 607 | "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=" 608 | }, 609 | "cookie-signature": { 610 | "version": "1.0.6", 611 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 612 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 613 | }, 614 | "cookiejar": { 615 | "version": "2.1.2", 616 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.2.tgz", 617 | "integrity": "sha512-Mw+adcfzPxcPeI+0WlvRrr/3lGVO0bD75SxX6811cxSh1Wbxx7xZBGK1eVtDf6si8rg2lhnUjsVLMFMfbRIuwA==", 618 | "dev": true 619 | }, 620 | "core-util-is": { 621 | "version": "1.0.2", 622 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 623 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 624 | "dev": true 625 | }, 626 | "cross-spawn": { 627 | "version": "6.0.5", 628 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 629 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 630 | "dev": true, 631 | "requires": { 632 | "nice-try": "^1.0.4", 633 | "path-key": "^2.0.1", 634 | "semver": "^5.5.0", 635 | "shebang-command": "^1.2.0", 636 | "which": "^1.2.9" 637 | } 638 | }, 639 | "crypto-random-string": { 640 | "version": "2.0.0", 641 | "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", 642 | "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", 643 | "dev": true 644 | }, 645 | "debug": { 646 | "version": "2.6.9", 647 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 648 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 649 | "requires": { 650 | "ms": "2.0.0" 651 | } 652 | }, 653 | "decompress-response": { 654 | "version": "3.3.0", 655 | "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", 656 | "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", 657 | "dev": true, 658 | "requires": { 659 | "mimic-response": "^1.0.0" 660 | } 661 | }, 662 | "deep-eql": { 663 | "version": "3.0.1", 664 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 665 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 666 | "dev": true, 667 | "requires": { 668 | "type-detect": "^4.0.0" 669 | } 670 | }, 671 | "deep-extend": { 672 | "version": "0.6.0", 673 | "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", 674 | "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", 675 | "dev": true 676 | }, 677 | "deep-is": { 678 | "version": "0.1.3", 679 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 680 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 681 | "dev": true 682 | }, 683 | "defer-to-connect": { 684 | "version": "1.1.3", 685 | "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", 686 | "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==", 687 | "dev": true 688 | }, 689 | "define-properties": { 690 | "version": "1.1.3", 691 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 692 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 693 | "dev": true, 694 | "requires": { 695 | "object-keys": "^1.0.12" 696 | } 697 | }, 698 | "delayed-stream": { 699 | "version": "1.0.0", 700 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 701 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 702 | "dev": true 703 | }, 704 | "depd": { 705 | "version": "1.1.2", 706 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 707 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 708 | }, 709 | "destroy": { 710 | "version": "1.0.4", 711 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 712 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 713 | }, 714 | "doctrine": { 715 | "version": "3.0.0", 716 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 717 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 718 | "dev": true, 719 | "requires": { 720 | "esutils": "^2.0.2" 721 | } 722 | }, 723 | "dot-prop": { 724 | "version": "5.2.0", 725 | "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.2.0.tgz", 726 | "integrity": "sha512-uEUyaDKoSQ1M4Oq8l45hSE26SnTxL6snNnqvK/VWx5wJhmff5z0FUVJDKDanor/6w3kzE3i7XZOk+7wC0EXr1A==", 727 | "dev": true, 728 | "requires": { 729 | "is-obj": "^2.0.0" 730 | } 731 | }, 732 | "dtrace-provider": { 733 | "version": "0.8.7", 734 | "resolved": "https://registry.npmjs.org/dtrace-provider/-/dtrace-provider-0.8.7.tgz", 735 | "integrity": "sha1-3JObTT4GIM/gwc2APQ0tftBP/QQ=", 736 | "optional": true, 737 | "requires": { 738 | "nan": "^2.10.0" 739 | } 740 | }, 741 | "duplexer3": { 742 | "version": "0.1.4", 743 | "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.4.tgz", 744 | "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=", 745 | "dev": true 746 | }, 747 | "ee-first": { 748 | "version": "1.1.1", 749 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 750 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 751 | }, 752 | "emoji-regex": { 753 | "version": "7.0.3", 754 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 755 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 756 | "dev": true 757 | }, 758 | "encodeurl": { 759 | "version": "1.0.2", 760 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 761 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 762 | }, 763 | "end-of-stream": { 764 | "version": "1.4.4", 765 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 766 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 767 | "dev": true, 768 | "requires": { 769 | "once": "^1.4.0" 770 | } 771 | }, 772 | "error-ex": { 773 | "version": "1.3.2", 774 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 775 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 776 | "dev": true, 777 | "requires": { 778 | "is-arrayish": "^0.2.1" 779 | } 780 | }, 781 | "es-abstract": { 782 | "version": "1.13.0", 783 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 784 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 785 | "dev": true, 786 | "requires": { 787 | "es-to-primitive": "^1.2.0", 788 | "function-bind": "^1.1.1", 789 | "has": "^1.0.3", 790 | "is-callable": "^1.1.4", 791 | "is-regex": "^1.0.4", 792 | "object-keys": "^1.0.12" 793 | } 794 | }, 795 | "es-to-primitive": { 796 | "version": "1.2.0", 797 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 798 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 799 | "dev": true, 800 | "requires": { 801 | "is-callable": "^1.1.4", 802 | "is-date-object": "^1.0.1", 803 | "is-symbol": "^1.0.2" 804 | } 805 | }, 806 | "escape-goat": { 807 | "version": "2.1.1", 808 | "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", 809 | "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==", 810 | "dev": true 811 | }, 812 | "escape-html": { 813 | "version": "1.0.3", 814 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 815 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 816 | }, 817 | "escape-string-regexp": { 818 | "version": "1.0.5", 819 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 820 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 821 | "dev": true 822 | }, 823 | "eslint": { 824 | "version": "5.14.1", 825 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.14.1.tgz", 826 | "integrity": "sha512-CyUMbmsjxedx8B0mr79mNOqetvkbij/zrXnFeK2zc3pGRn3/tibjiNAv/3UxFEyfMDjh+ZqTrJrEGBFiGfD5Og==", 827 | "dev": true, 828 | "requires": { 829 | "@babel/code-frame": "^7.0.0", 830 | "ajv": "^6.9.1", 831 | "chalk": "^2.1.0", 832 | "cross-spawn": "^6.0.5", 833 | "debug": "^4.0.1", 834 | "doctrine": "^3.0.0", 835 | "eslint-scope": "^4.0.0", 836 | "eslint-utils": "^1.3.1", 837 | "eslint-visitor-keys": "^1.0.0", 838 | "espree": "^5.0.1", 839 | "esquery": "^1.0.1", 840 | "esutils": "^2.0.2", 841 | "file-entry-cache": "^5.0.1", 842 | "functional-red-black-tree": "^1.0.1", 843 | "glob": "^7.1.2", 844 | "globals": "^11.7.0", 845 | "ignore": "^4.0.6", 846 | "import-fresh": "^3.0.0", 847 | "imurmurhash": "^0.1.4", 848 | "inquirer": "^6.2.2", 849 | "js-yaml": "^3.12.0", 850 | "json-stable-stringify-without-jsonify": "^1.0.1", 851 | "levn": "^0.3.0", 852 | "lodash": "^4.17.11", 853 | "minimatch": "^3.0.4", 854 | "mkdirp": "^0.5.1", 855 | "natural-compare": "^1.4.0", 856 | "optionator": "^0.8.2", 857 | "path-is-inside": "^1.0.2", 858 | "progress": "^2.0.0", 859 | "regexpp": "^2.0.1", 860 | "semver": "^5.5.1", 861 | "strip-ansi": "^4.0.0", 862 | "strip-json-comments": "^2.0.1", 863 | "table": "^5.2.3", 864 | "text-table": "^0.2.0" 865 | }, 866 | "dependencies": { 867 | "debug": { 868 | "version": "4.1.1", 869 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 870 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 871 | "dev": true, 872 | "requires": { 873 | "ms": "^2.1.1" 874 | } 875 | }, 876 | "glob": { 877 | "version": "7.1.3", 878 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 879 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 880 | "dev": true, 881 | "requires": { 882 | "fs.realpath": "^1.0.0", 883 | "inflight": "^1.0.4", 884 | "inherits": "2", 885 | "minimatch": "^3.0.4", 886 | "once": "^1.3.0", 887 | "path-is-absolute": "^1.0.0" 888 | } 889 | }, 890 | "ms": { 891 | "version": "2.1.1", 892 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 893 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 894 | "dev": true 895 | } 896 | } 897 | }, 898 | "eslint-config-airbnb-base": { 899 | "version": "13.1.0", 900 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.1.0.tgz", 901 | "integrity": "sha512-XWwQtf3U3zIoKO1BbHh6aUhJZQweOwSt4c2JrPDg9FP3Ltv3+YfEv7jIDB8275tVnO/qOHbfuYg3kzw6Je7uWw==", 902 | "dev": true, 903 | "requires": { 904 | "eslint-restricted-globals": "^0.1.1", 905 | "object.assign": "^4.1.0", 906 | "object.entries": "^1.0.4" 907 | } 908 | }, 909 | "eslint-import-resolver-node": { 910 | "version": "0.3.2", 911 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 912 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 913 | "dev": true, 914 | "requires": { 915 | "debug": "^2.6.9", 916 | "resolve": "^1.5.0" 917 | } 918 | }, 919 | "eslint-module-utils": { 920 | "version": "2.3.0", 921 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.3.0.tgz", 922 | "integrity": "sha512-lmDJgeOOjk8hObTysjqH7wyMi+nsHwwvfBykwfhjR1LNdd7C2uFJBvx4OpWYpXOw4df1yE1cDEVd1yLHitk34w==", 923 | "dev": true, 924 | "requires": { 925 | "debug": "^2.6.8", 926 | "pkg-dir": "^2.0.0" 927 | } 928 | }, 929 | "eslint-plugin-import": { 930 | "version": "2.16.0", 931 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.16.0.tgz", 932 | "integrity": "sha512-z6oqWlf1x5GkHIFgrSvtmudnqM6Q60KM4KvpWi5ubonMjycLjndvd5+8VAZIsTlHC03djdgJuyKG6XO577px6A==", 933 | "dev": true, 934 | "requires": { 935 | "contains-path": "^0.1.0", 936 | "debug": "^2.6.9", 937 | "doctrine": "1.5.0", 938 | "eslint-import-resolver-node": "^0.3.2", 939 | "eslint-module-utils": "^2.3.0", 940 | "has": "^1.0.3", 941 | "lodash": "^4.17.11", 942 | "minimatch": "^3.0.4", 943 | "read-pkg-up": "^2.0.0", 944 | "resolve": "^1.9.0" 945 | }, 946 | "dependencies": { 947 | "doctrine": { 948 | "version": "1.5.0", 949 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 950 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 951 | "dev": true, 952 | "requires": { 953 | "esutils": "^2.0.2", 954 | "isarray": "^1.0.0" 955 | } 956 | } 957 | } 958 | }, 959 | "eslint-restricted-globals": { 960 | "version": "0.1.1", 961 | "resolved": "https://registry.npmjs.org/eslint-restricted-globals/-/eslint-restricted-globals-0.1.1.tgz", 962 | "integrity": "sha1-NfDVy8ZMLj7WLpO0saevBbp+1Nc=", 963 | "dev": true 964 | }, 965 | "eslint-scope": { 966 | "version": "4.0.0", 967 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz", 968 | "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==", 969 | "dev": true, 970 | "requires": { 971 | "esrecurse": "^4.1.0", 972 | "estraverse": "^4.1.1" 973 | } 974 | }, 975 | "eslint-utils": { 976 | "version": "1.4.3", 977 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 978 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 979 | "dev": true, 980 | "requires": { 981 | "eslint-visitor-keys": "^1.1.0" 982 | }, 983 | "dependencies": { 984 | "eslint-visitor-keys": { 985 | "version": "1.3.0", 986 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.3.0.tgz", 987 | "integrity": "sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==", 988 | "dev": true 989 | } 990 | } 991 | }, 992 | "eslint-visitor-keys": { 993 | "version": "1.0.0", 994 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 995 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 996 | "dev": true 997 | }, 998 | "espree": { 999 | "version": "5.0.1", 1000 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", 1001 | "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", 1002 | "dev": true, 1003 | "requires": { 1004 | "acorn": "^6.0.7", 1005 | "acorn-jsx": "^5.0.0", 1006 | "eslint-visitor-keys": "^1.0.0" 1007 | } 1008 | }, 1009 | "esprima": { 1010 | "version": "4.0.1", 1011 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1012 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1013 | "dev": true 1014 | }, 1015 | "esquery": { 1016 | "version": "1.0.1", 1017 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 1018 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 1019 | "dev": true, 1020 | "requires": { 1021 | "estraverse": "^4.0.0" 1022 | } 1023 | }, 1024 | "esrecurse": { 1025 | "version": "4.2.1", 1026 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 1027 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 1028 | "dev": true, 1029 | "requires": { 1030 | "estraverse": "^4.1.0" 1031 | } 1032 | }, 1033 | "estraverse": { 1034 | "version": "4.2.0", 1035 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 1036 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 1037 | "dev": true 1038 | }, 1039 | "esutils": { 1040 | "version": "2.0.2", 1041 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 1042 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 1043 | "dev": true 1044 | }, 1045 | "etag": { 1046 | "version": "1.8.1", 1047 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1048 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 1049 | }, 1050 | "express": { 1051 | "version": "4.16.4", 1052 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.4.tgz", 1053 | "integrity": "sha512-j12Uuyb4FMrd/qQAm6uCHAkPtO8FDTRJZBDd5D2KOL2eLaz1yUNdUB/NOIyq0iU4q4cFarsUCrnFDPBcnksuOg==", 1054 | "requires": { 1055 | "accepts": "~1.3.5", 1056 | "array-flatten": "1.1.1", 1057 | "body-parser": "1.18.3", 1058 | "content-disposition": "0.5.2", 1059 | "content-type": "~1.0.4", 1060 | "cookie": "0.3.1", 1061 | "cookie-signature": "1.0.6", 1062 | "debug": "2.6.9", 1063 | "depd": "~1.1.2", 1064 | "encodeurl": "~1.0.2", 1065 | "escape-html": "~1.0.3", 1066 | "etag": "~1.8.1", 1067 | "finalhandler": "1.1.1", 1068 | "fresh": "0.5.2", 1069 | "merge-descriptors": "1.0.1", 1070 | "methods": "~1.1.2", 1071 | "on-finished": "~2.3.0", 1072 | "parseurl": "~1.3.2", 1073 | "path-to-regexp": "0.1.7", 1074 | "proxy-addr": "~2.0.4", 1075 | "qs": "6.5.2", 1076 | "range-parser": "~1.2.0", 1077 | "safe-buffer": "5.1.2", 1078 | "send": "0.16.2", 1079 | "serve-static": "1.13.2", 1080 | "setprototypeof": "1.1.0", 1081 | "statuses": "~1.4.0", 1082 | "type-is": "~1.6.16", 1083 | "utils-merge": "1.0.1", 1084 | "vary": "~1.1.2" 1085 | } 1086 | }, 1087 | "extend": { 1088 | "version": "3.0.2", 1089 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 1090 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 1091 | "dev": true 1092 | }, 1093 | "external-editor": { 1094 | "version": "3.0.3", 1095 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 1096 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 1097 | "dev": true, 1098 | "requires": { 1099 | "chardet": "^0.7.0", 1100 | "iconv-lite": "^0.4.24", 1101 | "tmp": "^0.0.33" 1102 | }, 1103 | "dependencies": { 1104 | "iconv-lite": { 1105 | "version": "0.4.24", 1106 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1107 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1108 | "dev": true, 1109 | "requires": { 1110 | "safer-buffer": ">= 2.1.2 < 3" 1111 | } 1112 | } 1113 | } 1114 | }, 1115 | "fast-deep-equal": { 1116 | "version": "2.0.1", 1117 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 1118 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 1119 | "dev": true 1120 | }, 1121 | "fast-json-stable-stringify": { 1122 | "version": "2.0.0", 1123 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 1124 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 1125 | "dev": true 1126 | }, 1127 | "fast-levenshtein": { 1128 | "version": "2.0.6", 1129 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1130 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1131 | "dev": true 1132 | }, 1133 | "figures": { 1134 | "version": "2.0.0", 1135 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 1136 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 1137 | "dev": true, 1138 | "requires": { 1139 | "escape-string-regexp": "^1.0.5" 1140 | } 1141 | }, 1142 | "file-entry-cache": { 1143 | "version": "5.0.1", 1144 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 1145 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 1146 | "dev": true, 1147 | "requires": { 1148 | "flat-cache": "^2.0.1" 1149 | } 1150 | }, 1151 | "fill-range": { 1152 | "version": "7.0.1", 1153 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1154 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1155 | "dev": true, 1156 | "requires": { 1157 | "to-regex-range": "^5.0.1" 1158 | } 1159 | }, 1160 | "finalhandler": { 1161 | "version": "1.1.1", 1162 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz", 1163 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", 1164 | "requires": { 1165 | "debug": "2.6.9", 1166 | "encodeurl": "~1.0.2", 1167 | "escape-html": "~1.0.3", 1168 | "on-finished": "~2.3.0", 1169 | "parseurl": "~1.3.2", 1170 | "statuses": "~1.4.0", 1171 | "unpipe": "~1.0.0" 1172 | } 1173 | }, 1174 | "find-up": { 1175 | "version": "2.1.0", 1176 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1177 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1178 | "dev": true, 1179 | "requires": { 1180 | "locate-path": "^2.0.0" 1181 | } 1182 | }, 1183 | "flat-cache": { 1184 | "version": "2.0.1", 1185 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 1186 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 1187 | "dev": true, 1188 | "requires": { 1189 | "flatted": "^2.0.0", 1190 | "rimraf": "2.6.3", 1191 | "write": "1.0.3" 1192 | }, 1193 | "dependencies": { 1194 | "glob": { 1195 | "version": "7.1.3", 1196 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1197 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1198 | "dev": true, 1199 | "requires": { 1200 | "fs.realpath": "^1.0.0", 1201 | "inflight": "^1.0.4", 1202 | "inherits": "2", 1203 | "minimatch": "^3.0.4", 1204 | "once": "^1.3.0", 1205 | "path-is-absolute": "^1.0.0" 1206 | } 1207 | }, 1208 | "rimraf": { 1209 | "version": "2.6.3", 1210 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1211 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1212 | "dev": true, 1213 | "requires": { 1214 | "glob": "^7.1.3" 1215 | } 1216 | } 1217 | } 1218 | }, 1219 | "flatted": { 1220 | "version": "2.0.0", 1221 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", 1222 | "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==", 1223 | "dev": true 1224 | }, 1225 | "follow-redirects": { 1226 | "version": "1.5.10", 1227 | "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.5.10.tgz", 1228 | "integrity": "sha512-0V5l4Cizzvqt5D44aTXbFZz+FtyXV1vrDN6qrelxtfYQKW0KO0W2T/hkE8xvGa/540LkZlkaUjO4ailYTFtHVQ==", 1229 | "requires": { 1230 | "debug": "=3.1.0" 1231 | }, 1232 | "dependencies": { 1233 | "debug": { 1234 | "version": "3.1.0", 1235 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1236 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1237 | "requires": { 1238 | "ms": "2.0.0" 1239 | } 1240 | } 1241 | } 1242 | }, 1243 | "form-data": { 1244 | "version": "2.3.3", 1245 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 1246 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 1247 | "dev": true, 1248 | "requires": { 1249 | "asynckit": "^0.4.0", 1250 | "combined-stream": "^1.0.6", 1251 | "mime-types": "^2.1.12" 1252 | } 1253 | }, 1254 | "formidable": { 1255 | "version": "1.2.1", 1256 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.2.1.tgz", 1257 | "integrity": "sha512-Fs9VRguL0gqGHkXS5GQiMCr1VhZBxz0JnJs4JmMp/2jL18Fmbzvv7vOFRU+U8TBkHEE/CX1qDXzJplVULgsLeg==", 1258 | "dev": true 1259 | }, 1260 | "forwarded": { 1261 | "version": "0.1.2", 1262 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 1263 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" 1264 | }, 1265 | "fresh": { 1266 | "version": "0.5.2", 1267 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1268 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 1269 | }, 1270 | "fs.realpath": { 1271 | "version": "1.0.0", 1272 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1273 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1274 | "dev": true 1275 | }, 1276 | "fsevents": { 1277 | "version": "2.1.3", 1278 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 1279 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 1280 | "dev": true, 1281 | "optional": true 1282 | }, 1283 | "function-bind": { 1284 | "version": "1.1.1", 1285 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1286 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1287 | "dev": true 1288 | }, 1289 | "functional-red-black-tree": { 1290 | "version": "1.0.1", 1291 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1292 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1293 | "dev": true 1294 | }, 1295 | "get-func-name": { 1296 | "version": "2.0.0", 1297 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 1298 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 1299 | "dev": true 1300 | }, 1301 | "get-stream": { 1302 | "version": "4.1.0", 1303 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 1304 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 1305 | "dev": true, 1306 | "requires": { 1307 | "pump": "^3.0.0" 1308 | } 1309 | }, 1310 | "glob": { 1311 | "version": "6.0.4", 1312 | "resolved": "https://registry.npmjs.org/glob/-/glob-6.0.4.tgz", 1313 | "integrity": "sha1-DwiGD2oVUSey+t1PnOJLGqtuTSI=", 1314 | "optional": true, 1315 | "requires": { 1316 | "inflight": "^1.0.4", 1317 | "inherits": "2", 1318 | "minimatch": "2 || 3", 1319 | "once": "^1.3.0", 1320 | "path-is-absolute": "^1.0.0" 1321 | } 1322 | }, 1323 | "glob-parent": { 1324 | "version": "5.1.1", 1325 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 1326 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 1327 | "dev": true, 1328 | "requires": { 1329 | "is-glob": "^4.0.1" 1330 | } 1331 | }, 1332 | "global-dirs": { 1333 | "version": "2.0.1", 1334 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.0.1.tgz", 1335 | "integrity": "sha512-5HqUqdhkEovj2Of/ms3IeS/EekcO54ytHRLV4PEY2rhRwrHXLQjeVEES0Lhka0xwNDtGYn58wyC4s5+MHsOO6A==", 1336 | "dev": true, 1337 | "requires": { 1338 | "ini": "^1.3.5" 1339 | } 1340 | }, 1341 | "globals": { 1342 | "version": "11.11.0", 1343 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.11.0.tgz", 1344 | "integrity": "sha512-WHq43gS+6ufNOEqlrDBxVEbb8ntfXrfAUU2ZOpCxrBdGKW3gyv8mCxAfIBD0DroPKGrJ2eSsXsLtY9MPntsyTw==", 1345 | "dev": true 1346 | }, 1347 | "got": { 1348 | "version": "9.6.0", 1349 | "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", 1350 | "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", 1351 | "dev": true, 1352 | "requires": { 1353 | "@sindresorhus/is": "^0.14.0", 1354 | "@szmarczak/http-timer": "^1.1.2", 1355 | "cacheable-request": "^6.0.0", 1356 | "decompress-response": "^3.3.0", 1357 | "duplexer3": "^0.1.4", 1358 | "get-stream": "^4.1.0", 1359 | "lowercase-keys": "^1.0.1", 1360 | "mimic-response": "^1.0.1", 1361 | "p-cancelable": "^1.0.0", 1362 | "to-readable-stream": "^1.0.0", 1363 | "url-parse-lax": "^3.0.0" 1364 | } 1365 | }, 1366 | "graceful-fs": { 1367 | "version": "4.1.15", 1368 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 1369 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 1370 | "dev": true 1371 | }, 1372 | "has": { 1373 | "version": "1.0.3", 1374 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1375 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1376 | "dev": true, 1377 | "requires": { 1378 | "function-bind": "^1.1.1" 1379 | } 1380 | }, 1381 | "has-flag": { 1382 | "version": "3.0.0", 1383 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1384 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1385 | "dev": true 1386 | }, 1387 | "has-symbols": { 1388 | "version": "1.0.0", 1389 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 1390 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 1391 | "dev": true 1392 | }, 1393 | "has-yarn": { 1394 | "version": "2.1.0", 1395 | "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", 1396 | "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==", 1397 | "dev": true 1398 | }, 1399 | "hosted-git-info": { 1400 | "version": "2.7.1", 1401 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 1402 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 1403 | "dev": true 1404 | }, 1405 | "http-cache-semantics": { 1406 | "version": "4.1.0", 1407 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 1408 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==", 1409 | "dev": true 1410 | }, 1411 | "http-errors": { 1412 | "version": "1.6.3", 1413 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 1414 | "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", 1415 | "requires": { 1416 | "depd": "~1.1.2", 1417 | "inherits": "2.0.3", 1418 | "setprototypeof": "1.1.0", 1419 | "statuses": ">= 1.4.0 < 2" 1420 | } 1421 | }, 1422 | "iconv-lite": { 1423 | "version": "0.4.23", 1424 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 1425 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 1426 | "requires": { 1427 | "safer-buffer": ">= 2.1.2 < 3" 1428 | } 1429 | }, 1430 | "ignore": { 1431 | "version": "4.0.6", 1432 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1433 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1434 | "dev": true 1435 | }, 1436 | "ignore-by-default": { 1437 | "version": "1.0.1", 1438 | "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", 1439 | "integrity": "sha1-SMptcvbGo68Aqa1K5odr44ieKwk=", 1440 | "dev": true 1441 | }, 1442 | "import-fresh": { 1443 | "version": "3.0.0", 1444 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", 1445 | "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", 1446 | "dev": true, 1447 | "requires": { 1448 | "parent-module": "^1.0.0", 1449 | "resolve-from": "^4.0.0" 1450 | } 1451 | }, 1452 | "import-lazy": { 1453 | "version": "2.1.0", 1454 | "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", 1455 | "integrity": "sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM=", 1456 | "dev": true 1457 | }, 1458 | "imurmurhash": { 1459 | "version": "0.1.4", 1460 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1461 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1462 | "dev": true 1463 | }, 1464 | "inflight": { 1465 | "version": "1.0.6", 1466 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1467 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1468 | "requires": { 1469 | "once": "^1.3.0", 1470 | "wrappy": "1" 1471 | } 1472 | }, 1473 | "inherits": { 1474 | "version": "2.0.3", 1475 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1476 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1477 | }, 1478 | "ini": { 1479 | "version": "1.3.5", 1480 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 1481 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 1482 | "dev": true 1483 | }, 1484 | "inquirer": { 1485 | "version": "6.2.2", 1486 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.2.tgz", 1487 | "integrity": "sha512-Z2rREiXA6cHRR9KBOarR3WuLlFzlIfAEIiB45ll5SSadMg7WqOh1MKEjjndfuH5ewXdixWCxqnVfGOQzPeiztA==", 1488 | "dev": true, 1489 | "requires": { 1490 | "ansi-escapes": "^3.2.0", 1491 | "chalk": "^2.4.2", 1492 | "cli-cursor": "^2.1.0", 1493 | "cli-width": "^2.0.0", 1494 | "external-editor": "^3.0.3", 1495 | "figures": "^2.0.0", 1496 | "lodash": "^4.17.11", 1497 | "mute-stream": "0.0.7", 1498 | "run-async": "^2.2.0", 1499 | "rxjs": "^6.4.0", 1500 | "string-width": "^2.1.0", 1501 | "strip-ansi": "^5.0.0", 1502 | "through": "^2.3.6" 1503 | }, 1504 | "dependencies": { 1505 | "ansi-regex": { 1506 | "version": "4.0.0", 1507 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz", 1508 | "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==", 1509 | "dev": true 1510 | }, 1511 | "strip-ansi": { 1512 | "version": "5.0.0", 1513 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz", 1514 | "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==", 1515 | "dev": true, 1516 | "requires": { 1517 | "ansi-regex": "^4.0.0" 1518 | } 1519 | } 1520 | } 1521 | }, 1522 | "ip-regex": { 1523 | "version": "2.1.0", 1524 | "resolved": "https://registry.npmjs.org/ip-regex/-/ip-regex-2.1.0.tgz", 1525 | "integrity": "sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=", 1526 | "dev": true 1527 | }, 1528 | "ipaddr.js": { 1529 | "version": "1.8.0", 1530 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.8.0.tgz", 1531 | "integrity": "sha1-6qM9bd16zo9/b+DJygRA5wZzix4=" 1532 | }, 1533 | "is-arrayish": { 1534 | "version": "0.2.1", 1535 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1536 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1537 | "dev": true 1538 | }, 1539 | "is-binary-path": { 1540 | "version": "2.1.0", 1541 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1542 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1543 | "dev": true, 1544 | "requires": { 1545 | "binary-extensions": "^2.0.0" 1546 | } 1547 | }, 1548 | "is-callable": { 1549 | "version": "1.1.4", 1550 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1551 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 1552 | "dev": true 1553 | }, 1554 | "is-ci": { 1555 | "version": "2.0.0", 1556 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", 1557 | "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", 1558 | "dev": true, 1559 | "requires": { 1560 | "ci-info": "^2.0.0" 1561 | } 1562 | }, 1563 | "is-date-object": { 1564 | "version": "1.0.1", 1565 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1566 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1567 | "dev": true 1568 | }, 1569 | "is-extglob": { 1570 | "version": "2.1.1", 1571 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1572 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1573 | "dev": true 1574 | }, 1575 | "is-fullwidth-code-point": { 1576 | "version": "2.0.0", 1577 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1578 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1579 | "dev": true 1580 | }, 1581 | "is-glob": { 1582 | "version": "4.0.1", 1583 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1584 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1585 | "dev": true, 1586 | "requires": { 1587 | "is-extglob": "^2.1.1" 1588 | } 1589 | }, 1590 | "is-installed-globally": { 1591 | "version": "0.3.2", 1592 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.2.tgz", 1593 | "integrity": "sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g==", 1594 | "dev": true, 1595 | "requires": { 1596 | "global-dirs": "^2.0.1", 1597 | "is-path-inside": "^3.0.1" 1598 | } 1599 | }, 1600 | "is-ip": { 1601 | "version": "2.0.0", 1602 | "resolved": "https://registry.npmjs.org/is-ip/-/is-ip-2.0.0.tgz", 1603 | "integrity": "sha1-aO6gfooKCpTC0IDdZ0xzGrKkYas=", 1604 | "dev": true, 1605 | "requires": { 1606 | "ip-regex": "^2.0.0" 1607 | } 1608 | }, 1609 | "is-npm": { 1610 | "version": "4.0.0", 1611 | "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz", 1612 | "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==", 1613 | "dev": true 1614 | }, 1615 | "is-number": { 1616 | "version": "7.0.0", 1617 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1618 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1619 | "dev": true 1620 | }, 1621 | "is-obj": { 1622 | "version": "2.0.0", 1623 | "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", 1624 | "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", 1625 | "dev": true 1626 | }, 1627 | "is-path-inside": { 1628 | "version": "3.0.2", 1629 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.2.tgz", 1630 | "integrity": "sha512-/2UGPSgmtqwo1ktx8NDHjuPwZWmHhO+gj0f93EkhLB5RgW9RZevWYYlIkS6zePc6U2WpOdQYIwHe9YC4DWEBVg==", 1631 | "dev": true 1632 | }, 1633 | "is-promise": { 1634 | "version": "2.1.0", 1635 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1636 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1637 | "dev": true 1638 | }, 1639 | "is-regex": { 1640 | "version": "1.0.4", 1641 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1642 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1643 | "dev": true, 1644 | "requires": { 1645 | "has": "^1.0.1" 1646 | } 1647 | }, 1648 | "is-symbol": { 1649 | "version": "1.0.2", 1650 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1651 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1652 | "dev": true, 1653 | "requires": { 1654 | "has-symbols": "^1.0.0" 1655 | } 1656 | }, 1657 | "is-typedarray": { 1658 | "version": "1.0.0", 1659 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1660 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1661 | "dev": true 1662 | }, 1663 | "is-yarn-global": { 1664 | "version": "0.3.0", 1665 | "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", 1666 | "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==", 1667 | "dev": true 1668 | }, 1669 | "isarray": { 1670 | "version": "1.0.0", 1671 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1672 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1673 | "dev": true 1674 | }, 1675 | "isexe": { 1676 | "version": "2.0.0", 1677 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1678 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1679 | "dev": true 1680 | }, 1681 | "js-tokens": { 1682 | "version": "4.0.0", 1683 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1684 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1685 | "dev": true 1686 | }, 1687 | "js-yaml": { 1688 | "version": "3.13.1", 1689 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1690 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1691 | "dev": true, 1692 | "requires": { 1693 | "argparse": "^1.0.7", 1694 | "esprima": "^4.0.0" 1695 | } 1696 | }, 1697 | "json-buffer": { 1698 | "version": "3.0.0", 1699 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", 1700 | "integrity": "sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg=", 1701 | "dev": true 1702 | }, 1703 | "json-schema-traverse": { 1704 | "version": "0.4.1", 1705 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1706 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1707 | "dev": true 1708 | }, 1709 | "json-stable-stringify-without-jsonify": { 1710 | "version": "1.0.1", 1711 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1712 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1713 | "dev": true 1714 | }, 1715 | "keyv": { 1716 | "version": "3.1.0", 1717 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", 1718 | "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", 1719 | "dev": true, 1720 | "requires": { 1721 | "json-buffer": "3.0.0" 1722 | } 1723 | }, 1724 | "latest-version": { 1725 | "version": "5.1.0", 1726 | "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", 1727 | "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", 1728 | "dev": true, 1729 | "requires": { 1730 | "package-json": "^6.3.0" 1731 | } 1732 | }, 1733 | "levn": { 1734 | "version": "0.3.0", 1735 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1736 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1737 | "dev": true, 1738 | "requires": { 1739 | "prelude-ls": "~1.1.2", 1740 | "type-check": "~0.3.2" 1741 | } 1742 | }, 1743 | "load-json-file": { 1744 | "version": "2.0.0", 1745 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1746 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1747 | "dev": true, 1748 | "requires": { 1749 | "graceful-fs": "^4.1.2", 1750 | "parse-json": "^2.2.0", 1751 | "pify": "^2.0.0", 1752 | "strip-bom": "^3.0.0" 1753 | } 1754 | }, 1755 | "locate-path": { 1756 | "version": "2.0.0", 1757 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1758 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1759 | "dev": true, 1760 | "requires": { 1761 | "p-locate": "^2.0.0", 1762 | "path-exists": "^3.0.0" 1763 | } 1764 | }, 1765 | "lodash": { 1766 | "version": "4.17.19", 1767 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz", 1768 | "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==", 1769 | "dev": true 1770 | }, 1771 | "lowercase-keys": { 1772 | "version": "1.0.1", 1773 | "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", 1774 | "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", 1775 | "dev": true 1776 | }, 1777 | "make-dir": { 1778 | "version": "3.1.0", 1779 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 1780 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 1781 | "dev": true, 1782 | "requires": { 1783 | "semver": "^6.0.0" 1784 | }, 1785 | "dependencies": { 1786 | "semver": { 1787 | "version": "6.3.0", 1788 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 1789 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 1790 | "dev": true 1791 | } 1792 | } 1793 | }, 1794 | "media-typer": { 1795 | "version": "0.3.0", 1796 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1797 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1798 | }, 1799 | "merge-descriptors": { 1800 | "version": "1.0.1", 1801 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1802 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1803 | }, 1804 | "methods": { 1805 | "version": "1.1.2", 1806 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1807 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1808 | }, 1809 | "mime": { 1810 | "version": "1.4.1", 1811 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 1812 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==" 1813 | }, 1814 | "mime-db": { 1815 | "version": "1.38.0", 1816 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.38.0.tgz", 1817 | "integrity": "sha512-bqVioMFFzc2awcdJZIzR3HjZFX20QhilVS7hytkKrv7xFAn8bM1gzc/FOX2awLISvWe0PV8ptFKcon+wZ5qYkg==" 1818 | }, 1819 | "mime-types": { 1820 | "version": "2.1.22", 1821 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.22.tgz", 1822 | "integrity": "sha512-aGl6TZGnhm/li6F7yx82bJiBZwgiEa4Hf6CNr8YO+r5UHr53tSTYZb102zyU50DOWWKeOv0uQLRL0/9EiKWCog==", 1823 | "requires": { 1824 | "mime-db": "~1.38.0" 1825 | } 1826 | }, 1827 | "mimic-fn": { 1828 | "version": "1.2.0", 1829 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1830 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1831 | "dev": true 1832 | }, 1833 | "mimic-response": { 1834 | "version": "1.0.1", 1835 | "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", 1836 | "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", 1837 | "dev": true 1838 | }, 1839 | "minimatch": { 1840 | "version": "3.0.4", 1841 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1842 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1843 | "requires": { 1844 | "brace-expansion": "^1.1.7" 1845 | } 1846 | }, 1847 | "minimist": { 1848 | "version": "1.2.5", 1849 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1850 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1851 | }, 1852 | "mkdirp": { 1853 | "version": "0.5.5", 1854 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1855 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1856 | "requires": { 1857 | "minimist": "^1.2.5" 1858 | } 1859 | }, 1860 | "moment": { 1861 | "version": "2.24.0", 1862 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.24.0.tgz", 1863 | "integrity": "sha512-bV7f+6l2QigeBBZSM/6yTNq4P2fNpSWj/0e7jQcy87A8e7o2nAfP/34/2ky5Vw4B9S446EtIhodAzkFCcR4dQg==", 1864 | "optional": true 1865 | }, 1866 | "ms": { 1867 | "version": "2.0.0", 1868 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1869 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1870 | }, 1871 | "mute-stream": { 1872 | "version": "0.0.7", 1873 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1874 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1875 | "dev": true 1876 | }, 1877 | "mv": { 1878 | "version": "2.1.1", 1879 | "resolved": "https://registry.npmjs.org/mv/-/mv-2.1.1.tgz", 1880 | "integrity": "sha1-rmzg1vbV4KT32JN5jQPB6pVZtqI=", 1881 | "optional": true, 1882 | "requires": { 1883 | "mkdirp": "~0.5.1", 1884 | "ncp": "~2.0.0", 1885 | "rimraf": "~2.4.0" 1886 | } 1887 | }, 1888 | "nan": { 1889 | "version": "2.12.1", 1890 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.12.1.tgz", 1891 | "integrity": "sha512-JY7V6lRkStKcKTvHO5NVSQRv+RV+FIL5pvDoLiAtSL9pKlC5x9PKQcZDsq7m4FO4d57mkhC6Z+QhAh3Jdk5JFw==", 1892 | "optional": true 1893 | }, 1894 | "natural-compare": { 1895 | "version": "1.4.0", 1896 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1897 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1898 | "dev": true 1899 | }, 1900 | "ncp": { 1901 | "version": "2.0.0", 1902 | "resolved": "https://registry.npmjs.org/ncp/-/ncp-2.0.0.tgz", 1903 | "integrity": "sha1-GVoh1sRuNh0vsSgbo4uR6d9727M=", 1904 | "optional": true 1905 | }, 1906 | "negotiator": { 1907 | "version": "0.6.1", 1908 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", 1909 | "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=" 1910 | }, 1911 | "nice-try": { 1912 | "version": "1.0.5", 1913 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1914 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1915 | "dev": true 1916 | }, 1917 | "nodemon": { 1918 | "version": "2.0.4", 1919 | "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-2.0.4.tgz", 1920 | "integrity": "sha512-Ltced+hIfTmaS28Zjv1BM552oQ3dbwPqI4+zI0SLgq+wpJhSyqgYude/aZa/3i31VCQWMfXJVxvu86abcam3uQ==", 1921 | "dev": true, 1922 | "requires": { 1923 | "chokidar": "^3.2.2", 1924 | "debug": "^3.2.6", 1925 | "ignore-by-default": "^1.0.1", 1926 | "minimatch": "^3.0.4", 1927 | "pstree.remy": "^1.1.7", 1928 | "semver": "^5.7.1", 1929 | "supports-color": "^5.5.0", 1930 | "touch": "^3.1.0", 1931 | "undefsafe": "^2.0.2", 1932 | "update-notifier": "^4.0.0" 1933 | }, 1934 | "dependencies": { 1935 | "debug": { 1936 | "version": "3.2.6", 1937 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 1938 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 1939 | "dev": true, 1940 | "requires": { 1941 | "ms": "^2.1.1" 1942 | } 1943 | }, 1944 | "ms": { 1945 | "version": "2.1.2", 1946 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1947 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1948 | "dev": true 1949 | }, 1950 | "semver": { 1951 | "version": "5.7.1", 1952 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1953 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1954 | "dev": true 1955 | } 1956 | } 1957 | }, 1958 | "nopt": { 1959 | "version": "1.0.10", 1960 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", 1961 | "integrity": "sha1-bd0hvSoxQXuScn3Vhfim83YI6+4=", 1962 | "dev": true, 1963 | "requires": { 1964 | "abbrev": "1" 1965 | } 1966 | }, 1967 | "normalize-package-data": { 1968 | "version": "2.5.0", 1969 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1970 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1971 | "dev": true, 1972 | "requires": { 1973 | "hosted-git-info": "^2.1.4", 1974 | "resolve": "^1.10.0", 1975 | "semver": "2 || 3 || 4 || 5", 1976 | "validate-npm-package-license": "^3.0.1" 1977 | } 1978 | }, 1979 | "normalize-path": { 1980 | "version": "3.0.0", 1981 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1982 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1983 | "dev": true 1984 | }, 1985 | "normalize-url": { 1986 | "version": "4.5.0", 1987 | "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.0.tgz", 1988 | "integrity": "sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ==", 1989 | "dev": true 1990 | }, 1991 | "object-keys": { 1992 | "version": "1.1.0", 1993 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.0.tgz", 1994 | "integrity": "sha512-6OO5X1+2tYkNyNEx6TsCxEqFfRWaqx6EtMiSbGrw8Ob8v9Ne+Hl8rBAgLBZn5wjEz3s/s6U1WXFUFOcxxAwUpg==", 1995 | "dev": true 1996 | }, 1997 | "object.assign": { 1998 | "version": "4.1.0", 1999 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 2000 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 2001 | "dev": true, 2002 | "requires": { 2003 | "define-properties": "^1.1.2", 2004 | "function-bind": "^1.1.1", 2005 | "has-symbols": "^1.0.0", 2006 | "object-keys": "^1.0.11" 2007 | } 2008 | }, 2009 | "object.entries": { 2010 | "version": "1.1.0", 2011 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", 2012 | "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", 2013 | "dev": true, 2014 | "requires": { 2015 | "define-properties": "^1.1.3", 2016 | "es-abstract": "^1.12.0", 2017 | "function-bind": "^1.1.1", 2018 | "has": "^1.0.3" 2019 | } 2020 | }, 2021 | "on-finished": { 2022 | "version": "2.3.0", 2023 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2024 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2025 | "requires": { 2026 | "ee-first": "1.1.1" 2027 | } 2028 | }, 2029 | "once": { 2030 | "version": "1.4.0", 2031 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2032 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2033 | "requires": { 2034 | "wrappy": "1" 2035 | } 2036 | }, 2037 | "onetime": { 2038 | "version": "2.0.1", 2039 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 2040 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 2041 | "dev": true, 2042 | "requires": { 2043 | "mimic-fn": "^1.0.0" 2044 | } 2045 | }, 2046 | "optionator": { 2047 | "version": "0.8.2", 2048 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 2049 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 2050 | "dev": true, 2051 | "requires": { 2052 | "deep-is": "~0.1.3", 2053 | "fast-levenshtein": "~2.0.4", 2054 | "levn": "~0.3.0", 2055 | "prelude-ls": "~1.1.2", 2056 | "type-check": "~0.3.2", 2057 | "wordwrap": "~1.0.0" 2058 | } 2059 | }, 2060 | "os-tmpdir": { 2061 | "version": "1.0.2", 2062 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2063 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 2064 | "dev": true 2065 | }, 2066 | "p-cancelable": { 2067 | "version": "1.1.0", 2068 | "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", 2069 | "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==", 2070 | "dev": true 2071 | }, 2072 | "p-limit": { 2073 | "version": "1.3.0", 2074 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 2075 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 2076 | "dev": true, 2077 | "requires": { 2078 | "p-try": "^1.0.0" 2079 | } 2080 | }, 2081 | "p-locate": { 2082 | "version": "2.0.0", 2083 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 2084 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 2085 | "dev": true, 2086 | "requires": { 2087 | "p-limit": "^1.1.0" 2088 | } 2089 | }, 2090 | "p-try": { 2091 | "version": "1.0.0", 2092 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 2093 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 2094 | "dev": true 2095 | }, 2096 | "package-json": { 2097 | "version": "6.5.0", 2098 | "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", 2099 | "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", 2100 | "dev": true, 2101 | "requires": { 2102 | "got": "^9.6.0", 2103 | "registry-auth-token": "^4.0.0", 2104 | "registry-url": "^5.0.0", 2105 | "semver": "^6.2.0" 2106 | }, 2107 | "dependencies": { 2108 | "semver": { 2109 | "version": "6.3.0", 2110 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2111 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2112 | "dev": true 2113 | } 2114 | } 2115 | }, 2116 | "parent-module": { 2117 | "version": "1.0.0", 2118 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.0.tgz", 2119 | "integrity": "sha512-8Mf5juOMmiE4FcmzYc4IaiS9L3+9paz2KOiXzkRviCP6aDmN49Hz6EMWz0lGNp9pX80GvvAuLADtyGfW/Em3TA==", 2120 | "dev": true, 2121 | "requires": { 2122 | "callsites": "^3.0.0" 2123 | } 2124 | }, 2125 | "parse-json": { 2126 | "version": "2.2.0", 2127 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 2128 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 2129 | "dev": true, 2130 | "requires": { 2131 | "error-ex": "^1.2.0" 2132 | } 2133 | }, 2134 | "parseurl": { 2135 | "version": "1.3.2", 2136 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", 2137 | "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=" 2138 | }, 2139 | "path-exists": { 2140 | "version": "3.0.0", 2141 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2142 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2143 | "dev": true 2144 | }, 2145 | "path-is-absolute": { 2146 | "version": "1.0.1", 2147 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2148 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 2149 | }, 2150 | "path-is-inside": { 2151 | "version": "1.0.2", 2152 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 2153 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 2154 | "dev": true 2155 | }, 2156 | "path-key": { 2157 | "version": "2.0.1", 2158 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2159 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2160 | "dev": true 2161 | }, 2162 | "path-parse": { 2163 | "version": "1.0.6", 2164 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2165 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 2166 | "dev": true 2167 | }, 2168 | "path-to-regexp": { 2169 | "version": "0.1.7", 2170 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2171 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2172 | }, 2173 | "path-type": { 2174 | "version": "2.0.0", 2175 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 2176 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 2177 | "dev": true, 2178 | "requires": { 2179 | "pify": "^2.0.0" 2180 | } 2181 | }, 2182 | "pathval": { 2183 | "version": "1.1.0", 2184 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz", 2185 | "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=", 2186 | "dev": true 2187 | }, 2188 | "picomatch": { 2189 | "version": "2.2.2", 2190 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 2191 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 2192 | "dev": true 2193 | }, 2194 | "pify": { 2195 | "version": "2.3.0", 2196 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 2197 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 2198 | "dev": true 2199 | }, 2200 | "pkg-dir": { 2201 | "version": "2.0.0", 2202 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 2203 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 2204 | "dev": true, 2205 | "requires": { 2206 | "find-up": "^2.1.0" 2207 | } 2208 | }, 2209 | "prelude-ls": { 2210 | "version": "1.1.2", 2211 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2212 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2213 | "dev": true 2214 | }, 2215 | "prepend-http": { 2216 | "version": "2.0.0", 2217 | "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", 2218 | "integrity": "sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=", 2219 | "dev": true 2220 | }, 2221 | "process-nextick-args": { 2222 | "version": "2.0.0", 2223 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 2224 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 2225 | "dev": true 2226 | }, 2227 | "progress": { 2228 | "version": "2.0.3", 2229 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2230 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2231 | "dev": true 2232 | }, 2233 | "proxy-addr": { 2234 | "version": "2.0.4", 2235 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.4.tgz", 2236 | "integrity": "sha512-5erio2h9jp5CHGwcybmxmVqHmnCBZeewlfJ0pex+UW7Qny7OOZXTtH56TGNyBizkgiOwhJtMKrVzDTeKcySZwA==", 2237 | "requires": { 2238 | "forwarded": "~0.1.2", 2239 | "ipaddr.js": "1.8.0" 2240 | } 2241 | }, 2242 | "pstree.remy": { 2243 | "version": "1.1.8", 2244 | "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", 2245 | "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==", 2246 | "dev": true 2247 | }, 2248 | "pump": { 2249 | "version": "3.0.0", 2250 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 2251 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 2252 | "dev": true, 2253 | "requires": { 2254 | "end-of-stream": "^1.1.0", 2255 | "once": "^1.3.1" 2256 | } 2257 | }, 2258 | "punycode": { 2259 | "version": "2.1.1", 2260 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2261 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2262 | "dev": true 2263 | }, 2264 | "pupa": { 2265 | "version": "2.0.1", 2266 | "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.0.1.tgz", 2267 | "integrity": "sha512-hEJH0s8PXLY/cdXh66tNEQGndDrIKNqNC5xmrysZy3i5C3oEoLna7YAOad+7u125+zH1HNXUmGEkrhb3c2VriA==", 2268 | "dev": true, 2269 | "requires": { 2270 | "escape-goat": "^2.0.0" 2271 | } 2272 | }, 2273 | "qs": { 2274 | "version": "6.5.2", 2275 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 2276 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" 2277 | }, 2278 | "range-parser": { 2279 | "version": "1.2.0", 2280 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", 2281 | "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=" 2282 | }, 2283 | "raw-body": { 2284 | "version": "2.3.3", 2285 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", 2286 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", 2287 | "requires": { 2288 | "bytes": "3.0.0", 2289 | "http-errors": "1.6.3", 2290 | "iconv-lite": "0.4.23", 2291 | "unpipe": "1.0.0" 2292 | } 2293 | }, 2294 | "rc": { 2295 | "version": "1.2.8", 2296 | "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", 2297 | "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", 2298 | "dev": true, 2299 | "requires": { 2300 | "deep-extend": "^0.6.0", 2301 | "ini": "~1.3.0", 2302 | "minimist": "^1.2.0", 2303 | "strip-json-comments": "~2.0.1" 2304 | } 2305 | }, 2306 | "read-pkg": { 2307 | "version": "2.0.0", 2308 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 2309 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 2310 | "dev": true, 2311 | "requires": { 2312 | "load-json-file": "^2.0.0", 2313 | "normalize-package-data": "^2.3.2", 2314 | "path-type": "^2.0.0" 2315 | } 2316 | }, 2317 | "read-pkg-up": { 2318 | "version": "2.0.0", 2319 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 2320 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 2321 | "dev": true, 2322 | "requires": { 2323 | "find-up": "^2.0.0", 2324 | "read-pkg": "^2.0.0" 2325 | } 2326 | }, 2327 | "readable-stream": { 2328 | "version": "2.3.6", 2329 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2330 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2331 | "dev": true, 2332 | "requires": { 2333 | "core-util-is": "~1.0.0", 2334 | "inherits": "~2.0.3", 2335 | "isarray": "~1.0.0", 2336 | "process-nextick-args": "~2.0.0", 2337 | "safe-buffer": "~5.1.1", 2338 | "string_decoder": "~1.1.1", 2339 | "util-deprecate": "~1.0.1" 2340 | } 2341 | }, 2342 | "readdirp": { 2343 | "version": "3.4.0", 2344 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.4.0.tgz", 2345 | "integrity": "sha512-0xe001vZBnJEK+uKcj8qOhyAKPzIT+gStxWr3LCB0DwcXR5NZJ3IaC+yGnHCYzB/S7ov3m3EEbZI2zeNvX+hGQ==", 2346 | "dev": true, 2347 | "requires": { 2348 | "picomatch": "^2.2.1" 2349 | } 2350 | }, 2351 | "regexpp": { 2352 | "version": "2.0.1", 2353 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 2354 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 2355 | "dev": true 2356 | }, 2357 | "registry-auth-token": { 2358 | "version": "4.2.0", 2359 | "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.0.tgz", 2360 | "integrity": "sha512-P+lWzPrsgfN+UEpDS3U8AQKg/UjZX6mQSJueZj3EK+vNESoqBSpBUD3gmu4sF9lOsjXWjF11dQKUqemf3veq1w==", 2361 | "dev": true, 2362 | "requires": { 2363 | "rc": "^1.2.8" 2364 | } 2365 | }, 2366 | "registry-url": { 2367 | "version": "5.1.0", 2368 | "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", 2369 | "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", 2370 | "dev": true, 2371 | "requires": { 2372 | "rc": "^1.2.8" 2373 | } 2374 | }, 2375 | "resolve": { 2376 | "version": "1.10.0", 2377 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz", 2378 | "integrity": "sha512-3sUr9aq5OfSg2S9pNtPA9hL1FVEAjvfOC4leW0SNf/mpnaakz2a9femSd6LqAww2RaFctwyf1lCqnTHuF1rxDg==", 2379 | "dev": true, 2380 | "requires": { 2381 | "path-parse": "^1.0.6" 2382 | } 2383 | }, 2384 | "resolve-from": { 2385 | "version": "4.0.0", 2386 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2387 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2388 | "dev": true 2389 | }, 2390 | "responselike": { 2391 | "version": "1.0.2", 2392 | "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", 2393 | "integrity": "sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec=", 2394 | "dev": true, 2395 | "requires": { 2396 | "lowercase-keys": "^1.0.0" 2397 | } 2398 | }, 2399 | "restore-cursor": { 2400 | "version": "2.0.0", 2401 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 2402 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 2403 | "dev": true, 2404 | "requires": { 2405 | "onetime": "^2.0.0", 2406 | "signal-exit": "^3.0.2" 2407 | } 2408 | }, 2409 | "rimraf": { 2410 | "version": "2.4.5", 2411 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.4.5.tgz", 2412 | "integrity": "sha1-7nEM5dk6j9uFb7Xqj/Di11k0sto=", 2413 | "optional": true, 2414 | "requires": { 2415 | "glob": "^6.0.1" 2416 | } 2417 | }, 2418 | "run-async": { 2419 | "version": "2.3.0", 2420 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 2421 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 2422 | "dev": true, 2423 | "requires": { 2424 | "is-promise": "^2.1.0" 2425 | } 2426 | }, 2427 | "rxjs": { 2428 | "version": "6.4.0", 2429 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.4.0.tgz", 2430 | "integrity": "sha512-Z9Yfa11F6B9Sg/BK9MnqnQ+aQYicPLtilXBp2yUtDt2JRCE0h26d33EnfO3ZxoNxG0T92OUucP3Ct7cpfkdFfw==", 2431 | "dev": true, 2432 | "requires": { 2433 | "tslib": "^1.9.0" 2434 | } 2435 | }, 2436 | "safe-buffer": { 2437 | "version": "5.1.2", 2438 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2439 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 2440 | }, 2441 | "safe-json-stringify": { 2442 | "version": "1.2.0", 2443 | "resolved": "https://registry.npmjs.org/safe-json-stringify/-/safe-json-stringify-1.2.0.tgz", 2444 | "integrity": "sha512-gH8eh2nZudPQO6TytOvbxnuhYBOvDBBLW52tz5q6X58lJcd/tkmqFR+5Z9adS8aJtURSXWThWy/xJtJwixErvg==", 2445 | "optional": true 2446 | }, 2447 | "safer-buffer": { 2448 | "version": "2.1.2", 2449 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2450 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2451 | }, 2452 | "semver": { 2453 | "version": "5.6.0", 2454 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 2455 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", 2456 | "dev": true 2457 | }, 2458 | "semver-diff": { 2459 | "version": "3.1.1", 2460 | "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", 2461 | "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", 2462 | "dev": true, 2463 | "requires": { 2464 | "semver": "^6.3.0" 2465 | }, 2466 | "dependencies": { 2467 | "semver": { 2468 | "version": "6.3.0", 2469 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2470 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2471 | "dev": true 2472 | } 2473 | } 2474 | }, 2475 | "send": { 2476 | "version": "0.16.2", 2477 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 2478 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 2479 | "requires": { 2480 | "debug": "2.6.9", 2481 | "depd": "~1.1.2", 2482 | "destroy": "~1.0.4", 2483 | "encodeurl": "~1.0.2", 2484 | "escape-html": "~1.0.3", 2485 | "etag": "~1.8.1", 2486 | "fresh": "0.5.2", 2487 | "http-errors": "~1.6.2", 2488 | "mime": "1.4.1", 2489 | "ms": "2.0.0", 2490 | "on-finished": "~2.3.0", 2491 | "range-parser": "~1.2.0", 2492 | "statuses": "~1.4.0" 2493 | } 2494 | }, 2495 | "serve-static": { 2496 | "version": "1.13.2", 2497 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 2498 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 2499 | "requires": { 2500 | "encodeurl": "~1.0.2", 2501 | "escape-html": "~1.0.3", 2502 | "parseurl": "~1.3.2", 2503 | "send": "0.16.2" 2504 | } 2505 | }, 2506 | "setprototypeof": { 2507 | "version": "1.1.0", 2508 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 2509 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 2510 | }, 2511 | "shebang-command": { 2512 | "version": "1.2.0", 2513 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2514 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2515 | "dev": true, 2516 | "requires": { 2517 | "shebang-regex": "^1.0.0" 2518 | } 2519 | }, 2520 | "shebang-regex": { 2521 | "version": "1.0.0", 2522 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2523 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2524 | "dev": true 2525 | }, 2526 | "signal-exit": { 2527 | "version": "3.0.2", 2528 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2529 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2530 | "dev": true 2531 | }, 2532 | "slice-ansi": { 2533 | "version": "2.1.0", 2534 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2535 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2536 | "dev": true, 2537 | "requires": { 2538 | "ansi-styles": "^3.2.0", 2539 | "astral-regex": "^1.0.0", 2540 | "is-fullwidth-code-point": "^2.0.0" 2541 | } 2542 | }, 2543 | "spdx-correct": { 2544 | "version": "3.1.0", 2545 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 2546 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 2547 | "dev": true, 2548 | "requires": { 2549 | "spdx-expression-parse": "^3.0.0", 2550 | "spdx-license-ids": "^3.0.0" 2551 | } 2552 | }, 2553 | "spdx-exceptions": { 2554 | "version": "2.2.0", 2555 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 2556 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 2557 | "dev": true 2558 | }, 2559 | "spdx-expression-parse": { 2560 | "version": "3.0.0", 2561 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 2562 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 2563 | "dev": true, 2564 | "requires": { 2565 | "spdx-exceptions": "^2.1.0", 2566 | "spdx-license-ids": "^3.0.0" 2567 | } 2568 | }, 2569 | "spdx-license-ids": { 2570 | "version": "3.0.3", 2571 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.3.tgz", 2572 | "integrity": "sha512-uBIcIl3Ih6Phe3XHK1NqboJLdGfwr1UN3k6wSD1dZpmPsIkb8AGNbZYJ1fOBk834+Gxy8rpfDxrS6XLEMZMY2g==", 2573 | "dev": true 2574 | }, 2575 | "sprintf-js": { 2576 | "version": "1.0.3", 2577 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2578 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2579 | "dev": true 2580 | }, 2581 | "statuses": { 2582 | "version": "1.4.0", 2583 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 2584 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==" 2585 | }, 2586 | "string-width": { 2587 | "version": "2.1.1", 2588 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2589 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2590 | "dev": true, 2591 | "requires": { 2592 | "is-fullwidth-code-point": "^2.0.0", 2593 | "strip-ansi": "^4.0.0" 2594 | } 2595 | }, 2596 | "string_decoder": { 2597 | "version": "1.1.1", 2598 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2599 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2600 | "dev": true, 2601 | "requires": { 2602 | "safe-buffer": "~5.1.0" 2603 | } 2604 | }, 2605 | "strip-ansi": { 2606 | "version": "4.0.0", 2607 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2608 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2609 | "dev": true, 2610 | "requires": { 2611 | "ansi-regex": "^3.0.0" 2612 | } 2613 | }, 2614 | "strip-bom": { 2615 | "version": "3.0.0", 2616 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2617 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2618 | "dev": true 2619 | }, 2620 | "strip-json-comments": { 2621 | "version": "2.0.1", 2622 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2623 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2624 | "dev": true 2625 | }, 2626 | "superagent": { 2627 | "version": "3.8.3", 2628 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-3.8.3.tgz", 2629 | "integrity": "sha512-GLQtLMCoEIK4eDv6OGtkOoSMt3D+oq0y3dsxMuYuDvaNUvuT8eFBuLmfR0iYYzHC1e8hpzC6ZsxbuP6DIalMFA==", 2630 | "dev": true, 2631 | "requires": { 2632 | "component-emitter": "^1.2.0", 2633 | "cookiejar": "^2.1.0", 2634 | "debug": "^3.1.0", 2635 | "extend": "^3.0.0", 2636 | "form-data": "^2.3.1", 2637 | "formidable": "^1.2.0", 2638 | "methods": "^1.1.1", 2639 | "mime": "^1.4.1", 2640 | "qs": "^6.5.1", 2641 | "readable-stream": "^2.3.5" 2642 | }, 2643 | "dependencies": { 2644 | "debug": { 2645 | "version": "3.2.6", 2646 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 2647 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 2648 | "dev": true, 2649 | "requires": { 2650 | "ms": "^2.1.1" 2651 | } 2652 | }, 2653 | "ms": { 2654 | "version": "2.1.1", 2655 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2656 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 2657 | "dev": true 2658 | } 2659 | } 2660 | }, 2661 | "supports-color": { 2662 | "version": "5.5.0", 2663 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2664 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2665 | "dev": true, 2666 | "requires": { 2667 | "has-flag": "^3.0.0" 2668 | } 2669 | }, 2670 | "table": { 2671 | "version": "5.2.3", 2672 | "resolved": "https://registry.npmjs.org/table/-/table-5.2.3.tgz", 2673 | "integrity": "sha512-N2RsDAMvDLvYwFcwbPyF3VmVSSkuF+G1e+8inhBLtHpvwXGw4QRPEZhihQNeEN0i1up6/f6ObCJXNdlRG3YVyQ==", 2674 | "dev": true, 2675 | "requires": { 2676 | "ajv": "^6.9.1", 2677 | "lodash": "^4.17.11", 2678 | "slice-ansi": "^2.1.0", 2679 | "string-width": "^3.0.0" 2680 | }, 2681 | "dependencies": { 2682 | "ansi-regex": { 2683 | "version": "4.0.0", 2684 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz", 2685 | "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==", 2686 | "dev": true 2687 | }, 2688 | "string-width": { 2689 | "version": "3.0.0", 2690 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.0.0.tgz", 2691 | "integrity": "sha512-rr8CUxBbvOZDUvc5lNIJ+OC1nPVpz+Siw9VBtUjB9b6jZehZLFt0JMCZzShFHIsI8cbhm0EsNIfWJMFV3cu3Ew==", 2692 | "dev": true, 2693 | "requires": { 2694 | "emoji-regex": "^7.0.1", 2695 | "is-fullwidth-code-point": "^2.0.0", 2696 | "strip-ansi": "^5.0.0" 2697 | } 2698 | }, 2699 | "strip-ansi": { 2700 | "version": "5.0.0", 2701 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz", 2702 | "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==", 2703 | "dev": true, 2704 | "requires": { 2705 | "ansi-regex": "^4.0.0" 2706 | } 2707 | } 2708 | } 2709 | }, 2710 | "term-size": { 2711 | "version": "2.2.0", 2712 | "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.0.tgz", 2713 | "integrity": "sha512-a6sumDlzyHVJWb8+YofY4TW112G6p2FCPEAFk+59gIYHv3XHRhm9ltVQ9kli4hNWeQBwSpe8cRN25x0ROunMOw==", 2714 | "dev": true 2715 | }, 2716 | "text-table": { 2717 | "version": "0.2.0", 2718 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2719 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2720 | "dev": true 2721 | }, 2722 | "through": { 2723 | "version": "2.3.8", 2724 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2725 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2726 | "dev": true 2727 | }, 2728 | "tmp": { 2729 | "version": "0.0.33", 2730 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2731 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2732 | "dev": true, 2733 | "requires": { 2734 | "os-tmpdir": "~1.0.2" 2735 | } 2736 | }, 2737 | "to-readable-stream": { 2738 | "version": "1.0.0", 2739 | "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", 2740 | "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==", 2741 | "dev": true 2742 | }, 2743 | "to-regex-range": { 2744 | "version": "5.0.1", 2745 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2746 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2747 | "dev": true, 2748 | "requires": { 2749 | "is-number": "^7.0.0" 2750 | } 2751 | }, 2752 | "touch": { 2753 | "version": "3.1.0", 2754 | "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.0.tgz", 2755 | "integrity": "sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==", 2756 | "dev": true, 2757 | "requires": { 2758 | "nopt": "~1.0.10" 2759 | } 2760 | }, 2761 | "tslib": { 2762 | "version": "1.9.3", 2763 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 2764 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", 2765 | "dev": true 2766 | }, 2767 | "type-check": { 2768 | "version": "0.3.2", 2769 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2770 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2771 | "dev": true, 2772 | "requires": { 2773 | "prelude-ls": "~1.1.2" 2774 | } 2775 | }, 2776 | "type-detect": { 2777 | "version": "4.0.8", 2778 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 2779 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 2780 | "dev": true 2781 | }, 2782 | "type-fest": { 2783 | "version": "0.8.1", 2784 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 2785 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 2786 | "dev": true 2787 | }, 2788 | "type-is": { 2789 | "version": "1.6.16", 2790 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.16.tgz", 2791 | "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==", 2792 | "requires": { 2793 | "media-typer": "0.3.0", 2794 | "mime-types": "~2.1.18" 2795 | } 2796 | }, 2797 | "typedarray-to-buffer": { 2798 | "version": "3.1.5", 2799 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 2800 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 2801 | "dev": true, 2802 | "requires": { 2803 | "is-typedarray": "^1.0.0" 2804 | } 2805 | }, 2806 | "undefsafe": { 2807 | "version": "2.0.3", 2808 | "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.3.tgz", 2809 | "integrity": "sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A==", 2810 | "dev": true, 2811 | "requires": { 2812 | "debug": "^2.2.0" 2813 | } 2814 | }, 2815 | "unique-string": { 2816 | "version": "2.0.0", 2817 | "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", 2818 | "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", 2819 | "dev": true, 2820 | "requires": { 2821 | "crypto-random-string": "^2.0.0" 2822 | } 2823 | }, 2824 | "unpipe": { 2825 | "version": "1.0.0", 2826 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2827 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2828 | }, 2829 | "update-notifier": { 2830 | "version": "4.1.0", 2831 | "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.1.0.tgz", 2832 | "integrity": "sha512-w3doE1qtI0/ZmgeoDoARmI5fjDoT93IfKgEGqm26dGUOh8oNpaSTsGNdYRN/SjOuo10jcJGwkEL3mroKzktkew==", 2833 | "dev": true, 2834 | "requires": { 2835 | "boxen": "^4.2.0", 2836 | "chalk": "^3.0.0", 2837 | "configstore": "^5.0.1", 2838 | "has-yarn": "^2.1.0", 2839 | "import-lazy": "^2.1.0", 2840 | "is-ci": "^2.0.0", 2841 | "is-installed-globally": "^0.3.1", 2842 | "is-npm": "^4.0.0", 2843 | "is-yarn-global": "^0.3.0", 2844 | "latest-version": "^5.0.0", 2845 | "pupa": "^2.0.1", 2846 | "semver-diff": "^3.1.1", 2847 | "xdg-basedir": "^4.0.0" 2848 | }, 2849 | "dependencies": { 2850 | "ansi-styles": { 2851 | "version": "4.2.1", 2852 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 2853 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 2854 | "dev": true, 2855 | "requires": { 2856 | "@types/color-name": "^1.1.1", 2857 | "color-convert": "^2.0.1" 2858 | } 2859 | }, 2860 | "chalk": { 2861 | "version": "3.0.0", 2862 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", 2863 | "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", 2864 | "dev": true, 2865 | "requires": { 2866 | "ansi-styles": "^4.1.0", 2867 | "supports-color": "^7.1.0" 2868 | } 2869 | }, 2870 | "color-convert": { 2871 | "version": "2.0.1", 2872 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2873 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2874 | "dev": true, 2875 | "requires": { 2876 | "color-name": "~1.1.4" 2877 | } 2878 | }, 2879 | "color-name": { 2880 | "version": "1.1.4", 2881 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2882 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2883 | "dev": true 2884 | }, 2885 | "has-flag": { 2886 | "version": "4.0.0", 2887 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 2888 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 2889 | "dev": true 2890 | }, 2891 | "supports-color": { 2892 | "version": "7.1.0", 2893 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 2894 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 2895 | "dev": true, 2896 | "requires": { 2897 | "has-flag": "^4.0.0" 2898 | } 2899 | } 2900 | } 2901 | }, 2902 | "uri-js": { 2903 | "version": "4.2.2", 2904 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2905 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2906 | "dev": true, 2907 | "requires": { 2908 | "punycode": "^2.1.0" 2909 | } 2910 | }, 2911 | "url-parse-lax": { 2912 | "version": "3.0.0", 2913 | "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", 2914 | "integrity": "sha1-FrXK/Afb42dsGxmZF3gj1lA6yww=", 2915 | "dev": true, 2916 | "requires": { 2917 | "prepend-http": "^2.0.0" 2918 | } 2919 | }, 2920 | "util-deprecate": { 2921 | "version": "1.0.2", 2922 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2923 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2924 | "dev": true 2925 | }, 2926 | "utils-merge": { 2927 | "version": "1.0.1", 2928 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2929 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 2930 | }, 2931 | "validate-npm-package-license": { 2932 | "version": "3.0.4", 2933 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2934 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2935 | "dev": true, 2936 | "requires": { 2937 | "spdx-correct": "^3.0.0", 2938 | "spdx-expression-parse": "^3.0.0" 2939 | } 2940 | }, 2941 | "vary": { 2942 | "version": "1.1.2", 2943 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2944 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2945 | }, 2946 | "which": { 2947 | "version": "1.3.1", 2948 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2949 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2950 | "dev": true, 2951 | "requires": { 2952 | "isexe": "^2.0.0" 2953 | } 2954 | }, 2955 | "widest-line": { 2956 | "version": "3.1.0", 2957 | "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", 2958 | "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", 2959 | "dev": true, 2960 | "requires": { 2961 | "string-width": "^4.0.0" 2962 | }, 2963 | "dependencies": { 2964 | "ansi-regex": { 2965 | "version": "5.0.0", 2966 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 2967 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 2968 | "dev": true 2969 | }, 2970 | "emoji-regex": { 2971 | "version": "8.0.0", 2972 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2973 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2974 | "dev": true 2975 | }, 2976 | "is-fullwidth-code-point": { 2977 | "version": "3.0.0", 2978 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2979 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2980 | "dev": true 2981 | }, 2982 | "string-width": { 2983 | "version": "4.2.0", 2984 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 2985 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 2986 | "dev": true, 2987 | "requires": { 2988 | "emoji-regex": "^8.0.0", 2989 | "is-fullwidth-code-point": "^3.0.0", 2990 | "strip-ansi": "^6.0.0" 2991 | } 2992 | }, 2993 | "strip-ansi": { 2994 | "version": "6.0.0", 2995 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2996 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2997 | "dev": true, 2998 | "requires": { 2999 | "ansi-regex": "^5.0.0" 3000 | } 3001 | } 3002 | } 3003 | }, 3004 | "wordwrap": { 3005 | "version": "1.0.0", 3006 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 3007 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 3008 | "dev": true 3009 | }, 3010 | "wrappy": { 3011 | "version": "1.0.2", 3012 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3013 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 3014 | }, 3015 | "write": { 3016 | "version": "1.0.3", 3017 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 3018 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 3019 | "dev": true, 3020 | "requires": { 3021 | "mkdirp": "^0.5.1" 3022 | } 3023 | }, 3024 | "write-file-atomic": { 3025 | "version": "3.0.3", 3026 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 3027 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 3028 | "dev": true, 3029 | "requires": { 3030 | "imurmurhash": "^0.1.4", 3031 | "is-typedarray": "^1.0.0", 3032 | "signal-exit": "^3.0.2", 3033 | "typedarray-to-buffer": "^3.1.5" 3034 | } 3035 | }, 3036 | "xdg-basedir": { 3037 | "version": "4.0.0", 3038 | "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", 3039 | "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", 3040 | "dev": true 3041 | } 3042 | } 3043 | } 3044 | -------------------------------------------------------------------------------- /speakers-service/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "speakers-service", 3 | "version": "1.0.0", 4 | "description": "A service to manage speakers", 5 | "scripts": { 6 | "start": "nodemon bin/run | bunyan" 7 | }, 8 | "keywords": [], 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "axios": "^0.19.2", 13 | "bunyan": "^1.8.12", 14 | "express": "^4.16.4" 15 | }, 16 | "devDependencies": { 17 | "chai": "^4.2.0", 18 | "chai-http": "^4.2.1", 19 | "eslint": "^5.14.1", 20 | "eslint-config-airbnb-base": "^13.1.0", 21 | "eslint-plugin-import": "^2.16.0", 22 | "nodemon": "^2.0.4" 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /speakers-service/server/lib/Speakers.js: -------------------------------------------------------------------------------- 1 | const fs = require('fs'); 2 | const util = require('util'); 3 | 4 | const readFile = util.promisify(fs.readFile); 5 | 6 | class SpeakersService { 7 | constructor(datafile) { 8 | this.datafile = datafile; 9 | } 10 | 11 | async getNames() { 12 | const data = await this.getData(); 13 | 14 | return data.map(speaker => ({ 15 | name: speaker.name, 16 | shortname: speaker.shortname, 17 | })); 18 | } 19 | 20 | async getListShort() { 21 | const data = await this.getData(); 22 | return data.map(speaker => ({ 23 | name: speaker.name, 24 | shortname: speaker.shortname, 25 | title: speaker.title, 26 | })); 27 | } 28 | 29 | async getList() { 30 | const data = await this.getData(); 31 | return data.map(speaker => ({ 32 | name: speaker.name, 33 | shortname: speaker.shortname, 34 | title: speaker.title, 35 | summary: speaker.summary, 36 | })); 37 | } 38 | 39 | async getAllArtwork() { 40 | const data = await this.getData(); 41 | const artwork = data.reduce((acc, elm) => { 42 | if (elm.artwork) { 43 | // eslint-disable-next-line no-param-reassign 44 | acc = [...acc, ...elm.artwork]; 45 | } 46 | return acc; 47 | }, []); 48 | return artwork; 49 | } 50 | 51 | async getSpeaker(shortname) { 52 | const data = await this.getData(); 53 | const speaker = data.find(current => current.shortname === shortname); 54 | if (!speaker) return null; 55 | return { 56 | title: speaker.title, 57 | name: speaker.name, 58 | shortname: speaker.shortname, 59 | description: speaker.description, 60 | }; 61 | } 62 | 63 | async getArtworkForSpeaker(shortname) { 64 | const data = await this.getData(); 65 | const speaker = data.find(current => current.shortname === shortname); 66 | if (!speaker || !speaker.artwork) return null; 67 | return speaker.artwork; 68 | } 69 | 70 | async getData() { 71 | const data = await readFile(this.datafile, 'utf8'); 72 | if (!data) return []; 73 | return JSON.parse(data).speakers; 74 | } 75 | } 76 | 77 | module.exports = SpeakersService; 78 | -------------------------------------------------------------------------------- /speakers-service/server/service.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | 3 | const service = express(); 4 | 5 | const Speakers = require('./lib/Speakers'); 6 | 7 | module.exports = (config) => { 8 | const log = config.log(); 9 | const speakers = new Speakers(config.data.speakers); 10 | // Add a request logging middleware in development mode 11 | if (service.get('env') === 'development') { 12 | service.use((req, res, next) => { 13 | log.debug(`${req.method}: ${req.url}`); 14 | return next(); 15 | }); 16 | } 17 | 18 | service.use('/images', express.static(config.data.images)) 19 | 20 | service.get('/list', async (req, res, next) => { 21 | try{ 22 | return res.json(await speakers.getList()); 23 | }catch(err){ 24 | return next(err); 25 | } 26 | }); 27 | 28 | service.get('/list-short', async (req, res, next) => { 29 | try{ 30 | return res.json(await speakers.getListShort()); 31 | }catch(err){ 32 | return next(err); 33 | } 34 | }); 35 | 36 | service.get('/names', async (req, res, next) => { 37 | try{ 38 | return res.json(await speakers.getNames()); 39 | }catch(err){ 40 | return next(err); 41 | } 42 | }); 43 | 44 | service.get('/artworks', async (req, res, next) => { 45 | try{ 46 | return res.json(await speakers.getAllArtwork()); 47 | }catch(err){ 48 | return next(err); 49 | } 50 | }); 51 | 52 | service.get('/speaker/:shortname', async (req, res, next) => { 53 | try{ 54 | return res.json(await speakers.getSpeaker(req.params.shortname)); 55 | }catch(err){ 56 | return next(err); 57 | } 58 | }); 59 | 60 | service.get('/artwork/:shortname', async (req, res, next) => { 61 | try{ 62 | return res.json(await speakers.getArtworkForSpeaker(req.params.shortname)); 63 | }catch(err){ 64 | return next(err); 65 | } 66 | }); 67 | 68 | // eslint-disable-next-line no-unused-vars 69 | service.use((error, req, res, next) => { 70 | res.status(error.status || 500); 71 | // Log out the error to the console 72 | log.error(error); 73 | return res.json({ 74 | error: { 75 | message: error.message, 76 | }, 77 | }); 78 | }); 79 | return service; 80 | }; 81 | --------------------------------------------------------------------------------