2015-12-09 04:35:05 +01:00
|
|
|
|
angular
|
|
|
|
|
.module('bit.vault')
|
|
|
|
|
|
2017-02-28 06:18:11 +01:00
|
|
|
|
.controller('vaultController', function ($scope, $uibModal, apiService, $filter, cryptoService, authService, toastr,
|
2017-03-19 03:55:54 +01:00
|
|
|
|
cipherService, $q) {
|
2017-01-03 04:26:32 +01:00
|
|
|
|
$scope.logins = [];
|
2015-12-09 04:35:05 +01:00
|
|
|
|
$scope.folders = [];
|
2017-02-22 04:50:48 +01:00
|
|
|
|
$scope.loading = true;
|
2017-03-07 06:36:27 +01:00
|
|
|
|
|
2017-03-19 03:55:54 +01:00
|
|
|
|
$scope.$on('$viewContentLoaded', function () {
|
|
|
|
|
var folderPromise = apiService.folders.list({}, function (folders) {
|
2017-03-07 06:36:27 +01:00
|
|
|
|
var decFolders = [{
|
|
|
|
|
id: null,
|
|
|
|
|
name: '(none)'
|
|
|
|
|
}];
|
|
|
|
|
|
2017-03-19 03:55:54 +01:00
|
|
|
|
for (var i = 0; i < folders.Data.length; i++) {
|
|
|
|
|
var decFolder = cipherService.decryptFolderPreview(folders.Data[i]);
|
|
|
|
|
decFolders.push(decFolder);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$scope.folders = decFolders;
|
|
|
|
|
}).$promise;
|
|
|
|
|
|
|
|
|
|
var cipherPromise = apiService.ciphers.list({}, function (ciphers) {
|
|
|
|
|
var decLogins = [];
|
|
|
|
|
|
2017-03-07 06:36:27 +01:00
|
|
|
|
for (var i = 0; i < ciphers.Data.length; i++) {
|
2017-03-19 03:55:54 +01:00
|
|
|
|
if (ciphers.Data[i].Type === 1) {
|
2017-03-07 06:36:27 +01:00
|
|
|
|
var decLogin = cipherService.decryptLoginPreview(ciphers.Data[i]);
|
|
|
|
|
decLogins.push(decLogin);
|
|
|
|
|
}
|
2017-02-22 04:50:48 +01:00
|
|
|
|
}
|
2015-12-09 04:35:05 +01:00
|
|
|
|
|
2017-03-07 06:36:27 +01:00
|
|
|
|
$scope.logins = decLogins;
|
2017-03-19 03:55:54 +01:00
|
|
|
|
}).$promise;
|
|
|
|
|
|
|
|
|
|
$q.all([folderPromise, cipherPromise]).then(function () {
|
|
|
|
|
$scope.loading = false;
|
2017-03-07 06:36:27 +01:00
|
|
|
|
});
|
2015-12-09 04:35:05 +01:00
|
|
|
|
});
|
|
|
|
|
|
2016-08-09 05:50:47 +02:00
|
|
|
|
$scope.folderSort = function (item) {
|
|
|
|
|
if (!item.id) {
|
|
|
|
|
return '';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return item.name.toLowerCase();
|
|
|
|
|
};
|
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
$scope.editLogin = function (login) {
|
2015-12-09 04:35:05 +01:00
|
|
|
|
var editModel = $uibModal.open({
|
|
|
|
|
animation: true,
|
2017-01-03 04:26:32 +01:00
|
|
|
|
templateUrl: 'app/vault/views/vaultEditLogin.html',
|
|
|
|
|
controller: 'vaultEditLoginController',
|
2015-12-09 04:35:05 +01:00
|
|
|
|
resolve: {
|
2017-01-03 04:26:32 +01:00
|
|
|
|
loginId: function () { return login.id; },
|
2015-12-09 04:35:05 +01:00
|
|
|
|
folders: function () { return $scope.folders; }
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
2016-11-10 01:26:02 +01:00
|
|
|
|
editModel.result.then(function (returnVal) {
|
|
|
|
|
if (returnVal.action === 'edit') {
|
2017-01-03 04:26:32 +01:00
|
|
|
|
var loginToUpdate = $filter('filter')($scope.logins, { id: returnVal.data.id }, true);
|
2016-11-10 01:26:02 +01:00
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
if (loginToUpdate && loginToUpdate.length > 0) {
|
|
|
|
|
loginToUpdate[0].folderId = returnVal.data.folderId;
|
|
|
|
|
loginToUpdate[0].name = returnVal.data.name;
|
|
|
|
|
loginToUpdate[0].username = returnVal.data.username;
|
|
|
|
|
loginToUpdate[0].favorite = returnVal.data.favorite;
|
2016-11-10 01:26:02 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (returnVal.action === 'delete') {
|
2017-01-03 04:26:32 +01:00
|
|
|
|
var loginToDelete = $filter('filter')($scope.logins, { id: returnVal.data }, true);
|
|
|
|
|
if (loginToDelete && loginToDelete.length > 0) {
|
|
|
|
|
var index = $scope.logins.indexOf(loginToDelete[0]);
|
2016-11-10 01:26:02 +01:00
|
|
|
|
if (index > -1) {
|
2017-01-03 04:26:32 +01:00
|
|
|
|
$scope.logins.splice(index, 1);
|
2016-11-10 01:26:02 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
2015-12-09 04:35:05 +01:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
$scope.$on('vaultAddLogin', function (event, args) {
|
|
|
|
|
$scope.addLogin();
|
2015-12-09 04:35:05 +01:00
|
|
|
|
});
|
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
$scope.addLogin = function (folder) {
|
2015-12-09 04:35:05 +01:00
|
|
|
|
var addModel = $uibModal.open({
|
|
|
|
|
animation: true,
|
2017-01-03 04:26:32 +01:00
|
|
|
|
templateUrl: 'app/vault/views/vaultAddLogin.html',
|
|
|
|
|
controller: 'vaultAddLoginController',
|
2015-12-09 04:35:05 +01:00
|
|
|
|
resolve: {
|
|
|
|
|
folders: function () { return $scope.folders; },
|
|
|
|
|
selectedFolder: function () { return folder; }
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
addModel.result.then(function (addedLogin) {
|
|
|
|
|
$scope.logins.push(addedLogin);
|
2015-12-09 04:35:05 +01:00
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
$scope.deleteLogin = function (login) {
|
|
|
|
|
if (!confirm('Are you sure you want to delete this login (' + login.name + ')?')) {
|
2015-12-09 04:35:05 +01:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
apiService.logins.del({ id: login.id }, function () {
|
|
|
|
|
var index = $scope.logins.indexOf(login);
|
2016-11-10 03:49:15 +01:00
|
|
|
|
if (index > -1) {
|
2017-01-03 04:26:32 +01:00
|
|
|
|
$scope.logins.splice(index, 1);
|
2016-11-10 03:49:15 +01:00
|
|
|
|
}
|
2015-12-09 04:35:05 +01:00
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$scope.editFolder = function (folder) {
|
|
|
|
|
var editModel = $uibModal.open({
|
|
|
|
|
animation: true,
|
|
|
|
|
templateUrl: 'app/vault/views/vaultEditFolder.html',
|
|
|
|
|
controller: 'vaultEditFolderController',
|
|
|
|
|
size: 'sm',
|
|
|
|
|
resolve: {
|
|
|
|
|
folderId: function () { return folder.id; }
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
editModel.result.then(function (editedFolder) {
|
|
|
|
|
var folder = $filter('filter')($scope.folders, { id: editedFolder.id }, true);
|
|
|
|
|
if (folder && folder.length > 0) {
|
|
|
|
|
folder[0].name = editedFolder.name;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$scope.$on('vaultAddFolder', function (event, args) {
|
|
|
|
|
$scope.addFolder();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$scope.addFolder = function () {
|
|
|
|
|
var addModel = $uibModal.open({
|
|
|
|
|
animation: true,
|
|
|
|
|
templateUrl: 'app/vault/views/vaultAddFolder.html',
|
|
|
|
|
controller: 'vaultAddFolderController',
|
|
|
|
|
size: 'sm'
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
addModel.result.then(function (addedFolder) {
|
|
|
|
|
$scope.folders.push(addedFolder);
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$scope.deleteFolder = function (folder) {
|
2015-12-27 05:15:35 +01:00
|
|
|
|
if (!confirm('Are you sure you want to delete this folder (' + folder.name + ')?')) {
|
2015-12-09 04:35:05 +01:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
apiService.folders.del({ id: folder.id }, function () {
|
|
|
|
|
var index = $scope.folders.indexOf(folder);
|
2016-11-10 03:49:15 +01:00
|
|
|
|
if (index > -1) {
|
|
|
|
|
$scope.folders.splice(index, 1);
|
|
|
|
|
}
|
2015-12-09 04:35:05 +01:00
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$scope.canDeleteFolder = function (folder) {
|
|
|
|
|
if (!folder || !folder.id) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2017-01-03 04:26:32 +01:00
|
|
|
|
var logins = $filter('filter')($scope.logins, { folderId: folder.id });
|
|
|
|
|
return logins.length === 0;
|
2015-12-09 04:35:05 +01:00
|
|
|
|
};
|
|
|
|
|
});
|