mirror of
https://github.com/nextcloud/passman.git
synced 2024-11-15 12:32:46 +08:00
6767322a22
Fix share button, fix shared_key not added to storedCredential after sharing (Fixes #249) Add password app importer. Fixes #248 Fix version check via proxy. Fixes #237 Fix activity app not filtering. Fixes #246 Add EnPass txt importer. Fixes #159 Fix for disabled share button Require vault key for export. Fixes #199 Indicate that sharing only works with users that have 1 or more vaults. Fixes #242 Reset tags on logout. Fixes #245 Ability to enter OTP secret manually. Fixes #198 Create teampass importer. Fixes #244
121 lines
No EOL
3.3 KiB
JavaScript
121 lines
No EOL
3.3 KiB
JavaScript
/**
|
|
* Nextcloud - passman
|
|
*
|
|
* @copyright Copyright (c) 2016, Sander Brand (brantje@gmail.com)
|
|
* @copyright Copyright (c) 2016, Marcos Zuriaga Miguel (wolfi@wolfi.es)
|
|
* @license GNU AGPL version 3 or any later version
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
// Importers should always start with this
|
|
/** global: PassmanImporter */
|
|
var PassmanImporter = PassmanImporter || {};
|
|
(function(window, $, PassmanImporter) {
|
|
'use strict';
|
|
// Define the importer
|
|
|
|
// Define the importer
|
|
PassmanImporter.randomData = {
|
|
info: {
|
|
name: 'Random data',
|
|
id: 'randomData',
|
|
exportSteps: ['Create\'s 50 random credentials for testing purposes.']
|
|
}
|
|
};
|
|
|
|
PassmanImporter.randomData.readFile = function () {
|
|
/** global: C_Promise */
|
|
return new C_Promise(function () {
|
|
var tags =
|
|
['Social media',
|
|
'Hosting',
|
|
'Forums',
|
|
'Webshops',
|
|
'FTP',
|
|
'SSH',
|
|
'Banking',
|
|
'Applications',
|
|
'Server stuff',
|
|
'mysql',
|
|
'Wifi',
|
|
'Games',
|
|
'Certificate',
|
|
'Serials'
|
|
];
|
|
var label;
|
|
var credential_list = [];
|
|
var _this = this;
|
|
var generateCredential = function (max, i, callback) {
|
|
if (jQuery) {
|
|
var url = OC.generateUrl('apps/passman/api/internal/generate_person');
|
|
$.ajax({
|
|
url: url,
|
|
dataType: 'json',
|
|
success: function (data) {
|
|
if(data) {
|
|
var _credential = PassmanImporter.newCredential();
|
|
label = (Math.random() >= 0.5) ? data.domain : data.email_d + ' - ' + data.email_u;
|
|
_credential.label = label;
|
|
_credential.username = data.username;
|
|
_credential.password = data.password;
|
|
_credential.url = data.url;
|
|
|
|
var tag_amount = Math.floor(Math.random() * 5);
|
|
var ta = 0;
|
|
var _tags = [];
|
|
while (ta < tag_amount) {
|
|
var item = tags[Math.floor(Math.random() * tags.length)];
|
|
if (_tags.indexOf(item) === -1) {
|
|
_tags.push(item);
|
|
ta++
|
|
}
|
|
}
|
|
_credential.tags = _tags.map(function (item) {
|
|
if (item) {
|
|
return {text: item}
|
|
}
|
|
|
|
}).filter(function (item) {
|
|
return (item);
|
|
});
|
|
credential_list.push(_credential);
|
|
|
|
if (i < max) {
|
|
var progress = {
|
|
percent: i / max * 100,
|
|
loaded: i,
|
|
total: max
|
|
};
|
|
_this.call_progress(progress);
|
|
generateCredential(max, i + 1, callback)
|
|
} else {
|
|
callback(credential_list)
|
|
}
|
|
} else {
|
|
generateCredential(max, i , callback)
|
|
}
|
|
}
|
|
});
|
|
}
|
|
};
|
|
|
|
|
|
generateCredential(50, 1, function (credential_list) {
|
|
_this.call_then(credential_list);
|
|
});
|
|
});
|
|
};
|
|
})(window, $, PassmanImporter); |