bitwarden-estensione-browser/src/background/contextMenus.background.ts

103 lines
3.5 KiB
TypeScript
Raw Normal View History

2018-01-12 17:09:30 +01:00
import { BrowserApi } from '../browser/browserApi';
2017-12-07 22:02:15 +01:00
import MainBackground from './main.background';
2018-01-26 16:48:32 +01:00
import { Analytics } from 'jslib/misc';
2018-01-09 23:55:28 +01:00
import {
2018-01-10 05:05:46 +01:00
CipherService,
2018-01-09 23:55:28 +01:00
PasswordGenerationService,
2018-04-23 19:04:11 +02:00
PlatformUtilsService,
2018-01-09 23:55:28 +01:00
} from 'jslib/abstractions';
2017-12-07 22:02:15 +01:00
export default class ContextMenusBackground {
private contextMenus: any;
constructor(private main: MainBackground, private cipherService: CipherService,
2018-04-23 19:04:11 +02:00
private passwordGenerationService: PasswordGenerationService, private analytics: Analytics,
private platformUtilsService: PlatformUtilsService) {
2017-12-07 22:02:15 +01:00
this.contextMenus = chrome.contextMenus;
}
async init() {
if (!this.contextMenus) {
return;
}
this.contextMenus.onClicked.addListener(async (info: any, tab: any) => {
if (info.menuItemId === 'generate-password') {
await this.generatePasswordToClipboard();
} else if (info.parentMenuItemId === 'autofill' || info.parentMenuItemId === 'copy-username' ||
info.parentMenuItemId === 'copy-password') {
await this.cipherAction(info);
}
});
}
private async generatePasswordToClipboard() {
const options = await this.passwordGenerationService.getOptions();
2018-04-23 19:04:11 +02:00
const password = await this.passwordGenerationService.generatePassword(options);
this.platformUtilsService.copyToClipboard(password, { window: window });
2017-12-07 22:02:15 +01:00
this.passwordGenerationService.addHistory(password);
2018-01-19 22:19:24 +01:00
this.analytics.ga('send', {
2017-12-07 22:02:15 +01:00
hitType: 'event',
eventAction: 'Generated Password From Context Menu',
});
}
private async cipherAction(info: any) {
const id = info.menuItemId.split('_')[1];
if (id === 'noop') {
if (chrome.browserAction && chrome.browserAction.openPopup) {
chrome.browserAction.openPopup();
}
return;
}
const ciphers = await this.cipherService.getAllDecrypted();
for (let i = 0; i < ciphers.length; i++) {
const cipher = ciphers[i];
if (cipher.id !== id) {
continue;
}
if (info.parentMenuItemId === 'autofill') {
2018-01-19 22:19:24 +01:00
this.analytics.ga('send', {
2017-12-07 22:02:15 +01:00
hitType: 'event',
eventAction: 'Autofilled From Context Menu',
});
await this.startAutofillPage(cipher);
} else if (info.parentMenuItemId === 'copy-username') {
2018-01-19 22:19:24 +01:00
this.analytics.ga('send', {
2017-12-07 22:02:15 +01:00
hitType: 'event',
eventAction: 'Copied Username From Context Menu',
});
this.platformUtilsService.copyToClipboard(cipher.login.username, { window: window });
2017-12-07 22:02:15 +01:00
} else if (info.parentMenuItemId === 'copy-password') {
2018-01-19 22:19:24 +01:00
this.analytics.ga('send', {
2017-12-07 22:02:15 +01:00
hitType: 'event',
eventAction: 'Copied Password From Context Menu',
});
this.platformUtilsService.copyToClipboard(cipher.login.password, { window: window });
2017-12-07 22:02:15 +01:00
}
break;
}
}
private async startAutofillPage(cipher: any) {
this.main.loginToAutoFill = cipher;
const tab = await BrowserApi.getTabFromCurrentWindow();
if (tab == null) {
return;
}
BrowserApi.tabSendMessage(tab, {
2017-12-07 22:02:15 +01:00
command: 'collectPageDetails',
tab: tab,
sender: 'contextMenu',
});
}
}