├── .babelrc ├── .gitignore ├── .npmignore ├── .travis.yml ├── LICENSE ├── README.md ├── examples └── deployment.yaml ├── package.json ├── src ├── authorization.js ├── build-requests.js ├── compile-required-images.js ├── confirm-submit.js ├── filter-missing-images.js ├── get-config.js ├── get-options.js ├── index.js ├── list-tags.js ├── log-build.js ├── manifest-container-builds.js ├── manifest.js ├── parse-input-yaml.js ├── select-images.js ├── stringify.js └── submit-build-request.js ├── test ├── build-requests.test.js ├── compile-required-images.test.js ├── confirm-submit.test.js ├── filter-missing-images.test.js ├── get-config.fixture.gcloud-config-helper-output.json ├── get-config.test.js ├── get-options.test.js ├── list-tags.fixture.result.json ├── list-tags.test.js ├── log-build.test.js ├── manifest-container-builds.test.js ├── manifest.test.js ├── parse-input-yaml.test.js ├── select-images.test.js ├── submit-build-request.fixture.result.json └── submit-build-request.test.js └── yarn.lock /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | presets: [ 3 | ["env", {targets: {"node": "6.12.0"}}] 4 | ], 5 | plugins: [ 6 | "transform-object-rest-spread" 7 | ] 8 | } 9 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | dist/ 3 | package-lock.json 4 | coverage/ 5 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | src/ 2 | test/ 3 | .gitignore 4 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - "6" 4 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 Dmitry Minkovsky 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # kube-cloud-build 2 | 3 | Specify container builds inside your Kubernetes manifests. 4 | 5 | [![Build Status](https://travis-ci.org/dminkovsky/kube-cloud-build.svg?branch=master)](https://travis-ci.org/dminkovsky/kube-cloud-build) 6 | 7 | Kubernetes helps orchestrate container deployments. But before Kubernetes can 8 | orchestrate anything, the container images specified in your Kubernetes 9 | manifests must be built and available in an image registry. Making this happen 10 | can be much easier said than done! 11 | 12 | `kube-cloud-build` integrates Kubernetes and [Google Cloud Container Builder](https://cloud.google.com/container-builder/docs/). 13 | It lets you declare Cloud Container Builder [build steps](https://cloud.google.com/container-builder/docs/how-to/writing-build-requests) 14 | for containers right inside the manifests where they are used. With the build 15 | steps inside your manifests, any time you update the images specified by your 16 | manifests, `kube-cloud-build` will automatically generate build requests based 17 | on the missing images' build steps. Never write a build request by hand again! 18 | 19 | `kube-cloud-build` examines your Kubernetes manifests, identifies images that 20 | are missing from Google Container Registry (GCR), generates build requests for 21 | the missing images, and submits the build requests for you. 22 | 23 | To use this tool, just add Container Builder build steps to your manifests. 24 | Then, any time you update an image's tag in a manifest, run that manifest 25 | through this tool. It'll make sure the images you need are built and available 26 | on GCR. Deploy with confidence, knowing you wont receive an image pull error. 27 | 28 | ### Install 29 | 30 | ``` 31 | $ npm install -g kube-cloud-build 32 | ``` 33 | 34 | ### Usage 35 | 36 | Process a single manifest: 37 | 38 | ``` 39 | $ k8s-cloud-build -r repo -f examples/deployment.yaml 40 | ``` 41 | 42 | or an entire helm chart: 43 | 44 | ``` 45 | $ helm template /path/to/chart | k8s-cloud-build -r repo 46 | ``` 47 | 48 | ### Example 49 | 50 | Suppose you have the following manifest: 51 | ``` 52 | $ cat examples/deployment.yaml 53 | apiVersion: apps/v1beta2 54 | kind: Deployment 55 | metadata: 56 | name: frontend 57 | spec: 58 | replicas: 3 59 | template: 60 | spec: 61 | initContainers: 62 | - name: init 63 | image: gcr.io/some-project-123456/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14 64 | containers: 65 | - name: container1 66 | image: gcr.io/some-project-123456/container1:v4 67 | - name: container2 68 | image: gcr.io/some-project-123456/container2:v4 69 | ``` 70 | 71 | You can deploy this manifest, but you will get a bunch of image pull errors if 72 | the images for the containers it specifies do not exist on GCR. You can build these images 73 | manually by submitting build requests to Container Builder, but with many manifests 74 | and containers this quickly becomes difficult to manage. 75 | 76 | The solution: add your Container Builder build steps directly to your manifest: 77 | 78 | ``` 79 | $ cat examples/deployment.yaml 80 | apiVersion: apps/v1beta2 81 | kind: Deployment 82 | metadata: 83 | name: frontend 84 | spec: 85 | replicas: 3 86 | template: 87 | + metadata: 88 | + annotations: 89 | + google.cloud.container.build: > 90 | + [{ 91 | + "container": "init", 92 | + "steps": [{ 93 | + "name": "gcr.io/cloud-builders/docker", 94 | + "dir": "init", 95 | + "args": [ 96 | + "build", 97 | + "-t", 98 | + "gcr.io/some-project-123456/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14", 99 | + "." 100 | + ] 101 | + }] 102 | + },{ 103 | + "container": "container1", 104 | + "steps": [{ 105 | + "name": "gcr.io/cloud-builders/docker", 106 | + "dir": "container1", 107 | + "args": [ 108 | + "build", 109 | + "-t", 110 | + "gcr.io/some-project-123456/container1:v4", 111 | + "." 112 | + ] 113 | + }] 114 | + },{ 115 | + "container": "container2", 116 | + "steps": [{ 117 | + "name": "gcr.io/cloud-builders/docker", 118 | + "dir": "container2", 119 | + "args": [ 120 | + "build", 121 | + "-t", 122 | + "gcr.io/some-project-123456/container2:v4", 123 | + "." 124 | + ] 125 | + }] 126 | + }] 127 | spec: 128 | initContainers: 129 | - name: init 130 | image: gcr.io/some-project-123456/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14 131 | containers: 132 | - name: container1 133 | image: gcr.io/some-project-123456/container1:v4 134 | - name: container2 135 | image: gcr.io/some-project-123456/container2:v4 136 | ``` 137 | 138 | Now feed this manifest to `kube-cloud-build`. It will communicate with GCR, identify images 139 | that are missing, and ask which you want to build: 140 | 141 | ``` 142 | $ k8s-cloud-build -r repo -f deployment.yaml 143 | ? The following images are missing from Google Container Registry. Choose the ones you want to build: (Press to select, to toggle all, to inverse selection) 144 | ❯◯ gcr.io/some-project-123456/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14 145 | ◯ gcr.io/some-project-123456/container1:v4 146 | ◯ gcr.io/some-project-123456/container2:v4 147 | ``` 148 | 149 | `kube-cloud-build` ignores images that are [not part of your project](test/manifest-container-builds.test.js#L21) 150 | or lack build instructions. Given the images you select, `kube-cloud-build` 151 | compiles the required containers' build steps into Container Builder build 152 | requests. Steps are grouped into build requests by tag. 153 | 154 | Review and optionally submit the requests: 155 | 156 | ``` 157 | { 158 | "source": { 159 | "repoSource": { 160 | "projectId": "some-project-123456", 161 | "repoName": "repo", 162 | "commitSha": "8f4dfd28dbc51960d0bd2d463c23593cb878fd14" 163 | } 164 | }, 165 | "steps": [ 166 | { 167 | "name": "gcr.io/cloud-builders/docker", 168 | "dir": "init", 169 | "args": [ 170 | "build", 171 | "-t", 172 | "gcr.io/some-project-123456/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14", 173 | "." 174 | ] 175 | } 176 | ], 177 | "images": [ 178 | "gcr.io/some-project-123456/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14" 179 | ] 180 | } 181 | { 182 | "source": { 183 | "repoSource": { 184 | "projectId": "some-project-123456", 185 | "repoName": "repo", 186 | "tagName": "v4" 187 | } 188 | }, 189 | "steps": [ 190 | { 191 | "name": "gcr.io/cloud-builders/docker", 192 | "dir": "container1", 193 | "args": [ 194 | "build", 195 | "-t", 196 | "gcr.io/some-project-123456/container1:v4", 197 | "." 198 | ] 199 | }, 200 | { 201 | "name": "gcr.io/cloud-builders/docker", 202 | "dir": "container2", 203 | "args": [ 204 | "build", 205 | "-t", 206 | "gcr.io/some-project-123456/container2:v4", 207 | "." 208 | ] 209 | } 210 | ], 211 | "images": [ 212 | "gcr.io/some-project-123456/container1:v4", 213 | "gcr.io/some-project-123456/container2:v4" 214 | ] 215 | } 216 | ? Do you want to submit these build requests? (y/N) 217 | ``` 218 | 219 | If you choose "yes," `kube-cloud-build` will submit these build requests. 220 | 221 | ### Usage 222 | 223 | ``` 224 | k8s-cloud-build -r [-f ] 225 | 226 | -f Manifest file, if not reading from stdin 227 | -r Google Source Repository to use in build requests 228 | ``` 229 | 230 | `kube-cloud-build` accepts input by way of the `-f` switch or on `stdin`. 231 | `stdin` is useful for deploying Helm charts: 232 | 233 | ``` 234 | $ helm template /path/to/chart | k8s-cloud-build -r repo 235 | ``` 236 | 237 | The project ID and API access token used to communicate with the Google Cloud 238 | API are determined using [`gcloud config config-helper`](src/get-config.js). 239 | 240 | If all required images are present on GCR, `kube-cloud-build` exits silently with status 0. 241 | 242 | ### FAQ 243 | 244 | **What API calls does this tool make?** 245 | 246 | During the course of its operation, `kube-cloud-build` makes Google Cloud API 247 | calls analogous to: 248 | 249 | * [`gcloud container images list-tags`](src/list-tags.js) 250 | * [`gcloud container builds submit`](src/submit-build-request.js) 251 | 252 | **What resource types can this tool handle?** 253 | 254 | `kube-cloud-build` handles Kubernetes resources that are either a `Pod` or 255 | contain a `PodTemplateSpec`: 256 | 257 | * `Pod` 258 | * `CronJob` 259 | * `Deployment` 260 | * `DaemonSet` 261 | * `Job` 262 | * `ReplicaSet` 263 | * `ReplicationController` 264 | * `StatefulSet` 265 | 266 | For each of these resources types, `kube-cloud-build` looks for a `google.cloud.container.build` 267 | annotation inside of the metadata of the relevant [Pod](https://kubernetes.io/docs/api-reference/v1.8/#pod-v1-core) or 268 | [PodTemplateSpec](https://kubernetes.io/docs/api-reference/v1.8/#podtemplatespec-v1-core). 269 | -------------------------------------------------------------------------------- /examples/deployment.yaml: -------------------------------------------------------------------------------- 1 | apiVersion: apps/v1beta2 2 | kind: Deployment 3 | metadata: 4 | name: frontend 5 | spec: 6 | replicas: 3 7 | template: 8 | metadata: 9 | annotations: 10 | google.cloud.container.build: > 11 | [{ 12 | "container": "init", 13 | "steps": [{ 14 | "name": "gcr.io/cloud-builders/docker", 15 | "dir": "init", 16 | "args": [ 17 | "build", 18 | "-t", 19 | "gcr.io/fresh-metrics-154816/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14", 20 | "." 21 | ] 22 | }] 23 | },{ 24 | "container": "container1", 25 | "steps": [{ 26 | "name": "gcr.io/cloud-builders/docker", 27 | "dir": "container1", 28 | "args": [ 29 | "build", 30 | "-t", 31 | "gcr.io/fresh-metrics-154816/container1:v4", 32 | "." 33 | ] 34 | }] 35 | },{ 36 | "container": "container2", 37 | "steps": [{ 38 | "name": "gcr.io/cloud-builders/docker", 39 | "dir": "container2", 40 | "args": [ 41 | "build", 42 | "-t", 43 | "gcr.io/fresh-metrics-154816/container2:v4", 44 | "." 45 | ] 46 | }] 47 | }] 48 | spec: 49 | initContainers: 50 | - name: init 51 | image: gcr.io/fresh-metrics-154816/init:8f4dfd28dbc51960d0bd2d463c23593cb878fd14 52 | containers: 53 | - name: container1 54 | image: gcr.io/fresh-metrics-154816/container1:v4 55 | - name: container2 56 | image: gcr.io/fresh-metrics-154816/container2:v4 57 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "kube-cloud-build", 3 | "version": "2.0.1", 4 | "description": "Build containers specified in Kubernetes manifests", 5 | "main": "dist/index.js", 6 | "dependencies": { 7 | "bluebird": "^3.5.1", 8 | "deep-equal": "^1.0.1", 9 | "docker-parse-image": "^3.0.1", 10 | "inquirer": "^4.0.0", 11 | "js-yaml": "^3.10.0", 12 | "minimist": "^1.2.0", 13 | "raw-body": "^2.3.2", 14 | "request": "^2.83.0", 15 | "request-promise": "^4.2.2", 16 | "ttys": "^0.0.3" 17 | }, 18 | "devDependencies": { 19 | "babel-cli": "^6.26.0", 20 | "babel-plugin-transform-object-rest-spread": "^6.26.0", 21 | "babel-preset-env": "^1.6.1", 22 | "jest": "^21.2.1" 23 | }, 24 | "scripts": { 25 | "test": "jest", 26 | "build": "yarn install && yarn run test && rm -rf dist && mkdir dist && babel src -d dist", 27 | "prepublishOnly": "yarn build" 28 | }, 29 | "bin": { 30 | "k8s-cloud-build": "dist/index.js" 31 | }, 32 | "author": "Dmitry Minkovsky ", 33 | "license": "MIT", 34 | "repository": { 35 | "type": "git", 36 | "url": "https://github.com/dminkovsky/kube-cloud-build" 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /src/authorization.js: -------------------------------------------------------------------------------- 1 | export default function authorization(token) { 2 | return { 3 | 'Authorization': `Bearer ${token}`, 4 | }; 5 | } 6 | -------------------------------------------------------------------------------- /src/build-requests.js: -------------------------------------------------------------------------------- 1 | export default function buildRequests({projectId, repoName, containerBuilds}) { 2 | const requests = []; 3 | containerBuilds.forEach(({tagName, commitSha, image, build}) => { 4 | let request = findRequest(requests, {tagName, commitSha}); 5 | if (!request) { 6 | request = newBuildRequest({projectId, repoName, tagName, commitSha}); 7 | requests.push(request); 8 | } 9 | build.steps.forEach(step => request.steps.push(step)); 10 | request.images.push(formatImage(image)); 11 | }); 12 | return requests; 13 | } 14 | 15 | function findRequest(requests, {tagName, commitSha}) { 16 | return requests.filter(({source: {repoSource}}) => { 17 | return repoSource.tagName && repoSource.tagName === tagName || 18 | repoSource.commitSha && repoSource.commitSha === commitSha; 19 | })[0] || null; 20 | } 21 | 22 | function newBuildRequest({projectId, repoName, tagName, commitSha}) { 23 | return { 24 | source: { 25 | repoSource: { 26 | projectId, 27 | repoName, 28 | tagName, 29 | commitSha, 30 | } 31 | }, 32 | steps: [], 33 | images: [], 34 | }; 35 | } 36 | 37 | function formatImage({registry, namespace, repository, tag}) { 38 | return `${registry}/${namespace}/${repository}:${tag}`; 39 | } 40 | -------------------------------------------------------------------------------- /src/compile-required-images.js: -------------------------------------------------------------------------------- 1 | import stringify from './stringify'; 2 | 3 | module.exports = function({ 4 | isSupported, 5 | manifestContainerBuilds, 6 | compareBuilds, 7 | }) { 8 | return function compileRequiredImages(projectId, manifests) { 9 | return manifests.reduce((accum, manifest) => { 10 | if (!isSupported(manifest)) { 11 | return accum; 12 | } 13 | manifestContainerBuilds(projectId, manifest).forEach(containerBuild => { 14 | const {image, build} = containerBuild; 15 | const exists = accum.filter(c => c.image.fullname === image.fullname)[0]; 16 | if (!exists) { 17 | accum.push(containerBuild) 18 | } else if (!compareBuilds(exists.build.steps, build.steps)) { 19 | console.log(stringify(exists.build), stringify(build)); 20 | throw REPEAT_ERROR; 21 | } 22 | }); 23 | return accum; 24 | }, []); 25 | } 26 | } 27 | 28 | export const REPEAT_ERROR = 'Repeat container builds must have identical build steps'; 29 | -------------------------------------------------------------------------------- /src/confirm-submit.js: -------------------------------------------------------------------------------- 1 | import stringify from './stringify'; 2 | 3 | module.exports = function({ 4 | log, 5 | inquirer, 6 | }) { 7 | return function confirmSubmit(requests) { 8 | requests.forEach(request => log(stringify(request))); 9 | return inquirer({ 10 | type: 'confirm', 11 | name: 'confirmed', 12 | message: 'Do you want to submit these build requests?', 13 | default: false, 14 | }); 15 | }; 16 | } 17 | -------------------------------------------------------------------------------- /src/filter-missing-images.js: -------------------------------------------------------------------------------- 1 | import Promise from 'bluebird'; 2 | 3 | module.exports = function({ 4 | listTags, 5 | }) { 6 | return function filterMissingImages(containerBuilds, projectId, token) { 7 | return Promise.filter( 8 | containerBuilds, 9 | ({image: {repository, tag}}) => listTags(repository, projectId, token).then(tags => tags.indexOf(tag) < 0), 10 | {concurrency: 3} 11 | ); 12 | }; 13 | } 14 | -------------------------------------------------------------------------------- /src/get-config.js: -------------------------------------------------------------------------------- 1 | const CMD_CONFIG = 'gcloud config config-helper --format=json'; 2 | 3 | module.exports = function({ 4 | exec, 5 | }) { 6 | return function getConfig() { 7 | return new Promise((resolve, reject) => { 8 | exec(CMD_CONFIG, (error, stdout, stderr) => { 9 | if (error) { 10 | reject(error); 11 | } else { 12 | resolve(stdout.trim()); 13 | } 14 | }); 15 | }) 16 | .then(JSON.parse) 17 | .then(({credential: {access_token: token}, configuration: {properties: {core: {project: projectId}}}}) => ({projectId, token})); 18 | }; 19 | } 20 | 21 | module.exports.CMD_CONFIG = CMD_CONFIG; 22 | -------------------------------------------------------------------------------- /src/get-options.js: -------------------------------------------------------------------------------- 1 | module.exports = function({ 2 | process, 3 | minimist 4 | }) { 5 | return function getOptions() { 6 | const { 7 | f: file, 8 | r: repoName, 9 | } = minimist(process.argv.slice(2)); 10 | if (!repoName) { 11 | throw 'repoName (-r) required'; 12 | } 13 | return { 14 | file, 15 | repoName, 16 | }; 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | import fs from 'fs'; 4 | import assert from 'assert'; 5 | import {exec} from 'child_process'; 6 | import rawBody from 'raw-body'; 7 | import jsYaml from 'js-yaml'; 8 | import dockerParseImage from 'docker-parse-image'; 9 | import request from 'request-promise'; 10 | import Promise from 'bluebird'; 11 | import minimist from 'minimist'; 12 | import inquirer from 'inquirer'; 13 | import ttys from 'ttys'; 14 | import __deepEqual from 'deep-equal'; 15 | 16 | import {isSupported, getContainers, getBuilds} from './manifest'; 17 | import buildRequests from './build-requests'; 18 | 19 | const {log} = console; 20 | 21 | const getConfig = require('./get-config')({exec}); 22 | const getOptions = require('./get-options')({process, minimist}); 23 | const parseInputYaml = require('./parse-input-yaml')({process, fs, rawBody, jsYaml}); 24 | const listTags = require('./list-tags')({request}); 25 | const submitBuildRequest = require('./submit-build-request')({request}); 26 | const manifestContainerBuilds = require('./manifest-container-builds')({getContainers, getBuilds}); 27 | const compileRequiredImages = require('./compile-required-images')({isSupported, manifestContainerBuilds, compareBuilds: deepEqual}); 28 | const filterMissingImages = require('./filter-missing-images')({listTags}); 29 | const inquirerModule = inquirer.createPromptModule({input: ttys.stdin, output: ttys.stdout}); 30 | const selectImages = require('./select-images')({inquirer: inquirerModule}); 31 | const confirmSubmit = require('./confirm-submit')({log, inquirer: inquirerModule}); 32 | 33 | (async function main() { 34 | try { 35 | const {projectId, token} = await getConfig(); 36 | const {file, repoName} = getOptions(); 37 | const manifests = await parseInputYaml(file); 38 | const requiredImages = compileRequiredImages(projectId, manifests); 39 | const missingImages = await filterMissingImages(requiredImages, projectId, token); 40 | if (!missingImages.length) { 41 | process.exit(0); 42 | } 43 | const selected = await selectImages(missingImages) 44 | if (!selected.length) { 45 | process.exit(0); 46 | } 47 | const requests = buildRequests({projectId, repoName, containerBuilds: selected}); 48 | const {confirmed} = await confirmSubmit(requests); 49 | if (!confirmed) { 50 | process.exit(1); 51 | } 52 | for (let i = 0; i < requests.length; i++) { 53 | const request = requests[i]; 54 | const id = await submitBuildRequest({buildRequest: request, projectId, token}); 55 | process.stdout.write(id); 56 | } 57 | } catch (e) { 58 | process.stderr.write(e.toString()); 59 | process.exit(1); 60 | } 61 | })(); 62 | 63 | function deepEqual(a, b) { 64 | return __deepEqual(a, b, {strict: true}); 65 | } 66 | -------------------------------------------------------------------------------- /src/list-tags.js: -------------------------------------------------------------------------------- 1 | import authorization from './authorization'; 2 | 3 | module.exports = function({ 4 | request, 5 | }) { 6 | return function listTags(repository, projectId, token) { 7 | return request({ 8 | url: listTagsUrl(projectId, repository), 9 | headers: { 10 | ...authorization(token), 11 | }, 12 | }) 13 | .then(JSON.parse) 14 | .then(({tags}) => tags); 15 | } 16 | } 17 | 18 | function listTagsUrl(projectId, repository) { 19 | return `https://gcr.io/v2/${projectId}/${repository}/tags/list`; 20 | } 21 | 22 | module.exports.listTagsUrl = listTagsUrl; 23 | -------------------------------------------------------------------------------- /src/log-build.js: -------------------------------------------------------------------------------- 1 | const cmdLogStream = id => `gcloud container builds log --stream ${id}`; 2 | 3 | module.exports = function({ 4 | process, 5 | exec, 6 | }) { 7 | return function logBuild(id) { 8 | return new Promise((resolve, reject) => { 9 | const log = exec(cmdLogStream(id)) 10 | log.stdout.pipe(process.stdout); 11 | log.stdout.on('end', resolve); 12 | log.stdout.on('error', reject); 13 | }); 14 | }; 15 | } 16 | 17 | module.exports.cmdLogStream = cmdLogStream; 18 | -------------------------------------------------------------------------------- /src/manifest-container-builds.js: -------------------------------------------------------------------------------- 1 | import dockerParseImage from 'docker-parse-image'; 2 | 3 | module.exports = function({ 4 | getContainers, 5 | getBuilds, 6 | }) { 7 | return function manifestContainerBuilds(projectId, manifest) { 8 | const containers = getContainers(manifest); 9 | const builds = getBuilds(manifest); 10 | const accum = []; 11 | if (!builds) { 12 | return accum; 13 | } 14 | return containers.reduce((accum, {name, image}) => { 15 | const build = getBuild(builds, name); 16 | const parsedImage = dockerParseImage(image); 17 | const {registry, namespace, tag} = parsedImage; 18 | if (!(build && 19 | registry === 'gcr.io' && 20 | namespace === projectId && 21 | tag !== null && 22 | tag !== 'latest')) { 23 | return accum; 24 | } 25 | accum.push({ 26 | image: parsedImage, 27 | build, 28 | ...(isCommitSha(tag) ? {commitSha: tag} : {tagName: tag}), 29 | }); 30 | return accum; 31 | }, accum); 32 | }; 33 | } 34 | 35 | function isCommitSha(str) { 36 | try { 37 | return Buffer.from(str, 'hex').length === 20; 38 | } catch(e) { 39 | return false; 40 | } 41 | } 42 | 43 | function getBuild(builds, name) { 44 | return builds.filter(({container}) => container === name)[0] || null; 45 | } 46 | -------------------------------------------------------------------------------- /src/manifest.js: -------------------------------------------------------------------------------- 1 | const BUILD_INSTRUCTIONS_ANNOTATION = 'google.cloud.container.build'; 2 | 3 | const SUPPORTED_RESOURCES = [ 4 | 'Pod', 5 | 'CronJob', 6 | 'Deployment', 7 | 'DaemonSet', 8 | 'Job', 9 | 'ReplicaSet', 10 | 'ReplicationController', 11 | 'StatefulSet', 12 | ]; 13 | 14 | function visitManifest(manifest, visitor) { 15 | const {kind} = manifest; 16 | switch (kind) { 17 | case 'Pod': 18 | return visitor.pod(manifest); 19 | case 'CronJob': 20 | return visitor.cronJob(manifest); 21 | case 'Deployment': 22 | case 'DaemonSet': 23 | case 'Job': 24 | case 'ReplicaSet': 25 | case 'ReplicationController': 26 | case 'StatefulSet': 27 | return visitor.composite(manifest); 28 | } 29 | } 30 | 31 | function getPodSpec(manifest) { 32 | return visitManifest(manifest, { 33 | pod: () => manifest.spec, 34 | cronJob: () => manifest.spec.jobTemplate.spec.template.spec, 35 | composite: () => manifest.spec.template.spec, 36 | }); 37 | } 38 | 39 | function getPodSpecContainers({initContainers = [], containers = []}) { 40 | return initContainers.concat(containers); 41 | } 42 | 43 | function getContainers(manifest) { 44 | return getPodSpecContainers(getPodSpec(manifest)); 45 | } 46 | 47 | function getBuilds(manifest) { 48 | const json = visitManifest(manifest, { 49 | pod: () => manifest.metadata && 50 | manifest.metadata.annotations && 51 | manifest.metadata.annotations[BUILD_INSTRUCTIONS_ANNOTATION], 52 | cronJob: () => manifest.spec.jobTemplate.spec.template.metadata && 53 | manifest.spec.jobTemplate.spec.template.metadata.annotations && 54 | manifest.spec.jobTemplate.spec.template.metadata.annotations[BUILD_INSTRUCTIONS_ANNOTATION], 55 | composite: () => manifest.spec.template.metadata && 56 | manifest.spec.template.metadata.annotations && 57 | manifest.spec.template.metadata.annotations[BUILD_INSTRUCTIONS_ANNOTATION] 58 | }); 59 | return json && JSON.parse(json) || null; 60 | } 61 | 62 | function isSupported({kind}) { 63 | return SUPPORTED_RESOURCES.indexOf(kind) > -1; 64 | } 65 | 66 | export { 67 | BUILD_INSTRUCTIONS_ANNOTATION, 68 | isSupported, 69 | getContainers, 70 | getBuilds, 71 | }; 72 | -------------------------------------------------------------------------------- /src/parse-input-yaml.js: -------------------------------------------------------------------------------- 1 | module.exports = function({ 2 | process, 3 | fs, 4 | rawBody, 5 | jsYaml, 6 | }) { 7 | return function parseInputYaml(file) { 8 | const stream = file ? fs.createReadStream(file) : process.stdin; 9 | return rawBody(stream, {encoding: 'utf-8'}) 10 | .then(jsYaml.safeLoadAll); 11 | }; 12 | } 13 | -------------------------------------------------------------------------------- /src/select-images.js: -------------------------------------------------------------------------------- 1 | module.exports = function({ 2 | inquirer, 3 | }) { 4 | return function selectImages(containerBuilds) { 5 | return inquirer({ 6 | type: 'checkbox', 7 | message: 'The following images are missing from Google Container Registry. Choose the ones you want to build:', 8 | name: 'images', 9 | choices: containerBuilds.map(({image: {fullname}}) => ({name: fullname})), 10 | }) 11 | .then(({images}) => { 12 | return containerBuilds.filter(({image: {fullname}}) => images.indexOf(fullname) > -1); 13 | }); 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /src/stringify.js: -------------------------------------------------------------------------------- 1 | export default function stringify(obj) { 2 | return JSON.stringify(obj, null, 4); 3 | } 4 | -------------------------------------------------------------------------------- /src/submit-build-request.js: -------------------------------------------------------------------------------- 1 | import authorization from './authorization'; 2 | 3 | module.exports = function({ 4 | request, 5 | }) { 6 | return function submitBuildRequest({buildRequest, projectId, token}) { 7 | return request({ 8 | url: submitBuildRequestUrl(projectId), 9 | method: 'POST', 10 | headers: { 11 | 'Content-Type': 'application/json', 12 | ...authorization(token), 13 | }, 14 | body: JSON.stringify(buildRequest), 15 | }) 16 | .then(JSON.parse) 17 | .then(({metadata: {build: {id}}}) => id); 18 | } 19 | } 20 | 21 | function submitBuildRequestUrl(projectId) { 22 | return `https://cloudbuild.googleapis.com/v1/projects/${projectId}/builds`; 23 | } 24 | 25 | module.exports.submitBuildRequestUrl = submitBuildRequestUrl; 26 | -------------------------------------------------------------------------------- /test/build-requests.test.js: -------------------------------------------------------------------------------- 1 | import dockerParseImage from 'docker-parse-image'; 2 | 3 | import buildRequests from '../src/build-requests'; 4 | 5 | const projectId = 'projectId'; 6 | const repoName = 'repoName'; 7 | 8 | describe('`buildRequests()`', () => { 9 | 10 | const tagName1 = 'tag1'; 11 | const tagName2 = 'tag2'; 12 | const commitSha1 = '19a0cee5919812aae6ccabea10855b3848f3d72b'; 13 | const commitSha2 = '3801c83e4f36e6cb2a26f7734b1fd7b631112724'; 14 | const image1 = `registry/namespace/repository:${tagName1}`; 15 | const image2 = `registry/namespace/repository:${tagName2}`; 16 | const image3 = `registry/namespace/repository:${commitSha1}`; 17 | const image4 = `registry/namespace/repository:${commitSha2}`; 18 | 19 | const build1 = { steps: ['step1'] }; 20 | const build2 = { steps: ['step2'] }; 21 | const build3 = { steps: ['step3'] }; 22 | const build4 = { steps: ['step4'] }; 23 | 24 | const containerBuild1 = { 25 | tagName: tagName1, 26 | image: dockerParseImage(image1), 27 | build: build1, 28 | }; 29 | const containerBuild2 = { 30 | tagName: tagName2, 31 | image: dockerParseImage(image2), 32 | build: build2, 33 | }; 34 | const containerBuild3 = { 35 | commitSha: commitSha1, 36 | image: dockerParseImage(image3), 37 | build: build3, 38 | }; 39 | const containerBuild4 = { 40 | commitSha: commitSha2, 41 | image: dockerParseImage(image4), 42 | build: build4, 43 | }; 44 | 45 | test('two different tags', () => { 46 | const containerBuilds = [containerBuild1, containerBuild2]; 47 | const requests = buildRequests({projectId, repoName, containerBuilds}); 48 | expect(requests).toEqual([{ 49 | source: { 50 | repoSource: { 51 | projectId, 52 | repoName, 53 | tagName: tagName1, 54 | }, 55 | }, 56 | steps: build1.steps, 57 | images: [image1] 58 | }, { 59 | source: { 60 | repoSource: { 61 | projectId, 62 | repoName, 63 | tagName: tagName2, 64 | }, 65 | }, 66 | steps: build2.steps, 67 | images: [image2] 68 | }]); 69 | }); 70 | 71 | test('two different commitSha', () => { 72 | const containerBuilds = [containerBuild3, containerBuild4]; 73 | const requests = buildRequests({projectId, repoName, containerBuilds}); 74 | expect(requests).toEqual([{ 75 | source: { 76 | repoSource: { 77 | projectId, 78 | repoName, 79 | commitSha: commitSha1, 80 | }, 81 | }, 82 | steps: build3.steps, 83 | images: [image3] 84 | }, { 85 | source: { 86 | repoSource: { 87 | projectId, 88 | repoName, 89 | commitSha: commitSha2, 90 | }, 91 | }, 92 | steps: build4.steps, 93 | images: [image4] 94 | }]); 95 | }); 96 | 97 | test('a tag and a commitSha', () => { 98 | const containerBuilds = [containerBuild2, containerBuild3]; 99 | const requests = buildRequests({projectId, repoName, containerBuilds}); 100 | expect(requests).toEqual([{ 101 | source: { 102 | repoSource: { 103 | projectId, 104 | repoName, 105 | tagName: tagName2, 106 | }, 107 | }, 108 | steps: build2.steps, 109 | images: [image2] 110 | }, { 111 | source: { 112 | repoSource: { 113 | projectId, 114 | repoName, 115 | commitSha: commitSha1, 116 | }, 117 | }, 118 | steps: build3.steps, 119 | images: [image3] 120 | }]); 121 | }); 122 | 123 | test('a commitSha and a tag', () => { 124 | const containerBuilds = [containerBuild3, containerBuild2]; 125 | const requests = buildRequests({projectId, repoName, containerBuilds}); 126 | expect(requests).toEqual([{ 127 | source: { 128 | repoSource: { 129 | projectId, 130 | repoName, 131 | commitSha: commitSha1, 132 | }, 133 | }, 134 | steps: build3.steps, 135 | images: [image3] 136 | }, { 137 | source: { 138 | repoSource: { 139 | projectId, 140 | repoName, 141 | tagName: tagName2, 142 | }, 143 | }, 144 | steps: build2.steps, 145 | images: [image2] 146 | }]); 147 | }); 148 | }); 149 | 150 | -------------------------------------------------------------------------------- /test/compile-required-images.test.js: -------------------------------------------------------------------------------- 1 | import dockerParseImage from 'docker-parse-image'; 2 | 3 | import compileRequiredImages, {REPEAT_ERROR} from '../src/compile-required-images'; 4 | 5 | describe('`compileManifest()`', () => { 6 | 7 | const manifest = 'manifest'; 8 | const projectId = 'projectId'; 9 | const containerBuild = {image: {fullname: 'image'}, build: {}}; 10 | 11 | function getIsSupported() { 12 | return jest.fn().mockReturnValue(true); 13 | } 14 | 15 | function getCompareBuilds() { 16 | return jest.fn().mockReturnValue(true); 17 | } 18 | 19 | test('ignores unsupported kubernetes types', () => { 20 | const isSupported = jest.fn().mockReturnValue(false); 21 | const manifestContainerBuilds = jest.fn().mockReturnValue([containerBuild]); 22 | const compareBuilds = getCompareBuilds(); 23 | const fn = compileRequiredImages({isSupported, manifestContainerBuilds, compareBuilds}); 24 | expect(fn(projectId, [manifest])).toEqual([]); 25 | expect(isSupported).toBeCalledWith(manifest); 26 | }); 27 | 28 | test('works within a single manifest', () => { 29 | const isSupported = getIsSupported(); 30 | const containerBuild1 = {image: {fullname: 'image1'}}; 31 | const containerBuild2 = {image: {fullname: 'image2'}}; 32 | const manifestContainerBuilds = jest.fn().mockReturnValue([containerBuild1, containerBuild2]); 33 | const compareBuilds = getCompareBuilds(); 34 | const fn = compileRequiredImages({isSupported, manifestContainerBuilds, compareBuilds}); 35 | expect(fn(projectId, [manifest])).toEqual([containerBuild1, containerBuild2]); 36 | expect(manifestContainerBuilds).toBeCalledWith(projectId, manifest); 37 | }); 38 | 39 | test('works across manifests', () => { 40 | const isSupported = getIsSupported(); 41 | const containerBuild1 = {image: {fullname: 'image1'}}; 42 | const containerBuild2 = {image: {fullname: 'image2'}}; 43 | const manifestContainerBuilds = jest.fn() 44 | .mockReturnValueOnce([containerBuild1]) 45 | .mockReturnValueOnce([containerBuild2]); 46 | const compareBuilds = getCompareBuilds(); 47 | const fn = compileRequiredImages({isSupported, manifestContainerBuilds, compareBuilds}); 48 | expect(fn(projectId, [manifest, manifest])).toEqual([containerBuild1, containerBuild2]); 49 | expect(manifestContainerBuilds.mock.calls[0]).toEqual([projectId, manifest]); 50 | expect(manifestContainerBuilds.mock.calls[1]).toEqual([projectId, manifest]); 51 | }); 52 | 53 | test('de-duplicates duplicate container builds within a single manifest', () => { 54 | const isSupported = getIsSupported(); 55 | const manifestContainerBuilds = jest.fn() 56 | .mockReturnValue([containerBuild, containerBuild]); 57 | const compareBuilds = getCompareBuilds(); 58 | const fn = compileRequiredImages({isSupported, manifestContainerBuilds, compareBuilds}); 59 | expect(fn(projectId, [manifest])).toEqual([containerBuild]); 60 | expect(manifestContainerBuilds.mock.calls[0]).toEqual([projectId, manifest]); 61 | }); 62 | 63 | test('de-duplicates duplicate container builds across manifests', () => { 64 | const isSupported = getIsSupported(); 65 | const manifestContainerBuilds = jest.fn() 66 | .mockReturnValueOnce([containerBuild]) 67 | .mockReturnValueOnce([containerBuild]); 68 | const compareBuilds = getCompareBuilds(); 69 | const fn = compileRequiredImages({isSupported, manifestContainerBuilds, compareBuilds}); 70 | expect(fn(projectId, [manifest, manifest])).toEqual([containerBuild]); 71 | expect(manifestContainerBuilds.mock.calls[0]).toEqual([projectId, manifest]); 72 | expect(manifestContainerBuilds.mock.calls[1]).toEqual([projectId, manifest]); 73 | }); 74 | 75 | test('fails when repeat container builds have different builds', () => { 76 | const isSupported = getIsSupported(); 77 | const manifestContainerBuilds = jest.fn().mockReturnValue([containerBuild, containerBuild]); 78 | const compareBuilds = jest.fn().mockReturnValue(false); 79 | const fn = compileRequiredImages({isSupported, manifestContainerBuilds, compareBuilds}); 80 | expect(() => fn(projectId, [manifest])).toThrow(REPEAT_ERROR); 81 | }); 82 | }); 83 | -------------------------------------------------------------------------------- /test/confirm-submit.test.js: -------------------------------------------------------------------------------- 1 | import confirmSubmit from '../src/confirm-submit'; 2 | import stringify from '../src/stringify'; 3 | 4 | describe('`confirmSubmit()`', () => { 5 | 6 | test('works', async () => { 7 | const log = jest.fn(); 8 | const result = true; 9 | const inquirer = jest.fn().mockReturnValue(Promise.resolve(result)); 10 | const request = {}; 11 | expect(await confirmSubmit({log, inquirer})([request, request])).toBe(result); 12 | expect(log).toBeCalledWith(stringify(request)); 13 | expect(log).toHaveBeenCalledTimes(2); 14 | expect(inquirer).toBeCalledWith({ 15 | type: 'confirm', 16 | name: 'confirmed', 17 | message: 'Do you want to submit these build requests?', 18 | default: false, 19 | }); 20 | }); 21 | }); 22 | 23 | -------------------------------------------------------------------------------- /test/filter-missing-images.test.js: -------------------------------------------------------------------------------- 1 | import filterMissingImages from '../src/filter-missing-images'; 2 | 3 | describe('`filterMissingImages()`', () => { 4 | 5 | const projectId = 'projectId'; 6 | const token = 'token'; 7 | const repository = 'repository'; 8 | const tag = 'tag'; 9 | const containerBuilds = [{image: {repository, tag}}]; 10 | 11 | test('identifies container builds that are missing', async () => { 12 | const listTags = jest.fn().mockReturnValue(Promise.resolve([])); 13 | expect(await filterMissingImages({listTags})(containerBuilds, projectId, token)).toEqual(containerBuilds); 14 | expect(listTags).toHaveBeenCalledWith(repository, projectId, token); 15 | }); 16 | 17 | test('identifies container builds that are not missing', async () => { 18 | const listTags = jest.fn().mockReturnValue(Promise.resolve([tag])); 19 | expect(await filterMissingImages({listTags})(containerBuilds, projectId, token)).toEqual([]); 20 | expect(listTags).toHaveBeenCalledWith(repository, projectId, token); 21 | }); 22 | }); 23 | 24 | -------------------------------------------------------------------------------- /test/get-config.fixture.gcloud-config-helper-output.json: -------------------------------------------------------------------------------- 1 | { 2 | "configuration": { 3 | "active_configuration": "default", 4 | "properties": { 5 | "core": { 6 | "account": "account", 7 | "disable_usage_reporting": "True", 8 | "project": "projectId" 9 | } 10 | } 11 | }, 12 | "credential": { 13 | "access_token": "token", 14 | "token_expiry": "2017-11-20T20:39:27Z" 15 | }, 16 | "sentinels": { 17 | "config_sentinel": "/Users/dmitry/.config/gcloud/config_sentinel" 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /test/get-config.test.js: -------------------------------------------------------------------------------- 1 | import fs from 'fs'; 2 | 3 | import getConfig from '../src/get-config.js'; 4 | 5 | const {CMD_CONFIG} = getConfig; 6 | 7 | describe('`getConfig()`', () => { 8 | 9 | test('works', async () => { 10 | const result = fs.readFileSync(`${__dirname}/get-config.fixture.gcloud-config-helper-output.json`, 'utf-8'); 11 | const exec = jest.fn((cmd, cb) => cb(null, result)); 12 | expect(await getConfig({exec})()).toEqual({token: 'token', projectId: 'projectId'}); 13 | expect(exec.mock.calls[0][0]).toBe(CMD_CONFIG); 14 | }); 15 | }); 16 | -------------------------------------------------------------------------------- /test/get-options.test.js: -------------------------------------------------------------------------------- 1 | import getOptions from '../src/get-options'; 2 | 3 | describe('`getOptions()`', () => { 4 | 5 | test('fails when repoName not specified', () => { 6 | const file = 'file'; 7 | const repoName = 'repoName'; 8 | const process = {argv: [0, 1, 2]} 9 | const minimist = jest.fn().mockReturnValue({f: file}); 10 | expect(() => getOptions({process, minimist})()).toThrow('repoName (-r) required'); 11 | }); 12 | 13 | test('works', () => { 14 | const file = 'file'; 15 | const repoName = 'repoName'; 16 | const process = {argv: [0, 1, 2]} 17 | const minimist = jest.fn().mockReturnValue({f: file, r: repoName}); 18 | expect(getOptions({process, minimist})()).toEqual({file, repoName}); 19 | expect(minimist).toBeCalledWith([2]); 20 | }); 21 | }); 22 | -------------------------------------------------------------------------------- /test/list-tags.fixture.result.json: -------------------------------------------------------------------------------- 1 | { 2 | "child": [], 3 | "manifest": { 4 | "sha256:0e3d2ece2ae9bbe8c0234beb0968c1461955e8f8d1b07616293a720b3c1d64a9": { 5 | "imageSizeBytes": "310391515", 6 | "layerId": "", 7 | "mediaType": "application/vnd.docker.distribution.manifest.v2+json", 8 | "tag": [ 9 | "90a0a34c6d85aa439c2be9baefbef091b86369e1" 10 | ], 11 | "timeCreatedMs": "1510541605759", 12 | "timeUploadedMs": "1510541641433" 13 | }, 14 | "sha256:276ca0e408d0e84a2f5151381e6e2a1b9afbda20773c42ac44e32849cfcb2936": { 15 | "imageSizeBytes": "310391570", 16 | "layerId": "", 17 | "mediaType": "application/vnd.docker.distribution.manifest.v2+json", 18 | "tag": [ 19 | "ecd6a597f7a54c3dc878525577c4a8af8ce271cf" 20 | ], 21 | "timeCreatedMs": "1510691151291", 22 | "timeUploadedMs": "1510691327330" 23 | }, 24 | "sha256:baf170e4b0610371d53f058be2b1662ecc85f7edb4b0edb4a1db0198717fd090": { 25 | "imageSizeBytes": "310391717", 26 | "layerId": "", 27 | "mediaType": "application/vnd.docker.distribution.manifest.v2+json", 28 | "tag": [], 29 | "timeCreatedMs": "1510685190397", 30 | "timeUploadedMs": "1510685368672" 31 | } 32 | }, 33 | "name": "some-project-712678/some-repository", 34 | "tags": [ 35 | "90a0a34c6d85aa439c2be9baefbef091b86369e1", 36 | "ecd6a597f7a54c3dc878525577c4a8af8ce271cf" 37 | ] 38 | } 39 | -------------------------------------------------------------------------------- /test/list-tags.test.js: -------------------------------------------------------------------------------- 1 | import listTags from '../src/list-tags'; 2 | import authorization from '../src/authorization'; 3 | 4 | const {listTagsUrl} = listTags; 5 | 6 | describe('`listTags()`', () => { 7 | const projectId = 'projectId'; 8 | const repository = 'repository'; 9 | const token = 'token'; 10 | 11 | const result = require('fs').readFileSync(`${__dirname}/list-tags.fixture.result.json`, 'utf-8'); 12 | const resultTags = ['90a0a34c6d85aa439c2be9baefbef091b86369e1', 'ecd6a597f7a54c3dc878525577c4a8af8ce271cf']; 13 | const request = jest.fn().mockReturnValue(Promise.resolve(result)); 14 | 15 | test('works', async () => { 16 | const tags = await listTags({request})(repository, projectId, token); 17 | expect(tags).toEqual(resultTags); 18 | expect(request).toBeCalledWith({ 19 | url: listTagsUrl(projectId, repository), 20 | headers: { 21 | ...authorization(token) 22 | }, 23 | }); 24 | }); 25 | }); 26 | 27 | -------------------------------------------------------------------------------- /test/log-build.test.js: -------------------------------------------------------------------------------- 1 | import logBuild from '../src/log-build'; 2 | 3 | const {cmdLogStream} = logBuild; 4 | 5 | describe('`logBuild()`', () => { 6 | 7 | test('works', async () => { 8 | const result = 'result'; 9 | const process = {stdout: 'stdout'}; 10 | const pipe = jest.fn(); 11 | const on = jest.fn((event, fn) => { 12 | if (event === 'end') { 13 | setTimeout(() => fn(result), 0); 14 | } 15 | }); 16 | const childProcess = {stdout: {pipe, on}}; 17 | const exec = jest.fn().mockReturnValue(childProcess); 18 | const id = 'id'; 19 | expect(await logBuild({process, exec})(id)).toEqual(result); 20 | expect(exec).toBeCalledWith(cmdLogStream(id)); 21 | expect(pipe).toBeCalledWith(process.stdout); 22 | }); 23 | }); 24 | 25 | -------------------------------------------------------------------------------- /test/manifest-container-builds.test.js: -------------------------------------------------------------------------------- 1 | import dockerParseImage from 'docker-parse-image'; 2 | 3 | import manifestContainerBuilds from '../src/manifest-container-builds'; 4 | 5 | describe('`manifestContainerBuilds(manifest)`', () => { 6 | 7 | const projectId = 'projectId'; 8 | const manifest = 'manifest'; 9 | const tag = 'tag'; 10 | const image = `gcr.io/${projectId}/image:${tag}`; 11 | 12 | function mockGetContainers(image) { 13 | return jest.fn().mockReturnValue([{name: 'container', image}]); 14 | } 15 | 16 | function mockGetBuilds() { 17 | return jest.fn().mockReturnValue([{container: 'container'}]); 18 | } 19 | 20 | test('ignores containers with unsupported images', () => { 21 | const unsupportedImages = [ 22 | 'busybox', 23 | 'gcr.io/some/image', 24 | `gcr.io/${projectId}/image`, 25 | `gcr.io/${projectId}/image:latest` 26 | ] 27 | unsupportedImages.forEach(image => { 28 | const getContainers = mockGetContainers(image); 29 | const getBuilds = mockGetBuilds(); 30 | const fn = manifestContainerBuilds({getContainers, getBuilds}); 31 | expect(fn(projectId, manifest)).toEqual([]); 32 | }); 33 | }); 34 | 35 | test('ignores containers with empty build annotiations', () => { 36 | const getContainers = mockGetContainers(image); 37 | const getBuilds = jest.fn().mockReturnValue([]); 38 | const fn = manifestContainerBuilds({getContainers, getBuilds}); 39 | expect(fn(projectId, manifest)).toEqual([]); 40 | }); 41 | 42 | test('ignores containers without build annotiation', () => { 43 | const getContainers = mockGetContainers(image); 44 | const getBuilds = jest.fn().mockReturnValue(null); 45 | const fn = manifestContainerBuilds({getContainers, getBuilds}); 46 | expect(fn(projectId, manifest)).toEqual([]); 47 | }); 48 | 49 | test('handles image tagged with a tag', () => { 50 | const image = `gcr.io/${projectId}/image:${tag}`; 51 | const getContainers = mockGetContainers(image); 52 | const getBuilds = mockGetBuilds(); 53 | const fn = manifestContainerBuilds({getContainers, getBuilds}); 54 | expect(fn(projectId, manifest)).toEqual([{ 55 | tagName: tag, 56 | image: dockerParseImage(image), 57 | build: getBuilds()[0], 58 | }]); 59 | }); 60 | 61 | test('handles images tagged with a commit', () => { 62 | const commitSha = 'c485b392c587652b74623d3694a7888c3b5ce259'; 63 | const image = `gcr.io/${projectId}/image:${commitSha}`; 64 | const getContainers = mockGetContainers(image); 65 | const getBuilds = mockGetBuilds(); 66 | const fn = manifestContainerBuilds({getContainers, getBuilds}); 67 | expect(fn(projectId, manifest)).toEqual([{ 68 | commitSha, 69 | image: dockerParseImage(image), 70 | build: getBuilds()[0], 71 | }]); 72 | }); 73 | }); 74 | 75 | 76 | 77 | -------------------------------------------------------------------------------- /test/manifest.test.js: -------------------------------------------------------------------------------- 1 | import { 2 | getContainers, 3 | getBuilds, 4 | BUILD_INSTRUCTIONS_ANNOTATION 5 | } from '../src/manifest'; 6 | 7 | const projectId = 'project-id'; 8 | const initContainer = {image: 'init-container-image'}; 9 | const container = {image: 'container-image'}; 10 | const containers = [initContainer, container]; 11 | const builds = []; 12 | 13 | describe('`getContainers()` gets all containers from a manifest', () => { 14 | 15 | test('works with Pods', () => expect(getContainers(podManifest())).toEqual(containers)); 16 | test('works with Deployments', () => expect(getContainers(deploymentManifest())).toEqual(containers)); 17 | test('works with DaemonSets', () => expect(getContainers(daemonSetManifest())).toEqual(containers)); 18 | test('works with Jobs', () => expect(getContainers(jobManifest())).toEqual(containers)); 19 | test('works with ReplicaSets', () => expect(getContainers(replicaSetManifest())).toEqual(containers)); 20 | test('works with ReplicationControllers', () => expect(getContainers(replicationControllerManifest())).toEqual(containers)); 21 | test('works with StatefulSets', () => expect(getContainers(statefulSetManifest())).toEqual(containers)); 22 | test('works with CronJobs', () => expect(getContainers(cronJobManifest())).toEqual(containers)); 23 | }); 24 | 25 | describe('`getBuilds()` gets build instructions from a manifest', () => { 26 | 27 | test('works with Pods', () => expect(getBuilds(podManifest())).toEqual(builds)); 28 | test('works with Deployments', () => expect(getBuilds(deploymentManifest())).toEqual(builds)); 29 | test('works with DaemonSets', () => expect(getBuilds(daemonSetManifest())).toEqual(builds)); 30 | test('works with Jobs', () => expect(getBuilds(jobManifest())).toEqual(builds)); 31 | test('works with ReplicaSets', () => expect(getBuilds(replicaSetManifest())).toEqual(builds)); 32 | test('works with ReplicationControllers', () => expect(getBuilds(replicationControllerManifest())).toEqual(builds)); 33 | test('works with StatefulSets', () => expect(getBuilds(statefulSetManifest())).toEqual(builds)); 34 | test('works with CronJobs', () => expect(getBuilds(cronJobManifest())).toEqual(builds)); 35 | }); 36 | 37 | function podManifest() { 38 | return { 39 | kind: 'Pod', 40 | metadata: metadata(), 41 | spec: podSpec(), 42 | }; 43 | } 44 | 45 | function deploymentManifest() { 46 | return { 47 | kind: 'Deployment', 48 | spec: { 49 | template: podTemplateSpec() 50 | } 51 | }; 52 | } 53 | 54 | function daemonSetManifest() { 55 | return { 56 | kind: 'DaemonSet', 57 | spec: { 58 | template: podTemplateSpec() 59 | } 60 | }; 61 | } 62 | 63 | function jobManifest() { 64 | return { 65 | kind: 'Job', 66 | spec: { 67 | template: podTemplateSpec() 68 | } 69 | }; 70 | } 71 | 72 | function replicaSetManifest() { 73 | return { 74 | kind: 'ReplicaSet', 75 | spec: { 76 | template: podTemplateSpec() 77 | } 78 | }; 79 | } 80 | 81 | function replicationControllerManifest() { 82 | return { 83 | kind: 'ReplicationController', 84 | spec: { 85 | template: podTemplateSpec() 86 | } 87 | }; 88 | } 89 | 90 | function statefulSetManifest() { 91 | return { 92 | kind: 'StatefulSet', 93 | spec: { 94 | template: podTemplateSpec() 95 | } 96 | }; 97 | } 98 | 99 | function cronJobManifest() { 100 | return { 101 | kind: 'CronJob', 102 | spec: { 103 | jobTemplate: { 104 | spec: { 105 | template: podTemplateSpec() 106 | } 107 | } 108 | } 109 | }; 110 | } 111 | 112 | function podTemplateSpec() { 113 | return { 114 | metadata: metadata(), 115 | spec: podSpec(), 116 | }; 117 | } 118 | 119 | // TODO add cases where `containers` or `initContainers` are missing 120 | function podSpec() { 121 | return { 122 | containers: [container], 123 | initContainers: [initContainer], 124 | } 125 | } 126 | 127 | function metadata() { 128 | return { 129 | annotations: { 130 | [BUILD_INSTRUCTIONS_ANNOTATION]: JSON.stringify(builds), 131 | } 132 | }; 133 | } 134 | -------------------------------------------------------------------------------- /test/parse-input-yaml.test.js: -------------------------------------------------------------------------------- 1 | import parseInputYaml from '../src/parse-input-yaml'; 2 | 3 | describe('`parseInputYaml()`', () => { 4 | 5 | const stream = 'stream'; 6 | const agg = 'agg'; 7 | const parsed = 'parsed'; 8 | const fs = {createReadStream: jest.fn().mockReturnValue(stream)}; 9 | const rawBody = jest.fn().mockReturnValue(Promise.resolve(agg)); 10 | const jsYaml = {safeLoadAll: jest.fn().mockReturnValue(parsed)}; 11 | 12 | test('gets from specified file', async () => { 13 | const file = 'file'; 14 | expect(await parseInputYaml({fs, rawBody, jsYaml})(file)).toEqual(parsed); 15 | expect(fs.createReadStream).toBeCalledWith(file); 16 | expect(rawBody).toBeCalledWith(stream, {encoding: 'utf-8'}); 17 | expect(jsYaml.safeLoadAll).toBeCalledWith(agg); 18 | }); 19 | 20 | test('gets from stdin when file not specified', async () => { 21 | const process = {stdin: stream}; 22 | expect(await parseInputYaml({fs, rawBody, jsYaml, process})()).toEqual(parsed); 23 | expect(rawBody).toBeCalledWith(stream, {encoding: 'utf-8'}); 24 | expect(jsYaml.safeLoadAll).toBeCalledWith(agg); 25 | }) 26 | }); 27 | 28 | -------------------------------------------------------------------------------- /test/select-images.test.js: -------------------------------------------------------------------------------- 1 | import selectImages from '../src/select-images'; 2 | 3 | describe('`selectImages()`', () => { 4 | 5 | test('works', async () => { 6 | const inquirer = jest.fn().mockReturnValue(Promise.resolve({images: ['image2']})); 7 | const selectedImages = await selectImages({inquirer})([ 8 | {image: {fullname: 'image1'}}, 9 | {image: {fullname: 'image2'}}, 10 | ]); 11 | expect(selectedImages).toEqual([ 12 | {image: {fullname: 'image2'}}, 13 | ]); 14 | expect(inquirer).toHaveBeenCalledWith({ 15 | type: 'checkbox', 16 | message: 'The following images are missing from Google Container Registry. Choose the ones you want to build:', 17 | name: 'images', 18 | choices: [{name: 'image1'}, {name: 'image2'}], 19 | }); 20 | }); 21 | }); 22 | 23 | -------------------------------------------------------------------------------- /test/submit-build-request.fixture.result.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "operations/build/some-project-712678/MjBjNGRmMWQtZTcxYi00MDg1LTlhMzAtZDc2YjI3NDdkOGFk", 3 | "metadata": { 4 | "@type": "type.googleapis.com/google.devtools.cloudbuild.v1.BuildOperationMetadata", 5 | "build": { 6 | "id": "20c4df1d-e71b-4085-9a30-d76b2747d8ad", 7 | "status": "QUEUED", 8 | "source": { 9 | "repoSource": { 10 | "projectId": "some-project-712678", 11 | "repoName": "some-repository", 12 | "commitSha": "ecd6a597f7a54c3dc878525577c4a8af8ce271cf" 13 | } 14 | }, 15 | "createTime": "2017-11-19T19:15:30.951939918Z", 16 | "steps": [ 17 | { 18 | "name": "gcr.io/cloud-builders/docker", 19 | "args": [ 20 | "build", 21 | "-t", 22 | "gcr.io/some-project-712678/zookeeper:ecd6a597f7a54c3dc878525577c4a8af8ce271cf", 23 | "." 24 | ], 25 | "dir": "deploy/zookeeper" 26 | } 27 | ], 28 | "timeout": "600s", 29 | "images": [ 30 | "gcr.io/some-project-712678/zookeeper:ecd6a597f7a54c3dc878525577c4a8af8ce271cf" 31 | ], 32 | "projectId": "some-project-712678", 33 | "logsBucket": "gs://784456456234.cloudbuild-logs.googleusercontent.com", 34 | "sourceProvenance": { 35 | "resolvedRepoSource": { 36 | "projectId": "some-project-712678", 37 | "repoName": "some-repository", 38 | "commitSha": "ecd6a597f7a54c3dc878525577c4a8af8ce271cf" 39 | } 40 | }, 41 | "logUrl": "https://console.cloud.google.com/gcr/builds/20c4df1d-e71b-4085-9a30-d76b2747d8ad?project=some-project-712678" 42 | } 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /test/submit-build-request.test.js: -------------------------------------------------------------------------------- 1 | import submitBuildRequest from '../src/submit-build-request'; 2 | import authorization from '../src/authorization'; 3 | 4 | const {submitBuildRequestUrl} = submitBuildRequest; 5 | 6 | describe('`submitBuildRequest()`', () => { 7 | const projectId = 'projectId'; 8 | const repository = 'repository'; 9 | const token = 'token'; 10 | 11 | const result = require('fs').readFileSync(`${__dirname}/submit-build-request.fixture.result.json`, 'utf-8'); 12 | const resultId = '20c4df1d-e71b-4085-9a30-d76b2747d8ad'; 13 | const request = jest.fn().mockReturnValue(Promise.resolve(result)); 14 | 15 | test('works', async () => { 16 | const buildRequest = {}; 17 | const id = await submitBuildRequest({request})({buildRequest, projectId, token}); 18 | expect(id).toBe(resultId); 19 | expect(request).toBeCalledWith({ 20 | url: submitBuildRequestUrl(projectId), 21 | method: 'POST', 22 | headers: { 23 | 'Content-Type': 'application/json', 24 | ...authorization(token), 25 | }, 26 | body: JSON.stringify(buildRequest), 27 | }); 28 | }); 29 | }); 30 | 31 | -------------------------------------------------------------------------------- /yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | abab@^1.0.3: 6 | version "1.0.4" 7 | resolved "https://registry.yarnpkg.com/abab/-/abab-1.0.4.tgz#5faad9c2c07f60dd76770f71cf025b62a63cfd4e" 8 | 9 | abbrev@1: 10 | version "1.1.1" 11 | resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" 12 | 13 | acorn-globals@^3.1.0: 14 | version "3.1.0" 15 | resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-3.1.0.tgz#fd8270f71fbb4996b004fa880ee5d46573a731bf" 16 | dependencies: 17 | acorn "^4.0.4" 18 | 19 | acorn@^4.0.4: 20 | version "4.0.13" 21 | resolved "https://registry.yarnpkg.com/acorn/-/acorn-4.0.13.tgz#105495ae5361d697bd195c825192e1ad7f253787" 22 | 23 | ajv@^4.9.1: 24 | version "4.11.8" 25 | resolved "https://registry.yarnpkg.com/ajv/-/ajv-4.11.8.tgz#82ffb02b29e662ae53bdc20af15947706739c536" 26 | dependencies: 27 | co "^4.6.0" 28 | json-stable-stringify "^1.0.1" 29 | 30 | ajv@^5.1.0: 31 | version "5.4.0" 32 | resolved "https://registry.yarnpkg.com/ajv/-/ajv-5.4.0.tgz#32d1cf08dbc80c432f426f12e10b2511f6b46474" 33 | dependencies: 34 | co "^4.6.0" 35 | fast-deep-equal "^1.0.0" 36 | fast-json-stable-stringify "^2.0.0" 37 | json-schema-traverse "^0.3.0" 38 | 39 | align-text@^0.1.1, align-text@^0.1.3: 40 | version "0.1.4" 41 | resolved "https://registry.yarnpkg.com/align-text/-/align-text-0.1.4.tgz#0cd90a561093f35d0a99256c22b7069433fad117" 42 | dependencies: 43 | kind-of "^3.0.2" 44 | longest "^1.0.1" 45 | repeat-string "^1.5.2" 46 | 47 | amdefine@>=0.0.4: 48 | version "1.0.1" 49 | resolved "https://registry.yarnpkg.com/amdefine/-/amdefine-1.0.1.tgz#4a5282ac164729e93619bcfd3ad151f817ce91f5" 50 | 51 | ansi-escapes@^3.0.0: 52 | version "3.0.0" 53 | resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-3.0.0.tgz#ec3e8b4e9f8064fc02c3ac9b65f1c275bda8ef92" 54 | 55 | ansi-regex@^2.0.0: 56 | version "2.1.1" 57 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" 58 | 59 | ansi-regex@^3.0.0: 60 | version "3.0.0" 61 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998" 62 | 63 | ansi-styles@^2.2.1: 64 | version "2.2.1" 65 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz#b432dd3358b634cf75e1e4664368240533c1ddbe" 66 | 67 | ansi-styles@^3.1.0, ansi-styles@^3.2.0: 68 | version "3.2.0" 69 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.0.tgz#c159b8d5be0f9e5a6f346dab94f16ce022161b88" 70 | dependencies: 71 | color-convert "^1.9.0" 72 | 73 | anymatch@^1.3.0: 74 | version "1.3.2" 75 | resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-1.3.2.tgz#553dcb8f91e3c889845dfdba34c77721b90b9d7a" 76 | dependencies: 77 | micromatch "^2.1.5" 78 | normalize-path "^2.0.0" 79 | 80 | append-transform@^0.4.0: 81 | version "0.4.0" 82 | resolved "https://registry.yarnpkg.com/append-transform/-/append-transform-0.4.0.tgz#d76ebf8ca94d276e247a36bad44a4b74ab611991" 83 | dependencies: 84 | default-require-extensions "^1.0.0" 85 | 86 | aproba@^1.0.3: 87 | version "1.2.0" 88 | resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.2.0.tgz#6802e6264efd18c790a1b0d517f0f2627bf2c94a" 89 | 90 | are-we-there-yet@~1.1.2: 91 | version "1.1.4" 92 | resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz#bb5dca382bb94f05e15194373d16fd3ba1ca110d" 93 | dependencies: 94 | delegates "^1.0.0" 95 | readable-stream "^2.0.6" 96 | 97 | argparse@^1.0.7: 98 | version "1.0.9" 99 | resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.9.tgz#73d83bc263f86e97f8cc4f6bae1b0e90a7d22c86" 100 | dependencies: 101 | sprintf-js "~1.0.2" 102 | 103 | arr-diff@^2.0.0: 104 | version "2.0.0" 105 | resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-2.0.0.tgz#8f3b827f955a8bd669697e4a4256ac3ceae356cf" 106 | dependencies: 107 | arr-flatten "^1.0.1" 108 | 109 | arr-flatten@^1.0.1: 110 | version "1.1.0" 111 | resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1" 112 | 113 | array-equal@^1.0.0: 114 | version "1.0.0" 115 | resolved "https://registry.yarnpkg.com/array-equal/-/array-equal-1.0.0.tgz#8c2a5ef2472fd9ea742b04c77a75093ba2757c93" 116 | 117 | array-unique@^0.2.1: 118 | version "0.2.1" 119 | resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.2.1.tgz#a1d97ccafcbc2625cc70fadceb36a50c58b01a53" 120 | 121 | arrify@^1.0.1: 122 | version "1.0.1" 123 | resolved "https://registry.yarnpkg.com/arrify/-/arrify-1.0.1.tgz#898508da2226f380df904728456849c1501a4b0d" 124 | 125 | asn1@~0.2.3: 126 | version "0.2.3" 127 | resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.3.tgz#dac8787713c9966849fc8180777ebe9c1ddf3b86" 128 | 129 | assert-plus@1.0.0, assert-plus@^1.0.0: 130 | version "1.0.0" 131 | resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" 132 | 133 | assert-plus@^0.2.0: 134 | version "0.2.0" 135 | resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-0.2.0.tgz#d74e1b87e7affc0db8aadb7021f3fe48101ab234" 136 | 137 | astral-regex@^1.0.0: 138 | version "1.0.0" 139 | resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-1.0.0.tgz#6c8c3fb827dd43ee3918f27b82782ab7658a6fd9" 140 | 141 | async-each@^1.0.0: 142 | version "1.0.1" 143 | resolved "https://registry.yarnpkg.com/async-each/-/async-each-1.0.1.tgz#19d386a1d9edc6e7c1c85d388aedbcc56d33602d" 144 | 145 | async@^1.4.0: 146 | version "1.5.2" 147 | resolved "https://registry.yarnpkg.com/async/-/async-1.5.2.tgz#ec6a61ae56480c0c3cb241c95618e20892f9672a" 148 | 149 | async@^2.1.4: 150 | version "2.6.0" 151 | resolved "https://registry.yarnpkg.com/async/-/async-2.6.0.tgz#61a29abb6fcc026fea77e56d1c6ec53a795951f4" 152 | dependencies: 153 | lodash "^4.14.0" 154 | 155 | asynckit@^0.4.0: 156 | version "0.4.0" 157 | resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" 158 | 159 | aws-sign2@~0.6.0: 160 | version "0.6.0" 161 | resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.6.0.tgz#14342dd38dbcc94d0e5b87d763cd63612c0e794f" 162 | 163 | aws-sign2@~0.7.0: 164 | version "0.7.0" 165 | resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8" 166 | 167 | aws4@^1.2.1, aws4@^1.6.0: 168 | version "1.6.0" 169 | resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.6.0.tgz#83ef5ca860b2b32e4a0deedee8c771b9db57471e" 170 | 171 | babel-cli@^6.26.0: 172 | version "6.26.0" 173 | resolved "https://registry.yarnpkg.com/babel-cli/-/babel-cli-6.26.0.tgz#502ab54874d7db88ad00b887a06383ce03d002f1" 174 | dependencies: 175 | babel-core "^6.26.0" 176 | babel-polyfill "^6.26.0" 177 | babel-register "^6.26.0" 178 | babel-runtime "^6.26.0" 179 | commander "^2.11.0" 180 | convert-source-map "^1.5.0" 181 | fs-readdir-recursive "^1.0.0" 182 | glob "^7.1.2" 183 | lodash "^4.17.4" 184 | output-file-sync "^1.1.2" 185 | path-is-absolute "^1.0.1" 186 | slash "^1.0.0" 187 | source-map "^0.5.6" 188 | v8flags "^2.1.1" 189 | optionalDependencies: 190 | chokidar "^1.6.1" 191 | 192 | babel-code-frame@^6.26.0: 193 | version "6.26.0" 194 | resolved "https://registry.yarnpkg.com/babel-code-frame/-/babel-code-frame-6.26.0.tgz#63fd43f7dc1e3bb7ce35947db8fe369a3f58c74b" 195 | dependencies: 196 | chalk "^1.1.3" 197 | esutils "^2.0.2" 198 | js-tokens "^3.0.2" 199 | 200 | babel-core@^6.0.0, babel-core@^6.26.0: 201 | version "6.26.0" 202 | resolved "https://registry.yarnpkg.com/babel-core/-/babel-core-6.26.0.tgz#af32f78b31a6fcef119c87b0fd8d9753f03a0bb8" 203 | dependencies: 204 | babel-code-frame "^6.26.0" 205 | babel-generator "^6.26.0" 206 | babel-helpers "^6.24.1" 207 | babel-messages "^6.23.0" 208 | babel-register "^6.26.0" 209 | babel-runtime "^6.26.0" 210 | babel-template "^6.26.0" 211 | babel-traverse "^6.26.0" 212 | babel-types "^6.26.0" 213 | babylon "^6.18.0" 214 | convert-source-map "^1.5.0" 215 | debug "^2.6.8" 216 | json5 "^0.5.1" 217 | lodash "^4.17.4" 218 | minimatch "^3.0.4" 219 | path-is-absolute "^1.0.1" 220 | private "^0.1.7" 221 | slash "^1.0.0" 222 | source-map "^0.5.6" 223 | 224 | babel-generator@^6.18.0, babel-generator@^6.26.0: 225 | version "6.26.0" 226 | resolved "https://registry.yarnpkg.com/babel-generator/-/babel-generator-6.26.0.tgz#ac1ae20070b79f6e3ca1d3269613053774f20dc5" 227 | dependencies: 228 | babel-messages "^6.23.0" 229 | babel-runtime "^6.26.0" 230 | babel-types "^6.26.0" 231 | detect-indent "^4.0.0" 232 | jsesc "^1.3.0" 233 | lodash "^4.17.4" 234 | source-map "^0.5.6" 235 | trim-right "^1.0.1" 236 | 237 | babel-helper-builder-binary-assignment-operator-visitor@^6.24.1: 238 | version "6.24.1" 239 | resolved "https://registry.yarnpkg.com/babel-helper-builder-binary-assignment-operator-visitor/-/babel-helper-builder-binary-assignment-operator-visitor-6.24.1.tgz#cce4517ada356f4220bcae8a02c2b346f9a56664" 240 | dependencies: 241 | babel-helper-explode-assignable-expression "^6.24.1" 242 | babel-runtime "^6.22.0" 243 | babel-types "^6.24.1" 244 | 245 | babel-helper-call-delegate@^6.24.1: 246 | version "6.24.1" 247 | resolved "https://registry.yarnpkg.com/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz#ece6aacddc76e41c3461f88bfc575bd0daa2df8d" 248 | dependencies: 249 | babel-helper-hoist-variables "^6.24.1" 250 | babel-runtime "^6.22.0" 251 | babel-traverse "^6.24.1" 252 | babel-types "^6.24.1" 253 | 254 | babel-helper-define-map@^6.24.1: 255 | version "6.26.0" 256 | resolved "https://registry.yarnpkg.com/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz#a5f56dab41a25f97ecb498c7ebaca9819f95be5f" 257 | dependencies: 258 | babel-helper-function-name "^6.24.1" 259 | babel-runtime "^6.26.0" 260 | babel-types "^6.26.0" 261 | lodash "^4.17.4" 262 | 263 | babel-helper-explode-assignable-expression@^6.24.1: 264 | version "6.24.1" 265 | resolved "https://registry.yarnpkg.com/babel-helper-explode-assignable-expression/-/babel-helper-explode-assignable-expression-6.24.1.tgz#f25b82cf7dc10433c55f70592d5746400ac22caa" 266 | dependencies: 267 | babel-runtime "^6.22.0" 268 | babel-traverse "^6.24.1" 269 | babel-types "^6.24.1" 270 | 271 | babel-helper-function-name@^6.24.1: 272 | version "6.24.1" 273 | resolved "https://registry.yarnpkg.com/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz#d3475b8c03ed98242a25b48351ab18399d3580a9" 274 | dependencies: 275 | babel-helper-get-function-arity "^6.24.1" 276 | babel-runtime "^6.22.0" 277 | babel-template "^6.24.1" 278 | babel-traverse "^6.24.1" 279 | babel-types "^6.24.1" 280 | 281 | babel-helper-get-function-arity@^6.24.1: 282 | version "6.24.1" 283 | resolved "https://registry.yarnpkg.com/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz#8f7782aa93407c41d3aa50908f89b031b1b6853d" 284 | dependencies: 285 | babel-runtime "^6.22.0" 286 | babel-types "^6.24.1" 287 | 288 | babel-helper-hoist-variables@^6.24.1: 289 | version "6.24.1" 290 | resolved "https://registry.yarnpkg.com/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz#1ecb27689c9d25513eadbc9914a73f5408be7a76" 291 | dependencies: 292 | babel-runtime "^6.22.0" 293 | babel-types "^6.24.1" 294 | 295 | babel-helper-optimise-call-expression@^6.24.1: 296 | version "6.24.1" 297 | resolved "https://registry.yarnpkg.com/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz#f7a13427ba9f73f8f4fa993c54a97882d1244257" 298 | dependencies: 299 | babel-runtime "^6.22.0" 300 | babel-types "^6.24.1" 301 | 302 | babel-helper-regex@^6.24.1: 303 | version "6.26.0" 304 | resolved "https://registry.yarnpkg.com/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz#325c59f902f82f24b74faceed0363954f6495e72" 305 | dependencies: 306 | babel-runtime "^6.26.0" 307 | babel-types "^6.26.0" 308 | lodash "^4.17.4" 309 | 310 | babel-helper-remap-async-to-generator@^6.24.1: 311 | version "6.24.1" 312 | resolved "https://registry.yarnpkg.com/babel-helper-remap-async-to-generator/-/babel-helper-remap-async-to-generator-6.24.1.tgz#5ec581827ad723fecdd381f1c928390676e4551b" 313 | dependencies: 314 | babel-helper-function-name "^6.24.1" 315 | babel-runtime "^6.22.0" 316 | babel-template "^6.24.1" 317 | babel-traverse "^6.24.1" 318 | babel-types "^6.24.1" 319 | 320 | babel-helper-replace-supers@^6.24.1: 321 | version "6.24.1" 322 | resolved "https://registry.yarnpkg.com/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz#bf6dbfe43938d17369a213ca8a8bf74b6a90ab1a" 323 | dependencies: 324 | babel-helper-optimise-call-expression "^6.24.1" 325 | babel-messages "^6.23.0" 326 | babel-runtime "^6.22.0" 327 | babel-template "^6.24.1" 328 | babel-traverse "^6.24.1" 329 | babel-types "^6.24.1" 330 | 331 | babel-helpers@^6.24.1: 332 | version "6.24.1" 333 | resolved "https://registry.yarnpkg.com/babel-helpers/-/babel-helpers-6.24.1.tgz#3471de9caec388e5c850e597e58a26ddf37602b2" 334 | dependencies: 335 | babel-runtime "^6.22.0" 336 | babel-template "^6.24.1" 337 | 338 | babel-jest@^21.2.0: 339 | version "21.2.0" 340 | resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-21.2.0.tgz#2ce059519a9374a2c46f2455b6fbef5ad75d863e" 341 | dependencies: 342 | babel-plugin-istanbul "^4.0.0" 343 | babel-preset-jest "^21.2.0" 344 | 345 | babel-messages@^6.23.0: 346 | version "6.23.0" 347 | resolved "https://registry.yarnpkg.com/babel-messages/-/babel-messages-6.23.0.tgz#f3cdf4703858035b2a2951c6ec5edf6c62f2630e" 348 | dependencies: 349 | babel-runtime "^6.22.0" 350 | 351 | babel-plugin-check-es2015-constants@^6.22.0: 352 | version "6.22.0" 353 | resolved "https://registry.yarnpkg.com/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz#35157b101426fd2ffd3da3f75c7d1e91835bbf8a" 354 | dependencies: 355 | babel-runtime "^6.22.0" 356 | 357 | babel-plugin-istanbul@^4.0.0: 358 | version "4.1.5" 359 | resolved "https://registry.yarnpkg.com/babel-plugin-istanbul/-/babel-plugin-istanbul-4.1.5.tgz#6760cdd977f411d3e175bb064f2bc327d99b2b6e" 360 | dependencies: 361 | find-up "^2.1.0" 362 | istanbul-lib-instrument "^1.7.5" 363 | test-exclude "^4.1.1" 364 | 365 | babel-plugin-jest-hoist@^21.2.0: 366 | version "21.2.0" 367 | resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-21.2.0.tgz#2cef637259bd4b628a6cace039de5fcd14dbb006" 368 | 369 | babel-plugin-syntax-async-functions@^6.8.0: 370 | version "6.13.0" 371 | resolved "https://registry.yarnpkg.com/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz#cad9cad1191b5ad634bf30ae0872391e0647be95" 372 | 373 | babel-plugin-syntax-exponentiation-operator@^6.8.0: 374 | version "6.13.0" 375 | resolved "https://registry.yarnpkg.com/babel-plugin-syntax-exponentiation-operator/-/babel-plugin-syntax-exponentiation-operator-6.13.0.tgz#9ee7e8337290da95288201a6a57f4170317830de" 376 | 377 | babel-plugin-syntax-object-rest-spread@^6.13.0, babel-plugin-syntax-object-rest-spread@^6.8.0: 378 | version "6.13.0" 379 | resolved "https://registry.yarnpkg.com/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz#fd6536f2bce13836ffa3a5458c4903a597bb3bf5" 380 | 381 | babel-plugin-syntax-trailing-function-commas@^6.22.0: 382 | version "6.22.0" 383 | resolved "https://registry.yarnpkg.com/babel-plugin-syntax-trailing-function-commas/-/babel-plugin-syntax-trailing-function-commas-6.22.0.tgz#ba0360937f8d06e40180a43fe0d5616fff532cf3" 384 | 385 | babel-plugin-transform-async-to-generator@^6.22.0: 386 | version "6.24.1" 387 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-async-to-generator/-/babel-plugin-transform-async-to-generator-6.24.1.tgz#6536e378aff6cb1d5517ac0e40eb3e9fc8d08761" 388 | dependencies: 389 | babel-helper-remap-async-to-generator "^6.24.1" 390 | babel-plugin-syntax-async-functions "^6.8.0" 391 | babel-runtime "^6.22.0" 392 | 393 | babel-plugin-transform-es2015-arrow-functions@^6.22.0: 394 | version "6.22.0" 395 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz#452692cb711d5f79dc7f85e440ce41b9f244d221" 396 | dependencies: 397 | babel-runtime "^6.22.0" 398 | 399 | babel-plugin-transform-es2015-block-scoped-functions@^6.22.0: 400 | version "6.22.0" 401 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz#bbc51b49f964d70cb8d8e0b94e820246ce3a6141" 402 | dependencies: 403 | babel-runtime "^6.22.0" 404 | 405 | babel-plugin-transform-es2015-block-scoping@^6.23.0: 406 | version "6.26.0" 407 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz#d70f5299c1308d05c12f463813b0a09e73b1895f" 408 | dependencies: 409 | babel-runtime "^6.26.0" 410 | babel-template "^6.26.0" 411 | babel-traverse "^6.26.0" 412 | babel-types "^6.26.0" 413 | lodash "^4.17.4" 414 | 415 | babel-plugin-transform-es2015-classes@^6.23.0: 416 | version "6.24.1" 417 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz#5a4c58a50c9c9461e564b4b2a3bfabc97a2584db" 418 | dependencies: 419 | babel-helper-define-map "^6.24.1" 420 | babel-helper-function-name "^6.24.1" 421 | babel-helper-optimise-call-expression "^6.24.1" 422 | babel-helper-replace-supers "^6.24.1" 423 | babel-messages "^6.23.0" 424 | babel-runtime "^6.22.0" 425 | babel-template "^6.24.1" 426 | babel-traverse "^6.24.1" 427 | babel-types "^6.24.1" 428 | 429 | babel-plugin-transform-es2015-computed-properties@^6.22.0: 430 | version "6.24.1" 431 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz#6fe2a8d16895d5634f4cd999b6d3480a308159b3" 432 | dependencies: 433 | babel-runtime "^6.22.0" 434 | babel-template "^6.24.1" 435 | 436 | babel-plugin-transform-es2015-destructuring@^6.23.0: 437 | version "6.23.0" 438 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz#997bb1f1ab967f682d2b0876fe358d60e765c56d" 439 | dependencies: 440 | babel-runtime "^6.22.0" 441 | 442 | babel-plugin-transform-es2015-duplicate-keys@^6.22.0: 443 | version "6.24.1" 444 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz#73eb3d310ca969e3ef9ec91c53741a6f1576423e" 445 | dependencies: 446 | babel-runtime "^6.22.0" 447 | babel-types "^6.24.1" 448 | 449 | babel-plugin-transform-es2015-for-of@^6.23.0: 450 | version "6.23.0" 451 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz#f47c95b2b613df1d3ecc2fdb7573623c75248691" 452 | dependencies: 453 | babel-runtime "^6.22.0" 454 | 455 | babel-plugin-transform-es2015-function-name@^6.22.0: 456 | version "6.24.1" 457 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz#834c89853bc36b1af0f3a4c5dbaa94fd8eacaa8b" 458 | dependencies: 459 | babel-helper-function-name "^6.24.1" 460 | babel-runtime "^6.22.0" 461 | babel-types "^6.24.1" 462 | 463 | babel-plugin-transform-es2015-literals@^6.22.0: 464 | version "6.22.0" 465 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz#4f54a02d6cd66cf915280019a31d31925377ca2e" 466 | dependencies: 467 | babel-runtime "^6.22.0" 468 | 469 | babel-plugin-transform-es2015-modules-amd@^6.22.0, babel-plugin-transform-es2015-modules-amd@^6.24.1: 470 | version "6.24.1" 471 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz#3b3e54017239842d6d19c3011c4bd2f00a00d154" 472 | dependencies: 473 | babel-plugin-transform-es2015-modules-commonjs "^6.24.1" 474 | babel-runtime "^6.22.0" 475 | babel-template "^6.24.1" 476 | 477 | babel-plugin-transform-es2015-modules-commonjs@^6.23.0, babel-plugin-transform-es2015-modules-commonjs@^6.24.1: 478 | version "6.26.0" 479 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.0.tgz#0d8394029b7dc6abe1a97ef181e00758dd2e5d8a" 480 | dependencies: 481 | babel-plugin-transform-strict-mode "^6.24.1" 482 | babel-runtime "^6.26.0" 483 | babel-template "^6.26.0" 484 | babel-types "^6.26.0" 485 | 486 | babel-plugin-transform-es2015-modules-systemjs@^6.23.0: 487 | version "6.24.1" 488 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz#ff89a142b9119a906195f5f106ecf305d9407d23" 489 | dependencies: 490 | babel-helper-hoist-variables "^6.24.1" 491 | babel-runtime "^6.22.0" 492 | babel-template "^6.24.1" 493 | 494 | babel-plugin-transform-es2015-modules-umd@^6.23.0: 495 | version "6.24.1" 496 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz#ac997e6285cd18ed6176adb607d602344ad38468" 497 | dependencies: 498 | babel-plugin-transform-es2015-modules-amd "^6.24.1" 499 | babel-runtime "^6.22.0" 500 | babel-template "^6.24.1" 501 | 502 | babel-plugin-transform-es2015-object-super@^6.22.0: 503 | version "6.24.1" 504 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz#24cef69ae21cb83a7f8603dad021f572eb278f8d" 505 | dependencies: 506 | babel-helper-replace-supers "^6.24.1" 507 | babel-runtime "^6.22.0" 508 | 509 | babel-plugin-transform-es2015-parameters@^6.23.0: 510 | version "6.24.1" 511 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz#57ac351ab49caf14a97cd13b09f66fdf0a625f2b" 512 | dependencies: 513 | babel-helper-call-delegate "^6.24.1" 514 | babel-helper-get-function-arity "^6.24.1" 515 | babel-runtime "^6.22.0" 516 | babel-template "^6.24.1" 517 | babel-traverse "^6.24.1" 518 | babel-types "^6.24.1" 519 | 520 | babel-plugin-transform-es2015-shorthand-properties@^6.22.0: 521 | version "6.24.1" 522 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz#24f875d6721c87661bbd99a4622e51f14de38aa0" 523 | dependencies: 524 | babel-runtime "^6.22.0" 525 | babel-types "^6.24.1" 526 | 527 | babel-plugin-transform-es2015-spread@^6.22.0: 528 | version "6.22.0" 529 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz#d6d68a99f89aedc4536c81a542e8dd9f1746f8d1" 530 | dependencies: 531 | babel-runtime "^6.22.0" 532 | 533 | babel-plugin-transform-es2015-sticky-regex@^6.22.0: 534 | version "6.24.1" 535 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz#00c1cdb1aca71112cdf0cf6126c2ed6b457ccdbc" 536 | dependencies: 537 | babel-helper-regex "^6.24.1" 538 | babel-runtime "^6.22.0" 539 | babel-types "^6.24.1" 540 | 541 | babel-plugin-transform-es2015-template-literals@^6.22.0: 542 | version "6.22.0" 543 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz#a84b3450f7e9f8f1f6839d6d687da84bb1236d8d" 544 | dependencies: 545 | babel-runtime "^6.22.0" 546 | 547 | babel-plugin-transform-es2015-typeof-symbol@^6.23.0: 548 | version "6.23.0" 549 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz#dec09f1cddff94b52ac73d505c84df59dcceb372" 550 | dependencies: 551 | babel-runtime "^6.22.0" 552 | 553 | babel-plugin-transform-es2015-unicode-regex@^6.22.0: 554 | version "6.24.1" 555 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz#d38b12f42ea7323f729387f18a7c5ae1faeb35e9" 556 | dependencies: 557 | babel-helper-regex "^6.24.1" 558 | babel-runtime "^6.22.0" 559 | regexpu-core "^2.0.0" 560 | 561 | babel-plugin-transform-exponentiation-operator@^6.22.0: 562 | version "6.24.1" 563 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-exponentiation-operator/-/babel-plugin-transform-exponentiation-operator-6.24.1.tgz#2ab0c9c7f3098fa48907772bb813fe41e8de3a0e" 564 | dependencies: 565 | babel-helper-builder-binary-assignment-operator-visitor "^6.24.1" 566 | babel-plugin-syntax-exponentiation-operator "^6.8.0" 567 | babel-runtime "^6.22.0" 568 | 569 | babel-plugin-transform-object-rest-spread@^6.26.0: 570 | version "6.26.0" 571 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.26.0.tgz#0f36692d50fef6b7e2d4b3ac1478137a963b7b06" 572 | dependencies: 573 | babel-plugin-syntax-object-rest-spread "^6.8.0" 574 | babel-runtime "^6.26.0" 575 | 576 | babel-plugin-transform-regenerator@^6.22.0: 577 | version "6.26.0" 578 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz#e0703696fbde27f0a3efcacf8b4dca2f7b3a8f2f" 579 | dependencies: 580 | regenerator-transform "^0.10.0" 581 | 582 | babel-plugin-transform-strict-mode@^6.24.1: 583 | version "6.24.1" 584 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz#d5faf7aa578a65bbe591cf5edae04a0c67020758" 585 | dependencies: 586 | babel-runtime "^6.22.0" 587 | babel-types "^6.24.1" 588 | 589 | babel-polyfill@^6.26.0: 590 | version "6.26.0" 591 | resolved "https://registry.yarnpkg.com/babel-polyfill/-/babel-polyfill-6.26.0.tgz#379937abc67d7895970adc621f284cd966cf2153" 592 | dependencies: 593 | babel-runtime "^6.26.0" 594 | core-js "^2.5.0" 595 | regenerator-runtime "^0.10.5" 596 | 597 | babel-preset-env@^1.6.1: 598 | version "1.6.1" 599 | resolved "https://registry.yarnpkg.com/babel-preset-env/-/babel-preset-env-1.6.1.tgz#a18b564cc9b9afdf4aae57ae3c1b0d99188e6f48" 600 | dependencies: 601 | babel-plugin-check-es2015-constants "^6.22.0" 602 | babel-plugin-syntax-trailing-function-commas "^6.22.0" 603 | babel-plugin-transform-async-to-generator "^6.22.0" 604 | babel-plugin-transform-es2015-arrow-functions "^6.22.0" 605 | babel-plugin-transform-es2015-block-scoped-functions "^6.22.0" 606 | babel-plugin-transform-es2015-block-scoping "^6.23.0" 607 | babel-plugin-transform-es2015-classes "^6.23.0" 608 | babel-plugin-transform-es2015-computed-properties "^6.22.0" 609 | babel-plugin-transform-es2015-destructuring "^6.23.0" 610 | babel-plugin-transform-es2015-duplicate-keys "^6.22.0" 611 | babel-plugin-transform-es2015-for-of "^6.23.0" 612 | babel-plugin-transform-es2015-function-name "^6.22.0" 613 | babel-plugin-transform-es2015-literals "^6.22.0" 614 | babel-plugin-transform-es2015-modules-amd "^6.22.0" 615 | babel-plugin-transform-es2015-modules-commonjs "^6.23.0" 616 | babel-plugin-transform-es2015-modules-systemjs "^6.23.0" 617 | babel-plugin-transform-es2015-modules-umd "^6.23.0" 618 | babel-plugin-transform-es2015-object-super "^6.22.0" 619 | babel-plugin-transform-es2015-parameters "^6.23.0" 620 | babel-plugin-transform-es2015-shorthand-properties "^6.22.0" 621 | babel-plugin-transform-es2015-spread "^6.22.0" 622 | babel-plugin-transform-es2015-sticky-regex "^6.22.0" 623 | babel-plugin-transform-es2015-template-literals "^6.22.0" 624 | babel-plugin-transform-es2015-typeof-symbol "^6.23.0" 625 | babel-plugin-transform-es2015-unicode-regex "^6.22.0" 626 | babel-plugin-transform-exponentiation-operator "^6.22.0" 627 | babel-plugin-transform-regenerator "^6.22.0" 628 | browserslist "^2.1.2" 629 | invariant "^2.2.2" 630 | semver "^5.3.0" 631 | 632 | babel-preset-jest@^21.2.0: 633 | version "21.2.0" 634 | resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-21.2.0.tgz#ff9d2bce08abd98e8a36d9a8a5189b9173b85638" 635 | dependencies: 636 | babel-plugin-jest-hoist "^21.2.0" 637 | babel-plugin-syntax-object-rest-spread "^6.13.0" 638 | 639 | babel-register@^6.26.0: 640 | version "6.26.0" 641 | resolved "https://registry.yarnpkg.com/babel-register/-/babel-register-6.26.0.tgz#6ed021173e2fcb486d7acb45c6009a856f647071" 642 | dependencies: 643 | babel-core "^6.26.0" 644 | babel-runtime "^6.26.0" 645 | core-js "^2.5.0" 646 | home-or-tmp "^2.0.0" 647 | lodash "^4.17.4" 648 | mkdirp "^0.5.1" 649 | source-map-support "^0.4.15" 650 | 651 | babel-runtime@^6.18.0, babel-runtime@^6.22.0, babel-runtime@^6.26.0: 652 | version "6.26.0" 653 | resolved "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz#965c7058668e82b55d7bfe04ff2337bc8b5647fe" 654 | dependencies: 655 | core-js "^2.4.0" 656 | regenerator-runtime "^0.11.0" 657 | 658 | babel-template@^6.16.0, babel-template@^6.24.1, babel-template@^6.26.0: 659 | version "6.26.0" 660 | resolved "https://registry.yarnpkg.com/babel-template/-/babel-template-6.26.0.tgz#de03e2d16396b069f46dd9fff8521fb1a0e35e02" 661 | dependencies: 662 | babel-runtime "^6.26.0" 663 | babel-traverse "^6.26.0" 664 | babel-types "^6.26.0" 665 | babylon "^6.18.0" 666 | lodash "^4.17.4" 667 | 668 | babel-traverse@^6.18.0, babel-traverse@^6.24.1, babel-traverse@^6.26.0: 669 | version "6.26.0" 670 | resolved "https://registry.yarnpkg.com/babel-traverse/-/babel-traverse-6.26.0.tgz#46a9cbd7edcc62c8e5c064e2d2d8d0f4035766ee" 671 | dependencies: 672 | babel-code-frame "^6.26.0" 673 | babel-messages "^6.23.0" 674 | babel-runtime "^6.26.0" 675 | babel-types "^6.26.0" 676 | babylon "^6.18.0" 677 | debug "^2.6.8" 678 | globals "^9.18.0" 679 | invariant "^2.2.2" 680 | lodash "^4.17.4" 681 | 682 | babel-types@^6.18.0, babel-types@^6.19.0, babel-types@^6.24.1, babel-types@^6.26.0: 683 | version "6.26.0" 684 | resolved "https://registry.yarnpkg.com/babel-types/-/babel-types-6.26.0.tgz#a3b073f94ab49eb6fa55cd65227a334380632497" 685 | dependencies: 686 | babel-runtime "^6.26.0" 687 | esutils "^2.0.2" 688 | lodash "^4.17.4" 689 | to-fast-properties "^1.0.3" 690 | 691 | babylon@^6.18.0: 692 | version "6.18.0" 693 | resolved "https://registry.yarnpkg.com/babylon/-/babylon-6.18.0.tgz#af2f3b88fa6f5c1e4c634d1a0f8eac4f55b395e3" 694 | 695 | balanced-match@^1.0.0: 696 | version "1.0.0" 697 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" 698 | 699 | bcrypt-pbkdf@^1.0.0: 700 | version "1.0.1" 701 | resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz#63bc5dcb61331b92bc05fd528953c33462a06f8d" 702 | dependencies: 703 | tweetnacl "^0.14.3" 704 | 705 | binary-extensions@^1.0.0: 706 | version "1.11.0" 707 | resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-1.11.0.tgz#46aa1751fb6a2f93ee5e689bb1087d4b14c6c205" 708 | 709 | block-stream@*: 710 | version "0.0.9" 711 | resolved "https://registry.yarnpkg.com/block-stream/-/block-stream-0.0.9.tgz#13ebfe778a03205cfe03751481ebb4b3300c126a" 712 | dependencies: 713 | inherits "~2.0.0" 714 | 715 | bluebird@^3.5.0, bluebird@^3.5.1: 716 | version "3.5.1" 717 | resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.5.1.tgz#d9551f9de98f1fcda1e683d17ee91a0602ee2eb9" 718 | 719 | boom@2.x.x: 720 | version "2.10.1" 721 | resolved "https://registry.yarnpkg.com/boom/-/boom-2.10.1.tgz#39c8918ceff5799f83f9492a848f625add0c766f" 722 | dependencies: 723 | hoek "2.x.x" 724 | 725 | boom@4.x.x: 726 | version "4.3.1" 727 | resolved "https://registry.yarnpkg.com/boom/-/boom-4.3.1.tgz#4f8a3005cb4a7e3889f749030fd25b96e01d2e31" 728 | dependencies: 729 | hoek "4.x.x" 730 | 731 | boom@5.x.x: 732 | version "5.2.0" 733 | resolved "https://registry.yarnpkg.com/boom/-/boom-5.2.0.tgz#5dd9da6ee3a5f302077436290cb717d3f4a54e02" 734 | dependencies: 735 | hoek "4.x.x" 736 | 737 | brace-expansion@^1.1.7: 738 | version "1.1.8" 739 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.8.tgz#c07b211c7c952ec1f8efd51a77ef0d1d3990a292" 740 | dependencies: 741 | balanced-match "^1.0.0" 742 | concat-map "0.0.1" 743 | 744 | braces@^1.8.2: 745 | version "1.8.5" 746 | resolved "https://registry.yarnpkg.com/braces/-/braces-1.8.5.tgz#ba77962e12dff969d6b76711e914b737857bf6a7" 747 | dependencies: 748 | expand-range "^1.8.1" 749 | preserve "^0.2.0" 750 | repeat-element "^1.1.2" 751 | 752 | browser-resolve@^1.11.2: 753 | version "1.11.2" 754 | resolved "https://registry.yarnpkg.com/browser-resolve/-/browser-resolve-1.11.2.tgz#8ff09b0a2c421718a1051c260b32e48f442938ce" 755 | dependencies: 756 | resolve "1.1.7" 757 | 758 | browserslist@^2.1.2: 759 | version "2.9.0" 760 | resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-2.9.0.tgz#706aca15c53be15610f466e348cbfa0c00a6a379" 761 | dependencies: 762 | caniuse-lite "^1.0.30000760" 763 | electron-to-chromium "^1.3.27" 764 | 765 | bser@^2.0.0: 766 | version "2.0.0" 767 | resolved "https://registry.yarnpkg.com/bser/-/bser-2.0.0.tgz#9ac78d3ed5d915804fd87acb158bc797147a1719" 768 | dependencies: 769 | node-int64 "^0.4.0" 770 | 771 | builtin-modules@^1.0.0: 772 | version "1.1.1" 773 | resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-1.1.1.tgz#270f076c5a72c02f5b65a47df94c5fe3a278892f" 774 | 775 | bytes@3.0.0: 776 | version "3.0.0" 777 | resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.0.0.tgz#d32815404d689699f85a4ea4fa8755dd13a96048" 778 | 779 | callsites@^2.0.0: 780 | version "2.0.0" 781 | resolved "https://registry.yarnpkg.com/callsites/-/callsites-2.0.0.tgz#06eb84f00eea413da86affefacbffb36093b3c50" 782 | 783 | camelcase@^1.0.2: 784 | version "1.2.1" 785 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-1.2.1.tgz#9bb5304d2e0b56698b2c758b08a3eaa9daa58a39" 786 | 787 | camelcase@^4.1.0: 788 | version "4.1.0" 789 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-4.1.0.tgz#d545635be1e33c542649c69173e5de6acfae34dd" 790 | 791 | caniuse-lite@^1.0.30000760: 792 | version "1.0.30000769" 793 | resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30000769.tgz#d68c5aa0772ea3eac6c97d42e239c9b4d3261b93" 794 | 795 | caseless@~0.12.0: 796 | version "0.12.0" 797 | resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" 798 | 799 | center-align@^0.1.1: 800 | version "0.1.3" 801 | resolved "https://registry.yarnpkg.com/center-align/-/center-align-0.1.3.tgz#aa0d32629b6ee972200411cbd4461c907bc2b7ad" 802 | dependencies: 803 | align-text "^0.1.3" 804 | lazy-cache "^1.0.3" 805 | 806 | chalk@^1.1.3: 807 | version "1.1.3" 808 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz#a8115c55e4a702fe4d150abd3872822a7e09fc98" 809 | dependencies: 810 | ansi-styles "^2.2.1" 811 | escape-string-regexp "^1.0.2" 812 | has-ansi "^2.0.0" 813 | strip-ansi "^3.0.0" 814 | supports-color "^2.0.0" 815 | 816 | chalk@^2.0.0, chalk@^2.0.1: 817 | version "2.3.0" 818 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.3.0.tgz#b5ea48efc9c1793dccc9b4767c93914d3f2d52ba" 819 | dependencies: 820 | ansi-styles "^3.1.0" 821 | escape-string-regexp "^1.0.5" 822 | supports-color "^4.0.0" 823 | 824 | chardet@^0.4.0: 825 | version "0.4.0" 826 | resolved "https://registry.yarnpkg.com/chardet/-/chardet-0.4.0.tgz#0bbe1355ac44d7a3ed4a925707c4ef70f8190f6c" 827 | 828 | chokidar@^1.6.1: 829 | version "1.7.0" 830 | resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-1.7.0.tgz#798e689778151c8076b4b360e5edd28cda2bb468" 831 | dependencies: 832 | anymatch "^1.3.0" 833 | async-each "^1.0.0" 834 | glob-parent "^2.0.0" 835 | inherits "^2.0.1" 836 | is-binary-path "^1.0.0" 837 | is-glob "^2.0.0" 838 | path-is-absolute "^1.0.0" 839 | readdirp "^2.0.0" 840 | optionalDependencies: 841 | fsevents "^1.0.0" 842 | 843 | ci-info@^1.0.0: 844 | version "1.1.2" 845 | resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-1.1.2.tgz#03561259db48d0474c8bdc90f5b47b068b6bbfb4" 846 | 847 | cli-cursor@^2.1.0: 848 | version "2.1.0" 849 | resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-2.1.0.tgz#b35dac376479facc3e94747d41d0d0f5238ffcb5" 850 | dependencies: 851 | restore-cursor "^2.0.0" 852 | 853 | cli-width@^2.0.0: 854 | version "2.2.0" 855 | resolved "https://registry.yarnpkg.com/cli-width/-/cli-width-2.2.0.tgz#ff19ede8a9a5e579324147b0c11f0fbcbabed639" 856 | 857 | cliui@^2.1.0: 858 | version "2.1.0" 859 | resolved "https://registry.yarnpkg.com/cliui/-/cliui-2.1.0.tgz#4b475760ff80264c762c3a1719032e91c7fea0d1" 860 | dependencies: 861 | center-align "^0.1.1" 862 | right-align "^0.1.1" 863 | wordwrap "0.0.2" 864 | 865 | cliui@^3.2.0: 866 | version "3.2.0" 867 | resolved "https://registry.yarnpkg.com/cliui/-/cliui-3.2.0.tgz#120601537a916d29940f934da3b48d585a39213d" 868 | dependencies: 869 | string-width "^1.0.1" 870 | strip-ansi "^3.0.1" 871 | wrap-ansi "^2.0.0" 872 | 873 | co@^4.6.0: 874 | version "4.6.0" 875 | resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184" 876 | 877 | code-point-at@^1.0.0: 878 | version "1.1.0" 879 | resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" 880 | 881 | color-convert@^1.9.0: 882 | version "1.9.1" 883 | resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.1.tgz#c1261107aeb2f294ebffec9ed9ecad529a6097ed" 884 | dependencies: 885 | color-name "^1.1.1" 886 | 887 | color-name@^1.1.1: 888 | version "1.1.3" 889 | resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" 890 | 891 | combined-stream@^1.0.5, combined-stream@~1.0.5: 892 | version "1.0.5" 893 | resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.5.tgz#938370a57b4a51dea2c77c15d5c5fdf895164009" 894 | dependencies: 895 | delayed-stream "~1.0.0" 896 | 897 | commander@^2.11.0: 898 | version "2.11.0" 899 | resolved "https://registry.yarnpkg.com/commander/-/commander-2.11.0.tgz#157152fd1e7a6c8d98a5b715cf376df928004563" 900 | 901 | concat-map@0.0.1: 902 | version "0.0.1" 903 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 904 | 905 | console-control-strings@^1.0.0, console-control-strings@~1.1.0: 906 | version "1.1.0" 907 | resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" 908 | 909 | content-type-parser@^1.0.1: 910 | version "1.0.2" 911 | resolved "https://registry.yarnpkg.com/content-type-parser/-/content-type-parser-1.0.2.tgz#caabe80623e63638b2502fd4c7f12ff4ce2352e7" 912 | 913 | convert-source-map@^1.4.0, convert-source-map@^1.5.0: 914 | version "1.5.0" 915 | resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.5.0.tgz#9acd70851c6d5dfdd93d9282e5edf94a03ff46b5" 916 | 917 | core-js@^2.4.0, core-js@^2.5.0: 918 | version "2.5.1" 919 | resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.5.1.tgz#ae6874dc66937789b80754ff5428df66819ca50b" 920 | 921 | core-util-is@1.0.2, core-util-is@~1.0.0: 922 | version "1.0.2" 923 | resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" 924 | 925 | cross-spawn@^5.0.1: 926 | version "5.1.0" 927 | resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-5.1.0.tgz#e8bd0efee58fcff6f8f94510a0a554bbfa235449" 928 | dependencies: 929 | lru-cache "^4.0.1" 930 | shebang-command "^1.2.0" 931 | which "^1.2.9" 932 | 933 | cryptiles@2.x.x: 934 | version "2.0.5" 935 | resolved "https://registry.yarnpkg.com/cryptiles/-/cryptiles-2.0.5.tgz#3bdfecdc608147c1c67202fa291e7dca59eaa3b8" 936 | dependencies: 937 | boom "2.x.x" 938 | 939 | cryptiles@3.x.x: 940 | version "3.1.2" 941 | resolved "https://registry.yarnpkg.com/cryptiles/-/cryptiles-3.1.2.tgz#a89fbb220f5ce25ec56e8c4aa8a4fd7b5b0d29fe" 942 | dependencies: 943 | boom "5.x.x" 944 | 945 | cssom@0.3.x, "cssom@>= 0.3.2 < 0.4.0": 946 | version "0.3.2" 947 | resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.2.tgz#b8036170c79f07a90ff2f16e22284027a243848b" 948 | 949 | "cssstyle@>= 0.2.37 < 0.3.0": 950 | version "0.2.37" 951 | resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-0.2.37.tgz#541097234cb2513c83ceed3acddc27ff27987d54" 952 | dependencies: 953 | cssom "0.3.x" 954 | 955 | dashdash@^1.12.0: 956 | version "1.14.1" 957 | resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" 958 | dependencies: 959 | assert-plus "^1.0.0" 960 | 961 | debug@^2.2.0, debug@^2.6.8: 962 | version "2.6.9" 963 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" 964 | dependencies: 965 | ms "2.0.0" 966 | 967 | debug@^3.1.0: 968 | version "3.1.0" 969 | resolved "https://registry.yarnpkg.com/debug/-/debug-3.1.0.tgz#5bb5a0672628b64149566ba16819e61518c67261" 970 | dependencies: 971 | ms "2.0.0" 972 | 973 | decamelize@^1.0.0, decamelize@^1.1.1: 974 | version "1.2.0" 975 | resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290" 976 | 977 | deep-equal@^1.0.1: 978 | version "1.0.1" 979 | resolved "https://registry.yarnpkg.com/deep-equal/-/deep-equal-1.0.1.tgz#f5d260292b660e084eff4cdbc9f08ad3247448b5" 980 | 981 | deep-extend@~0.4.0: 982 | version "0.4.2" 983 | resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.4.2.tgz#48b699c27e334bf89f10892be432f6e4c7d34a7f" 984 | 985 | deep-is@~0.1.3: 986 | version "0.1.3" 987 | resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.3.tgz#b369d6fb5dbc13eecf524f91b070feedc357cf34" 988 | 989 | default-require-extensions@^1.0.0: 990 | version "1.0.0" 991 | resolved "https://registry.yarnpkg.com/default-require-extensions/-/default-require-extensions-1.0.0.tgz#f37ea15d3e13ffd9b437d33e1a75b5fb97874cb8" 992 | dependencies: 993 | strip-bom "^2.0.0" 994 | 995 | delayed-stream@~1.0.0: 996 | version "1.0.0" 997 | resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" 998 | 999 | delegates@^1.0.0: 1000 | version "1.0.0" 1001 | resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" 1002 | 1003 | depd@1.1.1: 1004 | version "1.1.1" 1005 | resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.1.tgz#5783b4e1c459f06fa5ca27f991f3d06e7a310359" 1006 | 1007 | detect-indent@^4.0.0: 1008 | version "4.0.0" 1009 | resolved "https://registry.yarnpkg.com/detect-indent/-/detect-indent-4.0.0.tgz#f76d064352cdf43a1cb6ce619c4ee3a9475de208" 1010 | dependencies: 1011 | repeating "^2.0.0" 1012 | 1013 | detect-libc@^1.0.2: 1014 | version "1.0.2" 1015 | resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.2.tgz#71ad5d204bf17a6a6ca8f450c61454066ef461e1" 1016 | 1017 | diff@^3.2.0: 1018 | version "3.4.0" 1019 | resolved "https://registry.yarnpkg.com/diff/-/diff-3.4.0.tgz#b1d85507daf3964828de54b37d0d73ba67dda56c" 1020 | 1021 | docker-parse-image@^3.0.1: 1022 | version "3.0.1" 1023 | resolved "https://registry.yarnpkg.com/docker-parse-image/-/docker-parse-image-3.0.1.tgz#33dc69291eac3414f84871f2d59d77b6f6948be4" 1024 | 1025 | ecc-jsbn@~0.1.1: 1026 | version "0.1.1" 1027 | resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz#0fc73a9ed5f0d53c38193398523ef7e543777505" 1028 | dependencies: 1029 | jsbn "~0.1.0" 1030 | 1031 | electron-to-chromium@^1.3.27: 1032 | version "1.3.27" 1033 | resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.27.tgz#78ecb8a399066187bb374eede35d9c70565a803d" 1034 | 1035 | errno@^0.1.4: 1036 | version "0.1.4" 1037 | resolved "https://registry.yarnpkg.com/errno/-/errno-0.1.4.tgz#b896e23a9e5e8ba33871fc996abd3635fc9a1c7d" 1038 | dependencies: 1039 | prr "~0.0.0" 1040 | 1041 | error-ex@^1.2.0: 1042 | version "1.3.1" 1043 | resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.1.tgz#f855a86ce61adc4e8621c3cda21e7a7612c3a8dc" 1044 | dependencies: 1045 | is-arrayish "^0.2.1" 1046 | 1047 | escape-string-regexp@^1.0.2, escape-string-regexp@^1.0.5: 1048 | version "1.0.5" 1049 | resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" 1050 | 1051 | escodegen@^1.6.1: 1052 | version "1.9.0" 1053 | resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-1.9.0.tgz#9811a2f265dc1cd3894420ee3717064b632b8852" 1054 | dependencies: 1055 | esprima "^3.1.3" 1056 | estraverse "^4.2.0" 1057 | esutils "^2.0.2" 1058 | optionator "^0.8.1" 1059 | optionalDependencies: 1060 | source-map "~0.5.6" 1061 | 1062 | esprima@^3.1.3: 1063 | version "3.1.3" 1064 | resolved "https://registry.yarnpkg.com/esprima/-/esprima-3.1.3.tgz#fdca51cee6133895e3c88d535ce49dbff62a4633" 1065 | 1066 | esprima@^4.0.0: 1067 | version "4.0.0" 1068 | resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.0.tgz#4499eddcd1110e0b218bacf2fa7f7f59f55ca804" 1069 | 1070 | estraverse@^4.2.0: 1071 | version "4.2.0" 1072 | resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.2.0.tgz#0dee3fed31fcd469618ce7342099fc1afa0bdb13" 1073 | 1074 | esutils@^2.0.2: 1075 | version "2.0.2" 1076 | resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.2.tgz#0abf4f1caa5bcb1f7a9d8acc6dea4faaa04bac9b" 1077 | 1078 | exec-sh@^0.2.0: 1079 | version "0.2.1" 1080 | resolved "https://registry.yarnpkg.com/exec-sh/-/exec-sh-0.2.1.tgz#163b98a6e89e6b65b47c2a28d215bc1f63989c38" 1081 | dependencies: 1082 | merge "^1.1.3" 1083 | 1084 | execa@^0.7.0: 1085 | version "0.7.0" 1086 | resolved "https://registry.yarnpkg.com/execa/-/execa-0.7.0.tgz#944becd34cc41ee32a63a9faf27ad5a65fc59777" 1087 | dependencies: 1088 | cross-spawn "^5.0.1" 1089 | get-stream "^3.0.0" 1090 | is-stream "^1.1.0" 1091 | npm-run-path "^2.0.0" 1092 | p-finally "^1.0.0" 1093 | signal-exit "^3.0.0" 1094 | strip-eof "^1.0.0" 1095 | 1096 | expand-brackets@^0.1.4: 1097 | version "0.1.5" 1098 | resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-0.1.5.tgz#df07284e342a807cd733ac5af72411e581d1177b" 1099 | dependencies: 1100 | is-posix-bracket "^0.1.0" 1101 | 1102 | expand-range@^1.8.1: 1103 | version "1.8.2" 1104 | resolved "https://registry.yarnpkg.com/expand-range/-/expand-range-1.8.2.tgz#a299effd335fe2721ebae8e257ec79644fc85337" 1105 | dependencies: 1106 | fill-range "^2.1.0" 1107 | 1108 | expect@^21.2.1: 1109 | version "21.2.1" 1110 | resolved "https://registry.yarnpkg.com/expect/-/expect-21.2.1.tgz#003ac2ac7005c3c29e73b38a272d4afadd6d1d7b" 1111 | dependencies: 1112 | ansi-styles "^3.2.0" 1113 | jest-diff "^21.2.1" 1114 | jest-get-type "^21.2.0" 1115 | jest-matcher-utils "^21.2.1" 1116 | jest-message-util "^21.2.1" 1117 | jest-regex-util "^21.2.0" 1118 | 1119 | extend@~3.0.0, extend@~3.0.1: 1120 | version "3.0.1" 1121 | resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.1.tgz#a755ea7bc1adfcc5a31ce7e762dbaadc5e636444" 1122 | 1123 | external-editor@^2.0.4: 1124 | version "2.1.0" 1125 | resolved "https://registry.yarnpkg.com/external-editor/-/external-editor-2.1.0.tgz#3d026a21b7f95b5726387d4200ac160d372c3b48" 1126 | dependencies: 1127 | chardet "^0.4.0" 1128 | iconv-lite "^0.4.17" 1129 | tmp "^0.0.33" 1130 | 1131 | extglob@^0.3.1: 1132 | version "0.3.2" 1133 | resolved "https://registry.yarnpkg.com/extglob/-/extglob-0.3.2.tgz#2e18ff3d2f49ab2765cec9023f011daa8d8349a1" 1134 | dependencies: 1135 | is-extglob "^1.0.0" 1136 | 1137 | extsprintf@1.3.0, extsprintf@^1.2.0: 1138 | version "1.3.0" 1139 | resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05" 1140 | 1141 | fast-deep-equal@^1.0.0: 1142 | version "1.0.0" 1143 | resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz#96256a3bc975595eb36d82e9929d060d893439ff" 1144 | 1145 | fast-json-stable-stringify@^2.0.0: 1146 | version "2.0.0" 1147 | resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz#d5142c0caee6b1189f87d3a76111064f86c8bbf2" 1148 | 1149 | fast-levenshtein@~2.0.4: 1150 | version "2.0.6" 1151 | resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" 1152 | 1153 | fb-watchman@^2.0.0: 1154 | version "2.0.0" 1155 | resolved "https://registry.yarnpkg.com/fb-watchman/-/fb-watchman-2.0.0.tgz#54e9abf7dfa2f26cd9b1636c588c1afc05de5d58" 1156 | dependencies: 1157 | bser "^2.0.0" 1158 | 1159 | figures@^2.0.0: 1160 | version "2.0.0" 1161 | resolved "https://registry.yarnpkg.com/figures/-/figures-2.0.0.tgz#3ab1a2d2a62c8bfb431a0c94cb797a2fce27c962" 1162 | dependencies: 1163 | escape-string-regexp "^1.0.5" 1164 | 1165 | filename-regex@^2.0.0: 1166 | version "2.0.1" 1167 | resolved "https://registry.yarnpkg.com/filename-regex/-/filename-regex-2.0.1.tgz#c1c4b9bee3e09725ddb106b75c1e301fe2f18b26" 1168 | 1169 | fileset@^2.0.2: 1170 | version "2.0.3" 1171 | resolved "https://registry.yarnpkg.com/fileset/-/fileset-2.0.3.tgz#8e7548a96d3cc2327ee5e674168723a333bba2a0" 1172 | dependencies: 1173 | glob "^7.0.3" 1174 | minimatch "^3.0.3" 1175 | 1176 | fill-range@^2.1.0: 1177 | version "2.2.3" 1178 | resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-2.2.3.tgz#50b77dfd7e469bc7492470963699fe7a8485a723" 1179 | dependencies: 1180 | is-number "^2.1.0" 1181 | isobject "^2.0.0" 1182 | randomatic "^1.1.3" 1183 | repeat-element "^1.1.2" 1184 | repeat-string "^1.5.2" 1185 | 1186 | find-up@^1.0.0: 1187 | version "1.1.2" 1188 | resolved "https://registry.yarnpkg.com/find-up/-/find-up-1.1.2.tgz#6b2e9822b1a2ce0a60ab64d610eccad53cb24d0f" 1189 | dependencies: 1190 | path-exists "^2.0.0" 1191 | pinkie-promise "^2.0.0" 1192 | 1193 | find-up@^2.0.0, find-up@^2.1.0: 1194 | version "2.1.0" 1195 | resolved "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz#45d1b7e506c717ddd482775a2b77920a3c0c57a7" 1196 | dependencies: 1197 | locate-path "^2.0.0" 1198 | 1199 | for-in@^1.0.1: 1200 | version "1.0.2" 1201 | resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80" 1202 | 1203 | for-own@^0.1.4: 1204 | version "0.1.5" 1205 | resolved "https://registry.yarnpkg.com/for-own/-/for-own-0.1.5.tgz#5265c681a4f294dabbf17c9509b6763aa84510ce" 1206 | dependencies: 1207 | for-in "^1.0.1" 1208 | 1209 | forever-agent@~0.6.1: 1210 | version "0.6.1" 1211 | resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" 1212 | 1213 | form-data@~2.1.1: 1214 | version "2.1.4" 1215 | resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.1.4.tgz#33c183acf193276ecaa98143a69e94bfee1750d1" 1216 | dependencies: 1217 | asynckit "^0.4.0" 1218 | combined-stream "^1.0.5" 1219 | mime-types "^2.1.12" 1220 | 1221 | form-data@~2.3.1: 1222 | version "2.3.1" 1223 | resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.1.tgz#6fb94fbd71885306d73d15cc497fe4cc4ecd44bf" 1224 | dependencies: 1225 | asynckit "^0.4.0" 1226 | combined-stream "^1.0.5" 1227 | mime-types "^2.1.12" 1228 | 1229 | fs-readdir-recursive@^1.0.0: 1230 | version "1.1.0" 1231 | resolved "https://registry.yarnpkg.com/fs-readdir-recursive/-/fs-readdir-recursive-1.1.0.tgz#e32fc030a2ccee44a6b5371308da54be0b397d27" 1232 | 1233 | fs.realpath@^1.0.0: 1234 | version "1.0.0" 1235 | resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" 1236 | 1237 | fsevents@^1.0.0, fsevents@^1.1.1: 1238 | version "1.1.3" 1239 | resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.1.3.tgz#11f82318f5fe7bb2cd22965a108e9306208216d8" 1240 | dependencies: 1241 | nan "^2.3.0" 1242 | node-pre-gyp "^0.6.39" 1243 | 1244 | fstream-ignore@^1.0.5: 1245 | version "1.0.5" 1246 | resolved "https://registry.yarnpkg.com/fstream-ignore/-/fstream-ignore-1.0.5.tgz#9c31dae34767018fe1d249b24dada67d092da105" 1247 | dependencies: 1248 | fstream "^1.0.0" 1249 | inherits "2" 1250 | minimatch "^3.0.0" 1251 | 1252 | fstream@^1.0.0, fstream@^1.0.10, fstream@^1.0.2: 1253 | version "1.0.11" 1254 | resolved "https://registry.yarnpkg.com/fstream/-/fstream-1.0.11.tgz#5c1fb1f117477114f0632a0eb4b71b3cb0fd3171" 1255 | dependencies: 1256 | graceful-fs "^4.1.2" 1257 | inherits "~2.0.0" 1258 | mkdirp ">=0.5 0" 1259 | rimraf "2" 1260 | 1261 | gauge@~2.7.3: 1262 | version "2.7.4" 1263 | resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7" 1264 | dependencies: 1265 | aproba "^1.0.3" 1266 | console-control-strings "^1.0.0" 1267 | has-unicode "^2.0.0" 1268 | object-assign "^4.1.0" 1269 | signal-exit "^3.0.0" 1270 | string-width "^1.0.1" 1271 | strip-ansi "^3.0.1" 1272 | wide-align "^1.1.0" 1273 | 1274 | get-caller-file@^1.0.1: 1275 | version "1.0.2" 1276 | resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.2.tgz#f702e63127e7e231c160a80c1554acb70d5047e5" 1277 | 1278 | get-stream@^3.0.0: 1279 | version "3.0.0" 1280 | resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz#8e943d1358dc37555054ecbe2edb05aa174ede14" 1281 | 1282 | getpass@^0.1.1: 1283 | version "0.1.7" 1284 | resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa" 1285 | dependencies: 1286 | assert-plus "^1.0.0" 1287 | 1288 | glob-base@^0.3.0: 1289 | version "0.3.0" 1290 | resolved "https://registry.yarnpkg.com/glob-base/-/glob-base-0.3.0.tgz#dbb164f6221b1c0b1ccf82aea328b497df0ea3c4" 1291 | dependencies: 1292 | glob-parent "^2.0.0" 1293 | is-glob "^2.0.0" 1294 | 1295 | glob-parent@^2.0.0: 1296 | version "2.0.0" 1297 | resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-2.0.0.tgz#81383d72db054fcccf5336daa902f182f6edbb28" 1298 | dependencies: 1299 | is-glob "^2.0.0" 1300 | 1301 | glob@^7.0.3, glob@^7.0.5, glob@^7.1.1, glob@^7.1.2: 1302 | version "7.1.2" 1303 | resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.2.tgz#c19c9df9a028702d678612384a6552404c636d15" 1304 | dependencies: 1305 | fs.realpath "^1.0.0" 1306 | inflight "^1.0.4" 1307 | inherits "2" 1308 | minimatch "^3.0.4" 1309 | once "^1.3.0" 1310 | path-is-absolute "^1.0.0" 1311 | 1312 | globals@^9.18.0: 1313 | version "9.18.0" 1314 | resolved "https://registry.yarnpkg.com/globals/-/globals-9.18.0.tgz#aa3896b3e69b487f17e31ed2143d69a8e30c2d8a" 1315 | 1316 | graceful-fs@^4.1.11, graceful-fs@^4.1.2, graceful-fs@^4.1.4: 1317 | version "4.1.11" 1318 | resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.1.11.tgz#0e8bdfe4d1ddb8854d64e04ea7c00e2a026e5658" 1319 | 1320 | growly@^1.3.0: 1321 | version "1.3.0" 1322 | resolved "https://registry.yarnpkg.com/growly/-/growly-1.3.0.tgz#f10748cbe76af964b7c96c93c6bcc28af120c081" 1323 | 1324 | handlebars@^4.0.3: 1325 | version "4.0.11" 1326 | resolved "https://registry.yarnpkg.com/handlebars/-/handlebars-4.0.11.tgz#630a35dfe0294bc281edae6ffc5d329fc7982dcc" 1327 | dependencies: 1328 | async "^1.4.0" 1329 | optimist "^0.6.1" 1330 | source-map "^0.4.4" 1331 | optionalDependencies: 1332 | uglify-js "^2.6" 1333 | 1334 | har-schema@^1.0.5: 1335 | version "1.0.5" 1336 | resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-1.0.5.tgz#d263135f43307c02c602afc8fe95970c0151369e" 1337 | 1338 | har-schema@^2.0.0: 1339 | version "2.0.0" 1340 | resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92" 1341 | 1342 | har-validator@~4.2.1: 1343 | version "4.2.1" 1344 | resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-4.2.1.tgz#33481d0f1bbff600dd203d75812a6a5fba002e2a" 1345 | dependencies: 1346 | ajv "^4.9.1" 1347 | har-schema "^1.0.5" 1348 | 1349 | har-validator@~5.0.3: 1350 | version "5.0.3" 1351 | resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-5.0.3.tgz#ba402c266194f15956ef15e0fcf242993f6a7dfd" 1352 | dependencies: 1353 | ajv "^5.1.0" 1354 | har-schema "^2.0.0" 1355 | 1356 | has-ansi@^2.0.0: 1357 | version "2.0.0" 1358 | resolved "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz#34f5049ce1ecdf2b0649af3ef24e45ed35416d91" 1359 | dependencies: 1360 | ansi-regex "^2.0.0" 1361 | 1362 | has-flag@^1.0.0: 1363 | version "1.0.0" 1364 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-1.0.0.tgz#9d9e793165ce017a00f00418c43f942a7b1d11fa" 1365 | 1366 | has-flag@^2.0.0: 1367 | version "2.0.0" 1368 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-2.0.0.tgz#e8207af1cc7b30d446cc70b734b5e8be18f88d51" 1369 | 1370 | has-unicode@^2.0.0: 1371 | version "2.0.1" 1372 | resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" 1373 | 1374 | hawk@3.1.3, hawk@~3.1.3: 1375 | version "3.1.3" 1376 | resolved "https://registry.yarnpkg.com/hawk/-/hawk-3.1.3.tgz#078444bd7c1640b0fe540d2c9b73d59678e8e1c4" 1377 | dependencies: 1378 | boom "2.x.x" 1379 | cryptiles "2.x.x" 1380 | hoek "2.x.x" 1381 | sntp "1.x.x" 1382 | 1383 | hawk@~6.0.2: 1384 | version "6.0.2" 1385 | resolved "https://registry.yarnpkg.com/hawk/-/hawk-6.0.2.tgz#af4d914eb065f9b5ce4d9d11c1cb2126eecc3038" 1386 | dependencies: 1387 | boom "4.x.x" 1388 | cryptiles "3.x.x" 1389 | hoek "4.x.x" 1390 | sntp "2.x.x" 1391 | 1392 | hoek@2.x.x: 1393 | version "2.16.3" 1394 | resolved "https://registry.yarnpkg.com/hoek/-/hoek-2.16.3.tgz#20bb7403d3cea398e91dc4710a8ff1b8274a25ed" 1395 | 1396 | hoek@4.x.x: 1397 | version "4.2.0" 1398 | resolved "https://registry.yarnpkg.com/hoek/-/hoek-4.2.0.tgz#72d9d0754f7fe25ca2d01ad8f8f9a9449a89526d" 1399 | 1400 | home-or-tmp@^2.0.0: 1401 | version "2.0.0" 1402 | resolved "https://registry.yarnpkg.com/home-or-tmp/-/home-or-tmp-2.0.0.tgz#e36c3f2d2cae7d746a857e38d18d5f32a7882db8" 1403 | dependencies: 1404 | os-homedir "^1.0.0" 1405 | os-tmpdir "^1.0.1" 1406 | 1407 | hosted-git-info@^2.1.4: 1408 | version "2.5.0" 1409 | resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.5.0.tgz#6d60e34b3abbc8313062c3b798ef8d901a07af3c" 1410 | 1411 | html-encoding-sniffer@^1.0.1: 1412 | version "1.0.2" 1413 | resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-1.0.2.tgz#e70d84b94da53aa375e11fe3a351be6642ca46f8" 1414 | dependencies: 1415 | whatwg-encoding "^1.0.1" 1416 | 1417 | http-errors@1.6.2: 1418 | version "1.6.2" 1419 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.2.tgz#0a002cc85707192a7e7946ceedc11155f60ec736" 1420 | dependencies: 1421 | depd "1.1.1" 1422 | inherits "2.0.3" 1423 | setprototypeof "1.0.3" 1424 | statuses ">= 1.3.1 < 2" 1425 | 1426 | http-signature@~1.1.0: 1427 | version "1.1.1" 1428 | resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.1.1.tgz#df72e267066cd0ac67fb76adf8e134a8fbcf91bf" 1429 | dependencies: 1430 | assert-plus "^0.2.0" 1431 | jsprim "^1.2.2" 1432 | sshpk "^1.7.0" 1433 | 1434 | http-signature@~1.2.0: 1435 | version "1.2.0" 1436 | resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1" 1437 | dependencies: 1438 | assert-plus "^1.0.0" 1439 | jsprim "^1.2.2" 1440 | sshpk "^1.7.0" 1441 | 1442 | iconv-lite@0.4.19, iconv-lite@^0.4.17: 1443 | version "0.4.19" 1444 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.19.tgz#f7468f60135f5e5dad3399c0a81be9a1603a082b" 1445 | 1446 | imurmurhash@^0.1.4: 1447 | version "0.1.4" 1448 | resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" 1449 | 1450 | inflight@^1.0.4: 1451 | version "1.0.6" 1452 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 1453 | dependencies: 1454 | once "^1.3.0" 1455 | wrappy "1" 1456 | 1457 | inherits@2, inherits@2.0.3, inherits@^2.0.1, inherits@~2.0.0, inherits@~2.0.3: 1458 | version "2.0.3" 1459 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" 1460 | 1461 | ini@~1.3.0: 1462 | version "1.3.4" 1463 | resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.4.tgz#0537cb79daf59b59a1a517dff706c86ec039162e" 1464 | 1465 | inquirer@^4.0.0: 1466 | version "4.0.0" 1467 | resolved "https://registry.yarnpkg.com/inquirer/-/inquirer-4.0.0.tgz#56c6354ae4e6201917027249bbd7667fca2cc031" 1468 | dependencies: 1469 | ansi-escapes "^3.0.0" 1470 | chalk "^2.0.0" 1471 | cli-cursor "^2.1.0" 1472 | cli-width "^2.0.0" 1473 | external-editor "^2.0.4" 1474 | figures "^2.0.0" 1475 | lodash "^4.3.0" 1476 | mute-stream "0.0.7" 1477 | run-async "^2.2.0" 1478 | rx-lite "^4.0.8" 1479 | rx-lite-aggregates "^4.0.8" 1480 | string-width "^2.1.0" 1481 | strip-ansi "^4.0.0" 1482 | through "^2.3.6" 1483 | 1484 | invariant@^2.2.2: 1485 | version "2.2.2" 1486 | resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.2.tgz#9e1f56ac0acdb6bf303306f338be3b204ae60360" 1487 | dependencies: 1488 | loose-envify "^1.0.0" 1489 | 1490 | invert-kv@^1.0.0: 1491 | version "1.0.0" 1492 | resolved "https://registry.yarnpkg.com/invert-kv/-/invert-kv-1.0.0.tgz#104a8e4aaca6d3d8cd157a8ef8bfab2d7a3ffdb6" 1493 | 1494 | is-arrayish@^0.2.1: 1495 | version "0.2.1" 1496 | resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" 1497 | 1498 | is-binary-path@^1.0.0: 1499 | version "1.0.1" 1500 | resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-1.0.1.tgz#75f16642b480f187a711c814161fd3a4a7655898" 1501 | dependencies: 1502 | binary-extensions "^1.0.0" 1503 | 1504 | is-buffer@^1.1.5: 1505 | version "1.1.6" 1506 | resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" 1507 | 1508 | is-builtin-module@^1.0.0: 1509 | version "1.0.0" 1510 | resolved "https://registry.yarnpkg.com/is-builtin-module/-/is-builtin-module-1.0.0.tgz#540572d34f7ac3119f8f76c30cbc1b1e037affbe" 1511 | dependencies: 1512 | builtin-modules "^1.0.0" 1513 | 1514 | is-ci@^1.0.10: 1515 | version "1.0.10" 1516 | resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-1.0.10.tgz#f739336b2632365061a9d48270cd56ae3369318e" 1517 | dependencies: 1518 | ci-info "^1.0.0" 1519 | 1520 | is-dotfile@^1.0.0: 1521 | version "1.0.3" 1522 | resolved "https://registry.yarnpkg.com/is-dotfile/-/is-dotfile-1.0.3.tgz#a6a2f32ffd2dfb04f5ca25ecd0f6b83cf798a1e1" 1523 | 1524 | is-equal-shallow@^0.1.3: 1525 | version "0.1.3" 1526 | resolved "https://registry.yarnpkg.com/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz#2238098fc221de0bcfa5d9eac4c45d638aa1c534" 1527 | dependencies: 1528 | is-primitive "^2.0.0" 1529 | 1530 | is-extendable@^0.1.1: 1531 | version "0.1.1" 1532 | resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" 1533 | 1534 | is-extglob@^1.0.0: 1535 | version "1.0.0" 1536 | resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-1.0.0.tgz#ac468177c4943405a092fc8f29760c6ffc6206c0" 1537 | 1538 | is-finite@^1.0.0: 1539 | version "1.0.2" 1540 | resolved "https://registry.yarnpkg.com/is-finite/-/is-finite-1.0.2.tgz#cc6677695602be550ef11e8b4aa6305342b6d0aa" 1541 | dependencies: 1542 | number-is-nan "^1.0.0" 1543 | 1544 | is-fullwidth-code-point@^1.0.0: 1545 | version "1.0.0" 1546 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb" 1547 | dependencies: 1548 | number-is-nan "^1.0.0" 1549 | 1550 | is-fullwidth-code-point@^2.0.0: 1551 | version "2.0.0" 1552 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" 1553 | 1554 | is-glob@^2.0.0, is-glob@^2.0.1: 1555 | version "2.0.1" 1556 | resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-2.0.1.tgz#d096f926a3ded5600f3fdfd91198cb0888c2d863" 1557 | dependencies: 1558 | is-extglob "^1.0.0" 1559 | 1560 | is-number@^2.1.0: 1561 | version "2.1.0" 1562 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-2.1.0.tgz#01fcbbb393463a548f2f466cce16dece49db908f" 1563 | dependencies: 1564 | kind-of "^3.0.2" 1565 | 1566 | is-number@^3.0.0: 1567 | version "3.0.0" 1568 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195" 1569 | dependencies: 1570 | kind-of "^3.0.2" 1571 | 1572 | is-posix-bracket@^0.1.0: 1573 | version "0.1.1" 1574 | resolved "https://registry.yarnpkg.com/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz#3334dc79774368e92f016e6fbc0a88f5cd6e6bc4" 1575 | 1576 | is-primitive@^2.0.0: 1577 | version "2.0.0" 1578 | resolved "https://registry.yarnpkg.com/is-primitive/-/is-primitive-2.0.0.tgz#207bab91638499c07b2adf240a41a87210034575" 1579 | 1580 | is-promise@^2.1.0: 1581 | version "2.1.0" 1582 | resolved "https://registry.yarnpkg.com/is-promise/-/is-promise-2.1.0.tgz#79a2a9ece7f096e80f36d2b2f3bc16c1ff4bf3fa" 1583 | 1584 | is-stream@^1.1.0: 1585 | version "1.1.0" 1586 | resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" 1587 | 1588 | is-typedarray@~1.0.0: 1589 | version "1.0.0" 1590 | resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" 1591 | 1592 | is-utf8@^0.2.0: 1593 | version "0.2.1" 1594 | resolved "https://registry.yarnpkg.com/is-utf8/-/is-utf8-0.2.1.tgz#4b0da1442104d1b336340e80797e865cf39f7d72" 1595 | 1596 | isarray@1.0.0, isarray@~1.0.0: 1597 | version "1.0.0" 1598 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" 1599 | 1600 | isexe@^2.0.0: 1601 | version "2.0.0" 1602 | resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" 1603 | 1604 | isobject@^2.0.0: 1605 | version "2.1.0" 1606 | resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" 1607 | dependencies: 1608 | isarray "1.0.0" 1609 | 1610 | isstream@~0.1.2: 1611 | version "0.1.2" 1612 | resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" 1613 | 1614 | istanbul-api@^1.1.1: 1615 | version "1.2.1" 1616 | resolved "https://registry.yarnpkg.com/istanbul-api/-/istanbul-api-1.2.1.tgz#0c60a0515eb11c7d65c6b50bba2c6e999acd8620" 1617 | dependencies: 1618 | async "^2.1.4" 1619 | fileset "^2.0.2" 1620 | istanbul-lib-coverage "^1.1.1" 1621 | istanbul-lib-hook "^1.1.0" 1622 | istanbul-lib-instrument "^1.9.1" 1623 | istanbul-lib-report "^1.1.2" 1624 | istanbul-lib-source-maps "^1.2.2" 1625 | istanbul-reports "^1.1.3" 1626 | js-yaml "^3.7.0" 1627 | mkdirp "^0.5.1" 1628 | once "^1.4.0" 1629 | 1630 | istanbul-lib-coverage@^1.0.1, istanbul-lib-coverage@^1.1.1: 1631 | version "1.1.1" 1632 | resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-1.1.1.tgz#73bfb998885299415c93d38a3e9adf784a77a9da" 1633 | 1634 | istanbul-lib-hook@^1.1.0: 1635 | version "1.1.0" 1636 | resolved "https://registry.yarnpkg.com/istanbul-lib-hook/-/istanbul-lib-hook-1.1.0.tgz#8538d970372cb3716d53e55523dd54b557a8d89b" 1637 | dependencies: 1638 | append-transform "^0.4.0" 1639 | 1640 | istanbul-lib-instrument@^1.4.2, istanbul-lib-instrument@^1.7.5, istanbul-lib-instrument@^1.9.1: 1641 | version "1.9.1" 1642 | resolved "https://registry.yarnpkg.com/istanbul-lib-instrument/-/istanbul-lib-instrument-1.9.1.tgz#250b30b3531e5d3251299fdd64b0b2c9db6b558e" 1643 | dependencies: 1644 | babel-generator "^6.18.0" 1645 | babel-template "^6.16.0" 1646 | babel-traverse "^6.18.0" 1647 | babel-types "^6.18.0" 1648 | babylon "^6.18.0" 1649 | istanbul-lib-coverage "^1.1.1" 1650 | semver "^5.3.0" 1651 | 1652 | istanbul-lib-report@^1.1.2: 1653 | version "1.1.2" 1654 | resolved "https://registry.yarnpkg.com/istanbul-lib-report/-/istanbul-lib-report-1.1.2.tgz#922be27c13b9511b979bd1587359f69798c1d425" 1655 | dependencies: 1656 | istanbul-lib-coverage "^1.1.1" 1657 | mkdirp "^0.5.1" 1658 | path-parse "^1.0.5" 1659 | supports-color "^3.1.2" 1660 | 1661 | istanbul-lib-source-maps@^1.1.0, istanbul-lib-source-maps@^1.2.2: 1662 | version "1.2.2" 1663 | resolved "https://registry.yarnpkg.com/istanbul-lib-source-maps/-/istanbul-lib-source-maps-1.2.2.tgz#750578602435f28a0c04ee6d7d9e0f2960e62c1c" 1664 | dependencies: 1665 | debug "^3.1.0" 1666 | istanbul-lib-coverage "^1.1.1" 1667 | mkdirp "^0.5.1" 1668 | rimraf "^2.6.1" 1669 | source-map "^0.5.3" 1670 | 1671 | istanbul-reports@^1.1.3: 1672 | version "1.1.3" 1673 | resolved "https://registry.yarnpkg.com/istanbul-reports/-/istanbul-reports-1.1.3.tgz#3b9e1e8defb6d18b1d425da8e8b32c5a163f2d10" 1674 | dependencies: 1675 | handlebars "^4.0.3" 1676 | 1677 | jest-changed-files@^21.2.0: 1678 | version "21.2.0" 1679 | resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-21.2.0.tgz#5dbeecad42f5d88b482334902ce1cba6d9798d29" 1680 | dependencies: 1681 | throat "^4.0.0" 1682 | 1683 | jest-cli@^21.2.1: 1684 | version "21.2.1" 1685 | resolved "https://registry.yarnpkg.com/jest-cli/-/jest-cli-21.2.1.tgz#9c528b6629d651911138d228bdb033c157ec8c00" 1686 | dependencies: 1687 | ansi-escapes "^3.0.0" 1688 | chalk "^2.0.1" 1689 | glob "^7.1.2" 1690 | graceful-fs "^4.1.11" 1691 | is-ci "^1.0.10" 1692 | istanbul-api "^1.1.1" 1693 | istanbul-lib-coverage "^1.0.1" 1694 | istanbul-lib-instrument "^1.4.2" 1695 | istanbul-lib-source-maps "^1.1.0" 1696 | jest-changed-files "^21.2.0" 1697 | jest-config "^21.2.1" 1698 | jest-environment-jsdom "^21.2.1" 1699 | jest-haste-map "^21.2.0" 1700 | jest-message-util "^21.2.1" 1701 | jest-regex-util "^21.2.0" 1702 | jest-resolve-dependencies "^21.2.0" 1703 | jest-runner "^21.2.1" 1704 | jest-runtime "^21.2.1" 1705 | jest-snapshot "^21.2.1" 1706 | jest-util "^21.2.1" 1707 | micromatch "^2.3.11" 1708 | node-notifier "^5.0.2" 1709 | pify "^3.0.0" 1710 | slash "^1.0.0" 1711 | string-length "^2.0.0" 1712 | strip-ansi "^4.0.0" 1713 | which "^1.2.12" 1714 | worker-farm "^1.3.1" 1715 | yargs "^9.0.0" 1716 | 1717 | jest-config@^21.2.1: 1718 | version "21.2.1" 1719 | resolved "https://registry.yarnpkg.com/jest-config/-/jest-config-21.2.1.tgz#c7586c79ead0bcc1f38c401e55f964f13bf2a480" 1720 | dependencies: 1721 | chalk "^2.0.1" 1722 | glob "^7.1.1" 1723 | jest-environment-jsdom "^21.2.1" 1724 | jest-environment-node "^21.2.1" 1725 | jest-get-type "^21.2.0" 1726 | jest-jasmine2 "^21.2.1" 1727 | jest-regex-util "^21.2.0" 1728 | jest-resolve "^21.2.0" 1729 | jest-util "^21.2.1" 1730 | jest-validate "^21.2.1" 1731 | pretty-format "^21.2.1" 1732 | 1733 | jest-diff@^21.2.1: 1734 | version "21.2.1" 1735 | resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-21.2.1.tgz#46cccb6cab2d02ce98bc314011764bb95b065b4f" 1736 | dependencies: 1737 | chalk "^2.0.1" 1738 | diff "^3.2.0" 1739 | jest-get-type "^21.2.0" 1740 | pretty-format "^21.2.1" 1741 | 1742 | jest-docblock@^21.2.0: 1743 | version "21.2.0" 1744 | resolved "https://registry.yarnpkg.com/jest-docblock/-/jest-docblock-21.2.0.tgz#51529c3b30d5fd159da60c27ceedc195faf8d414" 1745 | 1746 | jest-environment-jsdom@^21.2.1: 1747 | version "21.2.1" 1748 | resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-21.2.1.tgz#38d9980c8259b2a608ec232deee6289a60d9d5b4" 1749 | dependencies: 1750 | jest-mock "^21.2.0" 1751 | jest-util "^21.2.1" 1752 | jsdom "^9.12.0" 1753 | 1754 | jest-environment-node@^21.2.1: 1755 | version "21.2.1" 1756 | resolved "https://registry.yarnpkg.com/jest-environment-node/-/jest-environment-node-21.2.1.tgz#98c67df5663c7fbe20f6e792ac2272c740d3b8c8" 1757 | dependencies: 1758 | jest-mock "^21.2.0" 1759 | jest-util "^21.2.1" 1760 | 1761 | jest-get-type@^21.2.0: 1762 | version "21.2.0" 1763 | resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-21.2.0.tgz#f6376ab9db4b60d81e39f30749c6c466f40d4a23" 1764 | 1765 | jest-haste-map@^21.2.0: 1766 | version "21.2.0" 1767 | resolved "https://registry.yarnpkg.com/jest-haste-map/-/jest-haste-map-21.2.0.tgz#1363f0a8bb4338f24f001806571eff7a4b2ff3d8" 1768 | dependencies: 1769 | fb-watchman "^2.0.0" 1770 | graceful-fs "^4.1.11" 1771 | jest-docblock "^21.2.0" 1772 | micromatch "^2.3.11" 1773 | sane "^2.0.0" 1774 | worker-farm "^1.3.1" 1775 | 1776 | jest-jasmine2@^21.2.1: 1777 | version "21.2.1" 1778 | resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-21.2.1.tgz#9cc6fc108accfa97efebce10c4308548a4ea7592" 1779 | dependencies: 1780 | chalk "^2.0.1" 1781 | expect "^21.2.1" 1782 | graceful-fs "^4.1.11" 1783 | jest-diff "^21.2.1" 1784 | jest-matcher-utils "^21.2.1" 1785 | jest-message-util "^21.2.1" 1786 | jest-snapshot "^21.2.1" 1787 | p-cancelable "^0.3.0" 1788 | 1789 | jest-matcher-utils@^21.2.1: 1790 | version "21.2.1" 1791 | resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-21.2.1.tgz#72c826eaba41a093ac2b4565f865eb8475de0f64" 1792 | dependencies: 1793 | chalk "^2.0.1" 1794 | jest-get-type "^21.2.0" 1795 | pretty-format "^21.2.1" 1796 | 1797 | jest-message-util@^21.2.1: 1798 | version "21.2.1" 1799 | resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-21.2.1.tgz#bfe5d4692c84c827d1dcf41823795558f0a1acbe" 1800 | dependencies: 1801 | chalk "^2.0.1" 1802 | micromatch "^2.3.11" 1803 | slash "^1.0.0" 1804 | 1805 | jest-mock@^21.2.0: 1806 | version "21.2.0" 1807 | resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-21.2.0.tgz#7eb0770e7317968165f61ea2a7281131534b3c0f" 1808 | 1809 | jest-regex-util@^21.2.0: 1810 | version "21.2.0" 1811 | resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-21.2.0.tgz#1b1e33e63143babc3e0f2e6c9b5ba1eb34b2d530" 1812 | 1813 | jest-resolve-dependencies@^21.2.0: 1814 | version "21.2.0" 1815 | resolved "https://registry.yarnpkg.com/jest-resolve-dependencies/-/jest-resolve-dependencies-21.2.0.tgz#9e231e371e1a736a1ad4e4b9a843bc72bfe03d09" 1816 | dependencies: 1817 | jest-regex-util "^21.2.0" 1818 | 1819 | jest-resolve@^21.2.0: 1820 | version "21.2.0" 1821 | resolved "https://registry.yarnpkg.com/jest-resolve/-/jest-resolve-21.2.0.tgz#068913ad2ba6a20218e5fd32471f3874005de3a6" 1822 | dependencies: 1823 | browser-resolve "^1.11.2" 1824 | chalk "^2.0.1" 1825 | is-builtin-module "^1.0.0" 1826 | 1827 | jest-runner@^21.2.1: 1828 | version "21.2.1" 1829 | resolved "https://registry.yarnpkg.com/jest-runner/-/jest-runner-21.2.1.tgz#194732e3e518bfb3d7cbfc0fd5871246c7e1a467" 1830 | dependencies: 1831 | jest-config "^21.2.1" 1832 | jest-docblock "^21.2.0" 1833 | jest-haste-map "^21.2.0" 1834 | jest-jasmine2 "^21.2.1" 1835 | jest-message-util "^21.2.1" 1836 | jest-runtime "^21.2.1" 1837 | jest-util "^21.2.1" 1838 | pify "^3.0.0" 1839 | throat "^4.0.0" 1840 | worker-farm "^1.3.1" 1841 | 1842 | jest-runtime@^21.2.1: 1843 | version "21.2.1" 1844 | resolved "https://registry.yarnpkg.com/jest-runtime/-/jest-runtime-21.2.1.tgz#99dce15309c670442eee2ebe1ff53a3cbdbbb73e" 1845 | dependencies: 1846 | babel-core "^6.0.0" 1847 | babel-jest "^21.2.0" 1848 | babel-plugin-istanbul "^4.0.0" 1849 | chalk "^2.0.1" 1850 | convert-source-map "^1.4.0" 1851 | graceful-fs "^4.1.11" 1852 | jest-config "^21.2.1" 1853 | jest-haste-map "^21.2.0" 1854 | jest-regex-util "^21.2.0" 1855 | jest-resolve "^21.2.0" 1856 | jest-util "^21.2.1" 1857 | json-stable-stringify "^1.0.1" 1858 | micromatch "^2.3.11" 1859 | slash "^1.0.0" 1860 | strip-bom "3.0.0" 1861 | write-file-atomic "^2.1.0" 1862 | yargs "^9.0.0" 1863 | 1864 | jest-snapshot@^21.2.1: 1865 | version "21.2.1" 1866 | resolved "https://registry.yarnpkg.com/jest-snapshot/-/jest-snapshot-21.2.1.tgz#29e49f16202416e47343e757e5eff948c07fd7b0" 1867 | dependencies: 1868 | chalk "^2.0.1" 1869 | jest-diff "^21.2.1" 1870 | jest-matcher-utils "^21.2.1" 1871 | mkdirp "^0.5.1" 1872 | natural-compare "^1.4.0" 1873 | pretty-format "^21.2.1" 1874 | 1875 | jest-util@^21.2.1: 1876 | version "21.2.1" 1877 | resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-21.2.1.tgz#a274b2f726b0897494d694a6c3d6a61ab819bb78" 1878 | dependencies: 1879 | callsites "^2.0.0" 1880 | chalk "^2.0.1" 1881 | graceful-fs "^4.1.11" 1882 | jest-message-util "^21.2.1" 1883 | jest-mock "^21.2.0" 1884 | jest-validate "^21.2.1" 1885 | mkdirp "^0.5.1" 1886 | 1887 | jest-validate@^21.2.1: 1888 | version "21.2.1" 1889 | resolved "https://registry.yarnpkg.com/jest-validate/-/jest-validate-21.2.1.tgz#cc0cbca653cd54937ba4f2a111796774530dd3c7" 1890 | dependencies: 1891 | chalk "^2.0.1" 1892 | jest-get-type "^21.2.0" 1893 | leven "^2.1.0" 1894 | pretty-format "^21.2.1" 1895 | 1896 | jest@^21.2.1: 1897 | version "21.2.1" 1898 | resolved "https://registry.yarnpkg.com/jest/-/jest-21.2.1.tgz#c964e0b47383768a1438e3ccf3c3d470327604e1" 1899 | dependencies: 1900 | jest-cli "^21.2.1" 1901 | 1902 | js-tokens@^3.0.0, js-tokens@^3.0.2: 1903 | version "3.0.2" 1904 | resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.2.tgz#9866df395102130e38f7f996bceb65443209c25b" 1905 | 1906 | js-yaml@^3.10.0, js-yaml@^3.7.0: 1907 | version "3.10.0" 1908 | resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.10.0.tgz#2e78441646bd4682e963f22b6e92823c309c62dc" 1909 | dependencies: 1910 | argparse "^1.0.7" 1911 | esprima "^4.0.0" 1912 | 1913 | jsbn@~0.1.0: 1914 | version "0.1.1" 1915 | resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" 1916 | 1917 | jsdom@^9.12.0: 1918 | version "9.12.0" 1919 | resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-9.12.0.tgz#e8c546fffcb06c00d4833ca84410fed7f8a097d4" 1920 | dependencies: 1921 | abab "^1.0.3" 1922 | acorn "^4.0.4" 1923 | acorn-globals "^3.1.0" 1924 | array-equal "^1.0.0" 1925 | content-type-parser "^1.0.1" 1926 | cssom ">= 0.3.2 < 0.4.0" 1927 | cssstyle ">= 0.2.37 < 0.3.0" 1928 | escodegen "^1.6.1" 1929 | html-encoding-sniffer "^1.0.1" 1930 | nwmatcher ">= 1.3.9 < 2.0.0" 1931 | parse5 "^1.5.1" 1932 | request "^2.79.0" 1933 | sax "^1.2.1" 1934 | symbol-tree "^3.2.1" 1935 | tough-cookie "^2.3.2" 1936 | webidl-conversions "^4.0.0" 1937 | whatwg-encoding "^1.0.1" 1938 | whatwg-url "^4.3.0" 1939 | xml-name-validator "^2.0.1" 1940 | 1941 | jsesc@^1.3.0: 1942 | version "1.3.0" 1943 | resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-1.3.0.tgz#46c3fec8c1892b12b0833db9bc7622176dbab34b" 1944 | 1945 | jsesc@~0.5.0: 1946 | version "0.5.0" 1947 | resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" 1948 | 1949 | json-schema-traverse@^0.3.0: 1950 | version "0.3.1" 1951 | resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz#349a6d44c53a51de89b40805c5d5e59b417d3340" 1952 | 1953 | json-schema@0.2.3: 1954 | version "0.2.3" 1955 | resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.2.3.tgz#b480c892e59a2f05954ce727bd3f2a4e882f9e13" 1956 | 1957 | json-stable-stringify@^1.0.1: 1958 | version "1.0.1" 1959 | resolved "https://registry.yarnpkg.com/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz#9a759d39c5f2ff503fd5300646ed445f88c4f9af" 1960 | dependencies: 1961 | jsonify "~0.0.0" 1962 | 1963 | json-stringify-safe@~5.0.1: 1964 | version "5.0.1" 1965 | resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" 1966 | 1967 | json5@^0.5.1: 1968 | version "0.5.1" 1969 | resolved "https://registry.yarnpkg.com/json5/-/json5-0.5.1.tgz#1eade7acc012034ad84e2396767ead9fa5495821" 1970 | 1971 | jsonify@~0.0.0: 1972 | version "0.0.0" 1973 | resolved "https://registry.yarnpkg.com/jsonify/-/jsonify-0.0.0.tgz#2c74b6ee41d93ca51b7b5aaee8f503631d252a73" 1974 | 1975 | jsprim@^1.2.2: 1976 | version "1.4.1" 1977 | resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.1.tgz#313e66bc1e5cc06e438bc1b7499c2e5c56acb6a2" 1978 | dependencies: 1979 | assert-plus "1.0.0" 1980 | extsprintf "1.3.0" 1981 | json-schema "0.2.3" 1982 | verror "1.10.0" 1983 | 1984 | kind-of@^3.0.2: 1985 | version "3.2.2" 1986 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64" 1987 | dependencies: 1988 | is-buffer "^1.1.5" 1989 | 1990 | kind-of@^4.0.0: 1991 | version "4.0.0" 1992 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz#20813df3d712928b207378691a45066fae72dd57" 1993 | dependencies: 1994 | is-buffer "^1.1.5" 1995 | 1996 | lazy-cache@^1.0.3: 1997 | version "1.0.4" 1998 | resolved "https://registry.yarnpkg.com/lazy-cache/-/lazy-cache-1.0.4.tgz#a1d78fc3a50474cb80845d3b3b6e1da49a446e8e" 1999 | 2000 | lcid@^1.0.0: 2001 | version "1.0.0" 2002 | resolved "https://registry.yarnpkg.com/lcid/-/lcid-1.0.0.tgz#308accafa0bc483a3867b4b6f2b9506251d1b835" 2003 | dependencies: 2004 | invert-kv "^1.0.0" 2005 | 2006 | leven@^2.1.0: 2007 | version "2.1.0" 2008 | resolved "https://registry.yarnpkg.com/leven/-/leven-2.1.0.tgz#c2e7a9f772094dee9d34202ae8acce4687875580" 2009 | 2010 | levn@~0.3.0: 2011 | version "0.3.0" 2012 | resolved "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee" 2013 | dependencies: 2014 | prelude-ls "~1.1.2" 2015 | type-check "~0.3.2" 2016 | 2017 | load-json-file@^1.0.0: 2018 | version "1.1.0" 2019 | resolved "https://registry.yarnpkg.com/load-json-file/-/load-json-file-1.1.0.tgz#956905708d58b4bab4c2261b04f59f31c99374c0" 2020 | dependencies: 2021 | graceful-fs "^4.1.2" 2022 | parse-json "^2.2.0" 2023 | pify "^2.0.0" 2024 | pinkie-promise "^2.0.0" 2025 | strip-bom "^2.0.0" 2026 | 2027 | load-json-file@^2.0.0: 2028 | version "2.0.0" 2029 | resolved "https://registry.yarnpkg.com/load-json-file/-/load-json-file-2.0.0.tgz#7947e42149af80d696cbf797bcaabcfe1fe29ca8" 2030 | dependencies: 2031 | graceful-fs "^4.1.2" 2032 | parse-json "^2.2.0" 2033 | pify "^2.0.0" 2034 | strip-bom "^3.0.0" 2035 | 2036 | locate-path@^2.0.0: 2037 | version "2.0.0" 2038 | resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e" 2039 | dependencies: 2040 | p-locate "^2.0.0" 2041 | path-exists "^3.0.0" 2042 | 2043 | lodash@^4.13.1, lodash@^4.14.0, lodash@^4.17.4, lodash@^4.3.0: 2044 | version "4.17.4" 2045 | resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.4.tgz#78203a4d1c328ae1d86dca6460e369b57f4055ae" 2046 | 2047 | longest@^1.0.1: 2048 | version "1.0.1" 2049 | resolved "https://registry.yarnpkg.com/longest/-/longest-1.0.1.tgz#30a0b2da38f73770e8294a0d22e6625ed77d0097" 2050 | 2051 | loose-envify@^1.0.0: 2052 | version "1.3.1" 2053 | resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.3.1.tgz#d1a8ad33fa9ce0e713d65fdd0ac8b748d478c848" 2054 | dependencies: 2055 | js-tokens "^3.0.0" 2056 | 2057 | lru-cache@^4.0.1: 2058 | version "4.1.1" 2059 | resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.1.1.tgz#622e32e82488b49279114a4f9ecf45e7cd6bba55" 2060 | dependencies: 2061 | pseudomap "^1.0.2" 2062 | yallist "^2.1.2" 2063 | 2064 | makeerror@1.0.x: 2065 | version "1.0.11" 2066 | resolved "https://registry.yarnpkg.com/makeerror/-/makeerror-1.0.11.tgz#e01a5c9109f2af79660e4e8b9587790184f5a96c" 2067 | dependencies: 2068 | tmpl "1.0.x" 2069 | 2070 | mem@^1.1.0: 2071 | version "1.1.0" 2072 | resolved "https://registry.yarnpkg.com/mem/-/mem-1.1.0.tgz#5edd52b485ca1d900fe64895505399a0dfa45f76" 2073 | dependencies: 2074 | mimic-fn "^1.0.0" 2075 | 2076 | merge@^1.1.3: 2077 | version "1.2.0" 2078 | resolved "https://registry.yarnpkg.com/merge/-/merge-1.2.0.tgz#7531e39d4949c281a66b8c5a6e0265e8b05894da" 2079 | 2080 | micromatch@^2.1.5, micromatch@^2.3.11: 2081 | version "2.3.11" 2082 | resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-2.3.11.tgz#86677c97d1720b363431d04d0d15293bd38c1565" 2083 | dependencies: 2084 | arr-diff "^2.0.0" 2085 | array-unique "^0.2.1" 2086 | braces "^1.8.2" 2087 | expand-brackets "^0.1.4" 2088 | extglob "^0.3.1" 2089 | filename-regex "^2.0.0" 2090 | is-extglob "^1.0.0" 2091 | is-glob "^2.0.1" 2092 | kind-of "^3.0.2" 2093 | normalize-path "^2.0.1" 2094 | object.omit "^2.0.0" 2095 | parse-glob "^3.0.4" 2096 | regex-cache "^0.4.2" 2097 | 2098 | mime-db@~1.30.0: 2099 | version "1.30.0" 2100 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.30.0.tgz#74c643da2dd9d6a45399963465b26d5ca7d71f01" 2101 | 2102 | mime-types@^2.1.12, mime-types@~2.1.17, mime-types@~2.1.7: 2103 | version "2.1.17" 2104 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.17.tgz#09d7a393f03e995a79f8af857b70a9e0ab16557a" 2105 | dependencies: 2106 | mime-db "~1.30.0" 2107 | 2108 | mimic-fn@^1.0.0: 2109 | version "1.1.0" 2110 | resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.1.0.tgz#e667783d92e89dbd342818b5230b9d62a672ad18" 2111 | 2112 | minimatch@^3.0.0, minimatch@^3.0.2, minimatch@^3.0.3, minimatch@^3.0.4: 2113 | version "3.0.4" 2114 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" 2115 | dependencies: 2116 | brace-expansion "^1.1.7" 2117 | 2118 | minimist@0.0.8: 2119 | version "0.0.8" 2120 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.8.tgz#857fcabfc3397d2625b8228262e86aa7a011b05d" 2121 | 2122 | minimist@^1.1.1, minimist@^1.2.0: 2123 | version "1.2.0" 2124 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.0.tgz#a35008b20f41383eec1fb914f4cd5df79a264284" 2125 | 2126 | minimist@~0.0.1: 2127 | version "0.0.10" 2128 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.10.tgz#de3f98543dbf96082be48ad1a0c7cda836301dcf" 2129 | 2130 | "mkdirp@>=0.5 0", mkdirp@^0.5.1: 2131 | version "0.5.1" 2132 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.1.tgz#30057438eac6cf7f8c4767f38648d6697d75c903" 2133 | dependencies: 2134 | minimist "0.0.8" 2135 | 2136 | ms@2.0.0: 2137 | version "2.0.0" 2138 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" 2139 | 2140 | mute-stream@0.0.7: 2141 | version "0.0.7" 2142 | resolved "https://registry.yarnpkg.com/mute-stream/-/mute-stream-0.0.7.tgz#3075ce93bc21b8fab43e1bc4da7e8115ed1e7bab" 2143 | 2144 | nan@^2.3.0: 2145 | version "2.8.0" 2146 | resolved "https://registry.yarnpkg.com/nan/-/nan-2.8.0.tgz#ed715f3fe9de02b57a5e6252d90a96675e1f085a" 2147 | 2148 | natural-compare@^1.4.0: 2149 | version "1.4.0" 2150 | resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" 2151 | 2152 | node-int64@^0.4.0: 2153 | version "0.4.0" 2154 | resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" 2155 | 2156 | node-notifier@^5.0.2: 2157 | version "5.1.2" 2158 | resolved "https://registry.yarnpkg.com/node-notifier/-/node-notifier-5.1.2.tgz#2fa9e12605fa10009d44549d6fcd8a63dde0e4ff" 2159 | dependencies: 2160 | growly "^1.3.0" 2161 | semver "^5.3.0" 2162 | shellwords "^0.1.0" 2163 | which "^1.2.12" 2164 | 2165 | node-pre-gyp@^0.6.39: 2166 | version "0.6.39" 2167 | resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.6.39.tgz#c00e96860b23c0e1420ac7befc5044e1d78d8649" 2168 | dependencies: 2169 | detect-libc "^1.0.2" 2170 | hawk "3.1.3" 2171 | mkdirp "^0.5.1" 2172 | nopt "^4.0.1" 2173 | npmlog "^4.0.2" 2174 | rc "^1.1.7" 2175 | request "2.81.0" 2176 | rimraf "^2.6.1" 2177 | semver "^5.3.0" 2178 | tar "^2.2.1" 2179 | tar-pack "^3.4.0" 2180 | 2181 | nopt@^4.0.1: 2182 | version "4.0.1" 2183 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-4.0.1.tgz#d0d4685afd5415193c8c7505602d0d17cd64474d" 2184 | dependencies: 2185 | abbrev "1" 2186 | osenv "^0.1.4" 2187 | 2188 | normalize-package-data@^2.3.2: 2189 | version "2.4.0" 2190 | resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.4.0.tgz#12f95a307d58352075a04907b84ac8be98ac012f" 2191 | dependencies: 2192 | hosted-git-info "^2.1.4" 2193 | is-builtin-module "^1.0.0" 2194 | semver "2 || 3 || 4 || 5" 2195 | validate-npm-package-license "^3.0.1" 2196 | 2197 | normalize-path@^2.0.0, normalize-path@^2.0.1: 2198 | version "2.1.1" 2199 | resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-2.1.1.tgz#1ab28b556e198363a8c1a6f7e6fa20137fe6aed9" 2200 | dependencies: 2201 | remove-trailing-separator "^1.0.1" 2202 | 2203 | npm-run-path@^2.0.0: 2204 | version "2.0.2" 2205 | resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz#35a9232dfa35d7067b4cb2ddf2357b1871536c5f" 2206 | dependencies: 2207 | path-key "^2.0.0" 2208 | 2209 | npmlog@^4.0.2: 2210 | version "4.1.2" 2211 | resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-4.1.2.tgz#08a7f2a8bf734604779a9efa4ad5cc717abb954b" 2212 | dependencies: 2213 | are-we-there-yet "~1.1.2" 2214 | console-control-strings "~1.1.0" 2215 | gauge "~2.7.3" 2216 | set-blocking "~2.0.0" 2217 | 2218 | number-is-nan@^1.0.0: 2219 | version "1.0.1" 2220 | resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" 2221 | 2222 | "nwmatcher@>= 1.3.9 < 2.0.0": 2223 | version "1.4.3" 2224 | resolved "https://registry.yarnpkg.com/nwmatcher/-/nwmatcher-1.4.3.tgz#64348e3b3d80f035b40ac11563d278f8b72db89c" 2225 | 2226 | oauth-sign@~0.8.1, oauth-sign@~0.8.2: 2227 | version "0.8.2" 2228 | resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.8.2.tgz#46a6ab7f0aead8deae9ec0565780b7d4efeb9d43" 2229 | 2230 | object-assign@^4.1.0: 2231 | version "4.1.1" 2232 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 2233 | 2234 | object.omit@^2.0.0: 2235 | version "2.0.1" 2236 | resolved "https://registry.yarnpkg.com/object.omit/-/object.omit-2.0.1.tgz#1a9c744829f39dbb858c76ca3579ae2a54ebd1fa" 2237 | dependencies: 2238 | for-own "^0.1.4" 2239 | is-extendable "^0.1.1" 2240 | 2241 | once@^1.3.0, once@^1.3.3, once@^1.4.0: 2242 | version "1.4.0" 2243 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 2244 | dependencies: 2245 | wrappy "1" 2246 | 2247 | onetime@^2.0.0: 2248 | version "2.0.1" 2249 | resolved "https://registry.yarnpkg.com/onetime/-/onetime-2.0.1.tgz#067428230fd67443b2794b22bba528b6867962d4" 2250 | dependencies: 2251 | mimic-fn "^1.0.0" 2252 | 2253 | optimist@^0.6.1: 2254 | version "0.6.1" 2255 | resolved "https://registry.yarnpkg.com/optimist/-/optimist-0.6.1.tgz#da3ea74686fa21a19a111c326e90eb15a0196686" 2256 | dependencies: 2257 | minimist "~0.0.1" 2258 | wordwrap "~0.0.2" 2259 | 2260 | optionator@^0.8.1: 2261 | version "0.8.2" 2262 | resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.8.2.tgz#364c5e409d3f4d6301d6c0b4c05bba50180aeb64" 2263 | dependencies: 2264 | deep-is "~0.1.3" 2265 | fast-levenshtein "~2.0.4" 2266 | levn "~0.3.0" 2267 | prelude-ls "~1.1.2" 2268 | type-check "~0.3.2" 2269 | wordwrap "~1.0.0" 2270 | 2271 | os-homedir@^1.0.0: 2272 | version "1.0.2" 2273 | resolved "https://registry.yarnpkg.com/os-homedir/-/os-homedir-1.0.2.tgz#ffbc4988336e0e833de0c168c7ef152121aa7fb3" 2274 | 2275 | os-locale@^2.0.0: 2276 | version "2.1.0" 2277 | resolved "https://registry.yarnpkg.com/os-locale/-/os-locale-2.1.0.tgz#42bc2900a6b5b8bd17376c8e882b65afccf24bf2" 2278 | dependencies: 2279 | execa "^0.7.0" 2280 | lcid "^1.0.0" 2281 | mem "^1.1.0" 2282 | 2283 | os-tmpdir@^1.0.0, os-tmpdir@^1.0.1, os-tmpdir@~1.0.2: 2284 | version "1.0.2" 2285 | resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" 2286 | 2287 | osenv@^0.1.4: 2288 | version "0.1.4" 2289 | resolved "https://registry.yarnpkg.com/osenv/-/osenv-0.1.4.tgz#42fe6d5953df06c8064be6f176c3d05aaaa34644" 2290 | dependencies: 2291 | os-homedir "^1.0.0" 2292 | os-tmpdir "^1.0.0" 2293 | 2294 | output-file-sync@^1.1.2: 2295 | version "1.1.2" 2296 | resolved "https://registry.yarnpkg.com/output-file-sync/-/output-file-sync-1.1.2.tgz#d0a33eefe61a205facb90092e826598d5245ce76" 2297 | dependencies: 2298 | graceful-fs "^4.1.4" 2299 | mkdirp "^0.5.1" 2300 | object-assign "^4.1.0" 2301 | 2302 | p-cancelable@^0.3.0: 2303 | version "0.3.0" 2304 | resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-0.3.0.tgz#b9e123800bcebb7ac13a479be195b507b98d30fa" 2305 | 2306 | p-finally@^1.0.0: 2307 | version "1.0.0" 2308 | resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz#3fbcfb15b899a44123b34b6dcc18b724336a2cae" 2309 | 2310 | p-limit@^1.1.0: 2311 | version "1.1.0" 2312 | resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.1.0.tgz#b07ff2d9a5d88bec806035895a2bab66a27988bc" 2313 | 2314 | p-locate@^2.0.0: 2315 | version "2.0.0" 2316 | resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43" 2317 | dependencies: 2318 | p-limit "^1.1.0" 2319 | 2320 | parse-glob@^3.0.4: 2321 | version "3.0.4" 2322 | resolved "https://registry.yarnpkg.com/parse-glob/-/parse-glob-3.0.4.tgz#b2c376cfb11f35513badd173ef0bb6e3a388391c" 2323 | dependencies: 2324 | glob-base "^0.3.0" 2325 | is-dotfile "^1.0.0" 2326 | is-extglob "^1.0.0" 2327 | is-glob "^2.0.0" 2328 | 2329 | parse-json@^2.2.0: 2330 | version "2.2.0" 2331 | resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-2.2.0.tgz#f480f40434ef80741f8469099f8dea18f55a4dc9" 2332 | dependencies: 2333 | error-ex "^1.2.0" 2334 | 2335 | parse5@^1.5.1: 2336 | version "1.5.1" 2337 | resolved "https://registry.yarnpkg.com/parse5/-/parse5-1.5.1.tgz#9b7f3b0de32be78dc2401b17573ccaf0f6f59d94" 2338 | 2339 | path-exists@^2.0.0: 2340 | version "2.1.0" 2341 | resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-2.1.0.tgz#0feb6c64f0fc518d9a754dd5efb62c7022761f4b" 2342 | dependencies: 2343 | pinkie-promise "^2.0.0" 2344 | 2345 | path-exists@^3.0.0: 2346 | version "3.0.0" 2347 | resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" 2348 | 2349 | path-is-absolute@^1.0.0, path-is-absolute@^1.0.1: 2350 | version "1.0.1" 2351 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 2352 | 2353 | path-key@^2.0.0: 2354 | version "2.0.1" 2355 | resolved "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz#411cadb574c5a140d3a4b1910d40d80cc9f40b40" 2356 | 2357 | path-parse@^1.0.5: 2358 | version "1.0.5" 2359 | resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.5.tgz#3c1adf871ea9cd6c9431b6ea2bd74a0ff055c4c1" 2360 | 2361 | path-type@^1.0.0: 2362 | version "1.1.0" 2363 | resolved "https://registry.yarnpkg.com/path-type/-/path-type-1.1.0.tgz#59c44f7ee491da704da415da5a4070ba4f8fe441" 2364 | dependencies: 2365 | graceful-fs "^4.1.2" 2366 | pify "^2.0.0" 2367 | pinkie-promise "^2.0.0" 2368 | 2369 | path-type@^2.0.0: 2370 | version "2.0.0" 2371 | resolved "https://registry.yarnpkg.com/path-type/-/path-type-2.0.0.tgz#f012ccb8415b7096fc2daa1054c3d72389594c73" 2372 | dependencies: 2373 | pify "^2.0.0" 2374 | 2375 | performance-now@^0.2.0: 2376 | version "0.2.0" 2377 | resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-0.2.0.tgz#33ef30c5c77d4ea21c5a53869d91b56d8f2555e5" 2378 | 2379 | performance-now@^2.1.0: 2380 | version "2.1.0" 2381 | resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" 2382 | 2383 | pify@^2.0.0: 2384 | version "2.3.0" 2385 | resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" 2386 | 2387 | pify@^3.0.0: 2388 | version "3.0.0" 2389 | resolved "https://registry.yarnpkg.com/pify/-/pify-3.0.0.tgz#e5a4acd2c101fdf3d9a4d07f0dbc4db49dd28176" 2390 | 2391 | pinkie-promise@^2.0.0: 2392 | version "2.0.1" 2393 | resolved "https://registry.yarnpkg.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz#2135d6dfa7a358c069ac9b178776288228450ffa" 2394 | dependencies: 2395 | pinkie "^2.0.0" 2396 | 2397 | pinkie@^2.0.0: 2398 | version "2.0.4" 2399 | resolved "https://registry.yarnpkg.com/pinkie/-/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870" 2400 | 2401 | prelude-ls@~1.1.2: 2402 | version "1.1.2" 2403 | resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54" 2404 | 2405 | preserve@^0.2.0: 2406 | version "0.2.0" 2407 | resolved "https://registry.yarnpkg.com/preserve/-/preserve-0.2.0.tgz#815ed1f6ebc65926f865b310c0713bcb3315ce4b" 2408 | 2409 | pretty-format@^21.2.1: 2410 | version "21.2.1" 2411 | resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-21.2.1.tgz#ae5407f3cf21066cd011aa1ba5fce7b6a2eddb36" 2412 | dependencies: 2413 | ansi-regex "^3.0.0" 2414 | ansi-styles "^3.2.0" 2415 | 2416 | private@^0.1.6, private@^0.1.7: 2417 | version "0.1.8" 2418 | resolved "https://registry.yarnpkg.com/private/-/private-0.1.8.tgz#2381edb3689f7a53d653190060fcf822d2f368ff" 2419 | 2420 | process-nextick-args@~1.0.6: 2421 | version "1.0.7" 2422 | resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-1.0.7.tgz#150e20b756590ad3f91093f25a4f2ad8bff30ba3" 2423 | 2424 | prr@~0.0.0: 2425 | version "0.0.0" 2426 | resolved "https://registry.yarnpkg.com/prr/-/prr-0.0.0.tgz#1a84b85908325501411853d0081ee3fa86e2926a" 2427 | 2428 | pseudomap@^1.0.2: 2429 | version "1.0.2" 2430 | resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3" 2431 | 2432 | punycode@^1.4.1: 2433 | version "1.4.1" 2434 | resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e" 2435 | 2436 | qs@~6.4.0: 2437 | version "6.4.0" 2438 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.4.0.tgz#13e26d28ad6b0ffaa91312cd3bf708ed351e7233" 2439 | 2440 | qs@~6.5.1: 2441 | version "6.5.1" 2442 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.1.tgz#349cdf6eef89ec45c12d7d5eb3fc0c870343a6d8" 2443 | 2444 | randomatic@^1.1.3: 2445 | version "1.1.7" 2446 | resolved "https://registry.yarnpkg.com/randomatic/-/randomatic-1.1.7.tgz#c7abe9cc8b87c0baa876b19fde83fd464797e38c" 2447 | dependencies: 2448 | is-number "^3.0.0" 2449 | kind-of "^4.0.0" 2450 | 2451 | raw-body@^2.3.2: 2452 | version "2.3.2" 2453 | resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.3.2.tgz#bcd60c77d3eb93cde0050295c3f379389bc88f89" 2454 | dependencies: 2455 | bytes "3.0.0" 2456 | http-errors "1.6.2" 2457 | iconv-lite "0.4.19" 2458 | unpipe "1.0.0" 2459 | 2460 | rc@^1.1.7: 2461 | version "1.2.2" 2462 | resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.2.tgz#d8ce9cb57e8d64d9c7badd9876c7c34cbe3c7077" 2463 | dependencies: 2464 | deep-extend "~0.4.0" 2465 | ini "~1.3.0" 2466 | minimist "^1.2.0" 2467 | strip-json-comments "~2.0.1" 2468 | 2469 | read-pkg-up@^1.0.1: 2470 | version "1.0.1" 2471 | resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-1.0.1.tgz#9d63c13276c065918d57f002a57f40a1b643fb02" 2472 | dependencies: 2473 | find-up "^1.0.0" 2474 | read-pkg "^1.0.0" 2475 | 2476 | read-pkg-up@^2.0.0: 2477 | version "2.0.0" 2478 | resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-2.0.0.tgz#6b72a8048984e0c41e79510fd5e9fa99b3b549be" 2479 | dependencies: 2480 | find-up "^2.0.0" 2481 | read-pkg "^2.0.0" 2482 | 2483 | read-pkg@^1.0.0: 2484 | version "1.1.0" 2485 | resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-1.1.0.tgz#f5ffaa5ecd29cb31c0474bca7d756b6bb29e3f28" 2486 | dependencies: 2487 | load-json-file "^1.0.0" 2488 | normalize-package-data "^2.3.2" 2489 | path-type "^1.0.0" 2490 | 2491 | read-pkg@^2.0.0: 2492 | version "2.0.0" 2493 | resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-2.0.0.tgz#8ef1c0623c6a6db0dc6713c4bfac46332b2368f8" 2494 | dependencies: 2495 | load-json-file "^2.0.0" 2496 | normalize-package-data "^2.3.2" 2497 | path-type "^2.0.0" 2498 | 2499 | readable-stream@^2.0.2, readable-stream@^2.0.6, readable-stream@^2.1.4: 2500 | version "2.3.3" 2501 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.3.tgz#368f2512d79f9d46fdfc71349ae7878bbc1eb95c" 2502 | dependencies: 2503 | core-util-is "~1.0.0" 2504 | inherits "~2.0.3" 2505 | isarray "~1.0.0" 2506 | process-nextick-args "~1.0.6" 2507 | safe-buffer "~5.1.1" 2508 | string_decoder "~1.0.3" 2509 | util-deprecate "~1.0.1" 2510 | 2511 | readdirp@^2.0.0: 2512 | version "2.1.0" 2513 | resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-2.1.0.tgz#4ed0ad060df3073300c48440373f72d1cc642d78" 2514 | dependencies: 2515 | graceful-fs "^4.1.2" 2516 | minimatch "^3.0.2" 2517 | readable-stream "^2.0.2" 2518 | set-immediate-shim "^1.0.1" 2519 | 2520 | regenerate@^1.2.1: 2521 | version "1.3.3" 2522 | resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.3.3.tgz#0c336d3980553d755c39b586ae3b20aa49c82b7f" 2523 | 2524 | regenerator-runtime@^0.10.5: 2525 | version "0.10.5" 2526 | resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.10.5.tgz#336c3efc1220adcedda2c9fab67b5a7955a33658" 2527 | 2528 | regenerator-runtime@^0.11.0: 2529 | version "0.11.0" 2530 | resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.0.tgz#7e54fe5b5ccd5d6624ea6255c3473be090b802e1" 2531 | 2532 | regenerator-transform@^0.10.0: 2533 | version "0.10.1" 2534 | resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.10.1.tgz#1e4996837231da8b7f3cf4114d71b5691a0680dd" 2535 | dependencies: 2536 | babel-runtime "^6.18.0" 2537 | babel-types "^6.19.0" 2538 | private "^0.1.6" 2539 | 2540 | regex-cache@^0.4.2: 2541 | version "0.4.4" 2542 | resolved "https://registry.yarnpkg.com/regex-cache/-/regex-cache-0.4.4.tgz#75bdc58a2a1496cec48a12835bc54c8d562336dd" 2543 | dependencies: 2544 | is-equal-shallow "^0.1.3" 2545 | 2546 | regexpu-core@^2.0.0: 2547 | version "2.0.0" 2548 | resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-2.0.0.tgz#49d038837b8dcf8bfa5b9a42139938e6ea2ae240" 2549 | dependencies: 2550 | regenerate "^1.2.1" 2551 | regjsgen "^0.2.0" 2552 | regjsparser "^0.1.4" 2553 | 2554 | regjsgen@^0.2.0: 2555 | version "0.2.0" 2556 | resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.2.0.tgz#6c016adeac554f75823fe37ac05b92d5a4edb1f7" 2557 | 2558 | regjsparser@^0.1.4: 2559 | version "0.1.5" 2560 | resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.1.5.tgz#7ee8f84dc6fa792d3fd0ae228d24bd949ead205c" 2561 | dependencies: 2562 | jsesc "~0.5.0" 2563 | 2564 | remove-trailing-separator@^1.0.1: 2565 | version "1.1.0" 2566 | resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef" 2567 | 2568 | repeat-element@^1.1.2: 2569 | version "1.1.2" 2570 | resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.2.tgz#ef089a178d1483baae4d93eb98b4f9e4e11d990a" 2571 | 2572 | repeat-string@^1.5.2: 2573 | version "1.6.1" 2574 | resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" 2575 | 2576 | repeating@^2.0.0: 2577 | version "2.0.1" 2578 | resolved "https://registry.yarnpkg.com/repeating/-/repeating-2.0.1.tgz#5214c53a926d3552707527fbab415dbc08d06dda" 2579 | dependencies: 2580 | is-finite "^1.0.0" 2581 | 2582 | request-promise-core@1.1.1: 2583 | version "1.1.1" 2584 | resolved "https://registry.yarnpkg.com/request-promise-core/-/request-promise-core-1.1.1.tgz#3eee00b2c5aa83239cfb04c5700da36f81cd08b6" 2585 | dependencies: 2586 | lodash "^4.13.1" 2587 | 2588 | request-promise@^4.2.2: 2589 | version "4.2.2" 2590 | resolved "https://registry.yarnpkg.com/request-promise/-/request-promise-4.2.2.tgz#d1ea46d654a6ee4f8ee6a4fea1018c22911904b4" 2591 | dependencies: 2592 | bluebird "^3.5.0" 2593 | request-promise-core "1.1.1" 2594 | stealthy-require "^1.1.0" 2595 | tough-cookie ">=2.3.3" 2596 | 2597 | request@2.81.0: 2598 | version "2.81.0" 2599 | resolved "https://registry.yarnpkg.com/request/-/request-2.81.0.tgz#c6928946a0e06c5f8d6f8a9333469ffda46298a0" 2600 | dependencies: 2601 | aws-sign2 "~0.6.0" 2602 | aws4 "^1.2.1" 2603 | caseless "~0.12.0" 2604 | combined-stream "~1.0.5" 2605 | extend "~3.0.0" 2606 | forever-agent "~0.6.1" 2607 | form-data "~2.1.1" 2608 | har-validator "~4.2.1" 2609 | hawk "~3.1.3" 2610 | http-signature "~1.1.0" 2611 | is-typedarray "~1.0.0" 2612 | isstream "~0.1.2" 2613 | json-stringify-safe "~5.0.1" 2614 | mime-types "~2.1.7" 2615 | oauth-sign "~0.8.1" 2616 | performance-now "^0.2.0" 2617 | qs "~6.4.0" 2618 | safe-buffer "^5.0.1" 2619 | stringstream "~0.0.4" 2620 | tough-cookie "~2.3.0" 2621 | tunnel-agent "^0.6.0" 2622 | uuid "^3.0.0" 2623 | 2624 | request@^2.79.0, request@^2.83.0: 2625 | version "2.83.0" 2626 | resolved "https://registry.yarnpkg.com/request/-/request-2.83.0.tgz#ca0b65da02ed62935887808e6f510381034e3356" 2627 | dependencies: 2628 | aws-sign2 "~0.7.0" 2629 | aws4 "^1.6.0" 2630 | caseless "~0.12.0" 2631 | combined-stream "~1.0.5" 2632 | extend "~3.0.1" 2633 | forever-agent "~0.6.1" 2634 | form-data "~2.3.1" 2635 | har-validator "~5.0.3" 2636 | hawk "~6.0.2" 2637 | http-signature "~1.2.0" 2638 | is-typedarray "~1.0.0" 2639 | isstream "~0.1.2" 2640 | json-stringify-safe "~5.0.1" 2641 | mime-types "~2.1.17" 2642 | oauth-sign "~0.8.2" 2643 | performance-now "^2.1.0" 2644 | qs "~6.5.1" 2645 | safe-buffer "^5.1.1" 2646 | stringstream "~0.0.5" 2647 | tough-cookie "~2.3.3" 2648 | tunnel-agent "^0.6.0" 2649 | uuid "^3.1.0" 2650 | 2651 | require-directory@^2.1.1: 2652 | version "2.1.1" 2653 | resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" 2654 | 2655 | require-main-filename@^1.0.1: 2656 | version "1.0.1" 2657 | resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-1.0.1.tgz#97f717b69d48784f5f526a6c5aa8ffdda055a4d1" 2658 | 2659 | resolve@1.1.7: 2660 | version "1.1.7" 2661 | resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.1.7.tgz#203114d82ad2c5ed9e8e0411b3932875e889e97b" 2662 | 2663 | restore-cursor@^2.0.0: 2664 | version "2.0.0" 2665 | resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-2.0.0.tgz#9f7ee287f82fd326d4fd162923d62129eee0dfaf" 2666 | dependencies: 2667 | onetime "^2.0.0" 2668 | signal-exit "^3.0.2" 2669 | 2670 | right-align@^0.1.1: 2671 | version "0.1.3" 2672 | resolved "https://registry.yarnpkg.com/right-align/-/right-align-0.1.3.tgz#61339b722fe6a3515689210d24e14c96148613ef" 2673 | dependencies: 2674 | align-text "^0.1.1" 2675 | 2676 | rimraf@2, rimraf@^2.5.1, rimraf@^2.6.1: 2677 | version "2.6.2" 2678 | resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.6.2.tgz#2ed8150d24a16ea8651e6d6ef0f47c4158ce7a36" 2679 | dependencies: 2680 | glob "^7.0.5" 2681 | 2682 | run-async@^2.2.0: 2683 | version "2.3.0" 2684 | resolved "https://registry.yarnpkg.com/run-async/-/run-async-2.3.0.tgz#0371ab4ae0bdd720d4166d7dfda64ff7a445a6c0" 2685 | dependencies: 2686 | is-promise "^2.1.0" 2687 | 2688 | rx-lite-aggregates@^4.0.8: 2689 | version "4.0.8" 2690 | resolved "https://registry.yarnpkg.com/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz#753b87a89a11c95467c4ac1626c4efc4e05c67be" 2691 | dependencies: 2692 | rx-lite "*" 2693 | 2694 | rx-lite@*, rx-lite@^4.0.8: 2695 | version "4.0.8" 2696 | resolved "https://registry.yarnpkg.com/rx-lite/-/rx-lite-4.0.8.tgz#0b1e11af8bc44836f04a6407e92da42467b79444" 2697 | 2698 | safe-buffer@^5.0.1, safe-buffer@^5.1.1, safe-buffer@~5.1.0, safe-buffer@~5.1.1: 2699 | version "5.1.1" 2700 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.1.tgz#893312af69b2123def71f57889001671eeb2c853" 2701 | 2702 | sane@^2.0.0: 2703 | version "2.2.0" 2704 | resolved "https://registry.yarnpkg.com/sane/-/sane-2.2.0.tgz#d6d2e2fcab00e3d283c93b912b7c3a20846f1d56" 2705 | dependencies: 2706 | anymatch "^1.3.0" 2707 | exec-sh "^0.2.0" 2708 | fb-watchman "^2.0.0" 2709 | minimatch "^3.0.2" 2710 | minimist "^1.1.1" 2711 | walker "~1.0.5" 2712 | watch "~0.18.0" 2713 | optionalDependencies: 2714 | fsevents "^1.1.1" 2715 | 2716 | sax@^1.2.1: 2717 | version "1.2.4" 2718 | resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" 2719 | 2720 | "semver@2 || 3 || 4 || 5", semver@^5.3.0: 2721 | version "5.4.1" 2722 | resolved "https://registry.yarnpkg.com/semver/-/semver-5.4.1.tgz#e059c09d8571f0540823733433505d3a2f00b18e" 2723 | 2724 | set-blocking@^2.0.0, set-blocking@~2.0.0: 2725 | version "2.0.0" 2726 | resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" 2727 | 2728 | set-immediate-shim@^1.0.1: 2729 | version "1.0.1" 2730 | resolved "https://registry.yarnpkg.com/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz#4b2b1b27eb808a9f8dcc481a58e5e56f599f3f61" 2731 | 2732 | setprototypeof@1.0.3: 2733 | version "1.0.3" 2734 | resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.0.3.tgz#66567e37043eeb4f04d91bd658c0cbefb55b8e04" 2735 | 2736 | shebang-command@^1.2.0: 2737 | version "1.2.0" 2738 | resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea" 2739 | dependencies: 2740 | shebang-regex "^1.0.0" 2741 | 2742 | shebang-regex@^1.0.0: 2743 | version "1.0.0" 2744 | resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3" 2745 | 2746 | shellwords@^0.1.0: 2747 | version "0.1.1" 2748 | resolved "https://registry.yarnpkg.com/shellwords/-/shellwords-0.1.1.tgz#d6b9181c1a48d397324c84871efbcfc73fc0654b" 2749 | 2750 | signal-exit@^3.0.0, signal-exit@^3.0.2: 2751 | version "3.0.2" 2752 | resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.2.tgz#b5fdc08f1287ea1178628e415e25132b73646c6d" 2753 | 2754 | slash@^1.0.0: 2755 | version "1.0.0" 2756 | resolved "https://registry.yarnpkg.com/slash/-/slash-1.0.0.tgz#c41f2f6c39fc16d1cd17ad4b5d896114ae470d55" 2757 | 2758 | sntp@1.x.x: 2759 | version "1.0.9" 2760 | resolved "https://registry.yarnpkg.com/sntp/-/sntp-1.0.9.tgz#6541184cc90aeea6c6e7b35e2659082443c66198" 2761 | dependencies: 2762 | hoek "2.x.x" 2763 | 2764 | sntp@2.x.x: 2765 | version "2.1.0" 2766 | resolved "https://registry.yarnpkg.com/sntp/-/sntp-2.1.0.tgz#2c6cec14fedc2222739caf9b5c3d85d1cc5a2cc8" 2767 | dependencies: 2768 | hoek "4.x.x" 2769 | 2770 | source-map-support@^0.4.15: 2771 | version "0.4.18" 2772 | resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.4.18.tgz#0286a6de8be42641338594e97ccea75f0a2c585f" 2773 | dependencies: 2774 | source-map "^0.5.6" 2775 | 2776 | source-map@^0.4.4: 2777 | version "0.4.4" 2778 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.4.4.tgz#eba4f5da9c0dc999de68032d8b4f76173652036b" 2779 | dependencies: 2780 | amdefine ">=0.0.4" 2781 | 2782 | source-map@^0.5.3, source-map@^0.5.6, source-map@~0.5.1, source-map@~0.5.6: 2783 | version "0.5.7" 2784 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" 2785 | 2786 | spdx-correct@~1.0.0: 2787 | version "1.0.2" 2788 | resolved "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-1.0.2.tgz#4b3073d933ff51f3912f03ac5519498a4150db40" 2789 | dependencies: 2790 | spdx-license-ids "^1.0.2" 2791 | 2792 | spdx-expression-parse@~1.0.0: 2793 | version "1.0.4" 2794 | resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz#9bdf2f20e1f40ed447fbe273266191fced51626c" 2795 | 2796 | spdx-license-ids@^1.0.2: 2797 | version "1.2.2" 2798 | resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz#c9df7a3424594ade6bd11900d596696dc06bac57" 2799 | 2800 | sprintf-js@~1.0.2: 2801 | version "1.0.3" 2802 | resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" 2803 | 2804 | sshpk@^1.7.0: 2805 | version "1.13.1" 2806 | resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.13.1.tgz#512df6da6287144316dc4c18fe1cf1d940739be3" 2807 | dependencies: 2808 | asn1 "~0.2.3" 2809 | assert-plus "^1.0.0" 2810 | dashdash "^1.12.0" 2811 | getpass "^0.1.1" 2812 | optionalDependencies: 2813 | bcrypt-pbkdf "^1.0.0" 2814 | ecc-jsbn "~0.1.1" 2815 | jsbn "~0.1.0" 2816 | tweetnacl "~0.14.0" 2817 | 2818 | "statuses@>= 1.3.1 < 2": 2819 | version "1.4.0" 2820 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.4.0.tgz#bb73d446da2796106efcc1b601a253d6c46bd087" 2821 | 2822 | stealthy-require@^1.1.0: 2823 | version "1.1.1" 2824 | resolved "https://registry.yarnpkg.com/stealthy-require/-/stealthy-require-1.1.1.tgz#35b09875b4ff49f26a777e509b3090a3226bf24b" 2825 | 2826 | string-length@^2.0.0: 2827 | version "2.0.0" 2828 | resolved "https://registry.yarnpkg.com/string-length/-/string-length-2.0.0.tgz#d40dbb686a3ace960c1cffca562bf2c45f8363ed" 2829 | dependencies: 2830 | astral-regex "^1.0.0" 2831 | strip-ansi "^4.0.0" 2832 | 2833 | string-width@^1.0.1, string-width@^1.0.2: 2834 | version "1.0.2" 2835 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" 2836 | dependencies: 2837 | code-point-at "^1.0.0" 2838 | is-fullwidth-code-point "^1.0.0" 2839 | strip-ansi "^3.0.0" 2840 | 2841 | string-width@^2.0.0, string-width@^2.1.0: 2842 | version "2.1.1" 2843 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" 2844 | dependencies: 2845 | is-fullwidth-code-point "^2.0.0" 2846 | strip-ansi "^4.0.0" 2847 | 2848 | string_decoder@~1.0.3: 2849 | version "1.0.3" 2850 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.0.3.tgz#0fc67d7c141825de94282dd536bec6b9bce860ab" 2851 | dependencies: 2852 | safe-buffer "~5.1.0" 2853 | 2854 | stringstream@~0.0.4, stringstream@~0.0.5: 2855 | version "0.0.5" 2856 | resolved "https://registry.yarnpkg.com/stringstream/-/stringstream-0.0.5.tgz#4e484cd4de5a0bbbee18e46307710a8a81621878" 2857 | 2858 | strip-ansi@^3.0.0, strip-ansi@^3.0.1: 2859 | version "3.0.1" 2860 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" 2861 | dependencies: 2862 | ansi-regex "^2.0.0" 2863 | 2864 | strip-ansi@^4.0.0: 2865 | version "4.0.0" 2866 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" 2867 | dependencies: 2868 | ansi-regex "^3.0.0" 2869 | 2870 | strip-bom@3.0.0, strip-bom@^3.0.0: 2871 | version "3.0.0" 2872 | resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" 2873 | 2874 | strip-bom@^2.0.0: 2875 | version "2.0.0" 2876 | resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-2.0.0.tgz#6219a85616520491f35788bdbf1447a99c7e6b0e" 2877 | dependencies: 2878 | is-utf8 "^0.2.0" 2879 | 2880 | strip-eof@^1.0.0: 2881 | version "1.0.0" 2882 | resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf" 2883 | 2884 | strip-json-comments@~2.0.1: 2885 | version "2.0.1" 2886 | resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" 2887 | 2888 | supports-color@^2.0.0: 2889 | version "2.0.0" 2890 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz#535d045ce6b6363fa40117084629995e9df324c7" 2891 | 2892 | supports-color@^3.1.2: 2893 | version "3.2.3" 2894 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-3.2.3.tgz#65ac0504b3954171d8a64946b2ae3cbb8a5f54f6" 2895 | dependencies: 2896 | has-flag "^1.0.0" 2897 | 2898 | supports-color@^4.0.0: 2899 | version "4.5.0" 2900 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-4.5.0.tgz#be7a0de484dec5c5cddf8b3d59125044912f635b" 2901 | dependencies: 2902 | has-flag "^2.0.0" 2903 | 2904 | symbol-tree@^3.2.1: 2905 | version "3.2.2" 2906 | resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.2.tgz#ae27db38f660a7ae2e1c3b7d1bc290819b8519e6" 2907 | 2908 | tar-pack@^3.4.0: 2909 | version "3.4.1" 2910 | resolved "https://registry.yarnpkg.com/tar-pack/-/tar-pack-3.4.1.tgz#e1dbc03a9b9d3ba07e896ad027317eb679a10a1f" 2911 | dependencies: 2912 | debug "^2.2.0" 2913 | fstream "^1.0.10" 2914 | fstream-ignore "^1.0.5" 2915 | once "^1.3.3" 2916 | readable-stream "^2.1.4" 2917 | rimraf "^2.5.1" 2918 | tar "^2.2.1" 2919 | uid-number "^0.0.6" 2920 | 2921 | tar@^2.2.1: 2922 | version "2.2.1" 2923 | resolved "https://registry.yarnpkg.com/tar/-/tar-2.2.1.tgz#8e4d2a256c0e2185c6b18ad694aec968b83cb1d1" 2924 | dependencies: 2925 | block-stream "*" 2926 | fstream "^1.0.2" 2927 | inherits "2" 2928 | 2929 | test-exclude@^4.1.1: 2930 | version "4.1.1" 2931 | resolved "https://registry.yarnpkg.com/test-exclude/-/test-exclude-4.1.1.tgz#4d84964b0966b0087ecc334a2ce002d3d9341e26" 2932 | dependencies: 2933 | arrify "^1.0.1" 2934 | micromatch "^2.3.11" 2935 | object-assign "^4.1.0" 2936 | read-pkg-up "^1.0.1" 2937 | require-main-filename "^1.0.1" 2938 | 2939 | throat@^4.0.0: 2940 | version "4.1.0" 2941 | resolved "https://registry.yarnpkg.com/throat/-/throat-4.1.0.tgz#89037cbc92c56ab18926e6ba4cbb200e15672a6a" 2942 | 2943 | through@^2.3.6: 2944 | version "2.3.8" 2945 | resolved "https://registry.yarnpkg.com/through/-/through-2.3.8.tgz#0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5" 2946 | 2947 | tmp@^0.0.33: 2948 | version "0.0.33" 2949 | resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.0.33.tgz#6d34335889768d21b2bcda0aa277ced3b1bfadf9" 2950 | dependencies: 2951 | os-tmpdir "~1.0.2" 2952 | 2953 | tmpl@1.0.x: 2954 | version "1.0.4" 2955 | resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.4.tgz#23640dd7b42d00433911140820e5cf440e521dd1" 2956 | 2957 | to-fast-properties@^1.0.3: 2958 | version "1.0.3" 2959 | resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-1.0.3.tgz#b83571fa4d8c25b82e231b06e3a3055de4ca1a47" 2960 | 2961 | tough-cookie@>=2.3.3, tough-cookie@^2.3.2, tough-cookie@~2.3.0, tough-cookie@~2.3.3: 2962 | version "2.3.3" 2963 | resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.3.3.tgz#0b618a5565b6dea90bf3425d04d55edc475a7561" 2964 | dependencies: 2965 | punycode "^1.4.1" 2966 | 2967 | tr46@~0.0.3: 2968 | version "0.0.3" 2969 | resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" 2970 | 2971 | trim-right@^1.0.1: 2972 | version "1.0.1" 2973 | resolved "https://registry.yarnpkg.com/trim-right/-/trim-right-1.0.1.tgz#cb2e1203067e0c8de1f614094b9fe45704ea6003" 2974 | 2975 | ttys@^0.0.3: 2976 | version "0.0.3" 2977 | resolved "https://registry.yarnpkg.com/ttys/-/ttys-0.0.3.tgz#15bacde7831020de5f2f28f01b1732ef03651f4d" 2978 | 2979 | tunnel-agent@^0.6.0: 2980 | version "0.6.0" 2981 | resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" 2982 | dependencies: 2983 | safe-buffer "^5.0.1" 2984 | 2985 | tweetnacl@^0.14.3, tweetnacl@~0.14.0: 2986 | version "0.14.5" 2987 | resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" 2988 | 2989 | type-check@~0.3.2: 2990 | version "0.3.2" 2991 | resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz#5884cab512cf1d355e3fb784f30804b2b520db72" 2992 | dependencies: 2993 | prelude-ls "~1.1.2" 2994 | 2995 | uglify-js@^2.6: 2996 | version "2.8.29" 2997 | resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.8.29.tgz#29c5733148057bb4e1f75df35b7a9cb72e6a59dd" 2998 | dependencies: 2999 | source-map "~0.5.1" 3000 | yargs "~3.10.0" 3001 | optionalDependencies: 3002 | uglify-to-browserify "~1.0.0" 3003 | 3004 | uglify-to-browserify@~1.0.0: 3005 | version "1.0.2" 3006 | resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7" 3007 | 3008 | uid-number@^0.0.6: 3009 | version "0.0.6" 3010 | resolved "https://registry.yarnpkg.com/uid-number/-/uid-number-0.0.6.tgz#0ea10e8035e8eb5b8e4449f06da1c730663baa81" 3011 | 3012 | unpipe@1.0.0: 3013 | version "1.0.0" 3014 | resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" 3015 | 3016 | user-home@^1.1.1: 3017 | version "1.1.1" 3018 | resolved "https://registry.yarnpkg.com/user-home/-/user-home-1.1.1.tgz#2b5be23a32b63a7c9deb8d0f28d485724a3df190" 3019 | 3020 | util-deprecate@~1.0.1: 3021 | version "1.0.2" 3022 | resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" 3023 | 3024 | uuid@^3.0.0, uuid@^3.1.0: 3025 | version "3.1.0" 3026 | resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.1.0.tgz#3dd3d3e790abc24d7b0d3a034ffababe28ebbc04" 3027 | 3028 | v8flags@^2.1.1: 3029 | version "2.1.1" 3030 | resolved "https://registry.yarnpkg.com/v8flags/-/v8flags-2.1.1.tgz#aab1a1fa30d45f88dd321148875ac02c0b55e5b4" 3031 | dependencies: 3032 | user-home "^1.1.1" 3033 | 3034 | validate-npm-package-license@^3.0.1: 3035 | version "3.0.1" 3036 | resolved "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz#2804babe712ad3379459acfbe24746ab2c303fbc" 3037 | dependencies: 3038 | spdx-correct "~1.0.0" 3039 | spdx-expression-parse "~1.0.0" 3040 | 3041 | verror@1.10.0: 3042 | version "1.10.0" 3043 | resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400" 3044 | dependencies: 3045 | assert-plus "^1.0.0" 3046 | core-util-is "1.0.2" 3047 | extsprintf "^1.2.0" 3048 | 3049 | walker@~1.0.5: 3050 | version "1.0.7" 3051 | resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.7.tgz#2f7f9b8fd10d677262b18a884e28d19618e028fb" 3052 | dependencies: 3053 | makeerror "1.0.x" 3054 | 3055 | watch@~0.18.0: 3056 | version "0.18.0" 3057 | resolved "https://registry.yarnpkg.com/watch/-/watch-0.18.0.tgz#28095476c6df7c90c963138990c0a5423eb4b986" 3058 | dependencies: 3059 | exec-sh "^0.2.0" 3060 | minimist "^1.2.0" 3061 | 3062 | webidl-conversions@^3.0.0: 3063 | version "3.0.1" 3064 | resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" 3065 | 3066 | webidl-conversions@^4.0.0: 3067 | version "4.0.2" 3068 | resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-4.0.2.tgz#a855980b1f0b6b359ba1d5d9fb39ae941faa63ad" 3069 | 3070 | whatwg-encoding@^1.0.1: 3071 | version "1.0.3" 3072 | resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-1.0.3.tgz#57c235bc8657e914d24e1a397d3c82daee0a6ba3" 3073 | dependencies: 3074 | iconv-lite "0.4.19" 3075 | 3076 | whatwg-url@^4.3.0: 3077 | version "4.8.0" 3078 | resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-4.8.0.tgz#d2981aa9148c1e00a41c5a6131166ab4683bbcc0" 3079 | dependencies: 3080 | tr46 "~0.0.3" 3081 | webidl-conversions "^3.0.0" 3082 | 3083 | which-module@^2.0.0: 3084 | version "2.0.0" 3085 | resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a" 3086 | 3087 | which@^1.2.12, which@^1.2.9: 3088 | version "1.3.0" 3089 | resolved "https://registry.yarnpkg.com/which/-/which-1.3.0.tgz#ff04bdfc010ee547d780bec38e1ac1c2777d253a" 3090 | dependencies: 3091 | isexe "^2.0.0" 3092 | 3093 | wide-align@^1.1.0: 3094 | version "1.1.2" 3095 | resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.2.tgz#571e0f1b0604636ebc0dfc21b0339bbe31341710" 3096 | dependencies: 3097 | string-width "^1.0.2" 3098 | 3099 | window-size@0.1.0: 3100 | version "0.1.0" 3101 | resolved "https://registry.yarnpkg.com/window-size/-/window-size-0.1.0.tgz#5438cd2ea93b202efa3a19fe8887aee7c94f9c9d" 3102 | 3103 | wordwrap@0.0.2: 3104 | version "0.0.2" 3105 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.2.tgz#b79669bb42ecb409f83d583cad52ca17eaa1643f" 3106 | 3107 | wordwrap@~0.0.2: 3108 | version "0.0.3" 3109 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.3.tgz#a3d5da6cd5c0bc0008d37234bbaf1bed63059107" 3110 | 3111 | wordwrap@~1.0.0: 3112 | version "1.0.0" 3113 | resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-1.0.0.tgz#27584810891456a4171c8d0226441ade90cbcaeb" 3114 | 3115 | worker-farm@^1.3.1: 3116 | version "1.5.2" 3117 | resolved "https://registry.yarnpkg.com/worker-farm/-/worker-farm-1.5.2.tgz#32b312e5dc3d5d45d79ef44acc2587491cd729ae" 3118 | dependencies: 3119 | errno "^0.1.4" 3120 | xtend "^4.0.1" 3121 | 3122 | wrap-ansi@^2.0.0: 3123 | version "2.1.0" 3124 | resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-2.1.0.tgz#d8fc3d284dd05794fe84973caecdd1cf824fdd85" 3125 | dependencies: 3126 | string-width "^1.0.1" 3127 | strip-ansi "^3.0.1" 3128 | 3129 | wrappy@1: 3130 | version "1.0.2" 3131 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 3132 | 3133 | write-file-atomic@^2.1.0: 3134 | version "2.3.0" 3135 | resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-2.3.0.tgz#1ff61575c2e2a4e8e510d6fa4e243cce183999ab" 3136 | dependencies: 3137 | graceful-fs "^4.1.11" 3138 | imurmurhash "^0.1.4" 3139 | signal-exit "^3.0.2" 3140 | 3141 | xml-name-validator@^2.0.1: 3142 | version "2.0.1" 3143 | resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-2.0.1.tgz#4d8b8f1eccd3419aa362061becef515e1e559635" 3144 | 3145 | xtend@^4.0.1: 3146 | version "4.0.1" 3147 | resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af" 3148 | 3149 | y18n@^3.2.1: 3150 | version "3.2.1" 3151 | resolved "https://registry.yarnpkg.com/y18n/-/y18n-3.2.1.tgz#6d15fba884c08679c0d77e88e7759e811e07fa41" 3152 | 3153 | yallist@^2.1.2: 3154 | version "2.1.2" 3155 | resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52" 3156 | 3157 | yargs-parser@^7.0.0: 3158 | version "7.0.0" 3159 | resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-7.0.0.tgz#8d0ac42f16ea55debd332caf4c4038b3e3f5dfd9" 3160 | dependencies: 3161 | camelcase "^4.1.0" 3162 | 3163 | yargs@^9.0.0: 3164 | version "9.0.1" 3165 | resolved "https://registry.yarnpkg.com/yargs/-/yargs-9.0.1.tgz#52acc23feecac34042078ee78c0c007f5085db4c" 3166 | dependencies: 3167 | camelcase "^4.1.0" 3168 | cliui "^3.2.0" 3169 | decamelize "^1.1.1" 3170 | get-caller-file "^1.0.1" 3171 | os-locale "^2.0.0" 3172 | read-pkg-up "^2.0.0" 3173 | require-directory "^2.1.1" 3174 | require-main-filename "^1.0.1" 3175 | set-blocking "^2.0.0" 3176 | string-width "^2.0.0" 3177 | which-module "^2.0.0" 3178 | y18n "^3.2.1" 3179 | yargs-parser "^7.0.0" 3180 | 3181 | yargs@~3.10.0: 3182 | version "3.10.0" 3183 | resolved "https://registry.yarnpkg.com/yargs/-/yargs-3.10.0.tgz#f7ee7bd857dd7c1d2d38c0e74efbd681d1431fd1" 3184 | dependencies: 3185 | camelcase "^1.0.2" 3186 | cliui "^2.1.0" 3187 | decamelize "^1.0.0" 3188 | window-size "0.1.0" 3189 | --------------------------------------------------------------------------------