mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-23 21:31:29 +01:00
cb8849c355
* add eslint rule no-floating-promises * add eslint-disable comment to offending lines
92 lines
2.8 KiB
TypeScript
92 lines
2.8 KiB
TypeScript
import "module-alias/register";
|
|
|
|
import yargs from "yargs";
|
|
import { hideBin } from "yargs/helpers";
|
|
|
|
import { NativeMessagingVersion } from "@bitwarden/common/enums";
|
|
|
|
import { CredentialUpdatePayload } from "../../../src/models/native-messaging/encrypted-message-payloads/credential-update-payload";
|
|
import { LogUtils } from "../log-utils";
|
|
import NativeMessageService from "../native-message.service";
|
|
import * as config from "../variables";
|
|
|
|
// Command line arguments
|
|
const argv: any = yargs(hideBin(process.argv))
|
|
.option("name", {
|
|
alias: "n",
|
|
demand: true,
|
|
describe: "Name that the updated login will be given",
|
|
type: "string",
|
|
})
|
|
.option("username", {
|
|
alias: "u",
|
|
demand: true,
|
|
describe: "Username that the login will be given",
|
|
type: "string",
|
|
})
|
|
.option("password", {
|
|
alias: "p",
|
|
demand: true,
|
|
describe: "Password that the login will be given",
|
|
type: "string",
|
|
})
|
|
.option("uri", {
|
|
demand: true,
|
|
describe: "Uri that the login will be given",
|
|
type: "string",
|
|
})
|
|
.option("credentialId", {
|
|
demand: true,
|
|
describe: "GUID of the credential to update",
|
|
type: "string",
|
|
}).argv;
|
|
|
|
const { name, username, password, uri, credentialId } = argv;
|
|
|
|
// FIXME: Verify that this floating promise is intentional. If it is, add an explanatory comment and ensure there is proper error handling.
|
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
(async () => {
|
|
const nativeMessageService = new NativeMessageService(NativeMessagingVersion.One);
|
|
// Handshake
|
|
LogUtils.logInfo("Sending Handshake");
|
|
const handshakeResponse = await nativeMessageService.sendHandshake(
|
|
config.testRsaPublicKey,
|
|
config.applicationName,
|
|
);
|
|
|
|
if (!handshakeResponse.status) {
|
|
LogUtils.logError(" Handshake failed. Error was: " + handshakeResponse.error);
|
|
nativeMessageService.disconnect();
|
|
return;
|
|
}
|
|
LogUtils.logSuccess("Handshake success response");
|
|
|
|
// Get active account userId
|
|
const status = await nativeMessageService.checkStatus(handshakeResponse.sharedKey);
|
|
|
|
const activeUser = status.payload.filter((a) => a.active === true && a.status === "unlocked")[0];
|
|
if (activeUser === undefined) {
|
|
LogUtils.logError("No active or unlocked user");
|
|
}
|
|
LogUtils.logInfo("Active userId: " + activeUser.id);
|
|
|
|
const response = await nativeMessageService.credentialUpdate(handshakeResponse.sharedKey, {
|
|
name: name,
|
|
password: password,
|
|
userName: username,
|
|
uri: uri,
|
|
userId: activeUser.id,
|
|
credentialId: credentialId,
|
|
} as CredentialUpdatePayload);
|
|
|
|
if (response.payload.status === "failure") {
|
|
LogUtils.logError("Failure response returned ");
|
|
} else if (response.payload.status === "success") {
|
|
LogUtils.logSuccess("Success response returned ");
|
|
} else {
|
|
LogUtils.logWarning("Other response: ", response);
|
|
}
|
|
|
|
nativeMessageService.disconnect();
|
|
})();
|