diff --git a/.babelrc b/.babelrc index d192e91e..18c19dbc 100644 --- a/.babelrc +++ b/.babelrc @@ -1,5 +1,19 @@ { - "presets": [["es2015", {"modules": false}], "stage-2"], - "plugins": ["transform-runtime"], - "comments": false + "plugins": ["@babel/plugin-syntax-dynamic-import"], + "env": { + "test": { + "plugins": ["dynamic-import-node"], + "presets": [ + [ + "@babel/preset-env", + { + "modules": "commonjs", + "targets": { + "node": "current" + } + } + ] + ] + } + } } diff --git a/.editorconfig b/.editorconfig index 1a172686..198996b9 100644 --- a/.editorconfig +++ b/.editorconfig @@ -2,11 +2,8 @@ root = true [*] charset = utf-8 -indent_style = space +indent_style = tab indent_size = 4 end_of_line = lf insert_final_newline = true trim_trailing_whitespace = true - -[package.json] -indent_size = 2 diff --git a/.eslintignore b/.eslintignore index 2fece739..b215bb7f 100644 --- a/.eslintignore +++ b/.eslintignore @@ -1,3 +1,6 @@ -build/*.js -config/*.js -dist/*.js +/dist +/src-bex/www +/src-capacitor +/src-cordova +/.quasar +/node_modules diff --git a/.eslintrc.js b/.eslintrc.js index 44a6a419..6eb04c45 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -1,38 +1,89 @@ module.exports = { - root: true, - parser: 'babel-eslint', - parserOptions: { - sourceType: 'module' - }, - env: { - browser: true, - es6: true - }, - extends: [ - 'eslint:recommended' - ], - plugins: [ - 'html', - 'import' - ], - globals: { - 'cdk': true, - 'cordova': true, - 'DEV': true, - 'PROD': true, - '__THEME': true - }, - rules: { - 'arrow-parens': 0, - 'one-var': 0, - 'import/first': 0, - 'import/named': 2, - 'import/namespace': 2, - 'import/default': 2, - 'import/export': 2, - 'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0, - 'brace-style': [2, 'stroustrup', {'allowSingleLine': true}], - "no-console": 0 - } -}; + // https://eslint.org/docs/user-guide/configuring#configuration-cascading-and-hierarchy + // This option interrupts the configuration hierarchy at this file + // Remove this if you have an higher level ESLint config file (it usually happens into a monorepos) + root: true, + parserOptions: { + parser: 'babel-eslint', + ecmaVersion: 2018, // Allows for the parsing of modern ECMAScript features + sourceType: 'module' // Allows for the use of imports + }, + + env: { + browser: true + }, + + // Rules order is important, please avoid shuffling them + extends: [ + // Base ESLint recommended rules + // 'eslint:recommended', + + // Uncomment any of the lines below to choose desired strictness, + // but leave only one uncommented! + // See https://eslint.vuejs.org/rules/#available-rules + 'plugin:vue/essential', // Priority A: Essential (Error Prevention) + 'plugin:vue/strongly-recommended', // Priority B: Strongly Recommended (Improving Readability) + 'plugin:vue/recommended', // Priority C: Recommended (Minimizing Arbitrary Choices and Cognitive Overhead) + 'standard' + ], + + plugins: [ + // https://eslint.vuejs.org/user-guide/#why-doesn-t-it-work-on-vue-file + // required to lint *.vue files + 'vue', + + ], + + globals: { + 'ga': true, // Google Analytics + 'cordova': true, + '__statics': true, + 'process': true, + 'Capacitor': true, + 'chrome': true + }, + + // add your custom rules here + rules: { + // allow async-await + 'generator-star-spacing': 'off', + // allow paren-less arrow functions + 'arrow-parens': 'off', + 'one-var': 'off', + + 'import/first': 'off', + 'import/named': 'error', + 'import/namespace': 'error', + 'import/default': 'error', + 'import/export': 'error', + 'import/extensions': 'off', + 'import/no-unresolved': 'off', + 'import/no-extraneous-dependencies': 'off', + 'prefer-promise-reject-errors': 'off', + 'no-tabs': 'off', + 'no-trailing-spaces': 'off', + // allow debugger during development only + 'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off', + 'indent': [ + 'error', + 'tab' + ], + 'vue/script-indent': [ + 'error', + 'tab' + ], + 'vue/html-indent': [ + 'error', + 'tab' + ] + }, + "overrides": [ + { + "files": ["*.vue"], + "rules": { + "indent": "off" + } + } + ] +} diff --git a/.gitignore b/.gitignore index 5901ad2b..f9375961 100644 --- a/.gitignore +++ b/.gitignore @@ -1,19 +1,38 @@ .DS_Store .thumbs.db -.vscode -node_modules/ -dist/ -npm-debug.log* -cordova/platforms -cordova/plugins +node_modules + +# Quasar core related directories +.quasar +/dist + +# Cordova related directories and files +/src-cordova/node_modules +/src-cordova/platforms +/src-cordova/plugins +/src-cordova/www -# Junit reports -t/TESTS* +# Capacitor related directories and files +/src-capacitor/www +/src-capacitor/node_modules + +# BEX related directories and files +/src-bex/www +/src-bex/js/core + +# Log files +npm-debug.log* +yarn-debug.log* +yarn-error.log* -# IntelliJ +# Editor directories and files .idea -*.iml +*.suo +*.ntvs* +*.njsproj +*.sln -csc/ +/src/config.js -src/config.js +/junit.xml +/test/jest/coverage diff --git a/.npmrc b/.npmrc deleted file mode 100644 index 838ad427..00000000 --- a/.npmrc +++ /dev/null @@ -1,2 +0,0 @@ -save-prefix = -registry = https://npm-registry.sipwise.com/ diff --git a/.postcssrc.js b/.postcssrc.js new file mode 100644 index 00000000..1174fe52 --- /dev/null +++ b/.postcssrc.js @@ -0,0 +1,8 @@ +// https://github.com/michael-ciniawsky/postcss-load-config + +module.exports = { + plugins: [ + // to edit target browsers: use "browserslist" field in package.json + require('autoprefixer') + ] +} diff --git a/babel.config.js b/babel.config.js new file mode 100644 index 00000000..1952e0c2 --- /dev/null +++ b/babel.config.js @@ -0,0 +1,18 @@ +const fs = require('fs-extra') +let extend = undefined + +/** + * The .babelrc file has been created to assist Jest for transpiling. + * You should keep your application's babel rules in this file. + */ + +if (fs.existsSync('./.babelrc')) { + extend = './.babelrc' +} + +module.exports = { + presets: [ + '@quasar/babel-preset-app' + ], + extends: extend +} diff --git a/build/css-utils.js b/build/css-utils.js deleted file mode 100644 index 76717e4c..00000000 --- a/build/css-utils.js +++ /dev/null @@ -1,91 +0,0 @@ -var - ExtractTextPlugin = require('extract-text-webpack-plugin'), - autoprefixer = require('autoprefixer'), - purify = require('purify-css'), - glob = require('glob'), - path = require('path'), - fs = require('fs') - -module.exports.postcss = [autoprefixer()] - -module.exports.styleLoaders = function (options) { - options = options || {} - - function generateLoaders (loaders) { - if (options.postcss) { - loaders.splice(1, 0, 'postcss') - } - - var sourceLoader = loaders.map(function (loader) { - var extraParamChar - if (/\?/.test(loader)) { - loader = loader.replace(/\?/, '-loader?') - extraParamChar = '&' - } - else { - loader = loader + '-loader' - extraParamChar = '?' - } - return loader + (options.sourceMap ? extraParamChar + 'sourceMap' : '') - }).join('!') - - if (options.extract) { - return ExtractTextPlugin.extract({ - use: sourceLoader, - fallback: 'vue-style-loader' - }) - } - else { - return ['vue-style-loader', sourceLoader].join('!') - } - } - - return { - css: generateLoaders(['css']), - less: generateLoaders(['css', 'less']), - sass: generateLoaders(['css', 'sass?indentedSyntax']), - scss: generateLoaders(['css', 'sass']), - styl: generateLoaders(['css', 'stylus']), - stylus: generateLoaders(['css', 'stylus']) - } -} - -module.exports.styleRules = function (options) { - var output = [] - var loaders = exports.styleLoaders(options) - for (var extension in loaders) { - var loader = loaders[extension] - output.push({ - test: new RegExp('\\.' + extension + '$'), - loader: loader - }) - } - return output -} - -function getSize (size) { - return (size / 1024).toFixed(2) + 'kb' -} - -module.exports.purify = function(cb) { - var css = glob.sync(path.join(__dirname, '../dist/**/*.css')) - var js = glob.sync(path.join(__dirname, '../dist/**/*.js')) - - Promise.all(css.map(function (file) { - return new Promise(function (resolve) { - console.log('\n Purifying ' + path.relative(path.join(__dirname, '../dist'), file).bold + '...') - purify(js, [file], {minify: true}, function (purified) { - var oldSize = fs.statSync(file).size - fs.writeFileSync(file, purified) - var newSize = fs.statSync(file).size - - console.log( - ' * Reduced size by ' + ((1 - newSize / oldSize) * 100).toFixed(2) + '%, from ' + - getSize(oldSize) + ' to ' + getSize(newSize) + '.' - ) - resolve() - }) - }) - })) - .then(cb) -} diff --git a/build/env-utils.js b/build/env-utils.js deleted file mode 100644 index fe0c4eb0..00000000 --- a/build/env-utils.js +++ /dev/null @@ -1,13 +0,0 @@ -var - config = require('../config'), - theme = process.argv[2] || config.defaultTheme - -module.exports = { - dev: process.env.NODE_ENV === 'development', - prod: process.env.NODE_ENV === 'production', - - platform: { - theme: theme, - cordovaAssets: './cordova/platforms/' + (theme === 'mat' ? 'android' : 'ios') + '/platform_www' - } -} diff --git a/build/hot-reload.js b/build/hot-reload.js deleted file mode 100644 index 519350ae..00000000 --- a/build/hot-reload.js +++ /dev/null @@ -1,3 +0,0 @@ -/* eslint-disable */ -require('eventsource-polyfill') -require('webpack-hot-middleware/client?noInfo=true&reload=true') diff --git a/build/script.build.js b/build/script.build.js deleted file mode 100644 index 5089e717..00000000 --- a/build/script.build.js +++ /dev/null @@ -1,68 +0,0 @@ -process.env.NODE_ENV = 'production' - -require('colors') - -var - shell = require('shelljs'), - path = require('path'), - env = require('./env-utils'), - css = require('./css-utils'), - config = require('../config'), - webpack = require('webpack'), - webpackConfig = require('./webpack.prod.conf'), - targetPath = path.join(__dirname, '../dist') - -console.log(' WARNING!'.bold) -console.log(' Do NOT use VueRouter\'s "history" mode if') -console.log(' building for Cordova or Electron.\n') - -require('./script.clean.js') -console.log((' Building Quasar App with "' + env.platform.theme + '" theme...\n').bold) - -shell.mkdir('-p', targetPath) -shell.cp('-R', 'src/statics', targetPath) - -function finalize () { - console.log(( - '\n Build complete with "' + env.platform.theme.bold + '" theme in ' + - '"/dist"'.bold + ' folder.\n').cyan) - - console.log(' Built files are meant to be served over an HTTP server.'.bold) - console.log(' Opening index.html over file:// won\'t work.'.bold) -} - -webpackConfig.watch = (process.env['CSC_WATCH'])? true : false; -webpackConfig.watchOptions = { - ignored: [ - 'build', - 'config', - 'debian', - 'dist', - 'node_modules', - 't', - 'templates' - ] -} - -webpack(webpackConfig, function (err, stats) { - if (err) throw err - - process.stdout.write(stats.toString({ - colors: true, - modules: false, - children: false, - chunks: false, - chunkModules: false - }) + '\n') - - if (stats.hasErrors()) { - process.exit(1) - } - - if (config.build.purifyCSS) { - css.purify(finalize) - } - else { - finalize() - } -}) diff --git a/build/script.clean.js b/build/script.clean.js deleted file mode 100644 index 00472bd7..00000000 --- a/build/script.clean.js +++ /dev/null @@ -1,7 +0,0 @@ -var - shell = require('shelljs'), - path = require('path') - -shell.rm('-rf', path.resolve(__dirname, '../dist/*')) -shell.rm('-rf', path.resolve(__dirname, '../dist/.*')) -console.log(' Cleaned build artifacts.\n') diff --git a/build/script.dev.js b/build/script.dev.js deleted file mode 100644 index 62fa4849..00000000 --- a/build/script.dev.js +++ /dev/null @@ -1,86 +0,0 @@ -process.env.NODE_ENV = 'development' - -require('colors') - -var - path = require('path'), - express = require('express'), - webpack = require('webpack'), - env = require('./env-utils'), - config = require('../config'), - opn = require('opn'), - proxyMiddleware = require('http-proxy-middleware'), - webpackConfig = require('./webpack.dev.conf'), - app = express(), - port = process.env.PORT || config.dev.port, - uri = 'http://localhost:' + port - -console.log(' Starting dev server with "' + (process.argv[2] || env.platform.theme).bold + '" theme...') -console.log(' Will listen at ' + uri.bold) -if (config.dev.openBrowser) { - console.log(' Browser will open when build is ready.\n') -} - -var compiler = webpack(webpackConfig) - -// Define HTTP proxies to your custom API backend -// https://github.com/chimurai/http-proxy-middleware -var proxyTable = config.dev.proxyTable - -var devMiddleware = require('webpack-dev-middleware')(compiler, { - publicPath: webpackConfig.output.publicPath, - quiet: true -}) - -var hotMiddleware = require('webpack-hot-middleware')(compiler, { - log: function () {} -}) - -// force page reload when html-webpack-plugin template changes -compiler.plugin('compilation', function (compilation) { - compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) { - hotMiddleware.publish({ action: 'reload' }) - cb() - }) -}) - -// proxy requests like API. See /config/index.js -> dev.proxyTable -// https://github.com/chimurai/http-proxy-middleware -Object.keys(proxyTable).forEach(function (context) { - var options = proxyTable[context] - if (typeof options === 'string') { - options = { target: options } - } - app.use(proxyMiddleware(context, options)) -}) - -// handle fallback for HTML5 history API -app.use(require('connect-history-api-fallback')()) - -// serve webpack bundle output -app.use(devMiddleware) - -// enable hot-reload and state-preserving -// compilation error display -app.use(hotMiddleware) - -// serve pure static assets -var staticsPath = path.posix.join(webpackConfig.output.publicPath, 'statics/') -app.use(staticsPath, express.static('./src/statics')) - -// try to serve Cordova statics for Play App -app.use(express.static(env.platform.cordovaAssets)) - -module.exports = app.listen(port, function (err) { - if (err) { - console.log(err) - process.exit(1) - } - - // open browser if set so in /config/index.js - if (config.dev.openBrowser) { - devMiddleware.waitUntilValid(function () { - opn(uri) - }) - } -}) diff --git a/build/webpack.base.conf.js b/build/webpack.base.conf.js deleted file mode 100644 index 821bc5aa..00000000 --- a/build/webpack.base.conf.js +++ /dev/null @@ -1,108 +0,0 @@ -var - path = require('path'), - webpack = require('webpack'), - config = require('../config'), - cssUtils = require('./css-utils'), - env = require('./env-utils'), - merge = require('webpack-merge'), - projectRoot = path.resolve(__dirname, '../'), - ProgressBarPlugin = require('progress-bar-webpack-plugin'), - useCssSourceMap = - (env.dev && config.dev.cssSourceMap) || - (env.prod && config.build.productionSourceMap) - -function resolve (dir) { - return path.join(__dirname, '..', dir) -} - -module.exports = { - entry: { - app: './src/main.js' - }, - output: { - path: path.resolve(__dirname, '../dist'), - publicPath: config[env.prod ? 'build' : 'dev'].publicPath, - filename: 'js/[name].[hash].js', - chunkFilename: 'js/[id].[chunkhash].js' - }, - resolve: { - extensions: ['.js', '.vue', '.json'], - modules: [ - resolve('src'), - resolve('node_modules') - ], - alias: config.aliases - }, - module: { - rules: [ - { - enforce: 'pre', - test: /\.(vue|js)$/, - loader: 'eslint-loader', - include: projectRoot, - exclude: /node_modules/, - options: { - formatter: require('eslint-friendly-formatter') - } - }, - { - test: /\.js$/, - loader: 'babel-loader', - include: projectRoot, - exclude: /node_modules/ - }, - { - test: /\.vue$/, - loader: 'vue-loader', - options: { - postcss: cssUtils.postcss, - loaders: merge({js: 'babel-loader'}, cssUtils.styleLoaders({ - sourceMap: useCssSourceMap, - extract: env.prod - })) - } - }, - { - test: /\.json$/, - loader: 'json-loader' - }, - { - test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, - loader: 'url-loader', - options: { - limit: 10000, - name: 'img/[name].[hash:7].[ext]' - } - }, - { - test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, - loader: 'url-loader', - options: { - limit: 10000, - name: 'fonts/[name].[hash:7].[ext]' - } - } - ] - }, - plugins: [ - new webpack.DefinePlugin({ - 'process.env': config[env.prod ? 'build' : 'dev'].env, - 'DEV': env.dev, - 'PROD': env.prod, - '__THEME': '"' + env.platform.theme + '"' - }), - new webpack.LoaderOptionsPlugin({ - minimize: env.prod, - options: { - context: path.resolve(__dirname, '../src'), - postcss: cssUtils.postcss - } - }), - new ProgressBarPlugin({ - format: config.progressFormat - }) - ], - performance: { - hints: false - } -} diff --git a/build/webpack.dev.conf.js b/build/webpack.dev.conf.js deleted file mode 100644 index b4dd19e9..00000000 --- a/build/webpack.dev.conf.js +++ /dev/null @@ -1,43 +0,0 @@ -var - config = require('../config'), - webpack = require('webpack'), - merge = require('webpack-merge'), - cssUtils = require('./css-utils'), - baseWebpackConfig = require('./webpack.base.conf'), - HtmlWebpackPlugin = require('html-webpack-plugin'), - FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin') - -// add hot-reload related code to entry chunks -Object.keys(baseWebpackConfig.entry).forEach(function (name) { - baseWebpackConfig.entry[name] = ['./build/hot-reload.js', baseWebpackConfig.entry[name]] -}) - -module.exports = merge(baseWebpackConfig, { - // eval-source-map is faster for development - devtool: '#cheap-module-eval-source-map', - devServer: { - historyApiFallback: true, - noInfo: true - }, - module: { - rules: cssUtils.styleRules({ - sourceMap: config.dev.cssSourceMap, - postcss: true - }) - }, - plugins: [ - new webpack.HotModuleReplacementPlugin(), - new webpack.NoEmitOnErrorsPlugin(), - new HtmlWebpackPlugin({ - filename: 'index.html', - template: 'src/index.html', - inject: true - }), - new FriendlyErrorsPlugin({ - clearConsole: config.dev.clearConsoleOnRebuild - }) - ], - performance: { - hints: false - } -}) diff --git a/build/webpack.prod.conf.js b/build/webpack.prod.conf.js deleted file mode 100644 index c25411b8..00000000 --- a/build/webpack.prod.conf.js +++ /dev/null @@ -1,78 +0,0 @@ -var - path = require('path'), - config = require('../config'), - cssUtils = require('./css-utils'), - webpack = require('webpack'), - merge = require('webpack-merge'), - baseWebpackConfig = require('./webpack.base.conf'), - ExtractTextPlugin = require('extract-text-webpack-plugin'), - HtmlWebpackPlugin = require('html-webpack-plugin'), - OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin') - -module.exports = merge(baseWebpackConfig, { - module: { - rules: cssUtils.styleRules({ - sourceMap: config.build.productionSourceMap, - extract: true, - postcss: true - }) - }, - devtool: config.build.productionSourceMap ? '#source-map' : false, - plugins: [ - new webpack.optimize.UglifyJsPlugin({ - sourceMap: config.build.productionSourceMap, - minimize: true, - compress: { - warnings: false - } - }), - // Compress extracted CSS. We are using this plugin so that possible - // duplicated CSS from different components can be deduped. - new OptimizeCSSPlugin({ - cssProcessorOptions: { - safe: true - } - }), - // extract css into its own file - new ExtractTextPlugin({ - filename: '[name].[contenthash].css' - }), - new HtmlWebpackPlugin({ - filename: path.resolve(__dirname, '../dist/index.html'), - template: 'src/index.html', - inject: true, - minify: { - removeComments: true, - collapseWhitespace: true, - removeAttributeQuotes: true - // more options: - // https://github.com/kangax/html-minifier#options-quick-reference - }, - // necessary to consistently work with multiple chunks via CommonsChunkPlugin - chunksSortMode: 'dependency' - }), - // split vendor js into its own file - new webpack.optimize.CommonsChunkPlugin({ - name: 'vendor', - minChunks: function (module, count) { - // any required modules inside node_modules are extracted to vendor - return ( - module.resource && - /\.js$/.test(module.resource) && - ( - module.resource.indexOf('quasar') > -1 || - module.resource.indexOf( - path.join(__dirname, '../node_modules') - ) === 0 - ) - ) - } - }), - // extract webpack runtime and module manifest to its own file in order to - // prevent vendor hash from being updated whenever app bundle is updated - new webpack.optimize.CommonsChunkPlugin({ - name: 'manifest', - chunks: ['vendor'] - }) - ] -}) diff --git a/config/dev.env.js b/config/dev.env.js deleted file mode 100644 index efead7c8..00000000 --- a/config/dev.env.js +++ /dev/null @@ -1,6 +0,0 @@ -var merge = require('webpack-merge') -var prodEnv = require('./prod.env') - -module.exports = merge(prodEnv, { - NODE_ENV: '"development"' -}) diff --git a/config/index.js b/config/index.js deleted file mode 100644 index 8e8791c8..00000000 --- a/config/index.js +++ /dev/null @@ -1,65 +0,0 @@ -var path = require('path') - -module.exports = { - // Webpack aliases - aliases: { - 'quasar-frameworks': path.resolve(__dirname, '../node_modules/quasar-framework/'), - quasar: path.resolve(__dirname, '../node_modules/quasar-framework/'), - src: path.resolve(__dirname, '../src'), - assets: path.resolve(__dirname, '../src/assets'), - '@': path.resolve(__dirname, '../src/components'), - variables: path.resolve(__dirname, '../src/themes/quasar.variables.styl') - }, - - // Progress Bar Webpack plugin format - // https://github.com/clessg/progress-bar-webpack-plugin#options - progressFormat: ' [:bar] ' + ':percent'.bold + ' (:msg)', - - // Default theme to build with ('ios' or 'mat') - defaultTheme: 'mat', - - build: { - env: require('./prod.env'), - publicPath: '', - productionSourceMap: (process.env['CSC_SOURCE_MAP'])? true : false, - - // Remove unused CSS - // Disable it if it has side-effects for your specific app - purifyCSS: true - }, - dev: { - env: require('./dev.env'), - cssSourceMap: true, - // auto open browser or not - openBrowser: false, - publicPath: '/', - port: 8080, - - // If for example you are using Quasar Play - // to generate a QR code then on each dev (re)compilation - // you need to avoid clearing out the console, so set this - // to "false", otherwise you can set it to "true" to always - // have only the messages regarding your last (re)compilation. - clearConsoleOnRebuild: false, - - // Proxy your API if using any. - // Also see /build/script.dev.js and search for "proxy api requests" - // https://github.com/chimurai/http-proxy-middleware - proxyTable: {} - } -} - -/* - * proxyTable example: - * - proxyTable: { - // proxy all requests starting with /api - '/api': { - target: 'https://some.address.com/api', - changeOrigin: true, - pathRewrite: { - '^/api': '' - } - } - } - */ diff --git a/config/prod.env.js b/config/prod.env.js deleted file mode 100644 index 773d263d..00000000 --- a/config/prod.env.js +++ /dev/null @@ -1,3 +0,0 @@ -module.exports = { - NODE_ENV: '"production"' -} diff --git a/debian/control b/debian/control index 8dc6e835..bf81fd7c 100644 --- a/debian/control +++ b/debian/control @@ -6,7 +6,7 @@ Homepage: https://www.sipwise.com/ Standards-Version: 3.9.8 Build-Depends: debhelper-compat (= 12), - npm, + yarnpkg, Package: ngcp-csc-ui Architecture: all diff --git a/debian/rules b/debian/rules index d1914532..1d1ddc54 100755 --- a/debian/rules +++ b/debian/rules @@ -7,7 +7,7 @@ dh "$@" override_dh_auto_install: - npm ci + yarnpkg install cp src/config.template.js src/config.js - npm run build + yarnpkg run build mv dist csc diff --git a/design/call-forward-concept-v1.pdf b/design/call-forward-concept-v1.pdf deleted file mode 100644 index 7d30bdc7..00000000 Binary files a/design/call-forward-concept-v1.pdf and /dev/null differ diff --git a/design/call-forward-concept-v2.pdf b/design/call-forward-concept-v2.pdf deleted file mode 100644 index 552d3fe2..00000000 Binary files a/design/call-forward-concept-v2.pdf and /dev/null differ diff --git a/env/Dockerfile b/env/Dockerfile index 9dc1a4ab..47876591 100644 --- a/env/Dockerfile +++ b/env/Dockerfile @@ -5,16 +5,16 @@ FROM docker.mgm.sipwise.com/sipwise-buster:latest # is updated with the current date. It will force refresh of all # of the base images and things like `apt-get update` won't be using # old cached versions when the Dockerfile is built. -ENV REFRESHED_AT 2020-06-17 +ENV REFRESHED_AT 2020-08-27 # files that get-code generates COPY env/sources.list.d/builddeps.list /etc/apt/sources.list.d/ COPY env/sources.list.d/preferences /etc/apt/preferences.d/ RUN apt-get update && \ - apt-get install --assume-yes \ - npm \ + apt-get install --assume-yes --no-install-recommends \ nodejs \ + yarnpkg \ && \ apt-get clean diff --git a/env/run_csc_ui b/env/run_csc_ui index 5c00f90c..1250126e 100755 --- a/env/run_csc_ui +++ b/env/run_csc_ui @@ -36,16 +36,16 @@ echo "App config '${app_config}' is OK." echo "JFYI, important components versions:" echo -n "node --version : " && node --version -echo -n "npm --version : " && npm --version +echo -n "yarn --version : " && yarnpkg --version echo "Configuring Vue.js/Quasar dev environment, running 'npm ci'..." -if ! npm ci ; then +if ! yarnpkg install ; then echo "ERROR: cannot install all npm dependencies. Aborting." exit 1 fi echo "Starting Quasar dev environment, running 'npm run dev'..." -if ! npm run dev; then +if ! yarnpkg run dev ; then echo "ERROR: cannot run quasar dev environment. Aborting." exit 1 fi diff --git a/jest.config.js b/jest.config.js new file mode 100755 index 00000000..eb06ae47 --- /dev/null +++ b/jest.config.js @@ -0,0 +1,62 @@ +module.exports = { + globals: { + __DEV__: true + }, + setupFilesAfterEnv: [ + '/test/jest/jest.setup.js' + ], + // noStackTrace: true, + // bail: true, + // cache: false, + // verbose: true, + // watch: true, + collectCoverage: true, + coverageDirectory: '/test/jest/coverage', + collectCoverageFrom: [ + '/src/**/*.vue', + '/src/**/*.js', + '/src/**/*.ts', + '/src/**/*.jsx' + ], + coverageThreshold: { + global: { + // branches: 50, + // functions: 50, + // lines: 50, + // statements: 50 + } + }, + testMatch: [ + '/test/jest/__tests__/**/*.spec.js', + '/test/jest/__tests__/**/*.test.js', + '/src/**/__tests__/*_jest.spec.js' + ], + moduleFileExtensions: [ + 'vue', + 'js', + 'json' + ], + moduleNameMapper: { + '^vue$': '/node_modules/vue/dist/vue.common.js', + '^test-utils$': '/node_modules/@vue/test-utils/dist/vue-test-utils.js', + '^quasar$': '/node_modules/quasar/dist/quasar.common.js', + '^~/(.*)$': '/$1', + '^src/(.*)$': '/src/$1', + '.*css$': '/test/jest/utils/stub.css' + }, + transform: { + '.*\\.vue$': 'vue-jest', + '.*\\.js$': 'babel-jest', + '.+\\.(css|styl|less|sass|scss|svg|png|jpg|ttf|woff|woff2)$': 'jest-transform-stub' + // use these if NPM is being flaky + // '.*\\.vue$': '/node_modules/@quasar/quasar-app-extension-testing-unit-jest/node_modules/vue-jest', + // '.*\\.js$': '/node_modules/@quasar/quasar-app-extension-testing-unit-jest/node_modules/babel-jest' + }, + transformIgnorePatterns: [ + '/node_modules/(?!quasar/lang)' + ], + snapshotSerializers: [ + '/node_modules/jest-serializer-vue' + ], + reporters: ['default', 'jest-junit'] +} diff --git a/jsconfig.json b/jsconfig.json new file mode 100644 index 00000000..1351bd98 --- /dev/null +++ b/jsconfig.json @@ -0,0 +1,36 @@ +{ + "compilerOptions": { + "baseUrl": ".", + "paths": { + "src/*": [ + "src/*" + ], + "app/*": [ + "*" + ], + "components/*": [ + "src/components/*" + ], + "layouts/*": [ + "src/layouts/*" + ], + "pages/*": [ + "src/pages/*" + ], + "assets/*": [ + "src/assets/*" + ], + "boot/*": [ + "src/boot/*" + ], + "vue$": [ + "node_modules/vue/dist/vue.esm.js" + ] + } + }, + "exclude": [ + "dist", + ".quasar", + "node_modules" + ] +} \ No newline at end of file diff --git a/karma.js b/karma.js deleted file mode 100644 index 37cb8132..00000000 --- a/karma.js +++ /dev/null @@ -1,59 +0,0 @@ -'use strict'; - -var _ = require('lodash'); -var webpackCsc = require('./build/webpack.base.conf'); - -webpackCsc.module.rules.shift(); - -module.exports = function(config) { - config.set({ - basePath: '', - files: [ - './t/**/*.js' - ], - frameworks: ['mocha'], - plugins : [ - 'karma-mocha', - 'karma-webpack', - 'karma-chrome-launcher', - 'karma-firefox-launcher', - 'karma-junit-reporter', - ], - browsers: ['ChromeWebRTC', 'FirefoxWebRTC'], - customLaunchers: { - ChromeWebRTC: { - base: 'Chrome', - flags: [ - '--disable-web-security', - '--use-fake-device-for-media-stream', - '--use-fake-ui-for-media-stream', - '--ignore-certificate-errors', - '--no-sandbox', - '--disable-gpu' - ] - }, - FirefoxWebRTC: { - base: 'Firefox', - prefs: { - 'media.navigator.permission.disabled': true, - 'media.navigator.streams.fake': true - } - } - }, - reporters: [ - 'progress', - 'junit' - ], - junitReporter: { - outputDir: './t/' - }, - preprocessors: { - './src/**/*.js': ['webpack'], - './t/**/*.js': ['webpack'] - }, - webpack: { - module: webpackCsc.module, - plugins: webpackCsc.plugins - } - }); -}; diff --git a/package-lock.json b/package-lock.json deleted file mode 100644 index ea8ca28c..00000000 --- a/package-lock.json +++ /dev/null @@ -1,10295 +0,0 @@ -{ - "name": "ngcp-csc-ui", - "version": "0.3.1", - "lockfileVersion": 1, - "requires": true, - "dependencies": { - "accepts": { - "version": "1.3.5", - "resolved": "https://npm-registry.sipwise.com/accepts/-/accepts-1.3.5.tgz", - "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", - "dev": true, - "requires": { - "mime-types": "~2.1.18", - "negotiator": "0.6.1" - } - }, - "acorn": { - "version": "5.7.1", - "resolved": "https://npm-registry.sipwise.com/acorn/-/acorn-5.7.1.tgz", - "integrity": "sha512-d+nbxBUGKg7Arpsvbnlq61mc12ek3EY8EQldM3GPAhWJ1UVxC6TDGbIvUMNU6obBX3i1+ptCIzV4vq0gFPEGVQ==", - "dev": true - }, - "acorn-dynamic-import": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/acorn-dynamic-import/-/acorn-dynamic-import-2.0.2.tgz", - "integrity": "sha1-x1K9IQvvZ5UBtsbLf8hPj0cVjMQ=", - "dev": true, - "requires": { - "acorn": "^4.0.3" - }, - "dependencies": { - "acorn": { - "version": "4.0.13", - "resolved": "https://npm-registry.sipwise.com/acorn/-/acorn-4.0.13.tgz", - "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=", - "dev": true - } - } - }, - "acorn-jsx": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/acorn-jsx/-/acorn-jsx-3.0.1.tgz", - "integrity": "sha1-r9+UiPsezvyDSPb7IvRk4ypYs2s=", - "dev": true, - "requires": { - "acorn": "^3.0.4" - }, - "dependencies": { - "acorn": { - "version": "3.3.0", - "resolved": "https://npm-registry.sipwise.com/acorn/-/acorn-3.3.0.tgz", - "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", - "dev": true - } - } - }, - "after": { - "version": "0.8.2", - "resolved": "https://npm-registry.sipwise.com/after/-/after-0.8.2.tgz", - "integrity": "sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8=", - "dev": true - }, - "ajv": { - "version": "5.5.2", - "resolved": "https://npm-registry.sipwise.com/ajv/-/ajv-5.5.2.tgz", - "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", - "dev": true, - "requires": { - "co": "^4.6.0", - "fast-deep-equal": "^1.0.0", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.3.0" - } - }, - "ajv-keywords": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/ajv-keywords/-/ajv-keywords-2.1.1.tgz", - "integrity": "sha1-YXmX/F9gV2iUxDX5QNgZ4TW4B2I=", - "dev": true - }, - "align-text": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/align-text/-/align-text-0.1.4.tgz", - "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", - "dev": true, - "requires": { - "kind-of": "^3.0.2", - "longest": "^1.0.1", - "repeat-string": "^1.5.2" - } - }, - "alphanum-sort": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/alphanum-sort/-/alphanum-sort-1.0.2.tgz", - "integrity": "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=", - "dev": true - }, - "amdefine": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/amdefine/-/amdefine-1.0.1.tgz", - "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", - "dev": true - }, - "ansi-escapes": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/ansi-escapes/-/ansi-escapes-3.1.0.tgz", - "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", - "dev": true - }, - "ansi-html": { - "version": "0.0.7", - "resolved": "https://npm-registry.sipwise.com/ansi-html/-/ansi-html-0.0.7.tgz", - "integrity": "sha1-gTWEAhliqenm/QOflA0S9WynhZ4=", - "dev": true - }, - "ansi-regex": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/ansi-regex/-/ansi-regex-2.1.1.tgz", - "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", - "dev": true - }, - "ansi-styles": { - "version": "2.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-2.2.1.tgz", - "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", - "dev": true - }, - "anymatch": { - "version": "1.3.2", - "resolved": "https://npm-registry.sipwise.com/anymatch/-/anymatch-1.3.2.tgz", - "integrity": "sha1-VT3Lj5HjyImEXf26NMd3IbkLnXo=", - "dev": true, - "requires": { - "micromatch": "^2.1.5", - "normalize-path": "^2.0.0" - } - }, - "argparse": { - "version": "1.0.10", - "resolved": "https://npm-registry.sipwise.com/argparse/-/argparse-1.0.10.tgz", - "integrity": "sha1-vNZ5HqWuCXJeF+WtmIE0zUCz2RE=", - "dev": true, - "requires": { - "sprintf-js": "~1.0.2" - } - }, - "arr-diff": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/arr-diff/-/arr-diff-2.0.0.tgz", - "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", - "dev": true, - "requires": { - "arr-flatten": "^1.0.1" - } - }, - "arr-flatten": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/arr-flatten/-/arr-flatten-1.1.0.tgz", - "integrity": "sha1-NgSLv/TntH4TZkQxbJlmnqWukfE=", - "dev": true - }, - "arr-union": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/arr-union/-/arr-union-3.1.0.tgz", - "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", - "dev": true - }, - "array-flatten": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/array-flatten/-/array-flatten-1.1.1.tgz", - "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=", - "dev": true - }, - "array-slice": { - "version": "0.2.3", - "resolved": "https://npm-registry.sipwise.com/array-slice/-/array-slice-0.2.3.tgz", - "integrity": "sha1-3Tz7gO15c6dRF82sabC5nshhhvU=", - "dev": true - }, - "array-union": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/array-union/-/array-union-1.0.2.tgz", - "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", - "dev": true, - "requires": { - "array-uniq": "^1.0.1" - } - }, - "array-uniq": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/array-uniq/-/array-uniq-1.0.3.tgz", - "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", - "dev": true - }, - "array-unique": { - "version": "0.2.1", - "resolved": "https://npm-registry.sipwise.com/array-unique/-/array-unique-0.2.1.tgz", - "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", - "dev": true - }, - "arraybuffer.slice": { - "version": "0.0.6", - "resolved": "https://npm-registry.sipwise.com/arraybuffer.slice/-/arraybuffer.slice-0.0.6.tgz", - "integrity": "sha1-8zshWfBTKj8xB6JywMz70a0peco=", - "dev": true - }, - "arrify": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/arrify/-/arrify-1.0.1.tgz", - "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", - "dev": true - }, - "asn1.js": { - "version": "4.10.1", - "resolved": "https://npm-registry.sipwise.com/asn1.js/-/asn1.js-4.10.1.tgz", - "integrity": "sha1-ucK/WAXx5kqt7tbfOiv6+1pz9aA=", - "dev": true, - "requires": { - "bn.js": "^4.0.0", - "inherits": "^2.0.1", - "minimalistic-assert": "^1.0.0" - } - }, - "assert": { - "version": "1.4.1", - "resolved": "https://npm-registry.sipwise.com/assert/-/assert-1.4.1.tgz", - "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", - "dev": true, - "requires": { - "util": "0.10.3" - }, - "dependencies": { - "inherits": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/inherits/-/inherits-2.0.1.tgz", - "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=", - "dev": true - }, - "util": { - "version": "0.10.3", - "resolved": "https://npm-registry.sipwise.com/util/-/util-0.10.3.tgz", - "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", - "dev": true, - "requires": { - "inherits": "2.0.1" - } - } - } - }, - "assertion-error": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/assertion-error/-/assertion-error-1.1.0.tgz", - "integrity": "sha1-5gtrDo8wG9l+U3UhW9pAbIURjAs=", - "dev": true - }, - "assign-symbols": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/assign-symbols/-/assign-symbols-1.0.0.tgz", - "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", - "dev": true - }, - "async": { - "version": "2.6.1", - "resolved": "https://npm-registry.sipwise.com/async/-/async-2.6.1.tgz", - "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==", - "dev": true, - "requires": { - "lodash": "^4.17.10" - }, - "dependencies": { - "lodash": { - "version": "4.17.15", - "resolved": "https://npm-registry.sipwise.com/lodash/-/lodash-4.17.15.tgz", - "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", - "dev": true - } - } - }, - "async-each": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/async-each/-/async-each-1.0.1.tgz", - "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", - "dev": true - }, - "atob": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/atob/-/atob-2.1.1.tgz", - "integrity": "sha1-ri1acpR38onWDdf5amMUoi3Wwio=", - "dev": true - }, - "autoprefixer": { - "version": "6.7.7", - "resolved": "https://npm-registry.sipwise.com/autoprefixer/-/autoprefixer-6.7.7.tgz", - "integrity": "sha1-Hb0cg1ZY41zj+ZhAmdsAWFx4IBQ=", - "dev": true, - "requires": { - "browserslist": "^1.7.6", - "caniuse-db": "^1.0.30000634", - "normalize-range": "^0.1.2", - "num2fraction": "^1.2.2", - "postcss": "^5.2.16", - "postcss-value-parser": "^3.2.3" - } - }, - "babel-code-frame": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-code-frame/-/babel-code-frame-6.26.0.tgz", - "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", - "dev": true, - "requires": { - "chalk": "^1.1.3", - "esutils": "^2.0.2", - "js-tokens": "^3.0.2" - } - }, - "babel-core": { - "version": "6.26.3", - "resolved": "https://npm-registry.sipwise.com/babel-core/-/babel-core-6.26.3.tgz", - "integrity": "sha1-suLwnjQtDwyI4vAuBneUEl51wgc=", - "dev": true, - "requires": { - "babel-code-frame": "^6.26.0", - "babel-generator": "^6.26.0", - "babel-helpers": "^6.24.1", - "babel-messages": "^6.23.0", - "babel-register": "^6.26.0", - "babel-runtime": "^6.26.0", - "babel-template": "^6.26.0", - "babel-traverse": "^6.26.0", - "babel-types": "^6.26.0", - "babylon": "^6.18.0", - "convert-source-map": "^1.5.1", - "debug": "^2.6.9", - "json5": "^0.5.1", - "lodash": "^4.17.4", - "minimatch": "^3.0.4", - "path-is-absolute": "^1.0.1", - "private": "^0.1.8", - "slash": "^1.0.0", - "source-map": "^0.5.7" - } - }, - "babel-eslint": { - "version": "7.2.3", - "resolved": "https://npm-registry.sipwise.com/babel-eslint/-/babel-eslint-7.2.3.tgz", - "integrity": "sha1-sv4tgBJkcPXBlELcdXJTqJdxCCc=", - "dev": true, - "requires": { - "babel-code-frame": "^6.22.0", - "babel-traverse": "^6.23.1", - "babel-types": "^6.23.0", - "babylon": "^6.17.0" - } - }, - "babel-generator": { - "version": "6.26.1", - "resolved": "https://npm-registry.sipwise.com/babel-generator/-/babel-generator-6.26.1.tgz", - "integrity": "sha1-GERAjTuPDTWkBOp6wYDwh6YBvZA=", - "dev": true, - "requires": { - "babel-messages": "^6.23.0", - "babel-runtime": "^6.26.0", - "babel-types": "^6.26.0", - "detect-indent": "^4.0.0", - "jsesc": "^1.3.0", - "lodash": "^4.17.4", - "source-map": "^0.5.7", - "trim-right": "^1.0.1" - } - }, - "babel-helper-bindify-decorators": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-bindify-decorators/-/babel-helper-bindify-decorators-6.24.1.tgz", - "integrity": "sha1-FMGeXxQte0fxmlJDHlKxzLxAozA=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-helper-builder-binary-assignment-operator-visitor": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-builder-binary-assignment-operator-visitor/-/babel-helper-builder-binary-assignment-operator-visitor-6.24.1.tgz", - "integrity": "sha1-zORReto1b0IgvK6KAsKzRvmlZmQ=", - "dev": true, - "requires": { - "babel-helper-explode-assignable-expression": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-helper-call-delegate": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz", - "integrity": "sha1-7Oaqzdx25Bw0YfiL/Fdb0Nqi340=", - "dev": true, - "requires": { - "babel-helper-hoist-variables": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-helper-define-map": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz", - "integrity": "sha1-pfVtq0GiX5fstJjH66ypgZ+Vvl8=", - "dev": true, - "requires": { - "babel-helper-function-name": "^6.24.1", - "babel-runtime": "^6.26.0", - "babel-types": "^6.26.0", - "lodash": "^4.17.4" - } - }, - "babel-helper-explode-assignable-expression": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-explode-assignable-expression/-/babel-helper-explode-assignable-expression-6.24.1.tgz", - "integrity": "sha1-8luCz33BBDPFX3BZLVdGQArCLKo=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-helper-explode-class": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-explode-class/-/babel-helper-explode-class-6.24.1.tgz", - "integrity": "sha1-fcKjkQ3uAHBW4eMdZAztPVTqqes=", - "dev": true, - "requires": { - "babel-helper-bindify-decorators": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-helper-function-name": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", - "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", - "dev": true, - "requires": { - "babel-helper-get-function-arity": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-helper-get-function-arity": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", - "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-helper-hoist-variables": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz", - "integrity": "sha1-HssnaJydJVE+rbyZFKc/VAi+enY=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-helper-optimise-call-expression": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz", - "integrity": "sha1-96E0J7qfc/j0+pk8VKl4gtEkQlc=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-helper-regex": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz", - "integrity": "sha1-MlxZ+QL4LyS3T6zu0DY5VPZJXnI=", - "dev": true, - "requires": { - "babel-runtime": "^6.26.0", - "babel-types": "^6.26.0", - "lodash": "^4.17.4" - } - }, - "babel-helper-remap-async-to-generator": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-remap-async-to-generator/-/babel-helper-remap-async-to-generator-6.24.1.tgz", - "integrity": "sha1-XsWBgnrXI/7N04HxySg5BnbkVRs=", - "dev": true, - "requires": { - "babel-helper-function-name": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-helper-replace-supers": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz", - "integrity": "sha1-v22/5Dk40XNpohPKiov3S2qQqxo=", - "dev": true, - "requires": { - "babel-helper-optimise-call-expression": "^6.24.1", - "babel-messages": "^6.23.0", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-helpers": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-helpers/-/babel-helpers-6.24.1.tgz", - "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1" - } - }, - "babel-loader": { - "version": "7.1.5", - "resolved": "https://npm-registry.sipwise.com/babel-loader/-/babel-loader-7.1.5.tgz", - "integrity": "sha1-4+4M1zlKpVfgE7AtPkkr/QeqbWg=", - "dev": true, - "requires": { - "find-cache-dir": "^1.0.0", - "loader-utils": "^1.0.2", - "mkdirp": "^0.5.1" - } - }, - "babel-messages": { - "version": "6.23.0", - "resolved": "https://npm-registry.sipwise.com/babel-messages/-/babel-messages-6.23.0.tgz", - "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-check-es2015-constants": { - "version": "6.22.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz", - "integrity": "sha1-NRV7EBQm/S/9PaP3XH0ekYNbv4o=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-syntax-async-functions": { - "version": "6.13.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz", - "integrity": "sha1-ytnK0RkbWtY0vzCuCHI5HgZHvpU=", - "dev": true - }, - "babel-plugin-syntax-async-generators": { - "version": "6.13.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-async-generators/-/babel-plugin-syntax-async-generators-6.13.0.tgz", - "integrity": "sha1-a8lj67FuzLrmuStZbrfzXDQqi5o=", - "dev": true - }, - "babel-plugin-syntax-class-properties": { - "version": "6.13.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-class-properties/-/babel-plugin-syntax-class-properties-6.13.0.tgz", - "integrity": "sha1-1+sjt5oxf4VDlixQW4J8fWysJ94=", - "dev": true - }, - "babel-plugin-syntax-decorators": { - "version": "6.13.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-decorators/-/babel-plugin-syntax-decorators-6.13.0.tgz", - "integrity": "sha1-MSVjtNvePMgGzuPkFszurd0RrAs=", - "dev": true - }, - "babel-plugin-syntax-dynamic-import": { - "version": "6.18.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-dynamic-import/-/babel-plugin-syntax-dynamic-import-6.18.0.tgz", - "integrity": "sha1-jWomIpyDdFqZgqRBBRVyyqF5sdo=", - "dev": true - }, - "babel-plugin-syntax-exponentiation-operator": { - "version": "6.13.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-exponentiation-operator/-/babel-plugin-syntax-exponentiation-operator-6.13.0.tgz", - "integrity": "sha1-nufoM3KQ2pUoggGmpX9BcDF4MN4=", - "dev": true - }, - "babel-plugin-syntax-object-rest-spread": { - "version": "6.13.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", - "integrity": "sha1-/WU28rzhODb/o6VFjEkDpZe7O/U=", - "dev": true - }, - "babel-plugin-syntax-trailing-function-commas": { - "version": "6.22.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-syntax-trailing-function-commas/-/babel-plugin-syntax-trailing-function-commas-6.22.0.tgz", - "integrity": "sha1-ugNgk3+NBuQBgKQ/4NVhb/9TLPM=", - "dev": true - }, - "babel-plugin-transform-async-generator-functions": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-async-generator-functions/-/babel-plugin-transform-async-generator-functions-6.24.1.tgz", - "integrity": "sha1-8FiQAUX9PpkHpt3yjaWfIVJYpds=", - "dev": true, - "requires": { - "babel-helper-remap-async-to-generator": "^6.24.1", - "babel-plugin-syntax-async-generators": "^6.5.0", - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-async-to-generator": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-async-to-generator/-/babel-plugin-transform-async-to-generator-6.24.1.tgz", - "integrity": "sha1-ZTbjeK/2yx1VF6wOQOs+n8jQh2E=", - "dev": true, - "requires": { - "babel-helper-remap-async-to-generator": "^6.24.1", - "babel-plugin-syntax-async-functions": "^6.8.0", - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-class-properties": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-class-properties/-/babel-plugin-transform-class-properties-6.24.1.tgz", - "integrity": "sha1-anl2PqYdM9NvN7YRqp3vgagbRqw=", - "dev": true, - "requires": { - "babel-helper-function-name": "^6.24.1", - "babel-plugin-syntax-class-properties": "^6.8.0", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1" - } - }, - "babel-plugin-transform-decorators": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-decorators/-/babel-plugin-transform-decorators-6.24.1.tgz", - "integrity": "sha1-eIAT2PjGtSIr33s0Q5Df13Vp4k0=", - "dev": true, - "requires": { - "babel-helper-explode-class": "^6.24.1", - "babel-plugin-syntax-decorators": "^6.13.0", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-arrow-functions": { - "version": "6.22.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz", - "integrity": "sha1-RSaSy3EdX3ncf4XkQM5BufJE0iE=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-block-scoped-functions": { - "version": "6.22.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz", - "integrity": "sha1-u8UbSflk1wy42OC5ToICRs46YUE=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-block-scoping": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz", - "integrity": "sha1-1w9SmcEwjQXBL0Y4E7CgnnOxiV8=", - "dev": true, - "requires": { - "babel-runtime": "^6.26.0", - "babel-template": "^6.26.0", - "babel-traverse": "^6.26.0", - "babel-types": "^6.26.0", - "lodash": "^4.17.4" - } - }, - "babel-plugin-transform-es2015-classes": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz", - "integrity": "sha1-WkxYpQyclGHlZLSyo7+ryXolhNs=", - "dev": true, - "requires": { - "babel-helper-define-map": "^6.24.1", - "babel-helper-function-name": "^6.24.1", - "babel-helper-optimise-call-expression": "^6.24.1", - "babel-helper-replace-supers": "^6.24.1", - "babel-messages": "^6.23.0", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-computed-properties": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz", - "integrity": "sha1-b+Ko0WiV1WNPTNmZttNICjCBWbM=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-destructuring": { - "version": "6.23.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz", - "integrity": "sha1-mXux8auWf2gtKwh2/jWNYOdlxW0=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-duplicate-keys": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz", - "integrity": "sha1-c+s9MQypaePvnskcU3QabxV2Qj4=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-for-of": { - "version": "6.23.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz", - "integrity": "sha1-9HyVsrYT3x0+zC/bdXNiPHUkhpE=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-function-name": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz", - "integrity": "sha1-g0yJhTvDaxrw86TF26qU/Y6sqos=", - "dev": true, - "requires": { - "babel-helper-function-name": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-literals": { - "version": "6.22.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz", - "integrity": "sha1-T1SgLWzWbPkVKAAZox0xklN3yi4=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-modules-amd": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz", - "integrity": "sha1-Oz5UAXI5hC1tGcMBHEvS8AoA0VQ=", - "dev": true, - "requires": { - "babel-plugin-transform-es2015-modules-commonjs": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-modules-commonjs": { - "version": "6.26.2", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.2.tgz", - "integrity": "sha1-WKeThjqefKhwvcWogRF/+sJ9tvM=", - "dev": true, - "requires": { - "babel-plugin-transform-strict-mode": "^6.24.1", - "babel-runtime": "^6.26.0", - "babel-template": "^6.26.0", - "babel-types": "^6.26.0" - } - }, - "babel-plugin-transform-es2015-modules-systemjs": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz", - "integrity": "sha1-/4mhQrkRmpBhlfXxBuzzBdlAfSM=", - "dev": true, - "requires": { - "babel-helper-hoist-variables": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-modules-umd": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz", - "integrity": "sha1-rJl+YoXNGO1hdq22B9YCNErThGg=", - "dev": true, - "requires": { - "babel-plugin-transform-es2015-modules-amd": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-object-super": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz", - "integrity": "sha1-JM72muIcuDp/hgPa0CH1cusnj40=", - "dev": true, - "requires": { - "babel-helper-replace-supers": "^6.24.1", - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-parameters": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz", - "integrity": "sha1-V6w1GrScrxSpfNE7CfZv3wpiXys=", - "dev": true, - "requires": { - "babel-helper-call-delegate": "^6.24.1", - "babel-helper-get-function-arity": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-template": "^6.24.1", - "babel-traverse": "^6.24.1", - "babel-types": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-shorthand-properties": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz", - "integrity": "sha1-JPh11nIch2YbvZmkYi5R8U3jiqA=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-spread": { - "version": "6.22.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz", - "integrity": "sha1-1taKmfia7cRTbIGlQujdnxdG+NE=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-sticky-regex": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz", - "integrity": "sha1-AMHNsaynERLN8M9hJsLta0V8zbw=", - "dev": true, - "requires": { - "babel-helper-regex": "^6.24.1", - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-plugin-transform-es2015-template-literals": { - "version": "6.22.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz", - "integrity": "sha1-qEs0UPfp+PH2g51taH2oS7EjbY0=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-typeof-symbol": { - "version": "6.23.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz", - "integrity": "sha1-3sCfHN3/lLUqxz1QXITfWdzOs3I=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-es2015-unicode-regex": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz", - "integrity": "sha1-04sS9C6nMj9yk4fxinxa4frrNek=", - "dev": true, - "requires": { - "babel-helper-regex": "^6.24.1", - "babel-runtime": "^6.22.0", - "regexpu-core": "^2.0.0" - } - }, - "babel-plugin-transform-exponentiation-operator": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-exponentiation-operator/-/babel-plugin-transform-exponentiation-operator-6.24.1.tgz", - "integrity": "sha1-KrDJx/MJj6SJB3cruBP+QejeOg4=", - "dev": true, - "requires": { - "babel-helper-builder-binary-assignment-operator-visitor": "^6.24.1", - "babel-plugin-syntax-exponentiation-operator": "^6.8.0", - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-object-rest-spread": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.26.0.tgz", - "integrity": "sha1-DzZpLVD+9rfi1LOsFHgTepY7ewY=", - "dev": true, - "requires": { - "babel-plugin-syntax-object-rest-spread": "^6.8.0", - "babel-runtime": "^6.26.0" - } - }, - "babel-plugin-transform-regenerator": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz", - "integrity": "sha1-4HA2lvveJ/Cj78rPi03KL3s6jy8=", - "dev": true, - "requires": { - "regenerator-transform": "^0.10.0" - } - }, - "babel-plugin-transform-runtime": { - "version": "6.23.0", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-runtime/-/babel-plugin-transform-runtime-6.23.0.tgz", - "integrity": "sha1-iEkNRGUC6puOfvsP4J7E2ZR5se4=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0" - } - }, - "babel-plugin-transform-strict-mode": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz", - "integrity": "sha1-1fr3qleKZbvlkc9e2uBKDGcCB1g=", - "dev": true, - "requires": { - "babel-runtime": "^6.22.0", - "babel-types": "^6.24.1" - } - }, - "babel-preset-es2015": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-preset-es2015/-/babel-preset-es2015-6.24.1.tgz", - "integrity": "sha1-1EBQ1rwsn+6nAqrzjXJ6AhBTiTk=", - "dev": true, - "requires": { - "babel-plugin-check-es2015-constants": "^6.22.0", - "babel-plugin-transform-es2015-arrow-functions": "^6.22.0", - "babel-plugin-transform-es2015-block-scoped-functions": "^6.22.0", - "babel-plugin-transform-es2015-block-scoping": "^6.24.1", - "babel-plugin-transform-es2015-classes": "^6.24.1", - "babel-plugin-transform-es2015-computed-properties": "^6.24.1", - "babel-plugin-transform-es2015-destructuring": "^6.22.0", - "babel-plugin-transform-es2015-duplicate-keys": "^6.24.1", - "babel-plugin-transform-es2015-for-of": "^6.22.0", - "babel-plugin-transform-es2015-function-name": "^6.24.1", - "babel-plugin-transform-es2015-literals": "^6.22.0", - "babel-plugin-transform-es2015-modules-amd": "^6.24.1", - "babel-plugin-transform-es2015-modules-commonjs": "^6.24.1", - "babel-plugin-transform-es2015-modules-systemjs": "^6.24.1", - "babel-plugin-transform-es2015-modules-umd": "^6.24.1", - "babel-plugin-transform-es2015-object-super": "^6.24.1", - "babel-plugin-transform-es2015-parameters": "^6.24.1", - "babel-plugin-transform-es2015-shorthand-properties": "^6.24.1", - "babel-plugin-transform-es2015-spread": "^6.22.0", - "babel-plugin-transform-es2015-sticky-regex": "^6.24.1", - "babel-plugin-transform-es2015-template-literals": "^6.22.0", - "babel-plugin-transform-es2015-typeof-symbol": "^6.22.0", - "babel-plugin-transform-es2015-unicode-regex": "^6.24.1", - "babel-plugin-transform-regenerator": "^6.24.1" - } - }, - "babel-preset-stage-2": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-preset-stage-2/-/babel-preset-stage-2-6.24.1.tgz", - "integrity": "sha1-2eKWD7PXEYfw5k7sYrwHdnIZvcE=", - "dev": true, - "requires": { - "babel-plugin-syntax-dynamic-import": "^6.18.0", - "babel-plugin-transform-class-properties": "^6.24.1", - "babel-plugin-transform-decorators": "^6.24.1", - "babel-preset-stage-3": "^6.24.1" - } - }, - "babel-preset-stage-3": { - "version": "6.24.1", - "resolved": "https://npm-registry.sipwise.com/babel-preset-stage-3/-/babel-preset-stage-3-6.24.1.tgz", - "integrity": "sha1-g2raCp56f6N8sTj7kyb4eTSkg5U=", - "dev": true, - "requires": { - "babel-plugin-syntax-trailing-function-commas": "^6.22.0", - "babel-plugin-transform-async-generator-functions": "^6.24.1", - "babel-plugin-transform-async-to-generator": "^6.24.1", - "babel-plugin-transform-exponentiation-operator": "^6.24.1", - "babel-plugin-transform-object-rest-spread": "^6.22.0" - } - }, - "babel-register": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-register/-/babel-register-6.26.0.tgz", - "integrity": "sha1-btAhFz4vy0htestFxgCahW9kcHE=", - "dev": true, - "requires": { - "babel-core": "^6.26.0", - "babel-runtime": "^6.26.0", - "core-js": "^2.5.0", - "home-or-tmp": "^2.0.0", - "lodash": "^4.17.4", - "mkdirp": "^0.5.1", - "source-map-support": "^0.4.15" - } - }, - "babel-runtime": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-runtime/-/babel-runtime-6.26.0.tgz", - "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", - "requires": { - "core-js": "^2.4.0", - "regenerator-runtime": "^0.11.0" - } - }, - "babel-template": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-template/-/babel-template-6.26.0.tgz", - "integrity": "sha1-3gPi0WOWsGn0bdn/+FIfsaDjXgI=", - "dev": true, - "requires": { - "babel-runtime": "^6.26.0", - "babel-traverse": "^6.26.0", - "babel-types": "^6.26.0", - "babylon": "^6.18.0", - "lodash": "^4.17.4" - } - }, - "babel-traverse": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-traverse/-/babel-traverse-6.26.0.tgz", - "integrity": "sha1-RqnL1+3MYsjlwGTi0tjQ9ANXZu4=", - "dev": true, - "requires": { - "babel-code-frame": "^6.26.0", - "babel-messages": "^6.23.0", - "babel-runtime": "^6.26.0", - "babel-types": "^6.26.0", - "babylon": "^6.18.0", - "debug": "^2.6.8", - "globals": "^9.18.0", - "invariant": "^2.2.2", - "lodash": "^4.17.4" - } - }, - "babel-types": { - "version": "6.26.0", - "resolved": "https://npm-registry.sipwise.com/babel-types/-/babel-types-6.26.0.tgz", - "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=", - "dev": true, - "requires": { - "babel-runtime": "^6.26.0", - "esutils": "^2.0.2", - "lodash": "^4.17.4", - "to-fast-properties": "^1.0.3" - } - }, - "babylon": { - "version": "6.18.0", - "resolved": "https://npm-registry.sipwise.com/babylon/-/babylon-6.18.0.tgz", - "integrity": "sha1-ry87iPpvXB5MY00aD46sT1WzleM=", - "dev": true - }, - "backo2": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/backo2/-/backo2-1.0.2.tgz", - "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=", - "dev": true - }, - "balanced-match": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/balanced-match/-/balanced-match-1.0.0.tgz", - "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", - "dev": true - }, - "base": { - "version": "0.11.2", - "resolved": "https://npm-registry.sipwise.com/base/-/base-0.11.2.tgz", - "integrity": "sha1-e95c7RRbbVUakNuH+DxVi060io8=", - "dev": true, - "requires": { - "cache-base": "^1.0.1", - "class-utils": "^0.3.5", - "component-emitter": "^1.2.1", - "define-property": "^1.0.0", - "isobject": "^3.0.1", - "mixin-deep": "^1.2.0", - "pascalcase": "^0.1.1" - }, - "dependencies": { - "component-emitter": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/component-emitter/-/component-emitter-1.2.1.tgz", - "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", - "dev": true - }, - "define-property": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", - "dev": true, - "requires": { - "is-descriptor": "^1.0.0" - } - }, - "is-accessor-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha1-FpwvbT3x+ZJhgHI2XJsOofaHhlY=", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-data-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha1-2Eh2Mh0Oet0DmQQGq7u9NrqSaMc=", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-descriptor": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha1-OxWXRqZmBLBPjIFSS6NlxfFNhuw=", - "dev": true, - "requires": { - "is-accessor-descriptor": "^1.0.0", - "is-data-descriptor": "^1.0.0", - "kind-of": "^6.0.2" - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, - "kind-of": { - "version": "6.0.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - } - } - }, - "base64-arraybuffer": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz", - "integrity": "sha1-c5JncZI7Whl0etZmqlzUv5xunOg=", - "dev": true - }, - "base64-js": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/base64-js/-/base64-js-1.3.0.tgz", - "integrity": "sha512-ccav/yGvoa80BQDljCxsmmQ3Xvx60/UpBIij5QN21W3wBi/hhIC9OoO+KLpu9IJTS9j4DRVJ3aDDF9cMSoa2lw==", - "dev": true - }, - "base64id": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/base64id/-/base64id-1.0.0.tgz", - "integrity": "sha1-R2iMuZu2gE8OBtPnY7HDLlfY5rY=", - "dev": true - }, - "better-assert": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/better-assert/-/better-assert-1.0.2.tgz", - "integrity": "sha1-QIZrnhueC1W0gYlDEeaPr/rrxSI=", - "dev": true, - "requires": { - "callsite": "1.0.0" - } - }, - "bezier-easing": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/bezier-easing/-/bezier-easing-2.1.0.tgz", - "integrity": "sha1-wE3+i5JtbsrKGBPWn/F5t8ICXYY=", - "dev": true - }, - "big.js": { - "version": "3.2.0", - "resolved": "https://npm-registry.sipwise.com/big.js/-/big.js-3.2.0.tgz", - "integrity": "sha512-+hN/Zh2D08Mx65pZ/4g5bsmNiZUuChDiQfTUQ7qJr4/kuopCr88xZsAXv6mBoZEsUI4OuGHlX59qE94K2mMW8Q==", - "dev": true - }, - "binary-extensions": { - "version": "1.11.0", - "resolved": "https://npm-registry.sipwise.com/binary-extensions/-/binary-extensions-1.11.0.tgz", - "integrity": "sha1-RqoXUftqL5PuXmibsQh9SxTGwgU=", - "dev": true - }, - "blob": { - "version": "0.0.4", - "resolved": "https://npm-registry.sipwise.com/blob/-/blob-0.0.4.tgz", - "integrity": "sha1-vPEwUspURj8w+fx+lbmkdjCpSSE=", - "dev": true - }, - "bluebird": { - "version": "3.5.1", - "resolved": "https://npm-registry.sipwise.com/bluebird/-/bluebird-3.5.1.tgz", - "integrity": "sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA==", - "dev": true - }, - "bn.js": { - "version": "4.11.8", - "resolved": "https://npm-registry.sipwise.com/bn.js/-/bn.js-4.11.8.tgz", - "integrity": "sha1-LN4J617jQfSEdGuwMJsyU7GxRC8=", - "dev": true - }, - "body-parser": { - "version": "1.18.2", - "resolved": "https://npm-registry.sipwise.com/body-parser/-/body-parser-1.18.2.tgz", - "integrity": "sha1-h2eKGdhLR9hZuDGZvVm84iKxBFQ=", - "dev": true, - "requires": { - "bytes": "3.0.0", - "content-type": "~1.0.4", - "debug": "2.6.9", - "depd": "~1.1.1", - "http-errors": "~1.6.2", - "iconv-lite": "0.4.19", - "on-finished": "~2.3.0", - "qs": "6.5.1", - "raw-body": "2.3.2", - "type-is": "~1.6.15" - }, - "dependencies": { - "iconv-lite": { - "version": "0.4.19", - "resolved": "https://npm-registry.sipwise.com/iconv-lite/-/iconv-lite-0.4.19.tgz", - "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==", - "dev": true - } - } - }, - "boolbase": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/boolbase/-/boolbase-1.0.0.tgz", - "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=", - "dev": true - }, - "brace-expansion": { - "version": "1.1.11", - "resolved": "https://npm-registry.sipwise.com/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha1-PH/L9SnYcibz0vUrlm/1Jx60Qd0=", - "dev": true, - "requires": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "braces": { - "version": "1.8.5", - "resolved": "https://npm-registry.sipwise.com/braces/-/braces-1.8.5.tgz", - "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", - "dev": true, - "requires": { - "expand-range": "^1.8.1", - "preserve": "^0.2.0", - "repeat-element": "^1.1.2" - } - }, - "brorand": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/brorand/-/brorand-1.1.0.tgz", - "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=", - "dev": true - }, - "browser-stdout": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/browser-stdout/-/browser-stdout-1.3.0.tgz", - "integrity": "sha1-81HTKWnTL6XXpVZxVCY9korjvR8=", - "dev": true - }, - "browserify-aes": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/browserify-aes/-/browserify-aes-1.2.0.tgz", - "integrity": "sha1-Mmc0ZC9APavDADIJhTu3CtQo70g=", - "dev": true, - "requires": { - "buffer-xor": "^1.0.3", - "cipher-base": "^1.0.0", - "create-hash": "^1.1.0", - "evp_bytestokey": "^1.0.3", - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "browserify-cipher": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/browserify-cipher/-/browserify-cipher-1.0.1.tgz", - "integrity": "sha1-jWR0wbhwv9q807z8wZNKEOlPFfA=", - "dev": true, - "requires": { - "browserify-aes": "^1.0.4", - "browserify-des": "^1.0.0", - "evp_bytestokey": "^1.0.0" - } - }, - "browserify-des": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/browserify-des/-/browserify-des-1.0.2.tgz", - "integrity": "sha1-OvTx9Zg5QDVy8cZiBDdfen9wPpw=", - "dev": true, - "requires": { - "cipher-base": "^1.0.1", - "des.js": "^1.0.0", - "inherits": "^2.0.1", - "safe-buffer": "^5.1.2" - } - }, - "browserify-rsa": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/browserify-rsa/-/browserify-rsa-4.0.1.tgz", - "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=", - "dev": true, - "requires": { - "bn.js": "^4.1.0", - "randombytes": "^2.0.1" - } - }, - "browserify-sign": { - "version": "4.0.4", - "resolved": "https://npm-registry.sipwise.com/browserify-sign/-/browserify-sign-4.0.4.tgz", - "integrity": "sha1-qk62jl17ZYuqa/alfmMMvXqT0pg=", - "dev": true, - "requires": { - "bn.js": "^4.1.1", - "browserify-rsa": "^4.0.0", - "create-hash": "^1.1.0", - "create-hmac": "^1.1.2", - "elliptic": "^6.0.0", - "inherits": "^2.0.1", - "parse-asn1": "^5.0.0" - } - }, - "browserify-zlib": { - "version": "0.2.0", - "resolved": "https://npm-registry.sipwise.com/browserify-zlib/-/browserify-zlib-0.2.0.tgz", - "integrity": "sha1-KGlFnZqjviRf6P4sofRuLn9U1z8=", - "dev": true, - "requires": { - "pako": "~1.0.5" - } - }, - "browserslist": { - "version": "1.7.7", - "resolved": "https://npm-registry.sipwise.com/browserslist/-/browserslist-1.7.7.tgz", - "integrity": "sha1-C9dnBCWL6CmyOYu1Dkti0aFmsLk=", - "dev": true, - "requires": { - "caniuse-db": "^1.0.30000639", - "electron-to-chromium": "^1.2.7" - } - }, - "buffer": { - "version": "4.9.1", - "resolved": "https://npm-registry.sipwise.com/buffer/-/buffer-4.9.1.tgz", - "integrity": "sha1-bRu2AbB6TvztlwlBMgkwJ8lbwpg=", - "dev": true, - "requires": { - "base64-js": "^1.0.2", - "ieee754": "^1.1.4", - "isarray": "^1.0.0" - } - }, - "buffer-from": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/buffer-from/-/buffer-from-1.1.0.tgz", - "integrity": "sha512-c5mRlguI/Pe2dSZmpER62rSCu0ryKmWddzRYsuXc50U2/g8jMOulc31VZMa4mYx31U5xsmSOpDCgH88Vl9cDGQ==", - "dev": true - }, - "buffer-xor": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/buffer-xor/-/buffer-xor-1.0.3.tgz", - "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=", - "dev": true - }, - "builtin-modules": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/builtin-modules/-/builtin-modules-1.1.1.tgz", - "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", - "dev": true - }, - "builtin-status-codes": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", - "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=", - "dev": true - }, - "bytes": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/bytes/-/bytes-3.0.0.tgz", - "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=", - "dev": true - }, - "cache-base": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/cache-base/-/cache-base-1.0.1.tgz", - "integrity": "sha1-Cn9GQWgxyLZi7jb+TnxZ129marI=", - "dev": true, - "requires": { - "collection-visit": "^1.0.0", - "component-emitter": "^1.2.1", - "get-value": "^2.0.6", - "has-value": "^1.0.0", - "isobject": "^3.0.1", - "set-value": "^2.0.0", - "to-object-path": "^0.3.0", - "union-value": "^1.0.0", - "unset-value": "^1.0.0" - }, - "dependencies": { - "component-emitter": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/component-emitter/-/component-emitter-1.2.1.tgz", - "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", - "dev": true - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "caller-path": { - "version": "0.1.0", - "resolved": "https://npm-registry.sipwise.com/caller-path/-/caller-path-0.1.0.tgz", - "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", - "dev": true, - "requires": { - "callsites": "^0.2.0" - } - }, - "callsite": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/callsite/-/callsite-1.0.0.tgz", - "integrity": "sha1-KAOY5dZkvXQDi28JBRU+borxvCA=", - "dev": true - }, - "callsites": { - "version": "0.2.0", - "resolved": "https://npm-registry.sipwise.com/callsites/-/callsites-0.2.0.tgz", - "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", - "dev": true - }, - "camel-case": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/camel-case/-/camel-case-3.0.0.tgz", - "integrity": "sha1-yjw2iKTpzzpM2nd9xNy8cTJJz3M=", - "dev": true, - "requires": { - "no-case": "^2.2.0", - "upper-case": "^1.1.1" - } - }, - "camelcase": { - "version": "4.1.0", - "resolved": "https://npm-registry.sipwise.com/camelcase/-/camelcase-4.1.0.tgz", - "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", - "dev": true - }, - "caniuse-api": { - "version": "1.6.1", - "resolved": "https://npm-registry.sipwise.com/caniuse-api/-/caniuse-api-1.6.1.tgz", - "integrity": "sha1-tTTnxzTE+B7F++isoq0kNUuWLGw=", - "dev": true, - "requires": { - "browserslist": "^1.3.6", - "caniuse-db": "^1.0.30000529", - "lodash.memoize": "^4.1.2", - "lodash.uniq": "^4.5.0" - } - }, - "caniuse-db": { - "version": "1.0.30000871", - "resolved": "https://npm-registry.sipwise.com/caniuse-db/-/caniuse-db-1.0.30000871.tgz", - "integrity": "sha1-8ZlcH+MYkmSadgWVeoDJJRhCPU0=", - "dev": true - }, - "center-align": { - "version": "0.1.3", - "resolved": "https://npm-registry.sipwise.com/center-align/-/center-align-0.1.3.tgz", - "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", - "dev": true, - "requires": { - "align-text": "^0.1.3", - "lazy-cache": "^1.0.3" - } - }, - "chai": { - "version": "4.1.2", - "resolved": "https://npm-registry.sipwise.com/chai/-/chai-4.1.2.tgz", - "integrity": "sha1-D2RYS6ZC8PKs4oBiefTwbKI61zw=", - "dev": true, - "requires": { - "assertion-error": "^1.0.1", - "check-error": "^1.0.1", - "deep-eql": "^3.0.0", - "get-func-name": "^2.0.0", - "pathval": "^1.0.0", - "type-detect": "^4.0.0" - } - }, - "chalk": { - "version": "1.1.3", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-1.1.3.tgz", - "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", - "dev": true, - "requires": { - "ansi-styles": "^2.2.1", - "escape-string-regexp": "^1.0.2", - "has-ansi": "^2.0.0", - "strip-ansi": "^3.0.0", - "supports-color": "^2.0.0" - }, - "dependencies": { - "supports-color": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-2.0.0.tgz", - "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", - "dev": true - } - } - }, - "chardet": { - "version": "0.4.2", - "resolved": "https://npm-registry.sipwise.com/chardet/-/chardet-0.4.2.tgz", - "integrity": "sha1-tUc7M9yXxCTl2Y3IfVXU2KKci/I=", - "dev": true - }, - "check-error": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/check-error/-/check-error-1.0.2.tgz", - "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", - "dev": true - }, - "chokidar": { - "version": "1.7.0", - "resolved": "https://npm-registry.sipwise.com/chokidar/-/chokidar-1.7.0.tgz", - "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", - "dev": true, - "requires": { - "anymatch": "^1.3.0", - "async-each": "^1.0.0", - "fsevents": "^1.0.0", - "glob-parent": "^2.0.0", - "inherits": "^2.0.1", - "is-binary-path": "^1.0.0", - "is-glob": "^2.0.0", - "path-is-absolute": "^1.0.0", - "readdirp": "^2.0.0" - }, - "dependencies": { - "is-extglob": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", - "dev": true - }, - "is-glob": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-2.0.1.tgz", - "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - } - } - } - }, - "chownr": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/chownr/-/chownr-1.1.2.tgz", - "integrity": "sha512-GkfeAQh+QNy3wquu9oIZr6SS5x7wGdSgNQvD10X3r+AZr1Oys22HW8kAmDMvNg2+Dm0TeGaEuO8gFwdBXxwO8A==", - "dev": true, - "optional": true - }, - "cipher-base": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/cipher-base/-/cipher-base-1.0.4.tgz", - "integrity": "sha1-h2Dk7MJy9MNjUy+SbYdKriwTl94=", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "circular-json": { - "version": "0.3.3", - "resolved": "https://npm-registry.sipwise.com/circular-json/-/circular-json-0.3.3.tgz", - "integrity": "sha1-gVyZ6oT2gJUp0vRXkb34JxE1LWY=", - "dev": true - }, - "clap": { - "version": "1.2.3", - "resolved": "https://npm-registry.sipwise.com/clap/-/clap-1.2.3.tgz", - "integrity": "sha1-TzZ0WzIAhJJVf0ZBLWbVDLmbzlE=", - "dev": true, - "requires": { - "chalk": "^1.1.3" - } - }, - "class-utils": { - "version": "0.3.6", - "resolved": "https://npm-registry.sipwise.com/class-utils/-/class-utils-0.3.6.tgz", - "integrity": "sha1-+TNprouafOAv1B+q0MqDAzGQxGM=", - "dev": true, - "requires": { - "arr-union": "^3.1.0", - "define-property": "^0.2.5", - "isobject": "^3.0.0", - "static-extend": "^0.1.1" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "clean-css": { - "version": "4.1.11", - "resolved": "https://npm-registry.sipwise.com/clean-css/-/clean-css-4.1.11.tgz", - "integrity": "sha1-Ls3xRaujj1R0DybO/Q/z4D4SXWo=", - "dev": true, - "requires": { - "source-map": "0.5.x" - } - }, - "cli-cursor": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/cli-cursor/-/cli-cursor-2.1.0.tgz", - "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", - "dev": true, - "requires": { - "restore-cursor": "^2.0.0" - } - }, - "cli-width": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/cli-width/-/cli-width-2.2.0.tgz", - "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", - "dev": true - }, - "cliui": { - "version": "3.2.0", - "resolved": "https://npm-registry.sipwise.com/cliui/-/cliui-3.2.0.tgz", - "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", - "dev": true, - "requires": { - "string-width": "^1.0.1", - "strip-ansi": "^3.0.1", - "wrap-ansi": "^2.0.0" - }, - "dependencies": { - "is-fullwidth-code-point": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", - "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", - "dev": true, - "requires": { - "number-is-nan": "^1.0.0" - } - }, - "string-width": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/string-width/-/string-width-1.0.2.tgz", - "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", - "dev": true, - "requires": { - "code-point-at": "^1.0.0", - "is-fullwidth-code-point": "^1.0.0", - "strip-ansi": "^3.0.0" - } - } - } - }, - "clone": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/clone/-/clone-1.0.4.tgz", - "integrity": "sha1-2jCcwmPfFZlMaIypAheco8fNfH4=", - "dev": true - }, - "co": { - "version": "4.6.0", - "resolved": "https://npm-registry.sipwise.com/co/-/co-4.6.0.tgz", - "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", - "dev": true - }, - "coa": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/coa/-/coa-1.0.4.tgz", - "integrity": "sha1-qe8VNmDWqGqL3sAomlxoTSF0Mv0=", - "dev": true, - "requires": { - "q": "^1.1.2" - } - }, - "coalescy": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/coalescy/-/coalescy-1.0.0.tgz", - "integrity": "sha1-SwZYRrg2NhrabEtKSr9LwcrDG/E=", - "dev": true - }, - "code-point-at": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/code-point-at/-/code-point-at-1.1.0.tgz", - "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", - "dev": true - }, - "collection-visit": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/collection-visit/-/collection-visit-1.0.0.tgz", - "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", - "dev": true, - "requires": { - "map-visit": "^1.0.0", - "object-visit": "^1.0.0" - } - }, - "color": { - "version": "0.11.4", - "resolved": "https://npm-registry.sipwise.com/color/-/color-0.11.4.tgz", - "integrity": "sha1-bXtcdPtl6EHNSHkq0e1eB7kE12Q=", - "dev": true, - "requires": { - "clone": "^1.0.2", - "color-convert": "^1.3.0", - "color-string": "^0.3.0" - } - }, - "color-convert": { - "version": "1.9.2", - "resolved": "https://npm-registry.sipwise.com/color-convert/-/color-convert-1.9.2.tgz", - "integrity": "sha512-3NUJZdhMhcdPn8vJ9v2UQJoH0qqoGUkYTgFEPZaPjEtwmmKUfNV46zZmgB2M5M4DCEQHMaCfWHCxiBflLm04Tg==", - "dev": true, - "requires": { - "color-name": "1.1.1" - } - }, - "color-name": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/color-name/-/color-name-1.1.1.tgz", - "integrity": "sha1-SxQVMEz1ACjqgWQ2Q72C6gWANok=", - "dev": true - }, - "color-string": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/color-string/-/color-string-0.3.0.tgz", - "integrity": "sha1-J9RvtnAlxcL6JZk7+/V55HhBuZE=", - "dev": true, - "requires": { - "color-name": "^1.0.0" - } - }, - "colormin": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/colormin/-/colormin-1.1.2.tgz", - "integrity": "sha1-6i90IKcrlogaOKrlnsEkpvcpgTM=", - "dev": true, - "requires": { - "color": "^0.11.0", - "css-color-names": "0.0.4", - "has": "^1.0.1" - } - }, - "colors": { - "version": "1.3.1", - "resolved": "https://npm-registry.sipwise.com/colors/-/colors-1.3.1.tgz", - "integrity": "sha512-jg/vxRmv430jixZrC+La5kMbUWqIg32/JsYNZb94+JEmzceYbWKTsv1OuTp+7EaqiaWRR2tPcykibwCRgclIsw==", - "dev": true - }, - "combine-lists": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/combine-lists/-/combine-lists-1.0.1.tgz", - "integrity": "sha1-RYwH4J4NkA/Ci3Cj/sLazR0st/Y=", - "dev": true, - "requires": { - "lodash": "^4.5.0" - } - }, - "commander": { - "version": "2.16.0", - "resolved": "https://npm-registry.sipwise.com/commander/-/commander-2.16.0.tgz", - "integrity": "sha512-sVXqklSaotK9at437sFlFpyOcJonxe0yST/AG9DkQKUdIE6IqGIMv4SfAQSKaJbSdVEJYItASCrBiVQHq1HQew==", - "dev": true - }, - "commondir": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/commondir/-/commondir-1.0.1.tgz", - "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", - "dev": true - }, - "component-bind": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/component-bind/-/component-bind-1.0.0.tgz", - "integrity": "sha1-AMYIq33Nk4l8AAllGx06jh5zu9E=", - "dev": true - }, - "component-emitter": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/component-emitter/-/component-emitter-1.1.2.tgz", - "integrity": "sha1-KWWU8nU9qmOZbSrwjRWpURbJrsM=", - "dev": true - }, - "component-inherit": { - "version": "0.0.3", - "resolved": "https://npm-registry.sipwise.com/component-inherit/-/component-inherit-0.0.3.tgz", - "integrity": "sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM=", - "dev": true - }, - "concat-map": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", - "dev": true - }, - "concat-stream": { - "version": "1.6.2", - "resolved": "https://npm-registry.sipwise.com/concat-stream/-/concat-stream-1.6.2.tgz", - "integrity": "sha1-kEvfGUzTEi/Gdcd/xKw9T/D9GjQ=", - "dev": true, - "requires": { - "buffer-from": "^1.0.0", - "inherits": "^2.0.3", - "readable-stream": "^2.2.2", - "typedarray": "^0.0.6" - } - }, - "connect": { - "version": "3.6.6", - "resolved": "https://npm-registry.sipwise.com/connect/-/connect-3.6.6.tgz", - "integrity": "sha1-Ce/2xVr3I24TcTWnJXSFi2eG9SQ=", - "dev": true, - "requires": { - "debug": "2.6.9", - "finalhandler": "1.1.0", - "parseurl": "~1.3.2", - "utils-merge": "1.0.1" - }, - "dependencies": { - "finalhandler": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/finalhandler/-/finalhandler-1.1.0.tgz", - "integrity": "sha1-zgtoVbRYU+eRsvzGgARtiCU91/U=", - "dev": true, - "requires": { - "debug": "2.6.9", - "encodeurl": "~1.0.1", - "escape-html": "~1.0.3", - "on-finished": "~2.3.0", - "parseurl": "~1.3.2", - "statuses": "~1.3.1", - "unpipe": "~1.0.0" - } - }, - "statuses": { - "version": "1.3.1", - "resolved": "https://npm-registry.sipwise.com/statuses/-/statuses-1.3.1.tgz", - "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=", - "dev": true - } - } - }, - "connect-history-api-fallback": { - "version": "1.5.0", - "resolved": "https://npm-registry.sipwise.com/connect-history-api-fallback/-/connect-history-api-fallback-1.5.0.tgz", - "integrity": "sha1-sGhzk0vF40T+9hGhlqb6rgruAVo=", - "dev": true - }, - "console-browserify": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/console-browserify/-/console-browserify-1.1.0.tgz", - "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", - "dev": true, - "requires": { - "date-now": "^0.1.4" - } - }, - "consolidate": { - "version": "0.14.5", - "resolved": "https://npm-registry.sipwise.com/consolidate/-/consolidate-0.14.5.tgz", - "integrity": "sha1-WiUEe8dvcwcmZ8jLUsmJiI9JTGM=", - "dev": true, - "requires": { - "bluebird": "^3.1.1" - } - }, - "constants-browserify": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/constants-browserify/-/constants-browserify-1.0.0.tgz", - "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=", - "dev": true - }, - "contains-path": { - "version": "0.1.0", - "resolved": "https://npm-registry.sipwise.com/contains-path/-/contains-path-0.1.0.tgz", - "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", - "dev": true - }, - "content-disposition": { - "version": "0.5.2", - "resolved": "https://npm-registry.sipwise.com/content-disposition/-/content-disposition-0.5.2.tgz", - "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=", - "dev": true - }, - "content-type": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/content-type/-/content-type-1.0.4.tgz", - "integrity": "sha1-4TjMdeBAxyexlm/l5fjJruJW/js=", - "dev": true - }, - "convert-source-map": { - "version": "1.5.1", - "resolved": "https://npm-registry.sipwise.com/convert-source-map/-/convert-source-map-1.5.1.tgz", - "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=", - "dev": true - }, - "cookie": { - "version": "0.3.1", - "resolved": "https://npm-registry.sipwise.com/cookie/-/cookie-0.3.1.tgz", - "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=", - "dev": true - }, - "cookie-signature": { - "version": "1.0.6", - "resolved": "https://npm-registry.sipwise.com/cookie-signature/-/cookie-signature-1.0.6.tgz", - "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=", - "dev": true - }, - "copy-descriptor": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz", - "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", - "dev": true - }, - "core-js": { - "version": "2.5.7", - "resolved": "https://npm-registry.sipwise.com/core-js/-/core-js-2.5.7.tgz", - "integrity": "sha512-RszJCAxg/PP6uzXVXL6BsxSXx/B05oJAQ2vkJRjyjrEcNVycaqOmNb5OTxZPE3xa5gwZduqza6L9JOCenh/Ecw==" - }, - "core-util-is": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/core-util-is/-/core-util-is-1.0.2.tgz", - "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", - "dev": true - }, - "cosmiconfig": { - "version": "2.2.2", - "resolved": "https://npm-registry.sipwise.com/cosmiconfig/-/cosmiconfig-2.2.2.tgz", - "integrity": "sha512-GiNXLwAFPYHy25XmTPpafYvn3CLAkJ8FLsscq78MQd1Kh0OU6Yzhn4eV2MVF4G9WEQZoWEGltatdR+ntGPMl5A==", - "dev": true, - "requires": { - "is-directory": "^0.3.1", - "js-yaml": "^3.4.3", - "minimist": "^1.2.0", - "object-assign": "^4.1.0", - "os-homedir": "^1.0.1", - "parse-json": "^2.2.0", - "require-from-string": "^1.1.0" - }, - "dependencies": { - "minimist": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/minimist/-/minimist-1.2.0.tgz", - "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", - "dev": true - } - } - }, - "create-ecdh": { - "version": "4.0.3", - "resolved": "https://npm-registry.sipwise.com/create-ecdh/-/create-ecdh-4.0.3.tgz", - "integrity": "sha1-yREbbzMEXEaX8UR4f5JUzcd8Rf8=", - "dev": true, - "requires": { - "bn.js": "^4.1.0", - "elliptic": "^6.0.0" - } - }, - "create-hash": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/create-hash/-/create-hash-1.2.0.tgz", - "integrity": "sha1-iJB4rxGmN1a8+1m9IhmWvjqe8ZY=", - "dev": true, - "requires": { - "cipher-base": "^1.0.1", - "inherits": "^2.0.1", - "md5.js": "^1.3.4", - "ripemd160": "^2.0.1", - "sha.js": "^2.4.0" - } - }, - "create-hmac": { - "version": "1.1.7", - "resolved": "https://npm-registry.sipwise.com/create-hmac/-/create-hmac-1.1.7.tgz", - "integrity": "sha1-aRcMeLOrlXFHsriwRXLkfq0iQ/8=", - "dev": true, - "requires": { - "cipher-base": "^1.0.3", - "create-hash": "^1.1.0", - "inherits": "^2.0.1", - "ripemd160": "^2.0.0", - "safe-buffer": "^5.0.1", - "sha.js": "^2.4.8" - } - }, - "cross-spawn": { - "version": "5.1.0", - "resolved": "https://npm-registry.sipwise.com/cross-spawn/-/cross-spawn-5.1.0.tgz", - "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", - "dev": true, - "requires": { - "lru-cache": "^4.0.1", - "shebang-command": "^1.2.0", - "which": "^1.2.9" - } - }, - "crypto-browserify": { - "version": "3.12.0", - "resolved": "https://npm-registry.sipwise.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz", - "integrity": "sha1-OWz58xN/A+S45TLFj2mCVOAPgOw=", - "dev": true, - "requires": { - "browserify-cipher": "^1.0.0", - "browserify-sign": "^4.0.0", - "create-ecdh": "^4.0.0", - "create-hash": "^1.1.0", - "create-hmac": "^1.1.0", - "diffie-hellman": "^5.0.0", - "inherits": "^2.0.1", - "pbkdf2": "^3.0.3", - "public-encrypt": "^4.0.0", - "randombytes": "^2.0.0", - "randomfill": "^1.0.3" - } - }, - "css": { - "version": "2.2.3", - "resolved": "https://npm-registry.sipwise.com/css/-/css-2.2.3.tgz", - "integrity": "sha512-0W171WccAjQGGTKLhw4m2nnl0zPHUlTO/I8td4XzJgIB8Hg3ZZx71qT4G4eX8OVsSiaAKiUMy73E3nsbPlg2DQ==", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "source-map": "^0.1.38", - "source-map-resolve": "^0.5.1", - "urix": "^0.1.0" - }, - "dependencies": { - "source-map": { - "version": "0.1.43", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.1.43.tgz", - "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", - "dev": true, - "requires": { - "amdefine": ">=0.0.4" - } - } - } - }, - "css-color-names": { - "version": "0.0.4", - "resolved": "https://npm-registry.sipwise.com/css-color-names/-/css-color-names-0.0.4.tgz", - "integrity": "sha1-gIrcLnnPhHOAabZGyyDsJ762KeA=", - "dev": true - }, - "css-loader": { - "version": "0.28.11", - "resolved": "https://npm-registry.sipwise.com/css-loader/-/css-loader-0.28.11.tgz", - "integrity": "sha1-w/mGSnAL4nEbtaJGKyOJsaOS2rc=", - "dev": true, - "requires": { - "babel-code-frame": "^6.26.0", - "css-selector-tokenizer": "^0.7.0", - "cssnano": "^3.10.0", - "icss-utils": "^2.1.0", - "loader-utils": "^1.0.2", - "lodash.camelcase": "^4.3.0", - "object-assign": "^4.1.1", - "postcss": "^5.0.6", - "postcss-modules-extract-imports": "^1.2.0", - "postcss-modules-local-by-default": "^1.2.0", - "postcss-modules-scope": "^1.1.0", - "postcss-modules-values": "^1.3.0", - "postcss-value-parser": "^3.3.0", - "source-list-map": "^2.0.0" - } - }, - "css-parse": { - "version": "1.7.0", - "resolved": "https://npm-registry.sipwise.com/css-parse/-/css-parse-1.7.0.tgz", - "integrity": "sha1-Mh9s9zeCpv91ERE5D8BeLGV9jJs=", - "dev": true - }, - "css-select": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/css-select/-/css-select-1.2.0.tgz", - "integrity": "sha1-KzoRBTnFNV8c2NMUYj6HCxIeyFg=", - "dev": true, - "requires": { - "boolbase": "~1.0.0", - "css-what": "2.1", - "domutils": "1.5.1", - "nth-check": "~1.0.1" - }, - "dependencies": { - "domutils": { - "version": "1.5.1", - "resolved": "https://npm-registry.sipwise.com/domutils/-/domutils-1.5.1.tgz", - "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", - "dev": true, - "requires": { - "dom-serializer": "0", - "domelementtype": "1" - } - } - } - }, - "css-selector-tokenizer": { - "version": "0.7.0", - "resolved": "https://npm-registry.sipwise.com/css-selector-tokenizer/-/css-selector-tokenizer-0.7.0.tgz", - "integrity": "sha1-5piEdK6MlTR3v15+/s/OzNnPTIY=", - "dev": true, - "requires": { - "cssesc": "^0.1.0", - "fastparse": "^1.1.1", - "regexpu-core": "^1.0.0" - }, - "dependencies": { - "regexpu-core": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/regexpu-core/-/regexpu-core-1.0.0.tgz", - "integrity": "sha1-hqdj9Y7k18L2sQLkdkBQ3n7ZDGs=", - "dev": true, - "requires": { - "regenerate": "^1.2.1", - "regjsgen": "^0.2.0", - "regjsparser": "^0.1.4" - } - } - } - }, - "css-what": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/css-what/-/css-what-2.1.0.tgz", - "integrity": "sha1-lGfQMsOM+u+58teVASUwYvh/ob0=", - "dev": true - }, - "cssesc": { - "version": "0.1.0", - "resolved": "https://npm-registry.sipwise.com/cssesc/-/cssesc-0.1.0.tgz", - "integrity": "sha1-yBSQPkViM3GgR3tAEJqq++6t27Q=", - "dev": true - }, - "cssnano": { - "version": "3.10.0", - "resolved": "https://npm-registry.sipwise.com/cssnano/-/cssnano-3.10.0.tgz", - "integrity": "sha1-Tzj2zqK5sX+gFJDyPx3GjqZcHDg=", - "dev": true, - "requires": { - "autoprefixer": "^6.3.1", - "decamelize": "^1.1.2", - "defined": "^1.0.0", - "has": "^1.0.1", - "object-assign": "^4.0.1", - "postcss": "^5.0.14", - "postcss-calc": "^5.2.0", - "postcss-colormin": "^2.1.8", - "postcss-convert-values": "^2.3.4", - "postcss-discard-comments": "^2.0.4", - "postcss-discard-duplicates": "^2.0.1", - "postcss-discard-empty": "^2.0.1", - "postcss-discard-overridden": "^0.1.1", - "postcss-discard-unused": "^2.2.1", - "postcss-filter-plugins": "^2.0.0", - "postcss-merge-idents": "^2.1.5", - "postcss-merge-longhand": "^2.0.1", - "postcss-merge-rules": "^2.0.3", - "postcss-minify-font-values": "^1.0.2", - "postcss-minify-gradients": "^1.0.1", - "postcss-minify-params": "^1.0.4", - "postcss-minify-selectors": "^2.0.4", - "postcss-normalize-charset": "^1.1.0", - "postcss-normalize-url": "^3.0.7", - "postcss-ordered-values": "^2.1.0", - "postcss-reduce-idents": "^2.2.2", - "postcss-reduce-initial": "^1.0.0", - "postcss-reduce-transforms": "^1.0.3", - "postcss-svgo": "^2.1.1", - "postcss-unique-selectors": "^2.0.2", - "postcss-value-parser": "^3.2.3", - "postcss-zindex": "^2.0.1" - } - }, - "csso": { - "version": "2.3.2", - "resolved": "https://npm-registry.sipwise.com/csso/-/csso-2.3.2.tgz", - "integrity": "sha1-3dUsWHAz9J6Utx/FVWnyUuj/X4U=", - "dev": true, - "requires": { - "clap": "^1.0.9", - "source-map": "^0.5.3" - } - }, - "custom-event": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/custom-event/-/custom-event-1.0.1.tgz", - "integrity": "sha1-XQKkaFCt8bSjF5RqOSj8y1v9BCU=", - "dev": true - }, - "d": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/d/-/d-1.0.0.tgz", - "integrity": "sha1-dUu1v+VUUdpppYuU1F9MWwRi1Y8=", - "dev": true, - "requires": { - "es5-ext": "^0.10.9" - } - }, - "date-now": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/date-now/-/date-now-0.1.4.tgz", - "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=", - "dev": true - }, - "de-indent": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/de-indent/-/de-indent-1.0.2.tgz", - "integrity": "sha1-sgOOhG3DO6pXlhKNCAS0VbjB4h0=", - "dev": true - }, - "debug": { - "version": "2.6.9", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.6.9.tgz", - "integrity": "sha1-XRKFFd8TT/Mn6QpMk/Tgd6U2NB8=", - "dev": true, - "requires": { - "ms": "2.0.0" - } - }, - "decamelize": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/decamelize/-/decamelize-1.2.0.tgz", - "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", - "dev": true - }, - "decode-uri-component": { - "version": "0.2.0", - "resolved": "https://npm-registry.sipwise.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz", - "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", - "dev": true - }, - "decompress-response": { - "version": "3.3.0", - "resolved": "https://npm-registry.sipwise.com/decompress-response/-/decompress-response-3.3.0.tgz", - "integrity": "sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M=", - "requires": { - "mimic-response": "^1.0.0" - } - }, - "deep-eql": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/deep-eql/-/deep-eql-3.0.1.tgz", - "integrity": "sha1-38lARACtHI/gI+faHfHBR8S0RN8=", - "dev": true, - "requires": { - "type-detect": "^4.0.0" - } - }, - "deep-is": { - "version": "0.1.3", - "resolved": "https://npm-registry.sipwise.com/deep-is/-/deep-is-0.1.3.tgz", - "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", - "dev": true - }, - "define-properties": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/define-properties/-/define-properties-1.1.2.tgz", - "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=", - "dev": true, - "requires": { - "foreach": "^2.0.5", - "object-keys": "^1.0.8" - } - }, - "define-property": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-2.0.2.tgz", - "integrity": "sha1-1Flono1lS6d+AqgX+HENcCyxbp0=", - "dev": true, - "requires": { - "is-descriptor": "^1.0.2", - "isobject": "^3.0.1" - }, - "dependencies": { - "is-accessor-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha1-FpwvbT3x+ZJhgHI2XJsOofaHhlY=", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-data-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha1-2Eh2Mh0Oet0DmQQGq7u9NrqSaMc=", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-descriptor": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha1-OxWXRqZmBLBPjIFSS6NlxfFNhuw=", - "dev": true, - "requires": { - "is-accessor-descriptor": "^1.0.0", - "is-data-descriptor": "^1.0.0", - "kind-of": "^6.0.2" - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, - "kind-of": { - "version": "6.0.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - } - } - }, - "defined": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/defined/-/defined-1.0.0.tgz", - "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=", - "dev": true - }, - "del": { - "version": "2.2.2", - "resolved": "https://npm-registry.sipwise.com/del/-/del-2.2.2.tgz", - "integrity": "sha1-wSyYHQZ4RshLyvhiz/kw2Qf/0ag=", - "dev": true, - "requires": { - "globby": "^5.0.0", - "is-path-cwd": "^1.0.0", - "is-path-in-cwd": "^1.0.0", - "object-assign": "^4.0.1", - "pify": "^2.0.0", - "pinkie-promise": "^2.0.0", - "rimraf": "^2.2.8" - }, - "dependencies": { - "pify": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", - "dev": true - } - } - }, - "depd": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/depd/-/depd-1.1.2.tgz", - "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", - "dev": true - }, - "des.js": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/des.js/-/des.js-1.0.0.tgz", - "integrity": "sha1-wHTS4qpqipoH29YfmhXCzYPsjsw=", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "minimalistic-assert": "^1.0.0" - } - }, - "destroy": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/destroy/-/destroy-1.0.4.tgz", - "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", - "dev": true - }, - "detect-indent": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/detect-indent/-/detect-indent-4.0.0.tgz", - "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=", - "dev": true, - "requires": { - "repeating": "^2.0.0" - } - }, - "di": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/di/-/di-0.0.1.tgz", - "integrity": "sha1-gGZJMmzqp8qjMG112YXqJ0i6kTw=", - "dev": true - }, - "diff": { - "version": "3.3.1", - "resolved": "https://npm-registry.sipwise.com/diff/-/diff-3.3.1.tgz", - "integrity": "sha1-qoVnpu7QPFMfyJ0/cRzQ5SWd7HU=", - "dev": true - }, - "diffie-hellman": { - "version": "5.0.3", - "resolved": "https://npm-registry.sipwise.com/diffie-hellman/-/diffie-hellman-5.0.3.tgz", - "integrity": "sha1-QOjumPVaIUlgcUaSHGPhrl89KHU=", - "dev": true, - "requires": { - "bn.js": "^4.1.0", - "miller-rabin": "^4.0.0", - "randombytes": "^2.0.0" - } - }, - "doctrine": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/doctrine/-/doctrine-2.1.0.tgz", - "integrity": "sha1-XNAfwQFiG0LEzX9dGmYkNxbT850=", - "dev": true, - "requires": { - "esutils": "^2.0.2" - } - }, - "dom-converter": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/dom-converter/-/dom-converter-0.1.4.tgz", - "integrity": "sha1-pF71cnuJDJv/5tfIduexnLDhfzs=", - "dev": true, - "requires": { - "utila": "~0.3" - }, - "dependencies": { - "utila": { - "version": "0.3.3", - "resolved": "https://npm-registry.sipwise.com/utila/-/utila-0.3.3.tgz", - "integrity": "sha1-1+jn1+MJEHCSsF+NloiCTWM6QiY=", - "dev": true - } - } - }, - "dom-serialize": { - "version": "2.2.1", - "resolved": "https://npm-registry.sipwise.com/dom-serialize/-/dom-serialize-2.2.1.tgz", - "integrity": "sha1-ViromZ9Evl6jB29UGdzVnrQ6yVs=", - "dev": true, - "requires": { - "custom-event": "~1.0.0", - "ent": "~2.2.0", - "extend": "^3.0.0", - "void-elements": "^2.0.0" - } - }, - "dom-serializer": { - "version": "0.1.0", - "resolved": "https://npm-registry.sipwise.com/dom-serializer/-/dom-serializer-0.1.0.tgz", - "integrity": "sha1-BzxpdUbOB4DOI75KKOKT5AvDDII=", - "dev": true, - "requires": { - "domelementtype": "~1.1.1", - "entities": "~1.1.1" - }, - "dependencies": { - "domelementtype": { - "version": "1.1.3", - "resolved": "https://npm-registry.sipwise.com/domelementtype/-/domelementtype-1.1.3.tgz", - "integrity": "sha1-vSh3PiZCiBrsUVRJJCmcXNgiGFs=", - "dev": true - } - } - }, - "domain-browser": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/domain-browser/-/domain-browser-1.2.0.tgz", - "integrity": "sha1-PTH1AZGmdJ3RN1p/Ui6CPULlTto=", - "dev": true - }, - "domelementtype": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/domelementtype/-/domelementtype-1.3.0.tgz", - "integrity": "sha1-sXrtguirWeUt2cGbF1bg/BhyBMI=", - "dev": true - }, - "domhandler": { - "version": "2.4.2", - "resolved": "https://npm-registry.sipwise.com/domhandler/-/domhandler-2.4.2.tgz", - "integrity": "sha1-iAUJfpM9ZehVRvcm1g9euItE+AM=", - "dev": true, - "requires": { - "domelementtype": "1" - } - }, - "domutils": { - "version": "1.7.0", - "resolved": "https://npm-registry.sipwise.com/domutils/-/domutils-1.7.0.tgz", - "integrity": "sha1-Vuo0HoNOBuZ0ivehyyXaZ+qfjCo=", - "dev": true, - "requires": { - "dom-serializer": "0", - "domelementtype": "1" - } - }, - "duplexer3": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/duplexer3/-/duplexer3-0.1.4.tgz", - "integrity": "sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI=" - }, - "ee-first": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/ee-first/-/ee-first-1.1.1.tgz", - "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", - "dev": true - }, - "electron-to-chromium": { - "version": "1.3.52", - "resolved": "https://npm-registry.sipwise.com/electron-to-chromium/-/electron-to-chromium-1.3.52.tgz", - "integrity": "sha1-0tnxJwuko7lnuDHEDvcftNmrXOA=", - "dev": true - }, - "elliptic": { - "version": "6.4.0", - "resolved": "https://npm-registry.sipwise.com/elliptic/-/elliptic-6.4.0.tgz", - "integrity": "sha1-ysmvh2LIWDYYcAPI3+GT5eLq5d8=", - "dev": true, - "requires": { - "bn.js": "^4.4.0", - "brorand": "^1.0.1", - "hash.js": "^1.0.0", - "hmac-drbg": "^1.0.0", - "inherits": "^2.0.1", - "minimalistic-assert": "^1.0.0", - "minimalistic-crypto-utils": "^1.0.0" - } - }, - "emojis-list": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/emojis-list/-/emojis-list-2.1.0.tgz", - "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=", - "dev": true - }, - "encodeurl": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/encodeurl/-/encodeurl-1.0.2.tgz", - "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", - "dev": true - }, - "engine.io": { - "version": "1.8.3", - "resolved": "https://npm-registry.sipwise.com/engine.io/-/engine.io-1.8.3.tgz", - "integrity": "sha1-jef5eJXSDTm4X4ju7nd7K9QrE9Q=", - "dev": true, - "requires": { - "accepts": "1.3.3", - "base64id": "1.0.0", - "cookie": "0.3.1", - "debug": "2.3.3", - "engine.io-parser": "1.3.2", - "ws": "1.1.2" - }, - "dependencies": { - "accepts": { - "version": "1.3.3", - "resolved": "https://npm-registry.sipwise.com/accepts/-/accepts-1.3.3.tgz", - "integrity": "sha1-w8p0NJOGSMPg2cHjKN1otiLChMo=", - "dev": true, - "requires": { - "mime-types": "~2.1.11", - "negotiator": "0.6.1" - } - }, - "debug": { - "version": "2.3.3", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.3.3.tgz", - "integrity": "sha1-QMRT5n5uE8kB3ewxeviYbNqe/4w=", - "dev": true, - "requires": { - "ms": "0.7.2" - } - }, - "ms": { - "version": "0.7.2", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-0.7.2.tgz", - "integrity": "sha1-riXPJRKziFodldfwN4aNhDESR2U=", - "dev": true - } - } - }, - "engine.io-client": { - "version": "1.8.3", - "resolved": "https://npm-registry.sipwise.com/engine.io-client/-/engine.io-client-1.8.3.tgz", - "integrity": "sha1-F5jtk0USRkU9TG9jXXogH+lA1as=", - "dev": true, - "requires": { - "component-emitter": "1.2.1", - "component-inherit": "0.0.3", - "debug": "2.3.3", - "engine.io-parser": "1.3.2", - "has-cors": "1.1.0", - "indexof": "0.0.1", - "parsejson": "0.0.3", - "parseqs": "0.0.5", - "parseuri": "0.0.5", - "ws": "1.1.2", - "xmlhttprequest-ssl": "1.5.3", - "yeast": "0.1.2" - }, - "dependencies": { - "component-emitter": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/component-emitter/-/component-emitter-1.2.1.tgz", - "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", - "dev": true - }, - "debug": { - "version": "2.3.3", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.3.3.tgz", - "integrity": "sha1-QMRT5n5uE8kB3ewxeviYbNqe/4w=", - "dev": true, - "requires": { - "ms": "0.7.2" - } - }, - "ms": { - "version": "0.7.2", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-0.7.2.tgz", - "integrity": "sha1-riXPJRKziFodldfwN4aNhDESR2U=", - "dev": true - } - } - }, - "engine.io-parser": { - "version": "1.3.2", - "resolved": "https://npm-registry.sipwise.com/engine.io-parser/-/engine.io-parser-1.3.2.tgz", - "integrity": "sha1-k3sHnwAH0Ik+xW1GyyILjLQ1Igo=", - "dev": true, - "requires": { - "after": "0.8.2", - "arraybuffer.slice": "0.0.6", - "base64-arraybuffer": "0.1.5", - "blob": "0.0.4", - "has-binary": "0.1.7", - "wtf-8": "1.0.0" - } - }, - "enhanced-resolve": { - "version": "3.4.1", - "resolved": "https://npm-registry.sipwise.com/enhanced-resolve/-/enhanced-resolve-3.4.1.tgz", - "integrity": "sha1-BCHjOf1xQZs9oT0Smzl5BAIwR24=", - "dev": true, - "requires": { - "graceful-fs": "^4.1.2", - "memory-fs": "^0.4.0", - "object-assign": "^4.0.1", - "tapable": "^0.2.7" - } - }, - "ent": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/ent/-/ent-2.2.0.tgz", - "integrity": "sha1-6WQhkyWiHQX0RGai9obtbOX13R0=", - "dev": true - }, - "entities": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/entities/-/entities-1.1.1.tgz", - "integrity": "sha1-blwtClYhtdra7O+AuQ7ftc13cvA=", - "dev": true - }, - "errno": { - "version": "0.1.7", - "resolved": "https://npm-registry.sipwise.com/errno/-/errno-0.1.7.tgz", - "integrity": "sha1-RoTXF3mtOa8Xfj8AeZb3xnyFJhg=", - "dev": true, - "requires": { - "prr": "~1.0.1" - } - }, - "error-ex": { - "version": "1.3.2", - "resolved": "https://npm-registry.sipwise.com/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha1-tKxAZIEH/c3PriQvQovqihTU8b8=", - "dev": true, - "requires": { - "is-arrayish": "^0.2.1" - } - }, - "error-stack-parser": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/error-stack-parser/-/error-stack-parser-2.0.2.tgz", - "integrity": "sha512-E1fPutRDdIj/hohG0UpT5mayXNCxXP9d+snxFsPU9X0XgccOumKraa3juDMwTUyi7+Bu5+mCGagjg4IYeNbOdw==", - "dev": true, - "requires": { - "stackframe": "^1.0.4" - } - }, - "es5-ext": { - "version": "0.10.45", - "resolved": "https://npm-registry.sipwise.com/es5-ext/-/es5-ext-0.10.45.tgz", - "integrity": "sha512-FkfM6Vxxfmztilbxxz5UKSD4ICMf5tSpRFtDNtkAhOxZ0EKtX6qwmXNyH/sFyIbX2P/nU5AMiA9jilWsUGJzCQ==", - "dev": true, - "requires": { - "es6-iterator": "~2.0.3", - "es6-symbol": "~3.1.1", - "next-tick": "1" - } - }, - "es6-iterator": { - "version": "2.0.3", - "resolved": "https://npm-registry.sipwise.com/es6-iterator/-/es6-iterator-2.0.3.tgz", - "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", - "dev": true, - "requires": { - "d": "1", - "es5-ext": "^0.10.35", - "es6-symbol": "^3.1.1" - } - }, - "es6-map": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/es6-map/-/es6-map-0.1.5.tgz", - "integrity": "sha1-kTbgUD3MBqMBaQ8LsU/042TpSfA=", - "dev": true, - "requires": { - "d": "1", - "es5-ext": "~0.10.14", - "es6-iterator": "~2.0.1", - "es6-set": "~0.1.5", - "es6-symbol": "~3.1.1", - "event-emitter": "~0.3.5" - } - }, - "es6-promise": { - "version": "4.2.4", - "resolved": "https://npm-registry.sipwise.com/es6-promise/-/es6-promise-4.2.4.tgz", - "integrity": "sha512-/NdNZVJg+uZgtm9eS3O6lrOLYmQag2DjdEXuPaHlZ6RuVqgqaVZfgYCepEIKsLqwdQArOPtC3XzRLqGGfT8KQQ==", - "dev": true - }, - "es6-set": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/es6-set/-/es6-set-0.1.5.tgz", - "integrity": "sha1-0rPsXU2ADO2BjbU40ol02wpzzLE=", - "dev": true, - "requires": { - "d": "1", - "es5-ext": "~0.10.14", - "es6-iterator": "~2.0.1", - "es6-symbol": "3.1.1", - "event-emitter": "~0.3.5" - } - }, - "es6-symbol": { - "version": "3.1.1", - "resolved": "https://npm-registry.sipwise.com/es6-symbol/-/es6-symbol-3.1.1.tgz", - "integrity": "sha1-vwDvT9q2uhtG7Le2KbTH7VcVzHc=", - "dev": true, - "requires": { - "d": "1", - "es5-ext": "~0.10.14" - } - }, - "es6-weak-map": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/es6-weak-map/-/es6-weak-map-2.0.2.tgz", - "integrity": "sha1-XjqzIlH/0VOKH45f+hNXdy+S2W8=", - "dev": true, - "requires": { - "d": "1", - "es5-ext": "^0.10.14", - "es6-iterator": "^2.0.1", - "es6-symbol": "^3.1.1" - } - }, - "escape-html": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/escape-html/-/escape-html-1.0.3.tgz", - "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", - "dev": true - }, - "escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://npm-registry.sipwise.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", - "dev": true - }, - "escope": { - "version": "3.6.0", - "resolved": "https://npm-registry.sipwise.com/escope/-/escope-3.6.0.tgz", - "integrity": "sha1-4Bl16BJ4GhY6ba392AOY3GTIicM=", - "dev": true, - "requires": { - "es6-map": "^0.1.3", - "es6-weak-map": "^2.0.1", - "esrecurse": "^4.1.0", - "estraverse": "^4.1.1" - } - }, - "eslint": { - "version": "4.19.1", - "resolved": "https://npm-registry.sipwise.com/eslint/-/eslint-4.19.1.tgz", - "integrity": "sha1-MtHWU+HZBAiFS/spbwdux+GGowA=", - "dev": true, - "requires": { - "ajv": "^5.3.0", - "babel-code-frame": "^6.22.0", - "chalk": "^2.1.0", - "concat-stream": "^1.6.0", - "cross-spawn": "^5.1.0", - "debug": "^3.1.0", - "doctrine": "^2.1.0", - "eslint-scope": "^3.7.1", - "eslint-visitor-keys": "^1.0.0", - "espree": "^3.5.4", - "esquery": "^1.0.0", - "esutils": "^2.0.2", - "file-entry-cache": "^2.0.0", - "functional-red-black-tree": "^1.0.1", - "glob": "^7.1.2", - "globals": "^11.0.1", - "ignore": "^3.3.3", - "imurmurhash": "^0.1.4", - "inquirer": "^3.0.6", - "is-resolvable": "^1.0.0", - "js-yaml": "^3.9.1", - "json-stable-stringify-without-jsonify": "^1.0.1", - "levn": "^0.3.0", - "lodash": "^4.17.4", - "minimatch": "^3.0.2", - "mkdirp": "^0.5.1", - "natural-compare": "^1.4.0", - "optionator": "^0.8.2", - "path-is-inside": "^1.0.2", - "pluralize": "^7.0.0", - "progress": "^2.0.0", - "regexpp": "^1.0.1", - "require-uncached": "^1.0.3", - "semver": "^5.3.0", - "strip-ansi": "^4.0.0", - "strip-json-comments": "~2.0.1", - "table": "4.0.2", - "text-table": "~0.2.0" - }, - "dependencies": { - "ansi-regex": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/ansi-regex/-/ansi-regex-3.0.0.tgz", - "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", - "dev": true - }, - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "debug": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-3.1.0.tgz", - "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", - "dev": true, - "requires": { - "ms": "2.0.0" - } - }, - "esprima": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha1-E7BM2z5sXRnfkatph6hpVhmwqnE=", - "dev": true - }, - "globals": { - "version": "11.7.0", - "resolved": "https://npm-registry.sipwise.com/globals/-/globals-11.7.0.tgz", - "integrity": "sha512-K8BNSPySfeShBQXsahYB/AbbWruVOTyVpgoIDnl8odPpeSfP2J5QO2oLFFdl2j7GfDCtZj2bMKar2T49itTPCg==", - "dev": true - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "js-yaml": { - "version": "3.13.1", - "resolved": "https://npm-registry.sipwise.com/js-yaml/-/js-yaml-3.13.1.tgz", - "integrity": "sha1-r/FRswv9+o5J4F2iLnQV6d+jeEc=", - "dev": true, - "requires": { - "argparse": "^1.0.7", - "esprima": "^4.0.0" - } - }, - "strip-ansi": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/strip-ansi/-/strip-ansi-4.0.0.tgz", - "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", - "dev": true, - "requires": { - "ansi-regex": "^3.0.0" - } - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "eslint-config-standard": { - "version": "10.2.1", - "resolved": "https://npm-registry.sipwise.com/eslint-config-standard/-/eslint-config-standard-10.2.1.tgz", - "integrity": "sha1-wGHk0GbzedwXzVYsZOgZtN1FRZE=", - "dev": true - }, - "eslint-friendly-formatter": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/eslint-friendly-formatter/-/eslint-friendly-formatter-3.0.0.tgz", - "integrity": "sha1-J4h0Q1psRuwdlPoLH/SU4w7wQpA=", - "dev": true, - "requires": { - "chalk": "^1.0.0", - "coalescy": "1.0.0", - "extend": "^3.0.0", - "minimist": "^1.2.0", - "text-table": "^0.2.0" - }, - "dependencies": { - "minimist": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/minimist/-/minimist-1.2.0.tgz", - "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", - "dev": true - } - } - }, - "eslint-import-resolver-node": { - "version": "0.3.2", - "resolved": "https://npm-registry.sipwise.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", - "integrity": "sha1-WPFfuDm40FdsqYBBNHaqskcttmo=", - "dev": true, - "requires": { - "debug": "^2.6.9", - "resolve": "^1.5.0" - } - }, - "eslint-loader": { - "version": "1.9.0", - "resolved": "https://npm-registry.sipwise.com/eslint-loader/-/eslint-loader-1.9.0.tgz", - "integrity": "sha1-fhvp/t3KMo09z67xrUnVvv/oOhM=", - "dev": true, - "requires": { - "loader-fs-cache": "^1.0.0", - "loader-utils": "^1.0.2", - "object-assign": "^4.0.1", - "object-hash": "^1.1.4", - "rimraf": "^2.6.1" - } - }, - "eslint-module-utils": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/eslint-module-utils/-/eslint-module-utils-2.2.0.tgz", - "integrity": "sha1-snA2LNiLGkitMIl2zn+lTphBF0Y=", - "dev": true, - "requires": { - "debug": "^2.6.8", - "pkg-dir": "^1.0.0" - }, - "dependencies": { - "find-up": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/find-up/-/find-up-1.1.2.tgz", - "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", - "dev": true, - "requires": { - "path-exists": "^2.0.0", - "pinkie-promise": "^2.0.0" - } - }, - "path-exists": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/path-exists/-/path-exists-2.1.0.tgz", - "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", - "dev": true, - "requires": { - "pinkie-promise": "^2.0.0" - } - }, - "pkg-dir": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/pkg-dir/-/pkg-dir-1.0.0.tgz", - "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", - "dev": true, - "requires": { - "find-up": "^1.0.0" - } - } - } - }, - "eslint-plugin-html": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/eslint-plugin-html/-/eslint-plugin-html-3.2.2.tgz", - "integrity": "sha1-73CTYh06k94yBv0fkvNH6poaTfo=", - "dev": true, - "requires": { - "htmlparser2": "^3.8.2", - "semver": "^5.4.1" - } - }, - "eslint-plugin-import": { - "version": "2.13.0", - "resolved": "https://npm-registry.sipwise.com/eslint-plugin-import/-/eslint-plugin-import-2.13.0.tgz", - "integrity": "sha512-t6hGKQDMIt9N8R7vLepsYXgDfeuhp6ZJSgtrLEDxonpSubyxUZHjhm6LsAaZX8q6GYVxkbT3kTsV9G5mBCFR6A==", - "dev": true, - "requires": { - "contains-path": "^0.1.0", - "debug": "^2.6.8", - "doctrine": "1.5.0", - "eslint-import-resolver-node": "^0.3.1", - "eslint-module-utils": "^2.2.0", - "has": "^1.0.1", - "lodash": "^4.17.4", - "minimatch": "^3.0.3", - "read-pkg-up": "^2.0.0", - "resolve": "^1.6.0" - }, - "dependencies": { - "doctrine": { - "version": "1.5.0", - "resolved": "https://npm-registry.sipwise.com/doctrine/-/doctrine-1.5.0.tgz", - "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", - "dev": true, - "requires": { - "esutils": "^2.0.2", - "isarray": "^1.0.0" - } - } - } - }, - "eslint-plugin-node": { - "version": "5.2.1", - "resolved": "https://npm-registry.sipwise.com/eslint-plugin-node/-/eslint-plugin-node-5.2.1.tgz", - "integrity": "sha1-gN8yU8TXkBBF7If6ZgooTjK9yik=", - "dev": true, - "requires": { - "ignore": "^3.3.6", - "minimatch": "^3.0.4", - "resolve": "^1.3.3", - "semver": "5.3.0" - }, - "dependencies": { - "semver": { - "version": "5.3.0", - "resolved": "https://npm-registry.sipwise.com/semver/-/semver-5.3.0.tgz", - "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=", - "dev": true - } - } - }, - "eslint-plugin-promise": { - "version": "3.8.0", - "resolved": "https://npm-registry.sipwise.com/eslint-plugin-promise/-/eslint-plugin-promise-3.8.0.tgz", - "integrity": "sha1-ZevyeoRePB6db2pWIt3TgBaUtiE=", - "dev": true - }, - "eslint-plugin-standard": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/eslint-plugin-standard/-/eslint-plugin-standard-3.1.0.tgz", - "integrity": "sha1-Kp4hJZukxHwC1TstDJE11LECLUc=", - "dev": true - }, - "eslint-scope": { - "version": "3.7.3", - "resolved": "https://npm-registry.sipwise.com/eslint-scope/-/eslint-scope-3.7.3.tgz", - "integrity": "sha1-u1ByANPRf2AkdjYWC0gmKEsQhTU=", - "dev": true, - "requires": { - "esrecurse": "^4.1.0", - "estraverse": "^4.1.1" - } - }, - "eslint-visitor-keys": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", - "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", - "dev": true - }, - "espree": { - "version": "3.5.4", - "resolved": "https://npm-registry.sipwise.com/espree/-/espree-3.5.4.tgz", - "integrity": "sha1-sPRHGHyKi+2US4FaZgvd9d610ac=", - "dev": true, - "requires": { - "acorn": "^5.5.0", - "acorn-jsx": "^3.0.0" - } - }, - "esprima": { - "version": "2.7.3", - "resolved": "https://npm-registry.sipwise.com/esprima/-/esprima-2.7.3.tgz", - "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", - "dev": true - }, - "esquery": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/esquery/-/esquery-1.0.1.tgz", - "integrity": "sha1-QGxRZYsfWZGl+bYrHcJbAOPlxwg=", - "dev": true, - "requires": { - "estraverse": "^4.0.0" - } - }, - "esrecurse": { - "version": "4.2.1", - "resolved": "https://npm-registry.sipwise.com/esrecurse/-/esrecurse-4.2.1.tgz", - "integrity": "sha1-AHo7n9vCs7uH5IeeoZyS/b05Qs8=", - "dev": true, - "requires": { - "estraverse": "^4.1.0" - } - }, - "estraverse": { - "version": "4.2.0", - "resolved": "https://npm-registry.sipwise.com/estraverse/-/estraverse-4.2.0.tgz", - "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", - "dev": true - }, - "esutils": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/esutils/-/esutils-2.0.2.tgz", - "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", - "dev": true - }, - "etag": { - "version": "1.8.1", - "resolved": "https://npm-registry.sipwise.com/etag/-/etag-1.8.1.tgz", - "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", - "dev": true - }, - "event-emitter": { - "version": "0.3.5", - "resolved": "https://npm-registry.sipwise.com/event-emitter/-/event-emitter-0.3.5.tgz", - "integrity": "sha1-34xp7vFkeSPHFXuc6DhAYQsCzDk=", - "dev": true, - "requires": { - "d": "1", - "es5-ext": "~0.10.14" - } - }, - "eventemitter3": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/eventemitter3/-/eventemitter3-3.1.0.tgz", - "integrity": "sha512-ivIvhpq/Y0uSjcHDcOIccjmYjGLcP09MFGE7ysAwkAvkXfpZlC985pH2/ui64DKazbTW/4kN3yqozUxlXzI6cA==", - "dev": true - }, - "events": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/events/-/events-1.1.1.tgz", - "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=", - "dev": true - }, - "eventsource-polyfill": { - "version": "0.9.6", - "resolved": "https://npm-registry.sipwise.com/eventsource-polyfill/-/eventsource-polyfill-0.9.6.tgz", - "integrity": "sha1-EODRh/ERsWfyj9q5GIQ859gY8Tw=", - "dev": true - }, - "evp_bytestokey": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", - "integrity": "sha1-f8vbGY3HGVlDLv4ThCaE4FJaywI=", - "dev": true, - "requires": { - "md5.js": "^1.3.4", - "safe-buffer": "^5.1.1" - } - }, - "execa": { - "version": "0.7.0", - "resolved": "https://npm-registry.sipwise.com/execa/-/execa-0.7.0.tgz", - "integrity": "sha1-lEvs00zEHuMqY6n68nrVpl/Fl3c=", - "dev": true, - "requires": { - "cross-spawn": "^5.0.1", - "get-stream": "^3.0.0", - "is-stream": "^1.1.0", - "npm-run-path": "^2.0.0", - "p-finally": "^1.0.0", - "signal-exit": "^3.0.0", - "strip-eof": "^1.0.0" - } - }, - "expand-braces": { - "version": "0.1.2", - "resolved": "https://npm-registry.sipwise.com/expand-braces/-/expand-braces-0.1.2.tgz", - "integrity": "sha1-SIsdHSRRyz06axks/AMPRMWFX+o=", - "dev": true, - "requires": { - "array-slice": "^0.2.3", - "array-unique": "^0.2.1", - "braces": "^0.1.2" - }, - "dependencies": { - "braces": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/braces/-/braces-0.1.5.tgz", - "integrity": "sha1-wIVxEIUpHYt1/ddOqw+FlygHEeY=", - "dev": true, - "requires": { - "expand-range": "^0.1.0" - } - }, - "expand-range": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/expand-range/-/expand-range-0.1.1.tgz", - "integrity": "sha1-TLjtoJk8pW+k9B/ELzy7TMrf8EQ=", - "dev": true, - "requires": { - "is-number": "^0.1.1", - "repeat-string": "^0.2.2" - } - }, - "is-number": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/is-number/-/is-number-0.1.1.tgz", - "integrity": "sha1-aaevEWlj1HIG7JvZtIoUIW8eOAY=", - "dev": true - }, - "repeat-string": { - "version": "0.2.2", - "resolved": "https://npm-registry.sipwise.com/repeat-string/-/repeat-string-0.2.2.tgz", - "integrity": "sha1-x6jTI2BoNiBZp+RlH8aITosftK4=", - "dev": true - } - } - }, - "expand-brackets": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/expand-brackets/-/expand-brackets-0.1.5.tgz", - "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", - "dev": true, - "requires": { - "is-posix-bracket": "^0.1.0" - } - }, - "expand-range": { - "version": "1.8.2", - "resolved": "https://npm-registry.sipwise.com/expand-range/-/expand-range-1.8.2.tgz", - "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", - "dev": true, - "requires": { - "fill-range": "^2.1.0" - } - }, - "express": { - "version": "4.16.3", - "resolved": "https://npm-registry.sipwise.com/express/-/express-4.16.3.tgz", - "integrity": "sha1-avilAjUNsyRuzEvs9rWjTSL37VM=", - "dev": true, - "requires": { - "accepts": "~1.3.5", - "array-flatten": "1.1.1", - "body-parser": "1.18.2", - "content-disposition": "0.5.2", - "content-type": "~1.0.4", - "cookie": "0.3.1", - "cookie-signature": "1.0.6", - "debug": "2.6.9", - "depd": "~1.1.2", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "etag": "~1.8.1", - "finalhandler": "1.1.1", - "fresh": "0.5.2", - "merge-descriptors": "1.0.1", - "methods": "~1.1.2", - "on-finished": "~2.3.0", - "parseurl": "~1.3.2", - "path-to-regexp": "0.1.7", - "proxy-addr": "~2.0.3", - "qs": "6.5.1", - "range-parser": "~1.2.0", - "safe-buffer": "5.1.1", - "send": "0.16.2", - "serve-static": "1.13.2", - "setprototypeof": "1.1.0", - "statuses": "~1.4.0", - "type-is": "~1.6.16", - "utils-merge": "1.0.1", - "vary": "~1.1.2" - }, - "dependencies": { - "safe-buffer": { - "version": "5.1.1", - "resolved": "https://npm-registry.sipwise.com/safe-buffer/-/safe-buffer-5.1.1.tgz", - "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", - "dev": true - } - } - }, - "extend": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/extend/-/extend-3.0.2.tgz", - "integrity": "sha1-+LETa0Bx+9jrFAr/hYsQGewpFfo=", - "dev": true - }, - "extend-shallow": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-3.0.2.tgz", - "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", - "dev": true, - "requires": { - "assign-symbols": "^1.0.0", - "is-extendable": "^1.0.1" - }, - "dependencies": { - "is-extendable": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/is-extendable/-/is-extendable-1.0.1.tgz", - "integrity": "sha1-p0cPnkJnM9gb2B4RVSZOOjUHyrQ=", - "dev": true, - "requires": { - "is-plain-object": "^2.0.4" - } - } - } - }, - "external-editor": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/external-editor/-/external-editor-2.2.0.tgz", - "integrity": "sha1-BFURz9jRM/OEZnPRBHwVTiFK09U=", - "dev": true, - "requires": { - "chardet": "^0.4.0", - "iconv-lite": "^0.4.17", - "tmp": "^0.0.33" - } - }, - "extglob": { - "version": "0.3.2", - "resolved": "https://npm-registry.sipwise.com/extglob/-/extglob-0.3.2.tgz", - "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - }, - "dependencies": { - "is-extglob": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", - "dev": true - } - } - }, - "extract-text-webpack-plugin": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/extract-text-webpack-plugin/-/extract-text-webpack-plugin-3.0.2.tgz", - "integrity": "sha1-XwQ+qgL5dQqSWLeMCm4NwUCPsvc=", - "dev": true, - "requires": { - "async": "^2.4.1", - "loader-utils": "^1.1.0", - "schema-utils": "^0.3.0", - "webpack-sources": "^1.0.1" - } - }, - "fast-deep-equal": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz", - "integrity": "sha1-wFNHeBfIa1HaqFPIHgWbcz0CNhQ=", - "dev": true - }, - "fast-json-stable-stringify": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", - "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", - "dev": true - }, - "fast-levenshtein": { - "version": "2.0.6", - "resolved": "https://npm-registry.sipwise.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", - "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", - "dev": true - }, - "fastparse": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/fastparse/-/fastparse-1.1.1.tgz", - "integrity": "sha1-0eJkOzipTXWDtHkGDmxK/8lAcfg=", - "dev": true - }, - "figures": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/figures/-/figures-2.0.0.tgz", - "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", - "dev": true, - "requires": { - "escape-string-regexp": "^1.0.5" - } - }, - "file-entry-cache": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/file-entry-cache/-/file-entry-cache-2.0.0.tgz", - "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", - "dev": true, - "requires": { - "flat-cache": "^1.2.1", - "object-assign": "^4.0.1" - } - }, - "file-loader": { - "version": "0.11.2", - "resolved": "https://npm-registry.sipwise.com/file-loader/-/file-loader-0.11.2.tgz", - "integrity": "sha1-T/HfKK84cZpgmAk7iMgscdF5SjQ=", - "dev": true, - "requires": { - "loader-utils": "^1.0.2" - } - }, - "file-saver": { - "version": "1.3.3", - "resolved": "https://npm-registry.sipwise.com/file-saver/-/file-saver-1.3.3.tgz", - "integrity": "sha1-zdTETTqiZOrC9o7BZbx5HDSvEjI=", - "dev": true - }, - "filename-regex": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/filename-regex/-/filename-regex-2.0.1.tgz", - "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", - "dev": true - }, - "fill-range": { - "version": "2.2.4", - "resolved": "https://npm-registry.sipwise.com/fill-range/-/fill-range-2.2.4.tgz", - "integrity": "sha512-cnrcCbj01+j2gTG921VZPnHbjmdAf8oQV/iGeV2kZxGSyfYjjTyY79ErsK1WJWMpw6DaApEX72binqJE+/d+5Q==", - "dev": true, - "requires": { - "is-number": "^2.1.0", - "isobject": "^2.0.0", - "randomatic": "^3.0.0", - "repeat-element": "^1.1.2", - "repeat-string": "^1.5.2" - } - }, - "finalhandler": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/finalhandler/-/finalhandler-1.1.1.tgz", - "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", - "dev": true, - "requires": { - "debug": "2.6.9", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "on-finished": "~2.3.0", - "parseurl": "~1.3.2", - "statuses": "~1.4.0", - "unpipe": "~1.0.0" - } - }, - "find-cache-dir": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/find-cache-dir/-/find-cache-dir-1.0.0.tgz", - "integrity": "sha1-kojj6ePMN0hxfTnq3hfPcfww7m8=", - "dev": true, - "requires": { - "commondir": "^1.0.1", - "make-dir": "^1.0.0", - "pkg-dir": "^2.0.0" - } - }, - "find-up": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/find-up/-/find-up-2.1.0.tgz", - "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", - "dev": true, - "requires": { - "locate-path": "^2.0.0" - } - }, - "flat-cache": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/flat-cache/-/flat-cache-1.3.0.tgz", - "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", - "dev": true, - "requires": { - "circular-json": "^0.3.1", - "del": "^2.0.2", - "graceful-fs": "^4.1.2", - "write": "^0.2.1" - } - }, - "flatten": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/flatten/-/flatten-1.0.2.tgz", - "integrity": "sha1-2uRqnXj74lKSJYzB54CkHZXAN4I=", - "dev": true - }, - "follow-redirects": { - "version": "1.5.1", - "resolved": "https://npm-registry.sipwise.com/follow-redirects/-/follow-redirects-1.5.1.tgz", - "integrity": "sha512-v9GI1hpaqq1ZZR6pBD1+kI7O24PhDvNGNodjS3MdcEqyrahCp8zbtpv+2B/krUnSmUH80lbAS7MrdeK5IylgKg==", - "dev": true, - "requires": { - "debug": "^3.1.0" - }, - "dependencies": { - "debug": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-3.1.0.tgz", - "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", - "dev": true, - "requires": { - "ms": "2.0.0" - } - } - } - }, - "for-in": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/for-in/-/for-in-1.0.2.tgz", - "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", - "dev": true - }, - "for-own": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/for-own/-/for-own-0.1.5.tgz", - "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", - "dev": true, - "requires": { - "for-in": "^1.0.1" - } - }, - "foreach": { - "version": "2.0.5", - "resolved": "https://npm-registry.sipwise.com/foreach/-/foreach-2.0.5.tgz", - "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=", - "dev": true - }, - "forwarded": { - "version": "0.1.2", - "resolved": "https://npm-registry.sipwise.com/forwarded/-/forwarded-0.1.2.tgz", - "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=", - "dev": true - }, - "fragment-cache": { - "version": "0.2.1", - "resolved": "https://npm-registry.sipwise.com/fragment-cache/-/fragment-cache-0.2.1.tgz", - "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", - "dev": true, - "requires": { - "map-cache": "^0.2.2" - } - }, - "fresh": { - "version": "0.5.2", - "resolved": "https://npm-registry.sipwise.com/fresh/-/fresh-0.5.2.tgz", - "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", - "dev": true - }, - "friendly-errors-webpack-plugin": { - "version": "1.7.0", - "resolved": "https://npm-registry.sipwise.com/friendly-errors-webpack-plugin/-/friendly-errors-webpack-plugin-1.7.0.tgz", - "integrity": "sha1-78hsu4FiJFZYYaG+ep2E0Kr+oTY=", - "dev": true, - "requires": { - "chalk": "^1.1.3", - "error-stack-parser": "^2.0.0", - "string-width": "^2.0.0" - } - }, - "fs-access": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/fs-access/-/fs-access-1.0.1.tgz", - "integrity": "sha1-1qh/JiJxzv6+wwxVNAf7mV2od3o=", - "dev": true, - "requires": { - "null-check": "^1.0.0" - } - }, - "fs-minipass": { - "version": "1.2.6", - "resolved": "https://npm-registry.sipwise.com/fs-minipass/-/fs-minipass-1.2.6.tgz", - "integrity": "sha512-crhvyXcMejjv3Z5d2Fa9sf5xLYVCF5O1c71QxbVnbLsmYMBEvDAftewesN/HhY03YRoA7zOMxjNGrF5svGaaeQ==", - "dev": true, - "optional": true, - "requires": { - "minipass": "^2.2.1" - } - }, - "fs.realpath": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", - "dev": true - }, - "fsevents": { - "version": "1.2.4", - "resolved": "https://npm-registry.sipwise.com/fsevents/-/fsevents-1.2.4.tgz", - "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==", - "dev": true, - "optional": true, - "requires": { - "nan": "^2.9.2", - "node-pre-gyp": "^0.10.0" - }, - "dependencies": { - "abbrev": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/abbrev/-/abbrev-1.1.1.tgz", - "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", - "dev": true, - "optional": true - }, - "ansi-regex": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/ansi-regex/-/ansi-regex-2.1.1.tgz", - "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", - "dev": true, - "optional": true - }, - "aproba": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/aproba/-/aproba-1.2.0.tgz", - "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", - "dev": true, - "optional": true - }, - "are-we-there-yet": { - "version": "1.1.4", - "resolved": "https://npm-registry.sipwise.com/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz", - "integrity": "sha1-u13KOCu5TwXhUZQ3PRb9O6HKEQ0=", - "dev": true, - "optional": true, - "requires": { - "delegates": "^1.0.0", - "readable-stream": "^2.0.6" - } - }, - "balanced-match": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/balanced-match/-/balanced-match-1.0.0.tgz", - "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", - "dev": true, - "optional": true - }, - "brace-expansion": { - "version": "1.1.11", - "resolved": "https://npm-registry.sipwise.com/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", - "dev": true, - "optional": true, - "requires": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "code-point-at": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/code-point-at/-/code-point-at-1.1.0.tgz", - "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", - "dev": true, - "optional": true - }, - "concat-map": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", - "dev": true, - "optional": true - }, - "console-control-strings": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/console-control-strings/-/console-control-strings-1.1.0.tgz", - "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=", - "dev": true, - "optional": true - }, - "core-util-is": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/core-util-is/-/core-util-is-1.0.2.tgz", - "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", - "dev": true, - "optional": true - }, - "debug": { - "version": "2.6.9", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "optional": true, - "requires": { - "ms": "2.0.0" - } - }, - "deep-extend": { - "version": "0.5.1", - "resolved": "https://npm-registry.sipwise.com/deep-extend/-/deep-extend-0.5.1.tgz", - "integrity": "sha512-N8vBdOa+DF7zkRrDCsaOXoCs/E2fJfx9B9MrKnnSiHNh4ws7eSys6YQE4KvT1cecKmOASYQBhbKjeuDD9lT81w==", - "dev": true, - "optional": true - }, - "delegates": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/delegates/-/delegates-1.0.0.tgz", - "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=", - "dev": true, - "optional": true - }, - "detect-libc": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/detect-libc/-/detect-libc-1.0.3.tgz", - "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=", - "dev": true, - "optional": true - }, - "fs.realpath": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", - "dev": true, - "optional": true - }, - "gauge": { - "version": "2.7.4", - "resolved": "https://npm-registry.sipwise.com/gauge/-/gauge-2.7.4.tgz", - "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", - "dev": true, - "optional": true, - "requires": { - "aproba": "^1.0.3", - "console-control-strings": "^1.0.0", - "has-unicode": "^2.0.0", - "object-assign": "^4.1.0", - "signal-exit": "^3.0.0", - "string-width": "^1.0.1", - "strip-ansi": "^3.0.1", - "wide-align": "^1.1.0" - } - }, - "glob": { - "version": "7.1.2", - "resolved": "https://npm-registry.sipwise.com/glob/-/glob-7.1.2.tgz", - "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", - "dev": true, - "optional": true, - "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.0.4", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - } - }, - "has-unicode": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/has-unicode/-/has-unicode-2.0.1.tgz", - "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=", - "dev": true, - "optional": true - }, - "iconv-lite": { - "version": "0.4.21", - "resolved": "https://npm-registry.sipwise.com/iconv-lite/-/iconv-lite-0.4.21.tgz", - "integrity": "sha512-En5V9za5mBt2oUA03WGD3TwDv0MKAruqsuxstbMUZaj9W9k/m1CV/9py3l0L5kw9Bln8fdHQmzHSYtvpvTLpKw==", - "dev": true, - "optional": true, - "requires": { - "safer-buffer": "^2.1.0" - } - }, - "ignore-walk": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/ignore-walk/-/ignore-walk-3.0.1.tgz", - "integrity": "sha512-DTVlMx3IYPe0/JJcYP7Gxg7ttZZu3IInhuEhbchuqneY9wWe5Ojy2mXLBaQFUQmo0AW2r3qG7m1mg86js+gnlQ==", - "dev": true, - "optional": true, - "requires": { - "minimatch": "^3.0.4" - } - }, - "inflight": { - "version": "1.0.6", - "resolved": "https://npm-registry.sipwise.com/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", - "dev": true, - "optional": true, - "requires": { - "once": "^1.3.0", - "wrappy": "1" - } - }, - "inherits": { - "version": "2.0.3", - "resolved": "https://npm-registry.sipwise.com/inherits/-/inherits-2.0.3.tgz", - "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", - "dev": true, - "optional": true - }, - "ini": { - "version": "1.3.5", - "resolved": "https://npm-registry.sipwise.com/ini/-/ini-1.3.5.tgz", - "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", - "dev": true, - "optional": true - }, - "is-fullwidth-code-point": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", - "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", - "dev": true, - "optional": true, - "requires": { - "number-is-nan": "^1.0.0" - } - }, - "isarray": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/isarray/-/isarray-1.0.0.tgz", - "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", - "dev": true, - "optional": true - }, - "minimatch": { - "version": "3.0.4", - "resolved": "https://npm-registry.sipwise.com/minimatch/-/minimatch-3.0.4.tgz", - "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", - "dev": true, - "optional": true, - "requires": { - "brace-expansion": "^1.1.7" - } - }, - "minimist": { - "version": "0.0.8", - "resolved": "https://npm-registry.sipwise.com/minimist/-/minimist-0.0.8.tgz", - "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", - "dev": true, - "optional": true - }, - "mkdirp": { - "version": "0.5.1", - "resolved": "https://npm-registry.sipwise.com/mkdirp/-/mkdirp-0.5.1.tgz", - "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", - "dev": true, - "optional": true, - "requires": { - "minimist": "0.0.8" - } - }, - "ms": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", - "dev": true, - "optional": true - }, - "needle": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/needle/-/needle-2.2.0.tgz", - "integrity": "sha512-eFagy6c+TYayorXw/qtAdSvaUpEbBsDwDyxYFgLZ0lTojfH7K+OdBqAF7TAFwDokJaGpubpSGG0wO3iC0XPi8w==", - "dev": true, - "optional": true, - "requires": { - "debug": "^2.1.2", - "iconv-lite": "^0.4.4", - "sax": "^1.2.4" - } - }, - "node-pre-gyp": { - "version": "0.10.0", - "resolved": "https://npm-registry.sipwise.com/node-pre-gyp/-/node-pre-gyp-0.10.0.tgz", - "integrity": "sha512-G7kEonQLRbcA/mOoFoxvlMrw6Q6dPf92+t/l0DFSMuSlDoWaI9JWIyPwK0jyE1bph//CUEL65/Fz1m2vJbmjQQ==", - "dev": true, - "optional": true, - "requires": { - "detect-libc": "^1.0.2", - "mkdirp": "^0.5.1", - "needle": "^2.2.0", - "nopt": "^4.0.1", - "npm-packlist": "^1.1.6", - "npmlog": "^4.0.2", - "rc": "^1.1.7", - "rimraf": "^2.6.1", - "semver": "^5.3.0", - "tar": "^4" - } - }, - "nopt": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/nopt/-/nopt-4.0.1.tgz", - "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", - "dev": true, - "optional": true, - "requires": { - "abbrev": "1", - "osenv": "^0.1.4" - } - }, - "npm-bundled": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/npm-bundled/-/npm-bundled-1.0.3.tgz", - "integrity": "sha512-ByQ3oJ/5ETLyglU2+8dBObvhfWXX8dtPZDMePCahptliFX2iIuhyEszyFk401PZUNQH20vvdW5MLjJxkwU80Ow==", - "dev": true, - "optional": true - }, - "npm-packlist": { - "version": "1.1.10", - "resolved": "https://npm-registry.sipwise.com/npm-packlist/-/npm-packlist-1.1.10.tgz", - "integrity": "sha512-AQC0Dyhzn4EiYEfIUjCdMl0JJ61I2ER9ukf/sLxJUcZHfo+VyEfz2rMJgLZSS1v30OxPQe1cN0LZA1xbcaVfWA==", - "dev": true, - "optional": true, - "requires": { - "ignore-walk": "^3.0.1", - "npm-bundled": "^1.0.1" - } - }, - "npmlog": { - "version": "4.1.2", - "resolved": "https://npm-registry.sipwise.com/npmlog/-/npmlog-4.1.2.tgz", - "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", - "dev": true, - "optional": true, - "requires": { - "are-we-there-yet": "~1.1.2", - "console-control-strings": "~1.1.0", - "gauge": "~2.7.3", - "set-blocking": "~2.0.0" - } - }, - "number-is-nan": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/number-is-nan/-/number-is-nan-1.0.1.tgz", - "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", - "dev": true, - "optional": true - }, - "object-assign": { - "version": "4.1.1", - "resolved": "https://npm-registry.sipwise.com/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", - "dev": true, - "optional": true - }, - "once": { - "version": "1.4.0", - "resolved": "https://npm-registry.sipwise.com/once/-/once-1.4.0.tgz", - "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", - "dev": true, - "optional": true, - "requires": { - "wrappy": "1" - } - }, - "os-homedir": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/os-homedir/-/os-homedir-1.0.2.tgz", - "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", - "dev": true, - "optional": true - }, - "os-tmpdir": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", - "dev": true, - "optional": true - }, - "osenv": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/osenv/-/osenv-0.1.5.tgz", - "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", - "dev": true, - "optional": true, - "requires": { - "os-homedir": "^1.0.0", - "os-tmpdir": "^1.0.0" - } - }, - "path-is-absolute": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", - "dev": true, - "optional": true - }, - "process-nextick-args": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/process-nextick-args/-/process-nextick-args-2.0.0.tgz", - "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", - "dev": true, - "optional": true - }, - "rc": { - "version": "1.2.7", - "resolved": "https://npm-registry.sipwise.com/rc/-/rc-1.2.7.tgz", - "integrity": "sha512-LdLD8xD4zzLsAT5xyushXDNscEjB7+2ulnl8+r1pnESlYtlJtVSoCMBGr30eDRJ3+2Gq89jK9P9e4tCEH1+ywA==", - "dev": true, - "optional": true, - "requires": { - "deep-extend": "^0.5.1", - "ini": "~1.3.0", - "minimist": "^1.2.0", - "strip-json-comments": "~2.0.1" - }, - "dependencies": { - "minimist": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/minimist/-/minimist-1.2.0.tgz", - "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", - "dev": true, - "optional": true - } - } - }, - "readable-stream": { - "version": "2.3.6", - "resolved": "https://npm-registry.sipwise.com/readable-stream/-/readable-stream-2.3.6.tgz", - "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", - "dev": true, - "optional": true, - "requires": { - "core-util-is": "~1.0.0", - "inherits": "~2.0.3", - "isarray": "~1.0.0", - "process-nextick-args": "~2.0.0", - "safe-buffer": "~5.1.1", - "string_decoder": "~1.1.1", - "util-deprecate": "~1.0.1" - } - }, - "rimraf": { - "version": "2.6.2", - "resolved": "https://npm-registry.sipwise.com/rimraf/-/rimraf-2.6.2.tgz", - "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", - "dev": true, - "optional": true, - "requires": { - "glob": "^7.0.5" - } - }, - "safe-buffer": { - "version": "5.1.1", - "resolved": "https://npm-registry.sipwise.com/safe-buffer/-/safe-buffer-5.1.1.tgz", - "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", - "dev": true, - "optional": true - }, - "safer-buffer": { - "version": "2.1.2", - "resolved": "https://npm-registry.sipwise.com/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", - "dev": true, - "optional": true - }, - "sax": { - "version": "1.2.4", - "resolved": "https://npm-registry.sipwise.com/sax/-/sax-1.2.4.tgz", - "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", - "dev": true, - "optional": true - }, - "semver": { - "version": "5.5.0", - "resolved": "https://npm-registry.sipwise.com/semver/-/semver-5.5.0.tgz", - "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==", - "dev": true, - "optional": true - }, - "set-blocking": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/set-blocking/-/set-blocking-2.0.0.tgz", - "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", - "dev": true, - "optional": true - }, - "signal-exit": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/signal-exit/-/signal-exit-3.0.2.tgz", - "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", - "dev": true, - "optional": true - }, - "string-width": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/string-width/-/string-width-1.0.2.tgz", - "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", - "dev": true, - "optional": true, - "requires": { - "code-point-at": "^1.0.0", - "is-fullwidth-code-point": "^1.0.0", - "strip-ansi": "^3.0.0" - } - }, - "string_decoder": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/string_decoder/-/string_decoder-1.1.1.tgz", - "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", - "dev": true, - "optional": true, - "requires": { - "safe-buffer": "~5.1.0" - } - }, - "strip-ansi": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/strip-ansi/-/strip-ansi-3.0.1.tgz", - "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", - "dev": true, - "optional": true, - "requires": { - "ansi-regex": "^2.0.0" - } - }, - "strip-json-comments": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz", - "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", - "dev": true, - "optional": true - }, - "util-deprecate": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", - "dev": true, - "optional": true - }, - "wide-align": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/wide-align/-/wide-align-1.1.2.tgz", - "integrity": "sha512-ijDLlyQ7s6x1JgCLur53osjm/UXUYD9+0PbYKrBsYisYXzCxN+HC3mYDNy/dWdmf3AwqwU3CXwDCvsNgGK1S0w==", - "dev": true, - "optional": true, - "requires": { - "string-width": "^1.0.2" - } - }, - "wrappy": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", - "dev": true, - "optional": true - } - } - }, - "function-bind": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha1-pWiZ0+o8m6uHS7l3O3xe3pL0iV0=", - "dev": true - }, - "functional-red-black-tree": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", - "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", - "dev": true - }, - "get-caller-file": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/get-caller-file/-/get-caller-file-1.0.3.tgz", - "integrity": "sha1-+Xj6TJDR3+f/LWvtoqUV5xO9z0o=", - "dev": true - }, - "get-func-name": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/get-func-name/-/get-func-name-2.0.0.tgz", - "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", - "dev": true - }, - "get-stream": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/get-stream/-/get-stream-3.0.0.tgz", - "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=" - }, - "get-value": { - "version": "2.0.6", - "resolved": "https://npm-registry.sipwise.com/get-value/-/get-value-2.0.6.tgz", - "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", - "dev": true - }, - "glob": { - "version": "7.1.2", - "resolved": "https://npm-registry.sipwise.com/glob/-/glob-7.1.2.tgz", - "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", - "dev": true, - "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.0.4", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - } - }, - "glob-base": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/glob-base/-/glob-base-0.3.0.tgz", - "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", - "dev": true, - "requires": { - "glob-parent": "^2.0.0", - "is-glob": "^2.0.0" - }, - "dependencies": { - "is-extglob": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", - "dev": true - }, - "is-glob": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-2.0.1.tgz", - "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - } - } - } - }, - "glob-parent": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/glob-parent/-/glob-parent-2.0.0.tgz", - "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", - "dev": true, - "requires": { - "is-glob": "^2.0.0" - }, - "dependencies": { - "is-extglob": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", - "dev": true - }, - "is-glob": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-2.0.1.tgz", - "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - } - } - } - }, - "globals": { - "version": "9.18.0", - "resolved": "https://npm-registry.sipwise.com/globals/-/globals-9.18.0.tgz", - "integrity": "sha1-qjiWs+abSH8X4x7SFD1pqOMMLYo=", - "dev": true - }, - "globby": { - "version": "5.0.0", - "resolved": "https://npm-registry.sipwise.com/globby/-/globby-5.0.0.tgz", - "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", - "dev": true, - "requires": { - "array-union": "^1.0.1", - "arrify": "^1.0.0", - "glob": "^7.0.3", - "object-assign": "^4.0.1", - "pify": "^2.0.0", - "pinkie-promise": "^2.0.0" - }, - "dependencies": { - "pify": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", - "dev": true - } - } - }, - "google-libphonenumber": { - "version": "3.0.7", - "resolved": "https://npm-registry.sipwise.com/google-libphonenumber/-/google-libphonenumber-3.0.7.tgz", - "integrity": "sha1-qQkYgWU2VFoiZL9dSUyzEY8ZXcw=", - "dev": true - }, - "got": { - "version": "7.1.0", - "resolved": "https://npm-registry.sipwise.com/got/-/got-7.1.0.tgz", - "integrity": "sha1-BUUP2ECU5rvqVvRRpDqcKJFmOFo=", - "requires": { - "decompress-response": "^3.2.0", - "duplexer3": "^0.1.4", - "get-stream": "^3.0.0", - "is-plain-obj": "^1.1.0", - "is-retry-allowed": "^1.0.0", - "is-stream": "^1.0.0", - "isurl": "^1.0.0-alpha5", - "lowercase-keys": "^1.0.0", - "p-cancelable": "^0.3.0", - "p-timeout": "^1.1.1", - "safe-buffer": "^5.0.1", - "timed-out": "^4.0.0", - "url-parse-lax": "^1.0.0", - "url-to-options": "^1.0.1" - } - }, - "graceful-fs": { - "version": "4.1.11", - "resolved": "https://npm-registry.sipwise.com/graceful-fs/-/graceful-fs-4.1.11.tgz", - "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", - "dev": true - }, - "growl": { - "version": "1.10.3", - "resolved": "https://npm-registry.sipwise.com/growl/-/growl-1.10.3.tgz", - "integrity": "sha1-GSa6kM8+3+KttJJ/WIC8IsZseQ8=", - "dev": true - }, - "has": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/has/-/has-1.0.3.tgz", - "integrity": "sha1-ci18v8H2qoJB8W3YFOAR4fQeh5Y=", - "dev": true, - "requires": { - "function-bind": "^1.1.1" - } - }, - "has-ansi": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/has-ansi/-/has-ansi-2.0.0.tgz", - "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", - "dev": true, - "requires": { - "ansi-regex": "^2.0.0" - } - }, - "has-binary": { - "version": "0.1.7", - "resolved": "https://npm-registry.sipwise.com/has-binary/-/has-binary-0.1.7.tgz", - "integrity": "sha1-aOYesWIQyVRaClzOBqhzkS/h5ow=", - "dev": true, - "requires": { - "isarray": "0.0.1" - }, - "dependencies": { - "isarray": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/isarray/-/isarray-0.0.1.tgz", - "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", - "dev": true - } - } - }, - "has-cors": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/has-cors/-/has-cors-1.1.0.tgz", - "integrity": "sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk=", - "dev": true - }, - "has-flag": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-1.0.0.tgz", - "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", - "dev": true - }, - "has-symbol-support-x": { - "version": "1.4.2", - "resolved": "https://npm-registry.sipwise.com/has-symbol-support-x/-/has-symbol-support-x-1.4.2.tgz", - "integrity": "sha1-FAn5i8ACR9pF2mfO4KNvKC/yZFU=" - }, - "has-symbols": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/has-symbols/-/has-symbols-1.0.0.tgz", - "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", - "dev": true - }, - "has-to-string-tag-x": { - "version": "1.4.1", - "resolved": "https://npm-registry.sipwise.com/has-to-string-tag-x/-/has-to-string-tag-x-1.4.1.tgz", - "integrity": "sha1-oEWrOD17SyASoAFIqwql8pAETU0=", - "requires": { - "has-symbol-support-x": "^1.4.1" - } - }, - "has-value": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/has-value/-/has-value-1.0.0.tgz", - "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", - "dev": true, - "requires": { - "get-value": "^2.0.6", - "has-values": "^1.0.0", - "isobject": "^3.0.0" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "has-values": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/has-values/-/has-values-1.0.0.tgz", - "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", - "dev": true, - "requires": { - "is-number": "^3.0.0", - "kind-of": "^4.0.0" - }, - "dependencies": { - "is-number": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "kind-of": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-4.0.0.tgz", - "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "hash-base": { - "version": "3.0.4", - "resolved": "https://npm-registry.sipwise.com/hash-base/-/hash-base-3.0.4.tgz", - "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "hash-sum": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/hash-sum/-/hash-sum-1.0.2.tgz", - "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", - "dev": true - }, - "hash.js": { - "version": "1.1.5", - "resolved": "https://npm-registry.sipwise.com/hash.js/-/hash.js-1.1.5.tgz", - "integrity": "sha512-eWI5HG9Np+eHV1KQhisXWwM+4EPPYe5dFX1UZZH7k/E3JzDEazVH+VGlZi6R94ZqImq+A3D1mCEtrFIfg/E7sA==", - "dev": true, - "requires": { - "inherits": "^2.0.3", - "minimalistic-assert": "^1.0.1" - } - }, - "he": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/he/-/he-1.1.1.tgz", - "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", - "dev": true - }, - "hmac-drbg": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz", - "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", - "dev": true, - "requires": { - "hash.js": "^1.0.3", - "minimalistic-assert": "^1.0.0", - "minimalistic-crypto-utils": "^1.0.1" - } - }, - "home-or-tmp": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/home-or-tmp/-/home-or-tmp-2.0.0.tgz", - "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=", - "dev": true, - "requires": { - "os-homedir": "^1.0.0", - "os-tmpdir": "^1.0.1" - } - }, - "hosted-git-info": { - "version": "2.7.1", - "resolved": "https://npm-registry.sipwise.com/hosted-git-info/-/hosted-git-info-2.7.1.tgz", - "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", - "dev": true - }, - "html-comment-regex": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/html-comment-regex/-/html-comment-regex-1.1.1.tgz", - "integrity": "sha1-ZouTd26q5V696POtRkswekljYl4=", - "dev": true - }, - "html-entities": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/html-entities/-/html-entities-1.2.1.tgz", - "integrity": "sha1-DfKTUfByEWNRXfueVUPl9u7VFi8=", - "dev": true - }, - "html-minifier": { - "version": "3.5.19", - "resolved": "https://npm-registry.sipwise.com/html-minifier/-/html-minifier-3.5.19.tgz", - "integrity": "sha512-Qr2JC9nsjK8oCrEmuB430ZIA8YWbF3D5LSjywD75FTuXmeqacwHgIM8wp3vHYzzPbklSjp53RdmDuzR4ub2HzA==", - "dev": true, - "requires": { - "camel-case": "3.0.x", - "clean-css": "4.1.x", - "commander": "2.16.x", - "he": "1.1.x", - "param-case": "2.1.x", - "relateurl": "0.2.x", - "uglify-js": "3.4.x" - } - }, - "html-webpack-plugin": { - "version": "2.30.1", - "resolved": "https://npm-registry.sipwise.com/html-webpack-plugin/-/html-webpack-plugin-2.30.1.tgz", - "integrity": "sha1-f5xCG36pHsRg9WUn1430hO51N9U=", - "dev": true, - "requires": { - "bluebird": "^3.4.7", - "html-minifier": "^3.2.3", - "loader-utils": "^0.2.16", - "lodash": "^4.17.3", - "pretty-error": "^2.0.2", - "toposort": "^1.0.0" - }, - "dependencies": { - "loader-utils": { - "version": "0.2.17", - "resolved": "https://npm-registry.sipwise.com/loader-utils/-/loader-utils-0.2.17.tgz", - "integrity": "sha1-+G5jdNQyBabmxg6RlvF8Apm/s0g=", - "dev": true, - "requires": { - "big.js": "^3.1.3", - "emojis-list": "^2.0.0", - "json5": "^0.5.0", - "object-assign": "^4.0.1" - } - } - } - }, - "htmlparser2": { - "version": "3.9.2", - "resolved": "https://npm-registry.sipwise.com/htmlparser2/-/htmlparser2-3.9.2.tgz", - "integrity": "sha1-G9+HrMoPP55T+k/M6w9LTLsAszg=", - "dev": true, - "requires": { - "domelementtype": "^1.3.0", - "domhandler": "^2.3.0", - "domutils": "^1.5.1", - "entities": "^1.1.1", - "inherits": "^2.0.1", - "readable-stream": "^2.0.2" - } - }, - "http-errors": { - "version": "1.6.3", - "resolved": "https://npm-registry.sipwise.com/http-errors/-/http-errors-1.6.3.tgz", - "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", - "dev": true, - "requires": { - "depd": "~1.1.2", - "inherits": "2.0.3", - "setprototypeof": "1.1.0", - "statuses": ">= 1.4.0 < 2" - } - }, - "http-proxy": { - "version": "1.17.0", - "resolved": "https://npm-registry.sipwise.com/http-proxy/-/http-proxy-1.17.0.tgz", - "integrity": "sha1-etOElGWPhGBeL220Q230EPTlvpo=", - "dev": true, - "requires": { - "eventemitter3": "^3.0.0", - "follow-redirects": "^1.0.0", - "requires-port": "^1.0.0" - } - }, - "http-proxy-middleware": { - "version": "0.19.1", - "resolved": "https://npm-registry.sipwise.com/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz", - "integrity": "sha1-GDx9xKoUeRUDBkmMIQza+WCApDo=", - "dev": true, - "requires": { - "http-proxy": "^1.17.0", - "is-glob": "^4.0.0", - "lodash": "^4.17.11", - "micromatch": "^3.1.10" - }, - "dependencies": { - "arr-diff": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", - "dev": true - }, - "array-unique": { - "version": "0.3.2", - "resolved": "https://npm-registry.sipwise.com/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", - "dev": true - }, - "braces": { - "version": "2.3.2", - "resolved": "https://npm-registry.sipwise.com/braces/-/braces-2.3.2.tgz", - "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", - "dev": true, - "requires": { - "arr-flatten": "^1.1.0", - "array-unique": "^0.3.2", - "extend-shallow": "^2.0.1", - "fill-range": "^4.0.0", - "isobject": "^3.0.1", - "repeat-element": "^1.1.2", - "snapdragon": "^0.8.1", - "snapdragon-node": "^2.0.1", - "split-string": "^3.0.2", - "to-regex": "^3.0.1" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "expand-brackets": { - "version": "2.1.4", - "resolved": "https://npm-registry.sipwise.com/expand-brackets/-/expand-brackets-2.1.4.tgz", - "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", - "dev": true, - "requires": { - "debug": "^2.3.3", - "define-property": "^0.2.5", - "extend-shallow": "^2.0.1", - "posix-character-classes": "^0.1.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - }, - "is-accessor-descriptor": { - "version": "0.1.6", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", - "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-data-descriptor": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", - "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-descriptor": { - "version": "0.1.6", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-0.1.6.tgz", - "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", - "dev": true, - "requires": { - "is-accessor-descriptor": "^0.1.6", - "is-data-descriptor": "^0.1.4", - "kind-of": "^5.0.0" - } - }, - "kind-of": { - "version": "5.1.0", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-5.1.0.tgz", - "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", - "dev": true - } - } - }, - "extglob": { - "version": "2.0.4", - "resolved": "https://npm-registry.sipwise.com/extglob/-/extglob-2.0.4.tgz", - "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", - "dev": true, - "requires": { - "array-unique": "^0.3.2", - "define-property": "^1.0.0", - "expand-brackets": "^2.1.4", - "extend-shallow": "^2.0.1", - "fragment-cache": "^0.2.1", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", - "dev": true, - "requires": { - "is-descriptor": "^1.0.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "fill-range": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/fill-range/-/fill-range-4.0.0.tgz", - "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", - "dev": true, - "requires": { - "extend-shallow": "^2.0.1", - "is-number": "^3.0.0", - "repeat-string": "^1.6.1", - "to-regex-range": "^2.1.0" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "is-accessor-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-data-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-descriptor": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", - "dev": true, - "requires": { - "is-accessor-descriptor": "^1.0.0", - "is-data-descriptor": "^1.0.0", - "kind-of": "^6.0.2" - } - }, - "is-number": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, - "kind-of": { - "version": "6.0.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - }, - "micromatch": { - "version": "3.1.10", - "resolved": "https://npm-registry.sipwise.com/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } - } - } - }, - "https-browserify": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/https-browserify/-/https-browserify-1.0.0.tgz", - "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=", - "dev": true - }, - "iconv-lite": { - "version": "0.4.23", - "resolved": "https://npm-registry.sipwise.com/iconv-lite/-/iconv-lite-0.4.23.tgz", - "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", - "dev": true, - "requires": { - "safer-buffer": ">= 2.1.2 < 3" - } - }, - "icss-replace-symbols": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/icss-replace-symbols/-/icss-replace-symbols-1.1.0.tgz", - "integrity": "sha1-Bupvg2ead0njhs/h/oEq5dsiPe0=", - "dev": true - }, - "icss-utils": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/icss-utils/-/icss-utils-2.1.0.tgz", - "integrity": "sha1-g/Cg7DeL8yRheLbCrZE28TWxyWI=", - "dev": true, - "requires": { - "postcss": "^6.0.1" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "postcss": { - "version": "6.0.23", - "resolved": "https://npm-registry.sipwise.com/postcss/-/postcss-6.0.23.tgz", - "integrity": "sha1-YcgswyisYOZ3ZF+XkFTrmLwOMyQ=", - "dev": true, - "requires": { - "chalk": "^2.4.1", - "source-map": "^0.6.1", - "supports-color": "^5.4.0" - } - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "ieee754": { - "version": "1.1.12", - "resolved": "https://npm-registry.sipwise.com/ieee754/-/ieee754-1.1.12.tgz", - "integrity": "sha512-GguP+DRY+pJ3soyIiGPTvdiVXjZ+DbXOxGpXn3eMvNW4x4irjqXm4wHKscC+TfxSJ0yw/S1F24tqdMNsMZTiLA==", - "dev": true - }, - "ignore": { - "version": "3.3.10", - "resolved": "https://npm-registry.sipwise.com/ignore/-/ignore-3.3.10.tgz", - "integrity": "sha1-Cpf7h2mG6AgcYxFg+PnziRV/AEM=", - "dev": true - }, - "imurmurhash": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/imurmurhash/-/imurmurhash-0.1.4.tgz", - "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", - "dev": true - }, - "indexes-of": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/indexes-of/-/indexes-of-1.0.1.tgz", - "integrity": "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=", - "dev": true - }, - "indexof": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/indexof/-/indexof-0.0.1.tgz", - "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=", - "dev": true - }, - "inflight": { - "version": "1.0.6", - "resolved": "https://npm-registry.sipwise.com/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", - "dev": true, - "requires": { - "once": "^1.3.0", - "wrappy": "1" - } - }, - "inherits": { - "version": "2.0.3", - "resolved": "https://npm-registry.sipwise.com/inherits/-/inherits-2.0.3.tgz", - "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", - "dev": true - }, - "inquirer": { - "version": "3.3.0", - "resolved": "https://npm-registry.sipwise.com/inquirer/-/inquirer-3.3.0.tgz", - "integrity": "sha1-ndLyrXZdyrH/BEO0kUQqILoifck=", - "dev": true, - "requires": { - "ansi-escapes": "^3.0.0", - "chalk": "^2.0.0", - "cli-cursor": "^2.1.0", - "cli-width": "^2.0.0", - "external-editor": "^2.0.4", - "figures": "^2.0.0", - "lodash": "^4.3.0", - "mute-stream": "0.0.7", - "run-async": "^2.2.0", - "rx-lite": "^4.0.8", - "rx-lite-aggregates": "^4.0.8", - "string-width": "^2.1.0", - "strip-ansi": "^4.0.0", - "through": "^2.3.6" - }, - "dependencies": { - "ansi-regex": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/ansi-regex/-/ansi-regex-3.0.0.tgz", - "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", - "dev": true - }, - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "strip-ansi": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/strip-ansi/-/strip-ansi-4.0.0.tgz", - "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", - "dev": true, - "requires": { - "ansi-regex": "^3.0.0" - } - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "interpret": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/interpret/-/interpret-1.1.0.tgz", - "integrity": "sha1-ftGxQQxqDg94z5XTuEQMY/eLhhQ=", - "dev": true - }, - "invariant": { - "version": "2.2.4", - "resolved": "https://npm-registry.sipwise.com/invariant/-/invariant-2.2.4.tgz", - "integrity": "sha1-YQ88ksk1nOHbYW5TgAjSP/NRWOY=", - "dev": true, - "requires": { - "loose-envify": "^1.0.0" - } - }, - "invert-kv": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/invert-kv/-/invert-kv-1.0.0.tgz", - "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=", - "dev": true - }, - "ipaddr.js": { - "version": "1.6.0", - "resolved": "https://npm-registry.sipwise.com/ipaddr.js/-/ipaddr.js-1.6.0.tgz", - "integrity": "sha1-4/o1e3c9phnybpXwSdBVxyeW+Gs=", - "dev": true - }, - "is-absolute-url": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/is-absolute-url/-/is-absolute-url-2.1.0.tgz", - "integrity": "sha1-UFMN+4T8yap9vnhS6Do3uTufKqY=", - "dev": true - }, - "is-accessor-descriptor": { - "version": "0.1.6", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", - "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - } - }, - "is-arrayish": { - "version": "0.2.1", - "resolved": "https://npm-registry.sipwise.com/is-arrayish/-/is-arrayish-0.2.1.tgz", - "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", - "dev": true - }, - "is-binary-path": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/is-binary-path/-/is-binary-path-1.0.1.tgz", - "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", - "dev": true, - "requires": { - "binary-extensions": "^1.0.0" - } - }, - "is-buffer": { - "version": "1.1.6", - "resolved": "https://npm-registry.sipwise.com/is-buffer/-/is-buffer-1.1.6.tgz", - "integrity": "sha1-76ouqdqg16suoTqXsritUf776L4=", - "dev": true - }, - "is-builtin-module": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-builtin-module/-/is-builtin-module-1.0.0.tgz", - "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", - "dev": true, - "requires": { - "builtin-modules": "^1.0.0" - } - }, - "is-data-descriptor": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", - "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - } - }, - "is-descriptor": { - "version": "0.1.6", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-0.1.6.tgz", - "integrity": "sha1-Nm2CQN3kh8pRgjsaufB6EKeCUco=", - "dev": true, - "requires": { - "is-accessor-descriptor": "^0.1.6", - "is-data-descriptor": "^0.1.4", - "kind-of": "^5.0.0" - }, - "dependencies": { - "kind-of": { - "version": "5.1.0", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-5.1.0.tgz", - "integrity": "sha1-cpyR4thXt6QZofmqZWhcTDP1hF0=", - "dev": true - } - } - }, - "is-directory": { - "version": "0.3.1", - "resolved": "https://npm-registry.sipwise.com/is-directory/-/is-directory-0.3.1.tgz", - "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", - "dev": true - }, - "is-dotfile": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/is-dotfile/-/is-dotfile-1.0.3.tgz", - "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", - "dev": true - }, - "is-equal-shallow": { - "version": "0.1.3", - "resolved": "https://npm-registry.sipwise.com/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", - "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", - "dev": true, - "requires": { - "is-primitive": "^2.0.0" - } - }, - "is-extendable": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/is-extendable/-/is-extendable-0.1.1.tgz", - "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", - "dev": true - }, - "is-extglob": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", - "dev": true - }, - "is-finite": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/is-finite/-/is-finite-1.0.2.tgz", - "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", - "dev": true, - "requires": { - "number-is-nan": "^1.0.0" - } - }, - "is-fullwidth-code-point": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", - "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", - "dev": true - }, - "is-glob": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-4.0.1.tgz", - "integrity": "sha1-dWfb6fL14kZ7x3q4PEopSCQHpdw=", - "dev": true, - "requires": { - "is-extglob": "^2.1.1" - } - }, - "is-number": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/is-number/-/is-number-2.1.0.tgz", - "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - } - }, - "is-object": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/is-object/-/is-object-1.0.1.tgz", - "integrity": "sha1-iVJojF7C/9awPsyF52ngKQMINHA=" - }, - "is-path-cwd": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-path-cwd/-/is-path-cwd-1.0.0.tgz", - "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", - "dev": true - }, - "is-path-in-cwd": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz", - "integrity": "sha512-FjV1RTW48E7CWM7eE/J2NJvAEEVektecDBVBE5Hh3nM1Jd0kvhHtX68Pr3xsDf857xt3Y4AkwVULK1Vku62aaQ==", - "dev": true, - "requires": { - "is-path-inside": "^1.0.0" - } - }, - "is-path-inside": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/is-path-inside/-/is-path-inside-1.0.1.tgz", - "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", - "dev": true, - "requires": { - "path-is-inside": "^1.0.1" - } - }, - "is-plain-obj": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz", - "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=" - }, - "is-plain-object": { - "version": "2.0.4", - "resolved": "https://npm-registry.sipwise.com/is-plain-object/-/is-plain-object-2.0.4.tgz", - "integrity": "sha1-LBY7P6+xtgbZ0Xko8FwqHDjgdnc=", - "dev": true, - "requires": { - "isobject": "^3.0.1" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "is-posix-bracket": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", - "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", - "dev": true - }, - "is-primitive": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/is-primitive/-/is-primitive-2.0.0.tgz", - "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", - "dev": true - }, - "is-promise": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/is-promise/-/is-promise-2.1.0.tgz", - "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", - "dev": true - }, - "is-resolvable": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/is-resolvable/-/is-resolvable-1.1.0.tgz", - "integrity": "sha1-+xj4fOH+uSUWnJpAfBkxijIG7Yg=", - "dev": true - }, - "is-retry-allowed": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/is-retry-allowed/-/is-retry-allowed-1.1.0.tgz", - "integrity": "sha1-EaBgVotnM5REAz0BJaYaINVk+zQ=" - }, - "is-stream": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/is-stream/-/is-stream-1.1.0.tgz", - "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" - }, - "is-svg": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/is-svg/-/is-svg-2.1.0.tgz", - "integrity": "sha1-z2EJDaDZ77yrhyLeum8DIgjbsOk=", - "dev": true, - "requires": { - "html-comment-regex": "^1.1.0" - } - }, - "is-windows": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/is-windows/-/is-windows-1.0.2.tgz", - "integrity": "sha1-0YUOuXkezRjmGCzhKjDzlmNLsZ0=", - "dev": true - }, - "is-wsl": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/is-wsl/-/is-wsl-1.1.0.tgz", - "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=", - "dev": true - }, - "isarray": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/isarray/-/isarray-1.0.0.tgz", - "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", - "dev": true - }, - "isbinaryfile": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/isbinaryfile/-/isbinaryfile-3.0.2.tgz", - "integrity": "sha1-Sj6XTsDLqQBNP8bN5yCeppNopiE=", - "dev": true - }, - "isexe": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", - "dev": true - }, - "isobject": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-2.1.0.tgz", - "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", - "dev": true, - "requires": { - "isarray": "1.0.0" - } - }, - "isurl": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/isurl/-/isurl-1.0.0.tgz", - "integrity": "sha1-sn9PSfPNqj6kSgpbfzRi5u3DnWc=", - "requires": { - "has-to-string-tag-x": "^1.2.0", - "is-object": "^1.0.1" - } - }, - "js-base64": { - "version": "2.4.8", - "resolved": "https://npm-registry.sipwise.com/js-base64/-/js-base64-2.4.8.tgz", - "integrity": "sha512-hm2nYpDrwoO/OzBhdcqs/XGT6XjSuSSCVEpia+Kl2J6x4CYt5hISlVL/AYU1khoDXv0AQVgxtdJySb9gjAn56Q==", - "dev": true - }, - "js-tokens": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/js-tokens/-/js-tokens-3.0.2.tgz", - "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", - "dev": true - }, - "js-yaml": { - "version": "3.13.1", - "resolved": "https://npm-registry.sipwise.com/js-yaml/-/js-yaml-3.13.1.tgz", - "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", - "dev": true, - "requires": { - "argparse": "^1.0.7", - "esprima": "^4.0.0" - }, - "dependencies": { - "esprima": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", - "dev": true - } - } - }, - "jsesc": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/jsesc/-/jsesc-1.3.0.tgz", - "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=", - "dev": true - }, - "json-loader": { - "version": "0.5.7", - "resolved": "https://npm-registry.sipwise.com/json-loader/-/json-loader-0.5.7.tgz", - "integrity": "sha1-3KFKcCNf+C8KyaOr62DTN6NlGF0=", - "dev": true - }, - "json-schema-traverse": { - "version": "0.3.1", - "resolved": "https://npm-registry.sipwise.com/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", - "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", - "dev": true - }, - "json-stable-stringify-without-jsonify": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", - "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", - "dev": true - }, - "json3": { - "version": "3.3.2", - "resolved": "https://npm-registry.sipwise.com/json3/-/json3-3.3.2.tgz", - "integrity": "sha1-PAQ0dD35Pi9cQq7nsZvLSDV19OE=", - "dev": true - }, - "json5": { - "version": "0.5.1", - "resolved": "https://npm-registry.sipwise.com/json5/-/json5-0.5.1.tgz", - "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", - "dev": true - }, - "karma": { - "version": "1.7.1", - "resolved": "https://npm-registry.sipwise.com/karma/-/karma-1.7.1.tgz", - "integrity": "sha1-hcwI6eCiLXzpzKN8ShvoJPaisa4=", - "dev": true, - "requires": { - "bluebird": "^3.3.0", - "body-parser": "^1.16.1", - "chokidar": "^1.4.1", - "colors": "^1.1.0", - "combine-lists": "^1.0.0", - "connect": "^3.6.0", - "core-js": "^2.2.0", - "di": "^0.0.1", - "dom-serialize": "^2.2.0", - "expand-braces": "^0.1.1", - "glob": "^7.1.1", - "graceful-fs": "^4.1.2", - "http-proxy": "^1.13.0", - "isbinaryfile": "^3.0.0", - "lodash": "^3.8.0", - "log4js": "^0.6.31", - "mime": "^1.3.4", - "minimatch": "^3.0.2", - "optimist": "^0.6.1", - "qjobs": "^1.1.4", - "range-parser": "^1.2.0", - "rimraf": "^2.6.0", - "safe-buffer": "^5.0.1", - "socket.io": "1.7.3", - "source-map": "^0.5.3", - "tmp": "0.0.31", - "useragent": "^2.1.12" - }, - "dependencies": { - "lodash": { - "version": "3.10.1", - "resolved": "https://npm-registry.sipwise.com/lodash/-/lodash-3.10.1.tgz", - "integrity": "sha1-W/Rejkm6QYnhfUgnid/RW9FAt7Y=", - "dev": true - }, - "tmp": { - "version": "0.0.31", - "resolved": "https://npm-registry.sipwise.com/tmp/-/tmp-0.0.31.tgz", - "integrity": "sha1-jzirlDjhcxXl29izZX6L+yd65Kc=", - "dev": true, - "requires": { - "os-tmpdir": "~1.0.1" - } - } - } - }, - "karma-chrome-launcher": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/karma-chrome-launcher/-/karma-chrome-launcher-2.2.0.tgz", - "integrity": "sha1-zxudBxNswY/iOTJ9JGVMPbw2is8=", - "dev": true, - "requires": { - "fs-access": "^1.0.0", - "which": "^1.2.1" - } - }, - "karma-firefox-launcher": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/karma-firefox-launcher/-/karma-firefox-launcher-1.1.0.tgz", - "integrity": "sha512-LbZ5/XlIXLeQ3cqnCbYLn+rOVhuMIK9aZwlP6eOLGzWdo1UVp7t6CN3DP4SafiRLjexKwHeKHDm0c38Mtd3VxA==", - "dev": true - }, - "karma-junit-reporter": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/karma-junit-reporter/-/karma-junit-reporter-1.2.0.tgz", - "integrity": "sha1-T5xAzt+xo5X4rvh2q/lhiZF8Y5Y=", - "dev": true, - "requires": { - "path-is-absolute": "^1.0.0", - "xmlbuilder": "8.2.2" - } - }, - "karma-mocha": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/karma-mocha/-/karma-mocha-1.3.0.tgz", - "integrity": "sha1-7qrH/8DiAetjxGdEDStpx883eL8=", - "dev": true, - "requires": { - "minimist": "1.2.0" - }, - "dependencies": { - "minimist": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/minimist/-/minimist-1.2.0.tgz", - "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", - "dev": true - } - } - }, - "karma-webpack": { - "version": "2.0.13", - "resolved": "https://npm-registry.sipwise.com/karma-webpack/-/karma-webpack-2.0.13.tgz", - "integrity": "sha1-z1bjBWwVt3R6C7IUD8mmvkHdnwI=", - "dev": true, - "requires": { - "async": "^2.0.0", - "babel-runtime": "^6.0.0", - "loader-utils": "^1.0.0", - "lodash": "^4.0.0", - "source-map": "^0.5.6", - "webpack-dev-middleware": "^1.12.0" - } - }, - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - }, - "last-call-webpack-plugin": { - "version": "2.1.2", - "resolved": "https://npm-registry.sipwise.com/last-call-webpack-plugin/-/last-call-webpack-plugin-2.1.2.tgz", - "integrity": "sha1-rYDG4xCZgpTS7SGApo6VieR2jEQ=", - "dev": true, - "requires": { - "lodash": "^4.17.4", - "webpack-sources": "^1.0.1" - } - }, - "lazy-cache": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/lazy-cache/-/lazy-cache-1.0.4.tgz", - "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=", - "dev": true - }, - "lcid": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/lcid/-/lcid-1.0.0.tgz", - "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", - "dev": true, - "requires": { - "invert-kv": "^1.0.0" - } - }, - "levn": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/levn/-/levn-0.3.0.tgz", - "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", - "dev": true, - "requires": { - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2" - } - }, - "load-json-file": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/load-json-file/-/load-json-file-2.0.0.tgz", - "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", - "dev": true, - "requires": { - "graceful-fs": "^4.1.2", - "parse-json": "^2.2.0", - "pify": "^2.0.0", - "strip-bom": "^3.0.0" - }, - "dependencies": { - "pify": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", - "dev": true - } - } - }, - "load-script": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/load-script/-/load-script-1.0.0.tgz", - "integrity": "sha1-BJGTngvuVkPuSUp+PaPSuscMbKQ=", - "dev": true - }, - "loader-fs-cache": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/loader-fs-cache/-/loader-fs-cache-1.0.1.tgz", - "integrity": "sha1-VuC/CL2XCLJqdltoUJhAyN7J/bw=", - "dev": true, - "requires": { - "find-cache-dir": "^0.1.1", - "mkdirp": "0.5.1" - }, - "dependencies": { - "find-cache-dir": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/find-cache-dir/-/find-cache-dir-0.1.1.tgz", - "integrity": "sha1-yN765XyKUqinhPnjHFfHQumToLk=", - "dev": true, - "requires": { - "commondir": "^1.0.1", - "mkdirp": "^0.5.1", - "pkg-dir": "^1.0.0" - } - }, - "find-up": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/find-up/-/find-up-1.1.2.tgz", - "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", - "dev": true, - "requires": { - "path-exists": "^2.0.0", - "pinkie-promise": "^2.0.0" - } - }, - "path-exists": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/path-exists/-/path-exists-2.1.0.tgz", - "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", - "dev": true, - "requires": { - "pinkie-promise": "^2.0.0" - } - }, - "pkg-dir": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/pkg-dir/-/pkg-dir-1.0.0.tgz", - "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", - "dev": true, - "requires": { - "find-up": "^1.0.0" - } - } - } - }, - "loader-runner": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/loader-runner/-/loader-runner-2.3.0.tgz", - "integrity": "sha1-9IKuqC1UPgeSFwDVpG7yb9rGuKI=", - "dev": true - }, - "loader-utils": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/loader-utils/-/loader-utils-1.1.0.tgz", - "integrity": "sha1-yYrvSIvM7aL/teLeZG1qdUQp9c0=", - "dev": true, - "requires": { - "big.js": "^3.1.3", - "emojis-list": "^2.0.0", - "json5": "^0.5.0" - } - }, - "locate-path": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/locate-path/-/locate-path-2.0.0.tgz", - "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", - "dev": true, - "requires": { - "p-locate": "^2.0.0", - "path-exists": "^3.0.0" - } - }, - "lodash": { - "version": "4.17.15", - "resolved": "https://npm-registry.sipwise.com/lodash/-/lodash-4.17.15.tgz", - "integrity": "sha1-tEf2ZwoEVbv+7dETku/zMOoJdUg=", - "dev": true - }, - "lodash.camelcase": { - "version": "4.3.0", - "resolved": "https://npm-registry.sipwise.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", - "integrity": "sha1-soqmKIorn8ZRA1x3EfZathkDMaY=", - "dev": true - }, - "lodash.clonedeep": { - "version": "4.5.0", - "resolved": "https://npm-registry.sipwise.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", - "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", - "dev": true - }, - "lodash.debounce": { - "version": "4.0.8", - "resolved": "https://npm-registry.sipwise.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz", - "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", - "dev": true - }, - "lodash.memoize": { - "version": "4.1.2", - "resolved": "https://npm-registry.sipwise.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz", - "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=", - "dev": true - }, - "lodash.uniq": { - "version": "4.5.0", - "resolved": "https://npm-registry.sipwise.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz", - "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=", - "dev": true - }, - "log4js": { - "version": "0.6.38", - "resolved": "https://npm-registry.sipwise.com/log4js/-/log4js-0.6.38.tgz", - "integrity": "sha1-LElBFmldb7JUgJQ9P8hy5mKlIv0=", - "dev": true, - "requires": { - "readable-stream": "~1.0.2", - "semver": "~4.3.3" - }, - "dependencies": { - "isarray": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/isarray/-/isarray-0.0.1.tgz", - "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", - "dev": true - }, - "readable-stream": { - "version": "1.0.34", - "resolved": "https://npm-registry.sipwise.com/readable-stream/-/readable-stream-1.0.34.tgz", - "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", - "dev": true, - "requires": { - "core-util-is": "~1.0.0", - "inherits": "~2.0.1", - "isarray": "0.0.1", - "string_decoder": "~0.10.x" - } - }, - "semver": { - "version": "4.3.6", - "resolved": "https://npm-registry.sipwise.com/semver/-/semver-4.3.6.tgz", - "integrity": "sha1-MAvG4OhjdPe6YQaLWx7NV/xlMto=", - "dev": true - }, - "string_decoder": { - "version": "0.10.31", - "resolved": "https://npm-registry.sipwise.com/string_decoder/-/string_decoder-0.10.31.tgz", - "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", - "dev": true - } - } - }, - "longest": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/longest/-/longest-1.0.1.tgz", - "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=", - "dev": true - }, - "loose-envify": { - "version": "1.4.0", - "resolved": "https://npm-registry.sipwise.com/loose-envify/-/loose-envify-1.4.0.tgz", - "integrity": "sha1-ce5R+nvkyuwaY4OffmgtgTLTDK8=", - "dev": true, - "requires": { - "js-tokens": "^3.0.0 || ^4.0.0" - } - }, - "lower-case": { - "version": "1.1.4", - "resolved": "https://npm-registry.sipwise.com/lower-case/-/lower-case-1.1.4.tgz", - "integrity": "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=", - "dev": true - }, - "lowercase-keys": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/lowercase-keys/-/lowercase-keys-1.0.1.tgz", - "integrity": "sha1-b54wtHCE2XGnyCD/FabFFnt0wm8=" - }, - "lru-cache": { - "version": "4.1.3", - "resolved": "https://npm-registry.sipwise.com/lru-cache/-/lru-cache-4.1.3.tgz", - "integrity": "sha512-fFEhvcgzuIoJVUF8fYr5KR0YqxD238zgObTps31YdADwPPAp82a4M8TrckkWyx7ekNlf9aBcVn81cFwwXngrJA==", - "dev": true, - "requires": { - "pseudomap": "^1.0.2", - "yallist": "^2.1.2" - } - }, - "make-dir": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/make-dir/-/make-dir-1.3.0.tgz", - "integrity": "sha1-ecEDO4BRW9bSTsmTPoYMp17ifww=", - "dev": true, - "requires": { - "pify": "^3.0.0" - } - }, - "map-cache": { - "version": "0.2.2", - "resolved": "https://npm-registry.sipwise.com/map-cache/-/map-cache-0.2.2.tgz", - "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", - "dev": true - }, - "map-visit": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/map-visit/-/map-visit-1.0.0.tgz", - "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", - "dev": true, - "requires": { - "object-visit": "^1.0.0" - } - }, - "math-expression-evaluator": { - "version": "1.2.17", - "resolved": "https://npm-registry.sipwise.com/math-expression-evaluator/-/math-expression-evaluator-1.2.17.tgz", - "integrity": "sha1-3oGf282E3M2PrlnGrreWFbnSZqw=", - "dev": true - }, - "math-random": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/math-random/-/math-random-1.0.1.tgz", - "integrity": "sha1-izqsWIuKZuSXXjzepn97sylgH6w=", - "dev": true - }, - "md5.js": { - "version": "1.3.4", - "resolved": "https://npm-registry.sipwise.com/md5.js/-/md5.js-1.3.4.tgz", - "integrity": "sha1-6b296UogpawYsENA/Fdk1bCdkB0=", - "dev": true, - "requires": { - "hash-base": "^3.0.0", - "inherits": "^2.0.1" - } - }, - "media-typer": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/media-typer/-/media-typer-0.3.0.tgz", - "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", - "dev": true - }, - "mem": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/mem/-/mem-1.1.0.tgz", - "integrity": "sha1-Xt1StIXKHZAP5kiVUFOZoN+kX3Y=", - "dev": true, - "requires": { - "mimic-fn": "^1.0.0" - } - }, - "memory-fs": { - "version": "0.4.1", - "resolved": "https://npm-registry.sipwise.com/memory-fs/-/memory-fs-0.4.1.tgz", - "integrity": "sha1-OpoguEYlI+RHz7x+i7gO1me/xVI=", - "dev": true, - "requires": { - "errno": "^0.1.3", - "readable-stream": "^2.0.1" - } - }, - "merge-descriptors": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz", - "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=", - "dev": true - }, - "methods": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/methods/-/methods-1.1.2.tgz", - "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", - "dev": true - }, - "micromatch": { - "version": "2.3.11", - "resolved": "https://npm-registry.sipwise.com/micromatch/-/micromatch-2.3.11.tgz", - "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", - "dev": true, - "requires": { - "arr-diff": "^2.0.0", - "array-unique": "^0.2.1", - "braces": "^1.8.2", - "expand-brackets": "^0.1.4", - "extglob": "^0.3.1", - "filename-regex": "^2.0.0", - "is-extglob": "^1.0.0", - "is-glob": "^2.0.1", - "kind-of": "^3.0.2", - "normalize-path": "^2.0.1", - "object.omit": "^2.0.0", - "parse-glob": "^3.0.4", - "regex-cache": "^0.4.2" - }, - "dependencies": { - "is-extglob": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", - "dev": true - }, - "is-glob": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-2.0.1.tgz", - "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - } - } - } - }, - "miller-rabin": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/miller-rabin/-/miller-rabin-4.0.1.tgz", - "integrity": "sha1-8IA1HIZbDcViqEYpZtqlNUPHik0=", - "dev": true, - "requires": { - "bn.js": "^4.0.0", - "brorand": "^1.0.1" - } - }, - "mime": { - "version": "1.4.1", - "resolved": "https://npm-registry.sipwise.com/mime/-/mime-1.4.1.tgz", - "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==", - "dev": true - }, - "mime-db": { - "version": "1.35.0", - "resolved": "https://npm-registry.sipwise.com/mime-db/-/mime-db-1.35.0.tgz", - "integrity": "sha512-JWT/IcCTsB0Io3AhWUMjRqucrHSPsSf2xKLaRldJVULioggvkJvggZ3VXNNSRkCddE6D+BUI4HEIZIA2OjwIvg==", - "dev": true - }, - "mime-types": { - "version": "2.1.19", - "resolved": "https://npm-registry.sipwise.com/mime-types/-/mime-types-2.1.19.tgz", - "integrity": "sha512-P1tKYHVSZ6uFo26mtnve4HQFE3koh1UWVkp8YUC+ESBHe945xWSoXuHHiGarDqcEZ+whpCDnlNw5LON0kLo+sw==", - "dev": true, - "requires": { - "mime-db": "~1.35.0" - } - }, - "mimic-fn": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/mimic-fn/-/mimic-fn-1.2.0.tgz", - "integrity": "sha1-ggyGo5M0ZA6ZUWkovQP8qIBX0CI=", - "dev": true - }, - "mimic-response": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/mimic-response/-/mimic-response-1.0.1.tgz", - "integrity": "sha1-SSNTiHju9CBjy4o+OweYeBSHqxs=" - }, - "minimalistic-assert": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", - "integrity": "sha1-LhlN4ERibUoQ5/f7wAznPoPk1cc=", - "dev": true - }, - "minimalistic-crypto-utils": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", - "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=", - "dev": true - }, - "minimatch": { - "version": "3.0.4", - "resolved": "https://npm-registry.sipwise.com/minimatch/-/minimatch-3.0.4.tgz", - "integrity": "sha1-UWbihkV/AzBgZL5Ul+jbsMPTIIM=", - "dev": true, - "requires": { - "brace-expansion": "^1.1.7" - } - }, - "minimist": { - "version": "0.0.8", - "resolved": "https://npm-registry.sipwise.com/minimist/-/minimist-0.0.8.tgz", - "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", - "dev": true - }, - "minipass": { - "version": "2.3.5", - "resolved": "https://npm-registry.sipwise.com/minipass/-/minipass-2.3.5.tgz", - "integrity": "sha512-Gi1W4k059gyRbyVUZQ4mEqLm0YIUiGYfvxhF6SIlk3ui1WVxMTGfGdQ2SInh3PDrRTVvPKgULkpJtT4RH10+VA==", - "dev": true, - "optional": true, - "requires": { - "safe-buffer": "^5.1.2", - "yallist": "^3.0.0" - }, - "dependencies": { - "yallist": { - "version": "3.0.3", - "resolved": "https://npm-registry.sipwise.com/yallist/-/yallist-3.0.3.tgz", - "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A==", - "dev": true, - "optional": true - } - } - }, - "minizlib": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/minizlib/-/minizlib-1.2.1.tgz", - "integrity": "sha512-7+4oTUOWKg7AuL3vloEWekXY2/D20cevzsrNT2kGWm+39J9hGTCBv8VI5Pm5lXZ/o3/mdR4f8rflAPhnQb8mPA==", - "dev": true, - "optional": true, - "requires": { - "minipass": "^2.2.1" - } - }, - "mixin-deep": { - "version": "1.3.2", - "resolved": "https://npm-registry.sipwise.com/mixin-deep/-/mixin-deep-1.3.2.tgz", - "integrity": "sha1-ESC0PcNZp4Xc5ltVuC4lfM9HlWY=", - "dev": true, - "requires": { - "for-in": "^1.0.2", - "is-extendable": "^1.0.1" - }, - "dependencies": { - "is-extendable": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/is-extendable/-/is-extendable-1.0.1.tgz", - "integrity": "sha1-p0cPnkJnM9gb2B4RVSZOOjUHyrQ=", - "dev": true, - "requires": { - "is-plain-object": "^2.0.4" - } - } - } - }, - "mkdirp": { - "version": "0.5.1", - "resolved": "https://npm-registry.sipwise.com/mkdirp/-/mkdirp-0.5.1.tgz", - "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", - "dev": true, - "requires": { - "minimist": "0.0.8" - } - }, - "mocha": { - "version": "4.1.0", - "resolved": "https://npm-registry.sipwise.com/mocha/-/mocha-4.1.0.tgz", - "integrity": "sha512-0RVnjg1HJsXY2YFDoTNzcc1NKhYuXKRrBAG2gDygmJJA136Cs2QlRliZG1mA0ap7cuaT30mw16luAeln+4RiNA==", - "dev": true, - "requires": { - "browser-stdout": "1.3.0", - "commander": "2.11.0", - "debug": "3.1.0", - "diff": "3.3.1", - "escape-string-regexp": "1.0.5", - "glob": "7.1.2", - "growl": "1.10.3", - "he": "1.1.1", - "mkdirp": "0.5.1", - "supports-color": "4.4.0" - }, - "dependencies": { - "commander": { - "version": "2.11.0", - "resolved": "https://npm-registry.sipwise.com/commander/-/commander-2.11.0.tgz", - "integrity": "sha1-FXFS/R56bI2YpbcVzzdt+SgARWM=", - "dev": true - }, - "debug": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-3.1.0.tgz", - "integrity": "sha1-W7WgZyYotkFJVmuhaBnmFRjGcmE=", - "dev": true, - "requires": { - "ms": "2.0.0" - } - }, - "has-flag": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-2.0.0.tgz", - "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", - "dev": true - }, - "supports-color": { - "version": "4.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-4.4.0.tgz", - "integrity": "sha1-iD992rwWUUKyphQn8zUt7RldGj4=", - "dev": true, - "requires": { - "has-flag": "^2.0.0" - } - } - } - }, - "moment": { - "version": "2.22.2", - "resolved": "https://npm-registry.sipwise.com/moment/-/moment-2.22.2.tgz", - "integrity": "sha1-PCV/mDn8DpP/UxSWMiOeuQeD/2Y=", - "dev": true - }, - "ms": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", - "dev": true - }, - "mute-stream": { - "version": "0.0.7", - "resolved": "https://npm-registry.sipwise.com/mute-stream/-/mute-stream-0.0.7.tgz", - "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", - "dev": true - }, - "nan": { - "version": "2.11.1", - "resolved": "https://npm-registry.sipwise.com/nan/-/nan-2.11.1.tgz", - "integrity": "sha512-iji6k87OSXa0CcrLl9z+ZiYSuR2o+c0bGuNmXdrhTQTakxytAFsC56SArGYoiHlJlFoHSnvmhpceZJaXkVuOtA==", - "dev": true, - "optional": true - }, - "nanomatch": { - "version": "1.2.13", - "resolved": "https://npm-registry.sipwise.com/nanomatch/-/nanomatch-1.2.13.tgz", - "integrity": "sha1-uHqKpPwN6P5r6IiVs4mD/yZb0Rk=", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "fragment-cache": "^0.2.1", - "is-windows": "^1.0.2", - "kind-of": "^6.0.2", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "arr-diff": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", - "dev": true - }, - "array-unique": { - "version": "0.3.2", - "resolved": "https://npm-registry.sipwise.com/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", - "dev": true - }, - "kind-of": { - "version": "6.0.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - } - } - }, - "natural-compare": { - "version": "1.4.0", - "resolved": "https://npm-registry.sipwise.com/natural-compare/-/natural-compare-1.4.0.tgz", - "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", - "dev": true - }, - "negotiator": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/negotiator/-/negotiator-0.6.1.tgz", - "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=", - "dev": true - }, - "neo-async": { - "version": "2.5.1", - "resolved": "https://npm-registry.sipwise.com/neo-async/-/neo-async-2.5.1.tgz", - "integrity": "sha512-3KL3fvuRkZ7s4IFOMfztb7zJp3QaVWnBeGoJlgB38XnCRPj/0tLzzLG5IB8NYOHbJ8g8UGrgZv44GLDk6CxTxA==", - "dev": true - }, - "next-tick": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/next-tick/-/next-tick-1.0.0.tgz", - "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=", - "dev": true - }, - "no-case": { - "version": "2.3.2", - "resolved": "https://npm-registry.sipwise.com/no-case/-/no-case-2.3.2.tgz", - "integrity": "sha1-YLgTOWvjmz8SiKTB7V0efSi0ZKw=", - "dev": true, - "requires": { - "lower-case": "^1.1.1" - } - }, - "node-libs-browser": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/node-libs-browser/-/node-libs-browser-2.1.0.tgz", - "integrity": "sha512-5AzFzdoIMb89hBGMZglEegffzgRg+ZFoUmisQ8HI4j1KDdpx13J0taNp2y9xPbur6W61gepGDDotGBVQ7mfUCg==", - "dev": true, - "requires": { - "assert": "^1.1.1", - "browserify-zlib": "^0.2.0", - "buffer": "^4.3.0", - "console-browserify": "^1.1.0", - "constants-browserify": "^1.0.0", - "crypto-browserify": "^3.11.0", - "domain-browser": "^1.1.1", - "events": "^1.0.0", - "https-browserify": "^1.0.0", - "os-browserify": "^0.3.0", - "path-browserify": "0.0.0", - "process": "^0.11.10", - "punycode": "^1.2.4", - "querystring-es3": "^0.2.0", - "readable-stream": "^2.3.3", - "stream-browserify": "^2.0.1", - "stream-http": "^2.7.2", - "string_decoder": "^1.0.0", - "timers-browserify": "^2.0.4", - "tty-browserify": "0.0.0", - "url": "^0.11.0", - "util": "^0.10.3", - "vm-browserify": "0.0.4" - }, - "dependencies": { - "punycode": { - "version": "1.4.1", - "resolved": "https://npm-registry.sipwise.com/punycode/-/punycode-1.4.1.tgz", - "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", - "dev": true - } - } - }, - "normalize-package-data": { - "version": "2.4.0", - "resolved": "https://npm-registry.sipwise.com/normalize-package-data/-/normalize-package-data-2.4.0.tgz", - "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", - "dev": true, - "requires": { - "hosted-git-info": "^2.1.4", - "is-builtin-module": "^1.0.0", - "semver": "2 || 3 || 4 || 5", - "validate-npm-package-license": "^3.0.1" - } - }, - "normalize-path": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/normalize-path/-/normalize-path-2.1.1.tgz", - "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", - "dev": true, - "requires": { - "remove-trailing-separator": "^1.0.1" - } - }, - "normalize-range": { - "version": "0.1.2", - "resolved": "https://npm-registry.sipwise.com/normalize-range/-/normalize-range-0.1.2.tgz", - "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=", - "dev": true - }, - "normalize-url": { - "version": "1.9.1", - "resolved": "https://npm-registry.sipwise.com/normalize-url/-/normalize-url-1.9.1.tgz", - "integrity": "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=", - "dev": true, - "requires": { - "object-assign": "^4.0.1", - "prepend-http": "^1.0.0", - "query-string": "^4.1.0", - "sort-keys": "^1.0.0" - } - }, - "npm-run-path": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/npm-run-path/-/npm-run-path-2.0.2.tgz", - "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", - "dev": true, - "requires": { - "path-key": "^2.0.0" - } - }, - "nth-check": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/nth-check/-/nth-check-1.0.1.tgz", - "integrity": "sha1-mSms32KPwsQQmN6rgqxYDPFJquQ=", - "dev": true, - "requires": { - "boolbase": "~1.0.0" - } - }, - "null-check": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/null-check/-/null-check-1.0.0.tgz", - "integrity": "sha1-l33/1xdgErnsMNKjnbXPcqBDnt0=", - "dev": true - }, - "num2fraction": { - "version": "1.2.2", - "resolved": "https://npm-registry.sipwise.com/num2fraction/-/num2fraction-1.2.2.tgz", - "integrity": "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=", - "dev": true - }, - "number-is-nan": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/number-is-nan/-/number-is-nan-1.0.1.tgz", - "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", - "dev": true - }, - "object-assign": { - "version": "4.1.1", - "resolved": "https://npm-registry.sipwise.com/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", - "dev": true - }, - "object-component": { - "version": "0.0.3", - "resolved": "https://npm-registry.sipwise.com/object-component/-/object-component-0.0.3.tgz", - "integrity": "sha1-8MaapQ78lbhmwYb0AKM3acsvEpE=", - "dev": true - }, - "object-copy": { - "version": "0.1.0", - "resolved": "https://npm-registry.sipwise.com/object-copy/-/object-copy-0.1.0.tgz", - "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", - "dev": true, - "requires": { - "copy-descriptor": "^0.1.0", - "define-property": "^0.2.5", - "kind-of": "^3.0.3" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - } - } - }, - "object-hash": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/object-hash/-/object-hash-1.3.0.tgz", - "integrity": "sha512-05KzQ70lSeGSrZJQXE5wNDiTkBJDlUT/myi6RX9dVIvz7a7Qh4oH93BQdiPMn27nldYvVQCKMUaM83AfizZlsQ==", - "dev": true - }, - "object-keys": { - "version": "1.0.12", - "resolved": "https://npm-registry.sipwise.com/object-keys/-/object-keys-1.0.12.tgz", - "integrity": "sha512-FTMyFUm2wBcGHnH2eXmz7tC6IwlqQZ6mVZ+6dm6vZ4IQIHjs6FdNsQBuKGPuUUUY6NfJw2PshC08Tn6LzLDOag==", - "dev": true - }, - "object-visit": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/object-visit/-/object-visit-1.0.1.tgz", - "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", - "dev": true, - "requires": { - "isobject": "^3.0.0" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "object.assign": { - "version": "4.1.0", - "resolved": "https://npm-registry.sipwise.com/object.assign/-/object.assign-4.1.0.tgz", - "integrity": "sha1-lovxEA15Vrs8oIbwBvhGs7xACNo=", - "dev": true, - "requires": { - "define-properties": "^1.1.2", - "function-bind": "^1.1.1", - "has-symbols": "^1.0.0", - "object-keys": "^1.0.11" - } - }, - "object.omit": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/object.omit/-/object.omit-2.0.1.tgz", - "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", - "dev": true, - "requires": { - "for-own": "^0.1.4", - "is-extendable": "^0.1.1" - } - }, - "object.pick": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/object.pick/-/object.pick-1.3.0.tgz", - "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", - "dev": true, - "requires": { - "isobject": "^3.0.1" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "on-finished": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/on-finished/-/on-finished-2.3.0.tgz", - "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", - "dev": true, - "requires": { - "ee-first": "1.1.1" - } - }, - "once": { - "version": "1.4.0", - "resolved": "https://npm-registry.sipwise.com/once/-/once-1.4.0.tgz", - "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", - "dev": true, - "requires": { - "wrappy": "1" - } - }, - "onetime": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/onetime/-/onetime-2.0.1.tgz", - "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", - "dev": true, - "requires": { - "mimic-fn": "^1.0.0" - } - }, - "opn": { - "version": "5.3.0", - "resolved": "https://npm-registry.sipwise.com/opn/-/opn-5.3.0.tgz", - "integrity": "sha512-bYJHo/LOmoTd+pfiYhfZDnf9zekVJrY+cnS2a5F2x+w5ppvTqObojTP7WiFG+kVZs9Inw+qQ/lw7TroWwhdd2g==", - "dev": true, - "requires": { - "is-wsl": "^1.1.0" - } - }, - "optimist": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/optimist/-/optimist-0.6.1.tgz", - "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=", - "dev": true, - "requires": { - "minimist": "~0.0.1", - "wordwrap": "~0.0.2" - }, - "dependencies": { - "wordwrap": { - "version": "0.0.3", - "resolved": "https://npm-registry.sipwise.com/wordwrap/-/wordwrap-0.0.3.tgz", - "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", - "dev": true - } - } - }, - "optimize-css-assets-webpack-plugin": { - "version": "3.2.0", - "resolved": "https://npm-registry.sipwise.com/optimize-css-assets-webpack-plugin/-/optimize-css-assets-webpack-plugin-3.2.0.tgz", - "integrity": "sha512-Fjn7wyyadPAriuH2DHamDQw5B8GohEWbroBkKoPeP+vSF2PIAPI7WDihi8WieMRb/At4q7Ea7zTKaMDuSoIAAg==", - "dev": true, - "requires": { - "cssnano": "^3.4.0", - "last-call-webpack-plugin": "^2.1.2" - } - }, - "optionator": { - "version": "0.8.2", - "resolved": "https://npm-registry.sipwise.com/optionator/-/optionator-0.8.2.tgz", - "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", - "dev": true, - "requires": { - "deep-is": "~0.1.3", - "fast-levenshtein": "~2.0.4", - "levn": "~0.3.0", - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2", - "wordwrap": "~1.0.0" - } - }, - "options": { - "version": "0.0.6", - "resolved": "https://npm-registry.sipwise.com/options/-/options-0.0.6.tgz", - "integrity": "sha1-7CLTEoBrtT5zF3Pnza788cZDEo8=", - "dev": true - }, - "os-browserify": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/os-browserify/-/os-browserify-0.3.0.tgz", - "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=", - "dev": true - }, - "os-homedir": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/os-homedir/-/os-homedir-1.0.2.tgz", - "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", - "dev": true - }, - "os-locale": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/os-locale/-/os-locale-2.1.0.tgz", - "integrity": "sha1-QrwpAKa1uL0XN2yOiCtlr8zyS/I=", - "dev": true, - "requires": { - "execa": "^0.7.0", - "lcid": "^1.0.0", - "mem": "^1.1.0" - } - }, - "os-tmpdir": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", - "dev": true - }, - "p-cancelable": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/p-cancelable/-/p-cancelable-0.3.0.tgz", - "integrity": "sha1-ueEjgAvOu3rBOkeb4ZW1B7mNMPo=" - }, - "p-finally": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/p-finally/-/p-finally-1.0.0.tgz", - "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" - }, - "p-limit": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/p-limit/-/p-limit-1.3.0.tgz", - "integrity": "sha1-uGvV8MJWkJEcdZD8v8IBDVSzzLg=", - "dev": true, - "requires": { - "p-try": "^1.0.0" - } - }, - "p-locate": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/p-locate/-/p-locate-2.0.0.tgz", - "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", - "dev": true, - "requires": { - "p-limit": "^1.1.0" - } - }, - "p-timeout": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/p-timeout/-/p-timeout-1.2.1.tgz", - "integrity": "sha1-XrOzU7f86Z8QGhA4iAuwVOu+o4Y=", - "requires": { - "p-finally": "^1.0.0" - } - }, - "p-try": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/p-try/-/p-try-1.0.0.tgz", - "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", - "dev": true - }, - "pako": { - "version": "1.0.6", - "resolved": "https://npm-registry.sipwise.com/pako/-/pako-1.0.6.tgz", - "integrity": "sha512-lQe48YPsMJAig+yngZ87Lus+NF+3mtu7DVOBu6b/gHO1YpKwIj5AWjZ/TOS7i46HD/UixzWb1zeWDZfGZ3iYcg==", - "dev": true - }, - "param-case": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/param-case/-/param-case-2.1.1.tgz", - "integrity": "sha1-35T9jPZTHs915r75oIWPvHK+Ikc=", - "dev": true, - "requires": { - "no-case": "^2.2.0" - } - }, - "parse-asn1": { - "version": "5.1.1", - "resolved": "https://npm-registry.sipwise.com/parse-asn1/-/parse-asn1-5.1.1.tgz", - "integrity": "sha512-KPx7flKXg775zZpnp9SxJlz00gTd4BmJ2yJufSc44gMCRrRQ7NSzAcSJQfifuOLgW6bEi+ftrALtsgALeB2Adw==", - "dev": true, - "requires": { - "asn1.js": "^4.0.0", - "browserify-aes": "^1.0.0", - "create-hash": "^1.1.0", - "evp_bytestokey": "^1.0.0", - "pbkdf2": "^3.0.3" - } - }, - "parse-glob": { - "version": "3.0.4", - "resolved": "https://npm-registry.sipwise.com/parse-glob/-/parse-glob-3.0.4.tgz", - "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", - "dev": true, - "requires": { - "glob-base": "^0.3.0", - "is-dotfile": "^1.0.0", - "is-extglob": "^1.0.0", - "is-glob": "^2.0.0" - }, - "dependencies": { - "is-extglob": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", - "dev": true - }, - "is-glob": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-2.0.1.tgz", - "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - } - } - } - }, - "parse-json": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/parse-json/-/parse-json-2.2.0.tgz", - "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", - "dev": true, - "requires": { - "error-ex": "^1.2.0" - } - }, - "parsejson": { - "version": "0.0.3", - "resolved": "https://npm-registry.sipwise.com/parsejson/-/parsejson-0.0.3.tgz", - "integrity": "sha1-q343WfIJ7OmUN5c/fQ8fZK4OZKs=", - "dev": true, - "requires": { - "better-assert": "~1.0.0" - } - }, - "parseqs": { - "version": "0.0.5", - "resolved": "https://npm-registry.sipwise.com/parseqs/-/parseqs-0.0.5.tgz", - "integrity": "sha1-1SCKNzjkZ2bikbouoXNoSSGouJ0=", - "dev": true, - "requires": { - "better-assert": "~1.0.0" - } - }, - "parseuri": { - "version": "0.0.5", - "resolved": "https://npm-registry.sipwise.com/parseuri/-/parseuri-0.0.5.tgz", - "integrity": "sha1-gCBKUNTbt3m/3G6+J3jZDkvOMgo=", - "dev": true, - "requires": { - "better-assert": "~1.0.0" - } - }, - "parseurl": { - "version": "1.3.2", - "resolved": "https://npm-registry.sipwise.com/parseurl/-/parseurl-1.3.2.tgz", - "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=", - "dev": true - }, - "pascalcase": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/pascalcase/-/pascalcase-0.1.1.tgz", - "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", - "dev": true - }, - "path-browserify": { - "version": "0.0.0", - "resolved": "https://npm-registry.sipwise.com/path-browserify/-/path-browserify-0.0.0.tgz", - "integrity": "sha1-oLhwcpquIUAFt9UDLsLLuw+0RRo=", - "dev": true - }, - "path-dirname": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/path-dirname/-/path-dirname-1.0.2.tgz", - "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", - "dev": true - }, - "path-exists": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", - "dev": true - }, - "path-is-absolute": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", - "dev": true - }, - "path-is-inside": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/path-is-inside/-/path-is-inside-1.0.2.tgz", - "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", - "dev": true - }, - "path-key": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/path-key/-/path-key-2.0.1.tgz", - "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", - "dev": true - }, - "path-parse": { - "version": "1.0.5", - "resolved": "https://npm-registry.sipwise.com/path-parse/-/path-parse-1.0.5.tgz", - "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=", - "dev": true - }, - "path-to-regexp": { - "version": "0.1.7", - "resolved": "https://npm-registry.sipwise.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz", - "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=", - "dev": true - }, - "path-type": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/path-type/-/path-type-2.0.0.tgz", - "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", - "dev": true, - "requires": { - "pify": "^2.0.0" - }, - "dependencies": { - "pify": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", - "dev": true - } - } - }, - "pathval": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/pathval/-/pathval-1.1.0.tgz", - "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=", - "dev": true - }, - "pbkdf2": { - "version": "3.0.16", - "resolved": "https://npm-registry.sipwise.com/pbkdf2/-/pbkdf2-3.0.16.tgz", - "integrity": "sha512-y4CXP3thSxqf7c0qmOF+9UeOTrifiVTIM+u7NWlq+PRsHbr7r7dpCmvzrZxa96JJUNi0Y5w9VqG5ZNeCVMoDcA==", - "dev": true, - "requires": { - "create-hash": "^1.1.2", - "create-hmac": "^1.1.4", - "ripemd160": "^2.0.1", - "safe-buffer": "^5.0.1", - "sha.js": "^2.4.8" - } - }, - "pify": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/pify/-/pify-3.0.0.tgz", - "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", - "dev": true - }, - "pinkie": { - "version": "2.0.4", - "resolved": "https://npm-registry.sipwise.com/pinkie/-/pinkie-2.0.4.tgz", - "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", - "dev": true - }, - "pinkie-promise": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/pinkie-promise/-/pinkie-promise-2.0.1.tgz", - "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", - "dev": true, - "requires": { - "pinkie": "^2.0.0" - } - }, - "pkg-dir": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/pkg-dir/-/pkg-dir-2.0.0.tgz", - "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", - "dev": true, - "requires": { - "find-up": "^2.1.0" - } - }, - "pluralize": { - "version": "7.0.0", - "resolved": "https://npm-registry.sipwise.com/pluralize/-/pluralize-7.0.0.tgz", - "integrity": "sha1-KYuJ34uTsCIdv0Ia0rGx6iP8Z3c=", - "dev": true - }, - "posix-character-classes": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz", - "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", - "dev": true - }, - "postcss": { - "version": "5.2.18", - "resolved": "https://npm-registry.sipwise.com/postcss/-/postcss-5.2.18.tgz", - "integrity": "sha1-ut+hSX1GJE9jkPWLMZgw2RB4U8U=", - "dev": true, - "requires": { - "chalk": "^1.1.3", - "js-base64": "^2.1.9", - "source-map": "^0.5.6", - "supports-color": "^3.2.3" - } - }, - "postcss-calc": { - "version": "5.3.1", - "resolved": "https://npm-registry.sipwise.com/postcss-calc/-/postcss-calc-5.3.1.tgz", - "integrity": "sha1-d7rnypKK2FcW4v2kLyYb98HWW14=", - "dev": true, - "requires": { - "postcss": "^5.0.2", - "postcss-message-helpers": "^2.0.0", - "reduce-css-calc": "^1.2.6" - } - }, - "postcss-colormin": { - "version": "2.2.2", - "resolved": "https://npm-registry.sipwise.com/postcss-colormin/-/postcss-colormin-2.2.2.tgz", - "integrity": "sha1-ZjFBfV8OkJo9fsJrJMio0eT5bks=", - "dev": true, - "requires": { - "colormin": "^1.0.5", - "postcss": "^5.0.13", - "postcss-value-parser": "^3.2.3" - } - }, - "postcss-convert-values": { - "version": "2.6.1", - "resolved": "https://npm-registry.sipwise.com/postcss-convert-values/-/postcss-convert-values-2.6.1.tgz", - "integrity": "sha1-u9hZPFwf0uPRwyK7kl3K6Nrk1i0=", - "dev": true, - "requires": { - "postcss": "^5.0.11", - "postcss-value-parser": "^3.1.2" - } - }, - "postcss-discard-comments": { - "version": "2.0.4", - "resolved": "https://npm-registry.sipwise.com/postcss-discard-comments/-/postcss-discard-comments-2.0.4.tgz", - "integrity": "sha1-vv6J+v1bPazlzM5Rt2uBUUvgDj0=", - "dev": true, - "requires": { - "postcss": "^5.0.14" - } - }, - "postcss-discard-duplicates": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/postcss-discard-duplicates/-/postcss-discard-duplicates-2.1.0.tgz", - "integrity": "sha1-uavye4isGIFYpesSq8riAmO5GTI=", - "dev": true, - "requires": { - "postcss": "^5.0.4" - } - }, - "postcss-discard-empty": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/postcss-discard-empty/-/postcss-discard-empty-2.1.0.tgz", - "integrity": "sha1-0rS9nVztXr2Nyt52QMfXzX9PkrU=", - "dev": true, - "requires": { - "postcss": "^5.0.14" - } - }, - "postcss-discard-overridden": { - "version": "0.1.1", - "resolved": "https://npm-registry.sipwise.com/postcss-discard-overridden/-/postcss-discard-overridden-0.1.1.tgz", - "integrity": "sha1-ix6vVU9ob7KIzYdMVWZ7CqNmjVg=", - "dev": true, - "requires": { - "postcss": "^5.0.16" - } - }, - "postcss-discard-unused": { - "version": "2.2.3", - "resolved": "https://npm-registry.sipwise.com/postcss-discard-unused/-/postcss-discard-unused-2.2.3.tgz", - "integrity": "sha1-vOMLLMWR/8Y0Mitfs0ZLbZNPRDM=", - "dev": true, - "requires": { - "postcss": "^5.0.14", - "uniqs": "^2.0.0" - } - }, - "postcss-filter-plugins": { - "version": "2.0.3", - "resolved": "https://npm-registry.sipwise.com/postcss-filter-plugins/-/postcss-filter-plugins-2.0.3.tgz", - "integrity": "sha1-giRf34IzcEFkXkdxFNjlk6oYuOw=", - "dev": true, - "requires": { - "postcss": "^5.0.4" - } - }, - "postcss-load-config": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/postcss-load-config/-/postcss-load-config-1.2.0.tgz", - "integrity": "sha1-U56a/J3chiASHr+djDZz4M5Q0oo=", - "dev": true, - "requires": { - "cosmiconfig": "^2.1.0", - "object-assign": "^4.1.0", - "postcss-load-options": "^1.2.0", - "postcss-load-plugins": "^2.3.0" - } - }, - "postcss-load-options": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/postcss-load-options/-/postcss-load-options-1.2.0.tgz", - "integrity": "sha1-sJixVZ3awt8EvAuzdfmaXP4rbYw=", - "dev": true, - "requires": { - "cosmiconfig": "^2.1.0", - "object-assign": "^4.1.0" - } - }, - "postcss-load-plugins": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/postcss-load-plugins/-/postcss-load-plugins-2.3.0.tgz", - "integrity": "sha1-dFdoEWWZrKLwCfrUJrABdQSdjZI=", - "dev": true, - "requires": { - "cosmiconfig": "^2.1.1", - "object-assign": "^4.1.0" - } - }, - "postcss-loader": { - "version": "1.3.3", - "resolved": "https://npm-registry.sipwise.com/postcss-loader/-/postcss-loader-1.3.3.tgz", - "integrity": "sha1-piHqH6KQYqg5cqRvVEhncTAZFus=", - "dev": true, - "requires": { - "loader-utils": "^1.0.2", - "object-assign": "^4.1.1", - "postcss": "^5.2.15", - "postcss-load-config": "^1.2.0" - } - }, - "postcss-merge-idents": { - "version": "2.1.7", - "resolved": "https://npm-registry.sipwise.com/postcss-merge-idents/-/postcss-merge-idents-2.1.7.tgz", - "integrity": "sha1-TFUwMTwI4dWzu/PSu8dH4njuonA=", - "dev": true, - "requires": { - "has": "^1.0.1", - "postcss": "^5.0.10", - "postcss-value-parser": "^3.1.1" - } - }, - "postcss-merge-longhand": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/postcss-merge-longhand/-/postcss-merge-longhand-2.0.2.tgz", - "integrity": "sha1-I9kM0Sewp3mUkVMyc5A0oaTz1lg=", - "dev": true, - "requires": { - "postcss": "^5.0.4" - } - }, - "postcss-merge-rules": { - "version": "2.1.2", - "resolved": "https://npm-registry.sipwise.com/postcss-merge-rules/-/postcss-merge-rules-2.1.2.tgz", - "integrity": "sha1-0d9d+qexrMO+VT8OnhDofGG19yE=", - "dev": true, - "requires": { - "browserslist": "^1.5.2", - "caniuse-api": "^1.5.2", - "postcss": "^5.0.4", - "postcss-selector-parser": "^2.2.2", - "vendors": "^1.0.0" - } - }, - "postcss-message-helpers": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/postcss-message-helpers/-/postcss-message-helpers-2.0.0.tgz", - "integrity": "sha1-pPL0+rbk/gAvCu0ABHjN9S+bpg4=", - "dev": true - }, - "postcss-minify-font-values": { - "version": "1.0.5", - "resolved": "https://npm-registry.sipwise.com/postcss-minify-font-values/-/postcss-minify-font-values-1.0.5.tgz", - "integrity": "sha1-S1jttWZB66fIR0qzUmyv17vey2k=", - "dev": true, - "requires": { - "object-assign": "^4.0.1", - "postcss": "^5.0.4", - "postcss-value-parser": "^3.0.2" - } - }, - "postcss-minify-gradients": { - "version": "1.0.5", - "resolved": "https://npm-registry.sipwise.com/postcss-minify-gradients/-/postcss-minify-gradients-1.0.5.tgz", - "integrity": "sha1-Xb2hE3NwP4PPtKPqOIHY11/15uE=", - "dev": true, - "requires": { - "postcss": "^5.0.12", - "postcss-value-parser": "^3.3.0" - } - }, - "postcss-minify-params": { - "version": "1.2.2", - "resolved": "https://npm-registry.sipwise.com/postcss-minify-params/-/postcss-minify-params-1.2.2.tgz", - "integrity": "sha1-rSzgcTc7lDs9kwo/pZo1jCjW8fM=", - "dev": true, - "requires": { - "alphanum-sort": "^1.0.1", - "postcss": "^5.0.2", - "postcss-value-parser": "^3.0.2", - "uniqs": "^2.0.0" - } - }, - "postcss-minify-selectors": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/postcss-minify-selectors/-/postcss-minify-selectors-2.1.1.tgz", - "integrity": "sha1-ssapjAByz5G5MtGkllCBFDEXNb8=", - "dev": true, - "requires": { - "alphanum-sort": "^1.0.2", - "has": "^1.0.1", - "postcss": "^5.0.14", - "postcss-selector-parser": "^2.0.0" - } - }, - "postcss-modules-extract-imports": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/postcss-modules-extract-imports/-/postcss-modules-extract-imports-1.2.0.tgz", - "integrity": "sha1-ZhQOzs447wa/DT41XWm/WdFB6oU=", - "dev": true, - "requires": { - "postcss": "^6.0.1" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "postcss": { - "version": "6.0.23", - "resolved": "https://npm-registry.sipwise.com/postcss/-/postcss-6.0.23.tgz", - "integrity": "sha1-YcgswyisYOZ3ZF+XkFTrmLwOMyQ=", - "dev": true, - "requires": { - "chalk": "^2.4.1", - "source-map": "^0.6.1", - "supports-color": "^5.4.0" - } - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "postcss-modules-local-by-default": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/postcss-modules-local-by-default/-/postcss-modules-local-by-default-1.2.0.tgz", - "integrity": "sha1-99gMOYxaOT+nlkRmvRlQCn1hwGk=", - "dev": true, - "requires": { - "css-selector-tokenizer": "^0.7.0", - "postcss": "^6.0.1" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "postcss": { - "version": "6.0.23", - "resolved": "https://npm-registry.sipwise.com/postcss/-/postcss-6.0.23.tgz", - "integrity": "sha1-YcgswyisYOZ3ZF+XkFTrmLwOMyQ=", - "dev": true, - "requires": { - "chalk": "^2.4.1", - "source-map": "^0.6.1", - "supports-color": "^5.4.0" - } - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "postcss-modules-scope": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/postcss-modules-scope/-/postcss-modules-scope-1.1.0.tgz", - "integrity": "sha1-1upkmUx5+XtipytCb75gVqGUu5A=", - "dev": true, - "requires": { - "css-selector-tokenizer": "^0.7.0", - "postcss": "^6.0.1" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "postcss": { - "version": "6.0.23", - "resolved": "https://npm-registry.sipwise.com/postcss/-/postcss-6.0.23.tgz", - "integrity": "sha1-YcgswyisYOZ3ZF+XkFTrmLwOMyQ=", - "dev": true, - "requires": { - "chalk": "^2.4.1", - "source-map": "^0.6.1", - "supports-color": "^5.4.0" - } - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "postcss-modules-values": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/postcss-modules-values/-/postcss-modules-values-1.3.0.tgz", - "integrity": "sha1-7P+p1+GSUYOJ9CrQ6D9yrsRW6iA=", - "dev": true, - "requires": { - "icss-replace-symbols": "^1.1.0", - "postcss": "^6.0.1" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "postcss": { - "version": "6.0.23", - "resolved": "https://npm-registry.sipwise.com/postcss/-/postcss-6.0.23.tgz", - "integrity": "sha1-YcgswyisYOZ3ZF+XkFTrmLwOMyQ=", - "dev": true, - "requires": { - "chalk": "^2.4.1", - "source-map": "^0.6.1", - "supports-color": "^5.4.0" - } - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "postcss-normalize-charset": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/postcss-normalize-charset/-/postcss-normalize-charset-1.1.1.tgz", - "integrity": "sha1-757nEhLX/nWceO0WL2HtYrXLk/E=", - "dev": true, - "requires": { - "postcss": "^5.0.5" - } - }, - "postcss-normalize-url": { - "version": "3.0.8", - "resolved": "https://npm-registry.sipwise.com/postcss-normalize-url/-/postcss-normalize-url-3.0.8.tgz", - "integrity": "sha1-EI90s/L82viRov+j6kWSJ5/HgiI=", - "dev": true, - "requires": { - "is-absolute-url": "^2.0.0", - "normalize-url": "^1.4.0", - "postcss": "^5.0.14", - "postcss-value-parser": "^3.2.3" - } - }, - "postcss-ordered-values": { - "version": "2.2.3", - "resolved": "https://npm-registry.sipwise.com/postcss-ordered-values/-/postcss-ordered-values-2.2.3.tgz", - "integrity": "sha1-7sbCpntsQSqNsgQud/6NpD+VwR0=", - "dev": true, - "requires": { - "postcss": "^5.0.4", - "postcss-value-parser": "^3.0.1" - } - }, - "postcss-reduce-idents": { - "version": "2.4.0", - "resolved": "https://npm-registry.sipwise.com/postcss-reduce-idents/-/postcss-reduce-idents-2.4.0.tgz", - "integrity": "sha1-wsbSDMlYKE9qv75j92Cb9AkFmtM=", - "dev": true, - "requires": { - "postcss": "^5.0.4", - "postcss-value-parser": "^3.0.2" - } - }, - "postcss-reduce-initial": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/postcss-reduce-initial/-/postcss-reduce-initial-1.0.1.tgz", - "integrity": "sha1-aPgGlfBF0IJjqHmtJA343WT2ROo=", - "dev": true, - "requires": { - "postcss": "^5.0.4" - } - }, - "postcss-reduce-transforms": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/postcss-reduce-transforms/-/postcss-reduce-transforms-1.0.4.tgz", - "integrity": "sha1-/3b02CEkN7McKYpC0uFEQCV3GuE=", - "dev": true, - "requires": { - "has": "^1.0.1", - "postcss": "^5.0.8", - "postcss-value-parser": "^3.0.1" - } - }, - "postcss-selector-parser": { - "version": "2.2.3", - "resolved": "https://npm-registry.sipwise.com/postcss-selector-parser/-/postcss-selector-parser-2.2.3.tgz", - "integrity": "sha1-+UN3iGBsPJrO4W/+jYsWKX8nu5A=", - "dev": true, - "requires": { - "flatten": "^1.0.2", - "indexes-of": "^1.0.1", - "uniq": "^1.0.1" - } - }, - "postcss-svgo": { - "version": "2.1.6", - "resolved": "https://npm-registry.sipwise.com/postcss-svgo/-/postcss-svgo-2.1.6.tgz", - "integrity": "sha1-tt8YqmE7Zm4TPwittSGcJoSsEI0=", - "dev": true, - "requires": { - "is-svg": "^2.0.0", - "postcss": "^5.0.14", - "postcss-value-parser": "^3.2.3", - "svgo": "^0.7.0" - } - }, - "postcss-unique-selectors": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/postcss-unique-selectors/-/postcss-unique-selectors-2.0.2.tgz", - "integrity": "sha1-mB1X0p3csz57Hf4f1DuGSfkzyh0=", - "dev": true, - "requires": { - "alphanum-sort": "^1.0.1", - "postcss": "^5.0.4", - "uniqs": "^2.0.0" - } - }, - "postcss-value-parser": { - "version": "3.3.0", - "resolved": "https://npm-registry.sipwise.com/postcss-value-parser/-/postcss-value-parser-3.3.0.tgz", - "integrity": "sha1-h/OPnxj3dKSrTIojL1xc6IcqnRU=", - "dev": true - }, - "postcss-zindex": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/postcss-zindex/-/postcss-zindex-2.2.0.tgz", - "integrity": "sha1-0hCd3AVbka9n/EyzsCWUZjnSryI=", - "dev": true, - "requires": { - "has": "^1.0.1", - "postcss": "^5.0.4", - "uniqs": "^2.0.0" - } - }, - "prelude-ls": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/prelude-ls/-/prelude-ls-1.1.2.tgz", - "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", - "dev": true - }, - "prepend-http": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/prepend-http/-/prepend-http-1.0.4.tgz", - "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=" - }, - "preserve": { - "version": "0.2.0", - "resolved": "https://npm-registry.sipwise.com/preserve/-/preserve-0.2.0.tgz", - "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", - "dev": true - }, - "prettier": { - "version": "1.13.7", - "resolved": "https://npm-registry.sipwise.com/prettier/-/prettier-1.13.7.tgz", - "integrity": "sha512-KIU72UmYPGk4MujZGYMFwinB7lOf2LsDNGSOC8ufevsrPLISrZbNJlWstRi3m0AMuszbH+EFSQ/r6w56RSPK6w==", - "dev": true - }, - "pretty-error": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/pretty-error/-/pretty-error-2.1.1.tgz", - "integrity": "sha1-X0+HyPkeWuPzuoerTPXgOxoX8aM=", - "dev": true, - "requires": { - "renderkid": "^2.0.1", - "utila": "~0.4" - } - }, - "private": { - "version": "0.1.8", - "resolved": "https://npm-registry.sipwise.com/private/-/private-0.1.8.tgz", - "integrity": "sha1-I4Hts2ifelPWUxkAYPz4ItLzaP8=", - "dev": true - }, - "process": { - "version": "0.11.10", - "resolved": "https://npm-registry.sipwise.com/process/-/process-0.11.10.tgz", - "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=", - "dev": true - }, - "process-nextick-args": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/process-nextick-args/-/process-nextick-args-2.0.0.tgz", - "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", - "dev": true - }, - "progress": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/progress/-/progress-2.0.0.tgz", - "integrity": "sha1-ihvjZr+Pwj2yvSPxDG/pILQ4nR8=", - "dev": true - }, - "progress-bar-webpack-plugin": { - "version": "1.11.0", - "resolved": "https://npm-registry.sipwise.com/progress-bar-webpack-plugin/-/progress-bar-webpack-plugin-1.11.0.tgz", - "integrity": "sha512-XT6r8strD6toU0ZVip25baJINo7uE4BD4H8d4vhOV4GIK5PvNNky8GYJ2wMmVoYP8eo/sSmtNWn0Vw7zWDDE3A==", - "dev": true, - "requires": { - "chalk": "^1.1.1", - "object.assign": "^4.0.1", - "progress": "^1.1.8" - }, - "dependencies": { - "progress": { - "version": "1.1.8", - "resolved": "https://npm-registry.sipwise.com/progress/-/progress-1.1.8.tgz", - "integrity": "sha1-4mDHj2Fhzdmw5WzD4Khd4Xx6V74=", - "dev": true - } - } - }, - "proxy-addr": { - "version": "2.0.3", - "resolved": "https://npm-registry.sipwise.com/proxy-addr/-/proxy-addr-2.0.3.tgz", - "integrity": "sha512-jQTChiCJteusULxjBp8+jftSQE5Obdl3k4cnmLA6WXtK6XFuWRnvVL7aCiBqaLPM8c4ph0S4tKna8XvmIwEnXQ==", - "dev": true, - "requires": { - "forwarded": "~0.1.2", - "ipaddr.js": "1.6.0" - } - }, - "prr": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/prr/-/prr-1.0.1.tgz", - "integrity": "sha1-0/wRS6BplaRexok/SEzrHXj19HY=", - "dev": true - }, - "pseudomap": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/pseudomap/-/pseudomap-1.0.2.tgz", - "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", - "dev": true - }, - "public-encrypt": { - "version": "4.0.2", - "resolved": "https://npm-registry.sipwise.com/public-encrypt/-/public-encrypt-4.0.2.tgz", - "integrity": "sha512-4kJ5Esocg8X3h8YgJsKAuoesBgB7mqH3eowiDzMUPKiRDDE7E/BqqZD1hnTByIaAFiwAw246YEltSq7tdrOH0Q==", - "dev": true, - "requires": { - "bn.js": "^4.1.0", - "browserify-rsa": "^4.0.0", - "create-hash": "^1.1.0", - "parse-asn1": "^5.0.0", - "randombytes": "^2.0.1" - } - }, - "punycode": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/punycode/-/punycode-2.1.1.tgz", - "integrity": "sha1-tYsBCsQMIsVldhbI0sLALHv0eew=", - "dev": true - }, - "purify-css": { - "version": "1.2.6", - "resolved": "https://npm-registry.sipwise.com/purify-css/-/purify-css-1.2.6.tgz", - "integrity": "sha1-VsK1jk4RNCR8b9wgukQ7UbReiy8=", - "dev": true, - "requires": { - "clean-css": "^4.0.12", - "glob": "^7.1.1", - "rework": "^1.0.1", - "uglify-js": "^3.0.6", - "yargs": "^8.0.1" - } - }, - "q": { - "version": "1.5.1", - "resolved": "https://npm-registry.sipwise.com/q/-/q-1.5.1.tgz", - "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=", - "dev": true - }, - "qjobs": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/qjobs/-/qjobs-1.2.0.tgz", - "integrity": "sha1-xF6cYYAL0IfviNfiVkI73Unl0HE=", - "dev": true - }, - "qs": { - "version": "6.5.1", - "resolved": "https://npm-registry.sipwise.com/qs/-/qs-6.5.1.tgz", - "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==", - "dev": true - }, - "quasar-extras": { - "version": "0.0.8", - "resolved": "https://npm-registry.sipwise.com/quasar-extras/-/quasar-extras-0.0.8.tgz", - "integrity": "sha1-De+n+YLLuhheMUK37unTgpkoISo=" - }, - "quasar-framework": { - "version": "0.14.9", - "resolved": "https://npm-registry.sipwise.com/quasar-framework/-/quasar-framework-0.14.9.tgz", - "integrity": "sha1-0EwPZCrvizX2NmaVxbT8CL/PaME=" - }, - "query-string": { - "version": "4.3.4", - "resolved": "https://npm-registry.sipwise.com/query-string/-/query-string-4.3.4.tgz", - "integrity": "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=", - "dev": true, - "requires": { - "object-assign": "^4.1.0", - "strict-uri-encode": "^1.0.0" - } - }, - "querystring": { - "version": "0.2.0", - "resolved": "https://npm-registry.sipwise.com/querystring/-/querystring-0.2.0.tgz", - "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", - "dev": true - }, - "querystring-es3": { - "version": "0.2.1", - "resolved": "https://npm-registry.sipwise.com/querystring-es3/-/querystring-es3-0.2.1.tgz", - "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=", - "dev": true - }, - "randomatic": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/randomatic/-/randomatic-3.0.0.tgz", - "integrity": "sha512-VdxFOIEY3mNO5PtSRkkle/hPJDHvQhK21oa73K4yAc9qmp6N429gAyF1gZMOTMeS0/AYzaV/2Trcef+NaIonSA==", - "dev": true, - "requires": { - "is-number": "^4.0.0", - "kind-of": "^6.0.0", - "math-random": "^1.0.1" - }, - "dependencies": { - "is-number": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/is-number/-/is-number-4.0.0.tgz", - "integrity": "sha1-ACbjf1RU1z41bf5lZGmYZ8an8P8=", - "dev": true - }, - "kind-of": { - "version": "6.0.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - } - } - }, - "randombytes": { - "version": "2.0.6", - "resolved": "https://npm-registry.sipwise.com/randombytes/-/randombytes-2.0.6.tgz", - "integrity": "sha512-CIQ5OFxf4Jou6uOKe9t1AOgqpeU5fd70A8NPdHSGeYXqXsPe6peOwI0cUl88RWZ6sP1vPMV3avd/R6cZ5/sP1A==", - "dev": true, - "requires": { - "safe-buffer": "^5.1.0" - } - }, - "randomfill": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/randomfill/-/randomfill-1.0.4.tgz", - "integrity": "sha1-ySGW/IarQr6YPxvzF3giSTHWFFg=", - "dev": true, - "requires": { - "randombytes": "^2.0.5", - "safe-buffer": "^5.1.0" - } - }, - "range-parser": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/range-parser/-/range-parser-1.2.0.tgz", - "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=", - "dev": true - }, - "raw-body": { - "version": "2.3.2", - "resolved": "https://npm-registry.sipwise.com/raw-body/-/raw-body-2.3.2.tgz", - "integrity": "sha1-vNYMd9Prk83gBQKVw/N5OJvIj4k=", - "dev": true, - "requires": { - "bytes": "3.0.0", - "http-errors": "1.6.2", - "iconv-lite": "0.4.19", - "unpipe": "1.0.0" - }, - "dependencies": { - "depd": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/depd/-/depd-1.1.1.tgz", - "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k=", - "dev": true - }, - "http-errors": { - "version": "1.6.2", - "resolved": "https://npm-registry.sipwise.com/http-errors/-/http-errors-1.6.2.tgz", - "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=", - "dev": true, - "requires": { - "depd": "1.1.1", - "inherits": "2.0.3", - "setprototypeof": "1.0.3", - "statuses": ">= 1.3.1 < 2" - } - }, - "iconv-lite": { - "version": "0.4.19", - "resolved": "https://npm-registry.sipwise.com/iconv-lite/-/iconv-lite-0.4.19.tgz", - "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==", - "dev": true - }, - "setprototypeof": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/setprototypeof/-/setprototypeof-1.0.3.tgz", - "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=", - "dev": true - } - } - }, - "read-pkg": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/read-pkg/-/read-pkg-2.0.0.tgz", - "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", - "dev": true, - "requires": { - "load-json-file": "^2.0.0", - "normalize-package-data": "^2.3.2", - "path-type": "^2.0.0" - } - }, - "read-pkg-up": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/read-pkg-up/-/read-pkg-up-2.0.0.tgz", - "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", - "dev": true, - "requires": { - "find-up": "^2.0.0", - "read-pkg": "^2.0.0" - } - }, - "readable-stream": { - "version": "2.3.6", - "resolved": "https://npm-registry.sipwise.com/readable-stream/-/readable-stream-2.3.6.tgz", - "integrity": "sha1-sRwn2IuP8fvgcGQ8+UsMea4bCq8=", - "dev": true, - "requires": { - "core-util-is": "~1.0.0", - "inherits": "~2.0.3", - "isarray": "~1.0.0", - "process-nextick-args": "~2.0.0", - "safe-buffer": "~5.1.1", - "string_decoder": "~1.1.1", - "util-deprecate": "~1.0.1" - } - }, - "readdirp": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/readdirp/-/readdirp-2.1.0.tgz", - "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", - "dev": true, - "requires": { - "graceful-fs": "^4.1.2", - "minimatch": "^3.0.2", - "readable-stream": "^2.0.2", - "set-immediate-shim": "^1.0.1" - } - }, - "rechoir": { - "version": "0.6.2", - "resolved": "https://npm-registry.sipwise.com/rechoir/-/rechoir-0.6.2.tgz", - "integrity": "sha1-hSBLVNuoLVdC4oyWdW70OvUOM4Q=", - "dev": true, - "requires": { - "resolve": "^1.1.6" - } - }, - "reduce-css-calc": { - "version": "1.3.0", - "resolved": "https://npm-registry.sipwise.com/reduce-css-calc/-/reduce-css-calc-1.3.0.tgz", - "integrity": "sha1-dHyRTgSWFKTJz7umKYca0dKSdxY=", - "dev": true, - "requires": { - "balanced-match": "^0.4.2", - "math-expression-evaluator": "^1.2.14", - "reduce-function-call": "^1.0.1" - }, - "dependencies": { - "balanced-match": { - "version": "0.4.2", - "resolved": "https://npm-registry.sipwise.com/balanced-match/-/balanced-match-0.4.2.tgz", - "integrity": "sha1-yz8+PHMtwPAe5wtAPzAuYddwmDg=", - "dev": true - } - } - }, - "reduce-function-call": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/reduce-function-call/-/reduce-function-call-1.0.2.tgz", - "integrity": "sha1-WiAL+S4ON3UXUv5FsKszD9S2vpk=", - "dev": true, - "requires": { - "balanced-match": "^0.4.2" - }, - "dependencies": { - "balanced-match": { - "version": "0.4.2", - "resolved": "https://npm-registry.sipwise.com/balanced-match/-/balanced-match-0.4.2.tgz", - "integrity": "sha1-yz8+PHMtwPAe5wtAPzAuYddwmDg=", - "dev": true - } - } - }, - "regenerate": { - "version": "1.4.0", - "resolved": "https://npm-registry.sipwise.com/regenerate/-/regenerate-1.4.0.tgz", - "integrity": "sha1-SoVuxLVuQHfFV1icroXnpMiGmhE=", - "dev": true - }, - "regenerator-runtime": { - "version": "0.11.1", - "resolved": "https://npm-registry.sipwise.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", - "integrity": "sha1-vgWtf5v30i4Fb5cmzuUBf78Z4uk=" - }, - "regenerator-transform": { - "version": "0.10.1", - "resolved": "https://npm-registry.sipwise.com/regenerator-transform/-/regenerator-transform-0.10.1.tgz", - "integrity": "sha1-HkmWg3Ix2ot/PPQRTXG1aRoGgN0=", - "dev": true, - "requires": { - "babel-runtime": "^6.18.0", - "babel-types": "^6.19.0", - "private": "^0.1.6" - } - }, - "regex-cache": { - "version": "0.4.4", - "resolved": "https://npm-registry.sipwise.com/regex-cache/-/regex-cache-0.4.4.tgz", - "integrity": "sha1-db3FiioUls7EihKDW8VMjVYjNt0=", - "dev": true, - "requires": { - "is-equal-shallow": "^0.1.3" - } - }, - "regex-not": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/regex-not/-/regex-not-1.0.2.tgz", - "integrity": "sha1-H07OJ+ALC2XgJHpoEOaoXYOldSw=", - "dev": true, - "requires": { - "extend-shallow": "^3.0.2", - "safe-regex": "^1.1.0" - } - }, - "regexpp": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/regexpp/-/regexpp-1.1.0.tgz", - "integrity": "sha1-DjUW3Qt5BPQT0tQZPc5GGMOmias=", - "dev": true - }, - "regexpu-core": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/regexpu-core/-/regexpu-core-2.0.0.tgz", - "integrity": "sha1-SdA4g3uNz4v6W5pCE5k45uoq4kA=", - "dev": true, - "requires": { - "regenerate": "^1.2.1", - "regjsgen": "^0.2.0", - "regjsparser": "^0.1.4" - } - }, - "regjsgen": { - "version": "0.2.0", - "resolved": "https://npm-registry.sipwise.com/regjsgen/-/regjsgen-0.2.0.tgz", - "integrity": "sha1-bAFq3qxVT3WCP+N6wFuS1aTtsfc=", - "dev": true - }, - "regjsparser": { - "version": "0.1.5", - "resolved": "https://npm-registry.sipwise.com/regjsparser/-/regjsparser-0.1.5.tgz", - "integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=", - "dev": true, - "requires": { - "jsesc": "~0.5.0" - }, - "dependencies": { - "jsesc": { - "version": "0.5.0", - "resolved": "https://npm-registry.sipwise.com/jsesc/-/jsesc-0.5.0.tgz", - "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", - "dev": true - } - } - }, - "relateurl": { - "version": "0.2.7", - "resolved": "https://npm-registry.sipwise.com/relateurl/-/relateurl-0.2.7.tgz", - "integrity": "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=", - "dev": true - }, - "remove-trailing-separator": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", - "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", - "dev": true - }, - "renderkid": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/renderkid/-/renderkid-2.0.1.tgz", - "integrity": "sha1-iYyr/Ivt5Le5ETWj/9Mj5YwNsxk=", - "dev": true, - "requires": { - "css-select": "^1.1.0", - "dom-converter": "~0.1", - "htmlparser2": "~3.3.0", - "strip-ansi": "^3.0.0", - "utila": "~0.3" - }, - "dependencies": { - "domhandler": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/domhandler/-/domhandler-2.1.0.tgz", - "integrity": "sha1-0mRvXlf2w7qxHPbLBdPArPdBJZQ=", - "dev": true, - "requires": { - "domelementtype": "1" - } - }, - "domutils": { - "version": "1.1.6", - "resolved": "https://npm-registry.sipwise.com/domutils/-/domutils-1.1.6.tgz", - "integrity": "sha1-vdw94Jm5ou+sxRxiPyj0FuzFdIU=", - "dev": true, - "requires": { - "domelementtype": "1" - } - }, - "htmlparser2": { - "version": "3.3.0", - "resolved": "https://npm-registry.sipwise.com/htmlparser2/-/htmlparser2-3.3.0.tgz", - "integrity": "sha1-zHDQWln2VC5D8OaFyYLhTJJKnv4=", - "dev": true, - "requires": { - "domelementtype": "1", - "domhandler": "2.1", - "domutils": "1.1", - "readable-stream": "1.0" - } - }, - "isarray": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/isarray/-/isarray-0.0.1.tgz", - "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", - "dev": true - }, - "readable-stream": { - "version": "1.0.34", - "resolved": "https://npm-registry.sipwise.com/readable-stream/-/readable-stream-1.0.34.tgz", - "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", - "dev": true, - "requires": { - "core-util-is": "~1.0.0", - "inherits": "~2.0.1", - "isarray": "0.0.1", - "string_decoder": "~0.10.x" - } - }, - "string_decoder": { - "version": "0.10.31", - "resolved": "https://npm-registry.sipwise.com/string_decoder/-/string_decoder-0.10.31.tgz", - "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", - "dev": true - }, - "utila": { - "version": "0.3.3", - "resolved": "https://npm-registry.sipwise.com/utila/-/utila-0.3.3.tgz", - "integrity": "sha1-1+jn1+MJEHCSsF+NloiCTWM6QiY=", - "dev": true - } - } - }, - "repeat-element": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/repeat-element/-/repeat-element-1.1.2.tgz", - "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", - "dev": true - }, - "repeat-string": { - "version": "1.6.1", - "resolved": "https://npm-registry.sipwise.com/repeat-string/-/repeat-string-1.6.1.tgz", - "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", - "dev": true - }, - "repeating": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/repeating/-/repeating-2.0.1.tgz", - "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", - "dev": true, - "requires": { - "is-finite": "^1.0.0" - } - }, - "require-directory": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", - "dev": true - }, - "require-from-string": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/require-from-string/-/require-from-string-1.2.1.tgz", - "integrity": "sha1-UpyczvJzgK3+yaL5ZbZJu+5jZBg=", - "dev": true - }, - "require-main-filename": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/require-main-filename/-/require-main-filename-1.0.1.tgz", - "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", - "dev": true - }, - "require-uncached": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/require-uncached/-/require-uncached-1.0.3.tgz", - "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", - "dev": true, - "requires": { - "caller-path": "^0.1.0", - "resolve-from": "^1.0.0" - } - }, - "requires-port": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/requires-port/-/requires-port-1.0.0.tgz", - "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", - "dev": true - }, - "resolve": { - "version": "1.8.1", - "resolved": "https://npm-registry.sipwise.com/resolve/-/resolve-1.8.1.tgz", - "integrity": "sha512-AicPrAC7Qu1JxPCZ9ZgCZlY35QgFnNqc+0LtbRNxnVw4TXvjQ72wnuL9JQcEBgXkI9JM8MsT9kaQoHcpCRJOYA==", - "dev": true, - "requires": { - "path-parse": "^1.0.5" - } - }, - "resolve-from": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/resolve-from/-/resolve-from-1.0.1.tgz", - "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", - "dev": true - }, - "resolve-url": { - "version": "0.2.1", - "resolved": "https://npm-registry.sipwise.com/resolve-url/-/resolve-url-0.2.1.tgz", - "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", - "dev": true - }, - "restore-cursor": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/restore-cursor/-/restore-cursor-2.0.0.tgz", - "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", - "dev": true, - "requires": { - "onetime": "^2.0.0", - "signal-exit": "^3.0.2" - } - }, - "ret": { - "version": "0.1.15", - "resolved": "https://npm-registry.sipwise.com/ret/-/ret-0.1.15.tgz", - "integrity": "sha1-uKSCXVvbH8P29Twrwz+BOIaBx7w=", - "dev": true - }, - "rework": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/rework/-/rework-1.0.1.tgz", - "integrity": "sha1-MIBqhBNCtUUQqkEQhQzUhTQUSqc=", - "dev": true, - "requires": { - "convert-source-map": "^0.3.3", - "css": "^2.0.0" - }, - "dependencies": { - "convert-source-map": { - "version": "0.3.5", - "resolved": "https://npm-registry.sipwise.com/convert-source-map/-/convert-source-map-0.3.5.tgz", - "integrity": "sha1-8dgClQr33SYxof6+BZZVDIarMZA=", - "dev": true - } - } - }, - "right-align": { - "version": "0.1.3", - "resolved": "https://npm-registry.sipwise.com/right-align/-/right-align-0.1.3.tgz", - "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", - "dev": true, - "requires": { - "align-text": "^0.1.1" - } - }, - "rimraf": { - "version": "2.6.2", - "resolved": "https://npm-registry.sipwise.com/rimraf/-/rimraf-2.6.2.tgz", - "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", - "dev": true, - "requires": { - "glob": "^7.0.5" - } - }, - "ripemd160": { - "version": "2.0.2", - "resolved": "https://npm-registry.sipwise.com/ripemd160/-/ripemd160-2.0.2.tgz", - "integrity": "sha1-ocGm9iR1FXe6XQeRTLyShQWFiQw=", - "dev": true, - "requires": { - "hash-base": "^3.0.0", - "inherits": "^2.0.1" - } - }, - "run-async": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/run-async/-/run-async-2.3.0.tgz", - "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", - "dev": true, - "requires": { - "is-promise": "^2.1.0" - } - }, - "rx-lite": { - "version": "4.0.8", - "resolved": "https://npm-registry.sipwise.com/rx-lite/-/rx-lite-4.0.8.tgz", - "integrity": "sha1-Cx4Rr4vESDbwSmQH6S2kJGe3lEQ=", - "dev": true - }, - "rx-lite-aggregates": { - "version": "4.0.8", - "resolved": "https://npm-registry.sipwise.com/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz", - "integrity": "sha1-dTuHqJoRyVRnxKwWJsTvxOBcZ74=", - "dev": true, - "requires": { - "rx-lite": "*" - } - }, - "safe-buffer": { - "version": "5.1.2", - "resolved": "https://npm-registry.sipwise.com/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" - }, - "safe-regex": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/safe-regex/-/safe-regex-1.1.0.tgz", - "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", - "dev": true, - "requires": { - "ret": "~0.1.10" - } - }, - "safer-buffer": { - "version": "2.1.2", - "resolved": "https://npm-registry.sipwise.com/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha1-RPoWGwGHuVSd2Eu5GAL5vYOFzWo=", - "dev": true - }, - "sax": { - "version": "1.2.4", - "resolved": "https://npm-registry.sipwise.com/sax/-/sax-1.2.4.tgz", - "integrity": "sha1-KBYjTiN4vdxOU1T6tcqold9xANk=", - "dev": true - }, - "schema-utils": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/schema-utils/-/schema-utils-0.3.0.tgz", - "integrity": "sha1-9YdyIs4+kx7a4DnxfrNxbnE3+M8=", - "dev": true, - "requires": { - "ajv": "^5.0.0" - } - }, - "semver": { - "version": "5.5.0", - "resolved": "https://npm-registry.sipwise.com/semver/-/semver-5.5.0.tgz", - "integrity": "sha512-4SJ3dm0WAwWy/NVeioZh5AntkdJoWKxHxcmyP622fOkgHa4z3R0TdBJICINyaSDE6uNwVc8gZr+ZinwZAH4xIA==", - "dev": true - }, - "send": { - "version": "0.16.2", - "resolved": "https://npm-registry.sipwise.com/send/-/send-0.16.2.tgz", - "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", - "dev": true, - "requires": { - "debug": "2.6.9", - "depd": "~1.1.2", - "destroy": "~1.0.4", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "etag": "~1.8.1", - "fresh": "0.5.2", - "http-errors": "~1.6.2", - "mime": "1.4.1", - "ms": "2.0.0", - "on-finished": "~2.3.0", - "range-parser": "~1.2.0", - "statuses": "~1.4.0" - } - }, - "serve-static": { - "version": "1.13.2", - "resolved": "https://npm-registry.sipwise.com/serve-static/-/serve-static-1.13.2.tgz", - "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", - "dev": true, - "requires": { - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "parseurl": "~1.3.2", - "send": "0.16.2" - } - }, - "set-blocking": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/set-blocking/-/set-blocking-2.0.0.tgz", - "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", - "dev": true - }, - "set-immediate-shim": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", - "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", - "dev": true - }, - "set-value": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/set-value/-/set-value-2.0.1.tgz", - "integrity": "sha1-oY1AUw5vB95CKMfe/kInr4ytAFs=", - "dev": true, - "requires": { - "extend-shallow": "^2.0.1", - "is-extendable": "^0.1.1", - "is-plain-object": "^2.0.3", - "split-string": "^3.0.1" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "setimmediate": { - "version": "1.0.5", - "resolved": "https://npm-registry.sipwise.com/setimmediate/-/setimmediate-1.0.5.tgz", - "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=", - "dev": true - }, - "setprototypeof": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/setprototypeof/-/setprototypeof-1.1.0.tgz", - "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", - "dev": true - }, - "sha.js": { - "version": "2.4.11", - "resolved": "https://npm-registry.sipwise.com/sha.js/-/sha.js-2.4.11.tgz", - "integrity": "sha1-N6XPC4HsvGlD3hCbopYNGyZYSuc=", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "safe-buffer": "^5.0.1" - } - }, - "shebang-command": { - "version": "1.2.0", - "resolved": "https://npm-registry.sipwise.com/shebang-command/-/shebang-command-1.2.0.tgz", - "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", - "dev": true, - "requires": { - "shebang-regex": "^1.0.0" - } - }, - "shebang-regex": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/shebang-regex/-/shebang-regex-1.0.0.tgz", - "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", - "dev": true - }, - "shelljs": { - "version": "0.7.8", - "resolved": "https://npm-registry.sipwise.com/shelljs/-/shelljs-0.7.8.tgz", - "integrity": "sha1-3svPh0sNHl+3LhSxZKloMEjprLM=", - "dev": true, - "requires": { - "glob": "^7.0.0", - "interpret": "^1.0.0", - "rechoir": "^0.6.2" - } - }, - "signal-exit": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/signal-exit/-/signal-exit-3.0.2.tgz", - "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", - "dev": true - }, - "slash": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/slash/-/slash-1.0.0.tgz", - "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", - "dev": true - }, - "slice-ansi": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/slice-ansi/-/slice-ansi-1.0.0.tgz", - "integrity": "sha1-BE8aSdiEL/MHqta1Be0Xi9lQE00=", - "dev": true, - "requires": { - "is-fullwidth-code-point": "^2.0.0" - } - }, - "snapdragon": { - "version": "0.8.2", - "resolved": "https://npm-registry.sipwise.com/snapdragon/-/snapdragon-0.8.2.tgz", - "integrity": "sha1-ZJIufFZbDhQgS6GqfWlkJ40lGC0=", - "dev": true, - "requires": { - "base": "^0.11.1", - "debug": "^2.2.0", - "define-property": "^0.2.5", - "extend-shallow": "^2.0.1", - "map-cache": "^0.2.2", - "source-map": "^0.5.6", - "source-map-resolve": "^0.5.0", - "use": "^3.1.0" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "snapdragon-node": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz", - "integrity": "sha1-bBdfhv8UvbByRWPo88GwIaKGhTs=", - "dev": true, - "requires": { - "define-property": "^1.0.0", - "isobject": "^3.0.0", - "snapdragon-util": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", - "dev": true, - "requires": { - "is-descriptor": "^1.0.0" - } - }, - "is-accessor-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha1-FpwvbT3x+ZJhgHI2XJsOofaHhlY=", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-data-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha1-2Eh2Mh0Oet0DmQQGq7u9NrqSaMc=", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-descriptor": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha1-OxWXRqZmBLBPjIFSS6NlxfFNhuw=", - "dev": true, - "requires": { - "is-accessor-descriptor": "^1.0.0", - "is-data-descriptor": "^1.0.0", - "kind-of": "^6.0.2" - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, - "kind-of": { - "version": "6.0.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - } - } - }, - "snapdragon-util": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz", - "integrity": "sha1-+VZHlIbyrNeXAGk/b3uAXkWrVuI=", - "dev": true, - "requires": { - "kind-of": "^3.2.0" - } - }, - "socket.io": { - "version": "1.7.3", - "resolved": "https://npm-registry.sipwise.com/socket.io/-/socket.io-1.7.3.tgz", - "integrity": "sha1-uK+cq6AJSeVo42nxMn6pvp6iRhs=", - "dev": true, - "requires": { - "debug": "2.3.3", - "engine.io": "1.8.3", - "has-binary": "0.1.7", - "object-assign": "4.1.0", - "socket.io-adapter": "0.5.0", - "socket.io-client": "1.7.3", - "socket.io-parser": "2.3.1" - }, - "dependencies": { - "debug": { - "version": "2.3.3", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.3.3.tgz", - "integrity": "sha1-QMRT5n5uE8kB3ewxeviYbNqe/4w=", - "dev": true, - "requires": { - "ms": "0.7.2" - } - }, - "ms": { - "version": "0.7.2", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-0.7.2.tgz", - "integrity": "sha1-riXPJRKziFodldfwN4aNhDESR2U=", - "dev": true - }, - "object-assign": { - "version": "4.1.0", - "resolved": "https://npm-registry.sipwise.com/object-assign/-/object-assign-4.1.0.tgz", - "integrity": "sha1-ejs9DpgGPUP0wD8uiubNUahog6A=", - "dev": true - } - } - }, - "socket.io-adapter": { - "version": "0.5.0", - "resolved": "https://npm-registry.sipwise.com/socket.io-adapter/-/socket.io-adapter-0.5.0.tgz", - "integrity": "sha1-y21LuL7IHhB4uZZ3+c7QBGBmu4s=", - "dev": true, - "requires": { - "debug": "2.3.3", - "socket.io-parser": "2.3.1" - }, - "dependencies": { - "debug": { - "version": "2.3.3", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.3.3.tgz", - "integrity": "sha1-QMRT5n5uE8kB3ewxeviYbNqe/4w=", - "dev": true, - "requires": { - "ms": "0.7.2" - } - }, - "ms": { - "version": "0.7.2", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-0.7.2.tgz", - "integrity": "sha1-riXPJRKziFodldfwN4aNhDESR2U=", - "dev": true - } - } - }, - "socket.io-client": { - "version": "1.7.3", - "resolved": "https://npm-registry.sipwise.com/socket.io-client/-/socket.io-client-1.7.3.tgz", - "integrity": "sha1-sw6GqhDV7zVGYBwJzeR2Xjgdo3c=", - "dev": true, - "requires": { - "backo2": "1.0.2", - "component-bind": "1.0.0", - "component-emitter": "1.2.1", - "debug": "2.3.3", - "engine.io-client": "1.8.3", - "has-binary": "0.1.7", - "indexof": "0.0.1", - "object-component": "0.0.3", - "parseuri": "0.0.5", - "socket.io-parser": "2.3.1", - "to-array": "0.1.4" - }, - "dependencies": { - "component-emitter": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/component-emitter/-/component-emitter-1.2.1.tgz", - "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", - "dev": true - }, - "debug": { - "version": "2.3.3", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.3.3.tgz", - "integrity": "sha1-QMRT5n5uE8kB3ewxeviYbNqe/4w=", - "dev": true, - "requires": { - "ms": "0.7.2" - } - }, - "ms": { - "version": "0.7.2", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-0.7.2.tgz", - "integrity": "sha1-riXPJRKziFodldfwN4aNhDESR2U=", - "dev": true - } - } - }, - "socket.io-parser": { - "version": "2.3.1", - "resolved": "https://npm-registry.sipwise.com/socket.io-parser/-/socket.io-parser-2.3.1.tgz", - "integrity": "sha1-3VMgJRA85Clpcya+/WQAX8/ltKA=", - "dev": true, - "requires": { - "component-emitter": "1.1.2", - "debug": "2.2.0", - "isarray": "0.0.1", - "json3": "3.3.2" - }, - "dependencies": { - "debug": { - "version": "2.2.0", - "resolved": "https://npm-registry.sipwise.com/debug/-/debug-2.2.0.tgz", - "integrity": "sha1-+HBX6ZWxofauaklgZkE3vFbwOdo=", - "dev": true, - "requires": { - "ms": "0.7.1" - } - }, - "isarray": { - "version": "0.0.1", - "resolved": "https://npm-registry.sipwise.com/isarray/-/isarray-0.0.1.tgz", - "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", - "dev": true - }, - "ms": { - "version": "0.7.1", - "resolved": "https://npm-registry.sipwise.com/ms/-/ms-0.7.1.tgz", - "integrity": "sha1-nNE8A62/8ltl7/3nzoZO6VIBcJg=", - "dev": true - } - } - }, - "sort-keys": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/sort-keys/-/sort-keys-1.1.2.tgz", - "integrity": "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=", - "dev": true, - "requires": { - "is-plain-obj": "^1.0.0" - } - }, - "source-list-map": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/source-list-map/-/source-list-map-2.0.0.tgz", - "integrity": "sha512-I2UmuJSRr/T8jisiROLU3A3ltr+swpniSmNPI4Ml3ZCX6tVnDsuZzK7F2hl5jTqbZBWCEKlj5HRQiPExXLgE8A==", - "dev": true - }, - "source-map": { - "version": "0.5.7", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", - "dev": true - }, - "source-map-resolve": { - "version": "0.5.2", - "resolved": "https://npm-registry.sipwise.com/source-map-resolve/-/source-map-resolve-0.5.2.tgz", - "integrity": "sha1-cuLMNAlVQ+Q7LGKyxMENSpBU8lk=", - "dev": true, - "requires": { - "atob": "^2.1.1", - "decode-uri-component": "^0.2.0", - "resolve-url": "^0.2.1", - "source-map-url": "^0.4.0", - "urix": "^0.1.0" - } - }, - "source-map-support": { - "version": "0.4.18", - "resolved": "https://npm-registry.sipwise.com/source-map-support/-/source-map-support-0.4.18.tgz", - "integrity": "sha1-Aoam3ovkJkEzhZTpfM6nXwosWF8=", - "dev": true, - "requires": { - "source-map": "^0.5.6" - } - }, - "source-map-url": { - "version": "0.4.0", - "resolved": "https://npm-registry.sipwise.com/source-map-url/-/source-map-url-0.4.0.tgz", - "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", - "dev": true - }, - "spdx-correct": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/spdx-correct/-/spdx-correct-3.0.0.tgz", - "integrity": "sha512-N19o9z5cEyc8yQQPukRCZ9EUmb4HUpnrmaL/fxS2pBo2jbfcFRVuFZ/oFC+vZz0MNNk0h80iMn5/S6qGZOL5+g==", - "dev": true, - "requires": { - "spdx-expression-parse": "^3.0.0", - "spdx-license-ids": "^3.0.0" - } - }, - "spdx-exceptions": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/spdx-exceptions/-/spdx-exceptions-2.1.0.tgz", - "integrity": "sha512-4K1NsmrlCU1JJgUrtgEeTVyfx8VaYea9J9LvARxhbHtVtohPs/gFGG5yy49beySjlIMhhXZ4QqujIZEfS4l6Cg==", - "dev": true - }, - "spdx-expression-parse": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", - "integrity": "sha1-meEZt6XaAOBUkcn6M4t5BII7QdA=", - "dev": true, - "requires": { - "spdx-exceptions": "^2.1.0", - "spdx-license-ids": "^3.0.0" - } - }, - "spdx-license-ids": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/spdx-license-ids/-/spdx-license-ids-3.0.0.tgz", - "integrity": "sha512-2+EPwgbnmOIl8HjGBXXMd9NAu02vLjOO1nWw4kmeRDFyHn+M/ETfHxQUK0oXg8ctgVnl9t3rosNVsZ1jG61nDA==", - "dev": true - }, - "split-string": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/split-string/-/split-string-3.1.0.tgz", - "integrity": "sha1-fLCd2jqGWFcFxks5pkZgOGguj+I=", - "dev": true, - "requires": { - "extend-shallow": "^3.0.0" - } - }, - "sprintf-js": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/sprintf-js/-/sprintf-js-1.0.3.tgz", - "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", - "dev": true - }, - "stackframe": { - "version": "1.0.4", - "resolved": "https://npm-registry.sipwise.com/stackframe/-/stackframe-1.0.4.tgz", - "integrity": "sha1-NXskqZL5Qny6a1RdlqFO0svKGHs=", - "dev": true - }, - "static-extend": { - "version": "0.1.2", - "resolved": "https://npm-registry.sipwise.com/static-extend/-/static-extend-0.1.2.tgz", - "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", - "dev": true, - "requires": { - "define-property": "^0.2.5", - "object-copy": "^0.1.0" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - } - } - }, - "statuses": { - "version": "1.4.0", - "resolved": "https://npm-registry.sipwise.com/statuses/-/statuses-1.4.0.tgz", - "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==", - "dev": true - }, - "stream-browserify": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/stream-browserify/-/stream-browserify-2.0.1.tgz", - "integrity": "sha1-ZiZu5fm9uZQKTkUUyvtDu3Hlyds=", - "dev": true, - "requires": { - "inherits": "~2.0.1", - "readable-stream": "^2.0.2" - } - }, - "stream-http": { - "version": "2.8.3", - "resolved": "https://npm-registry.sipwise.com/stream-http/-/stream-http-2.8.3.tgz", - "integrity": "sha1-stJCRpKIpaJ+xP6JM6z2I95lFPw=", - "dev": true, - "requires": { - "builtin-status-codes": "^3.0.0", - "inherits": "^2.0.1", - "readable-stream": "^2.3.6", - "to-arraybuffer": "^1.0.0", - "xtend": "^4.0.0" - } - }, - "strict-uri-encode": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", - "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=", - "dev": true - }, - "string-width": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/string-width/-/string-width-2.1.1.tgz", - "integrity": "sha1-q5Pyeo3BPSjKyBXEYhQ6bZASrp4=", - "dev": true, - "requires": { - "is-fullwidth-code-point": "^2.0.0", - "strip-ansi": "^4.0.0" - }, - "dependencies": { - "ansi-regex": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/ansi-regex/-/ansi-regex-3.0.0.tgz", - "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", - "dev": true - }, - "strip-ansi": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/strip-ansi/-/strip-ansi-4.0.0.tgz", - "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", - "dev": true, - "requires": { - "ansi-regex": "^3.0.0" - } - } - } - }, - "string_decoder": { - "version": "1.1.1", - "resolved": "https://npm-registry.sipwise.com/string_decoder/-/string_decoder-1.1.1.tgz", - "integrity": "sha1-nPFhG6YmhdcDCunkujQUnDrwP8g=", - "dev": true, - "requires": { - "safe-buffer": "~5.1.0" - } - }, - "strip-ansi": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/strip-ansi/-/strip-ansi-3.0.1.tgz", - "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", - "dev": true, - "requires": { - "ansi-regex": "^2.0.0" - } - }, - "strip-bom": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/strip-bom/-/strip-bom-3.0.0.tgz", - "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", - "dev": true - }, - "strip-eof": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/strip-eof/-/strip-eof-1.0.0.tgz", - "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", - "dev": true - }, - "strip-json-comments": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz", - "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", - "dev": true - }, - "stylus": { - "version": "0.54.5", - "resolved": "https://npm-registry.sipwise.com/stylus/-/stylus-0.54.5.tgz", - "integrity": "sha1-QrlWCTHKcJDOhRWnmLqeaqPW3Hk=", - "dev": true, - "requires": { - "css-parse": "1.7.x", - "debug": "*", - "glob": "7.0.x", - "mkdirp": "0.5.x", - "sax": "0.5.x", - "source-map": "0.1.x" - }, - "dependencies": { - "glob": { - "version": "7.0.6", - "resolved": "https://npm-registry.sipwise.com/glob/-/glob-7.0.6.tgz", - "integrity": "sha1-IRuvr0nlJbjNkyYNFKsTYVKz9Xo=", - "dev": true, - "requires": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.0.2", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - } - }, - "sax": { - "version": "0.5.8", - "resolved": "https://npm-registry.sipwise.com/sax/-/sax-0.5.8.tgz", - "integrity": "sha1-1HLbIo6zMcJQaw6MFVJK25OdEsE=", - "dev": true - }, - "source-map": { - "version": "0.1.43", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.1.43.tgz", - "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", - "dev": true, - "requires": { - "amdefine": ">=0.0.4" - } - } - } - }, - "stylus-loader": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/stylus-loader/-/stylus-loader-3.0.2.tgz", - "integrity": "sha1-J6cGQgsFo44DjnyssVNXjUUFE8Y=", - "dev": true, - "requires": { - "loader-utils": "^1.0.2", - "lodash.clonedeep": "^4.5.0", - "when": "~3.6.x" - } - }, - "supports-color": { - "version": "3.2.3", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-3.2.3.tgz", - "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", - "dev": true, - "requires": { - "has-flag": "^1.0.0" - } - }, - "svgo": { - "version": "0.7.2", - "resolved": "https://npm-registry.sipwise.com/svgo/-/svgo-0.7.2.tgz", - "integrity": "sha1-n1dyQTlSE1xv779Ar+ak+qiLS7U=", - "dev": true, - "requires": { - "coa": "~1.0.1", - "colors": "~1.1.2", - "csso": "~2.3.1", - "js-yaml": "~3.7.0", - "mkdirp": "~0.5.1", - "sax": "~1.2.1", - "whet.extend": "~0.9.9" - }, - "dependencies": { - "colors": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/colors/-/colors-1.1.2.tgz", - "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=", - "dev": true - }, - "js-yaml": { - "version": "3.7.0", - "resolved": "https://npm-registry.sipwise.com/js-yaml/-/js-yaml-3.7.0.tgz", - "integrity": "sha1-XJZ93YN6m/3KXy3oQlOr6KHAO4A=", - "dev": true, - "requires": { - "argparse": "^1.0.7", - "esprima": "^2.6.0" - } - } - } - }, - "table": { - "version": "4.0.2", - "resolved": "https://npm-registry.sipwise.com/table/-/table-4.0.2.tgz", - "integrity": "sha1-ozRHN1OR52atNNNIbm4q7chNLjY=", - "dev": true, - "requires": { - "ajv": "^5.2.3", - "ajv-keywords": "^2.1.0", - "chalk": "^2.1.0", - "lodash": "^4.17.4", - "slice-ansi": "1.0.0", - "string-width": "^2.1.1" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "tapable": { - "version": "0.2.8", - "resolved": "https://npm-registry.sipwise.com/tapable/-/tapable-0.2.8.tgz", - "integrity": "sha1-mTcqXJmb8t8WCvwNdL7U9HlIzSI=", - "dev": true - }, - "tar": { - "version": "4.4.10", - "resolved": "https://npm-registry.sipwise.com/tar/-/tar-4.4.10.tgz", - "integrity": "sha512-g2SVs5QIxvo6OLp0GudTqEf05maawKUxXru104iaayWA09551tFCTI8f1Asb4lPfkBr91k07iL4c11XO3/b0tA==", - "dev": true, - "optional": true, - "requires": { - "chownr": "^1.1.1", - "fs-minipass": "^1.2.5", - "minipass": "^2.3.5", - "minizlib": "^1.2.1", - "mkdirp": "^0.5.0", - "safe-buffer": "^5.1.2", - "yallist": "^3.0.3" - }, - "dependencies": { - "yallist": { - "version": "3.0.3", - "resolved": "https://npm-registry.sipwise.com/yallist/-/yallist-3.0.3.tgz", - "integrity": "sha512-S+Zk8DEWE6oKpV+vI3qWkaK+jSbIK86pCwe2IF/xwIpQ8jEuxpw9NyaGjmp9+BoJv5FV2piqCDcoCtStppiq2A==", - "dev": true, - "optional": true - } - } - }, - "text-table": { - "version": "0.2.0", - "resolved": "https://npm-registry.sipwise.com/text-table/-/text-table-0.2.0.tgz", - "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", - "dev": true - }, - "through": { - "version": "2.3.8", - "resolved": "https://npm-registry.sipwise.com/through/-/through-2.3.8.tgz", - "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", - "dev": true - }, - "time-stamp": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/time-stamp/-/time-stamp-2.0.0.tgz", - "integrity": "sha1-lcakRTDhW6jW9KPsuMOj+sRto1c=", - "dev": true - }, - "timed-out": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/timed-out/-/timed-out-4.0.1.tgz", - "integrity": "sha1-8y6srFoXW+ol1/q1Zas+2HQe9W8=" - }, - "timers-browserify": { - "version": "2.0.10", - "resolved": "https://npm-registry.sipwise.com/timers-browserify/-/timers-browserify-2.0.10.tgz", - "integrity": "sha512-YvC1SV1XdOUaL6gx5CoGroT3Gu49pK9+TZ38ErPldOWW4j49GI1HKs9DV+KGq/w6y+LZ72W1c8cKz2vzY+qpzg==", - "dev": true, - "requires": { - "setimmediate": "^1.0.4" - } - }, - "tmp": { - "version": "0.0.33", - "resolved": "https://npm-registry.sipwise.com/tmp/-/tmp-0.0.33.tgz", - "integrity": "sha1-bTQzWIl2jSGyvNoKonfO07G/rfk=", - "dev": true, - "requires": { - "os-tmpdir": "~1.0.2" - } - }, - "to-array": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/to-array/-/to-array-0.1.4.tgz", - "integrity": "sha1-F+bBH3PdTz10zaek/zI46a2b+JA=", - "dev": true - }, - "to-arraybuffer": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", - "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=", - "dev": true - }, - "to-fast-properties": { - "version": "1.0.3", - "resolved": "https://npm-registry.sipwise.com/to-fast-properties/-/to-fast-properties-1.0.3.tgz", - "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=", - "dev": true - }, - "to-object-path": { - "version": "0.3.0", - "resolved": "https://npm-registry.sipwise.com/to-object-path/-/to-object-path-0.3.0.tgz", - "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - } - }, - "to-regex": { - "version": "3.0.2", - "resolved": "https://npm-registry.sipwise.com/to-regex/-/to-regex-3.0.2.tgz", - "integrity": "sha1-E8/dmzNlUvMLUfM6iuG0Knp1mc4=", - "dev": true, - "requires": { - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "regex-not": "^1.0.2", - "safe-regex": "^1.1.0" - } - }, - "to-regex-range": { - "version": "2.1.1", - "resolved": "https://npm-registry.sipwise.com/to-regex-range/-/to-regex-range-2.1.1.tgz", - "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", - "dev": true, - "requires": { - "is-number": "^3.0.0", - "repeat-string": "^1.6.1" - }, - "dependencies": { - "is-number": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - } - } - } - }, - "toposort": { - "version": "1.0.7", - "resolved": "https://npm-registry.sipwise.com/toposort/-/toposort-1.0.7.tgz", - "integrity": "sha1-LmhELZ9k7HILjMieZEOsbKqVACk=", - "dev": true - }, - "trim-right": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/trim-right/-/trim-right-1.0.1.tgz", - "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", - "dev": true - }, - "tty-browserify": { - "version": "0.0.0", - "resolved": "https://npm-registry.sipwise.com/tty-browserify/-/tty-browserify-0.0.0.tgz", - "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=", - "dev": true - }, - "type-check": { - "version": "0.3.2", - "resolved": "https://npm-registry.sipwise.com/type-check/-/type-check-0.3.2.tgz", - "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", - "dev": true, - "requires": { - "prelude-ls": "~1.1.2" - } - }, - "type-detect": { - "version": "4.0.8", - "resolved": "https://npm-registry.sipwise.com/type-detect/-/type-detect-4.0.8.tgz", - "integrity": "sha1-dkb7XxiHHPu3dJ5pvTmmOI63RQw=", - "dev": true - }, - "type-is": { - "version": "1.6.16", - "resolved": "https://npm-registry.sipwise.com/type-is/-/type-is-1.6.16.tgz", - "integrity": "sha512-HRkVv/5qY2G6I8iab9cI7v1bOIdhm94dVjQCPFElW9W+3GeDOSHmy2EBYe4VTApuzolPcmgFTN3ftVJRKR2J9Q==", - "dev": true, - "requires": { - "media-typer": "0.3.0", - "mime-types": "~2.1.18" - } - }, - "typedarray": { - "version": "0.0.6", - "resolved": "https://npm-registry.sipwise.com/typedarray/-/typedarray-0.0.6.tgz", - "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", - "dev": true - }, - "uglify-js": { - "version": "3.4.5", - "resolved": "https://npm-registry.sipwise.com/uglify-js/-/uglify-js-3.4.5.tgz", - "integrity": "sha512-Fm52gLqJqFBnT+Sn411NPDnsgaWiYeRLw42x7Va/mS8TKgaepwoGY7JLXHSEef3d3PmdFXSz1Zx7KMLL89E2QA==", - "dev": true, - "requires": { - "commander": "~2.16.0", - "source-map": "~0.6.1" - }, - "dependencies": { - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - } - } - }, - "uglify-to-browserify": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", - "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", - "dev": true, - "optional": true - }, - "uglifyjs-webpack-plugin": { - "version": "0.4.6", - "resolved": "https://npm-registry.sipwise.com/uglifyjs-webpack-plugin/-/uglifyjs-webpack-plugin-0.4.6.tgz", - "integrity": "sha1-uVH0q7a9YX5m9j64kUmOORdj4wk=", - "dev": true, - "requires": { - "source-map": "^0.5.6", - "uglify-js": "^2.8.29", - "webpack-sources": "^1.0.1" - }, - "dependencies": { - "camelcase": { - "version": "1.2.1", - "resolved": "https://npm-registry.sipwise.com/camelcase/-/camelcase-1.2.1.tgz", - "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=", - "dev": true - }, - "cliui": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/cliui/-/cliui-2.1.0.tgz", - "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", - "dev": true, - "requires": { - "center-align": "^0.1.1", - "right-align": "^0.1.1", - "wordwrap": "0.0.2" - } - }, - "uglify-js": { - "version": "2.8.29", - "resolved": "https://npm-registry.sipwise.com/uglify-js/-/uglify-js-2.8.29.tgz", - "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", - "dev": true, - "requires": { - "source-map": "~0.5.1", - "uglify-to-browserify": "~1.0.0", - "yargs": "~3.10.0" - } - }, - "wordwrap": { - "version": "0.0.2", - "resolved": "https://npm-registry.sipwise.com/wordwrap/-/wordwrap-0.0.2.tgz", - "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=", - "dev": true - }, - "yargs": { - "version": "3.10.0", - "resolved": "https://npm-registry.sipwise.com/yargs/-/yargs-3.10.0.tgz", - "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", - "dev": true, - "requires": { - "camelcase": "^1.0.2", - "cliui": "^2.1.0", - "decamelize": "^1.0.0", - "window-size": "0.1.0" - } - } - } - }, - "ultron": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/ultron/-/ultron-1.0.2.tgz", - "integrity": "sha1-rOEWq1V80Zc4ak6I9GhTeMiy5Po=", - "dev": true - }, - "union-value": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/union-value/-/union-value-1.0.1.tgz", - "integrity": "sha1-C2/nuDWuzaYcbqTU8CwUIh4QmEc=", - "dev": true, - "requires": { - "arr-union": "^3.1.0", - "get-value": "^2.0.6", - "is-extendable": "^0.1.1", - "set-value": "^2.0.1" - } - }, - "uniq": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/uniq/-/uniq-1.0.1.tgz", - "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", - "dev": true - }, - "uniqs": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/uniqs/-/uniqs-2.0.0.tgz", - "integrity": "sha1-/+3ks2slKQaW5uFl1KWe25mOawI=", - "dev": true - }, - "unpipe": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/unpipe/-/unpipe-1.0.0.tgz", - "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", - "dev": true - }, - "unset-value": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/unset-value/-/unset-value-1.0.0.tgz", - "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", - "dev": true, - "requires": { - "has-value": "^0.3.1", - "isobject": "^3.0.0" - }, - "dependencies": { - "has-value": { - "version": "0.3.1", - "resolved": "https://npm-registry.sipwise.com/has-value/-/has-value-0.3.1.tgz", - "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", - "dev": true, - "requires": { - "get-value": "^2.0.3", - "has-values": "^0.1.4", - "isobject": "^2.0.0" - }, - "dependencies": { - "isobject": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-2.1.0.tgz", - "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", - "dev": true, - "requires": { - "isarray": "1.0.0" - } - } - } - }, - "has-values": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/has-values/-/has-values-0.1.4.tgz", - "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", - "dev": true - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "upath": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/upath/-/upath-1.1.0.tgz", - "integrity": "sha512-bzpH/oBhoS/QI/YtbkqCg6VEiPYjSZtrHQM6/QnJS6OL9pKUFLqb3aFh4Scvwm45+7iAgiMkLhSbaZxUqmrprw==", - "dev": true - }, - "upper-case": { - "version": "1.1.3", - "resolved": "https://npm-registry.sipwise.com/upper-case/-/upper-case-1.1.3.tgz", - "integrity": "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=", - "dev": true - }, - "uri-js": { - "version": "4.2.2", - "resolved": "https://npm-registry.sipwise.com/uri-js/-/uri-js-4.2.2.tgz", - "integrity": "sha1-lMVA4f93KVbiKZUHwBCupsiDjrA=", - "dev": true, - "requires": { - "punycode": "^2.1.0" - } - }, - "urix": { - "version": "0.1.0", - "resolved": "https://npm-registry.sipwise.com/urix/-/urix-0.1.0.tgz", - "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", - "dev": true - }, - "url": { - "version": "0.11.0", - "resolved": "https://npm-registry.sipwise.com/url/-/url-0.11.0.tgz", - "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", - "dev": true, - "requires": { - "punycode": "1.3.2", - "querystring": "0.2.0" - }, - "dependencies": { - "punycode": { - "version": "1.3.2", - "resolved": "https://npm-registry.sipwise.com/punycode/-/punycode-1.3.2.tgz", - "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", - "dev": true - } - } - }, - "url-loader": { - "version": "0.5.9", - "resolved": "https://npm-registry.sipwise.com/url-loader/-/url-loader-0.5.9.tgz", - "integrity": "sha1-zI/qgse5Bud3cBklCGnlaemVwpU=", - "dev": true, - "requires": { - "loader-utils": "^1.0.2", - "mime": "1.3.x" - }, - "dependencies": { - "mime": { - "version": "1.3.6", - "resolved": "https://npm-registry.sipwise.com/mime/-/mime-1.3.6.tgz", - "integrity": "sha1-WR2E02U6awtKO5343lqoEI5y5eA=", - "dev": true - } - } - }, - "url-parse-lax": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/url-parse-lax/-/url-parse-lax-1.0.0.tgz", - "integrity": "sha1-evjzA2Rem9eaJy56FKxovAYJ2nM=", - "requires": { - "prepend-http": "^1.0.1" - } - }, - "url-to-options": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/url-to-options/-/url-to-options-1.0.1.tgz", - "integrity": "sha1-FQWgOiiaSMvXpDTvuu7FBV9WM6k=" - }, - "use": { - "version": "3.1.1", - "resolved": "https://npm-registry.sipwise.com/use/-/use-3.1.1.tgz", - "integrity": "sha1-1QyMrHmhn7wg8pEfVuuXP04QBw8=", - "dev": true - }, - "useragent": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/useragent/-/useragent-2.3.0.tgz", - "integrity": "sha1-IX+UOtVAyyEoZYqyP8lg9qiMmXI=", - "dev": true, - "requires": { - "lru-cache": "4.1.x", - "tmp": "0.0.x" - } - }, - "util": { - "version": "0.10.4", - "resolved": "https://npm-registry.sipwise.com/util/-/util-0.10.4.tgz", - "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", - "dev": true, - "requires": { - "inherits": "2.0.3" - } - }, - "util-deprecate": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", - "dev": true - }, - "utila": { - "version": "0.4.0", - "resolved": "https://npm-registry.sipwise.com/utila/-/utila-0.4.0.tgz", - "integrity": "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw=", - "dev": true - }, - "utils-merge": { - "version": "1.0.1", - "resolved": "https://npm-registry.sipwise.com/utils-merge/-/utils-merge-1.0.1.tgz", - "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", - "dev": true - }, - "uuid": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/uuid/-/uuid-3.2.1.tgz", - "integrity": "sha1-EsUou51Y0LkmXZovbw/ovhf/HxQ=" - }, - "validate-npm-package-license": { - "version": "3.0.3", - "resolved": "https://npm-registry.sipwise.com/validate-npm-package-license/-/validate-npm-package-license-3.0.3.tgz", - "integrity": "sha512-63ZOUnL4SIXj4L0NixR3L1lcjO38crAbgrTpl28t8jjrfuiOBL5Iygm+60qPs/KsZGzPNg6Smnc/oY16QTjF0g==", - "dev": true, - "requires": { - "spdx-correct": "^3.0.0", - "spdx-expression-parse": "^3.0.0" - } - }, - "vary": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/vary/-/vary-1.1.2.tgz", - "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", - "dev": true - }, - "vendors": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/vendors/-/vendors-1.0.2.tgz", - "integrity": "sha512-w/hry/368nO21AN9QljsaIhb9ZiZtZARoVH5f3CsFbawdLdayCgKRPup7CggujvySMxx0I91NOyxdVENohprLQ==", - "dev": true - }, - "vm-browserify": { - "version": "0.0.4", - "resolved": "https://npm-registry.sipwise.com/vm-browserify/-/vm-browserify-0.0.4.tgz", - "integrity": "sha1-XX6kW7755Kb/ZflUOOCofDV9WnM=", - "dev": true, - "requires": { - "indexof": "0.0.1" - } - }, - "void-elements": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/void-elements/-/void-elements-2.0.1.tgz", - "integrity": "sha1-wGavtYK7HLQSjWDqkjkulNXp2+w=", - "dev": true - }, - "vue": { - "version": "2.5.16", - "resolved": "https://npm-registry.sipwise.com/vue/-/vue-2.5.16.tgz", - "integrity": "sha512-/ffmsiVuPC8PsWcFkZngdpas19ABm5mh2wA7iDqcltyCTwlgZjHGeJYOXkBMo422iPwIcviOtrTCUpSfXmToLQ==" - }, - "vue-hot-reload-api": { - "version": "2.3.0", - "resolved": "https://npm-registry.sipwise.com/vue-hot-reload-api/-/vue-hot-reload-api-2.3.0.tgz", - "integrity": "sha512-2j/t+wIbyVMP5NvctQoSUvLkYKoWAAk2QlQiilrM2a6/ulzFgdcLUJfTvs4XQ/3eZhHiBmmEojbjmM4AzZj8JA==", - "dev": true - }, - "vue-i18n": { - "version": "7.3.2", - "resolved": "https://npm-registry.sipwise.com/vue-i18n/-/vue-i18n-7.3.2.tgz", - "integrity": "sha1-EgW7iBEyP9XETlfk/WGb6vL3qaE=" - }, - "vue-loader": { - "version": "13.7.2", - "resolved": "https://npm-registry.sipwise.com/vue-loader/-/vue-loader-13.7.2.tgz", - "integrity": "sha512-pgFWFsUjYO1v+J+3r7K0Q4lCp0eOyI24/q9j+cCudWyCTjgpjpcAa1MdwjlDUUettt9xkkUBbQ9fkAN1NC8t9w==", - "dev": true, - "requires": { - "consolidate": "^0.14.0", - "hash-sum": "^1.0.2", - "loader-utils": "^1.1.0", - "lru-cache": "^4.1.1", - "postcss": "^6.0.8", - "postcss-load-config": "^1.1.0", - "postcss-selector-parser": "^2.0.0", - "prettier": "^1.7.0", - "resolve": "^1.4.0", - "source-map": "^0.6.1", - "vue-hot-reload-api": "^2.2.0", - "vue-style-loader": "^3.0.0", - "vue-template-es2015-compiler": "^1.6.0" - }, - "dependencies": { - "ansi-styles": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dev": true, - "requires": { - "color-convert": "^1.9.0" - } - }, - "chalk": { - "version": "2.4.1", - "resolved": "https://npm-registry.sipwise.com/chalk/-/chalk-2.4.1.tgz", - "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - } - }, - "has-flag": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", - "dev": true - }, - "postcss": { - "version": "6.0.23", - "resolved": "https://npm-registry.sipwise.com/postcss/-/postcss-6.0.23.tgz", - "integrity": "sha1-YcgswyisYOZ3ZF+XkFTrmLwOMyQ=", - "dev": true, - "requires": { - "chalk": "^2.4.1", - "source-map": "^0.6.1", - "supports-color": "^5.4.0" - } - }, - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - }, - "supports-color": { - "version": "5.4.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-5.4.0.tgz", - "integrity": "sha512-zjaXglF5nnWpsq470jSv6P9DwPvgLkuapYmfDm3JWOm0vkNTVF2tI4UrN2r6jH1qM/uc/WtxYY1hYoA2dOKj5w==", - "dev": true, - "requires": { - "has-flag": "^3.0.0" - } - } - } - }, - "vue-password-strength-meter": { - "version": "1.7.2", - "resolved": "https://npm-registry.sipwise.com/vue-password-strength-meter/-/vue-password-strength-meter-1.7.2.tgz", - "integrity": "sha512-S17DsEbXciTcI0fKq1PXia7i3COM/AJOT7os8AVyGxglc5ho1EBssE+ogDa5cFh6Rn8pPgqfVCt/KBcNpgPBiA==" - }, - "vue-resource": { - "version": "1.3.4", - "resolved": "https://npm-registry.sipwise.com/vue-resource/-/vue-resource-1.3.4.tgz", - "integrity": "sha1-n8C99qL1yrQwEp/JnTR7PernsJk=", - "requires": { - "got": "^7.0.0" - } - }, - "vue-router": { - "version": "2.8.1", - "resolved": "https://npm-registry.sipwise.com/vue-router/-/vue-router-2.8.1.tgz", - "integrity": "sha1-mDPJ7lesg76wJpBW/v7nFxPyBpU=" - }, - "vue-scrollto": { - "version": "2.11.0", - "resolved": "https://npm-registry.sipwise.com/vue-scrollto/-/vue-scrollto-2.11.0.tgz", - "integrity": "sha1-BlfxJ/re1gpx+8yEHzkyeaSa7VU=", - "dev": true, - "requires": { - "bezier-easing": "^2.0.3" - } - }, - "vue-style-loader": { - "version": "3.1.2", - "resolved": "https://npm-registry.sipwise.com/vue-style-loader/-/vue-style-loader-3.1.2.tgz", - "integrity": "sha1-a2atNJmPyVIMLx5NX6QJFkHBWXo=", - "dev": true, - "requires": { - "hash-sum": "^1.0.2", - "loader-utils": "^1.0.2" - } - }, - "vue-template-compiler": { - "version": "2.5.16", - "resolved": "https://npm-registry.sipwise.com/vue-template-compiler/-/vue-template-compiler-2.5.16.tgz", - "integrity": "sha512-ZbuhCcF/hTYmldoUOVcu2fcbeSAZnfzwDskGduOrnjBiIWHgELAd+R8nAtX80aZkceWDKGQ6N9/0/EUpt+l22A==", - "dev": true, - "requires": { - "de-indent": "^1.0.2", - "he": "^1.1.0" - } - }, - "vue-template-es2015-compiler": { - "version": "1.6.0", - "resolved": "https://npm-registry.sipwise.com/vue-template-es2015-compiler/-/vue-template-es2015-compiler-1.6.0.tgz", - "integrity": "sha512-x3LV3wdmmERhVCYy3quqA57NJW7F3i6faas++pJQWtknWT+n7k30F4TVdHvCLn48peTJFRvCpxs3UuFPqgeELg==", - "dev": true - }, - "vuelidate": { - "version": "0.7.4", - "resolved": "https://npm-registry.sipwise.com/vuelidate/-/vuelidate-0.7.4.tgz", - "integrity": "sha1-Wg5UvgmsAZLxqjOH10uS4JRb+Ko=" - }, - "vuex": { - "version": "2.5.0", - "resolved": "https://npm-registry.sipwise.com/vuex/-/vuex-2.5.0.tgz", - "integrity": "sha1-IPAmWt5smlrGckpAXT/9tHJsl0E=" - }, - "vuex-router-sync": { - "version": "4.3.2", - "resolved": "https://npm-registry.sipwise.com/vuex-router-sync/-/vuex-router-sync-4.3.2.tgz", - "integrity": "sha1-YEtho3faqmiy726OAyayytJvNZ4=" - }, - "watchpack": { - "version": "1.6.0", - "resolved": "https://npm-registry.sipwise.com/watchpack/-/watchpack-1.6.0.tgz", - "integrity": "sha1-S8EsLr6KonenHx0/FNaFx7RGzQA=", - "dev": true, - "requires": { - "chokidar": "^2.0.2", - "graceful-fs": "^4.1.2", - "neo-async": "^2.5.0" - }, - "dependencies": { - "anymatch": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/anymatch/-/anymatch-2.0.0.tgz", - "integrity": "sha1-vLJLTzeTTZqnrBe0ra+J58du8us=", - "dev": true, - "requires": { - "micromatch": "^3.1.4", - "normalize-path": "^2.1.1" - } - }, - "arr-diff": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", - "dev": true - }, - "array-unique": { - "version": "0.3.2", - "resolved": "https://npm-registry.sipwise.com/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", - "dev": true - }, - "braces": { - "version": "2.3.2", - "resolved": "https://npm-registry.sipwise.com/braces/-/braces-2.3.2.tgz", - "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", - "dev": true, - "requires": { - "arr-flatten": "^1.1.0", - "array-unique": "^0.3.2", - "extend-shallow": "^2.0.1", - "fill-range": "^4.0.0", - "isobject": "^3.0.1", - "repeat-element": "^1.1.2", - "snapdragon": "^0.8.1", - "snapdragon-node": "^2.0.1", - "split-string": "^3.0.2", - "to-regex": "^3.0.1" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "chokidar": { - "version": "2.0.4", - "resolved": "https://npm-registry.sipwise.com/chokidar/-/chokidar-2.0.4.tgz", - "integrity": "sha512-z9n7yt9rOvIJrMhvDtDictKrkFHeihkNl6uWMmZlmL6tJtX9Cs+87oK+teBx+JIgzvbX3yZHT3eF8vpbDxHJXQ==", - "dev": true, - "requires": { - "anymatch": "^2.0.0", - "async-each": "^1.0.0", - "braces": "^2.3.0", - "fsevents": "^1.2.2", - "glob-parent": "^3.1.0", - "inherits": "^2.0.1", - "is-binary-path": "^1.0.0", - "is-glob": "^4.0.0", - "lodash.debounce": "^4.0.8", - "normalize-path": "^2.1.1", - "path-is-absolute": "^1.0.0", - "readdirp": "^2.0.0", - "upath": "^1.0.5" - } - }, - "expand-brackets": { - "version": "2.1.4", - "resolved": "https://npm-registry.sipwise.com/expand-brackets/-/expand-brackets-2.1.4.tgz", - "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", - "dev": true, - "requires": { - "debug": "^2.3.3", - "define-property": "^0.2.5", - "extend-shallow": "^2.0.1", - "posix-character-classes": "^0.1.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - }, - "is-accessor-descriptor": { - "version": "0.1.6", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", - "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-data-descriptor": { - "version": "0.1.4", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", - "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-descriptor": { - "version": "0.1.6", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-0.1.6.tgz", - "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", - "dev": true, - "requires": { - "is-accessor-descriptor": "^0.1.6", - "is-data-descriptor": "^0.1.4", - "kind-of": "^5.0.0" - } - }, - "kind-of": { - "version": "5.1.0", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-5.1.0.tgz", - "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", - "dev": true - } - } - }, - "extglob": { - "version": "2.0.4", - "resolved": "https://npm-registry.sipwise.com/extglob/-/extglob-2.0.4.tgz", - "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", - "dev": true, - "requires": { - "array-unique": "^0.3.2", - "define-property": "^1.0.0", - "expand-brackets": "^2.1.4", - "extend-shallow": "^2.0.1", - "fragment-cache": "^0.2.1", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", - "dev": true, - "requires": { - "is-descriptor": "^1.0.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "fill-range": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/fill-range/-/fill-range-4.0.0.tgz", - "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", - "dev": true, - "requires": { - "extend-shallow": "^2.0.1", - "is-number": "^3.0.0", - "repeat-string": "^1.6.1", - "to-regex-range": "^2.1.0" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "glob-parent": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/glob-parent/-/glob-parent-3.1.0.tgz", - "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", - "dev": true, - "requires": { - "is-glob": "^3.1.0", - "path-dirname": "^1.0.0" - }, - "dependencies": { - "is-glob": { - "version": "3.1.0", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-3.1.0.tgz", - "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", - "dev": true, - "requires": { - "is-extglob": "^2.1.0" - } - } - } - }, - "is-accessor-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", - "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-data-descriptor": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", - "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", - "dev": true, - "requires": { - "kind-of": "^6.0.0" - } - }, - "is-descriptor": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/is-descriptor/-/is-descriptor-1.0.2.tgz", - "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", - "dev": true, - "requires": { - "is-accessor-descriptor": "^1.0.0", - "is-data-descriptor": "^1.0.0", - "kind-of": "^6.0.2" - } - }, - "is-glob": { - "version": "4.0.0", - "resolved": "https://npm-registry.sipwise.com/is-glob/-/is-glob-4.0.0.tgz", - "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", - "dev": true, - "requires": { - "is-extglob": "^2.1.1" - } - }, - "is-number": { - "version": "3.0.0", - "resolved": "https://npm-registry.sipwise.com/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://npm-registry.sipwise.com/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, - "kind-of": { - "version": "6.0.2", - "resolved": "https://npm-registry.sipwise.com/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - }, - "micromatch": { - "version": "3.1.10", - "resolved": "https://npm-registry.sipwise.com/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } - } - } - }, - "webpack": { - "version": "3.12.0", - "resolved": "https://npm-registry.sipwise.com/webpack/-/webpack-3.12.0.tgz", - "integrity": "sha1-P540NgNwYC/PY56Xk520hvTsDXQ=", - "dev": true, - "requires": { - "acorn": "^5.0.0", - "acorn-dynamic-import": "^2.0.0", - "ajv": "^6.1.0", - "ajv-keywords": "^3.1.0", - "async": "^2.1.2", - "enhanced-resolve": "^3.4.0", - "escope": "^3.6.0", - "interpret": "^1.0.0", - "json-loader": "^0.5.4", - "json5": "^0.5.1", - "loader-runner": "^2.3.0", - "loader-utils": "^1.1.0", - "memory-fs": "~0.4.1", - "mkdirp": "~0.5.0", - "node-libs-browser": "^2.0.0", - "source-map": "^0.5.3", - "supports-color": "^4.2.1", - "tapable": "^0.2.7", - "uglifyjs-webpack-plugin": "^0.4.6", - "watchpack": "^1.4.0", - "webpack-sources": "^1.0.1", - "yargs": "^8.0.2" - }, - "dependencies": { - "ajv": { - "version": "6.5.2", - "resolved": "https://npm-registry.sipwise.com/ajv/-/ajv-6.5.2.tgz", - "integrity": "sha512-hOs7GfvI6tUI1LfZddH82ky6mOMyTuY0mk7kE2pWpmhhUSkumzaTO5vbVwij39MdwPQWCV4Zv57Eo06NtL/GVA==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.1" - } - }, - "ajv-keywords": { - "version": "3.2.0", - "resolved": "https://npm-registry.sipwise.com/ajv-keywords/-/ajv-keywords-3.2.0.tgz", - "integrity": "sha1-6GuBnGAs+IIa1jdBNpjx3sAhhHo=", - "dev": true - }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://npm-registry.sipwise.com/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", - "dev": true - }, - "has-flag": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/has-flag/-/has-flag-2.0.0.tgz", - "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", - "dev": true - }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://npm-registry.sipwise.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha1-afaofZUTq4u4/mO9sJecRI5oRmA=", - "dev": true - }, - "supports-color": { - "version": "4.5.0", - "resolved": "https://npm-registry.sipwise.com/supports-color/-/supports-color-4.5.0.tgz", - "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", - "dev": true, - "requires": { - "has-flag": "^2.0.0" - } - } - } - }, - "webpack-dev-middleware": { - "version": "1.12.2", - "resolved": "https://npm-registry.sipwise.com/webpack-dev-middleware/-/webpack-dev-middleware-1.12.2.tgz", - "integrity": "sha1-+PwRIM47T8VoDO7LQ9d3lmshEF4=", - "dev": true, - "requires": { - "memory-fs": "~0.4.1", - "mime": "^1.5.0", - "path-is-absolute": "^1.0.0", - "range-parser": "^1.0.3", - "time-stamp": "^2.0.0" - }, - "dependencies": { - "mime": { - "version": "1.6.0", - "resolved": "https://npm-registry.sipwise.com/mime/-/mime-1.6.0.tgz", - "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", - "dev": true - } - } - }, - "webpack-hot-middleware": { - "version": "2.22.3", - "resolved": "https://npm-registry.sipwise.com/webpack-hot-middleware/-/webpack-hot-middleware-2.22.3.tgz", - "integrity": "sha512-mrG3bJGX4jgWbrpY0ghIpPgCmNhZziFMBJBmZfpIe6K/P1rWPkdkbGihbCUIufgQ8ruX4txE5/CKSeFNzDcYOw==", - "dev": true, - "requires": { - "ansi-html": "0.0.7", - "html-entities": "^1.2.0", - "querystring": "^0.2.0", - "strip-ansi": "^3.0.0" - } - }, - "webpack-merge": { - "version": "4.1.3", - "resolved": "https://npm-registry.sipwise.com/webpack-merge/-/webpack-merge-4.1.3.tgz", - "integrity": "sha512-zxwAIGK7nKdu5CIZL0BjTQoq3elV0t0MfB7rUC1zj668geid52abs6hN/ACwZdK6LeMS8dC9B6WmtF978zH5mg==", - "dev": true, - "requires": { - "lodash": "^4.17.5" - }, - "dependencies": { - "lodash": { - "version": "4.17.15", - "resolved": "https://npm-registry.sipwise.com/lodash/-/lodash-4.17.15.tgz", - "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", - "dev": true - } - } - }, - "webpack-sources": { - "version": "1.1.0", - "resolved": "https://npm-registry.sipwise.com/webpack-sources/-/webpack-sources-1.1.0.tgz", - "integrity": "sha512-aqYp18kPphgoO5c/+NaUvEeACtZjMESmDChuD3NBciVpah3XpMEU9VAAtIaB1BsfJWWTSdv8Vv1m3T0aRk2dUw==", - "dev": true, - "requires": { - "source-list-map": "^2.0.0", - "source-map": "~0.6.1" - }, - "dependencies": { - "source-map": { - "version": "0.6.1", - "resolved": "https://npm-registry.sipwise.com/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha1-dHIq8y6WFOnCh6jQu95IteLxomM=", - "dev": true - } - } - }, - "when": { - "version": "3.6.4", - "resolved": "https://npm-registry.sipwise.com/when/-/when-3.6.4.tgz", - "integrity": "sha1-RztRfsFZ4rhQBUl6E5g/CVQS404=", - "dev": true - }, - "whet.extend": { - "version": "0.9.9", - "resolved": "https://npm-registry.sipwise.com/whet.extend/-/whet.extend-0.9.9.tgz", - "integrity": "sha1-+HfVv2SMl+WqVC+twW1qJZucEaE=", - "dev": true - }, - "which": { - "version": "1.3.1", - "resolved": "https://npm-registry.sipwise.com/which/-/which-1.3.1.tgz", - "integrity": "sha1-pFBD1U9YBTFtqNYvn1CRjT2nCwo=", - "dev": true, - "requires": { - "isexe": "^2.0.0" - } - }, - "which-module": { - "version": "2.0.0", - "resolved": "https://npm-registry.sipwise.com/which-module/-/which-module-2.0.0.tgz", - "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", - "dev": true - }, - "window-size": { - "version": "0.1.0", - "resolved": "https://npm-registry.sipwise.com/window-size/-/window-size-0.1.0.tgz", - "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=", - "dev": true - }, - "wordwrap": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/wordwrap/-/wordwrap-1.0.0.tgz", - "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", - "dev": true - }, - "wrap-ansi": { - "version": "2.1.0", - "resolved": "https://npm-registry.sipwise.com/wrap-ansi/-/wrap-ansi-2.1.0.tgz", - "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", - "dev": true, - "requires": { - "string-width": "^1.0.1", - "strip-ansi": "^3.0.1" - }, - "dependencies": { - "is-fullwidth-code-point": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", - "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", - "dev": true, - "requires": { - "number-is-nan": "^1.0.0" - } - }, - "string-width": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/string-width/-/string-width-1.0.2.tgz", - "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", - "dev": true, - "requires": { - "code-point-at": "^1.0.0", - "is-fullwidth-code-point": "^1.0.0", - "strip-ansi": "^3.0.0" - } - } - } - }, - "wrappy": { - "version": "1.0.2", - "resolved": "https://npm-registry.sipwise.com/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", - "dev": true - }, - "write": { - "version": "0.2.1", - "resolved": "https://npm-registry.sipwise.com/write/-/write-0.2.1.tgz", - "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", - "dev": true, - "requires": { - "mkdirp": "^0.5.1" - } - }, - "ws": { - "version": "1.1.2", - "resolved": "https://npm-registry.sipwise.com/ws/-/ws-1.1.2.tgz", - "integrity": "sha1-iiRPoFJAHgjJiGz0SoUYnh/UBn8=", - "dev": true, - "requires": { - "options": ">=0.0.5", - "ultron": "1.0.x" - } - }, - "wtf-8": { - "version": "1.0.0", - "resolved": "https://npm-registry.sipwise.com/wtf-8/-/wtf-8-1.0.0.tgz", - "integrity": "sha1-OS2LotDxw00e4tYw8V0O+2jhBIo=", - "dev": true - }, - "xmlbuilder": { - "version": "8.2.2", - "resolved": "https://npm-registry.sipwise.com/xmlbuilder/-/xmlbuilder-8.2.2.tgz", - "integrity": "sha1-aSSGc0ELS6QuGmE2VR0pIjNap3M=", - "dev": true - }, - "xmlhttprequest-ssl": { - "version": "1.5.3", - "resolved": "https://npm-registry.sipwise.com/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.3.tgz", - "integrity": "sha1-GFqIjATspGw+QHDZn3tJ3jUomS0=", - "dev": true - }, - "xtend": { - "version": "4.0.1", - "resolved": "https://npm-registry.sipwise.com/xtend/-/xtend-4.0.1.tgz", - "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", - "dev": true - }, - "y18n": { - "version": "3.2.1", - "resolved": "https://npm-registry.sipwise.com/y18n/-/y18n-3.2.1.tgz", - "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=", - "dev": true - }, - "yallist": { - "version": "2.1.2", - "resolved": "https://npm-registry.sipwise.com/yallist/-/yallist-2.1.2.tgz", - "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", - "dev": true - }, - "yargs": { - "version": "8.0.2", - "resolved": "https://npm-registry.sipwise.com/yargs/-/yargs-8.0.2.tgz", - "integrity": "sha1-YpmpBVsc78lp/355wdkY3Osiw2A=", - "dev": true, - "requires": { - "camelcase": "^4.1.0", - "cliui": "^3.2.0", - "decamelize": "^1.1.1", - "get-caller-file": "^1.0.1", - "os-locale": "^2.0.0", - "read-pkg-up": "^2.0.0", - "require-directory": "^2.1.1", - "require-main-filename": "^1.0.1", - "set-blocking": "^2.0.0", - "string-width": "^2.0.0", - "which-module": "^2.0.0", - "y18n": "^3.2.1", - "yargs-parser": "^7.0.0" - } - }, - "yargs-parser": { - "version": "7.0.0", - "resolved": "https://npm-registry.sipwise.com/yargs-parser/-/yargs-parser-7.0.0.tgz", - "integrity": "sha1-jQrELxbqVd69MyyvTEA4s+P139k=", - "dev": true, - "requires": { - "camelcase": "^4.1.0" - } - }, - "yeast": { - "version": "0.1.2", - "resolved": "https://npm-registry.sipwise.com/yeast/-/yeast-0.1.2.tgz", - "integrity": "sha1-AI4G2AlDIMNy28L47XagymyKxBk=", - "dev": true - }, - "zxcvbn": { - "version": "4.4.2", - "resolved": "https://npm-registry.sipwise.com/zxcvbn/-/zxcvbn-4.4.2.tgz", - "integrity": "sha1-KOwXzwl0PtyrBW3dixsGJizHPDA=" - } - } -} diff --git a/package.json b/package.json index ee95246d..1fc73f74 100644 --- a/package.json +++ b/package.json @@ -1,93 +1,71 @@ { "name": "ngcp-csc-ui", - "productName": "Customer Self-Care Web UI", - "version": "0.3.1", - "description": "Customer Self-Care Web UI", + "version": "0.0.1", + "description": "A Quasar Framework app", + "productName": "Customer Self-Care Web Interface", "author": "Hans-Peter Herzog ", + "private": true, "scripts": { - "clean": "node build/script.clean.js", - "dev": "node build/script.dev.js", - "build": "node build/script.build.js mat", - "dev-build": "CSC_SOURCE_MAP=1 CSC_WATCH=1 node build/script.build.js mat", - "test": "karma start ./karma.js --single-run", - "dev-test": "karma start ./karma.js", - "dev-docker": "docker pull docker.mgm.sipwise.com/ngcp-csc-ui-env-buster; docker run --rm -p 8080:8080 -i -t -v $(pwd):/code:rw docker.mgm.sipwise.com/ngcp-csc-ui-env-buster:latest env/run_csc_ui $1" + "lint": "eslint --ext .js,.vue ./", + "test": "echo \"See package.json => scripts for available tests.\" && exit 0", + "build": "./node_modules/@quasar/cli/bin/quasar build", + "dev": "./node_modules/@quasar/cli/bin/quasar dev", + "dev:docker": "docker pull docker.mgm.sipwise.com/ngcp-csc-ui-env-buster; docker run --rm -p 8080:8080 -i -t -v $(pwd):/code:rw docker.mgm.sipwise.com/ngcp-csc-ui-env-buster:latest env/run_csc_ui $1", + "test:unit": "jest --updateSnapshot", + "test:unit:coverage": "jest --coverage", + "test:unit:watch": "jest --watch", + "test:unit:watchAll": "jest --watchAll", + "serve:test:coverage": "quasar serve test/jest/coverage/lcov-report/ --port 8788", + "concurrently:dev:jest": "concurrently \"quasar dev\" \"jest --watch\"" }, "dependencies": { - "babel-runtime": "^6.25.0", - "quasar-extras": "0.x", - "quasar-framework": "0.14.9", - "uuid": "3.2.1", - "vue": "^2.5.0", - "vue-i18n": "7.3.2", - "vue-password-strength-meter": "1.7.2", - "vue-resource": "1.3.4", - "vue-router": "^2.5.0", - "vuelidate": "0.7.4", - "vuex": "2.5.0", - "vuex-router-sync": "4.3.2", - "zxcvbn": "4.4.2" + "@quasar/extras": "^1.9.5", + "axios": "^0.18.1", + "core-js": "^3.6.5", + "file-saver": "^2.0.2", + "jest-junit": "^11.1.0", + "jwt-decode": "^2.2.0", + "load-script": "^1.0.0", + "lodash": "^4.17.20", + "moment": "^2.27.0", + "quasar": "^1.14.0", + "vue-i18n": "^8.0.0", + "vue-password-strength-meter": "^1.7.2", + "vue-resource": "^1.5.1", + "vue-scrollto": "^2.18.2", + "vuelidate": "^0.7.5", + "zxcvbn": "^4.4.2" }, "devDependencies": { - "autoprefixer": "^6.4.0", - "babel-core": "^6.0.0", - "babel-eslint": "^7.0.0", - "babel-loader": "^7.1.2", - "babel-plugin-transform-runtime": "^6.0.0", - "babel-preset-es2015": "^6.0.0", - "babel-preset-stage-2": "^6.0.0", - "chai": "^4.1.2", - "colors": "^1.1.2", - "connect-history-api-fallback": "^1.1.0", - "crypto-browserify": "3.12.0", - "css-loader": "^0.28.7", - "es6-promise": "^4.1.1", - "eslint": "^4.8.0", - "eslint-config-standard": "^10.2.1", - "eslint-friendly-formatter": "^3.0.0", - "eslint-loader": "^1.9.0", - "eslint-plugin-html": "^3.2.2", - "eslint-plugin-import": "^2.7.0", - "eslint-plugin-node": "^5.2.0", - "eslint-plugin-promise": "^3.5.0", - "eslint-plugin-standard": "^3.0.1", - "eventsource-polyfill": "^0.9.6", - "express": "^4.16.1", - "extract-text-webpack-plugin": "^3.0.0", - "file-loader": "^0.11.1", - "file-saver": "1.3.3", - "friendly-errors-webpack-plugin": "^1.1.3", - "glob": "^7.1.2", - "google-libphonenumber": "3.0.7", - "html-webpack-plugin": "^2.30.1", - "http-proxy-middleware": "0.19.1", - "json-loader": "^0.5.7", - "karma": "^1.7.1", - "karma-chrome-launcher": "^2.2.0", - "karma-firefox-launcher": "^1.0.1", - "karma-junit-reporter": "^1.2.0", - "karma-mocha": "^1.3.0", - "karma-webpack": "^2.0.4", - "load-script": "1.0.0", - "lodash": "4.17.15", - "mocha": "^4.0.0", - "moment": "2.22.2", - "opn": "^5.0.0", - "optimize-css-assets-webpack-plugin": "^3.2.0", - "postcss-loader": "^1.0.0", - "progress-bar-webpack-plugin": "^1.10.0", - "purify-css": "^1.2.6", - "shelljs": "^0.7.0", - "stylus": "^0.54.5", - "stylus-loader": "^3.0.1", - "url-loader": "^0.5.7", - "vue-loader": "^13.0.5", - "vue-scrollto": "2.11.0", - "vue-style-loader": "^3.0.3", - "vue-template-compiler": "^2.5.0", - "webpack": "^3.6.0", - "webpack-dev-middleware": "^1.12.0", - "webpack-hot-middleware": "^2.19.1", - "webpack-merge": "^4.1.0" + "@quasar/app": "^2.1.0", + "@quasar/cli": "^1.1.0", + "@quasar/quasar-app-extension-testing": "^1.0.0", + "@quasar/quasar-app-extension-testing-unit-jest": "^1.0.1", + "babel-eslint": "^10.0.1", + "eslint": "^6.8.0", + "eslint-config-standard": "^14.1.0", + "eslint-loader": "^3.0.3", + "eslint-plugin-import": "^2.14.0", + "eslint-plugin-node": "^11.0.0", + "eslint-plugin-promise": "^4.0.1", + "eslint-plugin-standard": "^4.0.0", + "eslint-plugin-vue": "^6.1.2", + "parseuri": "^0.0.6" + }, + "browserslist": [ + "last 10 Chrome versions", + "last 10 Firefox versions", + "last 4 Edge versions", + "last 7 Safari versions", + "last 8 Android versions", + "last 8 ChromeAndroid versions", + "last 8 FirefoxAndroid versions", + "last 10 iOS versions", + "last 5 Opera versions" + ], + "engines": { + "node": ">= 10.18.1", + "npm": ">= 6.13.4", + "yarn": ">= 1.21.1" } } diff --git a/src/statics/favicon.ico b/public/favicon.ico similarity index 100% rename from src/statics/favicon.ico rename to public/favicon.ico diff --git a/src/statics/ring.mp3 b/public/ring.mp3 similarity index 100% rename from src/statics/ring.mp3 rename to public/ring.mp3 diff --git a/src/statics/ring.ogg b/public/ring.ogg similarity index 100% rename from src/statics/ring.ogg rename to public/ring.ogg diff --git a/public/service-worker.js b/public/service-worker.js new file mode 100644 index 00000000..e9bd274f --- /dev/null +++ b/public/service-worker.js @@ -0,0 +1,17 @@ + +self.addEventListener('notificationclick', function (event) { + event.notification.close() + var promiseChain = clients.matchAll({ + type: 'window', + includeUncontrolled: true + }).then((windowClients) => { + var matchingClient = null + for (var i = 0; i < windowClients.length; i++) { + var windowClient = windowClients[i] + if (windowClient.url === event.notification.data.url) { + return windowClient.focus() + } + } + }) + event.waitUntil(promiseChain) +}) diff --git a/src/statics/sipwise_ale_logo.svg b/public/sipwise_ale_logo.svg similarity index 100% rename from src/statics/sipwise_ale_logo.svg rename to public/sipwise_ale_logo.svg diff --git a/src/statics/sipwise_ale_logo_1024_transparent.png b/public/sipwise_ale_logo_1024_transparent.png similarity index 100% rename from src/statics/sipwise_ale_logo_1024_transparent.png rename to public/sipwise_ale_logo_1024_transparent.png diff --git a/quasar.conf.js b/quasar.conf.js new file mode 100644 index 00000000..932aaeec --- /dev/null +++ b/quasar.conf.js @@ -0,0 +1,214 @@ +/* + * This file runs in a Node context (it's NOT transpiled by Babel), so use only + * the ES6 features that are supported by your Node version. https://node.green/ + */ + +// Configuration for your app +// https://quasar.dev/quasar-cli/quasar-conf-js +/* eslint-env node */ + +module.exports = function (/* ctx */) { + return { + // https://quasar.dev/quasar-cli/supporting-ts + supportTS: false, + + // https://quasar.dev/quasar-cli/prefetch-feature + // preFetch: true, + + // app boot file (/src/boot) + // --> boot files are part of "main.js" + // https://quasar.dev/quasar-cli/boot-files + boot: [ + 'config', + 'filters', + 'vuelidate', + 'i18n', + // 'axios', + 'vue-resource', + 'routes', + 'components', + 'vue-scrollto', + 'constants' + ], + + // https://quasar.dev/quasar-cli/quasar-conf-js#Property%3A-css + css: [ + 'app.fonts.styl', + 'app.common.styl', + 'app.styl' + ], + + // https://github.com/quasarframework/quasar/tree/dev/extras + extras: [ + // 'ionicons-v4', + // 'mdi-v5', + 'fontawesome-v5', + // 'eva-icons', + // 'themify', + // 'line-awesome', + // 'roboto-font-latin-ext', // this or either 'roboto-font', NEVER both! + + 'roboto-font', // optional, you are not bound to it + 'material-icons' // optional, you are not bound to it + ], + + // Full list of options: https://quasar.dev/quasar-cli/quasar-conf-js#Property%3A-build + build: { + vueRouterMode: 'hash', // available values: 'hash', 'history' + + // transpile: false, + + // Add dependencies for transpiling with Babel (Array of string/regex) + // (from node_modules, which are by default not transpiled). + // Applies only if "transpile" is set to true. + // transpileDependencies: [], + + // rtl: false, // https://quasar.dev/options/rtl-support + // preloadChunks: true, + // showProgress: false, + // gzip: true, + // analyze: true, + + // Options below are automatically set depending on the env, set them if you want to override + // extractCSS: false, + + // https://quasar.dev/quasar-cli/handling-webpack + extendWebpack (cfg) { + cfg.module.rules.push({ + enforce: 'pre', + test: /\.(js|vue)$/, + loader: 'eslint-loader', + exclude: /node_modules/ + }) + } + }, + + // Full list of options: https://quasar.dev/quasar-cli/quasar-conf-js#Property%3A-devServer + devServer: { + https: false, + port: 8080, + open: true // opens browser window automatically + }, + + // https://quasar.dev/quasar-cli/quasar-conf-js#Property%3A-framework + framework: { + iconSet: 'material-icons', // Quasar icon set + lang: 'en-us', // Quasar language pack + config: {}, + + // Possible values for "importStrategy": + // * 'auto' - (DEFAULT) Auto-import needed Quasar components & directives + // * 'all' - Manually specify what to import + importStrategy: 'auto', + + // For special cases outside of where "auto" importStrategy can have an impact + // (like functional components as one of the examples), + // you can manually specify Quasar components/directives to be available everywhere: + // + // components: [], + // directives: [], + + // Quasar plugins + plugins: [ + 'Notify', + 'Dialog', + 'SessionStorage', + 'LocalStorage', + 'Dark' + ] + }, + + // animations: 'all', // --- includes all animations + // https://quasar.dev/options/animations + animations: [], + + // https://quasar.dev/quasar-cli/developing-ssr/configuring-ssr + ssr: { + pwa: false + }, + + // https://quasar.dev/quasar-cli/developing-pwa/configuring-pwa + pwa: { + workboxPluginMode: 'GenerateSW', // 'GenerateSW' or 'InjectManifest' + workboxOptions: {}, // only for GenerateSW + manifest: { + name: 'Customer Self-Care Web Interface', + short_name: 'Customer Self-Care Web Interface', + description: 'A Quasar Framework app', + display: 'standalone', + orientation: 'portrait', + background_color: '#ffffff', + theme_color: '#027be3', + icons: [ + { + src: 'icons/icon-128x128.png', + sizes: '128x128', + type: 'image/png' + }, + { + src: 'icons/icon-192x192.png', + sizes: '192x192', + type: 'image/png' + }, + { + src: 'icons/icon-256x256.png', + sizes: '256x256', + type: 'image/png' + }, + { + src: 'icons/icon-384x384.png', + sizes: '384x384', + type: 'image/png' + }, + { + src: 'icons/icon-512x512.png', + sizes: '512x512', + type: 'image/png' + } + ] + } + }, + + // Full list of options: https://quasar.dev/quasar-cli/developing-cordova-apps/configuring-cordova + cordova: { + // noIosLegacyBuildFlag: true, // uncomment only if you know what you are doing + }, + + // Full list of options: https://quasar.dev/quasar-cli/developing-capacitor-apps/configuring-capacitor + capacitor: { + hideSplashscreen: true + }, + + // Full list of options: https://quasar.dev/quasar-cli/developing-electron-apps/configuring-electron + electron: { + bundler: 'packager', // 'packager' or 'builder' + + packager: { + // https://github.com/electron-userland/electron-packager/blob/master/docs/api.md#options + + // OS X / Mac App Store + // appBundleId: '', + // appCategoryType: '', + // osxSign: '', + // protocol: 'myapp://path', + + // Windows only + // win32metadata: { ... } + }, + + builder: { + // https://www.electron.build/configuration/configuration + + appId: 'ngcp-csc-ui' + }, + + // More info: https://quasar.dev/quasar-cli/developing-electron-apps/node-integration + nodeIntegration: true, + + extendWebpack (/* cfg */) { + // do something with Electron main process Webpack cfg + // chainWebpack also available besides this extendWebpack + } + } + } +} diff --git a/quasar.extensions.json b/quasar.extensions.json new file mode 100644 index 00000000..fff91966 --- /dev/null +++ b/quasar.extensions.json @@ -0,0 +1,14 @@ +{ + "@quasar/testing": { + "harnesses": [ + "unit-jest" + ] + }, + "@quasar/testing-unit-jest": { + "babel": "babelrc", + "options": [ + "scripts", + "SFC" + ] + } +} \ No newline at end of file diff --git a/quasar.testing.json b/quasar.testing.json new file mode 100644 index 00000000..090d098d --- /dev/null +++ b/quasar.testing.json @@ -0,0 +1,5 @@ +{ + "unit-jest": { + "runnerCommand": "jest" + } +} \ No newline at end of file diff --git a/src/App.vue b/src/App.vue index e3518d12..383b8b62 100644 --- a/src/App.vue +++ b/src/App.vue @@ -1,24 +1,10 @@ - - - diff --git a/src/api/call-blocking.js b/src/api/call-blocking.js index 4071d808..dbabb449 100644 --- a/src/api/call-blocking.js +++ b/src/api/call-blocking.js @@ -1,223 +1,219 @@ -import _ from 'lodash'; -import Vue from 'vue'; +import _ from 'lodash' +import Vue from 'vue' import { - enableBlockIn, - disableBlockIn, - getPreferences, - addToBlockInList, - editBlockInList, - removeFromBlockInList, - enableBlockOut, - disableBlockOut, - addToBlockOutList, - editBlockOutList, - removeFromBlockOutList, - enablePrivacy, - disablePrivacy -} from './subscriber'; - -export function enableIncomingCallBlocking(id) { - return enableBlockIn(id); -} - -export function disableIncomingCallBlocking(id) { - return disableBlockIn(id); -} - -export function getIncomingCallBlocking(id) { - return new Promise((resolve, reject)=>{ - getPreferences(id).then((result)=>{ - resolve({ - enabled: result.block_in_mode, - list: result.block_in_list, - blockAnonymous: result.block_in_clir - }); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function addNumberToIncomingList(id, number) { - return new Promise((resolve, reject)=>{ - if(_.isEmpty(number)) { - reject(new Error('Number may not be empty')); - } - else { - addToBlockInList(id, number).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - } - }); -} - -export function editNumberFromIncomingList(id, index, number) { - return new Promise((resolve, reject)=>{ - editBlockInList(id, index, number).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function removeNumberFromIncomingList(id, index) { - return new Promise((resolve, reject)=>{ - removeFromBlockInList(id, index).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function enableOutgoingCallBlocking(id) { - return enableBlockOut(id); -} - -export function disableOutgoingCallBlocking(id) { - return disableBlockOut(id); -} - -export function getOutgoingCallBlocking(id) { - return new Promise((resolve, reject)=>{ - getPreferences(id).then((result)=>{ - resolve({ - enabled: result.block_out_mode, - list: result.block_out_list - }); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function addNumberToOutgoingList(id, number) { - return new Promise((resolve, reject)=>{ - if(_.isEmpty(number)) { - reject(new Error('Number may not be empty')); - } - else { - addToBlockOutList(id, number).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - } - }); -} - -export function editNumberFromOutgoingList(id, index, number) { - return new Promise((resolve, reject)=>{ - editBlockOutList(id, index, number).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function removeNumberFromOutgoingList(id, index) { - return new Promise((resolve, reject)=>{ - removeFromBlockOutList(id, index).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function enablePrivacyCallBlocking(id) { - return enablePrivacy(id); -} - -export function disablePrivacyCallBlocking(id) { - return disablePrivacy(id); -} - -export function getPrivacyCallBlocking(id) { - return new Promise((resolve, reject)=>{ - getPreferences(id).then((result)=>{ - resolve(result.clir); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function removeNumberFromList(id, field, value) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getPreferences(id); - }).then((result)=>{ - var prefs = _.cloneDeep(result); - delete prefs._links; - prefs[field] = _.get(prefs, field, []).filter((number) => { - return number !== value; - }); - return Vue.http.put('api/subscriberpreferences/' + id, prefs); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function removeFromIncomingListByNumber(id, number) { - return new Promise((resolve, reject) => { - removeNumberFromList(id, 'block_in_list', number).then(() => { - resolve() - }).catch((err) => { - reject(err); - }); - }); -} - -export function removeFromOutgoingListByNumber(id, number) { - return new Promise((resolve, reject) => { - removeNumberFromList(id, 'block_out_list', number).then(() => { - resolve() - }).catch((err) => { - reject(err); - }); - }); -} - -export function toggleNumberInBothLists(options) { - return new Promise((resolve, reject) => { - Promise.resolve().then(() => { - return getPreferences(options.id); - }).then((result) => { - let prefs = _.cloneDeep(result); - delete prefs._links; - prefs['block_in_list'] = _.get(prefs, 'block_in_list', []); - prefs['block_out_list'] = _.get(prefs, 'block_out_list', []); - if (options.block_in_list === 'add') { - prefs['block_in_list'] = [options.number].concat(prefs['block_in_list']); - } - else if (options.block_in_list === 'remove') { - prefs['block_in_list'] = prefs['block_in_list'].filter((number) => { - return number !== options.number; - }); - } - if (options.block_out_list === 'add') { - prefs['block_out_list'] = [options.number].concat(prefs['block_out_list']); - } - else if (options.block_out_list === 'remove') { - prefs['block_out_list'] = prefs['block_out_list'].filter((number) => { - return number !== options.number; - }); - } - return Vue.http.put('api/subscriberpreferences/' + options.id, prefs); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); + enableBlockIn, + disableBlockIn, + getPreferences, + addToBlockInList, + editBlockInList, + removeFromBlockInList, + enableBlockOut, + disableBlockOut, + addToBlockOutList, + editBlockOutList, + removeFromBlockOutList, + enablePrivacy, + disablePrivacy +} from './subscriber' + +export function enableIncomingCallBlocking (id) { + return enableBlockIn(id) +} + +export function disableIncomingCallBlocking (id) { + return disableBlockIn(id) +} + +export function getIncomingCallBlocking (id) { + return new Promise((resolve, reject) => { + getPreferences(id).then((result) => { + resolve({ + enabled: result.block_in_mode, + list: result.block_in_list, + blockAnonymous: result.block_in_clir + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function addNumberToIncomingList (id, number) { + return new Promise((resolve, reject) => { + if (_.isEmpty(number)) { + reject(new Error('Number may not be empty')) + } else { + addToBlockInList(id, number).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + } + }) +} + +export function editNumberFromIncomingList (id, index, number) { + return new Promise((resolve, reject) => { + editBlockInList(id, index, number).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function removeNumberFromIncomingList (id, index) { + return new Promise((resolve, reject) => { + removeFromBlockInList(id, index).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function enableOutgoingCallBlocking (id) { + return enableBlockOut(id) +} + +export function disableOutgoingCallBlocking (id) { + return disableBlockOut(id) +} + +export function getOutgoingCallBlocking (id) { + return new Promise((resolve, reject) => { + getPreferences(id).then((result) => { + resolve({ + enabled: result.block_out_mode, + list: result.block_out_list + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function addNumberToOutgoingList (id, number) { + return new Promise((resolve, reject) => { + if (_.isEmpty(number)) { + reject(new Error('Number may not be empty')) + } else { + addToBlockOutList(id, number).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + } + }) +} + +export function editNumberFromOutgoingList (id, index, number) { + return new Promise((resolve, reject) => { + editBlockOutList(id, index, number).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function removeNumberFromOutgoingList (id, index) { + return new Promise((resolve, reject) => { + removeFromBlockOutList(id, index).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function enablePrivacyCallBlocking (id) { + return enablePrivacy(id) +} + +export function disablePrivacyCallBlocking (id) { + return disablePrivacy(id) +} + +export function getPrivacyCallBlocking (id) { + return new Promise((resolve, reject) => { + getPreferences(id).then((result) => { + resolve(result.clir) + }).catch((err) => { + reject(err) + }) + }) +} + +export function removeNumberFromList (id, field, value) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getPreferences(id) + }).then((result) => { + var prefs = _.cloneDeep(result) + delete prefs._links + prefs[field] = _.get(prefs, field, []).filter((number) => { + return number !== value + }) + return Vue.http.put('api/subscriberpreferences/' + id, prefs) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function removeFromIncomingListByNumber (id, number) { + return new Promise((resolve, reject) => { + removeNumberFromList(id, 'block_in_list', number).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function removeFromOutgoingListByNumber (id, number) { + return new Promise((resolve, reject) => { + removeNumberFromList(id, 'block_out_list', number).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function toggleNumberInBothLists (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getPreferences(options.id) + }).then((result) => { + const prefs = _.cloneDeep(result) + delete prefs._links + prefs.block_in_list = _.get(prefs, 'block_in_list', []) + prefs.block_out_list = _.get(prefs, 'block_out_list', []) + if (options.block_in_list === 'add') { + prefs.block_in_list = [options.number].concat(prefs.block_in_list) + } else if (options.block_in_list === 'remove') { + prefs.block_in_list = prefs.block_in_list.filter((number) => { + return number !== options.number + }) + } + if (options.block_out_list === 'add') { + prefs.block_out_list = [options.number].concat(prefs.block_out_list) + } else if (options.block_out_list === 'remove') { + prefs.block_out_list = prefs.block_out_list.filter((number) => { + return number !== options.number + }) + } + return Vue.http.put('api/subscriberpreferences/' + options.id, prefs) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/call-forward.js b/src/api/call-forward.js index 44f04e73..2d98b479 100644 --- a/src/api/call-forward.js +++ b/src/api/call-forward.js @@ -1,967 +1,986 @@ -import _ from 'lodash'; -import Vue from 'vue'; -import { i18n } from '../i18n'; -import { getJsonBody } from './utils'; -import { normalizeDestination } from '../filters/number-format'; -import { LIST_ALL_ROWS, patchReplaceFull } from './common'; - -export function getMappings(id) { - return new Promise((resolve, reject) => { - Vue.http.get('api/cfmappings/' + id).then((result) => { - let jsonBody = getJsonBody(result.body); - delete jsonBody._links; - delete jsonBody.cfs; - delete jsonBody.cfr; - resolve(getJsonBody(result.body)); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getSourcesets(id) { - return new Promise((resolve, reject) => { - Promise.resolve().then(() => { - return Vue.http.get('api/cfsourcesets/', - { params: { subscriber_id: id, page: 1, rows: LIST_ALL_ROWS } }) - }).then((result) => { - let totalCount = getJsonBody(result.body).total_count; - if (totalCount > LIST_ALL_ROWS) { - return Vue.http.get('api/cfsourcesets/', - { params: { subscriber_id: id, page: 1, - rows: totalCount } }) - } - else { - return Promise.resolve(result); - } - }).then((result) => { - let sourcesets = []; - if (getJsonBody(result.body)._embedded) { - sourcesets = getJsonBody(result.body)._embedded['ngcp:cfsourcesets']; - } - resolve(sourcesets); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getTimesets(id) { - return new Promise((resolve, reject) => { - Promise.resolve().then(() => { - return Vue.http.get('api/cftimesets/', - { params: { subscriber_id: id, page: 1, rows: LIST_ALL_ROWS } }) - }).then((result) => { - let totalCount = getJsonBody(result.body).total_count; - if (totalCount > LIST_ALL_ROWS) { - return Vue.http.get('api/cftimesets/', - { params: { subscriber_id: id, page: 1, - rows: totalCount } }) - } - else { - return Promise.resolve(result); - } - }).then((result) => { - let response = getJsonBody(result.body)._embedded || []; - let timesets = response['ngcp:cftimesets'] || []; - resolve(timesets); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getDestinationsets(id) { - return new Promise((resolve, reject) => { - Promise.resolve().then(() => { - return Vue.http.get('api/cfdestinationsets/', - { params: { subscriber_id: id, page: 1, rows: LIST_ALL_ROWS } }) - }).then((result) => { - let totalCount = getJsonBody(result.body).total_count; - if (totalCount > LIST_ALL_ROWS) { - return Vue.http.get('api/cfdestinationsets/', - { params: { subscriber_id: id, page: 1, - rows: totalCount } }) - } - else { - return Promise.resolve(result); - } - }).then((result) => { - if(getJsonBody(result.body)._embedded){ - resolve(getJsonBody(result.body)._embedded['ngcp:cfdestinationsets']); - } - else{ - resolve([]); - } - - }).catch((err) => { - reject(err); - }); - }); -} - -export function loadDestinations(options) { - return new Promise((resolve, reject) => { - Promise.resolve().then(() => { - return getSourcesets(options.subscriberId); - }).then((sourcesets) => { - let sourcesetsCollection = [{ - id: null, - name: null - }]; - let destinationPromises = []; - sourcesets.map((sourceset) => { - sourcesetsCollection.push({ - id: sourceset.id, - name: sourceset.name, - mode: sourceset.mode - }) - }); - sourcesetsCollection.forEach((sourceset) => { - destinationPromises.push( - getDestinationsBySourcesetId({ - timeset: options.timeset, - sourceset_id: sourceset.id, - sourceset_name: sourceset.name, - subscriberId: options.subscriberId, - sourceset_mode: sourceset.mode - }) - ) - }); - resolve(Promise.all(destinationPromises)); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getDestinationsBySourcesetId(options) { - return new Promise((resolve, reject) => { - let cftTimeset = null; - let cfuTimeset = null; - let cfnaTimeset = null; - let cfbTimeset = null; - Promise.resolve().then(() => { - return getMappings(options.subscriberId); - }).then((mappings) => { - let cftPromises = []; - let cfuPromises = []; - let cfnaPromises = []; - let cfbPromises = []; - if(_.has(mappings, 'cft') && _.isArray(mappings.cft) && mappings.cft.length > 0) { - mappings.cft.forEach((cftMapping) => { - if (cftMapping.timeset === options.timeset && cftMapping.sourceset_id === options.sourceset_id) { - cftTimeset = cftMapping.timeset_id; - cftPromises.push(getDestinationsetById(cftMapping.destinationset_id)); - } - }); - } - if(_.has(mappings, 'cfu') && _.isArray(mappings.cfu) && mappings.cfu.length > 0) { - mappings.cfu.forEach((cfuMapping) => { - if (cfuMapping.timeset === options.timeset && cfuMapping.sourceset_id === options.sourceset_id) { - cfuTimeset = cfuMapping.timeset_id; - cfuPromises.push(getDestinationsetById(cfuMapping.destinationset_id)); - } - }); - } - if(_.has(mappings, 'cfna') && _.isArray(mappings.cfna) && mappings.cfna.length > 0) { - mappings.cfna.forEach((cfnaMapping) => { - if (cfnaMapping.timeset === options.timeset && cfnaMapping.sourceset_id === options.sourceset_id) { - cfnaTimeset = cfnaMapping.timeset_id; - cfnaPromises.push(getDestinationsetById(cfnaMapping.destinationset_id)); - } - }); - } - if(_.has(mappings, 'cfb') && _.isArray(mappings.cfb) && mappings.cfb.length > 0) { - mappings.cfb.forEach((cfbMapping) => { - if (cfbMapping.timeset === options.timeset && cfbMapping.sourceset_id === options.sourceset_id) { - cfbTimeset = cfbMapping.timeset_id; - cfbPromises.push(getDestinationsetById(cfbMapping.destinationset_id)); - } - }); - } - return Promise.all([ - Promise.all(cftPromises), - Promise.all(cfuPromises), - Promise.all(cfnaPromises), - Promise.all(cfbPromises) - ]); - }).then((result) => { - let ownPhone = result[0].length > 0 && result[1].length === 0; - let cftDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[0]), groupName: 'cft', timesetId: cftTimeset, ownPhone: ownPhone }); - let cfuDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[1]), groupName: 'cfu', timesetId: cfuTimeset, ownPhone: ownPhone }); - let offlineDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[2]), groupName: 'cfna', timesetId: cfnaTimeset, ownPhone: ownPhone }); - let busyDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[3]), groupName: 'cfb', timesetId: cfbTimeset, ownPhone: ownPhone }); - let onlineDestinations = getOnlineDestinations({ cftDestinations: cftDestinations, cfuDestinations: cfuDestinations }); - resolve({ - sourcesetId: options.sourceset_id, - sourcesetName: options.sourceset_name, - sourcesetMode: options.sourceset_mode, - ownPhone: ownPhone, - destinationGroups: { - online: onlineDestinations, - offline: offlineDestinations, - busy: busyDestinations - } - }) - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getOnlineDestinations(options) { - if (options.cftDestinations.length > 0 && options.cfuDestinations.length === 0) { - return options.cftDestinations; - } - else { - return options.cfuDestinations; - } -} - -export function addNameIdOwnPhoneAndTerminating(options) { - let terminatingFlag = false; - options.group.forEach(destinationset => { - destinationset.groupName = options.groupName; - destinationset.timesetId = options.timesetId; - destinationset.ownPhone = options.ownPhone; - destinationset.destinations.forEach(destination => { - let normalized = normalizeDestination(destination.destination); - - if (!terminatingFlag && _.includes(['Voicebox', 'Fax2Mail', 'Manager Secretary', - 'Custom Announcement', 'Conference'], normalized)) { - terminatingFlag = true; - destination.terminated = false; - } - else if (terminatingFlag) { - destination.terminated = true; - } - else { - destination.terminated = false; - } - }); - }); - return options.group; -} - -export function getDestinationsetById(id) { - return new Promise((resolve, reject)=>{ - Vue.http.get('api/cfdestinationsets/' + id).then((res)=>{ - let destinationset = getJsonBody(res.body); - delete destinationset['_links']; - destinationset.destinations.sort((a, b) => { - return parseFloat(a.priority) - parseFloat(b.priority); - }); - resolve(destinationset); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function deleteDestinationFromDestinationset(options) { - let headers = { - 'Content-Type': 'application/json-patch+json' - }; - return new Promise((resolve, reject) => { - Vue.http.patch('api/cfdestinationsets/' + options.id, [{ - op: 'replace', - path: '/destinations', - value: options.data - }], { headers: headers }).then((result) => { - if (options.deleteDestinationset) { - deleteDestinationsetById(options.id).then((res) => { - resolve(res); - }).catch((err) => { - reject(err); - }); - } - else { - resolve(result); - } - }).catch((err) => { - reject(err); - }); - }); -} - -export function deleteDestinationsetById(id) { - return new Promise((resolve, reject) => { - Vue.http.delete('api/cfdestinationsets/' + id).then((result) => { - resolve(result); - }).catch((err) => { - reject(err); - }); - }); -} - -export function updateDestinationsetName(options) { - return patchReplaceFull({ - path: 'api/cfdestinationsets/' + options.id, - fieldPath: 'name', - value: options.name - }); -} - -export function addDestinationToDestinationset(options) { - return patchReplaceFull({ - path: 'api/cfdestinationsets/' + options.id, - fieldPath: 'destinations', - value: options.data - }); -} - -export function addNewDestinationset() { - let destinationsetName = `csc-${Date.now()}`; - return new Promise((resolve, reject) => { - Vue.http.post('api/cfdestinationsets/', { name: destinationsetName }) - .then((response) => { - resolve(_.last(_.split(response.headers.get('Location'), '/'))); - }).catch((err) => { - reject(err); - }); - }); -} - -export function addNewDestinationsetWithName(destinationsetName) { - return new Promise((resolve, reject) => { - Vue.http.post('api/cfdestinationsets/', { name: destinationsetName }) - .then((response) => { - resolve(_.last(_.split(response.headers.get('Location'), '/'))); - }).catch((err) => { - reject(err); - }); - }); -} - -export function addDestinationToExistingGroup(options) { - return new Promise((resolve, reject)=> { - Promise.resolve().then(() => { - return getDestinationsetById(options.id); - }).then((destinationset) => { - let data = destinationset.destinations; - data.push(options.data); - return addDestinationToDestinationset({ - id: options.id, data: data - }); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function addDestinationToEmptyGroup(options) { - return new Promise((resolve, reject)=> { - let destinationsetId; - Promise.resolve().then(() => { - return addNewDestinationset(); - }).then((id) => { - destinationsetId = id; - return addDestinationToDestinationset({ - id: id, data: [options.data] - }); - }).then(() => { - return getMappings(options.subscriberId); - }).then((mappings) => { - let updatedMappings = mappings[options.groupName]; - updatedMappings.push({ - destinationset_id: destinationsetId, - sourceset_id: options.sourcesetId, - timeset_id: options.timesetId - }); - return addNewMapping({ - mappings: updatedMappings, - group: options.groupName, - subscriberId: options.subscriberId - }); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function addNewMapping(options) { - return patchReplaceFull({ - path: 'api/cfmappings/' + options.subscriberId, - fieldPath: options.group, - value: options.mappings - }); -} - -export function addMultipleNewMappings(options) { - return new Promise((resolve, reject) => { - let headers = { - 'Content-Type': 'application/json-patch+json', - 'Prefer': 'return=representation' - }; - Vue.http.patch('api/cfmappings/' + options.subscriberId, options.mappings - , { headers: headers }).then((result) => { - resolve(getJsonBody(result.body)); - }).catch((err) => { - reject(err); - }); - }); -} - -export function changePositionOfDestination(options) { - return new Promise((resolve, reject) => { - let headers = { 'Content-Type': 'application/json-patch+json' }; - Vue.http.patch('api/cfdestinationsets/' + options.id, [{ - op: 'replace', - path: '/destinations', - value: options.destinations - }], { headers: headers }).then((result) => { - resolve(result); - }).catch((err) => { - reject(err); - }); - }); -} - -export function moveDestinationUp(options) { - return new Promise((resolve, reject)=> { - Promise.resolve().then(() => { - let getPromises = []; - getPromises.push(getDestinationsetById(options.prevId)); - getPromises.push(getDestinationsetById(options.id)); - return Promise.all(getPromises); - }).then((destinationsets) => { - let updatePromises = []; - let lastDestinationPrevId = _.findLast(destinationsets[0].destinations) || {}; - let lowestPriorityPrevId = lastDestinationPrevId.priority || 1; - let prevDestinations = destinationsets[0].destinations; - let currentDestinations = destinationsets[1].destinations; - let prevDestinationsMoveToIndex = prevDestinations.length < 2 ? - 1 : prevDestinations.length-2; - options.destination.priority = lowestPriorityPrevId; - prevDestinations.splice(prevDestinationsMoveToIndex, 0, options.destination); - currentDestinations.shift(); - updatePromises.push(addDestinationToDestinationset({ - id: options.prevId, - data: prevDestinations - })); - updatePromises.push(deleteDestinationFromDestinationset({ - id: options.id, - data: currentDestinations - })); - return Promise.all(updatePromises); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function moveDestinationDown(options) { - return new Promise((resolve, reject)=> { - Promise.resolve().then(() => { - let getPromises = []; - getPromises.push(getDestinationsetById(options.nextId)); - getPromises.push(getDestinationsetById(options.id)); - return Promise.all(getPromises); - }).then((destinationsets) => { - let updatePromises = []; - let firstDestinationNextId = _.head(destinationsets[0].destinations) || {}; - let highestPriorityNextId = firstDestinationNextId.priority || 1; - let nextDestinations = destinationsets[0].destinations; - let currentDestinations = destinationsets[1].destinations; - options.destination.priority = highestPriorityNextId; - nextDestinations.splice(1, 0, options.destination); - currentDestinations.pop(); - updatePromises.push(addDestinationToDestinationset({ - id: options.nextId, - data: nextDestinations - })); - updatePromises.push(deleteDestinationFromDestinationset({ - id: options.id, - data: currentDestinations - })); - return Promise.all(updatePromises); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getDaysFromRange(options) { - let fromDay = options.fromDay; - let toDay = options.toDay + 1; - let wdayMap = { - 1: i18n.t('pages.callForward.times.sunday'), - 2: i18n.t('pages.callForward.times.monday'), - 3: i18n.t('pages.callForward.times.tuesday'), - 4: i18n.t('pages.callForward.times.wednesday'), - 5: i18n.t('pages.callForward.times.thursday'), - 6: i18n.t('pages.callForward.times.friday'), - 7: i18n.t('pages.callForward.times.saturday') - }; - let days = []; - while (fromDay < toDay) { - days.push({ name: wdayMap[fromDay], number: fromDay.toString() }); - fromDay++; - } - return days; -} - -export function getHoursFromRange(options) { - let toHour = options.toHour + 1; - let fromMinute = options.hasMinute ? options.fromMinute : '00'; - let toMinute = options.hasMinute ? options.toMinute + 1 : '00'; - toMinute = !toMinute ? fromMinute + 1 : toMinute; - let hours = []; - if (options.hasMinute) { - while (options.fromHour < toHour) { - hours.push({ - from: `${options.fromHour}:${fromMinute}`, - to: `${options.fromHour}:${toMinute}`, - hour: options.fromHour.toString() - }); - options.fromHour++; - } - } - else { - hours.push({ - from: `${options.fromHour}:${fromMinute}`, - to: `${toHour}:${toMinute}` - }); - } - return hours; -} - -export function convertTimesetToWeekdays(options) { - let times = []; - let counter = 0; - let timesetIsCompatible = true; - let timesetHasDuplicate = false; - let timesetExists = false; - let timesetHasReverse = false; - let timesetId = null; - options.timesets.forEach((timeset) => { - let timesetNameMatches = timeset.name === options.timesetName; - if (counter === 0 && timesetNameMatches) { - timeset.times.forEach((time) => { - let isIncompatible = time.mday || time.month || time.year || !time.wday || !time.hour; - if (isIncompatible) { - timesetIsCompatible = false; - return; - } - else { - let days = []; - let hours = []; - let fromDay = parseInt(time.wday.split('-')[0]); - let toDay = time.wday.split('-')[1] ? parseInt(time.wday.split('-')[1]) : fromDay; - let fromHour = parseInt(time.hour.split('-')[0]); - let toHour = time.hour.split('-')[1] ? parseInt(time.hour.split('-')[1]) : fromHour; - let fromMinute = time.minute ? parseInt(time.minute.split('-')[0]) : undefined; - let toMinute = (time.minute && time.minute.split('-')[1]) ? parseInt(time.minute.split('-')[1]) : undefined; - let isReverse = fromDay > toDay || fromHour > toHour || fromMinute > toMinute; - let timesHour; - if (isReverse) { - timesetHasReverse = true; - return; - } - else { - hours = getHoursFromRange({ hasMinute: !!time.minute, - fromHour: fromHour, toHour: toHour, - fromMinute: fromMinute, toMinute: toMinute }); - days = getDaysFromRange({ fromDay: fromDay, toDay: toDay }); - days.forEach(day => { - hours.forEach(hour => { - timesHour = time.minute ? hour.hour : time.hour; - times.push({ - weekday: day.name, - from: hour.from, - to: hour.to, - wday: day.number, - hour: timesHour, - minute: time.minute - }); - }); - }); - timesetId = timeset.id; - timesetIsCompatible = true; - } - } - }); - timesetExists = true; - counter++; - } - else if (timesetNameMatches) { - timesetHasDuplicate = true; - return; - } - }); - return { - times: times, - timesetIsCompatible: timesetIsCompatible, - timesetExists: timesetExists, - timesetHasReverse: timesetHasReverse, - timesetHasDuplicate: timesetHasDuplicate, - timesetId: timesetId - }; -} - -export function loadTimesetTimes(options) { - return new Promise((resolve, reject)=> { - Promise.resolve().then(() => { - return getTimesets(options.subscriberId); - }).then((timesets) => { - let times = convertTimesetToWeekdays({ timesets: timesets, timesetName: options.timeset}); - return times; - }).then((times) => { - resolve(times); - }).catch((err) => { - reject(err); - }); - }); -} - -export function deleteTimeFromTimeset(options) { - let headers = { - 'Content-Type': 'application/json-patch+json' - }; - return new Promise((resolve, reject) => { - Vue.http.patch('api/cftimesets/' + options.timesetId, [{ - op: 'replace', - path: '/times', - value: options.times - }], { headers: headers }).then((result) => { - resolve(result); - }).catch((err) => { - reject(err); - }); - }); -} - -export function deleteTimesetById(id) { - return new Promise((resolve, reject) => { - Vue.http.delete('api/cftimesets/' + id).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function resetTimesetByName(options) { - return new Promise((resolve, reject)=> { - Promise.resolve().then(() => { - return getTimesets(options.id); - }).then((timesets) => { - let deleteTimesetPromises = []; - _.filter(timesets, { 'name': options.name }).forEach((timeset) => { - deleteTimesetPromises.push(deleteTimesetById(timeset.id)); - }); - return Promise.all(deleteTimesetPromises); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function addTimeToTimeset(options) { - return patchReplaceFull({ - path: 'api/cftimesets/' + options.id, - fieldPath: 'times', - value: options.times - }); -} - -export function addNewTimeset(timesetName) { - return new Promise((resolve, reject) => { - Vue.http.post('api/cftimesets/', { name: timesetName }) - .then((response) => { - resolve(_.last(_.split(response.headers.get('Location'), '/'))); - }).catch((err) => { - reject(err); - }); - }); -} - -export function convertAddTime(options) { - let time = options.time; - let weekday = options.weekday; - let convertedTime = []; - let fromHour = time.from.split(':')[0]; - let toHour = time.to.split(':')[0]; - let fromMinute = time.from.split(':')[1]; - let toMinute = time.to.split(':')[1]; - let bothHasFullHour = fromMinute === '00' && toMinute === '00'; - let bothHasSameHour = fromHour === toHour; - let fromMinuteNotZero = time.from.split(':')[1] !== '00'; - let toMinuteNotZero = time.to.split(':')[1] !== '00'; - let bothMinutesNotZeroAndNextHourPlusOne = fromMinuteNotZero && toMinuteNotZero && parseInt(toHour) === parseInt(fromHour) + 1; - let bothMinutesNotZero = time.from.split(':')[1] !== '00' && - time.to.split(':')[1] !== '00'; - let startNotZeroAndEndNextFullHour = - (parseInt(fromHour) === (parseInt(toHour) - 1) && toMinute === '00'); - if (bothHasFullHour) { - convertedTime.push({ wday: weekday, hour: `${parseInt(fromHour)}-${parseInt(toHour)-1}` }); - } - else if (bothHasSameHour) { - convertedTime.push({ wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-${parseInt(toMinute)-1}`}); - } - else if (startNotZeroAndEndNextFullHour) { - convertedTime.push({ wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }); - } - else if (bothMinutesNotZeroAndNextHourPlusOne) { - convertedTime.push( - { wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }, - { wday: weekday, hour: `${parseInt(toHour)}`, minute: `0-${parseInt(toMinute)-1}` } - ); - } - else if (bothMinutesNotZero) { - convertedTime.push( - { wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }, - { wday: weekday, hour: `${parseInt(fromHour)+1}-${parseInt(toHour)-1}` }, - { wday: weekday, hour: `${parseInt(toHour)}`, minute: `0-${parseInt(toMinute)-1}` } - ); - } - // From minute not zero and to minute zero - else if (fromMinuteNotZero) { - convertedTime.push( - { wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }, - { wday: weekday, hour: `${parseInt(fromHour)+1}-${parseInt(toHour)-1}` } - ); - } - // From minute zero and to minute not zero - else if (toMinuteNotZero) { - convertedTime.push( - { wday: weekday, hour: `${parseInt(fromHour)+1}-${parseInt(toHour)-1}` }, - { wday: weekday, hour: `${parseInt(toHour)}`, minute: `0-${parseInt(toMinute)-1}` } - ); - } - return convertedTime; -} - -export function createTimesetWithTime(options) { - return new Promise((resolve, reject)=> { - let convertedTime = convertAddTime({ time: options.time[0], weekday: options.weekday }); - Promise.resolve().then(() => { - return addNewTimeset(options.name); - }).then((timesetId) => { - return addTimeToTimeset({ id: timesetId, times: convertedTime }); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getTimesByTimesetId(id) { - return new Promise((resolve, reject)=>{ - Vue.http.get('api/cftimesets/' + id).then((res)=>{ - let timeset = getJsonBody(res.body); - delete timeset['_links']; - resolve(timeset.times); - }).catch((err) => { - reject(err); - }); - }); -} - -export function appendTimeToTimeset(options) { - return new Promise((resolve, reject)=> { - let convertedTime = convertAddTime({ time: options.time[0], weekday: options.weekday }); - Promise.resolve().then(() => { - return getTimesByTimesetId(options.id); - }).then((times) => { - let concatTimes = times.concat(convertedTime); - return addTimeToTimeset({ id: options.id, times: concatTimes }); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - - -export function getSourcesetById(id) { - return new Promise((resolve, reject)=>{ - Vue.http.get('api/cfsourcesets/' + id).then((res)=>{ - let sourceset = getJsonBody(res.body); - resolve(sourceset); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getSourcesBySourcesetId(id) { - return new Promise((resolve, reject)=>{ - Vue.http.get('api/cfsourcesets/' + id).then((res)=>{ - let sourceset = getJsonBody(res.body); - resolve(sourceset.sources); - }).catch((err) => { - reject(err); - }); - }); -} - -export function addSourceToSourceset(options) { - return new Promise((resolve, reject) => { - let headers = { - 'Content-Type': 'application/json-patch+json' - }; - Vue.http.patch('api/cfsourcesets/' + options.id, [{ - op: 'replace', - path: '/sources', - value: options.sources - }], { headers: headers }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function appendSourceToSourceset(options) { - return new Promise((resolve, reject)=> { - Promise.resolve().then(() => { - return getSourcesBySourcesetId(options.id); - }).then((sources) => { - let concatSources = sources.concat(options.source); - return addSourceToSourceset({ id: options.id, sources: concatSources }); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function createSourcesetWithSource(options) { - return new Promise((resolve, reject) => { - Vue.http.post('api/cfsourcesets/', { - name: options.sourcesetName, - subscriber_id: options.subscriberId, - mode: options.mode, - sources: [{ - source: options.source - }] - }).then((data) => { - let id = data.headers.map.location[0].split('cfsourcesets/')[1]; - resolve(id); - }).catch((err) => { - reject(err); - }); - }); -} - -export function deleteSourcesetById(id) { - return new Promise((resolve, reject) => { - Vue.http.delete('api/cfsourcesets/' + id).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function deleteItemFromArrayByIndex(options) { - return options.array.filter((item, index) => { - return options.index !== index; - }) -} - -export function deleteSourceFromSourcesetByIndex(options) { - return new Promise((resolve, reject) => { - let sources = deleteItemFromArrayByIndex({ - array: options.sources, - index: options.sourceIndex - }); - let headers = { - 'Content-Type': 'application/json-patch+json' - }; - Vue.http.patch('api/cfsourcesets/' + options.sourceset.sourcesetId, [{ - op: 'replace', - path: '/sources', - value: sources - }], { headers: headers }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function flipCfuAndCft(options) { - return new Promise((resolve, reject) => { - Promise.resolve().then(() => { - return getMappings(options.subscriberId); - }).then((mappings) => { - let flipValues = mappings[options.fromType].filter((destinationset) => { - return destinationset.sourceset_id === options.sourcesetId && destinationset.timeset_id === options.timesetId; - }); - let fromValues = mappings[options.fromType].filter((destinationset) => { - return !(destinationset.sourceset_id === options.sourcesetId && destinationset.timeset_id === options.timesetId); - }) - let toValues = mappings[options.toType].concat(flipValues); - let patchOptions = [ - { - op: 'replace', - path: '/' + options.fromType, - value: fromValues - }, { - op: 'replace', - path: '/' + options.toType, - value: toValues - } - ]; - let timeoutOption = { - op: 'replace', - path: '/cft_ringtimeout', - value: 15 - }; - if (!mappings.cft_ringtimeout) { - patchOptions.push(timeoutOption); - } - return new Promise((resolve, reject) => { - let headers = { - 'Content-Type': 'application/json-patch+json' - }; - Vue.http.patch('api/cfmappings/' + options.subscriberId, - patchOptions, { headers: headers }).then((result) => { - resolve(result); - }).catch((err) => { - reject(err); - }); - }); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); -} - -export function getOwnPhoneTimeout(id) { - return new Promise((resolve, reject)=>{ - Vue.http.get('api/cfmappings/' + id).then((res) => { - let timeout = getJsonBody(res.body).cft_ringtimeout; - resolve(timeout); - }).catch((err) => { - reject(err); - }); - }); -} - -export function updateOwnPhoneTimeout(options) { - return patchReplaceFull({ - path: 'api/cfmappings/' + options.subscriberId, - fieldPath: 'cft_ringtimeout', - value: options.timeout - }); +import _ from 'lodash' +import Vue from 'vue' +import { i18n } from 'src/boot/i18n' +import { getJsonBody } from './utils' +import { normalizeDestination } from '../filters/number-format' +import { LIST_ALL_ROWS, patchReplaceFull, get, getList } from './common' + +export function getMappings (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/cfmappings/' + id).then((result) => { + const jsonBody = getJsonBody(result.body) + delete jsonBody._links + delete jsonBody.cfs + delete jsonBody.cfr + resolve(getJsonBody(result.body)) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSourcesets (id) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return Vue.http.get('api/cfsourcesets/', + { params: { subscriber_id: id, page: 1, rows: LIST_ALL_ROWS } }) + }).then((result) => { + const totalCount = getJsonBody(result.body).total_count + if (totalCount > LIST_ALL_ROWS) { + return Vue.http.get('api/cfsourcesets/', + { + params: { + subscriber_id: id, + page: 1, + rows: totalCount + } + }) + } else { + return Promise.resolve(result) + } + }).then((result) => { + let sourcesets = [] + if (getJsonBody(result.body)._embedded) { + sourcesets = getJsonBody(result.body)._embedded['ngcp:cfsourcesets'] + } + resolve(sourcesets) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getTimesets (id) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return Vue.http.get('api/cftimesets/', + { params: { subscriber_id: id, page: 1, rows: LIST_ALL_ROWS } }) + }).then((result) => { + const totalCount = getJsonBody(result.body).total_count + if (totalCount > LIST_ALL_ROWS) { + return Vue.http.get('api/cftimesets/', + { + params: { + subscriber_id: id, + page: 1, + rows: totalCount + } + }) + } else { + return Promise.resolve(result) + } + }).then((result) => { + const response = getJsonBody(result.body)._embedded || [] + const timesets = response['ngcp:cftimesets'] || [] + resolve(timesets) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getDestinationsets (id) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return Vue.http.get('api/cfdestinationsets/', + { params: { subscriber_id: id, page: 1, rows: LIST_ALL_ROWS } }) + }).then((result) => { + const totalCount = getJsonBody(result.body).total_count + if (totalCount > LIST_ALL_ROWS) { + return Vue.http.get('api/cfdestinationsets/', + { + params: { + subscriber_id: id, + page: 1, + rows: totalCount + } + }) + } else { + return Promise.resolve(result) + } + }).then((result) => { + if (getJsonBody(result.body)._embedded) { + resolve(getJsonBody(result.body)._embedded['ngcp:cfdestinationsets']) + } else { + resolve([]) + } + }).catch((err) => { + reject(err) + }) + }) +} + +export function loadDestinations (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getSourcesets(options.subscriberId) + }).then((sourcesets) => { + const sourcesetsCollection = [{ + id: null, + name: null + }] + const destinationPromises = [] + sourcesets.map((sourceset) => { + sourcesetsCollection.push({ + id: sourceset.id, + name: sourceset.name, + mode: sourceset.mode + }) + }) + sourcesetsCollection.forEach((sourceset) => { + destinationPromises.push( + getDestinationsBySourcesetId({ + timeset: options.timeset, + sourceset_id: sourceset.id, + sourceset_name: sourceset.name, + subscriberId: options.subscriberId, + sourceset_mode: sourceset.mode + }) + ) + }) + resolve(Promise.all(destinationPromises)) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getDestinationsBySourcesetId (options) { + return new Promise((resolve, reject) => { + let cftTimeset = null + let cfuTimeset = null + let cfnaTimeset = null + let cfbTimeset = null + Promise.resolve().then(() => { + return getMappings(options.subscriberId) + }).then((mappings) => { + const cftPromises = [] + const cfuPromises = [] + const cfnaPromises = [] + const cfbPromises = [] + if (_.has(mappings, 'cft') && _.isArray(mappings.cft) && mappings.cft.length > 0) { + mappings.cft.forEach((cftMapping) => { + if (cftMapping.timeset === options.timeset && cftMapping.sourceset_id === options.sourceset_id) { + cftTimeset = cftMapping.timeset_id + cftPromises.push(getDestinationsetById(cftMapping.destinationset_id)) + } + }) + } + if (_.has(mappings, 'cfu') && _.isArray(mappings.cfu) && mappings.cfu.length > 0) { + mappings.cfu.forEach((cfuMapping) => { + if (cfuMapping.timeset === options.timeset && cfuMapping.sourceset_id === options.sourceset_id) { + cfuTimeset = cfuMapping.timeset_id + cfuPromises.push(getDestinationsetById(cfuMapping.destinationset_id)) + } + }) + } + if (_.has(mappings, 'cfna') && _.isArray(mappings.cfna) && mappings.cfna.length > 0) { + mappings.cfna.forEach((cfnaMapping) => { + if (cfnaMapping.timeset === options.timeset && cfnaMapping.sourceset_id === options.sourceset_id) { + cfnaTimeset = cfnaMapping.timeset_id + cfnaPromises.push(getDestinationsetById(cfnaMapping.destinationset_id)) + } + }) + } + if (_.has(mappings, 'cfb') && _.isArray(mappings.cfb) && mappings.cfb.length > 0) { + mappings.cfb.forEach((cfbMapping) => { + if (cfbMapping.timeset === options.timeset && cfbMapping.sourceset_id === options.sourceset_id) { + cfbTimeset = cfbMapping.timeset_id + cfbPromises.push(getDestinationsetById(cfbMapping.destinationset_id)) + } + }) + } + return Promise.all([ + Promise.all(cftPromises), + Promise.all(cfuPromises), + Promise.all(cfnaPromises), + Promise.all(cfbPromises) + ]) + }).then((result) => { + const ownPhone = result[0].length > 0 && result[1].length === 0 + const cftDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[0]), groupName: 'cft', timesetId: cftTimeset, ownPhone: ownPhone }) + const cfuDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[1]), groupName: 'cfu', timesetId: cfuTimeset, ownPhone: ownPhone }) + const offlineDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[2]), groupName: 'cfna', timesetId: cfnaTimeset, ownPhone: ownPhone }) + const busyDestinations = addNameIdOwnPhoneAndTerminating({ group: _.cloneDeep(result[3]), groupName: 'cfb', timesetId: cfbTimeset, ownPhone: ownPhone }) + const onlineDestinations = getOnlineDestinations({ cftDestinations: cftDestinations, cfuDestinations: cfuDestinations }) + resolve({ + sourcesetId: options.sourceset_id, + sourcesetName: options.sourceset_name, + sourcesetMode: options.sourceset_mode, + ownPhone: ownPhone, + destinationGroups: { + online: onlineDestinations, + offline: offlineDestinations, + busy: busyDestinations + } + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getOnlineDestinations (options) { + if (options.cftDestinations.length > 0 && options.cfuDestinations.length === 0) { + return options.cftDestinations + } else { + return options.cfuDestinations + } +} + +export function addNameIdOwnPhoneAndTerminating (options) { + let terminatingFlag = false + options.group.forEach(destinationset => { + destinationset.groupName = options.groupName + destinationset.timesetId = options.timesetId + destinationset.ownPhone = options.ownPhone + destinationset.destinations.forEach(destination => { + const normalized = normalizeDestination(destination.destination) + + if (!terminatingFlag && _.includes(['Voicebox', 'Fax2Mail', 'Manager Secretary', + 'Custom Announcement', 'Conference'], normalized)) { + terminatingFlag = true + destination.terminated = false + } else if (terminatingFlag) { + destination.terminated = true + } else { + destination.terminated = false + } + }) + }) + return options.group +} + +export function getDestinationsetById (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/cfdestinationsets/' + id).then((res) => { + const destinationset = getJsonBody(res.body) + delete destinationset._links + destinationset.destinations.sort((a, b) => { + return parseFloat(a.priority) - parseFloat(b.priority) + }) + resolve(destinationset) + }).catch((err) => { + reject(err) + }) + }) +} + +export function deleteDestinationFromDestinationset (options) { + const headers = { + 'Content-Type': 'application/json-patch+json' + } + return new Promise((resolve, reject) => { + Vue.http.patch('api/cfdestinationsets/' + options.id, [{ + op: 'replace', + path: '/destinations', + value: options.data + }], { headers: headers }).then((result) => { + if (options.deleteDestinationset) { + deleteDestinationsetById(options.id).then((res) => { + resolve(res) + }).catch((err) => { + reject(err) + }) + } else { + resolve(result) + } + }).catch((err) => { + reject(err) + }) + }) +} + +export function deleteDestinationsetById (id) { + return new Promise((resolve, reject) => { + Vue.http.delete('api/cfdestinationsets/' + id).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) +} + +export function updateDestinationsetName (options) { + return patchReplaceFull({ + path: 'api/cfdestinationsets/' + options.id, + fieldPath: 'name', + value: options.name + }) +} + +export function addDestinationToDestinationset (options) { + return patchReplaceFull({ + path: 'api/cfdestinationsets/' + options.id, + fieldPath: 'destinations', + value: options.data + }) +} + +export function addNewDestinationset () { + const destinationsetName = `csc-${Date.now()}` + return new Promise((resolve, reject) => { + Vue.http.post('api/cfdestinationsets/', { name: destinationsetName }) + .then((response) => { + resolve(_.last(_.split(response.headers.get('Location'), '/'))) + }).catch((err) => { + reject(err) + }) + }) +} + +export function addNewDestinationsetWithName (destinationsetName) { + return new Promise((resolve, reject) => { + Vue.http.post('api/cfdestinationsets/', { name: destinationsetName }) + .then((response) => { + resolve(_.last(_.split(response.headers.get('Location'), '/'))) + }).catch((err) => { + reject(err) + }) + }) +} + +export function addDestinationToExistingGroup (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getDestinationsetById(options.id) + }).then((destinationset) => { + const data = destinationset.destinations + data.push(options.data) + return addDestinationToDestinationset({ + id: options.id, data: data + }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function addDestinationToEmptyGroup (options) { + return new Promise((resolve, reject) => { + let destinationsetId + Promise.resolve().then(() => { + return addNewDestinationset() + }).then((id) => { + destinationsetId = id + return addDestinationToDestinationset({ + id: id, data: [options.data] + }) + }).then(() => { + return getMappings(options.subscriberId) + }).then((mappings) => { + const updatedMappings = mappings[options.groupName] + updatedMappings.push({ + destinationset_id: destinationsetId, + sourceset_id: options.sourcesetId, + timeset_id: options.timesetId + }) + return addNewMapping({ + mappings: updatedMappings, + group: options.groupName, + subscriberId: options.subscriberId + }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function addNewMapping (options) { + return patchReplaceFull({ + path: 'api/cfmappings/' + options.subscriberId, + fieldPath: options.group, + value: options.mappings + }) +} + +export function addMultipleNewMappings (options) { + return new Promise((resolve, reject) => { + const headers = { + 'Content-Type': 'application/json-patch+json', + Prefer: 'return=representation' + } + Vue.http.patch('api/cfmappings/' + options.subscriberId, options.mappings + , { headers: headers }).then((result) => { + resolve(getJsonBody(result.body)) + }).catch((err) => { + reject(err) + }) + }) +} + +export function changePositionOfDestination (options) { + return new Promise((resolve, reject) => { + const headers = { 'Content-Type': 'application/json-patch+json' } + Vue.http.patch('api/cfdestinationsets/' + options.id, [{ + op: 'replace', + path: '/destinations', + value: options.destinations + }], { headers: headers }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) +} + +export function moveDestinationUp (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + const getPromises = [] + getPromises.push(getDestinationsetById(options.prevId)) + getPromises.push(getDestinationsetById(options.id)) + return Promise.all(getPromises) + }).then((destinationsets) => { + const updatePromises = [] + const lastDestinationPrevId = _.findLast(destinationsets[0].destinations) || {} + const lowestPriorityPrevId = lastDestinationPrevId.priority || 1 + const prevDestinations = destinationsets[0].destinations + const currentDestinations = destinationsets[1].destinations + const prevDestinationsMoveToIndex = prevDestinations.length < 2 + ? 1 : prevDestinations.length - 2 + options.destination.priority = lowestPriorityPrevId + prevDestinations.splice(prevDestinationsMoveToIndex, 0, options.destination) + currentDestinations.shift() + updatePromises.push(addDestinationToDestinationset({ + id: options.prevId, + data: prevDestinations + })) + updatePromises.push(deleteDestinationFromDestinationset({ + id: options.id, + data: currentDestinations + })) + return Promise.all(updatePromises) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function moveDestinationDown (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + const getPromises = [] + getPromises.push(getDestinationsetById(options.nextId)) + getPromises.push(getDestinationsetById(options.id)) + return Promise.all(getPromises) + }).then((destinationsets) => { + const updatePromises = [] + const firstDestinationNextId = _.head(destinationsets[0].destinations) || {} + const highestPriorityNextId = firstDestinationNextId.priority || 1 + const nextDestinations = destinationsets[0].destinations + const currentDestinations = destinationsets[1].destinations + options.destination.priority = highestPriorityNextId + nextDestinations.splice(1, 0, options.destination) + currentDestinations.pop() + updatePromises.push(addDestinationToDestinationset({ + id: options.nextId, + data: nextDestinations + })) + updatePromises.push(deleteDestinationFromDestinationset({ + id: options.id, + data: currentDestinations + })) + return Promise.all(updatePromises) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function getDaysFromRange (options) { + let fromDay = options.fromDay + const toDay = options.toDay + 1 + const wdayMap = { + 1: i18n.t('pages.callForward.times.sunday'), + 2: i18n.t('pages.callForward.times.monday'), + 3: i18n.t('pages.callForward.times.tuesday'), + 4: i18n.t('pages.callForward.times.wednesday'), + 5: i18n.t('pages.callForward.times.thursday'), + 6: i18n.t('pages.callForward.times.friday'), + 7: i18n.t('pages.callForward.times.saturday') + } + const days = [] + while (fromDay < toDay) { + days.push({ name: wdayMap[fromDay], number: fromDay.toString() }) + fromDay++ + } + return days +} + +export function getHoursFromRange (options) { + const toHour = options.toHour + 1 + const fromMinute = options.hasMinute ? options.fromMinute : '00' + let toMinute = options.hasMinute ? options.toMinute + 1 : '00' + toMinute = !toMinute ? fromMinute + 1 : toMinute + const hours = [] + if (options.hasMinute) { + while (options.fromHour < toHour) { + hours.push({ + from: `${options.fromHour}:${fromMinute}`, + to: `${options.fromHour}:${toMinute}`, + hour: options.fromHour.toString() + }) + options.fromHour++ + } + } else { + hours.push({ + from: `${options.fromHour}:${fromMinute}`, + to: `${toHour}:${toMinute}` + }) + } + return hours +} + +export function convertTimesetToWeekdays (options) { + const times = [] + let counter = 0 + let timesetIsCompatible = true + let timesetHasDuplicate = false + let timesetExists = false + let timesetHasReverse = false + let timesetId = null + options.timesets.forEach((timeset) => { + const timesetNameMatches = timeset.name === options.timesetName + if (counter === 0 && timesetNameMatches) { + timeset.times.forEach((time) => { + const isIncompatible = time.mday || time.month || time.year || !time.wday || !time.hour + if (isIncompatible) { + timesetIsCompatible = false + } else { + let days = [] + let hours = [] + const fromDay = parseInt(time.wday.split('-')[0]) + const toDay = time.wday.split('-')[1] ? parseInt(time.wday.split('-')[1]) : fromDay + const fromHour = parseInt(time.hour.split('-')[0]) + const toHour = time.hour.split('-')[1] ? parseInt(time.hour.split('-')[1]) : fromHour + const fromMinute = time.minute ? parseInt(time.minute.split('-')[0]) : undefined + const toMinute = (time.minute && time.minute.split('-')[1]) ? parseInt(time.minute.split('-')[1]) : undefined + const isReverse = fromDay > toDay || fromHour > toHour || fromMinute > toMinute + let timesHour + if (isReverse) { + timesetHasReverse = true + } else { + hours = getHoursFromRange({ + hasMinute: !!time.minute, + fromHour: fromHour, + toHour: toHour, + fromMinute: fromMinute, + toMinute: toMinute + }) + days = getDaysFromRange({ fromDay: fromDay, toDay: toDay }) + days.forEach(day => { + hours.forEach(hour => { + timesHour = time.minute ? hour.hour : time.hour + times.push({ + weekday: day.name, + from: hour.from, + to: hour.to, + wday: day.number, + hour: timesHour, + minute: time.minute + }) + }) + }) + timesetId = timeset.id + timesetIsCompatible = true + } + } + }) + timesetId = timeset.id + timesetExists = true + counter++ + } else if (timesetNameMatches) { + timesetHasDuplicate = true + } + }) + return { + times: times, + timesetIsCompatible: timesetIsCompatible, + timesetExists: timesetExists, + timesetHasReverse: timesetHasReverse, + timesetHasDuplicate: timesetHasDuplicate, + timesetId: timesetId + } +} + +export function loadTimesetTimes (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getTimesets(options.subscriberId) + }).then((timesets) => { + const times = convertTimesetToWeekdays({ timesets: timesets, timesetName: options.timeset }) + return times + }).then((times) => { + resolve(times) + }).catch((err) => { + reject(err) + }) + }) +} + +export function deleteTimeFromTimeset (options) { + const headers = { + 'Content-Type': 'application/json-patch+json' + } + return new Promise((resolve, reject) => { + Vue.http.patch('api/cftimesets/' + options.timesetId, [{ + op: 'replace', + path: '/times', + value: options.times + }], { headers: headers }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) +} + +export function deleteTimesetById (id) { + return new Promise((resolve, reject) => { + Vue.http.delete('api/cftimesets/' + id).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function resetTimesetByName (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getTimesets(options.id) + }).then((timesets) => { + const deleteTimesetPromises = [] + _.filter(timesets, { name: options.name }).forEach((timeset) => { + deleteTimesetPromises.push(deleteTimesetById(timeset.id)) + }) + return Promise.all(deleteTimesetPromises) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function addTimeToTimeset (options) { + return patchReplaceFull({ + path: 'api/cftimesets/' + options.id, + fieldPath: 'times', + value: options.times + }) +} + +export function addNewTimeset (timesetName) { + return new Promise((resolve, reject) => { + Vue.http.post('api/cftimesets/', { name: timesetName }) + .then((response) => { + resolve(_.last(_.split(response.headers.get('Location'), '/'))) + }).catch((err) => { + reject(err) + }) + }) +} + +export function convertAddTime (options) { + const time = options.time + const weekday = options.weekday + const convertedTime = [] + const fromHour = time.from.split(':')[0] + const toHour = time.to.split(':')[0] + const fromMinute = time.from.split(':')[1] + const toMinute = time.to.split(':')[1] + const bothHasFullHour = fromMinute === '00' && toMinute === '00' + const bothHasSameHour = fromHour === toHour + const fromMinuteNotZero = time.from.split(':')[1] !== '00' + const toMinuteNotZero = time.to.split(':')[1] !== '00' + const bothMinutesNotZeroAndNextHourPlusOne = fromMinuteNotZero && toMinuteNotZero && parseInt(toHour) === parseInt(fromHour) + 1 + const bothMinutesNotZero = time.from.split(':')[1] !== '00' && + time.to.split(':')[1] !== '00' + const startNotZeroAndEndNextFullHour = + (parseInt(fromHour) === (parseInt(toHour) - 1) && toMinute === '00') + if (bothHasFullHour) { + convertedTime.push({ wday: weekday, hour: `${parseInt(fromHour)}-${parseInt(toHour) - 1}` }) + } else if (bothHasSameHour) { + convertedTime.push({ wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-${parseInt(toMinute) - 1}` }) + } else if (startNotZeroAndEndNextFullHour) { + convertedTime.push({ wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }) + } else if (bothMinutesNotZeroAndNextHourPlusOne) { + convertedTime.push( + { wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }, + { wday: weekday, hour: `${parseInt(toHour)}`, minute: `0-${parseInt(toMinute) - 1}` } + ) + } else if (bothMinutesNotZero) { + convertedTime.push( + { wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }, + { wday: weekday, hour: `${parseInt(fromHour) + 1}-${parseInt(toHour) - 1}` }, + { wday: weekday, hour: `${parseInt(toHour)}`, minute: `0-${parseInt(toMinute) - 1}` } + ) + } else if (fromMinuteNotZero) { + convertedTime.push( + { wday: weekday, hour: `${parseInt(fromHour)}`, minute: `${parseInt(fromMinute)}-59` }, + { wday: weekday, hour: `${parseInt(fromHour) + 1}-${parseInt(toHour) - 1}` } + ) + } else if (toMinuteNotZero) { + convertedTime.push( + { wday: weekday, hour: `${parseInt(fromHour) + 1}-${parseInt(toHour) - 1}` }, + { wday: weekday, hour: `${parseInt(toHour)}`, minute: `0-${parseInt(toMinute) - 1}` } + ) + } + return convertedTime +} + +export function createTimesetWithTime (options) { + return new Promise((resolve, reject) => { + const convertedTime = convertAddTime({ time: options.time[0], weekday: options.weekday }) + Promise.resolve().then(() => { + return addNewTimeset(options.name) + }).then((timesetId) => { + return addTimeToTimeset({ id: timesetId, times: convertedTime }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function getTimesByTimesetId (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/cftimesets/' + id).then((res) => { + const timeset = getJsonBody(res.body) + delete timeset._links + resolve(timeset.times) + }).catch((err) => { + reject(err) + }) + }) +} + +export function appendTimeToTimeset (options) { + return new Promise((resolve, reject) => { + const convertedTime = convertAddTime({ time: options.time[0], weekday: options.weekday }) + Promise.resolve().then(() => { + return getTimesByTimesetId(options.id) + }).then((times) => { + const concatTimes = times.concat(convertedTime) + return addTimeToTimeset({ id: options.id, times: concatTimes }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSourcesetById (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/cfsourcesets/' + id).then((res) => { + const sourceset = getJsonBody(res.body) + resolve(sourceset) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSourcesBySourcesetId (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/cfsourcesets/' + id).then((res) => { + const sourceset = getJsonBody(res.body) + resolve(sourceset.sources) + }).catch((err) => { + reject(err) + }) + }) +} + +export function addSourceToSourceset (options) { + return new Promise((resolve, reject) => { + const headers = { + 'Content-Type': 'application/json-patch+json' + } + Vue.http.patch('api/cfsourcesets/' + options.id, [{ + op: 'replace', + path: '/sources', + value: options.sources + }], { headers: headers }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function appendSourceToSourceset (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getSourcesBySourcesetId(options.id) + }).then((sources) => { + const concatSources = sources.concat(options.source) + return addSourceToSourceset({ id: options.id, sources: concatSources }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function createSourcesetWithSource (options) { + return new Promise((resolve, reject) => { + Vue.http.post('api/cfsourcesets/', { + name: options.sourcesetName, + subscriber_id: options.subscriberId, + mode: options.mode, + sources: [{ + source: options.source + }] + }).then((data) => { + const id = data.headers.map.location[0].split('cfsourcesets/')[1] + resolve(id) + }).catch((err) => { + reject(err) + }) + }) +} + +export function deleteSourcesetById (id) { + return new Promise((resolve, reject) => { + Vue.http.delete('api/cfsourcesets/' + id).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function deleteItemFromArrayByIndex (options) { + return options.array.filter((item, index) => { + return options.index !== index + }) +} + +export function deleteSourceFromSourcesetByIndex (options) { + return new Promise((resolve, reject) => { + const sources = deleteItemFromArrayByIndex({ + array: options.sources, + index: options.sourceIndex + }) + const headers = { + 'Content-Type': 'application/json-patch+json' + } + Vue.http.patch('api/cfsourcesets/' + options.sourceset.sourcesetId, [{ + op: 'replace', + path: '/sources', + value: sources + }], { headers: headers }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function flipCfuAndCft (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getMappings(options.subscriberId) + }).then((mappings) => { + const flipValues = mappings[options.fromType].filter((destinationset) => { + return destinationset.sourceset_id === options.sourcesetId && destinationset.timeset_id === options.timesetId + }) + const fromValues = mappings[options.fromType].filter((destinationset) => { + return !(destinationset.sourceset_id === options.sourcesetId && destinationset.timeset_id === options.timesetId) + }) + const toValues = mappings[options.toType].concat(flipValues) + const patchOptions = [ + { + op: 'replace', + path: '/' + options.fromType, + value: fromValues + }, { + op: 'replace', + path: '/' + options.toType, + value: toValues + } + ] + const timeoutOption = { + op: 'replace', + path: '/cft_ringtimeout', + value: 15 + } + if (!mappings.cft_ringtimeout) { + patchOptions.push(timeoutOption) + } + return new Promise((resolve, reject) => { + const headers = { + 'Content-Type': 'application/json-patch+json' + } + Vue.http.patch('api/cfmappings/' + options.subscriberId, + patchOptions, { headers: headers }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function getOwnPhoneTimeout (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/cfmappings/' + id).then((res) => { + const timeout = getJsonBody(res.body).cft_ringtimeout + resolve(timeout) + }).catch((err) => { + reject(err) + }) + }) +} + +export function updateOwnPhoneTimeout (options) { + return patchReplaceFull({ + path: 'api/cfmappings/' + options.subscriberId, + fieldPath: 'cft_ringtimeout', + value: options.timeout + }) +} + +export async function getCallForwardMappings (subscriberId) { + return get({ + path: 'api/cfmappings/' + subscriberId + }) +} + +export async function getCallForwardDestinationSets (subscriberId) { + return getList({ + path: 'api/cfdestinationsets/' + subscriberId + }) +} + +export async function getCallForwardSourceSets (subscriberId) { + return getList({ + path: 'api/cfsourcesets/' + subscriberId + }) +} + +export async function getCallForwardTimeSets (subscriberId) { + return getList({ + path: 'api/cftimesets/' + subscriberId + }) } diff --git a/src/api/common.js b/src/api/common.js index d1b00b45..966b64a5 100644 --- a/src/api/common.js +++ b/src/api/common.js @@ -1,228 +1,223 @@ -import _ from 'lodash'; -import Vue from 'vue'; +import _ from 'lodash' +import Vue from 'vue' import { - getJsonBody -} from './utils'; + getJsonBody +} from './utils' -export const LIST_DEFAULT_PAGE = 1; -export const LIST_DEFAULT_ROWS = 25; -export const LIST_ALL_ROWS = 1000; +export const LIST_DEFAULT_PAGE = 1 +export const LIST_DEFAULT_ROWS = 25 +export const LIST_ALL_ROWS = 1000 const PATCH_HEADERS = { - 'Content-Type': 'application/json-patch+json', - 'Prefer': 'return=minimal' -}; + 'Content-Type': 'application/json-patch+json', + Prefer: 'return=minimal' +} const GET_HEADERS = { - 'Accept': 'application/json' -}; + Accept: 'application/json' +} export class ApiResponseError extends Error { + constructor (code, message) { + super() + this.code = code + this.status = code + this.message = message + } +} + +export function getList (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge({ + all: false, + params: { + page: LIST_DEFAULT_PAGE, + rows: LIST_DEFAULT_ROWS + }, + headers: GET_HEADERS + }, options) + Promise.resolve().then(() => { + if (options.all === true) { + options.params.rows = LIST_ALL_ROWS + } + return Vue.http.get(options.path, { + params: options.params, + headers: options.headers + }) + }).then((res) => { + const body = getJsonBody(res.body) + if (options.all === true && body.total_count > LIST_ALL_ROWS) { + return Vue.http.get(options.path, { + params: _.merge(options.params, { + rows: body.total_count + }), + headers: options.headers + }) + } else { + return Promise.resolve(res) + } + }).then((res) => { + const body = getJsonBody(res.body) + const totalCount = _.get(body, 'total_count', 0) + let lastPage = Math.ceil(totalCount / options.params.rows) + if (options.all === true) { + lastPage = 1 + } + if (lastPage === 0) { + lastPage = null + } + const items = _.get(body, options.root, []) + for (let i = 0; i < items.length; i++) { + items[i] = normalizeEntity(items[i]) + } + resolve({ + items: items, + lastPage: lastPage + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function get (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge({ + headers: GET_HEADERS + }, options) + const requestOptions = { + headers: options.headers, + params: options.params + } + if (options.blob === true) { + requestOptions.responseType = 'blob' + } + return Vue.http.get(options.path, requestOptions).then((result) => { + let body = null + if (options.blob === true) { + body = URL.createObjectURL(result.body) + } else { + body = normalizeEntity(getJsonBody(result.body)) + } + resolve(body) + }).catch((err) => { + const code = _.get(err, 'body.code', null) + const message = _.get(err, 'body.message', null) + if (code !== null && message !== null) { + reject(new ApiResponseError(err.body.code, err.body.message)) + } else { + reject(err) + } + }) + }) +} + +export function patch (operation, options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge({ + headers: PATCH_HEADERS + }, options) + const body = { + op: operation, + path: '/' + options.fieldPath + } + if (options.value !== undefined) { + body.value = options.value + } + Vue.http.patch(options.path, [body], { + headers: options.headers + }).then((result) => { + resolve(result) + }).catch((err) => { + const code = _.get(err, 'body.code', null) + const message = _.get(err, 'body.message', null) + if (code !== null && message !== null) { + reject(new ApiResponseError(err.body.code, err.body.message)) + } else { + reject(err) + } + }) + }) +} + +export function patchReplace (options) { + return patch('replace', options) +} + +export function patchAdd (options) { + return patch('add', options) +} + +export function patchRemove (options) { + return patch('remove', options) +} + +export function patchFull (operation, options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + headers: { + Prefer: 'return=representation' + } + }) + patch(operation, options).then((result) => { + resolve(getJsonBody(result.body)) + }).catch((err) => { + reject(err) + }) + }) +} + +export function patchReplaceFull (options) { + return patchFull('replace', options) +} + +export function patchAddFull (options) { + return patchFull('add', options) +} + +export function patchRemoveFull (options) { + return patchFull('remove', options) +} + +export function getFieldList (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge({ + headers: GET_HEADERS + }, options) + Vue.http.get(options.path, { + headers: options.headers + }).then((result) => { + const fieldList = getJsonBody(result.body)[options.field] + resolve(fieldList) + }).catch((err) => { + reject(err) + }) + }) +} + +export function normalizeEntity (entity) { + if (entity && entity._links) { + delete entity._links + } + return entity +} - constructor(code, message) { - super(); - this.code = code; - this.status = code; - this.message = message; - } -} - -export function getList(options) { - return new Promise((resolve, reject) => { - options = options || {}; - options = _.merge({ - all: false, - params: { - page: LIST_DEFAULT_PAGE, - rows: LIST_DEFAULT_ROWS - }, - headers: GET_HEADERS - }, options); - Promise.resolve().then(() => { - if(options.all === true) { - options.params.rows = LIST_ALL_ROWS; - } - return Vue.http.get(options.path, { - params: options.params, - headers: options.headers - }); - }).then((res) => { - let body = getJsonBody(res.body); - if(options.all === true && body.total_count > LIST_ALL_ROWS) { - return Vue.http.get(options.path, { - params: _.merge(options.params, { - rows: body.total_count - }), - headers: options.headers - }); - } - else { - return Promise.resolve(res); - } - }).then((res) => { - let body = getJsonBody(res.body); - let totalCount = _.get(body, 'total_count', 0); - let lastPage = Math.ceil( totalCount / options.params.rows ); - if(options.all === true) { - lastPage = 1; - } - if(lastPage === 0) { - lastPage = null; - } - let items = _.get(body, options.root, []); - for(let i = 0; i < items.length; i++) { - items[i] = normalizeEntity(items[i]); - } - resolve({ - items: items, - lastPage: lastPage - }); - }).catch((err) => { - reject(err); - }); - }); -} - -export function get(options) { - return new Promise((resolve, reject) => { - options = options || {}; - options = _.merge({ - headers: GET_HEADERS - }, options); - let requestOptions ={ - headers: options.headers, - params: options.params - }; - if(options.blob === true) { - requestOptions.responseType = 'blob'; - } - return Vue.http.get(options.path, requestOptions).then((result) => { - let body = null; - if(options.blob === true) { - body = URL.createObjectURL(result.body); - } - else { - body = normalizeEntity(getJsonBody(result.body)); - } - resolve(body); - }).catch((err) => { - let code = _.get(err, 'body.code', null); - let message = _.get(err, 'body.message', null); - if(code !== null && message !== null) { - reject(new ApiResponseError(err.body.code, err.body.message)); - } - else { - reject(err); - } - }); - }); -} - -export function patch(operation, options) { - return new Promise((resolve, reject) => { - options = options || {}; - options = _.merge({ - headers: PATCH_HEADERS - }, options); - let body = { - op: operation, - path: '/'+ options.fieldPath - }; - if(options.value !== void(0)) { - body.value = options.value; - } - Vue.http.patch(options.path, [body], { - headers: options.headers - }).then((result) => { - resolve(result); - }).catch((err) => { - let code = _.get(err, 'body.code', null); - let message = _.get(err, 'body.message', null); - if(code !== null && message !== null) { - reject(new ApiResponseError(err.body.code, err.body.message)); - } - else { - reject(err); - } - }); - }); -} - -export function patchReplace(options) { - return patch('replace', options); -} - -export function patchAdd(options) { - return patch('add', options); -} - -export function patchRemove(options) { - return patch('remove', options); -} - -export function patchFull(operation, options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - headers: { - Prefer: 'return=representation' - } - }); - patch(operation, options).then((result)=>{ - resolve(getJsonBody(result.body)); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function patchReplaceFull(options) { - return patchFull('replace', options); -} - -export function patchAddFull(options) { - return patchFull('add', options); -} - -export function patchRemoveFull(options) { - return patchFull('remove', options); -} - -export function getFieldList(options) { - return new Promise((resolve, reject) => { - options = options || {}; - options = _.merge({ - headers: GET_HEADERS - }, options); - Vue.http.get(options.path, { - headers: options.headers - }).then((result) => { - let fieldList = getJsonBody(result.body)[options.field]; - resolve(fieldList); - }).catch((err) => { - reject(err); - }); - }); -} - -export function normalizeEntity(entity) { - if(entity && entity._links) { - delete entity._links; - } - return entity; -} - -export function getAsBlob(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - blob: true - }); - get(options).then((body)=>{ - resolve(body); - }).catch((err)=>{ - reject(err); - }); - }); +export function getAsBlob (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + blob: true + }) + get(options).then((body) => { + resolve(body) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/communication.js b/src/api/communication.js index 0bd32031..78b68d2c 100644 --- a/src/api/communication.js +++ b/src/api/communication.js @@ -1,21 +1,21 @@ -import _ from 'lodash'; -import Vue from 'vue'; +import _ from 'lodash' +import Vue from 'vue' -export function createFax(options) { - return new Promise((resolve, reject) => { - var formData = new FormData(); - var fields = _.clone(options); - delete fields.file; - var json = JSON.stringify(fields); - formData.append('json', json); - if (options.file) { - formData.append('faxfile', options.file); - } - Vue.http.post('api/faxes/', formData).then(() => { - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function createFax (options) { + return new Promise((resolve, reject) => { + var formData = new FormData() + var fields = _.clone(options) + delete fields.file + var json = JSON.stringify(fields) + formData.append('json', json) + if (options.file) { + formData.append('faxfile', options.file) + } + Vue.http.post('api/faxes/', formData).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/conversations.js b/src/api/conversations.js index 05e5e36c..24cc8b92 100644 --- a/src/api/conversations.js +++ b/src/api/conversations.js @@ -1,114 +1,106 @@ import _ from 'lodash' import { - saveAs + saveAs } from 'file-saver' import Vue from 'vue' import { - getIncomingCallBlocking, - getOutgoingCallBlocking + getIncomingCallBlocking, + getOutgoingCallBlocking } from './call-blocking' import { - getList + getList } from './common' -export function getConversations(options) { - return new Promise((resolve, reject) => { - let type = _.get(options, 'type', null); - let from = _.get(options, 'from', null); - let to = _.get(options, 'to', null); - let params ={ - subscriber_id: _.get(options, 'subscriberId'), - order_by: _.get(options, 'order_by', 'timestamp'), - order_by_direction: 'desc', - no_count: true, - tz: 'UTC', - page: _.get(options, 'page', 1), - rows: _.get(options, 'rows', 25) - }; - if (type !== null) { - params.type = type; - } - if (from !== null){ - params.from = from; - } - if (to !== null){ - params.to = to; - } - getList({ - path: 'api/conversations/', - root: '_embedded.ngcp:conversations', - params: params, - all: false - }).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); +export function getConversations (options) { + return new Promise((resolve, reject) => { + const type = _.get(options, 'type', null) + const params = { + subscriber_id: _.get(options, 'subscriberId'), + order_by: _.get(options, 'order_by', 'timestamp'), + order_by_direction: 'desc', + no_count: true, + tz: 'UTC', + page: _.get(options, 'page', 1), + rows: _.get(options, 'rows', 25) + } + if (type !== null) { + params.type = type + } + getList({ + path: 'api/conversations/', + root: '_embedded.ngcp:conversations', + params: params, + all: false + }).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) } -export function downloadVoiceMail(id) { - return new Promise((resolve, reject) => { - Vue.http.get('api/voicemailrecordings/' + id, { responseType: 'blob' }) - .then((res) => { - return res.blob(); - }).then(voicemail => { - saveAs((voicemail), "voicemail-" + id + '.wav'); - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function downloadVoiceMail (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/voicemailrecordings/' + id, { responseType: 'blob' }) + .then((res) => { + return res.blob() + }).then(voicemail => { + saveAs((voicemail), 'voicemail-' + id + '.wav') + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function downloadFax(id) { - return new Promise((resolve, reject) => { - Vue.http.get('api/faxrecordings/' + id, { responseType: 'blob' }) - .then((res) => { - return res.blob(); - }).then(fax => { - saveAs((fax), "fax-" + id + '.tif'); - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function downloadFax (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/faxrecordings/' + id, { responseType: 'blob' }) + .then((res) => { + return res.blob() + }).then(fax => { + saveAs((fax), 'fax-' + id + '.tif') + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function playVoiceMail(options) { - return new Promise((resolve, reject) => { - let params = { format: options.format }; - Vue.http.get(`api/voicemailrecordings/${options.id}`, { params: params, responseType: 'blob' }) - .then((res) => { - resolve(URL.createObjectURL(res.body)); - }).catch((err)=>{ - reject(err); - }); - }); +export function playVoiceMail (options) { + return new Promise((resolve, reject) => { + const params = { format: options.format } + Vue.http.get(`api/voicemailrecordings/${options.id}`, { params: params, responseType: 'blob' }) + .then((res) => { + resolve(URL.createObjectURL(res.body)) + }).catch((err) => { + reject(err) + }) + }) } -export function getIncomingBlocked(id) { - return new Promise((resolve, reject) => { - getIncomingCallBlocking(id).then((list) => { - resolve(list) - }).catch((err) => { - reject(err); - }); - }); +export function getIncomingBlocked (id) { + return new Promise((resolve, reject) => { + getIncomingCallBlocking(id).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) } -export function getOutgoingBlocked(id) { - return new Promise((resolve, reject) => { - getOutgoingCallBlocking(id).then((list) => { - resolve(list) - }).catch((err) => { - reject(err); - }); - }); +export function getOutgoingBlocked (id) { + return new Promise((resolve, reject) => { + getOutgoingCallBlocking(id).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) } -export async function deleteVoicemail(id) { - const res = await Vue.http.delete('api/voicemails/' + id) - return res.status >= 200 +export async function deleteVoicemail (id) { + const res = await Vue.http.delete('api/voicemails/' + id) + return res.status >= 200 } diff --git a/src/api/pbx-callqueues.js b/src/api/pbx-callqueues.js index 4f37ede1..3fdccb51 100644 --- a/src/api/pbx-callqueues.js +++ b/src/api/pbx-callqueues.js @@ -1,53 +1,53 @@ -import _ from 'lodash'; +import _ from 'lodash' import { - addPreference, - addPreferenceFull, - getAllPreferences, - getSubscriber -} from "./subscriber"; + addPreference, + addPreferenceFull, + getAllPreferences, + getSubscriber +} from './subscriber' -export function getCallQueues() { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getAllPreferences({ - all: true - }); - }).then((preferencesList)=>{ - resolve({ - items: _.get(preferencesList, 'items', []).filter((preferences)=>{ - return _.get(preferences, 'cloud_pbx_callqueue', false) - }) - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function getCallQueues () { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getAllPreferences({ + all: true + }) + }).then((preferencesList) => { + resolve({ + items: _.get(preferencesList, 'items', []).filter((preferences) => { + return _.get(preferences, 'cloud_pbx_callqueue', false) + }) + }) + }).catch((err) => { + reject(err) + }) + }) } -export function getCallQueueList() { - return new Promise((resolve, reject)=>{ - let callQueues = []; - Promise.resolve().then(()=>{ - return getCallQueues(); - }).then(($callQueues)=>{ - callQueues = $callQueues; - let subscriberPromises = []; - callQueues.items.forEach((callQueue)=>{ - subscriberPromises.push(getSubscriber(callQueue.id)); - }); - return Promise.all(subscriberPromises); - }).then((subscribers)=>{ - resolve({ - subscribers: { - items: subscribers - }, - callQueues: callQueues - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function getCallQueueList () { + return new Promise((resolve, reject) => { + let callQueues = [] + Promise.resolve().then(() => { + return getCallQueues() + }).then(($callQueues) => { + callQueues = $callQueues + const subscriberPromises = [] + callQueues.items.forEach((callQueue) => { + subscriberPromises.push(getSubscriber(callQueue.id)) + }) + return Promise.all(subscriberPromises) + }).then((subscribers) => { + resolve({ + subscribers: { + items: subscribers + }, + callQueues: callQueues + }) + }).catch((err) => { + reject(err) + }) + }) } /** @@ -56,51 +56,50 @@ export function getCallQueueList() { * @param options.queue_wrap_up_time * @return {Promise} */ -export function createCallQueue(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return Promise.all([ - addPreference(options.subscriber_id, 'cloud_pbx_callqueue', true), - addPreference(options.subscriber_id, 'max_queue_length', options.max_queue_length), - addPreference(options.subscriber_id, 'queue_wrap_up_time', options.queue_wrap_up_time) - ]); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function createCallQueue (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return Promise.all([ + addPreference(options.subscriber_id, 'cloud_pbx_callqueue', true), + addPreference(options.subscriber_id, 'max_queue_length', options.max_queue_length), + addPreference(options.subscriber_id, 'queue_wrap_up_time', options.queue_wrap_up_time) + ]) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function removeCallQueue(subscriber_id) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return addPreference(subscriber_id, 'cloud_pbx_callqueue', false); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function removeCallQueue (subscriberId) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return addPreference(subscriberId, 'cloud_pbx_callqueue', false) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function setCallQueueMaxLength(options) { - return new Promise((resolve, reject)=>{ - addPreferenceFull(options.callQueueId, 'max_queue_length', options.maxQueueLength).then((preferences)=>{ - resolve(preferences); - }).catch((err)=>{ - reject(err); - }); - }); +export function setCallQueueMaxLength (options) { + return new Promise((resolve, reject) => { + addPreferenceFull(options.callQueueId, 'max_queue_length', options.maxQueueLength).then((preferences) => { + resolve(preferences) + }).catch((err) => { + reject(err) + }) + }) } -export function setCallQueueWrapUpTime(options) { - return new Promise((resolve, reject)=>{ - addPreferenceFull(options.callQueueId, 'queue_wrap_up_time', options.queueWrapUpTime).then((preferences)=>{ - resolve(preferences); - }).catch((err)=>{ - reject(err); - }); - }); +export function setCallQueueWrapUpTime (options) { + return new Promise((resolve, reject) => { + addPreferenceFull(options.callQueueId, 'queue_wrap_up_time', options.queueWrapUpTime).then((preferences) => { + resolve(preferences) + }).catch((err) => { + reject(err) + }) + }) } - diff --git a/src/api/pbx-config.js b/src/api/pbx-config.js index 4265289d..d0677b0f 100644 --- a/src/api/pbx-config.js +++ b/src/api/pbx-config.js @@ -1,235 +1,233 @@ -import _ from 'lodash'; -import Vue from 'vue'; +import _ from 'lodash' +import Vue from 'vue' import { - getSubscribers -} from './subscriber'; -import uuid from 'uuid'; + getSubscribers +} from './subscriber' +import uuid from 'uuid' import { - getList, - get, - patchAdd, - patchRemove + getList, + get, + patchAdd, + patchRemove } from './common' -export const createId = uuid.v4; -export const PBX_CONFIG_ORDER_BY = 'create_timestamp'; -export const PBX_CONFIG_ORDER_DIRECTION = 'desc'; - -export function getPilot(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - params: { - is_pbx_group: 0, - is_pbx_pilot: 1, - rows: 1 - } - }); - getSubscribers(options).then((subscribers)=>{ - if (subscribers.items.length === 1) { - resolve(subscribers.items[0]); - } - else { - resolve(null); - } - }).catch((err)=>{ - reject(err); - }); - }); +export const createId = uuid.v4 +export const PBX_CONFIG_ORDER_BY = 'create_timestamp' +export const PBX_CONFIG_ORDER_DIRECTION = 'desc' + +export function getPilot (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + params: { + is_pbx_group: 0, + is_pbx_pilot: 1, + rows: 1 + } + }) + getSubscribers(options).then((subscribers) => { + if (subscribers.items.length === 1) { + resolve(subscribers.items[0]) + } else { + resolve(null) + } + }).catch((err) => { + reject(err) + }) + }) } -export function getProfiles(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/pbxdeviceprofiles/', - root: '_embedded.ngcp:pbxdeviceprofiles' - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); +export function getProfiles (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/pbxdeviceprofiles/', + root: '_embedded.ngcp:pbxdeviceprofiles' + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) } -export function getAllProfiles() { - return getProfiles({ - all: true - }); +export function getAllProfiles () { + return getProfiles({ + all: true + }) } -export function getModel(id) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return get({ - path: 'api/pbxdevicemodels/' + id - }); - }).then((model)=> { - resolve(model); - }).catch((err)=>{ - reject(err); - }); - }); +export function getModel (id) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return get({ + path: 'api/pbxdevicemodels/' + id + }) + }).then((model) => { + resolve(model) + }).catch((err) => { + reject(err) + }) + }) } -export function getModelFrontImage(id) { - return new Promise((resolve)=>{ - Vue.http.get('api/pbxdevicemodelimages/' + id, { - responseType: 'blob', - params: { - type: 'front' - } - }).then((res)=>{ - resolve({ - id: id, - url: URL.createObjectURL(res.body), - blob: res.body - }); - }).catch(()=>{ - resolve({ - id: id, - url: null, - blob: null - }); - }); - }); +export function getModelFrontImage (id) { + return new Promise((resolve) => { + Vue.http.get('api/pbxdevicemodelimages/' + id, { + responseType: 'blob', + params: { + type: 'front' + } + }).then((res) => { + resolve({ + id: id, + url: URL.createObjectURL(res.body), + blob: res.body + }) + }).catch(() => { + resolve({ + id: id, + url: null, + blob: null + }) + }) + }) } -export function getAllSoundSets(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/soundsets/', - root: '_embedded.ngcp:soundsets', - all: true - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); +export function getAllSoundSets (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/soundsets/', + root: '_embedded.ngcp:soundsets', + all: true + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) } -export function removeSoundSet(id) { - return Vue.http.delete('api/soundsets/' + id); +export function removeSoundSet (id) { + return Vue.http.delete('api/soundsets/' + id) } -export function getSoundSet(id) { - return new Promise((resolve, reject)=>{ - get({ - path: 'api/soundsets/' + id - }).then((soundSet)=>{ - resolve(soundSet); - }).catch((err)=>{ - reject(err); - }); - }); +export function getSoundSet (id) { + return new Promise((resolve, reject) => { + get({ + path: 'api/soundsets/' + id + }).then((soundSet) => { + resolve(soundSet) + }).catch((err) => { + reject(err) + }) + }) } -export function editSoundSetFields(id, fields) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getSoundSet(id); - }).then((result)=>{ - let prefs = Object.assign(result, fields); - delete fields._links; - return Vue.http.put('api/soundsets/' + id, prefs); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function editSoundSetFields (id, fields) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getSoundSet(id) + }).then((result) => { + const prefs = Object.assign(result, fields) + delete fields._links + return Vue.http.put('api/soundsets/' + id, prefs) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function createSoundSet(soundSet) { - return new Promise((resolve, reject)=>{ - Vue.http.post('api/soundsets/', soundSet).then(() => { - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function createSoundSet (soundSet) { + return new Promise((resolve, reject) => { + Vue.http.post('api/soundsets/', soundSet).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function setSoundSetName(id, value) { - return editSoundSetFields(id, { name: value }); +export function setSoundSetName (id, value) { + return editSoundSetFields(id, { name: value }) } -export function setSoundSetDescription(id, value) { - return editSoundSetFields(id, { description: value }); +export function setSoundSetDescription (id, value) { + return editSoundSetFields(id, { description: value }) } -export function playSoundFile(options) { - return new Promise((resolve, reject)=>{ - let params = { format: options.format }; - Vue.http.get(`api/soundfilerecordings/${options.id}`, { params: params, responseType: 'blob' }) - .then((res) => { - resolve(URL.createObjectURL(res.body)); - }).catch((err) => { - reject(err); - }); - }); +export function playSoundFile (options) { + return new Promise((resolve, reject) => { + const params = { format: options.format } + Vue.http.get(`api/soundfilerecordings/${options.id}`, { params: params, responseType: 'blob' }) + .then((res) => { + resolve(URL.createObjectURL(res.body)) + }).catch((err) => { + reject(err) + }) + }) } -export function uploadSoundFile(options, onProgress) { - return new Promise((resolve, reject) => { - let formData = new FormData(); - let loopplay = options.item.loopplay ? 1 : 2; - let fields = { - loopplay: loopplay, - filename: options.file.name, - set_id: options.item.set_id, - handle: options.item.handle, - }; - let json = JSON.stringify(fields); - let requestKey = `previous-${options.item.handle}-request`; - formData.append('json', json); - if (options.file) { - formData.append('soundfile', options.file); - } - Vue.http.post('api/soundfiles/', formData, { - before(request) { - Vue[requestKey] = request; - }, - progress(e) { - if (e.lengthComputable) { - onProgress(Math.ceil((e.loaded / e.total ) * 100)); - } - } - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); +export function uploadSoundFile (options, onProgress) { + return new Promise((resolve, reject) => { + const formData = new FormData() + const loopplay = options.item.loopplay ? 1 : 2 + const fields = { + loopplay: loopplay, + filename: options.file.name, + set_id: options.item.set_id, + handle: options.item.handle + } + const json = JSON.stringify(fields) + const requestKey = `previous-${options.item.handle}-request` + formData.append('json', json) + if (options.file) { + formData.append('soundfile', options.file) + } + Vue.http.post('api/soundfiles/', formData, { + before (request) { + Vue[requestKey] = request + }, + progress (e) { + if (e.lengthComputable) { + onProgress(Math.ceil((e.loaded / e.total) * 100)) + } + } + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function setSubscriberSoundSet(id, soundSet) { - return new Promise((resolve, reject)=>{ - let promise; - let path = 'api/subscriberpreferences/' + id; - let fieldPath = 'contract_sound_set'; - if(soundSet === null || soundSet === void(0)) { - promise = patchRemove({ - path: path, - fieldPath: 'contract_sound_set' - }); - } - else { - promise = patchAdd({ - path: path, - fieldPath: fieldPath, - value: soundSet - }); - } - promise.then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSubscriberSoundSet (id, soundSet) { + return new Promise((resolve, reject) => { + let promise + const path = 'api/subscriberpreferences/' + id + const fieldPath = 'contract_sound_set' + if (soundSet === null || soundSet === undefined) { + promise = patchRemove({ + path: path, + fieldPath: 'contract_sound_set' + }) + } else { + promise = patchAdd({ + path: path, + fieldPath: fieldPath, + value: soundSet + }) + } + promise.then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/pbx-devices.js b/src/api/pbx-devices.js index c20444a1..3abc32b0 100644 --- a/src/api/pbx-devices.js +++ b/src/api/pbx-devices.js @@ -1,183 +1,179 @@ import { - getModel, - getModelFrontImage, - PBX_CONFIG_ORDER_BY, - PBX_CONFIG_ORDER_DIRECTION -} from "./pbx-config"; -import _ from "lodash"; + getModel, + getModelFrontImage, + PBX_CONFIG_ORDER_BY, + PBX_CONFIG_ORDER_DIRECTION +} from './pbx-config' +import _ from 'lodash' import { - getList, - patchReplace, - patchReplaceFull -} from "./common"; -import Vue from "vue"; + getList, + patchReplace, + patchReplaceFull +} from './common' +import Vue from 'vue' -export function getDevices(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/pbxdevices/', - root: '_embedded.ngcp:pbxdevices' - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); +export function getDevices (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/pbxdevices/', + root: '_embedded.ngcp:pbxdevices' + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) } -export function getDeviceList(options) { - return new Promise((resolve, reject)=>{ - let params = { - page: options.page, - profile_id: options.profile_id, - identifier: options.identifier, - station_name: options.station_name, - order_by: PBX_CONFIG_ORDER_BY, - order_by_direction: PBX_CONFIG_ORDER_DIRECTION - }; - if (params.profile_id === null || params.profile_id === undefined || params.profile_id === "") { - delete params['profile_id']; - } - if (params.identifier === null || params.identifier === undefined || params.identifier === "") { - delete params['identifier']; - } - else { - params.identifier = "*" + params.identifier + "*" - } - if (params.station_name === null || params.station_name === undefined || params.station_name === "") { - delete params['station_name']; - } - else { - params.station_name = "*" + params.station_name + "*" - } - getDevices({ - params: params - }).then((devices)=>{ - resolve(devices); - }).catch((err)=>{ - reject(err); - }); - }); +export function getDeviceList (options) { + return new Promise((resolve, reject) => { + const params = { + page: options.page, + profile_id: options.profile_id, + identifier: options.identifier, + station_name: options.station_name, + order_by: PBX_CONFIG_ORDER_BY, + order_by_direction: PBX_CONFIG_ORDER_DIRECTION + } + if (params.profile_id === null || params.profile_id === undefined || params.profile_id === '') { + delete params.profile_id + } + if (params.identifier === null || params.identifier === undefined || params.identifier === '') { + delete params.identifier + } else { + params.identifier = '*' + params.identifier + '*' + } + if (params.station_name === null || params.station_name === undefined || params.station_name === '') { + delete params.station_name + } else { + params.station_name = '*' + params.station_name + '*' + } + getDevices({ + params: params + }).then((devices) => { + resolve(devices) + }).catch((err) => { + reject(err) + }) + }) } -export function createDevice(deviceData) { - return new Promise((resolve, reject)=>{ - Vue.http.post('api/pbxdevices/', { - station_name: deviceData.stationName, - identifier: deviceData.identifier, - profile_id: deviceData.profile - }).then((res)=>{ - resolve(res); - }).catch((err)=>{ - if (err.status >= 400) { - reject(new Error(err.body.message)); - } - else { - reject(err); - } - }); - }); +export function createDevice (deviceData) { + return new Promise((resolve, reject) => { + Vue.http.post('api/pbxdevices/', { + station_name: deviceData.stationName, + identifier: deviceData.identifier, + profile_id: deviceData.profile + }).then((res) => { + resolve(res) + }).catch((err) => { + if (err.status >= 400) { + reject(new Error(err.body.message)) + } else { + reject(err) + } + }) + }) } -export function removeDevice(id) { - return new Promise((resolve, reject)=>{ - Vue.http.delete('api/pbxdevices/' + id).then(()=>{ - resolve(); - }).catch((err)=>{ - if (err.status >= 400) { - reject(new Error(err.body.message)); - } - else { - reject(err); - } - }); - }); +export function removeDevice (id) { + return new Promise((resolve, reject) => { + Vue.http.delete('api/pbxdevices/' + id).then(() => { + resolve() + }).catch((err) => { + if (err.status >= 400) { + reject(new Error(err.body.message)) + } else { + reject(err) + } + }) + }) } -export function setDeviceStationName(deviceId, stationName) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return patchReplaceFull({ - path: 'api/pbxdevices/' + deviceId, - fieldPath: 'station_name', - value: stationName - }); - }).then((device)=>{ - resolve(device); - }).catch((err)=>{ - reject(err); - }); - }); +export function setDeviceStationName (deviceId, stationName) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return patchReplaceFull({ + path: 'api/pbxdevices/' + deviceId, + fieldPath: 'station_name', + value: stationName + }) + }).then((device) => { + resolve(device) + }).catch((err) => { + reject(err) + }) + }) } -export function setDeviceIdentifier(deviceId, identifier) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return patchReplaceFull({ - path: 'api/pbxdevices/' + deviceId, - fieldPath: 'identifier', - value: identifier - }); - }).then((device)=>{ - resolve(device); - }).catch((err)=>{ - reject(err); - }); - }); +export function setDeviceIdentifier (deviceId, identifier) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return patchReplaceFull({ + path: 'api/pbxdevices/' + deviceId, + fieldPath: 'identifier', + value: identifier + }) + }).then((device) => { + resolve(device) + }).catch((err) => { + reject(err) + }) + }) } -export function setDeviceProfile(deviceId, profileId) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return patchReplace({ - path: 'api/pbxdevices/' + deviceId, - fieldPath: 'lines', - value: [] - }); - }).then(()=>{ - return patchReplaceFull({ - path: 'api/pbxdevices/' + deviceId, - fieldPath: 'profile_id', - value: profileId - }); - }).then((device)=>{ - resolve(device); - }).catch((err)=>{ - reject(err); - }); - }); +export function setDeviceProfile (deviceId, profileId) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return patchReplace({ + path: 'api/pbxdevices/' + deviceId, + fieldPath: 'lines', + value: [] + }) + }).then(() => { + return patchReplaceFull({ + path: 'api/pbxdevices/' + deviceId, + fieldPath: 'profile_id', + value: profileId + }) + }).then((device) => { + resolve(device) + }).catch((err) => { + reject(err) + }) + }) } -export function setDeviceKeys(deviceId, keys) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return patchReplaceFull({ - path: 'api/pbxdevices/' + deviceId, - fieldPath: 'lines', - value: keys - }); - }).then((device)=>{ - resolve(device); - }).catch((err)=>{ - reject(err); - }); - }); +export function setDeviceKeys (deviceId, keys) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return patchReplaceFull({ + path: 'api/pbxdevices/' + deviceId, + fieldPath: 'lines', + value: keys + }) + }).then((device) => { + resolve(device) + }).catch((err) => { + reject(err) + }) + }) } -export function loadDeviceModel(modelId) { - return new Promise((resolve, reject)=>{ - Promise.all([ - getModel(modelId), - getModelFrontImage(modelId) - ]).then((res)=>{ - resolve({ - model: res[0], - modelImage: res[1] - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function loadDeviceModel (modelId) { + return new Promise((resolve, reject) => { + Promise.all([ + getModel(modelId), + getModelFrontImage(modelId) + ]).then((res) => { + resolve({ + model: res[0], + modelImage: res[1] + }) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/pbx-groups.js b/src/api/pbx-groups.js index 27636359..82a6800c 100644 --- a/src/api/pbx-groups.js +++ b/src/api/pbx-groups.js @@ -1,281 +1,279 @@ -import _ from "lodash"; +import _ from 'lodash' import { - createSubscriber, - deleteSubscriber, - getFullSubscribers, - getSubscriberAndPreferences, - getSubscribers, - setDisplayName, - setPbxExtension, setPbxGroupMemberIds, - setPbxHuntPolicy, - setPbxHuntTimeout, setSubscriberNumbers -} from "./subscriber"; + createSubscriber, + deleteSubscriber, + getFullSubscribers, + getSubscriberAndPreferences, + getSubscribers, + setDisplayName, + setPbxExtension, setPbxGroupMemberIds, + setPbxHuntPolicy, + setPbxHuntTimeout, setSubscriberNumbers +} from './subscriber' import { - getAllSoundSets, - getPilot, - getSoundSet, - createId, - PBX_CONFIG_ORDER_BY, - PBX_CONFIG_ORDER_DIRECTION, - setSubscriberSoundSet -} from "./pbx-config"; + getAllSoundSets, + getPilot, + getSoundSet, + createId, + PBX_CONFIG_ORDER_BY, + PBX_CONFIG_ORDER_DIRECTION, + setSubscriberSoundSet +} from './pbx-config' import { - assignNumbers, - getNumbers -} from "./user"; + assignNumbers, + getNumbers +} from './user' import { - getSeatsOnly -} from "./pbx-seats"; + getSeatsOnly +} from './pbx-seats' -export function getGroups(options) { - return new Promise((resolve, reject)=>{ - let result = { - subscribers: { - items: [] - }, - preferences: { - items: [] - }, - soundSets: { - items: [] - } - }; - options = options || {}; - options = _.merge(options, { - params: { - is_pbx_group: 1, - is_pbx_pilot: 0 - } - }); - Promise.resolve().then(()=>{ - return Promise.all([ - getFullSubscribers(options), - getAllSoundSets() - ]); - }).then(($result)=> { - result.groups = $result[0].subscribers; - result.preferences.items = $result[0].preferences; - result.soundSets = $result[1]; - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); +export function getGroups (options) { + return new Promise((resolve, reject) => { + const result = { + subscribers: { + items: [] + }, + preferences: { + items: [] + }, + soundSets: { + items: [] + } + } + options = options || {} + options = _.merge(options, { + params: { + is_pbx_group: 1, + is_pbx_pilot: 0 + } + }) + Promise.resolve().then(() => { + return Promise.all([ + getFullSubscribers(options), + getAllSoundSets() + ]) + }).then(($result) => { + result.groups = $result[0].subscribers + result.preferences.items = $result[0].preferences + result.soundSets = $result[1] + resolve(result) + }).catch((err) => { + reject(err) + }) + }) } -export function getGroupsOnly(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - params: { - is_pbx_group: 1, - is_pbx_pilot: 0 - } - }); - Promise.resolve().then(()=>{ - return getSubscribers(options); - }).then((result)=> { - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); +export function getGroupsOnly (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + params: { + is_pbx_group: 1, + is_pbx_pilot: 0 + } + }) + Promise.resolve().then(() => { + return getSubscribers(options) + }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) } -export function getGroupList(options) { - return new Promise((resolve, reject)=>{ - let page = _.get(options, 'page', 1); - Promise.all([ - getGroups({ - params: { - page: page, - order_by: PBX_CONFIG_ORDER_BY, - order_by_direction: PBX_CONFIG_ORDER_DIRECTION - } - }), - getSeatsOnly({ - all: true - }), - getPilot(), - getNumbers() - ]).then((result)=>{ - resolve({ - groups: result[0].groups, - preferences: result[0].preferences, - soundSets: result[0].soundSets, - seats: result[1], - pilot: result[2], - numbers: result[3] - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function getGroupList (options) { + return new Promise((resolve, reject) => { + const page = _.get(options, 'page', 1) + Promise.all([ + getGroups({ + params: { + page: page, + order_by: PBX_CONFIG_ORDER_BY, + order_by_direction: PBX_CONFIG_ORDER_DIRECTION + } + }), + getSeatsOnly({ + all: true + }), + getPilot(), + getNumbers() + ]).then((result) => { + resolve({ + groups: result[0].groups, + preferences: result[0].preferences, + soundSets: result[0].soundSets, + seats: result[1], + pilot: result[2], + numbers: result[3] + }) + }).catch((err) => { + reject(err) + }) + }) } -export function createGroup(group) { - return new Promise((resolve, reject)=>{ - let subscriberId; - Promise.resolve().then(()=>{ - return createSubscriber({ - username: _.kebabCase(group.name), - password: createId(), - is_pbx_group: true, - display_name: group.name, - pbx_extension: group.extension, - pbx_hunt_policy: group.huntPolicy, - pbx_hunt_timeout: group.huntTimeout, - pbx_groupmember_ids: group.seats - }); - }).then(($subscriberId)=>{ - subscriberId = $subscriberId; - if(group.soundSet !== null && group.soundSet !== void(0)) { - return getSoundSet(group.soundSet); - } - else { - return Promise.resolve(null); - } - }).then((soundSet)=>{ - let promises = [ - assignNumbers(group.aliasNumbers, subscriberId) - ]; - if(soundSet !== null) { - promises.push(setSubscriberSoundSet(subscriberId, soundSet.name)); - } - return Promise.all(promises); - }).then(()=>{ - resolve(subscriberId); - }).catch((err)=>{ - reject(err); - }); - }); +export function createGroup (group) { + return new Promise((resolve, reject) => { + let subscriberId + Promise.resolve().then(() => { + return createSubscriber({ + username: _.kebabCase(group.name), + password: createId(), + is_pbx_group: true, + display_name: group.name, + pbx_extension: group.extension, + pbx_hunt_policy: group.huntPolicy, + pbx_hunt_timeout: group.huntTimeout, + pbx_groupmember_ids: group.seats + }) + }).then(($subscriberId) => { + subscriberId = $subscriberId + if (group.soundSet !== null && group.soundSet !== undefined) { + return getSoundSet(group.soundSet) + } else { + return Promise.resolve(null) + } + }).then((soundSet) => { + const promises = [ + assignNumbers(group.aliasNumbers, subscriberId) + ] + if (soundSet !== null) { + promises.push(setSubscriberSoundSet(subscriberId, soundSet.name)) + } + return Promise.all(promises) + }).then(() => { + resolve(subscriberId) + }).catch((err) => { + reject(err) + }) + }) } -export function removeGroup(id) { - return deleteSubscriber(id); +export function removeGroup (id) { + return deleteSubscriber(id) } -export function setGroupName(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setDisplayName(options.groupId, options.groupName); - }).then(()=>{ - return getSubscriberAndPreferences(options.groupId); - }).then((result)=>{ - resolve({ - group: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setGroupName (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setDisplayName(options.groupId, options.groupName) + }).then(() => { + return getSubscriberAndPreferences(options.groupId) + }).then((result) => { + resolve({ + group: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } -export function setGroupExtension(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setPbxExtension(options.groupId, options.groupExtension); - }).then(()=>{ - return getSubscriberAndPreferences(options.groupId); - }).then((result)=>{ - resolve({ - group: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setGroupExtension (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setPbxExtension(options.groupId, options.groupExtension) + }).then(() => { + return getSubscriberAndPreferences(options.groupId) + }).then((result) => { + resolve({ + group: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } -export function setGroupHuntPolicy(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setPbxHuntPolicy(options.groupId, options.groupHuntPolicy); - }).then(()=>{ - return getSubscriberAndPreferences(options.groupId); - }).then((result)=>{ - resolve({ - group: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setGroupHuntPolicy (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setPbxHuntPolicy(options.groupId, options.groupHuntPolicy) + }).then(() => { + return getSubscriberAndPreferences(options.groupId) + }).then((result) => { + resolve({ + group: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } -export function setGroupHuntTimeout(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setPbxHuntTimeout(options.groupId, options.groupHuntTimeout); - }).then(()=>{ - return getSubscriberAndPreferences(options.groupId); - }).then((result)=>{ - resolve({ - group: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setGroupHuntTimeout (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setPbxHuntTimeout(options.groupId, options.groupHuntTimeout) + }).then(() => { + return getSubscriberAndPreferences(options.groupId) + }).then((result) => { + resolve({ + group: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } -export function setGroupNumbers(options) { - return new Promise((resolve, reject)=>{ - setSubscriberNumbers({ - subscriberId: options.groupId, - pilotId: options.pilotId, - assignedNumbers: options.assignedNumbers, - unassignedNumbers: options.unassignedNumbers - }).then((result)=>{ - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); +export function setGroupNumbers (options) { + return new Promise((resolve, reject) => { + setSubscriberNumbers({ + subscriberId: options.groupId, + pilotId: options.pilotId, + assignedNumbers: options.assignedNumbers, + unassignedNumbers: options.unassignedNumbers + }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) } -export function setGroupSeats(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setPbxGroupMemberIds(options.groupId, options.seatIds); - }).then(()=>{ - return getSubscriberAndPreferences(options.groupId); - }).then((result)=>{ - resolve({ - group: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setGroupSeats (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setPbxGroupMemberIds(options.groupId, options.seatIds) + }).then(() => { + return getSubscriberAndPreferences(options.groupId) + }).then((result) => { + resolve({ + group: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } -export function setGroupSoundSet(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - if(options.soundSetId !== null && options.soundSetId !== void(0)) { - return getSoundSet(options.soundSetId); - } - else { - return Promise.resolve(null); - } - }).then((soundSet)=>{ - let soundSetName = _.get(soundSet, 'name', null); - return setSubscriberSoundSet(options.groupId, soundSetName); - }).then(()=>{ - return getSubscriberAndPreferences(options.groupId); - }).then((result)=>{ - resolve({ - group: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setGroupSoundSet (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + if (options.soundSetId !== null && options.soundSetId !== undefined) { + return getSoundSet(options.soundSetId) + } else { + return Promise.resolve(null) + } + }).then((soundSet) => { + const soundSetName = _.get(soundSet, 'name', null) + return setSubscriberSoundSet(options.groupId, soundSetName) + }).then(() => { + return getSubscriberAndPreferences(options.groupId) + }).then((result) => { + resolve({ + group: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/pbx-ms-configs.js b/src/api/pbx-ms-configs.js index 4fe436e6..9f29a071 100644 --- a/src/api/pbx-ms-configs.js +++ b/src/api/pbx-ms-configs.js @@ -1,95 +1,94 @@ -import _ from 'lodash'; +import _ from 'lodash' import { - addPreference, - addPreferenceFull, - getAllPreferences, - getSubscriber, -} from "./subscriber"; + addPreference, + addPreferenceFull, + getAllPreferences, + getSubscriber +} from './subscriber' -export function getMsConfigs() { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getAllPreferences({ - all: true - }); - }).then((preferencesList)=>{ - resolve({ - items: _.get(preferencesList, 'items', []).filter((preferences)=>{ - return _.get(preferences, 'manager_secretary', false) - }) - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function getMsConfigs () { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getAllPreferences({ + all: true + }) + }).then((preferencesList) => { + resolve({ + items: _.get(preferencesList, 'items', []).filter((preferences) => { + return _.get(preferences, 'manager_secretary', false) + }) + }) + }).catch((err) => { + reject(err) + }) + }) } -export function getMsConfigList() { - return new Promise((resolve, reject)=>{ - let msConfigs = []; - Promise.resolve().then(()=>{ - return getMsConfigs(); - }).then(($msConfigs)=>{ - msConfigs = $msConfigs; - let subscriberPromises = []; - msConfigs.items.forEach((msConfig)=>{ - subscriberPromises.push(getSubscriber(msConfig.id)); - }); - return Promise.all(subscriberPromises); - }).then((subscribers)=>{ - resolve({ - subscribers: { - items: subscribers - }, - msConfigs: msConfigs - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function getMsConfigList () { + return new Promise((resolve, reject) => { + let msConfigs = [] + Promise.resolve().then(() => { + return getMsConfigs() + }).then(($msConfigs) => { + msConfigs = $msConfigs + const subscriberPromises = [] + msConfigs.items.forEach((msConfig) => { + subscriberPromises.push(getSubscriber(msConfig.id)) + }) + return Promise.all(subscriberPromises) + }).then((subscribers) => { + resolve({ + subscribers: { + items: subscribers + }, + msConfigs: msConfigs + }) + }).catch((err) => { + reject(err) + }) + }) } -export function createMsConfig(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return Promise.all([ - addPreference(options.subscriberId, 'manager_secretary', true), - addPreference(options.subscriberId, 'secretary_numbers', options.secretaryNumbers) - ]); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function createMsConfig (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return Promise.all([ + addPreference(options.subscriberId, 'manager_secretary', true), + addPreference(options.subscriberId, 'secretary_numbers', options.secretaryNumbers) + ]) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function removeMsConfig(subscriberId) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return Promise.all([ - addPreference(subscriberId, 'manager_secretary', false), - addPreference(subscriberId, 'secretary_numbers', []) - ]); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function removeMsConfig (subscriberId) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return Promise.all([ + addPreference(subscriberId, 'manager_secretary', false), + addPreference(subscriberId, 'secretary_numbers', []) + ]) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function setSecretaryNumber(options) { - return new Promise((resolve, reject)=>{ - let numbers = _.get(options, 'secretaryNumbers', []); - Promise.resolve().then(()=>{ - return addPreferenceFull(options.msConfigId, 'secretary_numbers', numbers); - }).then((prefs)=>{ - resolve(prefs); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSecretaryNumber (options) { + return new Promise((resolve, reject) => { + const numbers = _.get(options, 'secretaryNumbers', []) + Promise.resolve().then(() => { + return addPreferenceFull(options.msConfigId, 'secretary_numbers', numbers) + }).then((prefs) => { + resolve(prefs) + }).catch((err) => { + reject(err) + }) + }) } - diff --git a/src/api/pbx-seats.js b/src/api/pbx-seats.js index 70d7db6b..aa30fcac 100644 --- a/src/api/pbx-seats.js +++ b/src/api/pbx-seats.js @@ -1,156 +1,155 @@ import { - createSubscriber, - deleteSubscriber, - getFullSubscribers, - getSubscriberAndPreferences, getSubscribers, - setDisplayName, - setPbxExtension, - setPbxWebPassword, - setPbxGroupIds, - setSubscriberNumbers, - setPreferenceIntraPbx, - getPreferences -} from "./subscriber"; -import _ from "lodash"; + createSubscriber, + deleteSubscriber, + getFullSubscribers, + getSubscriberAndPreferences, getSubscribers, + setDisplayName, + setPbxExtension, + setPbxWebPassword, + setPbxGroupIds, + setSubscriberNumbers, + setPreferenceIntraPbx, + getPreferences +} from './subscriber' +import _ from 'lodash' import { - getAllSoundSets, - getPilot, - getSoundSet, - createId, - PBX_CONFIG_ORDER_BY, - PBX_CONFIG_ORDER_DIRECTION, - setSubscriberSoundSet -} from "./pbx-config"; + getAllSoundSets, + getPilot, + getSoundSet, + createId, + PBX_CONFIG_ORDER_BY, + PBX_CONFIG_ORDER_DIRECTION, + setSubscriberSoundSet +} from './pbx-config' import { - assignNumbers, - getNumbers -} from "./user"; + assignNumbers, + getNumbers +} from './user' import { - getGroupsOnly -} from "./pbx-groups"; + getGroupsOnly +} from './pbx-groups' -export function getSeats(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - params: { - is_pbx_group: 0, - is_pbx_pilot: 0 - } - }); - Promise.resolve().then(()=>{ - return Promise.all([ - getFullSubscribers(options), - getAllSoundSets() - ]); - }).then((result)=> { - resolve({ - subscribers: result[0].subscribers, - preferences: { - items: result[0].preferences - }, - soundSets: result[1] - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function getSeats (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + params: { + is_pbx_group: 0, + is_pbx_pilot: 0 + } + }) + Promise.resolve().then(() => { + return Promise.all([ + getFullSubscribers(options), + getAllSoundSets() + ]) + }).then((result) => { + resolve({ + subscribers: result[0].subscribers, + preferences: { + items: result[0].preferences + }, + soundSets: result[1] + }) + }).catch((err) => { + reject(err) + }) + }) } -export function getSeatsOnly(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - params: { - is_pbx_group: 0, - is_pbx_pilot: 0 - } - }); - Promise.resolve().then(()=>{ - return getSubscribers(options); - }).then((result)=> { - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); +export function getSeatsOnly (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + params: { + is_pbx_group: 0, + is_pbx_pilot: 0 + } + }) + Promise.resolve().then(() => { + return getSubscribers(options) + }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) } -export function getSeatList(options) { - return new Promise((resolve, reject)=>{ - let page = _.get(options, 'page', 1); - let display_name = _.get(options, 'display_name', null); - let params = { - page: page, - order_by: PBX_CONFIG_ORDER_BY, - order_by_direction: PBX_CONFIG_ORDER_DIRECTION - } - Promise.all([ - getSeats({ - params: display_name ? _.merge({ - display_name: display_name - }, params) : params - }), - getGroupsOnly({ - all: true - }), - getPilot(), - getNumbers() - ]).then((result) => { - resolve({ - seats: result[0].subscribers, - preferences: result[0].preferences, - soundSets: result[0].soundSets, - groups: result[1], - pilot: result[2], - numbers: result[3] - }); - }).catch((err) => { - reject(err); - }); - }); +export function getSeatList (options) { + return new Promise((resolve, reject) => { + const page = _.get(options, 'page', 1) + const displayName = _.get(options, 'display_name', null) + const params = { + page: page, + order_by: PBX_CONFIG_ORDER_BY, + order_by_direction: PBX_CONFIG_ORDER_DIRECTION + } + Promise.all([ + getSeats({ + params: displayName ? _.merge({ + display_name: displayName + }, params) : params + }), + getGroupsOnly({ + all: true + }), + getPilot(), + getNumbers() + ]).then((result) => { + resolve({ + seats: result[0].subscribers, + preferences: result[0].preferences, + soundSets: result[0].soundSets, + groups: result[1], + pilot: result[2], + numbers: result[3] + }) + }).catch((err) => { + reject(err) + }) + }) } -export function createSeat(seat) { - return new Promise((resolve, reject)=>{ - let subscriberId; - Promise.resolve().then(()=>{ - return createSubscriber({ - username: _.kebabCase(seat.name), - password: createId(), - display_name: seat.name, - webpassword: seat.webPassword.length > 0 ? seat.webPassword : null, - is_pbx_group: false, - pbx_extension: seat.extension, - pbx_group_ids: seat.groups - }); - }).then(($subscriberId)=>{ - subscriberId = $subscriberId; - setSeatIntraPbx(subscriberId, seat.clirIntrapbx); - if(seat.soundSet !== null && seat.soundSet !== void(0)) { - return getSoundSet(seat.soundSet); - } - else { - return Promise.resolve(null); - } - }).then((soundSet)=>{ - let promises = [ - assignNumbers(seat.aliasNumbers, subscriberId) - ]; - if(soundSet !== null) { - promises.push(setSubscriberSoundSet(subscriberId, soundSet.name)); - } - return Promise.all(promises); - }).then(()=>{ - resolve(subscriberId); - }).catch((err)=>{ - reject(err); - }); - }); +export function createSeat (seat) { + return new Promise((resolve, reject) => { + let subscriberId + Promise.resolve().then(() => { + return createSubscriber({ + username: _.kebabCase(seat.name), + password: createId(), + display_name: seat.name, + webpassword: seat.webPassword.length > 0 ? seat.webPassword : null, + is_pbx_group: false, + pbx_extension: seat.extension, + pbx_group_ids: seat.groups + }) + }).then(($subscriberId) => { + subscriberId = $subscriberId + setSeatIntraPbx(subscriberId, seat.clirIntrapbx) + if (seat.soundSet !== null && seat.soundSet !== undefined) { + return getSoundSet(seat.soundSet) + } else { + return Promise.resolve(null) + } + }).then((soundSet) => { + const promises = [ + assignNumbers(seat.aliasNumbers, subscriberId) + ] + if (soundSet !== null) { + promises.push(setSubscriberSoundSet(subscriberId, soundSet.name)) + } + return Promise.all(promises) + }).then(() => { + resolve(subscriberId) + }).catch((err) => { + reject(err) + }) + }) } -export function removeSeat(id) { - return deleteSubscriber(id); +export function removeSeat (id) { + return deleteSubscriber(id) } /** @@ -158,21 +157,21 @@ export function removeSeat(id) { * @param options.seatId * @param options.seatName */ -export function setSeatName(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setDisplayName(options.seatId, options.seatName); - }).then(()=>{ - return getSubscriberAndPreferences(options.seatId); - }).then((result)=>{ - resolve({ - seat: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSeatName (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setDisplayName(options.seatId, options.seatName) + }).then(() => { + return getSubscriberAndPreferences(options.seatId) + }).then((result) => { + resolve({ + seat: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } /** @@ -180,21 +179,21 @@ export function setSeatName(options) { * @param options.seatId * @param options.seatExtension */ -export function setSeatExtension(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setPbxExtension(options.seatId, options.seatExtension); - }).then(()=>{ - return getSubscriberAndPreferences(options.seatId); - }).then((result)=>{ - resolve({ - seat: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSeatExtension (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setPbxExtension(options.seatId, options.seatExtension) + }).then(() => { + return getSubscriberAndPreferences(options.seatId) + }).then((result) => { + resolve({ + seat: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } /** @@ -202,29 +201,29 @@ export function setSeatExtension(options) { * @param options.seatId * @param options.seatWebPassword */ -export function setSeatWebPassword(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setPbxWebPassword(options.seatId, options.seatWebPassword); - }).then(()=>{ - return getSubscriberAndPreferences(options.seatId); - }).then((result)=>{ - resolve({ - seat: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSeatWebPassword (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setPbxWebPassword(options.seatId, options.seatWebPassword) + }).then(() => { + return getSubscriberAndPreferences(options.seatId) + }).then((result) => { + resolve({ + seat: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } /** * @param seatId * @param clirIntrapbx */ -export function setSeatIntraPbx(seatId, clirIntrapbx) { - return setPreferenceIntraPbx(seatId, clirIntrapbx); +export function setSeatIntraPbx (seatId, clirIntrapbx) { + return setPreferenceIntraPbx(seatId, clirIntrapbx) } /** @@ -232,21 +231,21 @@ export function setSeatIntraPbx(seatId, clirIntrapbx) { * @param options.seatId * @param options.groupIds */ -export function setSeatGroups(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return setPbxGroupIds(options.seatId, options.groupIds); - }).then(()=>{ - return getSubscriberAndPreferences(options.seatId); - }).then((result)=>{ - resolve({ - seat: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSeatGroups (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return setPbxGroupIds(options.seatId, options.groupIds) + }).then(() => { + return getSubscriberAndPreferences(options.seatId) + }).then((result) => { + resolve({ + seat: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } /** @@ -257,19 +256,19 @@ export function setSeatGroups(options) { * @param options.unassignedNumbers * @return {Promise} */ -export function setSeatNumbers(options) { - return new Promise((resolve, reject)=>{ - setSubscriberNumbers({ - subscriberId: options.seatId, - pilotId: options.pilotId, - assignedNumbers: options.assignedNumbers, - unassignedNumbers: options.unassignedNumbers - }).then((result)=>{ - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSeatNumbers (options) { + return new Promise((resolve, reject) => { + setSubscriberNumbers({ + subscriberId: options.seatId, + pilotId: options.pilotId, + assignedNumbers: options.assignedNumbers, + unassignedNumbers: options.unassignedNumbers + }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) } /** @@ -277,39 +276,37 @@ export function setSeatNumbers(options) { * @param options.seatId * @param options.soundSetId */ -export function setSeatSoundSet(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - if(options.soundSetId !== null && options.soundSetId !== void(0)) { - return getSoundSet(options.soundSetId); - } - else { - return Promise.resolve(null); - } - }).then((soundSet)=>{ - let soundSetName = _.get(soundSet, 'name', null); - return setSubscriberSoundSet(options.seatId, soundSetName); - }).then(()=>{ - return getSubscriberAndPreferences(options.seatId); - }).then((result)=>{ - resolve({ - seat: result.subscriber, - preferences: result.preferences - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function setSeatSoundSet (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + if (options.soundSetId !== null && options.soundSetId !== undefined) { + return getSoundSet(options.soundSetId) + } else { + return Promise.resolve(null) + } + }).then((soundSet) => { + const soundSetName = _.get(soundSet, 'name', null) + return setSubscriberSoundSet(options.seatId, soundSetName) + }).then(() => { + return getSubscriberAndPreferences(options.seatId) + }).then((result) => { + resolve({ + seat: result.subscriber, + preferences: result.preferences + }) + }).catch((err) => { + reject(err) + }) + }) } /** * @param seatId */ -export async function getSeatPreferences(seatId) { - try { - return await getPreferences(seatId); - } - catch(err){ - return err; - } +export async function getSeatPreferences (seatId) { + try { + return await getPreferences(seatId) + } catch (err) { + return err + } } diff --git a/src/api/pbx-soundsets.js b/src/api/pbx-soundsets.js index 92e1ab60..f96d86ec 100644 --- a/src/api/pbx-soundsets.js +++ b/src/api/pbx-soundsets.js @@ -1,229 +1,228 @@ -import _ from "lodash"; +import _ from 'lodash' import { - getList, - patchReplaceFull, - getAsBlob, - get -} from "./common"; + getList, + patchReplaceFull, + getAsBlob, + get +} from './common' import { - PBX_CONFIG_ORDER_BY, - PBX_CONFIG_ORDER_DIRECTION -} from "./pbx-config"; -import Vue from "vue"; + PBX_CONFIG_ORDER_BY, + PBX_CONFIG_ORDER_DIRECTION +} from './pbx-config' +import Vue from 'vue' import { - Platform -} from 'quasar-framework' - -export function getSoundSets(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/soundsets/', - root: '_embedded.ngcp:soundsets' - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getSoundSetList(options) { - return new Promise((resolve, reject)=>{ - let params = { - page: options.page, - order_by: PBX_CONFIG_ORDER_BY, - order_by_direction: PBX_CONFIG_ORDER_DIRECTION - }; - getSoundSets({ - params: params - }).then((soundSets)=>{ - resolve({ - soundSets: soundSets - }); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function createSoundSet(soundSet) { - return new Promise((resolve, reject)=>{ - Vue.http.post('api/soundsets/', soundSet).then(() => { - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function removeSoundSet(soundSetId) { - return new Promise((resolve, reject)=>{ - Vue.http.delete('api/soundsets/' + soundSetId).then(()=>{ - resolve(); - }).catch((err)=>{ - if (err.status >= 400) { - reject(new Error(err.body.message)); - } - else { - reject(err); - } - }); - }); -} - -export function setSoundSetProperty(soundSetId, property, value) { - return new Promise((resolve, reject)=>{ - patchReplaceFull({ - path: 'api/soundsets/' + soundSetId, - fieldPath: property, - value: value - }).then((soundSet)=>{ - resolve(soundSet); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function setAsDefault(soundSetId) { - return setSoundSetProperty(soundSetId, 'contract_default', true); -} - -export function unsetAsDefault(soundSetId) { - return setSoundSetProperty(soundSetId, 'contract_default', false); -} - -export function setSoundSetName(soundSetId, name) { - return setSoundSetProperty(soundSetId, 'name', name); -} - -export function setSoundSetDescription(soundSetId, description) { - return setSoundSetProperty(soundSetId, 'description', description); -} - -export function getSoundHandles(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/soundhandles/', - root: '_embedded.ngcp:soundhandles' - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getAllSoundHandles(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - all: true - }); - getSoundHandles(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getSoundFiles(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/soundfiles/', - root: '_embedded.ngcp:soundfiles', - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getAllSoundFilesBySoundSetId(soundSetId) { - return new Promise((resolve, reject)=>{ - getSoundFiles({ - all: true, - params: { - set_id: soundSetId - } - }).then((soundFiles)=>{ - resolve(soundFiles); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getSoundFile(options) { - return new Promise((resolve, reject)=>{ - getAsBlob({ - path: 'api/soundfilerecordings/' + options.id, - params: { - format: Platform.mozilla ? 'ogg' : 'mp3' - } - }).then((result)=>{ - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function uploadSoundFile(options) { - return new Promise((resolve, reject)=>{ - let formData = new FormData(); - formData.append('json', JSON.stringify({ - loopplay: true, - filename: options.soundFileData.name, - set_id: options.soundSetId, - handle: options.soundHandle, - })); - formData.append('soundfile', options.soundFileData); - Vue.http.post('api/soundfiles/', formData, { - before(request) { - options.initialized(request); - }, - progress(progressEvent) { - if (progressEvent.lengthComputable) { - options.progressed(Math.ceil((progressEvent.loaded / progressEvent.total) * 100)); - } - } - }).then((res) => { - let fileId = _.last(res.headers.get('location').split(/\//)); - return Promise.all([ - get({ path: 'api/soundfiles/' + fileId }), - getSoundFile({ id: fileId }) - ]); - }).then((res)=>{ - resolve({ - soundFile: res[0], - soundFileUrl: res[1] - }); - }).catch((err) => { - reject(err); - }); - }); -} - -export function setLoopPlay(options) { - return new Promise((resolve, reject)=>{ - console.log(options); - patchReplaceFull({ - path: 'api/soundfiles/' + options.soundFileId, - fieldPath: 'loopplay', - value: (options.loopPlay === true)? 'true' : 'false' - }).then((soundFile)=>{ - resolve(soundFile); - }).catch((err)=>{ - reject(err); - }); - }); + Platform +} from 'quasar' + +export function getSoundSets (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/soundsets/', + root: '_embedded.ngcp:soundsets' + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSoundSetList (options) { + return new Promise((resolve, reject) => { + const params = { + page: options.page, + order_by: PBX_CONFIG_ORDER_BY, + order_by_direction: PBX_CONFIG_ORDER_DIRECTION + } + getSoundSets({ + params: params + }).then((soundSets) => { + resolve({ + soundSets: soundSets + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function createSoundSet (soundSet) { + return new Promise((resolve, reject) => { + Vue.http.post('api/soundsets/', soundSet).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function removeSoundSet (soundSetId) { + return new Promise((resolve, reject) => { + Vue.http.delete('api/soundsets/' + soundSetId).then(() => { + resolve() + }).catch((err) => { + if (err.status >= 400) { + reject(new Error(err.body.message)) + } else { + reject(err) + } + }) + }) +} + +export function setSoundSetProperty (soundSetId, property, value) { + return new Promise((resolve, reject) => { + patchReplaceFull({ + path: 'api/soundsets/' + soundSetId, + fieldPath: property, + value: value + }).then((soundSet) => { + resolve(soundSet) + }).catch((err) => { + reject(err) + }) + }) +} + +export function setAsDefault (soundSetId) { + return setSoundSetProperty(soundSetId, 'contract_default', true) +} + +export function unsetAsDefault (soundSetId) { + return setSoundSetProperty(soundSetId, 'contract_default', false) +} + +export function setSoundSetName (soundSetId, name) { + return setSoundSetProperty(soundSetId, 'name', name) +} + +export function setSoundSetDescription (soundSetId, description) { + return setSoundSetProperty(soundSetId, 'description', description) +} + +export function getSoundHandles (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/soundhandles/', + root: '_embedded.ngcp:soundhandles' + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getAllSoundHandles (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + all: true + }) + getSoundHandles(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSoundFiles (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/soundfiles/', + root: '_embedded.ngcp:soundfiles' + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getAllSoundFilesBySoundSetId (soundSetId) { + return new Promise((resolve, reject) => { + getSoundFiles({ + all: true, + params: { + set_id: soundSetId + } + }).then((soundFiles) => { + resolve(soundFiles) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSoundFile (options) { + return new Promise((resolve, reject) => { + getAsBlob({ + path: 'api/soundfilerecordings/' + options.id, + params: { + format: Platform.mozilla ? 'ogg' : 'mp3' + } + }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) +} + +export function uploadSoundFile (options) { + return new Promise((resolve, reject) => { + const formData = new FormData() + formData.append('json', JSON.stringify({ + loopplay: true, + filename: options.soundFileData.name, + set_id: options.soundSetId, + handle: options.soundHandle + })) + formData.append('soundfile', options.soundFileData) + Vue.http.post('api/soundfiles/', formData, { + before (request) { + options.initialized(request) + }, + progress (progressEvent) { + if (progressEvent.lengthComputable) { + options.progressed(Math.ceil((progressEvent.loaded / progressEvent.total) * 100)) + } + } + }).then((res) => { + const fileId = _.last(res.headers.get('location').split(/\//)) + return Promise.all([ + get({ path: 'api/soundfiles/' + fileId }), + getSoundFile({ id: fileId }) + ]) + }).then((res) => { + resolve({ + soundFile: res[0], + soundFileUrl: res[1] + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function setLoopPlay (options) { + return new Promise((resolve, reject) => { + console.log(options) + patchReplaceFull({ + path: 'api/soundfiles/' + options.soundFileId, + fieldPath: 'loopplay', + value: (options.loopPlay === true) ? 'true' : 'false' + }).then((soundFile) => { + resolve(soundFile) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/reminder.js b/src/api/reminder.js index 39c6b79e..b0140da8 100644 --- a/src/api/reminder.js +++ b/src/api/reminder.js @@ -2,97 +2,96 @@ import _ from 'lodash' import Vue from 'vue' import { - getList, - patchReplace + getList, + patchReplace } from './common' -export function createReminder(subscriberId) { - return new Promise((resolve, reject) => { - Vue.http.post('api/reminders/', { - subscriber_id: subscriberId, - time: '00:00', - recur: 'never', - active: false - }).then((result) => { - let parts = result.headers.get('Location').split('/'); - resolve(_.last(parts)); - }).catch((err) => { - reject(err); - }); - }); +export function createReminder (subscriberId) { + return new Promise((resolve, reject) => { + Vue.http.post('api/reminders/', { + subscriber_id: subscriberId, + time: '00:00', + recur: 'never', + active: false + }).then((result) => { + const parts = result.headers.get('Location').split('/') + resolve(_.last(parts)) + }).catch((err) => { + reject(err) + }) + }) } -export function getFirstReminder(subscriberId) { - return new Promise((resolve, reject) => { - getList({ - path: 'api/reminders/', - root: '_embedded.ngcp:reminders', - params: { - page: 1, - rows: 1, - subscriber_id: subscriberId - } - }).then((reminders)=>{ - resolve(_.get(reminders, 'items.0', null)); - }).catch((err)=>{ - reject(err); - }); - }); +export function getFirstReminder (subscriberId) { + return new Promise((resolve, reject) => { + getList({ + path: 'api/reminders/', + root: '_embedded.ngcp:reminders', + params: { + page: 1, + rows: 1, + subscriber_id: subscriberId + } + }).then((reminders) => { + resolve(_.get(reminders, 'items.0', null)) + }).catch((err) => { + reject(err) + }) + }) } -export function getReminder(subscriberId) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getFirstReminder(subscriberId); - }).then((reminder)=>{ - if(reminder === null) { - return createAndGetReminder(subscriberId); - } - else { - return Promise.resolve(reminder); - } - }).then((reminder)=>{ - resolve(reminder); - }).catch((err)=>{ - reject(err); - }); - }); +export function getReminder (subscriberId) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getFirstReminder(subscriberId) + }).then((reminder) => { + if (reminder === null) { + return createAndGetReminder(subscriberId) + } else { + return Promise.resolve(reminder) + } + }).then((reminder) => { + resolve(reminder) + }).catch((err) => { + reject(err) + }) + }) } -export function createAndGetReminder(subscriberId) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return createReminder(subscriberId); - }).then(()=>{ - return getFirstReminder(subscriberId); - }).then((reminder)=>{ - resolve(reminder); - }).catch((err)=>{ - reject(err); - }); - }); +export function createAndGetReminder (subscriberId) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return createReminder(subscriberId) + }).then(() => { + return getFirstReminder(subscriberId) + }).then((reminder) => { + resolve(reminder) + }).catch((err) => { + reject(err) + }) + }) } -export function setReminderActive(reminderId, active) { - return patchReplace({ - path: 'api/reminders/' + reminderId, - fieldPath: 'active', - value: active - }); +export function setReminderActive (reminderId, active) { + return patchReplace({ + path: 'api/reminders/' + reminderId, + fieldPath: 'active', + value: active + }) } -export function setReminderTime(reminderId, time) { - return patchReplace({ - path: 'api/reminders/' + reminderId, - fieldPath: 'time', - value: time - }); +export function setReminderTime (reminderId, time) { + return patchReplace({ + path: 'api/reminders/' + reminderId, + fieldPath: 'time', + value: time + }) } -export function setReminderRecurrence(reminderId, reccurence) { - return patchReplace({ - path: 'api/reminders/' + reminderId, - fieldPath: 'recur', - value: reccurence - }); +export function setReminderRecurrence (reminderId, reccurence) { + return patchReplace({ + path: 'api/reminders/' + reminderId, + fieldPath: 'recur', + value: reccurence + }) } diff --git a/src/api/rtcsession.js b/src/api/rtcsession.js index 6bac6da2..6a20d9e0 100644 --- a/src/api/rtcsession.js +++ b/src/api/rtcsession.js @@ -1,48 +1,48 @@ import config from '../config' -import Vue from 'vue'; -import { getJsonBody } from './utils'; +import Vue from 'vue' +import { getJsonBody } from './utils' -export function create() { - return new Promise((resolve, reject)=>{ - Vue.http.post('api/rtcsessions/').then((res)=>{ - resolve(res); - }).catch((err)=>{ - reject(err); - }); - }); +export function create () { + return new Promise((resolve, reject) => { + Vue.http.post('api/rtcsessions/').then((res) => { + resolve(res) + }).catch((err) => { + reject(err) + }) + }) } -export function getByUrl(url) { - return new Promise((resolve, reject)=>{ - Vue.http.get(url).then((res)=>{ - resolve(getJsonBody(res.body)); - }).catch((err)=>{ - reject(err); - }); - }); +export function getByUrl (url) { + return new Promise((resolve, reject) => { + Vue.http.get(url).then((res) => { + resolve(getJsonBody(res.body)) + }).catch((err) => { + reject(err) + }) + }) } -export function createSession() { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return create(); - }).then((res)=>{ - return getByUrl(config.baseHttpUrl + res.headers.get('Location')); - }).then((res)=>{ - resolve(res); - }).catch((err)=>{ - reject(err); - }); - }); +export function createSession () { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return create() + }).then((res) => { + return getByUrl(config.baseHttpUrl + res.headers.get('Location')) + }).then((res) => { + resolve(res) + }).catch((err) => { + reject(err) + }) + }) } -export function createSessionToken() { - return new Promise((resolve, reject)=>{ - createSession().then((res)=>{ - resolve(res.rtc_browser_token); - }).catch((err)=>{ - reject(err); - }); - }); +export function createSessionToken () { + return new Promise((resolve, reject) => { + createSession().then((res) => { + resolve(res.rtc_browser_token) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/speed-dial.js b/src/api/speed-dial.js index 9e3e7ddf..47720b50 100644 --- a/src/api/speed-dial.js +++ b/src/api/speed-dial.js @@ -1,92 +1,92 @@ import _ from 'lodash' -import Vue from 'vue'; -import { i18n } from '../i18n'; +import Vue from 'vue' +import { i18n } from 'src/boot/i18n' import { getFieldList } from './common' -export function getSpeedDialsById(id) { - return new Promise((resolve, reject) => { - getFieldList({ - path: 'api/speeddials/' + id, - field: 'speeddials' - }).then((result) => { - let sortedResult = _.sortBy(result, ['slot']); - resolve(sortedResult); - }).catch((err) => { - reject(err.body.message); - }); - }); +export function getSpeedDialsById (id) { + return new Promise((resolve, reject) => { + getFieldList({ + path: 'api/speeddials/' + id, + field: 'speeddials' + }).then((result) => { + const sortedResult = _.sortBy(result, ['slot']) + resolve(sortedResult) + }).catch((err) => { + reject(err.body.message) + }) + }) } -export function getUnassignedSlots(id) { - return new Promise((resolve, reject) => { - let slots = ["*0", "*1", "*2", "*3", "*4", "*5", "*6", "*7", "*8", "*9"]; - Promise.resolve().then(() => { - return getSpeedDialsById(id); - }).then((assignedSlots) => { - let unassignedSlots = _.difference(slots, assignedSlots.map((slot) => { - return slot.slot; - })); - let slotOptions = []; - unassignedSlots.forEach((slot) => { - slotOptions.push({ - label: `${i18n.t('speedDial.slot')} ${slot}`, - value: slot - }); - }); - resolve(slotOptions); - }).catch((err) => { - reject(err.body.message); - }); - }); +export function getUnassignedSlots (id) { + return new Promise((resolve, reject) => { + const slots = ['*0', '*1', '*2', '*3', '*4', '*5', '*6', '*7', '*8', '*9'] + Promise.resolve().then(() => { + return getSpeedDialsById(id) + }).then((assignedSlots) => { + const unassignedSlots = _.difference(slots, assignedSlots.map((slot) => { + return slot.slot + })) + const slotOptions = [] + unassignedSlots.forEach((slot) => { + slotOptions.push({ + label: `${i18n.t('speedDial.slot')} ${slot}`, + value: slot + }) + }) + resolve(slotOptions) + }).catch((err) => { + reject(err.body.message) + }) + }) } -export function unassignSpeedDialSlot(options) { - return new Promise((resolve, reject) => { - let updatedAssignedSlots = _.without(options.slots, options.slot); - let headers = { - 'Content-Type': 'application/json-patch+json' - }; - Vue.http.patch('api/speeddials/' + options.id, [{ - op: 'replace', - path: '/speeddials', - value: updatedAssignedSlots - }], { headers: headers }).then(() => { - resolve(); - }).catch((err) => { - reject(err.body.message); - }); - }); +export function unassignSpeedDialSlot (options) { + return new Promise((resolve, reject) => { + const updatedAssignedSlots = _.without(options.slots, options.slot) + const headers = { + 'Content-Type': 'application/json-patch+json' + } + Vue.http.patch('api/speeddials/' + options.id, [{ + op: 'replace', + path: '/speeddials', + value: updatedAssignedSlots + }], { headers: headers }).then(() => { + resolve() + }).catch((err) => { + reject(err.body.message) + }) + }) } -export function addSlotToSpeedDials(options) { - return new Promise((resolve, reject) => { - let headers = { - 'Content-Type': 'application/json-patch+json' - }; - Vue.http.patch('api/speeddials/' + options.id, [{ - op: 'replace', - path: '/speeddials', - value: options.slots - }], { headers: headers }).then(() => { - resolve(); - }).catch((err) => { - reject(err.body.message); - }); - }); +export function addSlotToSpeedDials (options) { + return new Promise((resolve, reject) => { + const headers = { + 'Content-Type': 'application/json-patch+json' + } + Vue.http.patch('api/speeddials/' + options.id, [{ + op: 'replace', + path: '/speeddials', + value: options.slots + }], { headers: headers }).then(() => { + resolve() + }).catch((err) => { + reject(err.body.message) + }) + }) } -export function assignSpeedDialSlot(options) { - return new Promise((resolve, reject) => { - Promise.resolve().then(() => { - return getSpeedDialsById(options.id); - }).then((result) => { - let concatSlots = result.concat(options.slot); - return addSlotToSpeedDials({ id: options.id, slots: concatSlots }); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); +export function assignSpeedDialSlot (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getSpeedDialsById(options.id) + }).then((result) => { + const concatSlots = result.concat(options.slot) + return addSlotToSpeedDials({ id: options.id, slots: concatSlots }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/subscriber.js b/src/api/subscriber.js index c8366ab6..5b7359a1 100644 --- a/src/api/subscriber.js +++ b/src/api/subscriber.js @@ -1,525 +1,519 @@ -import _ from 'lodash'; -import Vue from 'vue'; +import _ from 'lodash' +import Vue from 'vue' import { - getJsonBody + getJsonBody } from './utils' import { - getList, - get, - patchAdd, - patchReplace, - patchReplaceFull, - patchAddFull + getList, + get, + patchAdd, + patchReplace, + patchReplaceFull, + patchAddFull } from './common' import { - assignNumbers -} from "./user"; - -export function getPreferences(id) { - return new Promise((resolve, reject)=>{ - Vue.http.get('api/subscriberpreferences/' + id).then((result)=>{ - resolve(getJsonBody(result.body)); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export async function setPreference(id, field, value) { - try { - await replacePreference(id, field, value); - } - catch(err) { - let errCode = err.status + ""; - if(errCode === '422') { - try { - await addPreference(id, field, value); - } - catch (innerErr) { - throw innerErr; - } - } - } -} - -export function addPreference(id, field, value) { - return new Promise((resolve, reject)=>{ - patchAdd({ - path: 'api/subscriberpreferences/' + id, - fieldPath: field, - value: value - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function addPreferenceFull(id, field, value) { - return new Promise((resolve, reject)=>{ - patchAddFull({ - path: 'api/subscriberpreferences/' + id, - fieldPath: field, - value: value - }).then((preferences)=>{ - resolve(preferences); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function replacePreference(id, field, value) { - return new Promise((resolve, reject)=>{ - patchReplace({ - path: 'api/subscriberpreferences/' + id, - fieldPath: field, - value: value - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function prependItemToArrayPreference(id, field, value) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getPreferences(id); - }).then((result)=>{ - let prefs = _.cloneDeep(result); - delete prefs._links; - prefs[field] = _.get(prefs, field, []); - prefs[field] = [value].concat(prefs[field]); - return Vue.http.put('api/subscriberpreferences/' + id, prefs); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function appendItemToArrayPreference(id, field, value) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getPreferences(id); - }).then((result)=>{ - var prefs = _.cloneDeep(result); - delete prefs._links; - prefs[field] = _.get(prefs, field, []); - prefs[field].push(value); - return Vue.http.put('api/subscriberpreferences/' + id, prefs); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function editItemInArrayPreference(id, field, itemIndex, value) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getPreferences(id); - }).then((result)=>{ - let prefs = _.cloneDeep(result); - delete prefs._links; - if(_.isArray(prefs[field]) && itemIndex < prefs[field].length) { - prefs[field][itemIndex] = value; - return Vue.http.put('api/subscriberpreferences/' + id, prefs); - } - else { - return Promise.reject(new Error('Array index does not exists')); - } - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function removeItemFromArrayPreference(id, field, itemIndex) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return getPreferences(id); - }).then((result)=>{ - let prefs = _.cloneDeep(result); - delete prefs._links; - prefs[field] = _.get(prefs, field, []); - _.remove(prefs[field], (value, index)=>{ - return index === itemIndex; - }); - return Vue.http.put('api/subscriberpreferences/' + id, prefs); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function setBlockInMode(id, value) { - return setPreference(id, 'block_in_mode', value); -} - -export function enableBlockIn(id) { - return setBlockInMode(id, true); -} - -export function disableBlockIn(id) { - return setBlockInMode(id, false); -} - -export function addToBlockInList(id, number) { - return prependItemToArrayPreference(id, 'block_in_list', number); -} - -export function editBlockInList(id, index, number) { - return editItemInArrayPreference(id, 'block_in_list', index, number); -} - -export function removeFromBlockInList(id, index) { - return removeItemFromArrayPreference(id, 'block_in_list', index); -} - -export function setBlockOutMode(id, value) { - return setPreference(id, 'block_out_mode', value); -} - -export function enableBlockOut(id) { - return setBlockOutMode(id, true); + assignNumbers +} from './user' + +export function getPreferences (id) { + return new Promise((resolve, reject) => { + Vue.http.get('api/subscriberpreferences/' + id).then((result) => { + resolve(getJsonBody(result.body)) + }).catch((err) => { + reject(err) + }) + }) +} + +export async function setPreference (id, field, value) { + try { + await replacePreference(id, field, value) + } catch (err) { + const errCode = err.status + '' + if (errCode === '422') { + // eslint-disable-next-line no-useless-catch + try { + await addPreference(id, field, value) + } catch (innerErr) { + throw innerErr + } + } + } +} + +export function addPreference (id, field, value) { + return new Promise((resolve, reject) => { + patchAdd({ + path: 'api/subscriberpreferences/' + id, + fieldPath: field, + value: value + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function addPreferenceFull (id, field, value) { + return new Promise((resolve, reject) => { + patchAddFull({ + path: 'api/subscriberpreferences/' + id, + fieldPath: field, + value: value + }).then((preferences) => { + resolve(preferences) + }).catch((err) => { + reject(err) + }) + }) +} + +export function replacePreference (id, field, value) { + return new Promise((resolve, reject) => { + patchReplace({ + path: 'api/subscriberpreferences/' + id, + fieldPath: field, + value: value + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function prependItemToArrayPreference (id, field, value) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getPreferences(id) + }).then((result) => { + const prefs = _.cloneDeep(result) + delete prefs._links + prefs[field] = _.get(prefs, field, []) + prefs[field] = [value].concat(prefs[field]) + return Vue.http.put('api/subscriberpreferences/' + id, prefs) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function appendItemToArrayPreference (id, field, value) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getPreferences(id) + }).then((result) => { + var prefs = _.cloneDeep(result) + delete prefs._links + prefs[field] = _.get(prefs, field, []) + prefs[field].push(value) + return Vue.http.put('api/subscriberpreferences/' + id, prefs) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function editItemInArrayPreference (id, field, itemIndex, value) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getPreferences(id) + }).then((result) => { + const prefs = _.cloneDeep(result) + delete prefs._links + if (_.isArray(prefs[field]) && itemIndex < prefs[field].length) { + prefs[field][itemIndex] = value + return Vue.http.put('api/subscriberpreferences/' + id, prefs) + } else { + return Promise.reject(new Error('Array index does not exists')) + } + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function removeItemFromArrayPreference (id, field, itemIndex) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return getPreferences(id) + }).then((result) => { + const prefs = _.cloneDeep(result) + delete prefs._links + prefs[field] = _.get(prefs, field, []) + _.remove(prefs[field], (value, index) => { + return index === itemIndex + }) + return Vue.http.put('api/subscriberpreferences/' + id, prefs) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function setBlockInMode (id, value) { + return setPreference(id, 'block_in_mode', value) +} + +export function enableBlockIn (id) { + return setBlockInMode(id, true) +} + +export function disableBlockIn (id) { + return setBlockInMode(id, false) +} + +export function addToBlockInList (id, number) { + return prependItemToArrayPreference(id, 'block_in_list', number) +} + +export function editBlockInList (id, index, number) { + return editItemInArrayPreference(id, 'block_in_list', index, number) +} + +export function removeFromBlockInList (id, index) { + return removeItemFromArrayPreference(id, 'block_in_list', index) +} + +export function setBlockOutMode (id, value) { + return setPreference(id, 'block_out_mode', value) } -export function disableBlockOut(id) { - return setBlockOutMode(id, false); +export function enableBlockOut (id) { + return setBlockOutMode(id, true) } -export function addToBlockOutList(id, number) { - return prependItemToArrayPreference(id, 'block_out_list', number); +export function disableBlockOut (id) { + return setBlockOutMode(id, false) } -export function editBlockOutList(id, index, number) { - return editItemInArrayPreference(id, 'block_out_list', index, number); +export function addToBlockOutList (id, number) { + return prependItemToArrayPreference(id, 'block_out_list', number) } -export function removeFromBlockOutList(id, index) { - return removeItemFromArrayPreference(id, 'block_out_list', index); +export function editBlockOutList (id, index, number) { + return editItemInArrayPreference(id, 'block_out_list', index, number) } -export function setPrivacy(id, value) { - return setPreference(id, 'clir', value); +export function removeFromBlockOutList (id, index) { + return removeItemFromArrayPreference(id, 'block_out_list', index) } -export function enablePrivacy(id) { - return setPrivacy(id, true); +export function setPrivacy (id, value) { + return setPreference(id, 'clir', value) } -export function disablePrivacy(id) { - return setPrivacy(id, false); +export function enablePrivacy (id) { + return setPrivacy(id, true) } -export function createSubscriber(subscriber) { - return new Promise((resolve, reject)=>{ - Vue.http.post('api/subscribers/', subscriber, { - params: { - customer_id: subscriber.customer_id - } - }).then((res)=>{ - resolve(_.last(_.split(res.headers.get('Location'), '/'))); - }).catch((err)=>{ - if(err.status >= 400) { - reject(new Error(err.body.message)); - } - else { - reject(err); - } - }); - }); +export function disablePrivacy (id) { + return setPrivacy(id, false) } -export function deleteSubscriber(id) { - return new Promise((resolve, reject)=>{ - Vue.http.delete('api/subscribers/' + id).then(()=>{ - resolve(); - }).catch((err)=>{ - if(err.status >= 400) { - reject(new Error(err.body.message)); - } - else { - reject(err); - } - }); - }); +export function createSubscriber (subscriber) { + return new Promise((resolve, reject) => { + Vue.http.post('api/subscribers/', subscriber, { + params: { + customer_id: subscriber.customer_id + } + }).then((res) => { + resolve(_.last(_.split(res.headers.get('Location'), '/'))) + }).catch((err) => { + if (err.status >= 400) { + reject(new Error(err.body.message)) + } else { + reject(err) + } + }) + }) } -export function setField(id, field, value) { - return new Promise((resolve, reject)=>{ - Vue.http.patch('api/subscribers/' + id, [{ - op: 'replace', - path: '/'+ field, - value: value - }], { - headers: { - 'Content-Type': 'application/json-patch+json', - 'Prefer': 'return=minimal' - } - }).then((result)=>{ - resolve(result); - }).catch((err)=>{ - if(err.status >= 400) { - reject(new Error(err.body.message)); - } - else { - reject(err); - } - }); - }); +export function deleteSubscriber (id) { + return new Promise((resolve, reject) => { + Vue.http.delete('api/subscribers/' + id).then(() => { + resolve() + }).catch((err) => { + if (err.status >= 400) { + reject(new Error(err.body.message)) + } else { + reject(err) + } + }) + }) } -export function setDisplayName(id, displayName) { - return setField(id, 'display_name', displayName); +export function setField (id, field, value) { + return new Promise((resolve, reject) => { + Vue.http.patch('api/subscribers/' + id, [{ + op: 'replace', + path: '/' + field, + value: value + }], { + headers: { + 'Content-Type': 'application/json-patch+json', + Prefer: 'return=minimal' + } + }).then((result) => { + resolve(result) + }).catch((err) => { + if (err.status >= 400) { + reject(new Error(err.body.message)) + } else { + reject(err) + } + }) + }) } -export function setPbxExtension(id, pbxExtension) { - return setField(id, 'pbx_extension', pbxExtension); +export function setDisplayName (id, displayName) { + return setField(id, 'display_name', displayName) } -export function setPbxWebPassword(id, pbxWebPassword) { - return setField(id, 'webpassword', pbxWebPassword); +export function setPbxExtension (id, pbxExtension) { + return setField(id, 'pbx_extension', pbxExtension) } -export function setPbxHuntPolicy(id, pbxHuntPolicy) { - return setField(id, 'pbx_hunt_policy', pbxHuntPolicy); +export function setPbxWebPassword (id, pbxWebPassword) { + return setField(id, 'webpassword', pbxWebPassword) } -export function setPbxHuntTimeout(id, pbxHuntTimeout) { - return setField(id, 'pbx_hunt_timeout', pbxHuntTimeout); -} - -export function setPbxGroupMemberIds(id, ids) { - return setField(id, 'pbx_groupmember_ids', ids); -} - -export function setPbxGroupIds(id, ids) { - return setField(id, 'pbx_group_ids', ids); -} - -export function setPreferenceIntraPbx(id, value) { - return setPreference(id, 'clir_intrapbx', value); -} - -export function getSubscribers(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/subscribers/', - root: '_embedded.ngcp:subscribers' - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getFullSubscribers(options) { - return new Promise((resolve, reject)=>{ - let subscribers = { - items: [] - }; - Promise.resolve().then(()=>{ - return getSubscribers(options); - }).then(($subscribers)=> { - subscribers = $subscribers; - let promises = []; - subscribers.items.forEach((subscriber)=>{ - promises.push(getSubscriberPreference(subscriber.id)); - }); - return Promise.all(promises); - }).then((preferences)=>{ - resolve({ - subscribers: subscribers, - preferences: preferences - }); - }).catch((err)=>{ - reject(err); - }) - }); -} - -export function getSubscriber(id) { - return new Promise((resolve, reject)=>{ - get({ - path: 'api/subscribers/' + id - }).then((subscriber)=>{ - resolve(subscriber); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getSubscriberPreference(id) { - return new Promise((resolve, reject)=>{ - get({ - path: 'api/subscriberpreferences/' + id - }).then((subscriberPreference)=>{ - resolve(subscriberPreference); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function setBlockAnonymous(id, value) { - return setPreference(id, 'block_in_clir', value); -} - -export function blockAnonymous(id) { - return setBlockAnonymous(id, true); -} - -export function allowAnonymous(id) { - return setBlockAnonymous(id, false); -} - -export function getSubscribersByCallQueueEnabled() { - return new Promise((resolve, reject)=>{ - let prefsByCallQueueEnabled = []; - Promise.resolve().then(()=>{ - return getList({ - path: 'api/subscriberpreferences/', - root: '_embedded.ngcp:subscriberpreferences', - all: true - }); - }).then((prefs)=>{ - let subscriberPromises = []; - prefsByCallQueueEnabled = prefs.items.filter((pref)=>{ - return pref.cloud_pbx_callqueue === true; - }); - prefsByCallQueueEnabled.forEach((pref)=>{ - subscriberPromises.push(getSubscriber(pref.subscriber_id)); - }); - return Promise.all(subscriberPromises); - }).then((subscribers)=>{ - subscribers.forEach((subscriber, index)=>{ - subscriber.prefs = prefsByCallQueueEnabled[index]; - }); - resolve(subscribers); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function addNewCallQueueConfig(id, config) { - return Vue.http.put('api/subscriberpreferences/' + id, config); -} - -export function editCallQueuePreference(id, config) { - return new Promise((resolve, reject)=>{ - let $prefs = Object.assign(config, { cloud_pbx_callqueue: true }); - Promise.resolve().then(()=>{ - return getPreferences(id); - }).then((result)=>{ - let prefs = Object.assign(result, $prefs); - delete prefs._links; - return Vue.http.put('api/subscriberpreferences/' + id, prefs); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function setQueueLength(id, queueLength) { - return editCallQueuePreference(id, { max_queue_length: queueLength }); -} - -export function setWrapUpTime(id, wrapUpTime) { - return editCallQueuePreference(id, { queue_wrap_up_time: wrapUpTime }); -} - -export function removeCallQueueConfig(subscriberId) { - let param = { cloud_pbx_callqueue: false }; - return Vue.http.put('api/subscriberpreferences/' + subscriberId, param); -} - -export function getAllPreferences(options) { - return new Promise((resolve, reject)=>{ - options = options || {}; - options = _.merge(options, { - path: 'api/subscriberpreferences/', - root: '_embedded.ngcp:subscriberpreferences', - all: true - }); - getList(options).then((list)=>{ - resolve(list); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function getSubscriberAndPreferences(id) { - return new Promise((resolve, reject)=>{ - Promise.all([ - getSubscriber(id), - getPreferences(id) - ]).then((result)=>{ - resolve({ - subscriber: result[0], - preferences: result[1] - }); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function setSubscriberNumbers(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - return Promise.all([ - assignNumbers(options.assignedNumbers, options.subscriberId), - assignNumbers(options.unassignedNumbers, options.pilotId) - ]); - }).then(()=>{ - if(options.assignedNumbers.length > 0) { - return Promise.resolve({ - subscriber: null, - preferences: null - }); - } - else { - return getSubscriberAndPreferences(options.subscriberId); - } - }).then((result)=>{ - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); -} - -export function changePassword(subscriber, newPassword) { - return new Promise((resolve, reject)=>{ - patchReplaceFull({ - path: 'api/subscribers/' + subscriber, - fieldPath: 'webpassword', - value: newPassword - }).then((subscriber)=>{ - resolve(subscriber); - }).catch((err)=>{ - reject(err); - }); - }); +export function setPbxHuntPolicy (id, pbxHuntPolicy) { + return setField(id, 'pbx_hunt_policy', pbxHuntPolicy) +} + +export function setPbxHuntTimeout (id, pbxHuntTimeout) { + return setField(id, 'pbx_hunt_timeout', pbxHuntTimeout) +} + +export function setPbxGroupMemberIds (id, ids) { + return setField(id, 'pbx_groupmember_ids', ids) +} + +export function setPbxGroupIds (id, ids) { + return setField(id, 'pbx_group_ids', ids) +} + +export function setPreferenceIntraPbx (id, value) { + return setPreference(id, 'clir_intrapbx', value) +} + +export function getSubscribers (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/subscribers/', + root: '_embedded.ngcp:subscribers' + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getFullSubscribers (options) { + return new Promise((resolve, reject) => { + let subscribers = { + items: [] + } + Promise.resolve().then(() => { + return getSubscribers(options) + }).then(($subscribers) => { + subscribers = $subscribers + const promises = [] + subscribers.items.forEach((subscriber) => { + promises.push(getSubscriberPreference(subscriber.id)) + }) + return Promise.all(promises) + }).then((preferences) => { + resolve({ + subscribers: subscribers, + preferences: preferences + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSubscriber (id) { + return new Promise((resolve, reject) => { + get({ + path: 'api/subscribers/' + id + }).then((subscriber) => { + resolve(subscriber) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSubscriberPreference (id) { + return new Promise((resolve, reject) => { + get({ + path: 'api/subscriberpreferences/' + id + }).then((subscriberPreference) => { + resolve(subscriberPreference) + }).catch((err) => { + reject(err) + }) + }) +} + +export function setBlockAnonymous (id, value) { + return setPreference(id, 'block_in_clir', value) +} + +export function blockAnonymous (id) { + return setBlockAnonymous(id, true) +} + +export function allowAnonymous (id) { + return setBlockAnonymous(id, false) +} + +export function getSubscribersByCallQueueEnabled () { + return new Promise((resolve, reject) => { + let prefsByCallQueueEnabled = [] + Promise.resolve().then(() => { + return getList({ + path: 'api/subscriberpreferences/', + root: '_embedded.ngcp:subscriberpreferences', + all: true + }) + }).then((prefs) => { + const subscriberPromises = [] + prefsByCallQueueEnabled = prefs.items.filter((pref) => { + return pref.cloud_pbx_callqueue === true + }) + prefsByCallQueueEnabled.forEach((pref) => { + subscriberPromises.push(getSubscriber(pref.subscriber_id)) + }) + return Promise.all(subscriberPromises) + }).then((subscribers) => { + subscribers.forEach((subscriber, index) => { + subscriber.prefs = prefsByCallQueueEnabled[index] + }) + resolve(subscribers) + }).catch((err) => { + reject(err) + }) + }) +} + +export function addNewCallQueueConfig (id, config) { + return Vue.http.put('api/subscriberpreferences/' + id, config) +} + +export function editCallQueuePreference (id, config) { + return new Promise((resolve, reject) => { + const $prefs = Object.assign(config, { cloud_pbx_callqueue: true }) + Promise.resolve().then(() => { + return getPreferences(id) + }).then((result) => { + const prefs = Object.assign(result, $prefs) + delete prefs._links + return Vue.http.put('api/subscriberpreferences/' + id, prefs) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) +} + +export function setQueueLength (id, queueLength) { + return editCallQueuePreference(id, { max_queue_length: queueLength }) +} + +export function setWrapUpTime (id, wrapUpTime) { + return editCallQueuePreference(id, { queue_wrap_up_time: wrapUpTime }) +} + +export function removeCallQueueConfig (subscriberId) { + const param = { cloud_pbx_callqueue: false } + return Vue.http.put('api/subscriberpreferences/' + subscriberId, param) +} + +export function getAllPreferences (options) { + return new Promise((resolve, reject) => { + options = options || {} + options = _.merge(options, { + path: 'api/subscriberpreferences/', + root: '_embedded.ngcp:subscriberpreferences', + all: true + }) + getList(options).then((list) => { + resolve(list) + }).catch((err) => { + reject(err) + }) + }) +} + +export function getSubscriberAndPreferences (id) { + return new Promise((resolve, reject) => { + Promise.all([ + getSubscriber(id), + getPreferences(id) + ]).then((result) => { + resolve({ + subscriber: result[0], + preferences: result[1] + }) + }).catch((err) => { + reject(err) + }) + }) +} + +export function setSubscriberNumbers (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + return Promise.all([ + assignNumbers(options.assignedNumbers, options.subscriberId), + assignNumbers(options.unassignedNumbers, options.pilotId) + ]) + }).then(() => { + if (options.assignedNumbers.length > 0) { + return Promise.resolve({ + subscriber: null, + preferences: null + }) + } else { + return getSubscriberAndPreferences(options.subscriberId) + } + }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) +} + +export function changePassword (subscriber, newPassword) { + return new Promise((resolve, reject) => { + patchReplaceFull({ + path: 'api/subscribers/' + subscriber, + fieldPath: 'webpassword', + value: newPassword + }).then((subscriber) => { + resolve(subscriber) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/user.js b/src/api/user.js index 7189d5c2..8a07ee56 100644 --- a/src/api/user.js +++ b/src/api/user.js @@ -1,142 +1,140 @@ -import _ from 'lodash'; -import Vue from 'vue'; +import _ from 'lodash' +import Vue from 'vue' import { - get, - getList, - patchReplace + get, + getList, + patchReplace } from './common' -export function login(username, password) { - return new Promise((resolve, reject)=>{ - let jwt = null; - let subscriberId = null; - Vue.http.post('login_jwt', { - username: username, - password: password - }).then((result)=>{ - jwt = result.body.jwt; - subscriberId = result.body.subscriber_id + ""; - resolve({ - jwt: jwt, - subscriberId: subscriberId, - }); - }).catch((err)=>{ - if(err.status && err.status >= 400) { - reject(new Error(err.body.message)); - } - else { - reject(err); - } - }); - }); +export function login (username, password) { + return new Promise((resolve, reject) => { + let jwt = null + let subscriberId = null + Vue.http.post('login_jwt', { + username: username, + password: password + }).then((result) => { + jwt = result.body.jwt + subscriberId = result.body.subscriber_id + '' + resolve({ + jwt: jwt, + subscriberId: subscriberId + }) + }).catch((err) => { + if (err.status && err.status >= 400) { + reject(new Error(err.body.message)) + } else { + reject(err) + } + }) + }) } -export function getUserData(id) { - return new Promise((resolve, reject)=>{ - return Promise.all([ - getSubscriberById(id), - getCapabilities(id), - getFaxServerSettingsById(id) - ]).then((results)=>{ - results[1].faxactive = results[2] - resolve({ - subscriber: results[0], - capabilities: results[1] - }); - }).catch((err)=>{ - reject(err); - }); - }); +export function getUserData (id) { + return new Promise((resolve, reject) => { + return Promise.all([ + getSubscriberById(id), + getCapabilities(id), + getFaxServerSettingsById(id) + ]).then((results) => { + results[1].faxactive = results[2] + resolve({ + subscriber: results[0], + capabilities: results[1] + }) + }).catch((err) => { + reject(err) + }) + }) } -export function getSubscriberById(id) { - return new Promise((resolve, reject)=>{ - get({ - path: 'api/subscribers/' + id - }).then((body)=>{ - resolve(body); - }).catch((err)=>{ - reject(err); - }); - }); +export function getSubscriberById (id) { + return new Promise((resolve, reject) => { + get({ + path: 'api/subscribers/' + id + }).then((body) => { + resolve(body) + }).catch((err) => { + reject(err) + }) + }) } -export function getCapabilities() { - return new Promise((resolve, reject)=>{ - getList({ - path: 'api/capabilities/', - root: '_embedded.ngcp:capabilities', - all: true - }).then((capabilityList)=>{ - let capabilities = {}; - if(_.isArray(capabilityList.items)) { - capabilityList.items.forEach((capability)=>{ - capabilities[capability.name] = capability.enabled; - }); - } - resolve(capabilities); - }).catch((err)=>{ - reject(err); - }); - }); +export function getCapabilities () { + return new Promise((resolve, reject) => { + getList({ + path: 'api/capabilities/', + root: '_embedded.ngcp:capabilities', + all: true + }).then((capabilityList) => { + const capabilities = {} + if (_.isArray(capabilityList.items)) { + capabilityList.items.forEach((capability) => { + capabilities[capability.name] = capability.enabled + }) + } + resolve(capabilities) + }).catch((err) => { + reject(err) + }) + }) } -export function assignNumber(numberId, subscriberId) { - return new Promise((resolve, reject)=>{ - patchReplace({ - path: 'api/numbers/' + numberId, - fieldPath: 'subscriber_id', - value: subscriberId - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function assignNumber (numberId, subscriberId) { + return new Promise((resolve, reject) => { + patchReplace({ + path: 'api/numbers/' + numberId, + fieldPath: 'subscriber_id', + value: subscriberId + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function assignNumbers(numberIds, subscriberId) { - return new Promise((resolve, reject)=>{ - if(_.isArray(numberIds) && numberIds.length > 0) { - let assignNumberRequests = []; - numberIds.forEach((numberId)=>{ - assignNumberRequests.push(assignNumber(numberId, subscriberId)); - }); - Promise.all(assignNumberRequests).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - } - else { - resolve(); - } - }); +export function assignNumbers (numberIds, subscriberId) { + return new Promise((resolve, reject) => { + if (_.isArray(numberIds) && numberIds.length > 0) { + const assignNumberRequests = [] + numberIds.forEach((numberId) => { + assignNumberRequests.push(assignNumber(numberId, subscriberId)) + }) + Promise.all(assignNumberRequests).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + } else { + resolve() + } + }) } -export function getNumbers() { - return new Promise((resolve, reject)=>{ - getList({ - path: 'api/numbers/', - root: '_embedded.ngcp:numbers', - all: true - }).then((numberList)=>{ - resolve(numberList); - }).catch((err)=>{ - reject(err); - }); - }); +export function getNumbers () { + return new Promise((resolve, reject) => { + getList({ + path: 'api/numbers/', + root: '_embedded.ngcp:numbers', + all: true + }).then((numberList) => { + resolve(numberList) + }).catch((err) => { + reject(err) + }) + }) } -export function getFaxServerSettingsById(id) { - return new Promise((resolve, reject) => { - get({ - path: 'api/faxserversettings/' + id - }).then((body)=>{ - resolve(body.active); - }).catch((err)=>{ - reject(err); - }); - }); +export function getFaxServerSettingsById (id) { + return new Promise((resolve, reject) => { + get({ + path: 'api/faxserversettings/' + id + }).then((body) => { + resolve(body.active) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/api/utils.js b/src/api/utils.js index 4fff7c60..726488cc 100644 --- a/src/api/utils.js +++ b/src/api/utils.js @@ -1,15 +1,13 @@ +import _ from 'lodash' -import _ from 'lodash'; - -export function getJsonBody(body) { - if(_.isString(body)) { - try { - return JSON.parse(body); - } - catch(err) { - return body; - } - } - return body; +export function getJsonBody (body) { + if (_.isString(body)) { + try { + return JSON.parse(body) + } catch (err) { + return body + } + } + return body } diff --git a/src/api/voicebox.js b/src/api/voicebox.js index bd46641b..198d56b0 100644 --- a/src/api/voicebox.js +++ b/src/api/voicebox.js @@ -1,161 +1,160 @@ import _ from 'lodash' -import Vue from 'vue'; +import Vue from 'vue' import { - get, - getList, - patchReplace + get, + getList, + patchReplace } from './common' -export function getVoiceboxSettings(subscriberId) { - return new Promise((resolve, reject) => { - get({ - path: `api/voicemailsettings/${subscriberId}` - }).then((result)=>{ - let settings = _.clone(result); - delete settings._links; - resolve(settings); - }).catch((err)=>{ - reject(err); - }); - }); +export function getVoiceboxSettings (subscriberId) { + return new Promise((resolve, reject) => { + get({ + path: `api/voicemailsettings/${subscriberId}` + }).then((result) => { + const settings = _.clone(result) + delete settings._links + resolve(settings) + }).catch((err) => { + reject(err) + }) + }) } -export function setVoiceboxDelete(options) { - return patchReplace({ - path: `api/voicemailsettings/${options.subscriberId}`, - fieldPath: 'delete', - value: options.value - }); +export function setVoiceboxDelete (options) { + return patchReplace({ + path: `api/voicemailsettings/${options.subscriberId}`, + fieldPath: 'delete', + value: options.value + }) } -export function setVoiceboxAttach(options) { - return new Promise((resolve, reject)=>{ - Promise.resolve().then(()=>{ - if(options.value === false) { - return setVoiceboxDelete(options); - } - else { - return Promise.resolve(); - } - }).then(()=>{ - return patchReplace({ - path: `api/voicemailsettings/${options.subscriberId}`, - fieldPath: 'attach', - value: options.value - }); - }).then(()=>{ - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function setVoiceboxAttach (options) { + return new Promise((resolve, reject) => { + Promise.resolve().then(() => { + if (options.value === false) { + return setVoiceboxDelete(options) + } else { + return Promise.resolve() + } + }).then(() => { + return patchReplace({ + path: `api/voicemailsettings/${options.subscriberId}`, + fieldPath: 'attach', + value: options.value + }) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function setVoiceboxPin(options) { - return patchReplace({ - path: `api/voicemailsettings/${options.subscriberId}`, - fieldPath: 'pin', - value: options.value - }); +export function setVoiceboxPin (options) { + return patchReplace({ + path: `api/voicemailsettings/${options.subscriberId}`, + fieldPath: 'pin', + value: options.value + }) } -export function setVoiceboxEmail(options) { - return patchReplace({ - path: `api/voicemailsettings/${options.subscriberId}`, - fieldPath: 'email', - value: options.value - }); +export function setVoiceboxEmail (options) { + return patchReplace({ + path: `api/voicemailsettings/${options.subscriberId}`, + fieldPath: 'email', + value: options.value + }) } -export function getVoiceboxGreetingByType(options) { - return new Promise((resolve, reject) => { - getList({ - path: 'api/voicemailgreetings/', - root: '_embedded.ngcp:voicemailgreetings', - params: { subscriber_id: options.id, type: options.type } - }).then((result) => { - resolve(result); - }).catch((err)=>{ - reject(err); - }); - }); +export function getVoiceboxGreetingByType (options) { + return new Promise((resolve, reject) => { + getList({ + path: 'api/voicemailgreetings/', + root: '_embedded.ngcp:voicemailgreetings', + params: { subscriber_id: options.id, type: options.type } + }).then((result) => { + resolve(result) + }).catch((err) => { + reject(err) + }) + }) } -export function deleteVoiceboxGreetingById(id) { - return new Promise((resolve, reject) => { - Vue.http.delete(`api/voicemailgreetings/${id}`).then(() => { - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function deleteVoiceboxGreetingById (id) { + return new Promise((resolve, reject) => { + Vue.http.delete(`api/voicemailgreetings/${id}`).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function createNewGreeting(formData, onProgress, type) { - return new Promise((resolve, reject) => { - let requestKey = `previous${_.capitalize(type)}Request`; - Vue.http.post('api/voicemailgreetings/', formData, { - before(request) { - Vue[requestKey] = request; - }, - progress(e) { - if (e.lengthComputable) { - onProgress(Math.ceil((e.loaded / e.total ) * 100)); - } - } - }).then(() => { - resolve(); - }).catch((err)=>{ - reject(err); - }); - }); +export function createNewGreeting (formData, onProgress, type) { + return new Promise((resolve, reject) => { + const requestKey = `previous${_.capitalize(type)}Request` + Vue.http.post('api/voicemailgreetings/', formData, { + before (request) { + Vue[requestKey] = request + }, + progress (e) { + if (e.lengthComputable) { + onProgress(Math.ceil((e.loaded / e.total) * 100)) + } + } + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function uploadGreeting(options) { - return new Promise((resolve, reject) => { - let formData = new FormData(); - let fields = _.clone(options.data); - delete fields.file; - let json = JSON.stringify(fields); - formData.append('json', json); - if (options.data.file) { - formData.append('greetingfile', options.data.file); - } - Promise.resolve().then(() => { - return getVoiceboxGreetingByType({ - id: options.data.subscriber_id, - type: options.data.dir - }); - }).then((greetings) => { - if (_.some(greetings.items, { dir: options.data.dir })) { - deleteVoiceboxGreetingById(greetings.items[0].id); - } - return createNewGreeting(formData, options.onProgress, options.data.dir); - }).then(() => { - resolve(); - }).catch((err) => { - reject(err); - }); - }); +export function uploadGreeting (options) { + return new Promise((resolve, reject) => { + const formData = new FormData() + const fields = _.clone(options.data) + delete fields.file + const json = JSON.stringify(fields) + formData.append('json', json) + if (options.data.file) { + formData.append('greetingfile', options.data.file) + } + Promise.resolve().then(() => { + return getVoiceboxGreetingByType({ + id: options.data.subscriber_id, + type: options.data.dir + }) + }).then((greetings) => { + if (_.some(greetings.items, { dir: options.data.dir })) { + deleteVoiceboxGreetingById(greetings.items[0].id) + } + return createNewGreeting(formData, options.onProgress, options.data.dir) + }).then(() => { + resolve() + }).catch((err) => { + reject(err) + }) + }) } -export function abortPreviousRequest(name) { - return new Promise((resolve) => { - let requestKey = `previous${_.capitalize(name)}Request`; - Vue[requestKey].abort(); - resolve(); - }); +export function abortPreviousRequest (name) { + return new Promise((resolve) => { + const requestKey = `previous${_.capitalize(name)}Request` + Vue[requestKey].abort() + resolve() + }) } -export function playGreeting(options) { - return new Promise((resolve, reject)=>{ - let params = { format: options.format }; - Vue.http.get(`api/voicemailgreetings/${options.id}`, { params: params, responseType: 'blob' }) - .then((res) => { - resolve(URL.createObjectURL(res.body)); - }).catch((err) => { - reject(err); - }); - }); +export function playGreeting (options) { + return new Promise((resolve, reject) => { + const params = { format: options.format } + Vue.http.get(`api/voicemailgreetings/${options.id}`, { params: params, responseType: 'blob' }) + .then((res) => { + resolve(URL.createObjectURL(res.body)) + }).catch((err) => { + reject(err) + }) + }) } diff --git a/src/assets/quasar-logo-full.svg b/src/assets/quasar-logo-full.svg new file mode 100644 index 00000000..281d0729 --- /dev/null +++ b/src/assets/quasar-logo-full.svg @@ -0,0 +1,191 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/auth.js b/src/auth.js new file mode 100644 index 00000000..a89d6aae --- /dev/null +++ b/src/auth.js @@ -0,0 +1,31 @@ + +import { + getLocal, + setLocal, + deleteLocal +} from 'src/storage' + +export function getJwt () { + return getLocal('jwt') +} + +export function hasJwt () { + return getJwt() !== null +} + +export function setJwt (jwt) { + setLocal('jwt', jwt) +} + +export function deleteJwt () { + deleteLocal('jwt') + deleteLocal('subscriberId') +} + +export function setSubscriberId (subscriberId) { + setLocal('subscriberId', subscriberId) +} + +export function getSubscriberId () { + return getLocal('subscriberId') +} diff --git a/src/boot/.gitkeep b/src/boot/.gitkeep new file mode 100644 index 00000000..e69de29b diff --git a/src/boot/axios.js b/src/boot/axios.js new file mode 100644 index 00000000..3fad1693 --- /dev/null +++ b/src/boot/axios.js @@ -0,0 +1,23 @@ + +import axios from 'axios' +import { + getJwt, + hasJwt +} from 'src/auth' + +export default ({ Vue, store, app }) => { + const http = axios.create({ + baseURL: app.config.baseHttpUrl + }) + http.interceptors.request.use(function (config) { + if (hasJwt()) { + config.headers.Authorization = 'Bearer ' + getJwt() + } + return config + }, function (error) { + return Promise.reject(error) + }) + Vue.http = http + Vue.$http = http + store.$http = http +} diff --git a/src/boot/components.js b/src/boot/components.js new file mode 100644 index 00000000..e3136c4a --- /dev/null +++ b/src/boot/components.js @@ -0,0 +1,18 @@ + +import QItemMain from 'src/components/quasar-legacy/QItemMain' +import QItemSide from 'src/components/quasar-legacy/QItemSide' +import QCollapsible from 'src/components/quasar-legacy/QCollapsible' +import QAlert from 'src/components/quasar-legacy/QAlert' +import QResizeObservable from 'src/components/quasar-legacy/QResizeObservable' +import QModal from 'src/components/quasar-legacy/QModal' +import QPopover from 'src/components/quasar-legacy/QPopover' + +export default ({ Vue }) => { + Vue.component('q-item-main', QItemMain) + Vue.component('q-item-side', QItemSide) + Vue.component('q-collapsible', QCollapsible) + Vue.component('q-alert', QAlert) + Vue.component('q-resize-observable', QResizeObservable) + Vue.component('q-modal', QModal) + Vue.component('q-popover', QPopover) +} diff --git a/src/boot/config.js b/src/boot/config.js new file mode 100644 index 00000000..59734403 --- /dev/null +++ b/src/boot/config.js @@ -0,0 +1,13 @@ + +import Vue from 'vue' +import config from 'src/config' + +Vue.use({ + install (Vue, options) { + Vue.$config = config + } +}) + +export default ({ app }) => { + app.config = config +} diff --git a/src/boot/constants.js b/src/boot/constants.js new file mode 100644 index 00000000..0fe0caac --- /dev/null +++ b/src/boot/constants.js @@ -0,0 +1,9 @@ + +export default ({ Vue, app }) => { + Vue.prototype.$faxQualityOptions = [ + { label: app.i18n.t('communication.quality.normal'), value: 'normal' }, + { label: app.i18n.t('communication.quality.fine'), value: 'fine' }, + { label: app.i18n.t('communication.quality.super'), value: 'super' } + ] + Vue.prototype.$faxQualityOptionsDefault = Vue.prototype.$faxQualityOptions[0] +} diff --git a/src/boot/filters.js b/src/boot/filters.js new file mode 100644 index 00000000..d46a5f72 --- /dev/null +++ b/src/boot/filters.js @@ -0,0 +1,31 @@ + +import Vue from 'vue' +import NumberFilter from 'src/filters/number' +import NumberFormatFilter, { + normalizeDestination +} from 'src/filters/number-format' +import DateFilter, { + smartTime, + time +} from 'src/filters/date' +import { + startCase +} from 'src/filters/string' +import WholeCurrency from 'src/filters/currency' +import { + displayName +} from 'src/filters/subscriber' + +export default () => { + Vue.filter('number', NumberFilter) + Vue.filter('readableDate', DateFilter) + Vue.filter('numberFormat', NumberFormatFilter) + Vue.filter('destinationFormat', normalizeDestination) + Vue.filter('smartTime', smartTime) + Vue.filter('startCase', startCase) + Vue.filter('wholeCurrency', WholeCurrency) + Vue.filter('seatName', displayName) + Vue.filter('groupName', displayName) + Vue.filter('displayName', displayName) + Vue.filter('time', time) +} diff --git a/src/boot/i18n.js b/src/boot/i18n.js new file mode 100644 index 00000000..e8e7a3fa --- /dev/null +++ b/src/boot/i18n.js @@ -0,0 +1,31 @@ + +import Vue from 'vue' +import VueI18n from 'vue-i18n' +import { + messages +} from 'src/i18n' +import { + hasSession, + getSession, + setSession +} from 'src/storage' + +Vue.use(VueI18n) + +export const defaultLocale = 'en-US' + +export const i18n = new VueI18n({ + locale: defaultLocale, + fallbackLocale: defaultLocale, + messages +}) + +export default ({ app, store }) => { + app.i18n = i18n + store.$i18n = i18n + if (!hasSession('locale')) { + setSession('locale', navigator.language) + } + i18n.locale = getSession('locale') + '' + store.commit('user/changeSessionLocaleSucceeded', i18n.locale) +} diff --git a/src/boot/routes.js b/src/boot/routes.js new file mode 100644 index 00000000..27ad2738 --- /dev/null +++ b/src/boot/routes.js @@ -0,0 +1,54 @@ + +import routes from 'src/router/routes' +import _ from 'lodash' +import { + Dark +} from 'quasar' +import { + getJwt, getSubscriberId, + hasJwt +} from 'src/auth' + +export default ({ app, router, store }) => { + router.beforeEach((to, from, next) => { + if (!hasJwt() && to.path !== '/login') { + next({ + path: '/login' + }) + } else if (hasJwt() && to.path === '/login') { + next({ + path: '/' + }) + } else if (hasJwt() && to.path === '/conference') { + next({ + path: '/conference/room123' + }) + } else { + next() + } + }) + router.afterEach((to, from) => { + const mainTitle = app.i18n.t('title') + let title = _.get(to, 'meta.title', '') + const subTitle = _.get(to, 'meta.subtitle', '') + if (mainTitle !== '') { + title = mainTitle + ' - ' + title + } + if (subTitle !== '') { + title = title + ' - ' + subTitle + } + document.title = title + store.commit('routeChanged', to) + }) + + if (hasJwt()) { + store.commit('user/loginSucceeded', { + jwt: getJwt(), + subscriberId: getSubscriberId() + }) + } + + store.$router = router + router.addRoutes(routes(app)) + Dark.set(true) +} diff --git a/src/boot/vue-resource.js b/src/boot/vue-resource.js new file mode 100644 index 00000000..bac47748 --- /dev/null +++ b/src/boot/vue-resource.js @@ -0,0 +1,20 @@ + +import VueResource from 'vue-resource' +import { + getJwt, + hasJwt +} from 'src/auth' + +export default ({ Vue, app }) => { + Vue.use(VueResource) + Vue.http.options.root = app.config.baseHttpUrl + Vue.http.interceptors.push(function (request, next) { + if (hasJwt()) { + request.headers.set('Authorization', 'Bearer ' + getJwt()) + } + if (request.method === 'POST' && (request.body === undefined || request.body === null)) { + request.body = {} + } + next() + }) +} diff --git a/src/boot/vue-scrollto.js b/src/boot/vue-scrollto.js new file mode 100644 index 00000000..c521c6ca --- /dev/null +++ b/src/boot/vue-scrollto.js @@ -0,0 +1,6 @@ + +import VueScrollTo from 'vue-scrollto' + +export default ({ Vue }) => { + Vue.use(VueScrollTo) +} diff --git a/src/boot/vuelidate.js b/src/boot/vuelidate.js new file mode 100644 index 00000000..e22676ad --- /dev/null +++ b/src/boot/vuelidate.js @@ -0,0 +1,6 @@ + +import Vuelidate from 'vuelidate' + +export default ({ Vue, store }) => { + Vue.use(Vuelidate) +} diff --git a/src/components/CscAlertError.vue b/src/components/CscAlertError.vue index 88943ea4..5c794f81 100644 --- a/src/components/CscAlertError.vue +++ b/src/components/CscAlertError.vue @@ -1,41 +1,34 @@ diff --git a/src/components/CscList.vue b/src/components/CscList.vue index ba82460c..811481f0 100644 --- a/src/components/CscList.vue +++ b/src/components/CscList.vue @@ -1,22 +1,18 @@ - - diff --git a/src/components/CscListActionButton.vue b/src/components/CscListActionButton.vue index 6c8397c5..fac0c173 100644 --- a/src/components/CscListActionButton.vue +++ b/src/components/CscListActionButton.vue @@ -1,41 +1,37 @@ - - diff --git a/src/components/CscListActions.vue b/src/components/CscListActions.vue index 81837103..1baec281 100644 --- a/src/components/CscListActions.vue +++ b/src/components/CscListActions.vue @@ -1,53 +1,45 @@ diff --git a/src/components/CscListAddButton.vue b/src/components/CscListAddButton.vue index 5001e0db..3183c0c9 100644 --- a/src/components/CscListAddButton.vue +++ b/src/components/CscListAddButton.vue @@ -1,45 +1,36 @@ - - diff --git a/src/components/CscListItem.vue b/src/components/CscListItem.vue index dcf5d3dd..093d9298 100644 --- a/src/components/CscListItem.vue +++ b/src/components/CscListItem.vue @@ -1,145 +1,136 @@ diff --git a/src/components/CscLogo.vue b/src/components/CscLogo.vue index 5d8af67c..23851c80 100644 --- a/src/components/CscLogo.vue +++ b/src/components/CscLogo.vue @@ -1,75 +1,147 @@ diff --git a/src/components/CscPage.vue b/src/components/CscPage.vue index 919d7fca..db887234 100644 --- a/src/components/CscPage.vue +++ b/src/components/CscPage.vue @@ -1,84 +1,71 @@ - + + + + + + + + + + + + + + + + + + + + diff --git a/src/components/CscPageLogin.vue b/src/components/CscPageLogin.vue new file mode 100644 index 00000000..3b8c4c23 --- /dev/null +++ b/src/components/CscPageLogin.vue @@ -0,0 +1,189 @@ + + + + + diff --git a/src/components/CscPageStickyTabs.vue b/src/components/CscPageStickyTabs.vue new file mode 100644 index 00000000..8044bf63 --- /dev/null +++ b/src/components/CscPageStickyTabs.vue @@ -0,0 +1,73 @@ + + diff --git a/src/components/CscPopupMenu.vue b/src/components/CscPopupMenu.vue new file mode 100644 index 00000000..bc141cf3 --- /dev/null +++ b/src/components/CscPopupMenu.vue @@ -0,0 +1,16 @@ + + + diff --git a/src/components/CscPopupMenuItem.vue b/src/components/CscPopupMenuItem.vue new file mode 100644 index 00000000..b4f19383 --- /dev/null +++ b/src/components/CscPopupMenuItem.vue @@ -0,0 +1,47 @@ + + + diff --git a/src/components/CscPopupMenuItemDelete.vue b/src/components/CscPopupMenuItemDelete.vue new file mode 100644 index 00000000..523af070 --- /dev/null +++ b/src/components/CscPopupMenuItemDelete.vue @@ -0,0 +1,15 @@ + + diff --git a/src/components/CscPopupMenuItemStartCall.vue b/src/components/CscPopupMenuItemStartCall.vue new file mode 100644 index 00000000..014571cb --- /dev/null +++ b/src/components/CscPopupMenuItemStartCall.vue @@ -0,0 +1,15 @@ + + diff --git a/src/components/CscRemoveDialog.vue b/src/components/CscRemoveDialog.vue index ff2fc08e..55032c48 100644 --- a/src/components/CscRemoveDialog.vue +++ b/src/components/CscRemoveDialog.vue @@ -1,65 +1,73 @@ diff --git a/src/components/CscUserMenu.vue b/src/components/CscUserMenu.vue new file mode 100644 index 00000000..c96195e8 --- /dev/null +++ b/src/components/CscUserMenu.vue @@ -0,0 +1,126 @@ + + + + + diff --git a/src/components/Error404.vue b/src/components/Error404.vue index d2304b0d..81669c06 100644 --- a/src/components/Error404.vue +++ b/src/components/Error404.vue @@ -1,18 +1,20 @@ +export default { - +} + diff --git a/src/components/EssentialLink.vue b/src/components/EssentialLink.vue new file mode 100644 index 00000000..f73586ec --- /dev/null +++ b/src/components/EssentialLink.vue @@ -0,0 +1,49 @@ + + + diff --git a/src/components/Login.vue b/src/components/Login.vue deleted file mode 100644 index b89bee50..00000000 --- a/src/components/Login.vue +++ /dev/null @@ -1,245 +0,0 @@ - - - - - diff --git a/src/components/call/CscCall.vue b/src/components/call/CscCall.vue index 29278131..cdbb8029 100644 --- a/src/components/call/CscCall.vue +++ b/src/components/call/CscCall.vue @@ -1,610 +1,645 @@ diff --git a/src/components/form/CscCallInput.vue b/src/components/form/CscCallInput.vue index a50840fe..e187aaef 100644 --- a/src/components/form/CscCallInput.vue +++ b/src/components/form/CscCallInput.vue @@ -1,101 +1,86 @@ - +s diff --git a/src/components/layouts/CscLanguageMenu.vue b/src/components/layouts/CscLanguageMenu.vue deleted file mode 100644 index 647c4915..00000000 --- a/src/components/layouts/CscLanguageMenu.vue +++ /dev/null @@ -1,67 +0,0 @@ - - - - - diff --git a/src/components/layouts/CscUserMenu.vue b/src/components/layouts/CscUserMenu.vue deleted file mode 100644 index dff871c2..00000000 --- a/src/components/layouts/CscUserMenu.vue +++ /dev/null @@ -1,148 +0,0 @@ - - - - - diff --git a/src/components/layouts/Default.vue b/src/components/layouts/Default.vue deleted file mode 100644 index fb3ac2ea..00000000 --- a/src/components/layouts/Default.vue +++ /dev/null @@ -1,684 +0,0 @@ - - - - - diff --git a/src/components/layouts/MainMenu.vue b/src/components/layouts/MainMenu.vue deleted file mode 100644 index 94d4e506..00000000 --- a/src/components/layouts/MainMenu.vue +++ /dev/null @@ -1,293 +0,0 @@ - - - - - diff --git a/src/components/layouts/NewFeaturesMenu.vue b/src/components/layouts/NewFeaturesMenu.vue deleted file mode 100644 index 695465a4..00000000 --- a/src/components/layouts/NewFeaturesMenu.vue +++ /dev/null @@ -1,64 +0,0 @@ - - - - - diff --git a/src/components/pages/CallBlocking/CscBlockedNumber.vue b/src/components/pages/CallBlocking/CscBlockedNumber.vue index 9c044b5b..97601d50 100644 --- a/src/components/pages/CallBlocking/CscBlockedNumber.vue +++ b/src/components/pages/CallBlocking/CscBlockedNumber.vue @@ -1,183 +1,148 @@ diff --git a/src/components/pages/CallForward/CscCallForwardDestinations.vue b/src/components/pages/CallForward/CscCallForwardDestinations.vue index 2433316a..68f0a8ad 100644 --- a/src/components/pages/CallForward/CscCallForwardDestinations.vue +++ b/src/components/pages/CallForward/CscCallForwardDestinations.vue @@ -1,175 +1,174 @@ diff --git a/src/components/pages/CallForward/CscCallForwardTime.vue b/src/components/pages/CallForward/CscCallForwardTime.vue index 16dc2bc1..ad9de039 100644 --- a/src/components/pages/CallForward/CscCallForwardTime.vue +++ b/src/components/pages/CallForward/CscCallForwardTime.vue @@ -1,123 +1,87 @@ diff --git a/src/components/pages/CallForward/CscSourcesetsForm.vue b/src/components/pages/CallForward/CscSourcesetsForm.vue index 1c9d013d..bbd66a85 100644 --- a/src/components/pages/CallForward/CscSourcesetsForm.vue +++ b/src/components/pages/CallForward/CscSourcesetsForm.vue @@ -1,75 +1,67 @@ diff --git a/src/components/pages/Conference/CscConferenceParticipants.vue b/src/components/pages/Conference/CscConferenceParticipants.vue index 93556bf2..4dda7822 100644 --- a/src/components/pages/Conference/CscConferenceParticipants.vue +++ b/src/components/pages/Conference/CscConferenceParticipants.vue @@ -1,93 +1,86 @@ diff --git a/src/components/pages/Conversations/CscCallItem.vue b/src/components/pages/Conversations/CscCallItem.vue index e816eff9..964daf57 100644 --- a/src/components/pages/Conversations/CscCallItem.vue +++ b/src/components/pages/Conversations/CscCallItem.vue @@ -1,258 +1,202 @@ diff --git a/src/components/pages/Conversations/CscFaxItem.vue b/src/components/pages/Conversations/CscFaxItem.vue index ae1b4522..b64a78ee 100644 --- a/src/components/pages/Conversations/CscFaxItem.vue +++ b/src/components/pages/Conversations/CscFaxItem.vue @@ -1,152 +1,107 @@ diff --git a/src/components/pages/CscPageHome.vue b/src/components/pages/CscPageHome.vue new file mode 100644 index 00000000..b7d54ccb --- /dev/null +++ b/src/components/pages/CscPageHome.vue @@ -0,0 +1,137 @@ + + + + + diff --git a/src/components/pages/CscPageReminder.vue b/src/components/pages/CscPageReminder.vue new file mode 100644 index 00000000..409fdab5 --- /dev/null +++ b/src/components/pages/CscPageReminder.vue @@ -0,0 +1,198 @@ + + + diff --git a/src/components/pages/CscUserSettings.vue b/src/components/pages/CscUserSettings.vue index 9d68a671..252c2025 100644 --- a/src/components/pages/CscUserSettings.vue +++ b/src/components/pages/CscUserSettings.vue @@ -1,79 +1,69 @@ +import { + showGlobalError, + showToast +} from 'src/helpers/ui' +import { + RequestState +} from 'src/store/common' +import { + mapState, + mapGetters, + mapActions +} from 'vuex' +import CscPage from '../CscPage' +import CscChangePassword from './UserSettings/CscChangePassword' - +export default { + name: 'CscPageUserSettings', + components: { + CscChangePassword, + CscPage + }, + data () { + return { + } + }, + computed: { + ...mapState('user', [ + 'changePasswordState', + 'changePasswordError' + ]), + ...mapGetters('user', [ + 'getSubscriber', + 'isPasswordChanging' + ]) + }, + watch: { + changePasswordState (state) { + if (state === RequestState.succeeded) { + showToast(this.$t('changePasswordToast')) + } else if (state === RequestState.failed) { + showGlobalError(this.changePasswordError) + } + } + }, + methods: { + ...mapActions('user', [ + 'changePassword' + ]) + } +} + diff --git a/src/components/pages/Home.vue b/src/components/pages/Home.vue deleted file mode 100644 index e0f29163..00000000 --- a/src/components/pages/Home.vue +++ /dev/null @@ -1,185 +0,0 @@ - - - - - diff --git a/src/components/pages/NewCallForward/CscCallForwardGroup.vue b/src/components/pages/NewCallForward/CscCallForwardGroup.vue index cd2ff97f..31df6379 100644 --- a/src/components/pages/NewCallForward/CscCallForwardGroup.vue +++ b/src/components/pages/NewCallForward/CscCallForwardGroup.vue @@ -1,844 +1,800 @@ -