#!/usr/bin/env node import program from 'commander'; import Progress from 'progress'; import copy from '../lib/copy'; import { resolve } from 'path'; import login from '../lib/login'; import bytes from 'bytes'; import Now from '../lib'; import fs from 'fs'; import ms from 'ms'; import os from 'os'; program .option('-d, --debug', 'Debug mode [off]', false) .option('-f, --force', 'Force a new deployment even if nothing has changed', false) .option('-L, --login', 'Configure login') .option('-C, --no-clipboard', 'Do not attempt to copy URL to clipboard') .parse(process.argv); let path = program.args[program.args.length - 1]; if (path) { if ('/' !== path[0]) { path = resolve(process.cwd(), path); } } else { path = process.cwd(); } let config; try { config = fs.readFileSync(resolve(os.homedir(), '.now.json'), 'utf8'); config = JSON.parse(config); } catch (err) {} if (!config || !config.token) { login() .then((token) => { if (program.L) { console.log('> Logged in successfully. Token saved in ~/.now.json'); process.exit(0); } else { sync(token).catch((err) => { error(`Unknown error: ${err.stack}`); }); } }) .catch((e) => { error(`Authentication error – ${e.message}`); process.exit(1); }); } else { sync(config.token).catch((err) => { error(`Unknown error: ${err.stack}`); }); } async function sync (token) { const debug = !!program.debug; const clipboard = !program.noClipboard; const start = Date.now(); console.log(`> Deploying ${path}`); const now = new Now(token, { debug }); try { await now.create(path, { forceNew: program.force }); } catch (err) { handleError(err); } const { url } = now; const elapsed = ms(new Date() - start); if (clipboard) { try { await copy(url); console.log(`> ${url} (copied to clipboard) [${elapsed}]`); } catch (err) { console.log(`> ${url} [${elapsed}]`); } } else { console.log(`> ${url} [${elapsed}]`); } const start_u = new Date(); const complete = () => { const elapsed_u = ms(new Date() - start_u); console.log(`> Sync complete (${bytes(now.syncAmount)}) [${elapsed_u}] `); now.close(); }; if (now.syncAmount) { const bar = new Progress('> Upload [:bar] :percent :etas', { width: 20, complete: '=', incomplete: '', total: now.syncAmount }); now.upload(); now.on('upload', ({ name, data }) => { const amount = Buffer.byteLength(data); if (debug) { console.log(`> [debug] Uploaded: ${name} (${bytes(Buffer.byteLength(data))})`); } bar.tick(amount); }); now.on('complete', () => { complete(); }); now.on('error', (err) => { error('Upload failed'); handleError(err); process.exit(1); }); } else { console.log('> Sync complete (cached)'); now.close(); } } function handleError (err) { if (403 === err.status) { error('Authentication error. Run `now -L` to log-in again.'); } else if (500 === err.status) { error('Unexpected server error. Please retry.'); } else { error(`Unexpected error. Please try later. (${err.message})`); } process.exit(1); } function error (err) { console.error(`> \u001b[31mError!\u001b[39m ${err}.`); }