summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2016-01-27 10:52:00 +0100
committerVincent Petry <pvince81@owncloud.com>2016-01-27 11:09:43 +0100
commitcfba90a78dbb011ff268ec3053f15ca764939c78 (patch)
tree2c647086202268d4e62ca5e2f11ccc85151753c6
parent1594371c8c0124af2469bd70b9b917bfd845ae19 (diff)
downloadnextcloud-server-cfba90a78dbb011ff268ec3053f15ca764939c78.tar.gz
nextcloud-server-cfba90a78dbb011ff268ec3053f15ca764939c78.zip
Fix system tags proppatch with booleans
Backbone webdav adapter now converts booleans and ints to strings. Fixed system tags to use "true" / "false" strings for booleans instead of 1 / 0.
-rw-r--r--apps/dav/lib/systemtag/systemtagplugin.php10
-rw-r--r--apps/dav/tests/unit/systemtag/systemtagplugin.php8
-rw-r--r--core/js/oc-backbone-webdav.js9
-rw-r--r--core/js/systemtags/systemtagmodel.js4
-rw-r--r--core/js/tests/specs/oc-backbone-webdavSpec.js50
5 files changed, 63 insertions, 18 deletions
diff --git a/apps/dav/lib/systemtag/systemtagplugin.php b/apps/dav/lib/systemtag/systemtagplugin.php
index e104bb8dac4..4636ed428b1 100644
--- a/apps/dav/lib/systemtag/systemtagplugin.php
+++ b/apps/dav/lib/systemtag/systemtagplugin.php
@@ -199,11 +199,11 @@ class SystemTagPlugin extends \Sabre\DAV\ServerPlugin {
});
$propFind->handle(self::USERVISIBLE_PROPERTYNAME, function() use ($node) {
- return (int)$node->getSystemTag()->isUserVisible();
+ return $node->getSystemTag()->isUserVisible() ? 'true' : 'false';
});
$propFind->handle(self::USERASSIGNABLE_PROPERTYNAME, function() use ($node) {
- return (int)$node->getSystemTag()->isUserAssignable();
+ return $node->getSystemTag()->isUserAssignable() ? 'true' : 'false';
});
}
@@ -236,11 +236,13 @@ class SystemTagPlugin extends \Sabre\DAV\ServerPlugin {
}
if (isset($props[self::USERVISIBLE_PROPERTYNAME])) {
- $userVisible = (bool)$props[self::USERVISIBLE_PROPERTYNAME];
+ $propValue = $props[self::USERVISIBLE_PROPERTYNAME];
+ $userVisible = ($propValue !== 'false' && $propValue !== '0');
}
if (isset($props[self::USERASSIGNABLE_PROPERTYNAME])) {
- $userAssignable = (bool)$props[self::USERASSIGNABLE_PROPERTYNAME];
+ $propValue = $props[self::USERASSIGNABLE_PROPERTYNAME];
+ $userAssignable = ($propValue !== 'false' && $propValue !== '0');
}
$node->update($name, $userVisible, $userAssignable);
diff --git a/apps/dav/tests/unit/systemtag/systemtagplugin.php b/apps/dav/tests/unit/systemtag/systemtagplugin.php
index 1d22af75188..873dd7088a8 100644
--- a/apps/dav/tests/unit/systemtag/systemtagplugin.php
+++ b/apps/dav/tests/unit/systemtag/systemtagplugin.php
@@ -77,8 +77,8 @@ class SystemTagPlugin extends \Test\TestCase {
200 => [
self::ID_PROPERTYNAME => '1',
self::DISPLAYNAME_PROPERTYNAME => 'Test',
- self::USERVISIBLE_PROPERTYNAME => 1,
- self::USERASSIGNABLE_PROPERTYNAME => 1,
+ self::USERVISIBLE_PROPERTYNAME => 'true',
+ self::USERASSIGNABLE_PROPERTYNAME => 'true',
]
];
@@ -133,8 +133,8 @@ class SystemTagPlugin extends \Test\TestCase {
// properties to set
$propPatch = new \Sabre\DAV\PropPatch(array(
self::DISPLAYNAME_PROPERTYNAME => 'Test changed',
- self::USERVISIBLE_PROPERTYNAME => 0,
- self::USERASSIGNABLE_PROPERTYNAME => 1,
+ self::USERVISIBLE_PROPERTYNAME => 'false',
+ self::USERASSIGNABLE_PROPERTYNAME => 'true',
));
$this->plugin->handleUpdateProperties(
diff --git a/core/js/oc-backbone-webdav.js b/core/js/oc-backbone-webdav.js
index 24a2bb50193..7c32116f011 100644
--- a/core/js/oc-backbone-webdav.js
+++ b/core/js/oc-backbone-webdav.js
@@ -127,11 +127,16 @@
var key;
for (key in attrs) {
var changedProp = davProperties[key];
+ var value = attrs[key];
if (!changedProp) {
console.warn('No matching DAV property for property "' + key);
- continue;
+ changedProp = key;
}
- props[changedProp] = attrs[key];
+ if (_.isBoolean(value) || _.isNumber(value)) {
+ // convert to string
+ value = '' + value;
+ }
+ props[changedProp] = value;
}
return props;
}
diff --git a/core/js/systemtags/systemtagmodel.js b/core/js/systemtags/systemtagmodel.js
index 62bf3a70084..b41fbdde61e 100644
--- a/core/js/systemtags/systemtagmodel.js
+++ b/core/js/systemtags/systemtagmodel.js
@@ -37,8 +37,8 @@
return {
id: data.id,
name: data.name,
- userVisible: data.userVisible === true || data.userVisible === '1',
- userAssignable: data.userAssignable === true || data.userAssignable === '1'
+ userVisible: data.userVisible === true || data.userVisible === 'true',
+ userAssignable: data.userAssignable === true || data.userAssignable === 'true'
};
}
});
diff --git a/core/js/tests/specs/oc-backbone-webdavSpec.js b/core/js/tests/specs/oc-backbone-webdavSpec.js
index 8fe0b9e8297..97281e982ce 100644
--- a/core/js/tests/specs/oc-backbone-webdavSpec.js
+++ b/core/js/tests/specs/oc-backbone-webdavSpec.js
@@ -51,6 +51,17 @@ describe('Backbone Webdav extension', function() {
davProperties: {
'firstName': '{http://owncloud.org/ns}first-name',
'lastName': '{http://owncloud.org/ns}last-name',
+ 'age': '{http://owncloud.org/ns}age',
+ 'married': '{http://owncloud.org/ns}married'
+ },
+ parse: function(data) {
+ return {
+ id: data.id,
+ firstName: data.firstName,
+ lastName: data.lastName,
+ age: parseInt(data.age, 10),
+ married: data.married === 'true' || data.married === true
+ };
}
});
TestCollection = OC.Backbone.Collection.extend({
@@ -111,7 +122,9 @@ describe('Backbone Webdav extension', function() {
expect(davClientPropFindStub.getCall(0).args[1])
.toEqual([
'{http://owncloud.org/ns}first-name',
- '{http://owncloud.org/ns}last-name'
+ '{http://owncloud.org/ns}last-name',
+ '{http://owncloud.org/ns}age',
+ '{http://owncloud.org/ns}married'
]);
expect(davClientPropFindStub.getCall(0).args[2])
.toEqual(1);
@@ -212,9 +225,20 @@ describe('Backbone Webdav extension', function() {
davProperties: {
'firstName': '{http://owncloud.org/ns}first-name',
'lastName': '{http://owncloud.org/ns}last-name',
+ 'age': '{http://owncloud.org/ns}age', // int
+ 'married': '{http://owncloud.org/ns}married', // bool
},
url: function() {
return 'http://example.com/owncloud/remote.php/test/' + this.id;
+ },
+ parse: function(data) {
+ return {
+ id: data.id,
+ firstName: data.firstName,
+ lastName: data.lastName,
+ age: parseInt(data.age, 10),
+ married: data.married === 'true' || data.married === true
+ };
}
});
});
@@ -223,11 +247,15 @@ describe('Backbone Webdav extension', function() {
var model = new TestModel({
id: '123',
firstName: 'Hello',
- lastName: 'World'
+ lastName: 'World',
+ age: 32,
+ married: false
});
model.save({
- firstName: 'Hey'
+ firstName: 'Hey',
+ age: 33,
+ married: true
});
expect(davClientPropPatchStub.calledOnce).toEqual(true);
@@ -235,7 +263,9 @@ describe('Backbone Webdav extension', function() {
.toEqual('http://example.com/owncloud/remote.php/test/123');
expect(davClientPropPatchStub.getCall(0).args[1])
.toEqual({
- '{http://owncloud.org/ns}first-name': 'Hey'
+ '{http://owncloud.org/ns}first-name': 'Hey',
+ '{http://owncloud.org/ns}age': '33',
+ '{http://owncloud.org/ns}married': 'true'
});
expect(davClientPropPatchStub.getCall(0).args[2]['X-Requested-With'])
.toEqual('XMLHttpRequest');
@@ -247,6 +277,8 @@ describe('Backbone Webdav extension', function() {
expect(model.id).toEqual('123');
expect(model.get('firstName')).toEqual('Hey');
+ expect(model.get('age')).toEqual(33);
+ expect(model.get('married')).toEqual(true);
});
it('uses PROPFIND to fetch single model', function() {
@@ -262,7 +294,9 @@ describe('Backbone Webdav extension', function() {
expect(davClientPropFindStub.getCall(0).args[1])
.toEqual([
'{http://owncloud.org/ns}first-name',
- '{http://owncloud.org/ns}last-name'
+ '{http://owncloud.org/ns}last-name',
+ '{http://owncloud.org/ns}age',
+ '{http://owncloud.org/ns}married'
]);
expect(davClientPropFindStub.getCall(0).args[2])
.toEqual(0);
@@ -277,7 +311,9 @@ describe('Backbone Webdav extension', function() {
status: 'HTTP/1.1 200 OK',
properties: {
'{http://owncloud.org/ns}first-name': 'Hello',
- '{http://owncloud.org/ns}last-name': 'World'
+ '{http://owncloud.org/ns}last-name': 'World',
+ '{http://owncloud.org/ns}age': '35',
+ '{http://owncloud.org/ns}married': 'true'
}
}]
}
@@ -286,6 +322,8 @@ describe('Backbone Webdav extension', function() {
expect(model.id).toEqual('123');
expect(model.get('firstName')).toEqual('Hello');
expect(model.get('lastName')).toEqual('World');
+ expect(model.get('age')).toEqual(35);
+ expect(model.get('married')).toEqual(true);
});
it('makes a DELETE request to destroy model', function() {
var model = new TestModel({