mirror of
https://github.com/bitwarden/browser
synced 2025-12-11 13:53:34 +00:00
* Extract files only used in cli out of libs/node Move commands from libs/node to cli Move program from libs/node to cli Move services from libs/node to cli Move specs from libs/node to cli Naming changes based on ADR 12 Rename commands Rename models/request Rename models/response Remove entries from whitelist-capital-letters.txt * Merge lowDbStorageService into base class Move logic from extended lowdbStorage.service.ts into base-lowdb-storage.service.ts Delete lowdb-storage.service.ts Rename base-lowdb-storage.service.ts to lowdb-storage.service.ts * Merge login.command with base class program.ts - changed import temporarily to make it easier to review Remove passing in clientId, set "cli" when constructing ssoRedirectUri call Remove setting callbacks, use private methods instead Remove i18nService from constructor params Add syncService, keyConnectorService and logoutCallback to constructor Merge successCallback with handleSuccessResponse Remove validatedParams callback and added private method Move options(program.OptionValues) and set in run() Delete login.command.ts * Rename base-login.command.ts to login.command.ts * Merge base.program.ts with program.ts
150 lines
2.9 KiB
TypeScript
150 lines
2.9 KiB
TypeScript
import * as child_process from "child_process";
|
|
|
|
import { PlatformUtilsService } from "@bitwarden/common/abstractions/platformUtils.service";
|
|
import { ClientType } from "@bitwarden/common/enums/clientType";
|
|
import { DeviceType } from "@bitwarden/common/enums/deviceType";
|
|
|
|
// eslint-disable-next-line
|
|
const open = require("open");
|
|
|
|
export class CliPlatformUtilsService implements PlatformUtilsService {
|
|
clientType: ClientType;
|
|
|
|
private deviceCache: DeviceType = null;
|
|
|
|
constructor(clientType: ClientType, private packageJson: any) {
|
|
this.clientType = clientType;
|
|
}
|
|
|
|
getDevice(): DeviceType {
|
|
if (!this.deviceCache) {
|
|
switch (process.platform) {
|
|
case "win32":
|
|
this.deviceCache = DeviceType.WindowsDesktop;
|
|
break;
|
|
case "darwin":
|
|
this.deviceCache = DeviceType.MacOsDesktop;
|
|
break;
|
|
case "linux":
|
|
default:
|
|
this.deviceCache = DeviceType.LinuxDesktop;
|
|
break;
|
|
}
|
|
}
|
|
|
|
return this.deviceCache;
|
|
}
|
|
|
|
getDeviceString(): string {
|
|
const device = DeviceType[this.getDevice()].toLowerCase();
|
|
return device.replace("desktop", "");
|
|
}
|
|
|
|
getClientType() {
|
|
return this.clientType;
|
|
}
|
|
|
|
isFirefox() {
|
|
return false;
|
|
}
|
|
|
|
isChrome() {
|
|
return false;
|
|
}
|
|
|
|
isEdge() {
|
|
return false;
|
|
}
|
|
|
|
isOpera() {
|
|
return false;
|
|
}
|
|
|
|
isVivaldi() {
|
|
return false;
|
|
}
|
|
|
|
isSafari() {
|
|
return false;
|
|
}
|
|
|
|
isMacAppStore() {
|
|
return false;
|
|
}
|
|
|
|
isViewOpen() {
|
|
return Promise.resolve(false);
|
|
}
|
|
|
|
launchUri(uri: string, options?: any): void {
|
|
if (process.platform === "linux") {
|
|
child_process.spawnSync("xdg-open", [uri]);
|
|
} else {
|
|
open(uri);
|
|
}
|
|
}
|
|
|
|
getApplicationVersion(): Promise<string> {
|
|
return Promise.resolve(this.packageJson.version);
|
|
}
|
|
|
|
getApplicationVersionSync(): string {
|
|
return this.packageJson.version;
|
|
}
|
|
|
|
supportsWebAuthn(win: Window) {
|
|
return false;
|
|
}
|
|
|
|
supportsDuo(): boolean {
|
|
return false;
|
|
}
|
|
|
|
showToast(
|
|
type: "error" | "success" | "warning" | "info",
|
|
title: string,
|
|
text: string | string[],
|
|
options?: any
|
|
): void {
|
|
throw new Error("Not implemented.");
|
|
}
|
|
|
|
showDialog(
|
|
text: string,
|
|
title?: string,
|
|
confirmText?: string,
|
|
cancelText?: string,
|
|
type?: string
|
|
): Promise<boolean> {
|
|
throw new Error("Not implemented.");
|
|
}
|
|
|
|
isDev(): boolean {
|
|
return process.env.BWCLI_ENV === "development";
|
|
}
|
|
|
|
isSelfHost(): boolean {
|
|
return false;
|
|
}
|
|
|
|
copyToClipboard(text: string, options?: any): void {
|
|
throw new Error("Not implemented.");
|
|
}
|
|
|
|
readFromClipboard(options?: any): Promise<string> {
|
|
throw new Error("Not implemented.");
|
|
}
|
|
|
|
supportsBiometric(): Promise<boolean> {
|
|
return Promise.resolve(false);
|
|
}
|
|
|
|
authenticateBiometric(): Promise<boolean> {
|
|
return Promise.resolve(false);
|
|
}
|
|
|
|
supportsSecureStorage(): boolean {
|
|
return false;
|
|
}
|
|
}
|