1
0
mirror of https://github.com/bitwarden/browser synced 2025-12-16 08:13:42 +00:00

Load filtered sites for current tab. setup content script to collect and fill form data via message passing.

This commit is contained in:
Kyle Spearrin
2016-09-14 00:16:43 -04:00
parent e987c13b7a
commit 74dff39427
7 changed files with 193 additions and 6 deletions

View File

@@ -1,6 +1,78 @@
angular
angular
.module('bit.current')
.controller('currentController', function ($scope) {
.controller('currentController', function ($scope, siteService, cipherService, tldjs, toastr, $q) {
chrome.tabs.query({ active: true, currentWindow: true }, function (tabs) {
var url = null;
var id = null;
if (tabs.length > 0) {
url = tabs[0].url
id = tabs[0].id
}
var domain = tldjs.getDomain(url);
$scope.sites = [];
if (!domain) {
return;
}
chrome.tabs.sendMessage(id, { text: 'collectFormData' }, function (formData) {
var filteredPromises = [],
filteredSites = [],
promises = [],
decSites = [];
siteService.getAll(function (sites) {
for (var i = 0; i < sites.length; i++) {
var uriPromise = cipherService.decrypt(sites[i].uri, i);
filteredPromises.push(uriPromise);
uriPromise.then(function (obj) {
if (!obj.val) {
return;
}
var siteDomain = tldjs.getDomain(obj.val);
if (!siteDomain || siteDomain != domain) {
return;
}
filteredSites.push(obj.index);
});
}
$q.all(filteredPromises).then(function () {
for (var j = 0; j < filteredSites.length; j++) {
var index = filteredSites[j];
decSites.push({
id: sites[index].id,
folderId: sites[index].folderId,
favorite: sites[index].favorite
});
var namePromise = cipherService.decrypt(sites[index].name, j);
promises.push(namePromise);
namePromise.then(function (obj) {
decSites[obj.index].name = obj.val;
});
var usernamePromise = cipherService.decrypt(sites[index].username, j);
promises.push(usernamePromise);
usernamePromise.then(function (obj) {
decSites[obj.index].username = obj.val;
});
var passwordPromise = cipherService.decrypt(sites[index].password, j);
promises.push(passwordPromise);
passwordPromise.then(function (obj) {
decSites[obj.index].password = obj.val;
});
}
$q.all(promises).then(function () {
$scope.sites = decSites;
});
});
});
});
});
});

View File

@@ -1,2 +1,2 @@
angular
.module('bit.current', []);
.module('bit.current', ['toastr', 'ngclipboard']);

View File

@@ -1,6 +1,22 @@
<div class="header">
<div class="title">Current Sites</div>
<div class="title">Current Tab Sites</div>
</div>
<div class="content content-tabs">
Some content for your current sites.
<div class="list">
<div class="list-grouped">
<div ng-click="fillSite(site)" class="list-grouped-item condensed" style="cursor: pointer;"
ng-repeat="site in theSites = (sites | orderBy: ['name', 'username'])">
<a class="btn-list" href="" ng-click="$event.stopPropagation()" title="Copy Password" ngclipboard ngclipboard-error="clipboardError(e)"
ngclipboard-success="clipboardSuccess(e, 'Password')" data-clipboard-text="{{site.password}}" ng-class="{'disabled': !site.password}">
<i class="fa fa-lg fa-clipboard"></i>
</a>
<a class="btn-list" href="" ng-click="$event.stopPropagation()" title="Copy Username" ngclipboard ngclipboard-error="clipboardError(e)"
ngclipboard-success="clipboardSuccess(e, 'Username')" data-clipboard-text="{{site.username}}" ng-class="{'disabled': !site.username}">
<i class="fa fa-lg fa-copy"></i>
</a>
<span class="text">{{site.name}}</span>
<span class="detail">{{site.username}}</span>
</div>
</div>
</div>
</div>

View File

@@ -1,7 +1,7 @@
angular
.module('bit.vault')
.controller('vaultController', function ($scope, $rootScope, siteService, folderService, $q, cipherService, $state, $stateParams, $uibModal, toastr) {
.controller('vaultController', function ($scope, $rootScope, siteService, folderService, $q, cipherService, $state, $stateParams, toastr) {
$('#search').focus();
var delayLoad = true;