├── .gitignore ├── .travis.yml ├── Dockerfile ├── LICENSE.txt ├── README.md ├── add-keys.js ├── create-ipa.js ├── create-release.js ├── dev-version-xcode.js ├── ensure-login-keychain.js ├── find-identity-name.js ├── lib ├── exec.js ├── find-identity-name.js ├── git.js ├── list.js ├── logger.js └── slack.js ├── package-lock.json ├── package.json ├── remove-keys.js ├── upload-apk.js └── upload-ipa.js /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - node 4 | - 7 5 | - 4 6 | 7 | cache: 8 | directories: 9 | - "node_modules" 10 | -------------------------------------------------------------------------------- /Dockerfile: -------------------------------------------------------------------------------- 1 | FROM node:12 2 | RUN npm -g install xcode-build-tools 3 | -------------------------------------------------------------------------------- /LICENSE.txt: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2013 Fred Cox 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy of 6 | this software and associated documentation files (the "Software"), to deal in 7 | the Software without restriction, including without limitation the rights to 8 | use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of 9 | the Software, and to permit persons to whom the Software is furnished to do so, 10 | 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, FITNESS 17 | FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR 18 | COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER 19 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 20 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 21 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Xcode build tools 2 | 3 | A few scripts for our CI server 4 | 5 | [![Version](https://img.shields.io/npm/v/xcode-build-tools.svg)](https://www.npmjs.com/package/xcode-build-tools) 6 | [![License](https://img.shields.io/npm/l/xcode-build-tools.svg)](https://www.npmjs.com/package/xcode-build-tools) 7 | [![Build Status](https://travis-ci.org/ekreative/xcode-build-tools.svg?branch=master)](https://travis-ci.org/ekreative/xcode-build-tools) 8 | 9 | Install with `npm install xcode-build-tools` 10 | 11 | ## `add-keys` 12 | 13 | Usage: add-keys [options] 14 | 15 | Creates a new Keychain and sets as the default. Imports keys and certificates to it and enables build tool access 16 | 17 | WARNING: Changes your default keychain 18 | 19 | Options: 20 | 21 | -h, --help output usage information 22 | -V, --version output the version number 23 | -k, --keychain-name Keychain Name - default APP_NAME 24 | --timeout Keychain password timeout - default 1 hour 25 | --apple-cert Apple WWDR certificate - default download from apple 26 | --app-certs List of app sigining certificates - default APP_CER 27 | --app-keys List app sigining keys - default APP_KEY 28 | --app-key-passwords App sigining key password or list of passwords - default KEY_PASSWORD 29 | --provisioning-profiles Provisioning profiles - default PROVISIONING_PROFILE 30 | --codesign Programs that should be able to use the certificates - default codesign, productbuild 31 | 32 | ## `remove-keys` 33 | 34 | Usage: remove-keys [options] 35 | 36 | Delete a keychain and provisioning profiles 37 | 38 | Options: 39 | 40 | -h, --help output usage information 41 | -V, --version output the version number 42 | -k, --keychain-name Keychain Name - default APP_NAME 43 | --provisioning-profiles Provisioning profiles - default PROVISIONING_PROFILE 44 | 45 | ## `create-ipa` 46 | 47 | Usage: create-ipa [options] 48 | 49 | Create an .ipa file from an .app 50 | 51 | Options: 52 | 53 | -h, --help output usage information 54 | -V, --version output the version number 55 | -k, --keychain-name Keychain Name - default APP_NAME 56 | --developer-name Developer name to use - CODE_SIGN_IDENTITY 57 | --ipa Ipa file to create - default build/Release-iphoneos/$APP_NAME.ipa 58 | --app App file to convert - default build/Release-iphoneos/$APP_NAME.app 59 | --provisioning-profile Provisioning profile - default PROVISIONING_PROFILE 60 | 61 | ## `upload-ipa` 62 | 63 | Usage: upload-ipa [options] 64 | 65 | Upload ipa file to testbuild.rocks and (optional) send a link to slack 66 | 67 | Options: 68 | 69 | -h, --help output usage information 70 | -V, --version output the version number 71 | -p, --project-id Project Id - default PROJECT_ID 72 | --server Alternative server address 73 | --ipa Ipa file to upload - default build/Release-iphoneos/$APP_NAME.ipa 74 | --key Test build rocks key - default TEST_BUILD_ROCKS_KEY 75 | -s, --slack-hook Slack Hook - default SLACK_URL 76 | -c, --slack-channel Slack Channel - default SLACK_CHANNEL 77 | -m, --message Test build rocks message 78 | 79 | ## `upload-apk` 80 | 81 | Usage: upload-apk [options] 82 | 83 | Upload apk file to testbuild.rocks and (optional) send a link to slack 84 | 85 | Options: 86 | 87 | -h, --help output usage information 88 | -V, --version output the version number 89 | -p, --project-id Project Id - default PROJECT_ID 90 | --apk Apk file to upload - default app/build/outputs/apk/app-release.apk 91 | --key Test build rocks key - defaul tTEST_BUILD_ROCKS_KEY 92 | -s, --slack-hook Slack Hook - default SLACK_URL 93 | -c, --slack-channel Slack Channel - default SLACK_CHANNEL 94 | -m, --message Test build rocks message 95 | 96 | ## `create-release` 97 | 98 | Usage: create-release [options] 99 | 100 | Create a new release on GitLab 101 | 102 | Options: 103 | 104 | -h, --help output usage information 105 | -V, --version output the version number 106 | --server GitLab server 107 | --token Api key 108 | --project-id Project Id 109 | --tag-name Tag name 110 | --ref Git ref 111 | -n, --notes Release notes 112 | 113 | ## Summary of env vars 114 | 115 | * `APP_NAME` - Name of the app to build eg "Kidslox" 116 | 117 | To install keys 118 | 119 | * `PROVISIONING_PROFILE` - Location of provisioning profile 120 | * `APP_CER` - Location of your signing cert 121 | * `APP_KEY` - Location of the matching key 122 | * `KEY_PASSWORD` - Password to the signing key 123 | * `CODE_SIGN_IDENTITY` - Name of the developer eg 'iPhone Distribution: Developer' 124 | 125 | Upload builds 126 | 127 | * `TEST_BUILD_ROCKS_KEY` - API key for testbuild.rocks to upload 128 | * `PROJECT_ID` - Project id for testbuild.rocks 129 | 130 | Get slack notifications 131 | 132 | * `SLACK_URL` - Slack hook to notify of upload (or `SLACK_HOOK`) 133 | * `SLACK_CHANNEL` - Override the hook channel 134 | 135 | Create release 136 | 137 | * `GITLAB_API_TOKEN` - Token that gives access to the GitLab API to create a new release 138 | 139 | GitLab CI Variables used 140 | 141 | * `CI_PROJECT_ID` - GitLab project id 142 | * `CI_PROJECT_URL` - GitLab project url 143 | * `CI_COMMIT_SHA` - Current git commit 144 | * `CI_JOB_ID` - Current job number 145 | * `CI_COMMIT_REF_SLUG` - Current branch name (url friendly) 146 | -------------------------------------------------------------------------------- /add-keys.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var cpr = require('cpr') 6 | var crypto = require('crypto') 7 | var os = require('os') 8 | var path = require('path') 9 | var program = require('commander') 10 | 11 | var exec = require('./lib/exec') 12 | var list = require('./lib/list') 13 | var logger = require('./lib/logger') 14 | 15 | program 16 | .version(require('./package.json').version) 17 | .description('Creates a new Keychain and sets as the default. Imports keys and certificates to it and enables build tool access.\n \n WARNING: Changes your default keychain.\n This can cause problems for Graphic CI environments where git using osxkeychain. This can be solved by disabling this feature\n git config --system --unset credential.helper') 18 | .option('-k, --keychain-name ', 'Keychain Name - default APP_NAME', process.env.APP_NAME || 'build-tools') 19 | .option('--timeout ', 'Keychain password timeout - default 1 hour', parseInt, 3600) 20 | .option('--apple-cert ', 'Apple WWDR certificate - default download from apple', process.env.APPLE_CERT) 21 | .option('--app-certs ', 'List of app sigining certificates - default APP_CER', list, list(process.env.APP_CERT)) 22 | .option('--app-keys ', 'List app sigining keys - default APP_KEY', list, list(process.env.APP_KEY)) 23 | .option('--app-key-passwords ', 'App sigining key password or list of passwords - default KEY_PASSWORD', list, list(process.env.KEY_PASSWORD)) 24 | .option('--provisioning-profiles ', 'Provisioning profiles - default PROVISIONING_PROFILE', list, list(process.env.PROVISIONING_PROFILE)) 25 | .option('--codesign ', 'Programs that should be able to use the certificates - default codesign, productbuild', list, ['/usr/bin/codesign', '/usr/bin/productbuild']) 26 | .option('--password ', 'Set the password used for the keychain, otherwise a random password is generated') 27 | .parse(process.argv) 28 | 29 | var password = program.password || crypto.randomBytes(8).toString('hex') 30 | var commands = [ 31 | // delete existing keychain 32 | 'security delete-keychain "' + program.keychainName + '.keychain" || :', 33 | // Create a custom keychain 34 | 'security create-keychain -p "' + password + '" "' + program.keychainName + '.keychain"', 35 | // Add it to the list 36 | 'security list-keychains -s "' + program.keychainName + '.keychain"', 37 | // Make the custom keychain default, so xcodebuild will use it for signing 38 | 'security default-keychain -s "' + program.keychainName + '.keychain"', 39 | // Unlock the keychain 40 | 'security unlock-keychain -p "' + password + '" "' + program.keychainName + '.keychain"', 41 | // Set keychain timeout to 1 hour for long builds 42 | 'security set-keychain-settings -t ' + program.timeout + ' -l "' + program.keychainName + '.keychain"' 43 | ] 44 | var codesign = program.codesign.map(function (p) { return '-T "' + p + '"' }).join(' ') 45 | 46 | // Add the Apple developer root cert 47 | if (program.appleCert) { 48 | commands.push('security import "' + program.appleCert + '" -k "' + program.keychainName + '.keychain" ' + codesign) 49 | } else { 50 | commands.push( 51 | 'curl "https://developer.apple.com/certificationauthority/AppleWWDRCA.cer" > apple.cer', 'security import apple.cer -k "' + program.keychainName + '.keychain" ' + codesign, 'rm apple.cer' 52 | ) 53 | } 54 | 55 | // Add certificates to keychain and allow codesign to access them 56 | program.appCerts && program.appCerts.forEach(function (appCert) { 57 | commands.push('security import "' + appCert + '" -k "' + program.keychainName + '.keychain" ' + codesign) 58 | }) 59 | 60 | program.appKeys && program.appKeys.forEach(function (appKey, idx) { 61 | var keyPassword = program.appKeyPasswords[idx] || program.appKeyPasswords[0] || '' 62 | commands.push('security import "' + appKey + '" -k "' + program.keychainName + '.keychain" -P "' + keyPassword + '" ' + codesign) 63 | 64 | // Since Sierra this is needed to unlock the key for codesign without UI http://stackoverflow.com/a/40039594/859027 65 | commands.push('security set-key-partition-list -S apple-tool:,apple: -s -k "' + password + '" "' + program.keychainName + '.keychain"') 66 | }) 67 | 68 | var commandPromise = exec(commands.shift()) 69 | 70 | commands.forEach(function (command) { 71 | commandPromise = commandPromise.then(function () { 72 | return exec(command) 73 | }).catch(function (err) { 74 | // Ignore errors for existing items 75 | if (!/item already exists/.test(err)) { 76 | throw err 77 | } 78 | }) 79 | }) 80 | 81 | commandPromise = commandPromise.catch(function (err) { 82 | logger.error('Error setting up keychain', err) 83 | process.exit(1) 84 | }) 85 | 86 | commandPromise.then(function () { 87 | logger.info('Created keychain') 88 | }) 89 | 90 | // Put the provisioning profiles in place 91 | program.provisioningProfiles && program.provisioningProfiles.forEach(function (profile) { 92 | var name = path.basename(profile, path.extname(profile)) 93 | logger.info('Installing ' + profile) 94 | cpr(profile, os.homedir() + '/Library/MobileDevice/Provisioning Profiles/' + name + '.mobileprovision', { 95 | overwrite: true 96 | }, function (err) { 97 | if (err) { 98 | logger.error('Error copying profiles', err) 99 | process.exit(1) 100 | } 101 | }) 102 | }) 103 | -------------------------------------------------------------------------------- /create-ipa.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var program = require('commander') 6 | 7 | var exec = require('./lib/exec') 8 | var list = require('./lib/list') 9 | var logger = require('./lib/logger') 10 | 11 | program.version(require('./package.json').version) 12 | .description('Create an .ipa file from an .app') 13 | .option('-k, --keychain-name ', 'Keychain Name - default APP_NAME', process.env.APP_NAME || 'build-tools') 14 | .option('--ipa ', 'Ipa file to create - default build/Release-iphoneos/$APP_NAME.ipa', process.cwd() + '/build/Release-iphoneos/' + (process.env.APP_NAME ? process.env.APP_NAME + '.ipa' : 'app.ipa')) 15 | .option('--app ', 'App file to convert - default build/Release-iphoneos/$APP_NAME.app', process.cwd() + '/build/Release-iphoneos/' + (process.env.APP_NAME ? process.env.APP_NAME + '.app' : 'app.app')) 16 | .option('--provisioning-profile ', 'Provisioning profile - default PROVISIONING_PROFILE', list, list(process.env.PROVISIONING_PROFILE)) 17 | .parse(process.argv) 18 | 19 | var create = function create () { 20 | var embed = program.provisioningProfile.length ? ' -embed "' + program.provisioningProfile + '"' : '' 21 | 22 | return exec('xcrun -log -sdk iphoneos PackageApplication "' + program.app + '" -o "' + program.ipa + '" ' + embed) 23 | } 24 | 25 | create().catch(function (err) { 26 | logger.error('Error creating ipa', err) 27 | process.exit(1) 28 | }) 29 | -------------------------------------------------------------------------------- /create-release.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var execSync = require('child_process').execSync 6 | var fetch = require('node-fetch') 7 | var FormData = require('form-data') 8 | var program = require('commander') 9 | 10 | var git = require('./lib/git') 11 | var logger = require('./lib/logger') 12 | 13 | program 14 | .version(require('./package.json').version) 15 | .description('Create a new release on GitLab') 16 | .option('--server ', 'GitLab server', process.env.GITLAB_API || 'https://git.ekreative.com') 17 | .option('--token ', 'Api key', process.env.GITLAB_API_TOKEN) 18 | .option('--project-id ', 'Project Id', process.env.CI_PROJECT_ID) 19 | .option('--tag-name ', 'Tag name', 'auto') 20 | .option('--ref ', 'Git ref', process.env.CI_COMMIT_SHA || process.env.CI_BUILD_REF || 'auto') 21 | .option('--apk ', 'Apk file to find version - default app/build/outputs/apk/app-release.apk', (process.env.PROJECT_FOLDER || process.cwd()) + '/app/build/outputs/apk/app-release.apk') 22 | .option('--appVersion ', 'Set the version to tag, will have build number added') 23 | .option('--build-number ', 'Set the build number to use', process.env.CI_JOB_ID || process.env.CI_BUILD_ID || '1') 24 | .option('-n, --notes ', 'Release notes', 'auto') 25 | .parse(process.argv) 26 | 27 | if (!program.buildNumber) { 28 | throw new Error('Missing build number') 29 | } 30 | 31 | if (program.notes === 'auto') { 32 | program.notes = git.commit() 33 | } 34 | 35 | if (!program.server) { 36 | throw new Error('Missing GitLab server') 37 | } 38 | 39 | if (!program.token) { 40 | throw new Error('Missing GitLab token') 41 | } 42 | 43 | if (!program.projectId) { 44 | throw new Error('Missing GitLab Project Id') 45 | } 46 | 47 | if (program.tagName === 'auto') { 48 | if (program.appVersion) { 49 | program.tagName = 'v' + program.version + '-' + program.buildNumber 50 | } else { 51 | try { 52 | program.tagName = 'v' + iosVersion() + '-' + program.buildNumber 53 | } catch (e) { 54 | try { 55 | program.tagName = 'v' + androidVersion(program.apk) + '-' + program.buildNumber 56 | } catch (e) { 57 | var date = new Date() 58 | program.tagName = [date.getUTCFullYear(), date.getUTCMonth() + 1, date.getUTCDate()].map(leadingZero).join('-') + '.' + program.buildNumber 59 | } 60 | } 61 | } 62 | } 63 | 64 | if (!program.tagName) { 65 | throw new Error('Missing tag name') 66 | } 67 | 68 | if (program.ref === 'auto') { 69 | try { 70 | program.ref = git.ref() 71 | } catch (e) { 72 | throw new Error('Missing git ref') 73 | } 74 | } 75 | 76 | logger.info('Creating release: ' + program.tagName) 77 | 78 | var data = new FormData() 79 | data.append('tag_name', program.tagName) 80 | data.append('ref', program.ref) 81 | data.append('release_description', program.notes) 82 | 83 | data.getLengthSync = null // Work around until https://github.com/bitinn/node-fetch/issues/102 84 | 85 | var result = fetch(program.server + '/api/v4/projects/' + program.projectId + '/repository/tags', { 86 | method: 'POST', 87 | body: data, 88 | headers: { 89 | 'PRIVATE-TOKEN': program.token 90 | } 91 | }) 92 | .then(function (res) { 93 | if (res.status >= 200 && res.status < 300) { 94 | return res 95 | } 96 | return res.text().then(function (body) { 97 | throw new Error('Failed to create release [' + body + ']') 98 | }) 99 | }) 100 | result = result.then(function () { 101 | logger.info('Created release ' + program.tagName) 102 | }) 103 | 104 | result.catch(function (err) { 105 | logger.error('Error creating release', err) 106 | process.exit(1) 107 | }) 108 | 109 | function leadingZero (val) { 110 | var str = '' + val 111 | if (str.length === 1) { 112 | return '0' + str 113 | } 114 | return str 115 | } 116 | 117 | function iosVersion () { 118 | return ('' + execSync('agvtool what-marketing-version -terse1')).trim().split('\n').pop() 119 | } 120 | 121 | function androidVersion (apk) { 122 | var v = ('' + execSync('aapt dump badging "' + apk + '" | grep versionName')).trim() 123 | if (!v) { 124 | throw new Error('Failed to find appVersion') 125 | } 126 | var matches = v.match(/versionName='(.+?)'/) 127 | if (!matches || !matches[1]) { 128 | throw new Error('Invalid version from aapt ' + v) 129 | } 130 | return matches[1] 131 | } 132 | -------------------------------------------------------------------------------- /dev-version-xcode.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var program = require('commander') 6 | 7 | var exec = require('./lib/exec') 8 | var logger = require('./lib/logger') 9 | 10 | program.version(require('./package.json').version) 11 | .description('Set version for building') 12 | .option('-v, --current-version ', 'Current main version') 13 | .parse(process.argv) 14 | 15 | var version = function () { 16 | return Promise.resolve() 17 | .then(function () { 18 | if (program.currentVersion) { 19 | return program.currentVersion 20 | } else { 21 | return exec('agvtool what-marketing-version -terse1') 22 | .then(function (result) { 23 | return result.stdout.trim() 24 | }) 25 | } 26 | }) 27 | .then(function (version) { 28 | return exec('agvtool new-version -all "' + version + 'dev$(date +"%Y_%m_%d_%H_%M")$CI_BUILD_REF_NAME"') 29 | }) 30 | } 31 | 32 | version().catch(function (err) { 33 | logger.error('Error updating version', err) 34 | process.exit(1) 35 | }) 36 | -------------------------------------------------------------------------------- /ensure-login-keychain.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var program = require('commander') 6 | 7 | var exec = require('./lib/exec') 8 | var logger = require('./lib/logger') 9 | 10 | program 11 | .version(require('./package.json').version) 12 | .description('Ensure default login keychain exists') 13 | .parse(process.argv) 14 | 15 | exec('security list-keychains -d user').then(function (process) { 16 | var exists = false 17 | process.stdout.split('\n').forEach(function (keychainX) { 18 | var keychain = keychainX.trim() 19 | if (keychain) { 20 | if (/login\.keychain-db/.test(keychain)) { 21 | logger.info('Keychain exists') 22 | exists = true 23 | return 24 | } 25 | 26 | exec('security delete-keychain ' + keychain) 27 | .catch(function (err) { 28 | logger.error('Failed to delete keychain', keychain, err) 29 | }) 30 | } 31 | }) 32 | 33 | if (!exists) { 34 | return exec('security create-keychain -p "" login.keychain || :').then(function (process) { 35 | logger.info('Created keychain') 36 | return exec('security default-keychain -s login.keychain') 37 | }).then(function () { 38 | logger.info('Set default') 39 | }) 40 | } 41 | }) 42 | .catch(function (err) { 43 | logger.error('Tried to create keychain', err) 44 | process.exit(1) 45 | }) 46 | -------------------------------------------------------------------------------- /find-identity-name.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var program = require('commander') 6 | 7 | var find = require('./lib/find-identity-name') 8 | var logger = require('./lib/logger') 9 | 10 | program 11 | .version(require('./package.json').version) 12 | .option('-k, --keychain-name ', 'Keychain Name - default APP_NAME', process.env.APP_NAME || 'build-tools') 13 | .parse(process.argv) 14 | 15 | find(program.keychainName) 16 | .then(function (name) { 17 | process.stdout.write(name) 18 | }).catch(function (err) { 19 | logger.error('Error finding name', err) 20 | process.exit(1) 21 | }) 22 | -------------------------------------------------------------------------------- /lib/exec.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | var exec = require('child_process').exec 4 | 5 | var logger = require('./logger') 6 | 7 | module.exports = function (cmd, options) { 8 | return new Promise(function (resolve, reject) { 9 | logger.info(cmd) 10 | exec(cmd, options, function (err, stdout, stderr) { 11 | if (err) { 12 | reject(err) 13 | return 14 | } 15 | resolve({ stdout: stdout, stderr: stderr }) 16 | }) 17 | }) 18 | } 19 | -------------------------------------------------------------------------------- /lib/find-identity-name.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | var exec = require('./exec') 4 | 5 | module.exports = function (keyChainName) { 6 | var commandPromise = exec('security find-identity -v "' + keyChainName + '.keychain" || :') 7 | 8 | return commandPromise.then(function (out) { 9 | var matches = out.stdout.match(/1\) .+? "(.+?)"/) 10 | if (matches && matches[1]) { 11 | return matches[1] 12 | } 13 | throw new Error('No valid identities') 14 | }) 15 | } 16 | -------------------------------------------------------------------------------- /lib/git.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | var execSync = require('child_process').execSync 4 | 5 | module.exports.commit = function () { 6 | return ('' + execSync('git log --format=%B -n 1 || echo "No comment"')).trim() 7 | } 8 | 9 | module.exports.ref = function () { 10 | return ('' + execSync('git rev-parse HEAD')).trim() 11 | } 12 | 13 | module.exports.branch = function () { 14 | return ('' + execSync('git symbolic-ref --quiet --short HEAD || git rev-parse --short HEAD')).trim() 15 | } 16 | -------------------------------------------------------------------------------- /lib/list.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | module.exports = function (val) { return val ? val.split(',') : [] } 4 | -------------------------------------------------------------------------------- /lib/logger.js: -------------------------------------------------------------------------------- 1 | var winston = require('winston') 2 | 3 | module.exports = winston.createLogger({ 4 | format: winston.format.simple(), 5 | transports: [ 6 | new winston.transports.Console() 7 | ] 8 | }) 9 | -------------------------------------------------------------------------------- /lib/slack.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | var fetch = require('node-fetch') 4 | var moment = require('moment') 5 | 6 | var logger = require('./logger') 7 | 8 | module.exports = function (slackHook, slackChannel, projectUrl) { 9 | return function (json) { 10 | var data = { 11 | attachments: [{ 12 | fallback: 'Uploaded ' + json.name + ' to TestBuild.rocks', 13 | pretext: 'Uploaded ' + json.name + ' to TestBuild.rocks', 14 | title: json.name, 15 | title_link: json.install, 16 | color: 'good', 17 | fields: [{ 18 | title: 'Version', 19 | value: '' + json.version, 20 | short: true 21 | }, { 22 | title: 'Build', 23 | value: projectUrl ? '<' + projectUrl + '/-/jobs/' + json.build + '|' + json.build + '>' : '' + json.build, 24 | short: true 25 | }, { 26 | title: 'Platform', 27 | value: json.type, 28 | short: true 29 | }, { 30 | title: 'Date', 31 | value: moment.unix(json.date).format('llll'), 32 | short: true 33 | }], 34 | thumb_url: json.qrcode 35 | }], 36 | channel: slackChannel 37 | } 38 | 39 | if (json.iconurl) { 40 | data.image_url = json.iconurl 41 | } 42 | 43 | if (json.appServer) { 44 | data.attachments[0].fields.push({ 45 | title: 'Server', 46 | value: json.appServer, 47 | short: true 48 | }) 49 | } 50 | 51 | if (json.ref) { 52 | data.attachments[0].fields.push({ 53 | title: 'Git Ref', 54 | value: projectUrl ? '<' + projectUrl + '/tree/' + json.ref + '|' + json.ref + '>' : json.ref, 55 | short: true 56 | }) 57 | } 58 | 59 | if (json.commit) { 60 | data.attachments[0].fields.push({ 61 | title: 'Git Commit', 62 | value: projectUrl ? '<' + projectUrl + '/commit/' + json.commit + '|' + json.commit + '>' : json.commit, 63 | short: true 64 | }) 65 | } 66 | 67 | if (json.comment) { 68 | data.attachments[0].fields.push({ 69 | title: 'Comment', 70 | value: json.comment 71 | }) 72 | } 73 | 74 | var reqBody = JSON.stringify(data) 75 | return fetch(slackHook, { 76 | method: 'POST', 77 | body: reqBody 78 | }) 79 | .then(function (res) { 80 | if (res.status === 200) { 81 | logger.info('Sent to Slack') 82 | return 83 | } 84 | return res.text().then(function (body) { 85 | throw new Error('Failed to send to slack (' + slackHook + ', ' + slackChannel + ') [' + body + '] [' + reqBody + ']') 86 | }) 87 | }) 88 | } 89 | } 90 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "xcode-build-tools", 3 | "version": "4.18.5", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.5.5", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", 10 | "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.5.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 19 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@nodelib/fs.scandir": { 28 | "version": "2.1.1", 29 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.1.tgz", 30 | "integrity": "sha512-NT/skIZjgotDSiXs0WqYhgcuBKhUMgfekCmCGtkUAiLqZdOnrdjmZr9wRl3ll64J9NF79uZ4fk16Dx0yMc/Xbg==", 31 | "requires": { 32 | "@nodelib/fs.stat": "2.0.1", 33 | "run-parallel": "^1.1.9" 34 | } 35 | }, 36 | "@nodelib/fs.stat": { 37 | "version": "2.0.1", 38 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.1.tgz", 39 | "integrity": "sha512-+RqhBlLn6YRBGOIoVYthsG0J9dfpO79eJyN7BYBkZJtfqrBwf2KK+rD/M/yjZR6WBmIhAgOV7S60eCgaSWtbFw==" 40 | }, 41 | "@nodelib/fs.walk": { 42 | "version": "1.2.2", 43 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.2.tgz", 44 | "integrity": "sha512-J/DR3+W12uCzAJkw7niXDcqcKBg6+5G5Q/ZpThpGNzAUz70eOR6RV4XnnSN01qHZiVl0eavoxJsBypQoKsV2QQ==", 45 | "requires": { 46 | "@nodelib/fs.scandir": "2.1.1", 47 | "fastq": "^1.6.0" 48 | } 49 | }, 50 | "@types/events": { 51 | "version": "3.0.0", 52 | "resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.0.tgz", 53 | "integrity": "sha512-EaObqwIvayI5a8dCzhFrjKzVwKLxjoG9T6Ppd5CEo07LRKfQ8Yokw54r5+Wq7FaBQ+yXRvQAYPrHwya1/UFt9g==" 54 | }, 55 | "@types/glob": { 56 | "version": "7.1.1", 57 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.1.tgz", 58 | "integrity": "sha512-1Bh06cbWJUHMC97acuD6UMG29nMt0Aqz1vF3guLfG+kHHJhy3AyohZFFxYk2f7Q1SQIrNwvncxAE0N/9s70F2w==", 59 | "requires": { 60 | "@types/events": "*", 61 | "@types/minimatch": "*", 62 | "@types/node": "*" 63 | } 64 | }, 65 | "@types/minimatch": { 66 | "version": "3.0.3", 67 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", 68 | "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==" 69 | }, 70 | "@types/node": { 71 | "version": "12.7.2", 72 | "resolved": "https://registry.npmjs.org/@types/node/-/node-12.7.2.tgz", 73 | "integrity": "sha512-dyYO+f6ihZEtNPDcWNR1fkoTDf3zAK3lAABDze3mz6POyIercH0lEUawUFXlG8xaQZmm1yEBON/4TsYv/laDYg==" 74 | }, 75 | "acorn": { 76 | "version": "6.3.0", 77 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.3.0.tgz", 78 | "integrity": "sha512-/czfa8BwS88b9gWQVhc8eknunSA2DoJpJyTQkhheIf5E48u1N0R4q/YxxsAeqRrmK9TQ/uYfgLDfZo91UlANIA==", 79 | "dev": true 80 | }, 81 | "acorn-jsx": { 82 | "version": "5.0.1", 83 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 84 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 85 | "dev": true 86 | }, 87 | "ajv": { 88 | "version": "6.10.2", 89 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 90 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 91 | "dev": true, 92 | "requires": { 93 | "fast-deep-equal": "^2.0.1", 94 | "fast-json-stable-stringify": "^2.0.0", 95 | "json-schema-traverse": "^0.4.1", 96 | "uri-js": "^4.2.2" 97 | } 98 | }, 99 | "ansi-escapes": { 100 | "version": "4.2.1", 101 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.2.1.tgz", 102 | "integrity": "sha512-Cg3ymMAdN10wOk/VYfLV7KCQyv7EDirJ64500sU7n9UlmioEtDuU5Gd+hj73hXSU/ex7tHJSssmyftDdkMLO8Q==", 103 | "dev": true, 104 | "requires": { 105 | "type-fest": "^0.5.2" 106 | } 107 | }, 108 | "ansi-regex": { 109 | "version": "4.1.0", 110 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 111 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 112 | "dev": true 113 | }, 114 | "ansi-styles": { 115 | "version": "3.2.1", 116 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 117 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 118 | "dev": true, 119 | "requires": { 120 | "color-convert": "^1.9.0" 121 | } 122 | }, 123 | "argparse": { 124 | "version": "1.0.10", 125 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 126 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 127 | "dev": true, 128 | "requires": { 129 | "sprintf-js": "~1.0.2" 130 | } 131 | }, 132 | "array-includes": { 133 | "version": "3.0.3", 134 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 135 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 136 | "dev": true, 137 | "requires": { 138 | "define-properties": "^1.1.2", 139 | "es-abstract": "^1.7.0" 140 | } 141 | }, 142 | "array-union": { 143 | "version": "2.1.0", 144 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 145 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==" 146 | }, 147 | "astral-regex": { 148 | "version": "1.0.0", 149 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 150 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 151 | "dev": true 152 | }, 153 | "async": { 154 | "version": "2.6.2", 155 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.2.tgz", 156 | "integrity": "sha512-H1qVYh1MYhEEFLsP97cVKqCGo7KfCyTt6uEWqsTBr9SO84oK9Uwbyd/yCW+6rKJLHksBNUVWZDAjfS+Ccx0Bbg==", 157 | "requires": { 158 | "lodash": "^4.17.11" 159 | }, 160 | "dependencies": { 161 | "lodash": { 162 | "version": "4.17.11", 163 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 164 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==" 165 | } 166 | } 167 | }, 168 | "asynckit": { 169 | "version": "0.4.0", 170 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 171 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 172 | }, 173 | "balanced-match": { 174 | "version": "1.0.0", 175 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 176 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 177 | }, 178 | "brace-expansion": { 179 | "version": "1.1.8", 180 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 181 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 182 | "requires": { 183 | "balanced-match": "^1.0.0", 184 | "concat-map": "0.0.1" 185 | } 186 | }, 187 | "braces": { 188 | "version": "3.0.2", 189 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 190 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 191 | "requires": { 192 | "fill-range": "^7.0.1" 193 | } 194 | }, 195 | "callsites": { 196 | "version": "3.1.0", 197 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 198 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 199 | "dev": true 200 | }, 201 | "chalk": { 202 | "version": "2.4.2", 203 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 204 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 205 | "dev": true, 206 | "requires": { 207 | "ansi-styles": "^3.2.1", 208 | "escape-string-regexp": "^1.0.5", 209 | "supports-color": "^5.3.0" 210 | } 211 | }, 212 | "chardet": { 213 | "version": "0.7.0", 214 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 215 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 216 | "dev": true 217 | }, 218 | "cli-cursor": { 219 | "version": "3.1.0", 220 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 221 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 222 | "dev": true, 223 | "requires": { 224 | "restore-cursor": "^3.1.0" 225 | } 226 | }, 227 | "cli-width": { 228 | "version": "2.2.0", 229 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 230 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 231 | "dev": true 232 | }, 233 | "color": { 234 | "version": "3.0.0", 235 | "resolved": "https://registry.npmjs.org/color/-/color-3.0.0.tgz", 236 | "integrity": "sha512-jCpd5+s0s0t7p3pHQKpnJ0TpQKKdleP71LWcA0aqiljpiuAkOSUFN/dyH8ZwF0hRmFlrIuRhufds1QyEP9EB+w==", 237 | "requires": { 238 | "color-convert": "^1.9.1", 239 | "color-string": "^1.5.2" 240 | } 241 | }, 242 | "color-convert": { 243 | "version": "1.9.3", 244 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 245 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 246 | "requires": { 247 | "color-name": "1.1.3" 248 | } 249 | }, 250 | "color-name": { 251 | "version": "1.1.3", 252 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 253 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 254 | }, 255 | "color-string": { 256 | "version": "1.5.3", 257 | "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.5.3.tgz", 258 | "integrity": "sha512-dC2C5qeWoYkxki5UAXapdjqO672AM4vZuPGRQfO8b5HKuKGBbKWpITyDYN7TOFKvRW7kOgAn3746clDBMDJyQw==", 259 | "requires": { 260 | "color-name": "^1.0.0", 261 | "simple-swizzle": "^0.2.2" 262 | } 263 | }, 264 | "colornames": { 265 | "version": "1.1.1", 266 | "resolved": "https://registry.npmjs.org/colornames/-/colornames-1.1.1.tgz", 267 | "integrity": "sha1-+IiQMGhcfE/54qVZ9Qd+t2qBb5Y=" 268 | }, 269 | "colors": { 270 | "version": "1.3.3", 271 | "resolved": "https://registry.npmjs.org/colors/-/colors-1.3.3.tgz", 272 | "integrity": "sha512-mmGt/1pZqYRjMxB1axhTo16/snVZ5krrKkcmMeVKxzECMMXoCgnvTPp10QgHfcbQZw8Dq2jMNG6je4JlWU0gWg==" 273 | }, 274 | "colorspace": { 275 | "version": "1.1.2", 276 | "resolved": "https://registry.npmjs.org/colorspace/-/colorspace-1.1.2.tgz", 277 | "integrity": "sha512-vt+OoIP2d76xLhjwbBaucYlNSpPsrJWPlBTtwCpQKIu6/CSMutyzX93O/Do0qzpH3YoHEes8YEFXyZ797rEhzQ==", 278 | "requires": { 279 | "color": "3.0.x", 280 | "text-hex": "1.0.x" 281 | } 282 | }, 283 | "combined-stream": { 284 | "version": "1.0.8", 285 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 286 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 287 | "requires": { 288 | "delayed-stream": "~1.0.0" 289 | } 290 | }, 291 | "commander": { 292 | "version": "3.0.0", 293 | "resolved": "https://registry.npmjs.org/commander/-/commander-3.0.0.tgz", 294 | "integrity": "sha512-pl3QrGOBa9RZaslQiqnnKX2J068wcQw7j9AIaBQ9/JEp5RY6je4jKTImg0Bd+rpoONSe7GUFSgkxLeo17m3Pow==" 295 | }, 296 | "concat-map": { 297 | "version": "0.0.1", 298 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 299 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 300 | }, 301 | "contains-path": { 302 | "version": "0.1.0", 303 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 304 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 305 | "dev": true 306 | }, 307 | "core-util-is": { 308 | "version": "1.0.2", 309 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 310 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" 311 | }, 312 | "cpr": { 313 | "version": "3.0.1", 314 | "resolved": "https://registry.npmjs.org/cpr/-/cpr-3.0.1.tgz", 315 | "integrity": "sha1-uaVQOLfNgaNcF7l2GJW9hJau8eU=", 316 | "requires": { 317 | "graceful-fs": "^4.1.5", 318 | "minimist": "^1.2.0", 319 | "mkdirp": "~0.5.1", 320 | "rimraf": "^2.5.4" 321 | } 322 | }, 323 | "cross-spawn": { 324 | "version": "6.0.5", 325 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 326 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 327 | "dev": true, 328 | "requires": { 329 | "nice-try": "^1.0.4", 330 | "path-key": "^2.0.1", 331 | "semver": "^5.5.0", 332 | "shebang-command": "^1.2.0", 333 | "which": "^1.2.9" 334 | }, 335 | "dependencies": { 336 | "semver": { 337 | "version": "5.7.1", 338 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 339 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 340 | "dev": true 341 | } 342 | } 343 | }, 344 | "data-uri-to-buffer": { 345 | "version": "4.0.0", 346 | "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-4.0.0.tgz", 347 | "integrity": "sha512-Vr3mLBA8qWmcuschSLAOogKgQ/Jwxulv3RNE4FXnYWRGujzrRWQI4m12fQqRkwX06C0KanhLr4hK+GydchZsaA==" 348 | }, 349 | "debug": { 350 | "version": "4.1.1", 351 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 352 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 353 | "dev": true, 354 | "requires": { 355 | "ms": "^2.1.1" 356 | } 357 | }, 358 | "debug-log": { 359 | "version": "1.0.1", 360 | "resolved": "https://registry.npmjs.org/debug-log/-/debug-log-1.0.1.tgz", 361 | "integrity": "sha1-IwdjLUwEOCuN+KMvcLiVBG1SdF8=", 362 | "dev": true 363 | }, 364 | "deep-is": { 365 | "version": "0.1.3", 366 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 367 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 368 | "dev": true 369 | }, 370 | "define-properties": { 371 | "version": "1.1.3", 372 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 373 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 374 | "dev": true, 375 | "requires": { 376 | "object-keys": "^1.0.12" 377 | } 378 | }, 379 | "deglob": { 380 | "version": "3.1.0", 381 | "resolved": "https://registry.npmjs.org/deglob/-/deglob-3.1.0.tgz", 382 | "integrity": "sha512-al10l5QAYaM/PeuXkAr1Y9AQz0LCtWsnJG23pIgh44hDxHFOj36l6qvhfjnIWBYwZOqM1fXUFV9tkjL7JPdGvw==", 383 | "dev": true, 384 | "requires": { 385 | "find-root": "^1.0.0", 386 | "glob": "^7.0.5", 387 | "ignore": "^5.0.0", 388 | "pkg-config": "^1.1.0", 389 | "run-parallel": "^1.1.2", 390 | "uniq": "^1.0.1" 391 | }, 392 | "dependencies": { 393 | "ignore": { 394 | "version": "5.1.4", 395 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.4.tgz", 396 | "integrity": "sha512-MzbUSahkTW1u7JpKKjY7LCARd1fU5W2rLdxlM4kdkayuCwZImjkpluF9CM1aLewYJguPDqewLam18Y6AU69A8A==", 397 | "dev": true 398 | } 399 | } 400 | }, 401 | "del": { 402 | "version": "5.0.0", 403 | "resolved": "https://registry.npmjs.org/del/-/del-5.0.0.tgz", 404 | "integrity": "sha512-TfU3nUY0WDIhN18eq+pgpbLY9AfL5RfiE9czKaTSolc6aK7qASXfDErvYgjV1UqCR4sNXDoxO0/idPmhDUt2Sg==", 405 | "requires": { 406 | "globby": "^10.0.0", 407 | "is-path-cwd": "^2.0.0", 408 | "is-path-in-cwd": "^2.0.0", 409 | "p-map": "^2.0.0", 410 | "rimraf": "^2.6.3" 411 | }, 412 | "dependencies": { 413 | "glob": { 414 | "version": "7.1.4", 415 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 416 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 417 | "requires": { 418 | "fs.realpath": "^1.0.0", 419 | "inflight": "^1.0.4", 420 | "inherits": "2", 421 | "minimatch": "^3.0.4", 422 | "once": "^1.3.0", 423 | "path-is-absolute": "^1.0.0" 424 | } 425 | }, 426 | "rimraf": { 427 | "version": "2.7.1", 428 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 429 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 430 | "requires": { 431 | "glob": "^7.1.3" 432 | } 433 | } 434 | } 435 | }, 436 | "delayed-stream": { 437 | "version": "1.0.0", 438 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 439 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 440 | }, 441 | "diagnostics": { 442 | "version": "1.1.1", 443 | "resolved": "https://registry.npmjs.org/diagnostics/-/diagnostics-1.1.1.tgz", 444 | "integrity": "sha512-8wn1PmdunLJ9Tqbx+Fx/ZEuHfJf4NKSN2ZBj7SJC/OWRWha843+WsTjqMe1B5E3p28jqBlp+mJ2fPVxPyNgYKQ==", 445 | "requires": { 446 | "colorspace": "1.1.x", 447 | "enabled": "1.0.x", 448 | "kuler": "1.0.x" 449 | } 450 | }, 451 | "dir-glob": { 452 | "version": "3.0.1", 453 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 454 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 455 | "requires": { 456 | "path-type": "^4.0.0" 457 | }, 458 | "dependencies": { 459 | "path-type": { 460 | "version": "4.0.0", 461 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 462 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==" 463 | } 464 | } 465 | }, 466 | "doctrine": { 467 | "version": "3.0.0", 468 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 469 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 470 | "dev": true, 471 | "requires": { 472 | "esutils": "^2.0.2" 473 | } 474 | }, 475 | "emoji-regex": { 476 | "version": "8.0.0", 477 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 478 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 479 | "dev": true 480 | }, 481 | "enabled": { 482 | "version": "1.0.2", 483 | "resolved": "https://registry.npmjs.org/enabled/-/enabled-1.0.2.tgz", 484 | "integrity": "sha1-ll9lE9LC0cX0ZStkouM5ZGf8L5M=", 485 | "requires": { 486 | "env-variable": "0.0.x" 487 | } 488 | }, 489 | "env-variable": { 490 | "version": "0.0.5", 491 | "resolved": "https://registry.npmjs.org/env-variable/-/env-variable-0.0.5.tgz", 492 | "integrity": "sha512-zoB603vQReOFvTg5xMl9I1P2PnHsHQQKTEowsKKD7nseUfJq6UWzK+4YtlWUO1nhiQUxe6XMkk+JleSZD1NZFA==" 493 | }, 494 | "error-ex": { 495 | "version": "1.3.2", 496 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 497 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 498 | "dev": true, 499 | "requires": { 500 | "is-arrayish": "^0.2.1" 501 | } 502 | }, 503 | "es-abstract": { 504 | "version": "1.13.0", 505 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 506 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 507 | "dev": true, 508 | "requires": { 509 | "es-to-primitive": "^1.2.0", 510 | "function-bind": "^1.1.1", 511 | "has": "^1.0.3", 512 | "is-callable": "^1.1.4", 513 | "is-regex": "^1.0.4", 514 | "object-keys": "^1.0.12" 515 | } 516 | }, 517 | "es-to-primitive": { 518 | "version": "1.2.0", 519 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 520 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 521 | "dev": true, 522 | "requires": { 523 | "is-callable": "^1.1.4", 524 | "is-date-object": "^1.0.1", 525 | "is-symbol": "^1.0.2" 526 | } 527 | }, 528 | "escape-string-regexp": { 529 | "version": "1.0.5", 530 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 531 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 532 | "dev": true 533 | }, 534 | "eslint": { 535 | "version": "6.1.0", 536 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.1.0.tgz", 537 | "integrity": "sha512-QhrbdRD7ofuV09IuE2ySWBz0FyXCq0rriLTZXZqaWSI79CVtHVRdkFuFTViiqzZhkCgfOh9USpriuGN2gIpZDQ==", 538 | "dev": true, 539 | "requires": { 540 | "@babel/code-frame": "^7.0.0", 541 | "ajv": "^6.10.0", 542 | "chalk": "^2.1.0", 543 | "cross-spawn": "^6.0.5", 544 | "debug": "^4.0.1", 545 | "doctrine": "^3.0.0", 546 | "eslint-scope": "^5.0.0", 547 | "eslint-utils": "^1.3.1", 548 | "eslint-visitor-keys": "^1.0.0", 549 | "espree": "^6.0.0", 550 | "esquery": "^1.0.1", 551 | "esutils": "^2.0.2", 552 | "file-entry-cache": "^5.0.1", 553 | "functional-red-black-tree": "^1.0.1", 554 | "glob-parent": "^5.0.0", 555 | "globals": "^11.7.0", 556 | "ignore": "^4.0.6", 557 | "import-fresh": "^3.0.0", 558 | "imurmurhash": "^0.1.4", 559 | "inquirer": "^6.4.1", 560 | "is-glob": "^4.0.0", 561 | "js-yaml": "^3.13.1", 562 | "json-stable-stringify-without-jsonify": "^1.0.1", 563 | "levn": "^0.3.0", 564 | "lodash": "^4.17.14", 565 | "minimatch": "^3.0.4", 566 | "mkdirp": "^0.5.1", 567 | "natural-compare": "^1.4.0", 568 | "optionator": "^0.8.2", 569 | "progress": "^2.0.0", 570 | "regexpp": "^2.0.1", 571 | "semver": "^6.1.2", 572 | "strip-ansi": "^5.2.0", 573 | "strip-json-comments": "^3.0.1", 574 | "table": "^5.2.3", 575 | "text-table": "^0.2.0", 576 | "v8-compile-cache": "^2.0.3" 577 | } 578 | }, 579 | "eslint-config-standard": { 580 | "version": "13.0.1", 581 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-13.0.1.tgz", 582 | "integrity": "sha512-zLKp4QOgq6JFgRm1dDCVv1Iu0P5uZ4v5Wa4DTOkg2RFMxdCX/9Qf7lz9ezRj2dBRa955cWQF/O/LWEiYWAHbTw==", 583 | "dev": true 584 | }, 585 | "eslint-config-standard-jsx": { 586 | "version": "7.0.0", 587 | "resolved": "https://registry.npmjs.org/eslint-config-standard-jsx/-/eslint-config-standard-jsx-7.0.0.tgz", 588 | "integrity": "sha512-OiKOF3MFVmWOCVfsi8GHlVorOEiBsPzAnUhM3c6HML94O2krbdQ/eMABySHgHHOIBYRls9sR9I3lo6O0vXhVEg==", 589 | "dev": true 590 | }, 591 | "eslint-import-resolver-node": { 592 | "version": "0.3.2", 593 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 594 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 595 | "dev": true, 596 | "requires": { 597 | "debug": "^2.6.9", 598 | "resolve": "^1.5.0" 599 | }, 600 | "dependencies": { 601 | "debug": { 602 | "version": "2.6.9", 603 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 604 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 605 | "dev": true, 606 | "requires": { 607 | "ms": "2.0.0" 608 | } 609 | }, 610 | "ms": { 611 | "version": "2.0.0", 612 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 613 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 614 | "dev": true 615 | } 616 | } 617 | }, 618 | "eslint-module-utils": { 619 | "version": "2.4.1", 620 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.1.tgz", 621 | "integrity": "sha512-H6DOj+ejw7Tesdgbfs4jeS4YMFrT8uI8xwd1gtQqXssaR0EQ26L+2O/w6wkYFy2MymON0fTwHmXBvvfLNZVZEw==", 622 | "dev": true, 623 | "requires": { 624 | "debug": "^2.6.8", 625 | "pkg-dir": "^2.0.0" 626 | }, 627 | "dependencies": { 628 | "debug": { 629 | "version": "2.6.9", 630 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 631 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 632 | "dev": true, 633 | "requires": { 634 | "ms": "2.0.0" 635 | } 636 | }, 637 | "ms": { 638 | "version": "2.0.0", 639 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 640 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 641 | "dev": true 642 | } 643 | } 644 | }, 645 | "eslint-plugin-es": { 646 | "version": "1.4.0", 647 | "resolved": "https://registry.npmjs.org/eslint-plugin-es/-/eslint-plugin-es-1.4.0.tgz", 648 | "integrity": "sha512-XfFmgFdIUDgvaRAlaXUkxrRg5JSADoRC8IkKLc/cISeR3yHVMefFHQZpcyXXEUUPHfy5DwviBcrfqlyqEwlQVw==", 649 | "dev": true, 650 | "requires": { 651 | "eslint-utils": "^1.3.0", 652 | "regexpp": "^2.0.1" 653 | } 654 | }, 655 | "eslint-plugin-import": { 656 | "version": "2.18.2", 657 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.18.2.tgz", 658 | "integrity": "sha512-5ohpsHAiUBRNaBWAF08izwUGlbrJoJJ+W9/TBwsGoR1MnlgfwMIKrFeSjWbt6moabiXW9xNvtFz+97KHRfI4HQ==", 659 | "dev": true, 660 | "requires": { 661 | "array-includes": "^3.0.3", 662 | "contains-path": "^0.1.0", 663 | "debug": "^2.6.9", 664 | "doctrine": "1.5.0", 665 | "eslint-import-resolver-node": "^0.3.2", 666 | "eslint-module-utils": "^2.4.0", 667 | "has": "^1.0.3", 668 | "minimatch": "^3.0.4", 669 | "object.values": "^1.1.0", 670 | "read-pkg-up": "^2.0.0", 671 | "resolve": "^1.11.0" 672 | }, 673 | "dependencies": { 674 | "debug": { 675 | "version": "2.6.9", 676 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 677 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 678 | "dev": true, 679 | "requires": { 680 | "ms": "2.0.0" 681 | } 682 | }, 683 | "doctrine": { 684 | "version": "1.5.0", 685 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 686 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 687 | "dev": true, 688 | "requires": { 689 | "esutils": "^2.0.2", 690 | "isarray": "^1.0.0" 691 | } 692 | }, 693 | "ms": { 694 | "version": "2.0.0", 695 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 696 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 697 | "dev": true 698 | } 699 | } 700 | }, 701 | "eslint-plugin-node": { 702 | "version": "9.1.0", 703 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-9.1.0.tgz", 704 | "integrity": "sha512-ZwQYGm6EoV2cfLpE1wxJWsfnKUIXfM/KM09/TlorkukgCAwmkgajEJnPCmyzoFPQQkmvo5DrW/nyKutNIw36Mw==", 705 | "dev": true, 706 | "requires": { 707 | "eslint-plugin-es": "^1.4.0", 708 | "eslint-utils": "^1.3.1", 709 | "ignore": "^5.1.1", 710 | "minimatch": "^3.0.4", 711 | "resolve": "^1.10.1", 712 | "semver": "^6.1.0" 713 | }, 714 | "dependencies": { 715 | "ignore": { 716 | "version": "5.1.4", 717 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.4.tgz", 718 | "integrity": "sha512-MzbUSahkTW1u7JpKKjY7LCARd1fU5W2rLdxlM4kdkayuCwZImjkpluF9CM1aLewYJguPDqewLam18Y6AU69A8A==", 719 | "dev": true 720 | } 721 | } 722 | }, 723 | "eslint-plugin-promise": { 724 | "version": "4.2.1", 725 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-4.2.1.tgz", 726 | "integrity": "sha512-VoM09vT7bfA7D+upt+FjeBO5eHIJQBUWki1aPvB+vbNiHS3+oGIJGIeyBtKQTME6UPXXy3vV07OL1tHd3ANuDw==", 727 | "dev": true 728 | }, 729 | "eslint-plugin-react": { 730 | "version": "7.14.3", 731 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.14.3.tgz", 732 | "integrity": "sha512-EzdyyBWC4Uz2hPYBiEJrKCUi2Fn+BJ9B/pJQcjw5X+x/H2Nm59S4MJIvL4O5NEE0+WbnQwEBxWY03oUk+Bc3FA==", 733 | "dev": true, 734 | "requires": { 735 | "array-includes": "^3.0.3", 736 | "doctrine": "^2.1.0", 737 | "has": "^1.0.3", 738 | "jsx-ast-utils": "^2.1.0", 739 | "object.entries": "^1.1.0", 740 | "object.fromentries": "^2.0.0", 741 | "object.values": "^1.1.0", 742 | "prop-types": "^15.7.2", 743 | "resolve": "^1.10.1" 744 | }, 745 | "dependencies": { 746 | "doctrine": { 747 | "version": "2.1.0", 748 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 749 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 750 | "dev": true, 751 | "requires": { 752 | "esutils": "^2.0.2" 753 | } 754 | } 755 | } 756 | }, 757 | "eslint-plugin-standard": { 758 | "version": "4.0.0", 759 | "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-4.0.0.tgz", 760 | "integrity": "sha512-OwxJkR6TQiYMmt1EsNRMe5qG3GsbjlcOhbGUBY4LtavF9DsLaTcoR+j2Tdjqi23oUwKNUqX7qcn5fPStafMdlA==", 761 | "dev": true 762 | }, 763 | "eslint-scope": { 764 | "version": "5.0.0", 765 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 766 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 767 | "dev": true, 768 | "requires": { 769 | "esrecurse": "^4.1.0", 770 | "estraverse": "^4.1.1" 771 | } 772 | }, 773 | "eslint-utils": { 774 | "version": "1.4.0", 775 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.0.tgz", 776 | "integrity": "sha512-7ehnzPaP5IIEh1r1tkjuIrxqhNkzUJa9z3R92tLJdZIVdWaczEhr3EbhGtsMrVxi1KeR8qA7Off6SWc5WNQqyQ==", 777 | "dev": true, 778 | "requires": { 779 | "eslint-visitor-keys": "^1.0.0" 780 | } 781 | }, 782 | "eslint-visitor-keys": { 783 | "version": "1.1.0", 784 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 785 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 786 | "dev": true 787 | }, 788 | "espree": { 789 | "version": "6.0.0", 790 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.0.0.tgz", 791 | "integrity": "sha512-lJvCS6YbCn3ImT3yKkPe0+tJ+mH6ljhGNjHQH9mRtiO6gjhVAOhVXW1yjnwqGwTkK3bGbye+hb00nFNmu0l/1Q==", 792 | "dev": true, 793 | "requires": { 794 | "acorn": "^6.0.7", 795 | "acorn-jsx": "^5.0.0", 796 | "eslint-visitor-keys": "^1.0.0" 797 | } 798 | }, 799 | "esprima": { 800 | "version": "4.0.1", 801 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 802 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 803 | "dev": true 804 | }, 805 | "esquery": { 806 | "version": "1.0.1", 807 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 808 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 809 | "dev": true, 810 | "requires": { 811 | "estraverse": "^4.0.0" 812 | } 813 | }, 814 | "esrecurse": { 815 | "version": "4.2.1", 816 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 817 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 818 | "dev": true, 819 | "requires": { 820 | "estraverse": "^4.1.0" 821 | } 822 | }, 823 | "estraverse": { 824 | "version": "4.3.0", 825 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 826 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 827 | "dev": true 828 | }, 829 | "esutils": { 830 | "version": "2.0.3", 831 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 832 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 833 | "dev": true 834 | }, 835 | "external-editor": { 836 | "version": "3.1.0", 837 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 838 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 839 | "dev": true, 840 | "requires": { 841 | "chardet": "^0.7.0", 842 | "iconv-lite": "^0.4.24", 843 | "tmp": "^0.0.33" 844 | } 845 | }, 846 | "fast-deep-equal": { 847 | "version": "2.0.1", 848 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 849 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 850 | "dev": true 851 | }, 852 | "fast-glob": { 853 | "version": "3.0.4", 854 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.0.4.tgz", 855 | "integrity": "sha512-wkIbV6qg37xTJwqSsdnIphL1e+LaGz4AIQqr00mIubMaEhv1/HEmJ0uuCGZRNRUkZZmOB5mJKO0ZUTVq+SxMQg==", 856 | "requires": { 857 | "@nodelib/fs.stat": "^2.0.1", 858 | "@nodelib/fs.walk": "^1.2.1", 859 | "glob-parent": "^5.0.0", 860 | "is-glob": "^4.0.1", 861 | "merge2": "^1.2.3", 862 | "micromatch": "^4.0.2" 863 | } 864 | }, 865 | "fast-json-stable-stringify": { 866 | "version": "2.0.0", 867 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 868 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 869 | "dev": true 870 | }, 871 | "fast-levenshtein": { 872 | "version": "2.0.6", 873 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 874 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 875 | "dev": true 876 | }, 877 | "fast-safe-stringify": { 878 | "version": "2.0.6", 879 | "resolved": "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.0.6.tgz", 880 | "integrity": "sha512-q8BZ89jjc+mz08rSxROs8VsrBBcn1SIw1kq9NjolL509tkABRk9io01RAjSaEv1Xb2uFLt8VtRiZbGp5H8iDtg==" 881 | }, 882 | "fastq": { 883 | "version": "1.6.0", 884 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.6.0.tgz", 885 | "integrity": "sha512-jmxqQ3Z/nXoeyDmWAzF9kH1aGZSis6e/SbfPmJpUnyZ0ogr6iscHQaml4wsEepEWSdtmpy+eVXmCRIMpxaXqOA==", 886 | "requires": { 887 | "reusify": "^1.0.0" 888 | } 889 | }, 890 | "fecha": { 891 | "version": "2.3.3", 892 | "resolved": "https://registry.npmjs.org/fecha/-/fecha-2.3.3.tgz", 893 | "integrity": "sha512-lUGBnIamTAwk4znq5BcqsDaxSmZ9nDVJaij6NvRt/Tg4R69gERA+otPKbS86ROw9nxVMw2/mp1fnaiWqbs6Sdg==" 894 | }, 895 | "fetch-blob": { 896 | "version": "3.1.4", 897 | "resolved": "https://registry.npmjs.org/fetch-blob/-/fetch-blob-3.1.4.tgz", 898 | "integrity": "sha512-Eq5Xv5+VlSrYWEqKrusxY1C3Hm/hjeAsCGVG3ft7pZahlUAChpGZT/Ms1WmSLnEAisEXszjzu/s+ce6HZB2VHA==", 899 | "requires": { 900 | "node-domexception": "^1.0.0", 901 | "web-streams-polyfill": "^3.0.3" 902 | } 903 | }, 904 | "figures": { 905 | "version": "3.0.0", 906 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.0.0.tgz", 907 | "integrity": "sha512-HKri+WoWoUgr83pehn/SIgLOMZ9nAWC6dcGj26RY2R4F50u4+RTUz0RCrUlOV3nKRAICW1UGzyb+kcX2qK1S/g==", 908 | "dev": true, 909 | "requires": { 910 | "escape-string-regexp": "^1.0.5" 911 | } 912 | }, 913 | "file-entry-cache": { 914 | "version": "5.0.1", 915 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 916 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 917 | "dev": true, 918 | "requires": { 919 | "flat-cache": "^2.0.1" 920 | } 921 | }, 922 | "fill-range": { 923 | "version": "7.0.1", 924 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 925 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 926 | "requires": { 927 | "to-regex-range": "^5.0.1" 928 | } 929 | }, 930 | "find-root": { 931 | "version": "1.1.0", 932 | "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz", 933 | "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==", 934 | "dev": true 935 | }, 936 | "find-up": { 937 | "version": "2.1.0", 938 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 939 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 940 | "dev": true, 941 | "requires": { 942 | "locate-path": "^2.0.0" 943 | } 944 | }, 945 | "flat-cache": { 946 | "version": "2.0.1", 947 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 948 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 949 | "dev": true, 950 | "requires": { 951 | "flatted": "^2.0.0", 952 | "rimraf": "2.6.3", 953 | "write": "1.0.3" 954 | }, 955 | "dependencies": { 956 | "glob": { 957 | "version": "7.1.4", 958 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 959 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 960 | "dev": true, 961 | "requires": { 962 | "fs.realpath": "^1.0.0", 963 | "inflight": "^1.0.4", 964 | "inherits": "2", 965 | "minimatch": "^3.0.4", 966 | "once": "^1.3.0", 967 | "path-is-absolute": "^1.0.0" 968 | } 969 | }, 970 | "rimraf": { 971 | "version": "2.6.3", 972 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 973 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 974 | "dev": true, 975 | "requires": { 976 | "glob": "^7.1.3" 977 | } 978 | } 979 | } 980 | }, 981 | "flatted": { 982 | "version": "2.0.1", 983 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", 984 | "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", 985 | "dev": true 986 | }, 987 | "form-data": { 988 | "version": "2.5.0", 989 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.5.0.tgz", 990 | "integrity": "sha512-WXieX3G/8side6VIqx44ablyULoGruSde5PNTxoUyo5CeyAMX6nVWUd0rgist/EuX655cjhUhTo1Fo3tRYqbcA==", 991 | "requires": { 992 | "asynckit": "^0.4.0", 993 | "combined-stream": "^1.0.6", 994 | "mime-types": "^2.1.12" 995 | } 996 | }, 997 | "formdata-polyfill": { 998 | "version": "4.0.10", 999 | "resolved": "https://registry.npmjs.org/formdata-polyfill/-/formdata-polyfill-4.0.10.tgz", 1000 | "integrity": "sha512-buewHzMvYL29jdeQTVILecSaZKnt/RJWjoZCF5OW60Z67/GmSLBkOFM7qh1PI3zFNtJbaZL5eQu1vLfazOwj4g==", 1001 | "requires": { 1002 | "fetch-blob": "^3.1.2" 1003 | } 1004 | }, 1005 | "fs.realpath": { 1006 | "version": "1.0.0", 1007 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1008 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 1009 | }, 1010 | "function-bind": { 1011 | "version": "1.1.1", 1012 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1013 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1014 | "dev": true 1015 | }, 1016 | "functional-red-black-tree": { 1017 | "version": "1.0.1", 1018 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1019 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1020 | "dev": true 1021 | }, 1022 | "get-stdin": { 1023 | "version": "7.0.0", 1024 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-7.0.0.tgz", 1025 | "integrity": "sha512-zRKcywvrXlXsA0v0i9Io4KDRaAw7+a1ZpjRwl9Wox8PFlVCCHra7E9c4kqXCoCM9nR5tBkaTTZRBoCm60bFqTQ==", 1026 | "dev": true 1027 | }, 1028 | "glob": { 1029 | "version": "7.1.2", 1030 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 1031 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 1032 | "requires": { 1033 | "fs.realpath": "^1.0.0", 1034 | "inflight": "^1.0.4", 1035 | "inherits": "2", 1036 | "minimatch": "^3.0.4", 1037 | "once": "^1.3.0", 1038 | "path-is-absolute": "^1.0.0" 1039 | } 1040 | }, 1041 | "glob-parent": { 1042 | "version": "5.0.0", 1043 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.0.0.tgz", 1044 | "integrity": "sha512-Z2RwiujPRGluePM6j699ktJYxmPpJKCfpGA13jz2hmFZC7gKetzrWvg5KN3+OsIFmydGyZ1AVwERCq1w/ZZwRg==", 1045 | "requires": { 1046 | "is-glob": "^4.0.1" 1047 | } 1048 | }, 1049 | "globals": { 1050 | "version": "11.12.0", 1051 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1052 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1053 | "dev": true 1054 | }, 1055 | "globby": { 1056 | "version": "10.0.1", 1057 | "resolved": "https://registry.npmjs.org/globby/-/globby-10.0.1.tgz", 1058 | "integrity": "sha512-sSs4inE1FB2YQiymcmTv6NWENryABjUNPeWhOvmn4SjtKybglsyPZxFB3U1/+L1bYi0rNZDqCLlHyLYDl1Pq5A==", 1059 | "requires": { 1060 | "@types/glob": "^7.1.1", 1061 | "array-union": "^2.1.0", 1062 | "dir-glob": "^3.0.1", 1063 | "fast-glob": "^3.0.3", 1064 | "glob": "^7.1.3", 1065 | "ignore": "^5.1.1", 1066 | "merge2": "^1.2.3", 1067 | "slash": "^3.0.0" 1068 | }, 1069 | "dependencies": { 1070 | "glob": { 1071 | "version": "7.1.4", 1072 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 1073 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 1074 | "requires": { 1075 | "fs.realpath": "^1.0.0", 1076 | "inflight": "^1.0.4", 1077 | "inherits": "2", 1078 | "minimatch": "^3.0.4", 1079 | "once": "^1.3.0", 1080 | "path-is-absolute": "^1.0.0" 1081 | } 1082 | }, 1083 | "ignore": { 1084 | "version": "5.1.4", 1085 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.1.4.tgz", 1086 | "integrity": "sha512-MzbUSahkTW1u7JpKKjY7LCARd1fU5W2rLdxlM4kdkayuCwZImjkpluF9CM1aLewYJguPDqewLam18Y6AU69A8A==" 1087 | } 1088 | } 1089 | }, 1090 | "graceful-fs": { 1091 | "version": "4.1.11", 1092 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 1093 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" 1094 | }, 1095 | "has": { 1096 | "version": "1.0.3", 1097 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1098 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1099 | "dev": true, 1100 | "requires": { 1101 | "function-bind": "^1.1.1" 1102 | } 1103 | }, 1104 | "has-flag": { 1105 | "version": "3.0.0", 1106 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1107 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1108 | "dev": true 1109 | }, 1110 | "has-symbols": { 1111 | "version": "1.0.0", 1112 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 1113 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 1114 | "dev": true 1115 | }, 1116 | "hosted-git-info": { 1117 | "version": "2.8.4", 1118 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.4.tgz", 1119 | "integrity": "sha512-pzXIvANXEFrc5oFFXRMkbLPQ2rXRoDERwDLyrcUxGhaZhgP54BBSl9Oheh7Vv0T090cszWBxPjkQQ5Sq1PbBRQ==", 1120 | "dev": true 1121 | }, 1122 | "iconv-lite": { 1123 | "version": "0.4.24", 1124 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1125 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1126 | "dev": true, 1127 | "requires": { 1128 | "safer-buffer": ">= 2.1.2 < 3" 1129 | } 1130 | }, 1131 | "ignore": { 1132 | "version": "4.0.6", 1133 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1134 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1135 | "dev": true 1136 | }, 1137 | "import-fresh": { 1138 | "version": "3.1.0", 1139 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.1.0.tgz", 1140 | "integrity": "sha512-PpuksHKGt8rXfWEr9m9EHIpgyyaltBy8+eF6GJM0QCAxMgxCfucMF3mjecK2QsJr0amJW7gTqh5/wht0z2UhEQ==", 1141 | "dev": true, 1142 | "requires": { 1143 | "parent-module": "^1.0.0", 1144 | "resolve-from": "^4.0.0" 1145 | } 1146 | }, 1147 | "imurmurhash": { 1148 | "version": "0.1.4", 1149 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1150 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1151 | "dev": true 1152 | }, 1153 | "inflight": { 1154 | "version": "1.0.6", 1155 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1156 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1157 | "requires": { 1158 | "once": "^1.3.0", 1159 | "wrappy": "1" 1160 | } 1161 | }, 1162 | "inherits": { 1163 | "version": "2.0.3", 1164 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1165 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1166 | }, 1167 | "inquirer": { 1168 | "version": "6.5.1", 1169 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.5.1.tgz", 1170 | "integrity": "sha512-uxNHBeQhRXIoHWTSNYUFhQVrHYFThIt6IVo2fFmSe8aBwdR3/w6b58hJpiL/fMukFkvGzjg+hSxFtwvVmKZmXw==", 1171 | "dev": true, 1172 | "requires": { 1173 | "ansi-escapes": "^4.2.1", 1174 | "chalk": "^2.4.2", 1175 | "cli-cursor": "^3.1.0", 1176 | "cli-width": "^2.0.0", 1177 | "external-editor": "^3.0.3", 1178 | "figures": "^3.0.0", 1179 | "lodash": "^4.17.15", 1180 | "mute-stream": "0.0.8", 1181 | "run-async": "^2.2.0", 1182 | "rxjs": "^6.4.0", 1183 | "string-width": "^4.1.0", 1184 | "strip-ansi": "^5.1.0", 1185 | "through": "^2.3.6" 1186 | } 1187 | }, 1188 | "is-arrayish": { 1189 | "version": "0.2.1", 1190 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1191 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1192 | "dev": true 1193 | }, 1194 | "is-callable": { 1195 | "version": "1.1.4", 1196 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1197 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 1198 | "dev": true 1199 | }, 1200 | "is-date-object": { 1201 | "version": "1.0.1", 1202 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1203 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1204 | "dev": true 1205 | }, 1206 | "is-extglob": { 1207 | "version": "2.1.1", 1208 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1209 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" 1210 | }, 1211 | "is-fullwidth-code-point": { 1212 | "version": "3.0.0", 1213 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1214 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1215 | "dev": true 1216 | }, 1217 | "is-glob": { 1218 | "version": "4.0.1", 1219 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1220 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1221 | "requires": { 1222 | "is-extglob": "^2.1.1" 1223 | } 1224 | }, 1225 | "is-number": { 1226 | "version": "7.0.0", 1227 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1228 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" 1229 | }, 1230 | "is-path-cwd": { 1231 | "version": "2.2.0", 1232 | "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-2.2.0.tgz", 1233 | "integrity": "sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==" 1234 | }, 1235 | "is-path-in-cwd": { 1236 | "version": "2.1.0", 1237 | "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz", 1238 | "integrity": "sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ==", 1239 | "requires": { 1240 | "is-path-inside": "^2.1.0" 1241 | } 1242 | }, 1243 | "is-path-inside": { 1244 | "version": "2.1.0", 1245 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-2.1.0.tgz", 1246 | "integrity": "sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg==", 1247 | "requires": { 1248 | "path-is-inside": "^1.0.2" 1249 | } 1250 | }, 1251 | "is-promise": { 1252 | "version": "2.1.0", 1253 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1254 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1255 | "dev": true 1256 | }, 1257 | "is-regex": { 1258 | "version": "1.0.4", 1259 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1260 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1261 | "dev": true, 1262 | "requires": { 1263 | "has": "^1.0.1" 1264 | } 1265 | }, 1266 | "is-stream": { 1267 | "version": "1.1.0", 1268 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1269 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 1270 | }, 1271 | "is-symbol": { 1272 | "version": "1.0.2", 1273 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1274 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1275 | "dev": true, 1276 | "requires": { 1277 | "has-symbols": "^1.0.0" 1278 | } 1279 | }, 1280 | "isarray": { 1281 | "version": "1.0.0", 1282 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1283 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 1284 | }, 1285 | "isexe": { 1286 | "version": "2.0.0", 1287 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1288 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1289 | "dev": true 1290 | }, 1291 | "js-tokens": { 1292 | "version": "4.0.0", 1293 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1294 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1295 | "dev": true 1296 | }, 1297 | "js-yaml": { 1298 | "version": "3.13.1", 1299 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1300 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1301 | "dev": true, 1302 | "requires": { 1303 | "argparse": "^1.0.7", 1304 | "esprima": "^4.0.0" 1305 | } 1306 | }, 1307 | "json-parse-better-errors": { 1308 | "version": "1.0.2", 1309 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1310 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 1311 | "dev": true 1312 | }, 1313 | "json-schema-traverse": { 1314 | "version": "0.4.1", 1315 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1316 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1317 | "dev": true 1318 | }, 1319 | "json-stable-stringify-without-jsonify": { 1320 | "version": "1.0.1", 1321 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1322 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1323 | "dev": true 1324 | }, 1325 | "jsx-ast-utils": { 1326 | "version": "2.2.1", 1327 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.2.1.tgz", 1328 | "integrity": "sha512-v3FxCcAf20DayI+uxnCuw795+oOIkVu6EnJ1+kSzhqqTZHNkTZ7B66ZgLp4oLJ/gbA64cI0B7WRoHZMSRdyVRQ==", 1329 | "dev": true, 1330 | "requires": { 1331 | "array-includes": "^3.0.3", 1332 | "object.assign": "^4.1.0" 1333 | } 1334 | }, 1335 | "kuler": { 1336 | "version": "1.0.1", 1337 | "resolved": "https://registry.npmjs.org/kuler/-/kuler-1.0.1.tgz", 1338 | "integrity": "sha512-J9nVUucG1p/skKul6DU3PUZrhs0LPulNaeUOox0IyXDi8S4CztTHs1gQphhuZmzXG7VOQSf6NJfKuzteQLv9gQ==", 1339 | "requires": { 1340 | "colornames": "^1.1.1" 1341 | } 1342 | }, 1343 | "levn": { 1344 | "version": "0.3.0", 1345 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1346 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1347 | "dev": true, 1348 | "requires": { 1349 | "prelude-ls": "~1.1.2", 1350 | "type-check": "~0.3.2" 1351 | } 1352 | }, 1353 | "load-json-file": { 1354 | "version": "2.0.0", 1355 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1356 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1357 | "dev": true, 1358 | "requires": { 1359 | "graceful-fs": "^4.1.2", 1360 | "parse-json": "^2.2.0", 1361 | "pify": "^2.0.0", 1362 | "strip-bom": "^3.0.0" 1363 | } 1364 | }, 1365 | "locate-path": { 1366 | "version": "2.0.0", 1367 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1368 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1369 | "dev": true, 1370 | "requires": { 1371 | "p-locate": "^2.0.0", 1372 | "path-exists": "^3.0.0" 1373 | } 1374 | }, 1375 | "lodash": { 1376 | "version": "4.17.15", 1377 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 1378 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", 1379 | "dev": true 1380 | }, 1381 | "logform": { 1382 | "version": "2.1.2", 1383 | "resolved": "https://registry.npmjs.org/logform/-/logform-2.1.2.tgz", 1384 | "integrity": "sha512-+lZh4OpERDBLqjiwDLpAWNQu6KMjnlXH2ByZwCuSqVPJletw0kTWJf5CgSNAUKn1KUkv3m2cUz/LK8zyEy7wzQ==", 1385 | "requires": { 1386 | "colors": "^1.2.1", 1387 | "fast-safe-stringify": "^2.0.4", 1388 | "fecha": "^2.3.3", 1389 | "ms": "^2.1.1", 1390 | "triple-beam": "^1.3.0" 1391 | }, 1392 | "dependencies": { 1393 | "ms": { 1394 | "version": "2.1.2", 1395 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1396 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1397 | } 1398 | } 1399 | }, 1400 | "loose-envify": { 1401 | "version": "1.4.0", 1402 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1403 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1404 | "dev": true, 1405 | "requires": { 1406 | "js-tokens": "^3.0.0 || ^4.0.0" 1407 | } 1408 | }, 1409 | "merge2": { 1410 | "version": "1.2.4", 1411 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.2.4.tgz", 1412 | "integrity": "sha512-FYE8xI+6pjFOhokZu0We3S5NKCirLbCzSh2Usf3qEyr4X8U+0jNg9P8RZ4qz+V2UoECLVwSyzU3LxXBaLGtD3A==" 1413 | }, 1414 | "micromatch": { 1415 | "version": "4.0.2", 1416 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz", 1417 | "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==", 1418 | "requires": { 1419 | "braces": "^3.0.1", 1420 | "picomatch": "^2.0.5" 1421 | } 1422 | }, 1423 | "mime-db": { 1424 | "version": "1.40.0", 1425 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 1426 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==" 1427 | }, 1428 | "mime-types": { 1429 | "version": "2.1.24", 1430 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 1431 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 1432 | "requires": { 1433 | "mime-db": "1.40.0" 1434 | } 1435 | }, 1436 | "mimic-fn": { 1437 | "version": "2.1.0", 1438 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1439 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1440 | "dev": true 1441 | }, 1442 | "minimatch": { 1443 | "version": "3.0.4", 1444 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1445 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1446 | "requires": { 1447 | "brace-expansion": "^1.1.7" 1448 | } 1449 | }, 1450 | "minimist": { 1451 | "version": "1.2.0", 1452 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1453 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" 1454 | }, 1455 | "mkdirp": { 1456 | "version": "0.5.1", 1457 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1458 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1459 | "requires": { 1460 | "minimist": "0.0.8" 1461 | }, 1462 | "dependencies": { 1463 | "minimist": { 1464 | "version": "0.0.8", 1465 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1466 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 1467 | } 1468 | } 1469 | }, 1470 | "moment": { 1471 | "version": "2.24.0", 1472 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.24.0.tgz", 1473 | "integrity": "sha512-bV7f+6l2QigeBBZSM/6yTNq4P2fNpSWj/0e7jQcy87A8e7o2nAfP/34/2ky5Vw4B9S446EtIhodAzkFCcR4dQg==" 1474 | }, 1475 | "ms": { 1476 | "version": "2.1.2", 1477 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1478 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1479 | "dev": true 1480 | }, 1481 | "mute-stream": { 1482 | "version": "0.0.8", 1483 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1484 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1485 | "dev": true 1486 | }, 1487 | "natural-compare": { 1488 | "version": "1.4.0", 1489 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1490 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1491 | "dev": true 1492 | }, 1493 | "nice-try": { 1494 | "version": "1.0.5", 1495 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1496 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1497 | "dev": true 1498 | }, 1499 | "node-domexception": { 1500 | "version": "1.0.0", 1501 | "resolved": "https://registry.npmjs.org/node-domexception/-/node-domexception-1.0.0.tgz", 1502 | "integrity": "sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ==" 1503 | }, 1504 | "node-fetch": { 1505 | "version": "3.1.1", 1506 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-3.1.1.tgz", 1507 | "integrity": "sha512-SMk+vKgU77PYotRdWzqZGTZeuFKlsJ0hu4KPviQKkfY+N3vn2MIzr0rvpnYpR8MtB3IEuhlEcuOLbGvLRlA+yg==", 1508 | "requires": { 1509 | "data-uri-to-buffer": "^4.0.0", 1510 | "fetch-blob": "^3.1.3", 1511 | "formdata-polyfill": "^4.0.10" 1512 | } 1513 | }, 1514 | "normalize-package-data": { 1515 | "version": "2.5.0", 1516 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1517 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1518 | "dev": true, 1519 | "requires": { 1520 | "hosted-git-info": "^2.1.4", 1521 | "resolve": "^1.10.0", 1522 | "semver": "2 || 3 || 4 || 5", 1523 | "validate-npm-package-license": "^3.0.1" 1524 | }, 1525 | "dependencies": { 1526 | "semver": { 1527 | "version": "5.7.1", 1528 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1529 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1530 | "dev": true 1531 | } 1532 | } 1533 | }, 1534 | "object-assign": { 1535 | "version": "4.1.1", 1536 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1537 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1538 | "dev": true 1539 | }, 1540 | "object-keys": { 1541 | "version": "1.1.1", 1542 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1543 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1544 | "dev": true 1545 | }, 1546 | "object.assign": { 1547 | "version": "4.1.0", 1548 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1549 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1550 | "dev": true, 1551 | "requires": { 1552 | "define-properties": "^1.1.2", 1553 | "function-bind": "^1.1.1", 1554 | "has-symbols": "^1.0.0", 1555 | "object-keys": "^1.0.11" 1556 | } 1557 | }, 1558 | "object.entries": { 1559 | "version": "1.1.0", 1560 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", 1561 | "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", 1562 | "dev": true, 1563 | "requires": { 1564 | "define-properties": "^1.1.3", 1565 | "es-abstract": "^1.12.0", 1566 | "function-bind": "^1.1.1", 1567 | "has": "^1.0.3" 1568 | } 1569 | }, 1570 | "object.fromentries": { 1571 | "version": "2.0.0", 1572 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.0.tgz", 1573 | "integrity": "sha512-9iLiI6H083uiqUuvzyY6qrlmc/Gz8hLQFOcb/Ri/0xXFkSNS3ctV+CbE6yM2+AnkYfOB3dGjdzC0wrMLIhQICA==", 1574 | "dev": true, 1575 | "requires": { 1576 | "define-properties": "^1.1.2", 1577 | "es-abstract": "^1.11.0", 1578 | "function-bind": "^1.1.1", 1579 | "has": "^1.0.1" 1580 | } 1581 | }, 1582 | "object.values": { 1583 | "version": "1.1.0", 1584 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.0.tgz", 1585 | "integrity": "sha512-8mf0nKLAoFX6VlNVdhGj31SVYpaNFtUnuoOXWyFEstsWRgU837AK+JYM0iAxwkSzGRbwn8cbFmgbyxj1j4VbXg==", 1586 | "dev": true, 1587 | "requires": { 1588 | "define-properties": "^1.1.3", 1589 | "es-abstract": "^1.12.0", 1590 | "function-bind": "^1.1.1", 1591 | "has": "^1.0.3" 1592 | } 1593 | }, 1594 | "once": { 1595 | "version": "1.4.0", 1596 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1597 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1598 | "requires": { 1599 | "wrappy": "1" 1600 | } 1601 | }, 1602 | "one-time": { 1603 | "version": "0.0.4", 1604 | "resolved": "https://registry.npmjs.org/one-time/-/one-time-0.0.4.tgz", 1605 | "integrity": "sha1-+M33eISCb+Tf+T46nMN7HkSAdC4=" 1606 | }, 1607 | "onetime": { 1608 | "version": "5.1.0", 1609 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1610 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1611 | "dev": true, 1612 | "requires": { 1613 | "mimic-fn": "^2.1.0" 1614 | } 1615 | }, 1616 | "optionator": { 1617 | "version": "0.8.2", 1618 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1619 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1620 | "dev": true, 1621 | "requires": { 1622 | "deep-is": "~0.1.3", 1623 | "fast-levenshtein": "~2.0.4", 1624 | "levn": "~0.3.0", 1625 | "prelude-ls": "~1.1.2", 1626 | "type-check": "~0.3.2", 1627 | "wordwrap": "~1.0.0" 1628 | } 1629 | }, 1630 | "os-tmpdir": { 1631 | "version": "1.0.2", 1632 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1633 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1634 | "dev": true 1635 | }, 1636 | "p-limit": { 1637 | "version": "1.3.0", 1638 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1639 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1640 | "dev": true, 1641 | "requires": { 1642 | "p-try": "^1.0.0" 1643 | } 1644 | }, 1645 | "p-locate": { 1646 | "version": "2.0.0", 1647 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1648 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1649 | "dev": true, 1650 | "requires": { 1651 | "p-limit": "^1.1.0" 1652 | } 1653 | }, 1654 | "p-map": { 1655 | "version": "2.1.0", 1656 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-2.1.0.tgz", 1657 | "integrity": "sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw==" 1658 | }, 1659 | "p-try": { 1660 | "version": "1.0.0", 1661 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1662 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1663 | "dev": true 1664 | }, 1665 | "parent-module": { 1666 | "version": "1.0.1", 1667 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1668 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1669 | "dev": true, 1670 | "requires": { 1671 | "callsites": "^3.0.0" 1672 | } 1673 | }, 1674 | "parse-json": { 1675 | "version": "2.2.0", 1676 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1677 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1678 | "dev": true, 1679 | "requires": { 1680 | "error-ex": "^1.2.0" 1681 | } 1682 | }, 1683 | "path-exists": { 1684 | "version": "3.0.0", 1685 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1686 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1687 | "dev": true 1688 | }, 1689 | "path-is-absolute": { 1690 | "version": "1.0.1", 1691 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1692 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1693 | }, 1694 | "path-is-inside": { 1695 | "version": "1.0.2", 1696 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1697 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=" 1698 | }, 1699 | "path-key": { 1700 | "version": "2.0.1", 1701 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1702 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1703 | "dev": true 1704 | }, 1705 | "path-parse": { 1706 | "version": "1.0.6", 1707 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1708 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1709 | "dev": true 1710 | }, 1711 | "path-type": { 1712 | "version": "2.0.0", 1713 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1714 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1715 | "dev": true, 1716 | "requires": { 1717 | "pify": "^2.0.0" 1718 | } 1719 | }, 1720 | "picomatch": { 1721 | "version": "2.0.7", 1722 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.0.7.tgz", 1723 | "integrity": "sha512-oLHIdio3tZ0qH76NybpeneBhYVj0QFTfXEFTc/B3zKQspYfYYkWYgFsmzo+4kvId/bQRcNkVeguI3y+CD22BtA==" 1724 | }, 1725 | "pify": { 1726 | "version": "2.3.0", 1727 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1728 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1729 | "dev": true 1730 | }, 1731 | "pkg-conf": { 1732 | "version": "3.1.0", 1733 | "resolved": "https://registry.npmjs.org/pkg-conf/-/pkg-conf-3.1.0.tgz", 1734 | "integrity": "sha512-m0OTbR/5VPNPqO1ph6Fqbj7Hv6QU7gR/tQW40ZqrL1rjgCU85W6C1bJn0BItuJqnR98PWzw7Z8hHeChD1WrgdQ==", 1735 | "dev": true, 1736 | "requires": { 1737 | "find-up": "^3.0.0", 1738 | "load-json-file": "^5.2.0" 1739 | }, 1740 | "dependencies": { 1741 | "find-up": { 1742 | "version": "3.0.0", 1743 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 1744 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 1745 | "dev": true, 1746 | "requires": { 1747 | "locate-path": "^3.0.0" 1748 | } 1749 | }, 1750 | "graceful-fs": { 1751 | "version": "4.2.2", 1752 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.2.tgz", 1753 | "integrity": "sha512-IItsdsea19BoLC7ELy13q1iJFNmd7ofZH5+X/pJr90/nRoPEX0DJo1dHDbgtYWOhJhcCgMDTOw84RZ72q6lB+Q==", 1754 | "dev": true 1755 | }, 1756 | "load-json-file": { 1757 | "version": "5.3.0", 1758 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-5.3.0.tgz", 1759 | "integrity": "sha512-cJGP40Jc/VXUsp8/OrnyKyTZ1y6v/dphm3bioS+RrKXjK2BB6wHUd6JptZEFDGgGahMT+InnZO5i1Ei9mpC8Bw==", 1760 | "dev": true, 1761 | "requires": { 1762 | "graceful-fs": "^4.1.15", 1763 | "parse-json": "^4.0.0", 1764 | "pify": "^4.0.1", 1765 | "strip-bom": "^3.0.0", 1766 | "type-fest": "^0.3.0" 1767 | } 1768 | }, 1769 | "locate-path": { 1770 | "version": "3.0.0", 1771 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1772 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1773 | "dev": true, 1774 | "requires": { 1775 | "p-locate": "^3.0.0", 1776 | "path-exists": "^3.0.0" 1777 | } 1778 | }, 1779 | "p-limit": { 1780 | "version": "2.2.0", 1781 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.0.tgz", 1782 | "integrity": "sha512-pZbTJpoUsCzV48Mc9Nh51VbwO0X9cuPFE8gYwx9BTCt9SF8/b7Zljd2fVgOxhIF/HDTKgpVzs+GPhyKfjLLFRQ==", 1783 | "dev": true, 1784 | "requires": { 1785 | "p-try": "^2.0.0" 1786 | } 1787 | }, 1788 | "p-locate": { 1789 | "version": "3.0.0", 1790 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1791 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1792 | "dev": true, 1793 | "requires": { 1794 | "p-limit": "^2.0.0" 1795 | } 1796 | }, 1797 | "p-try": { 1798 | "version": "2.2.0", 1799 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1800 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1801 | "dev": true 1802 | }, 1803 | "parse-json": { 1804 | "version": "4.0.0", 1805 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1806 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1807 | "dev": true, 1808 | "requires": { 1809 | "error-ex": "^1.3.1", 1810 | "json-parse-better-errors": "^1.0.1" 1811 | } 1812 | }, 1813 | "pify": { 1814 | "version": "4.0.1", 1815 | "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", 1816 | "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", 1817 | "dev": true 1818 | }, 1819 | "type-fest": { 1820 | "version": "0.3.1", 1821 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.3.1.tgz", 1822 | "integrity": "sha512-cUGJnCdr4STbePCgqNFbpVNCepa+kAVohJs1sLhxzdH+gnEoOd8VhbYa7pD3zZYGiURWM2xzEII3fQcRizDkYQ==", 1823 | "dev": true 1824 | } 1825 | } 1826 | }, 1827 | "pkg-config": { 1828 | "version": "1.1.1", 1829 | "resolved": "https://registry.npmjs.org/pkg-config/-/pkg-config-1.1.1.tgz", 1830 | "integrity": "sha1-VX7yLXPaPIg3EHdmxS6tq94pj+Q=", 1831 | "dev": true, 1832 | "requires": { 1833 | "debug-log": "^1.0.0", 1834 | "find-root": "^1.0.0", 1835 | "xtend": "^4.0.1" 1836 | } 1837 | }, 1838 | "pkg-dir": { 1839 | "version": "2.0.0", 1840 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 1841 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 1842 | "dev": true, 1843 | "requires": { 1844 | "find-up": "^2.1.0" 1845 | } 1846 | }, 1847 | "prelude-ls": { 1848 | "version": "1.1.2", 1849 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1850 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1851 | "dev": true 1852 | }, 1853 | "process-nextick-args": { 1854 | "version": "2.0.0", 1855 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 1856 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==" 1857 | }, 1858 | "progress": { 1859 | "version": "2.0.3", 1860 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1861 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1862 | "dev": true 1863 | }, 1864 | "prop-types": { 1865 | "version": "15.7.2", 1866 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", 1867 | "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", 1868 | "dev": true, 1869 | "requires": { 1870 | "loose-envify": "^1.4.0", 1871 | "object-assign": "^4.1.1", 1872 | "react-is": "^16.8.1" 1873 | } 1874 | }, 1875 | "punycode": { 1876 | "version": "2.1.1", 1877 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1878 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1879 | "dev": true 1880 | }, 1881 | "react-is": { 1882 | "version": "16.9.0", 1883 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.9.0.tgz", 1884 | "integrity": "sha512-tJBzzzIgnnRfEm046qRcURvwQnZVXmuCbscxUO5RWrGTXpon2d4c8mI0D8WE6ydVIm29JiLB6+RslkIvym9Rjw==", 1885 | "dev": true 1886 | }, 1887 | "read-pkg": { 1888 | "version": "2.0.0", 1889 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1890 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1891 | "dev": true, 1892 | "requires": { 1893 | "load-json-file": "^2.0.0", 1894 | "normalize-package-data": "^2.3.2", 1895 | "path-type": "^2.0.0" 1896 | } 1897 | }, 1898 | "read-pkg-up": { 1899 | "version": "2.0.0", 1900 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1901 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1902 | "dev": true, 1903 | "requires": { 1904 | "find-up": "^2.0.0", 1905 | "read-pkg": "^2.0.0" 1906 | } 1907 | }, 1908 | "readable-stream": { 1909 | "version": "2.3.6", 1910 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 1911 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 1912 | "requires": { 1913 | "core-util-is": "~1.0.0", 1914 | "inherits": "~2.0.3", 1915 | "isarray": "~1.0.0", 1916 | "process-nextick-args": "~2.0.0", 1917 | "safe-buffer": "~5.1.1", 1918 | "string_decoder": "~1.1.1", 1919 | "util-deprecate": "~1.0.1" 1920 | } 1921 | }, 1922 | "regexpp": { 1923 | "version": "2.0.1", 1924 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1925 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1926 | "dev": true 1927 | }, 1928 | "resolve": { 1929 | "version": "1.12.0", 1930 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", 1931 | "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", 1932 | "dev": true, 1933 | "requires": { 1934 | "path-parse": "^1.0.6" 1935 | } 1936 | }, 1937 | "resolve-from": { 1938 | "version": "4.0.0", 1939 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1940 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1941 | "dev": true 1942 | }, 1943 | "restore-cursor": { 1944 | "version": "3.1.0", 1945 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1946 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1947 | "dev": true, 1948 | "requires": { 1949 | "onetime": "^5.1.0", 1950 | "signal-exit": "^3.0.2" 1951 | } 1952 | }, 1953 | "reusify": { 1954 | "version": "1.0.4", 1955 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1956 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==" 1957 | }, 1958 | "rimraf": { 1959 | "version": "2.6.1", 1960 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.1.tgz", 1961 | "integrity": "sha1-wjOOxkPfeht/5cVPqG9XQopV8z0=", 1962 | "requires": { 1963 | "glob": "^7.0.5" 1964 | } 1965 | }, 1966 | "run-async": { 1967 | "version": "2.3.0", 1968 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1969 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1970 | "dev": true, 1971 | "requires": { 1972 | "is-promise": "^2.1.0" 1973 | } 1974 | }, 1975 | "run-parallel": { 1976 | "version": "1.1.9", 1977 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.1.9.tgz", 1978 | "integrity": "sha512-DEqnSRTDw/Tc3FXf49zedI638Z9onwUotBMiUFKmrO2sdFKIbXamXGQ3Axd4qgphxKB4kw/qP1w5kTxnfU1B9Q==" 1979 | }, 1980 | "rxjs": { 1981 | "version": "6.5.2", 1982 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", 1983 | "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", 1984 | "dev": true, 1985 | "requires": { 1986 | "tslib": "^1.9.0" 1987 | } 1988 | }, 1989 | "safe-buffer": { 1990 | "version": "5.1.2", 1991 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1992 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1993 | }, 1994 | "safer-buffer": { 1995 | "version": "2.1.2", 1996 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1997 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1998 | "dev": true 1999 | }, 2000 | "semver": { 2001 | "version": "6.3.0", 2002 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2003 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2004 | "dev": true 2005 | }, 2006 | "shebang-command": { 2007 | "version": "1.2.0", 2008 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2009 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2010 | "dev": true, 2011 | "requires": { 2012 | "shebang-regex": "^1.0.0" 2013 | } 2014 | }, 2015 | "shebang-regex": { 2016 | "version": "1.0.0", 2017 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2018 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2019 | "dev": true 2020 | }, 2021 | "signal-exit": { 2022 | "version": "3.0.2", 2023 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2024 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2025 | "dev": true 2026 | }, 2027 | "simple-swizzle": { 2028 | "version": "0.2.2", 2029 | "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", 2030 | "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", 2031 | "requires": { 2032 | "is-arrayish": "^0.3.1" 2033 | }, 2034 | "dependencies": { 2035 | "is-arrayish": { 2036 | "version": "0.3.2", 2037 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", 2038 | "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==" 2039 | } 2040 | } 2041 | }, 2042 | "slash": { 2043 | "version": "3.0.0", 2044 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2045 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==" 2046 | }, 2047 | "slice-ansi": { 2048 | "version": "2.1.0", 2049 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2050 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2051 | "dev": true, 2052 | "requires": { 2053 | "ansi-styles": "^3.2.0", 2054 | "astral-regex": "^1.0.0", 2055 | "is-fullwidth-code-point": "^2.0.0" 2056 | }, 2057 | "dependencies": { 2058 | "is-fullwidth-code-point": { 2059 | "version": "2.0.0", 2060 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2061 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2062 | "dev": true 2063 | } 2064 | } 2065 | }, 2066 | "spdx-correct": { 2067 | "version": "3.1.0", 2068 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 2069 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 2070 | "dev": true, 2071 | "requires": { 2072 | "spdx-expression-parse": "^3.0.0", 2073 | "spdx-license-ids": "^3.0.0" 2074 | } 2075 | }, 2076 | "spdx-exceptions": { 2077 | "version": "2.2.0", 2078 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 2079 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 2080 | "dev": true 2081 | }, 2082 | "spdx-expression-parse": { 2083 | "version": "3.0.0", 2084 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 2085 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 2086 | "dev": true, 2087 | "requires": { 2088 | "spdx-exceptions": "^2.1.0", 2089 | "spdx-license-ids": "^3.0.0" 2090 | } 2091 | }, 2092 | "spdx-license-ids": { 2093 | "version": "3.0.5", 2094 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 2095 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", 2096 | "dev": true 2097 | }, 2098 | "sprintf-js": { 2099 | "version": "1.0.3", 2100 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2101 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2102 | "dev": true 2103 | }, 2104 | "stack-trace": { 2105 | "version": "0.0.10", 2106 | "resolved": "https://registry.npmjs.org/stack-trace/-/stack-trace-0.0.10.tgz", 2107 | "integrity": "sha1-VHxws0fo0ytOEI6hoqFZ5f3eGcA=" 2108 | }, 2109 | "standard": { 2110 | "version": "13.1.0", 2111 | "resolved": "https://registry.npmjs.org/standard/-/standard-13.1.0.tgz", 2112 | "integrity": "sha512-h3NaMzsa88+/xtjXCMvdn6EWWdlodsI/HvtsQF+EGwrF9kVNwNha9TkFABU6bSBoNfC79YDyIAq9ekxOMBFkuw==", 2113 | "dev": true, 2114 | "requires": { 2115 | "eslint": "~6.1.0", 2116 | "eslint-config-standard": "13.0.1", 2117 | "eslint-config-standard-jsx": "7.0.0", 2118 | "eslint-plugin-import": "~2.18.0", 2119 | "eslint-plugin-node": "~9.1.0", 2120 | "eslint-plugin-promise": "~4.2.1", 2121 | "eslint-plugin-react": "~7.14.2", 2122 | "eslint-plugin-standard": "~4.0.0", 2123 | "standard-engine": "~11.0.1" 2124 | } 2125 | }, 2126 | "standard-engine": { 2127 | "version": "11.0.1", 2128 | "resolved": "https://registry.npmjs.org/standard-engine/-/standard-engine-11.0.1.tgz", 2129 | "integrity": "sha512-WZQ5PpEDfRzPFk+H9xvKVQPQIxKnAQB2cb2Au4NyTCtdw5R0pyMBUZLbPXyFjnlhe8Ae+zfNrWU4m6H5b7cEAg==", 2130 | "dev": true, 2131 | "requires": { 2132 | "deglob": "^3.0.0", 2133 | "get-stdin": "^7.0.0", 2134 | "minimist": "^1.1.0", 2135 | "pkg-conf": "^3.1.0" 2136 | } 2137 | }, 2138 | "string-width": { 2139 | "version": "4.1.0", 2140 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.1.0.tgz", 2141 | "integrity": "sha512-NrX+1dVVh+6Y9dnQ19pR0pP4FiEIlUvdTGn8pw6CKTNq5sgib2nIhmUNT5TAmhWmvKr3WcxBcP3E8nWezuipuQ==", 2142 | "dev": true, 2143 | "requires": { 2144 | "emoji-regex": "^8.0.0", 2145 | "is-fullwidth-code-point": "^3.0.0", 2146 | "strip-ansi": "^5.2.0" 2147 | } 2148 | }, 2149 | "string_decoder": { 2150 | "version": "1.1.1", 2151 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2152 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2153 | "requires": { 2154 | "safe-buffer": "~5.1.0" 2155 | } 2156 | }, 2157 | "strip-ansi": { 2158 | "version": "5.2.0", 2159 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2160 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2161 | "dev": true, 2162 | "requires": { 2163 | "ansi-regex": "^4.1.0" 2164 | } 2165 | }, 2166 | "strip-bom": { 2167 | "version": "3.0.0", 2168 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2169 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2170 | "dev": true 2171 | }, 2172 | "strip-json-comments": { 2173 | "version": "3.0.1", 2174 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", 2175 | "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==", 2176 | "dev": true 2177 | }, 2178 | "supports-color": { 2179 | "version": "5.5.0", 2180 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2181 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2182 | "dev": true, 2183 | "requires": { 2184 | "has-flag": "^3.0.0" 2185 | } 2186 | }, 2187 | "table": { 2188 | "version": "5.4.6", 2189 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 2190 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 2191 | "dev": true, 2192 | "requires": { 2193 | "ajv": "^6.10.2", 2194 | "lodash": "^4.17.14", 2195 | "slice-ansi": "^2.1.0", 2196 | "string-width": "^3.0.0" 2197 | }, 2198 | "dependencies": { 2199 | "emoji-regex": { 2200 | "version": "7.0.3", 2201 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 2202 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 2203 | "dev": true 2204 | }, 2205 | "is-fullwidth-code-point": { 2206 | "version": "2.0.0", 2207 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2208 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2209 | "dev": true 2210 | }, 2211 | "string-width": { 2212 | "version": "3.1.0", 2213 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2214 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2215 | "dev": true, 2216 | "requires": { 2217 | "emoji-regex": "^7.0.1", 2218 | "is-fullwidth-code-point": "^2.0.0", 2219 | "strip-ansi": "^5.1.0" 2220 | } 2221 | } 2222 | } 2223 | }, 2224 | "text-hex": { 2225 | "version": "1.0.0", 2226 | "resolved": "https://registry.npmjs.org/text-hex/-/text-hex-1.0.0.tgz", 2227 | "integrity": "sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg==" 2228 | }, 2229 | "text-table": { 2230 | "version": "0.2.0", 2231 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2232 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2233 | "dev": true 2234 | }, 2235 | "through": { 2236 | "version": "2.3.8", 2237 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2238 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2239 | "dev": true 2240 | }, 2241 | "tmp": { 2242 | "version": "0.0.33", 2243 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2244 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2245 | "dev": true, 2246 | "requires": { 2247 | "os-tmpdir": "~1.0.2" 2248 | } 2249 | }, 2250 | "to-regex-range": { 2251 | "version": "5.0.1", 2252 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2253 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2254 | "requires": { 2255 | "is-number": "^7.0.0" 2256 | } 2257 | }, 2258 | "triple-beam": { 2259 | "version": "1.3.0", 2260 | "resolved": "https://registry.npmjs.org/triple-beam/-/triple-beam-1.3.0.tgz", 2261 | "integrity": "sha512-XrHUvV5HpdLmIj4uVMxHggLbFSZYIn7HEWsqePZcI50pco+MPqJ50wMGY794X7AOOhxOBAjbkqfAbEe/QMp2Lw==" 2262 | }, 2263 | "tslib": { 2264 | "version": "1.10.0", 2265 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 2266 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==", 2267 | "dev": true 2268 | }, 2269 | "type-check": { 2270 | "version": "0.3.2", 2271 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2272 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2273 | "dev": true, 2274 | "requires": { 2275 | "prelude-ls": "~1.1.2" 2276 | } 2277 | }, 2278 | "type-fest": { 2279 | "version": "0.5.2", 2280 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.5.2.tgz", 2281 | "integrity": "sha512-DWkS49EQKVX//Tbupb9TFa19c7+MK1XmzkrZUR8TAktmE/DizXoaoJV6TZ/tSIPXipqNiRI6CyAe7x69Jb6RSw==", 2282 | "dev": true 2283 | }, 2284 | "uniq": { 2285 | "version": "1.0.1", 2286 | "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", 2287 | "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", 2288 | "dev": true 2289 | }, 2290 | "uri-js": { 2291 | "version": "4.2.2", 2292 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2293 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2294 | "dev": true, 2295 | "requires": { 2296 | "punycode": "^2.1.0" 2297 | } 2298 | }, 2299 | "util-deprecate": { 2300 | "version": "1.0.2", 2301 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2302 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" 2303 | }, 2304 | "v8-compile-cache": { 2305 | "version": "2.1.0", 2306 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", 2307 | "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", 2308 | "dev": true 2309 | }, 2310 | "validate-npm-package-license": { 2311 | "version": "3.0.4", 2312 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2313 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2314 | "dev": true, 2315 | "requires": { 2316 | "spdx-correct": "^3.0.0", 2317 | "spdx-expression-parse": "^3.0.0" 2318 | } 2319 | }, 2320 | "web-streams-polyfill": { 2321 | "version": "3.2.0", 2322 | "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.2.0.tgz", 2323 | "integrity": "sha512-EqPmREeOzttaLRm5HS7io98goBgZ7IVz79aDvqjD0kYXLtFZTc0T/U6wHTPKyIjb+MdN7DFIIX6hgdBEpWmfPA==" 2324 | }, 2325 | "which": { 2326 | "version": "1.3.1", 2327 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2328 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2329 | "dev": true, 2330 | "requires": { 2331 | "isexe": "^2.0.0" 2332 | } 2333 | }, 2334 | "winston": { 2335 | "version": "3.2.1", 2336 | "resolved": "https://registry.npmjs.org/winston/-/winston-3.2.1.tgz", 2337 | "integrity": "sha512-zU6vgnS9dAWCEKg/QYigd6cgMVVNwyTzKs81XZtTFuRwJOcDdBg7AU0mXVyNbs7O5RH2zdv+BdNZUlx7mXPuOw==", 2338 | "requires": { 2339 | "async": "^2.6.1", 2340 | "diagnostics": "^1.1.1", 2341 | "is-stream": "^1.1.0", 2342 | "logform": "^2.1.1", 2343 | "one-time": "0.0.4", 2344 | "readable-stream": "^3.1.1", 2345 | "stack-trace": "0.0.x", 2346 | "triple-beam": "^1.3.0", 2347 | "winston-transport": "^4.3.0" 2348 | }, 2349 | "dependencies": { 2350 | "readable-stream": { 2351 | "version": "3.4.0", 2352 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.4.0.tgz", 2353 | "integrity": "sha512-jItXPLmrSR8jmTRmRWJXCnGJsfy85mB3Wd/uINMXA65yrnFo0cPClFIUWzo2najVNSl+mx7/4W8ttlLWJe99pQ==", 2354 | "requires": { 2355 | "inherits": "^2.0.3", 2356 | "string_decoder": "^1.1.1", 2357 | "util-deprecate": "^1.0.1" 2358 | } 2359 | } 2360 | } 2361 | }, 2362 | "winston-transport": { 2363 | "version": "4.3.0", 2364 | "resolved": "https://registry.npmjs.org/winston-transport/-/winston-transport-4.3.0.tgz", 2365 | "integrity": "sha512-B2wPuwUi3vhzn/51Uukcao4dIduEiPOcOt9HJ3QeaXgkJ5Z7UwpBzxS4ZGNHtrxrUvTwemsQiSys0ihOf8Mp1A==", 2366 | "requires": { 2367 | "readable-stream": "^2.3.6", 2368 | "triple-beam": "^1.2.0" 2369 | } 2370 | }, 2371 | "wordwrap": { 2372 | "version": "1.0.0", 2373 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2374 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 2375 | "dev": true 2376 | }, 2377 | "wrappy": { 2378 | "version": "1.0.2", 2379 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2380 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2381 | }, 2382 | "write": { 2383 | "version": "1.0.3", 2384 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2385 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2386 | "dev": true, 2387 | "requires": { 2388 | "mkdirp": "^0.5.1" 2389 | } 2390 | }, 2391 | "xtend": { 2392 | "version": "4.0.2", 2393 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2394 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 2395 | "dev": true 2396 | } 2397 | } 2398 | } 2399 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "xcode-build-tools", 3 | "version": "4.18.5", 4 | "description": "A few bash scripts to help with building ios apps", 5 | "main": "index.js", 6 | "scripts": { 7 | "test": "standard" 8 | }, 9 | "keywords": [ 10 | "xcode", 11 | "ios", 12 | "build" 13 | ], 14 | "author": "Fred Cox ", 15 | "license": "MIT", 16 | "bin": { 17 | "add-keys": "./add-keys.js", 18 | "create-ipa": "./create-ipa.js", 19 | "remove-keys": "./remove-keys.js", 20 | "upload-ipa": "./upload-ipa.js", 21 | "upload-apk": "./upload-apk.js", 22 | "find-identity-name": "./find-identity-name.js", 23 | "dev-version-xcode": "./dev-version-xcode.js", 24 | "create-release": "./create-release.js", 25 | "ensure-login-keychain": "./ensure-login-keychain.js" 26 | }, 27 | "dependencies": { 28 | "commander": "^3.0.0", 29 | "cpr": "^3.0.1", 30 | "del": "^5.0.0", 31 | "form-data": "^2.5.0", 32 | "moment": "^2.24.0", 33 | "node-fetch": "^3.1.1", 34 | "winston": "^3.2.1" 35 | }, 36 | "devDependencies": { 37 | "standard": "^13.1.0" 38 | }, 39 | "repository": { 40 | "type": "git", 41 | "url": "git+https://github.com/ekreative/xcode-build-tools.git" 42 | }, 43 | "bugs": { 44 | "url": "https://github.com/ekreative/xcode-build-tools/issues" 45 | }, 46 | "homepage": "https://github.com/ekreative/xcode-build-tools#readme" 47 | } 48 | -------------------------------------------------------------------------------- /remove-keys.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var del = require('del') 6 | var path = require('path') 7 | var program = require('commander') 8 | var os = require('os') 9 | 10 | var exec = require('./lib/exec') 11 | var list = require('./lib/list') 12 | var logger = require('./lib/logger') 13 | 14 | program 15 | .version(require('./package.json').version) 16 | .description('Delete a keychain and provisioning profiles') 17 | .option('-k, --keychain-name ', 'Keychain Name - default APP_NAME', process.env.APP_NAME || 'build-tools') 18 | .option('--provisioning-profiles ', 'Provisioning profiles - default PROVISIONING_PROFILE', list, list(process.env.PROVISIONING_PROFILE)) 19 | .parse(process.argv) 20 | 21 | var commandPromise = exec('security delete-keychain "' + program.keychainName + '.keychain" || :') 22 | 23 | commandPromise.catch(function (err) { 24 | logger.error('Error deleting keychain', err) 25 | process.exit(1) 26 | }) 27 | 28 | // Delete the provisioning profiles 29 | program.provisioningProfiles && program.provisioningProfiles.forEach(function (profile) { 30 | var name = path.basename(profile, path.extname(profile)) 31 | del(os.homedir() + '/Library/MobileDevice/Provisioning Profiles/' + name + '.mobileprovision', { force: true }, function (err) { 32 | if (err) { 33 | logger.error('Error deleting profiles', err) 34 | process.exit(1) 35 | } 36 | }) 37 | }) 38 | -------------------------------------------------------------------------------- /upload-apk.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var fetch = require('node-fetch') 6 | var FormData = require('form-data') 7 | var fs = require('fs') 8 | var program = require('commander') 9 | 10 | var git = require('./lib/git') 11 | var logger = require('./lib/logger') 12 | var slack = require('./lib/slack') 13 | 14 | program 15 | .version(require('./package.json').version) 16 | .description('Upload apk file to testbuild.rocks and (optional) send a link to slack') 17 | .option('-p, --project-id ', 'Project Id - default PROJECT_ID', process.env.PROJECT_ID) 18 | .option('--project-url ', 'GitLab project url', process.env.CI_PROJECT_URL) 19 | .option('--server ', 'Alternative server address', 'https://testbuild.rocks') 20 | .option('--apk ', 'Apk file to upload - default app/build/outputs/apk/app-release.apk', (process.env.PROJECT_FOLDER || process.cwd()) + '/app/build/outputs/apk/app-release.apk') 21 | .option('--key ', 'Test build rocks key - default TEST_BUILD_ROCKS_KEY', process.env.TEST_BUILD_ROCKS_KEY) 22 | .option('-s, --slack-hook ', 'Slack Hook - default SLACK_URL', process.env.SLACK_URL || process.env.SLACK_HOOK) 23 | .option('-c, --slack-channel ', 'Slack Channel - default SLACK_CHANNEL', process.env.SLACK_CHANNEL) 24 | .option('-m, --message ', 'Test build rocks message', 'auto') 25 | .option('-r, --ref ', 'Test build rocks git ref', process.env.CI_COMMIT_REF_SLUG || process.env.CI_BUILD_REF_SLUG || 'auto') 26 | .option('-c, --commit ', 'Test build rocks git commit', process.env.CI_COMMIT_SHA || process.env.CI_BUILD_REF || 'auto') 27 | .option('--job-name ', 'Build job name', process.env.CI_JOB_NAME || '') 28 | .parse(process.argv) 29 | 30 | if (!program.projectId) { 31 | throw new Error('Missing GitLab Project Id') 32 | } 33 | 34 | if (!program.apk) { 35 | throw new Error('Missing Apk file') 36 | } 37 | 38 | if (!fs.existsSync(program.apk)) { 39 | throw new Error('Apk file doesnt exist') 40 | } 41 | 42 | if (!program.key) { 43 | throw new Error('Missing Test build rocks token') 44 | } 45 | 46 | if (program.message === 'auto') { 47 | program.message = git.commit() 48 | } 49 | 50 | if (program.ref === 'auto') { 51 | try { 52 | program.ref = git.branch() 53 | } catch (e) { 54 | program.ref = '' 55 | } 56 | } 57 | 58 | if (program.commit === 'auto') { 59 | try { 60 | program.commit = git.ref() 61 | } catch (e) { 62 | program.commit = '' 63 | } 64 | } 65 | 66 | logger.info('Uploading build') 67 | 68 | var data = new FormData() 69 | data.append('app', fs.createReadStream(program.apk)) 70 | data.append('comment', program.message) 71 | data.append('ci', 'true') 72 | data.append('ref', program.ref) 73 | data.append('commit', program.commit) 74 | data.append('job-name', program.jobName) 75 | 76 | data.getLengthSync = null // Work around until https://github.com/bitinn/node-fetch/issues/102 77 | 78 | var result = fetch(program.server + '/api/builds/upload/' + program.projectId + '/android', { 79 | method: 'POST', 80 | body: data, 81 | headers: { 82 | 'X-API-Key': program.key 83 | } 84 | }) 85 | .then(function (res) { 86 | if (res.status === 200) { 87 | return res 88 | } 89 | return res.text().then(function (body) { 90 | throw new Error('Failed to upload build to testbuild.rocks [' + body + ']') 91 | }) 92 | }) 93 | .then(function (res) { return res.json() }) 94 | .then(function (json) { 95 | if (json.install) { 96 | logger.info('Build available at ' + json.install) 97 | } 98 | return json 99 | }) 100 | if (program.slackHook) { 101 | result = result.then(slack(program.slackHook, program.slackChannel, program.projectUrl)) 102 | } 103 | result.catch(function (err) { 104 | logger.error('Error uploading apk', err) 105 | process.exit(1) 106 | }) 107 | -------------------------------------------------------------------------------- /upload-ipa.js: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | 'use strict' 4 | 5 | var fetch = require('node-fetch') 6 | var FormData = require('form-data') 7 | var fs = require('fs') 8 | var program = require('commander') 9 | 10 | var git = require('./lib/git') 11 | var logger = require('./lib/logger') 12 | var slack = require('./lib/slack') 13 | 14 | program 15 | .version(require('./package.json').version) 16 | .description('Upload ipa file to testbuild.rocks and (optional) send a link to slack') 17 | .option('-p, --project-id ', 'Project Id - default PROJECT_ID', process.env.PROJECT_ID) 18 | .option('--project-url ', 'GitLab project url', process.env.CI_PROJECT_URL) 19 | .option('--server ', 'Alternative server address', 'https://testbuild.rocks') 20 | .option('--ipa ', 'Ipa file to upload - default build/Release-iphoneos/$APP_NAME.ipa', process.cwd() + '/build/Release-iphoneos/' + (process.env.APP_NAME ? process.env.APP_NAME + '.ipa' : 'app.ipa')) 21 | .option('--key ', 'Test build rocks key - default TEST_BUILD_ROCKS_KEY', process.env.TEST_BUILD_ROCKS_KEY) 22 | .option('-s, --slack-hook ', 'Slack Hook - default SLACK_URL', process.env.SLACK_URL || process.env.SLACK_HOOK) 23 | .option('-c, --slack-channel ', 'Slack Channel - default SLACK_CHANNEL', process.env.SLACK_CHANNEL) 24 | .option('-m, --message ', 'Test build rocks message', 'auto') 25 | .option('-r, --ref ', 'Test build rocks git ref', process.env.CI_COMMIT_REF_SLUG || process.env.CI_BUILD_REF_SLUG || 'auto') 26 | .option('-c, --commit ', 'Test build rocks git commit', process.env.CI_COMMIT_SHA || process.env.CI_BUILD_REF || 'auto') 27 | .option('--job-name ', 'Build job name', process.env.CI_JOB_NAME || '') 28 | .parse(process.argv) 29 | 30 | if (!program.projectId) { 31 | throw new Error('Missing GitLab Project Id') 32 | } 33 | 34 | if (!program.ipa) { 35 | throw new Error('Missing Ipa file') 36 | } 37 | 38 | if (!fs.existsSync(program.ipa)) { 39 | throw new Error('Ipa file doesnt exist') 40 | } 41 | 42 | if (!program.key) { 43 | throw new Error('Missing Test build rocks token') 44 | } 45 | 46 | if (program.message === 'auto') { 47 | program.message = git.commit() 48 | } 49 | 50 | if (program.ref === 'auto') { 51 | try { 52 | program.ref = git.branch() 53 | } catch (e) { 54 | program.ref = '' 55 | } 56 | } 57 | 58 | if (program.commit === 'auto') { 59 | try { 60 | program.commit = git.ref() 61 | } catch (e) { 62 | program.commit = '' 63 | } 64 | } 65 | 66 | logger.info('Uploading build') 67 | 68 | var data = new FormData() 69 | data.append('app', fs.createReadStream(program.ipa)) 70 | data.append('comment', program.message) 71 | data.append('ci', 'true') 72 | data.append('ref', program.ref) 73 | data.append('commit', program.commit) 74 | data.append('job-name', program.jobName) 75 | 76 | data.getLengthSync = null // Work around until https://github.com/bitinn/node-fetch/issues/102 77 | 78 | var result = fetch(program.server + '/api/builds/upload/' + program.projectId + '/ios', { 79 | method: 'POST', 80 | body: data, 81 | headers: { 82 | 'X-API-Key': program.key 83 | } 84 | }) 85 | .then(function (res) { 86 | if (res.status === 200) { 87 | return res 88 | } 89 | return res.text().then(function (body) { 90 | throw new Error('Failed to upload build to testbuild.rocks [' + body + ']') 91 | }) 92 | }) 93 | .then(function (res) { return res.json() }) 94 | .then(function (json) { 95 | if (json.install) { 96 | logger.info('Build available at ' + json.install) 97 | } 98 | return json 99 | }) 100 | if (program.slackHook) { 101 | result = result.then(slack(program.slackHook, program.slackChannel, program.projectUrl)) 102 | } 103 | result.catch(function (err) { 104 | logger.error('Error uploading ipa', err) 105 | process.exit(1) 106 | }) 107 | --------------------------------------------------------------------------------