diff options
author | Vincent Petry <pvince81@owncloud.com> | 2015-02-10 16:44:29 +0100 |
---|---|---|
committer | Vincent Petry <pvince81@owncloud.com> | 2015-02-10 16:44:29 +0100 |
commit | bd01ff135acb18d5be817ba153adaab9ac431782 (patch) | |
tree | a96fb641999405e4685f1021f00e9196e9e33854 /apps/files_external/js | |
parent | 5ae03fd650b6f3665d1c69ead674d4f5d6420513 (diff) | |
parent | 64f4f8fc84fd8fc27f0e9e316a2c4c2500c7134f (diff) | |
download | nextcloud-server-bd01ff135acb18d5be817ba153adaab9ac431782.tar.gz nextcloud-server-bd01ff135acb18d5be817ba153adaab9ac431782.zip |
Merge pull request #13190 from is-apps/master-sftp-key
Add SFTP public key authentication support
Diffstat (limited to 'apps/files_external/js')
-rw-r--r-- | apps/files_external/js/sftp_key.js | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/apps/files_external/js/sftp_key.js b/apps/files_external/js/sftp_key.js new file mode 100644 index 00000000000..2b39628247c --- /dev/null +++ b/apps/files_external/js/sftp_key.js @@ -0,0 +1,53 @@ +$(document).ready(function() { + + $('#externalStorage tbody tr.\\\\OC\\\\Files\\\\Storage\\\\SFTP_Key').each(function() { + var tr = $(this); + var config = $(tr).find('.configuration'); + if ($(config).find('.sftp_key').length === 0) { + setupTableRow(tr, config); + } + }); + + // We can't catch the DOM elements being added, but we can pick up when + // they receive focus + $('#externalStorage').on('focus', 'tbody tr.\\\\OC\\\\Files\\\\Storage\\\\SFTP_Key', function() { + var tr = $(this); + var config = $(tr).find('.configuration'); + + if ($(config).find('.sftp_key').length === 0) { + setupTableRow(tr, config); + } + }); + + $('#externalStorage').on('click', '.sftp_key', function(event) { + event.preventDefault(); + var tr = $(this).parent().parent(); + generateKeys(tr); + }); + + function setupTableRow(tr, config) { + $(config).append($(document.createElement('input')).addClass('button sftp_key') + .attr('type', 'button') + .attr('value', t('files_external', 'Generate keys'))); + // If there's no private key, build one + if (0 === $(config).find('[data-parameter="private_key"]').val().length) { + generateKeys(tr); + } + } + + function generateKeys(tr) { + var config = $(tr).find('.configuration'); + + $.post(OC.filePath('files_external', 'ajax', 'sftp_key.php'), {}, function(result) { + if (result && result.status === 'success') { + $(config).find('[data-parameter="public_key"]').val(result.data.public_key); + $(config).find('[data-parameter="private_key"]').val(result.data.private_key); + OC.MountConfig.saveStorage(tr, function() { + // Nothing to do + }); + } else { + OC.dialogs.alert(result.data.message, t('files_external', 'Error generating key pair') ); + } + }); + } +}); |