1
0
mirror of https://github.com/bitwarden/browser.git synced 2024-11-30 13:03:53 +01:00

update command

This commit is contained in:
Kyle Spearrin 2018-05-22 14:49:20 -04:00
parent 7b6c4c1bbc
commit 9233d78c2f
3 changed files with 74 additions and 3 deletions

View File

@ -0,0 +1,62 @@
import * as program from 'commander';
import * as fetch from 'node-fetch';
import { PlatformUtilsService } from 'jslib/abstractions/platformUtils.service';
import { Response } from '../models/response';
import { MessageResponse } from '../models/response/messageResponse';
export class UpdateCommand {
constructor(private platformUtilsService: PlatformUtilsService) { }
async run(cmd: program.Command): Promise<Response> {
const currentVersion = this.platformUtilsService.getApplicationVersion();
const response = await fetch.default('https://api.github.com/repos/bitwarden/cli/releases/latest');
if (response.status === 200) {
const responseJson = await response.json();
const res = new MessageResponse(null, null);
const tagName: string = responseJson.tag_name;
if (tagName === ('v' + currentVersion)) {
res.title = 'No update available.';
res.noColor = true;
return Response.success(res);
}
let downloadUrl: string = null;
if (responseJson.assets != null) {
for (const a of responseJson.assets) {
const download: string = a.browser_download_url;
if (download == null) {
continue;
}
if (process.platform === 'win32' && download.indexOf('bw-windows.zip') > -1) {
downloadUrl = download;
break;
} else if (process.platform === 'darwin' && download.indexOf('bw-macos.zip') > -1) {
downloadUrl = download;
break;
} else if (process.platform === 'linux' && download.indexOf('bw-linux.zip') > -1) {
downloadUrl = download;
break;
}
}
}
res.title = 'A new version is available: ' + tagName;
if (downloadUrl == null) {
downloadUrl = 'https://github.com/bitwarden/cli/releases';
} else {
res.raw = downloadUrl;
}
res.message = 'You can download this update at: ' + downloadUrl + '\n' +
'If you installed this CLI through a package manager ' +
'you should probably update using its update command instead.';
return Response.success(res);
} else {
return Response.error('Error contacting update API: ' + response.status);
}
}
}

View File

@ -5,6 +5,7 @@ export class MessageResponse implements BaseResponse {
title: string; title: string;
message: string; message: string;
raw: string; raw: string;
noColor = false;
constructor(title: string, message: string) { constructor(title: string, message: string) {
this.object = 'message'; this.object = 'message';

View File

@ -17,6 +17,7 @@ import { LoginCommand } from './commands/login.command';
import { LogoutCommand } from './commands/logout.command'; import { LogoutCommand } from './commands/logout.command';
import { SyncCommand } from './commands/sync.command'; import { SyncCommand } from './commands/sync.command';
import { UnlockCommand } from './commands/unlock.command'; import { UnlockCommand } from './commands/unlock.command';
import { UpdateCommand } from './commands/update.command';
import { Response } from './models/response'; import { Response } from './models/response';
import { ListResponse } from './models/response/listResponse'; import { ListResponse } from './models/response/listResponse';
@ -470,15 +471,18 @@ export class Program {
writeLn(''); writeLn('');
writeLn(' Returns the URL to download the newest version of this CLI tool.'); writeLn(' Returns the URL to download the newest version of this CLI tool.');
writeLn(''); writeLn('');
writeLn(' Returns nothing if no update is available.'); writeLn(' Use the `--raw` option to return only the download URL for the update.');
writeLn(''); writeLn('');
writeLn(' Examples:'); writeLn(' Examples:');
writeLn(''); writeLn('');
writeLn(' bw update'); writeLn(' bw update');
writeLn(' bw update --raw');
writeLn('', true); writeLn('', true);
}) })
.action(async (object, id, cmd) => { .action(async (object, id, cmd) => {
// TODO const command = new UpdateCommand(this.main.platformUtilsService);
const response = await command.run(cmd);
this.processResponse(response);
}); });
program program
@ -544,8 +548,12 @@ export class Program {
let out: string = ''; let out: string = '';
if (message.title != null) { if (message.title != null) {
if (message.noColor) {
out = message.title;
} else {
out = chalk.greenBright(message.title); out = chalk.greenBright(message.title);
} }
}
if (message.message != null) { if (message.message != null) {
if (message.title != null) { if (message.title != null) {
out += '\n'; out += '\n';