summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorMichael Gapczynski <mtgap@owncloud.com>2012-08-22 11:35:30 -0400
committerMichael Gapczynski <mtgap@owncloud.com>2012-08-22 11:57:58 -0400
commit9699ff03bd1a200fc7f73bb29173169d84009e5d (patch)
tree6e4ec83186cde8329f0e5c4ee36218359b33a004 /core
parent536fbb918919b3eb4c8d58b1d4e540c772353b07 (diff)
downloadnextcloud-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.php10
-rw-r--r--core/js/share.js45
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);
}
});
}