diff options
author | Michael Gapczynski <mtgap@owncloud.com> | 2012-08-22 11:35:30 -0400 |
---|---|---|
committer | Michael Gapczynski <mtgap@owncloud.com> | 2012-08-22 11:57:58 -0400 |
commit | 9699ff03bd1a200fc7f73bb29173169d84009e5d (patch) | |
tree | 6e4ec83186cde8329f0e5c4ee36218359b33a004 /core | |
parent | 536fbb918919b3eb4c8d58b1d4e540c772353b07 (diff) | |
download | nextcloud-server-9699ff03bd1a200fc7f73bb29173169d84009e5d.tar.gz nextcloud-server-9699ff03bd1a200fc7f73bb29173169d84009e5d.zip |
Revert using item name, no longer allowing the same item source exist for a user
Diffstat (limited to 'core')
-rw-r--r-- | core/ajax/share.php | 10 | ||||
-rw-r--r-- | core/js/share.js | 45 |
2 files changed, 32 insertions, 23 deletions
diff --git a/core/ajax/share.php b/core/ajax/share.php index 9376f18e8ad..04294a36ac0 100644 --- a/core/ajax/share.php +++ b/core/ajax/share.php @@ -24,9 +24,9 @@ OC_JSON::checkLoggedIn(); if (isset($_POST['action']) && isset($_POST['itemType']) && isset($_POST['itemSource'])) { switch ($_POST['action']) { case 'share': - if (isset($_POST['itemName']) && isset($_POST['shareType']) && isset($_POST['shareWith']) && isset($_POST['permissions'])) { + if (isset($_POST['shareType']) && isset($_POST['shareWith']) && isset($_POST['permissions'])) { try { - OCP\Share::shareItem($_POST['itemType'], $_POST['itemName'], $_POST['itemSource'], (int)$_POST['shareType'], $_POST['shareWith'], $_POST['permissions']); + OCP\Share::shareItem($_POST['itemType'], $_POST['itemSource'], (int)$_POST['shareType'], $_POST['shareWith'], $_POST['permissions']); // TODO May need to return private link OC_JSON::success(); } catch (Exception $exception) { @@ -56,9 +56,9 @@ if (isset($_POST['action']) && isset($_POST['itemType']) && isset($_POST['itemSo } break; case 'getItem': - if (isset($_GET['itemType']) && isset($_GET['itemName']) && isset($_GET['itemSource'])) { - $reshare = OCP\Share::getItemSharedWith($_GET['itemType'], $_GET['itemName'], OCP\Share::FORMAT_NONE, null, true); - if ($_GET['itemSource'] !== false) { + if (isset($_GET['itemType']) && isset($_GET['itemSource']) && isset($_GET['checkShares'])) { + $reshare = OCP\Share::getItemSharedWithBySource($_GET['itemType'], $_GET['itemSource'], OCP\Share::FORMAT_NONE, null, true); + if ($_GET['checkShares'] == "true") { $shares = OCP\Share::getItemShared($_GET['itemType'], $_GET['itemSource']); } else { $shares = false; diff --git a/core/js/share.js b/core/js/share.js index 418d18f86b7..c1d66ee9214 100644 --- a/core/js/share.js +++ b/core/js/share.js @@ -30,12 +30,14 @@ OC.Share={ } }); }, - loadItem:function(itemType, itemName, itemSource) { + loadItem:function(itemType, itemSource) { var data = ''; - if (typeof OC.Share.statuses[itemName] === 'undefined') { - itemSource = false; + if (typeof OC.Share.statuses[itemSource] === 'undefined') { + checkShares = false; + } else { + checkShares = true; } - $.ajax({type: 'GET', url: OC.filePath('core', 'ajax', 'share.php'), data: { fetch: 'getItem', itemType: itemType, itemName: itemName, itemSource: itemSource }, async: false, success: function(result) { + $.ajax({type: 'GET', url: OC.filePath('core', 'ajax', 'share.php'), data: { fetch: 'getItem', itemType: itemType, itemSource: itemSource, checkShares: checkShares }, async: false, success: function(result) { if (result && result.status === 'success') { data = result.data; } else { @@ -44,8 +46,8 @@ OC.Share={ }}); return data; }, - share:function(itemType, itemName, itemSource, shareType, shareWith, permissions, callback) { - $.post(OC.filePath('core', 'ajax', 'share.php'), { action: 'share', itemType: itemType, itemName: itemName, itemSource: itemSource, shareType: shareType, shareWith: shareWith, permissions: permissions }, function(result) { + share:function(itemType, itemSource, shareType, shareWith, permissions, callback) { + $.post(OC.filePath('core', 'ajax', 'share.php'), { action: 'share', itemType: itemType, itemSource: itemSource, shareType: shareType, shareWith: shareWith, permissions: permissions }, function(result) { if (result && result.status === 'success') { if (callback) { callback(result.data); @@ -73,9 +75,9 @@ OC.Share={ } }); }, - showDropDown:function(itemType, itemName, itemSource, appendTo, privateLink, possiblePermissions) { - var data = OC.Share.loadItem(itemType, itemName, itemSource); - var html = '<div id="dropdown" class="drop" data-item-type="'+itemType+'" data-item-name="'+itemName+'" data-item-source="'+itemSource+'">'; + showDropDown:function(itemType, itemSource, appendTo, privateLink, possiblePermissions) { + var data = OC.Share.loadItem(itemType, itemSource); + var html = '<div id="dropdown" class="drop" data-item-type="'+itemType+'" data-item-source="'+itemSource+'">'; if (data.reshare) { if (data.reshare.share_type == OC.Share.SHARE_TYPE_GROUP) { html += 'Shared with you and the group '+data.reshare.share_with+' by '+data.reshare.uid_owner; @@ -136,7 +138,7 @@ OC.Share={ $(this).val(shareWith); // Default permissions are Read and Share var permissions = OC.Share.PERMISSION_READ | OC.Share.PERMISSION_SHARE; - OC.Share.share($('#dropdown').data('item-type'), $('#dropdown').data('item-name'), $('#dropdown').data('item-source'), shareType, shareWith, permissions, function() { + OC.Share.share($('#dropdown').data('item-type'), $('#dropdown').data('item-source'), shareType, shareWith, permissions, function() { OC.Share.addShareWith(shareType, shareWith, permissions, possiblePermissions); $('#shareWith').val(''); }); @@ -251,9 +253,8 @@ $(document).ready(function() { $('a.share').live('click', function(event) { event.stopPropagation(); - if ($(this).data('item-type') !== undefined && $(this).data('item-name') !== undefined && $(this).data('item-source') !== undefined) { + if ($(this).data('item-type') !== undefined && $(this).data('item-source') !== undefined) { var itemType = $(this).data('item-type'); - var itemName = $(this).data('item-name'); var itemSource = $(this).data('item-source'); var appendTo = $(this).parent().parent(); var privateLink = false; @@ -264,13 +265,13 @@ $(document).ready(function() { if (OC.Share.droppedDown) { if (item != $('#dropdown').data('item')) { OC.Share.hideDropDown(function () { - OC.Share.showDropDown(itemType, itemName, itemSource, appendTo, privateLink, possiblePermissions); + OC.Share.showDropDown(itemType, itemSource, appendTo, privateLink, possiblePermissions); }); } else { OC.Share.hideDropDown(); } } else { - OC.Share.showDropDown(itemType, itemName, itemSource, appendTo, privateLink, possiblePermissions); + OC.Share.showDropDown(itemType, itemSource, appendTo, privateLink, possiblePermissions); } } }); @@ -280,7 +281,11 @@ $(document).ready(function() { FileActions.register('all', 'Share', FileActions.PERMISSION_SHARE, function(filename) { // Return the correct sharing icon if (scanFiles.scanning) { return; } // workaround to prevent additional http request block scanning feedback - var item = $('#dir').val() + filename; + if ($('#dir').val() == '/') { + var item = $('#dir').val() + filename; + } else { + var item = $('#dir').val() + '/' + filename; + } // Check if status is in cache if (OC.Share.statuses[item] === true) { return OC.imagePath('core', 'actions/public'); @@ -302,7 +307,11 @@ $(document).ready(function() { return OC.imagePath('core', 'actions/share'); } }, function(filename) { - var item = $('#dir').val() + filename; + if ($('#dir').val() == '/') { + var item = $('#dir').val() + filename; + } else { + var item = $('#dir').val() + '/' + filename; + } if ($('tr').filterAttr('data-file', filename).data('type') == 'dir') { var itemType = 'folder'; var possiblePermissions = OC.Share.PERMISSION_CREATE | OC.Share.PERMISSION_UPDATE | OC.Share.PERMISSION_DELETE | OC.Share.PERMISSION_SHARE; @@ -316,14 +325,14 @@ $(document).ready(function() { if (item != $('#dropdown').data('item')) { OC.Share.hideDropDown(function () { $('tr').filterAttr('data-file', filename).addClass('mouseOver'); - OC.Share.showDropDown(itemType, '/'+filename, item, appendTo, true, possiblePermissions); + OC.Share.showDropDown(itemType, item, appendTo, true, possiblePermissions); }); } else { OC.Share.hideDropDown(); } } else { $('tr').filterAttr('data-file',filename).addClass('mouseOver'); - OC.Share.showDropDown(itemType, '/'+filename, item, appendTo, true, possiblePermissions); + OC.Share.showDropDown(itemType, item, appendTo, true, possiblePermissions); } }); } |