Passed
Push — master ( 8555d5...a51f0d )
by John
14:05 queued 13s
created
apps/dav/lib/CalDAV/PublicCalendarObject.php 1 patch
Indentation   +7 added lines, -7 removed lines patch added patch discarded remove patch
@@ -23,11 +23,11 @@
 block discarded – undo
23 23
 
24 24
 class PublicCalendarObject extends CalendarObject {
25 25
 
26
-	/**
27
-	 * public calendars are always shared
28
-	 * @return bool
29
-	 */
30
-	protected function isShared() {
31
-		return true;
32
-	}
26
+    /**
27
+     * public calendars are always shared
28
+     * @return bool
29
+     */
30
+    protected function isShared() {
31
+        return true;
32
+    }
33 33
 }
Please login to merge, or discard this patch.
apps/dav/lib/CalDAV/Search/Xml/Filter/SearchTermFilter.php 2 patches
Indentation   +12 added lines, -12 removed lines patch added patch discarded remove patch
@@ -27,17 +27,17 @@
 block discarded – undo
27 27
 
28 28
 class SearchTermFilter implements XmlDeserializable {
29 29
 
30
-	/**
31
-	 * @param Reader $reader
32
-	 * @throws BadRequest
33
-	 * @return string
34
-	 */
35
-	public static function xmlDeserialize(Reader $reader) {
36
-		$value = $reader->parseInnerTree();
37
-		if (!is_string($value)) {
38
-			throw new BadRequest('The {' . SearchPlugin::NS_Nextcloud . '}search-term has illegal value');
39
-		}
30
+    /**
31
+     * @param Reader $reader
32
+     * @throws BadRequest
33
+     * @return string
34
+     */
35
+    public static function xmlDeserialize(Reader $reader) {
36
+        $value = $reader->parseInnerTree();
37
+        if (!is_string($value)) {
38
+            throw new BadRequest('The {' . SearchPlugin::NS_Nextcloud . '}search-term has illegal value');
39
+        }
40 40
 
41
-		return $value;
42
-	}
41
+        return $value;
42
+    }
43 43
 }
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -35,7 +35,7 @@
 block discarded – undo
35 35
 	public static function xmlDeserialize(Reader $reader) {
36 36
 		$value = $reader->parseInnerTree();
37 37
 		if (!is_string($value)) {
38
-			throw new BadRequest('The {' . SearchPlugin::NS_Nextcloud . '}search-term has illegal value');
38
+			throw new BadRequest('The {'.SearchPlugin::NS_Nextcloud.'}search-term has illegal value');
39 39
 		}
40 40
 
41 41
 		return $value;
Please login to merge, or discard this patch.
apps/dav/lib/SystemTag/SystemTagsByIdCollection.php 2 patches
Indentation   +140 added lines, -140 removed lines patch added patch discarded remove patch
@@ -35,144 +35,144 @@
 block discarded – undo
35 35
 
36 36
 class SystemTagsByIdCollection implements ICollection {
37 37
 
38
-	/**
39
-	 * @var ISystemTagManager
40
-	 */
41
-	private $tagManager;
42
-
43
-	/**
44
-	 * @var IGroupManager
45
-	 */
46
-	private $groupManager;
47
-
48
-	/**
49
-	 * @var IUserSession
50
-	 */
51
-	private $userSession;
52
-
53
-	/**
54
-	 * SystemTagsByIdCollection constructor.
55
-	 *
56
-	 * @param ISystemTagManager $tagManager
57
-	 * @param IUserSession $userSession
58
-	 * @param IGroupManager $groupManager
59
-	 */
60
-	public function __construct(
61
-		ISystemTagManager $tagManager,
62
-		IUserSession $userSession,
63
-		IGroupManager $groupManager
64
-	) {
65
-		$this->tagManager = $tagManager;
66
-		$this->userSession = $userSession;
67
-		$this->groupManager = $groupManager;
68
-	}
69
-
70
-	/**
71
-	 * Returns whether the currently logged in user is an administrator
72
-	 *
73
-	 * @return bool true if the user is an admin
74
-	 */
75
-	private function isAdmin() {
76
-		$user = $this->userSession->getUser();
77
-		if ($user !== null) {
78
-			return $this->groupManager->isAdmin($user->getUID());
79
-		}
80
-		return false;
81
-	}
82
-
83
-	/**
84
-	 * @param string $name
85
-	 * @param resource|string $data Initial payload
86
-	 * @throws Forbidden
87
-	 */
88
-	public function createFile($name, $data = null) {
89
-		throw new Forbidden('Cannot create tags by id');
90
-	}
91
-
92
-	/**
93
-	 * @param string $name
94
-	 */
95
-	public function createDirectory($name) {
96
-		throw new Forbidden('Permission denied to create collections');
97
-	}
98
-
99
-	/**
100
-	 * @param string $name
101
-	 */
102
-	public function getChild($name) {
103
-		try {
104
-			$tag = $this->tagManager->getTagsByIds([$name]);
105
-			$tag = current($tag);
106
-			if (!$this->tagManager->canUserSeeTag($tag, $this->userSession->getUser())) {
107
-				throw new NotFound('Tag with id ' . $name . ' not found');
108
-			}
109
-			return $this->makeNode($tag);
110
-		} catch (\InvalidArgumentException $e) {
111
-			throw new BadRequest('Invalid tag id', 0, $e);
112
-		} catch (TagNotFoundException $e) {
113
-			throw new NotFound('Tag with id ' . $name . ' not found', 0, $e);
114
-		}
115
-	}
116
-
117
-	public function getChildren() {
118
-		$visibilityFilter = true;
119
-		if ($this->isAdmin()) {
120
-			$visibilityFilter = null;
121
-		}
122
-
123
-		$tags = $this->tagManager->getAllTags($visibilityFilter);
124
-		return array_map(function ($tag) {
125
-			return $this->makeNode($tag);
126
-		}, $tags);
127
-	}
128
-
129
-	/**
130
-	 * @param string $name
131
-	 */
132
-	public function childExists($name) {
133
-		try {
134
-			$tag = $this->tagManager->getTagsByIds([$name]);
135
-			$tag = current($tag);
136
-			if (!$this->tagManager->canUserSeeTag($tag, $this->userSession->getUser())) {
137
-				return false;
138
-			}
139
-			return true;
140
-		} catch (\InvalidArgumentException $e) {
141
-			throw new BadRequest('Invalid tag id', 0, $e);
142
-		} catch (TagNotFoundException $e) {
143
-			return false;
144
-		}
145
-	}
146
-
147
-	public function delete() {
148
-		throw new Forbidden('Permission denied to delete this collection');
149
-	}
150
-
151
-	public function getName() {
152
-		return 'systemtags';
153
-	}
154
-
155
-	public function setName($name) {
156
-		throw new Forbidden('Permission denied to rename this collection');
157
-	}
158
-
159
-	/**
160
-	 * Returns the last modification time, as a unix timestamp
161
-	 *
162
-	 * @return int
163
-	 */
164
-	public function getLastModified() {
165
-		return null;
166
-	}
167
-
168
-	/**
169
-	 * Create a sabre node for the given system tag
170
-	 *
171
-	 * @param ISystemTag $tag
172
-	 *
173
-	 * @return SystemTagNode
174
-	 */
175
-	private function makeNode(ISystemTag $tag) {
176
-		return new SystemTagNode($tag, $this->userSession->getUser(), $this->isAdmin(), $this->tagManager);
177
-	}
38
+    /**
39
+     * @var ISystemTagManager
40
+     */
41
+    private $tagManager;
42
+
43
+    /**
44
+     * @var IGroupManager
45
+     */
46
+    private $groupManager;
47
+
48
+    /**
49
+     * @var IUserSession
50
+     */
51
+    private $userSession;
52
+
53
+    /**
54
+     * SystemTagsByIdCollection constructor.
55
+     *
56
+     * @param ISystemTagManager $tagManager
57
+     * @param IUserSession $userSession
58
+     * @param IGroupManager $groupManager
59
+     */
60
+    public function __construct(
61
+        ISystemTagManager $tagManager,
62
+        IUserSession $userSession,
63
+        IGroupManager $groupManager
64
+    ) {
65
+        $this->tagManager = $tagManager;
66
+        $this->userSession = $userSession;
67
+        $this->groupManager = $groupManager;
68
+    }
69
+
70
+    /**
71
+     * Returns whether the currently logged in user is an administrator
72
+     *
73
+     * @return bool true if the user is an admin
74
+     */
75
+    private function isAdmin() {
76
+        $user = $this->userSession->getUser();
77
+        if ($user !== null) {
78
+            return $this->groupManager->isAdmin($user->getUID());
79
+        }
80
+        return false;
81
+    }
82
+
83
+    /**
84
+     * @param string $name
85
+     * @param resource|string $data Initial payload
86
+     * @throws Forbidden
87
+     */
88
+    public function createFile($name, $data = null) {
89
+        throw new Forbidden('Cannot create tags by id');
90
+    }
91
+
92
+    /**
93
+     * @param string $name
94
+     */
95
+    public function createDirectory($name) {
96
+        throw new Forbidden('Permission denied to create collections');
97
+    }
98
+
99
+    /**
100
+     * @param string $name
101
+     */
102
+    public function getChild($name) {
103
+        try {
104
+            $tag = $this->tagManager->getTagsByIds([$name]);
105
+            $tag = current($tag);
106
+            if (!$this->tagManager->canUserSeeTag($tag, $this->userSession->getUser())) {
107
+                throw new NotFound('Tag with id ' . $name . ' not found');
108
+            }
109
+            return $this->makeNode($tag);
110
+        } catch (\InvalidArgumentException $e) {
111
+            throw new BadRequest('Invalid tag id', 0, $e);
112
+        } catch (TagNotFoundException $e) {
113
+            throw new NotFound('Tag with id ' . $name . ' not found', 0, $e);
114
+        }
115
+    }
116
+
117
+    public function getChildren() {
118
+        $visibilityFilter = true;
119
+        if ($this->isAdmin()) {
120
+            $visibilityFilter = null;
121
+        }
122
+
123
+        $tags = $this->tagManager->getAllTags($visibilityFilter);
124
+        return array_map(function ($tag) {
125
+            return $this->makeNode($tag);
126
+        }, $tags);
127
+    }
128
+
129
+    /**
130
+     * @param string $name
131
+     */
132
+    public function childExists($name) {
133
+        try {
134
+            $tag = $this->tagManager->getTagsByIds([$name]);
135
+            $tag = current($tag);
136
+            if (!$this->tagManager->canUserSeeTag($tag, $this->userSession->getUser())) {
137
+                return false;
138
+            }
139
+            return true;
140
+        } catch (\InvalidArgumentException $e) {
141
+            throw new BadRequest('Invalid tag id', 0, $e);
142
+        } catch (TagNotFoundException $e) {
143
+            return false;
144
+        }
145
+    }
146
+
147
+    public function delete() {
148
+        throw new Forbidden('Permission denied to delete this collection');
149
+    }
150
+
151
+    public function getName() {
152
+        return 'systemtags';
153
+    }
154
+
155
+    public function setName($name) {
156
+        throw new Forbidden('Permission denied to rename this collection');
157
+    }
158
+
159
+    /**
160
+     * Returns the last modification time, as a unix timestamp
161
+     *
162
+     * @return int
163
+     */
164
+    public function getLastModified() {
165
+        return null;
166
+    }
167
+
168
+    /**
169
+     * Create a sabre node for the given system tag
170
+     *
171
+     * @param ISystemTag $tag
172
+     *
173
+     * @return SystemTagNode
174
+     */
175
+    private function makeNode(ISystemTag $tag) {
176
+        return new SystemTagNode($tag, $this->userSession->getUser(), $this->isAdmin(), $this->tagManager);
177
+    }
178 178
 }
Please login to merge, or discard this patch.
Spacing   +3 added lines, -3 removed lines patch added patch discarded remove patch
@@ -104,13 +104,13 @@  discard block
 block discarded – undo
104 104
 			$tag = $this->tagManager->getTagsByIds([$name]);
105 105
 			$tag = current($tag);
106 106
 			if (!$this->tagManager->canUserSeeTag($tag, $this->userSession->getUser())) {
107
-				throw new NotFound('Tag with id ' . $name . ' not found');
107
+				throw new NotFound('Tag with id '.$name.' not found');
108 108
 			}
109 109
 			return $this->makeNode($tag);
110 110
 		} catch (\InvalidArgumentException $e) {
111 111
 			throw new BadRequest('Invalid tag id', 0, $e);
112 112
 		} catch (TagNotFoundException $e) {
113
-			throw new NotFound('Tag with id ' . $name . ' not found', 0, $e);
113
+			throw new NotFound('Tag with id '.$name.' not found', 0, $e);
114 114
 		}
115 115
 	}
116 116
 
@@ -121,7 +121,7 @@  discard block
 block discarded – undo
121 121
 		}
122 122
 
123 123
 		$tags = $this->tagManager->getAllTags($visibilityFilter);
124
-		return array_map(function ($tag) {
124
+		return array_map(function($tag) {
125 125
 			return $this->makeNode($tag);
126 126
 		}, $tags);
127 127
 	}
Please login to merge, or discard this patch.
apps/dav/lib/SystemTag/SystemTagPlugin.php 2 patches
Spacing   +11 added lines, -11 removed lines patch added patch discarded remove patch
@@ -133,7 +133,7 @@  discard block
 block discarded – undo
133 133
 			if ($node instanceof SystemTagsObjectMappingCollection) {
134 134
 				// also add to collection
135 135
 				$node->createFile($tag->getId());
136
-				$url = $request->getBaseUrl() . 'systemtags/';
136
+				$url = $request->getBaseUrl().'systemtags/';
137 137
 			} else {
138 138
 				$url = $request->getUrl();
139 139
 			}
@@ -142,7 +142,7 @@  discard block
 block discarded – undo
142 142
 				$url .= '/';
143 143
 			}
144 144
 
145
-			$response->setHeader('Content-Location', $url . $tag->getId());
145
+			$response->setHeader('Content-Location', $url.$tag->getId());
146 146
 
147 147
 			// created
148 148
 			$response->setStatus(201);
@@ -177,11 +177,11 @@  discard block
 block discarded – undo
177 177
 		$userAssignable = true;
178 178
 
179 179
 		if (isset($data['userVisible'])) {
180
-			$userVisible = (bool)$data['userVisible'];
180
+			$userVisible = (bool) $data['userVisible'];
181 181
 		}
182 182
 
183 183
 		if (isset($data['userAssignable'])) {
184
-			$userAssignable = (bool)$data['userAssignable'];
184
+			$userAssignable = (bool) $data['userAssignable'];
185 185
 		}
186 186
 
187 187
 		$groups = [];
@@ -224,29 +224,29 @@  discard block
 block discarded – undo
224 224
 			return;
225 225
 		}
226 226
 
227
-		$propFind->handle(self::ID_PROPERTYNAME, function () use ($node) {
227
+		$propFind->handle(self::ID_PROPERTYNAME, function() use ($node) {
228 228
 			return $node->getSystemTag()->getId();
229 229
 		});
230 230
 
231
-		$propFind->handle(self::DISPLAYNAME_PROPERTYNAME, function () use ($node) {
231
+		$propFind->handle(self::DISPLAYNAME_PROPERTYNAME, function() use ($node) {
232 232
 			return $node->getSystemTag()->getName();
233 233
 		});
234 234
 
235
-		$propFind->handle(self::USERVISIBLE_PROPERTYNAME, function () use ($node) {
235
+		$propFind->handle(self::USERVISIBLE_PROPERTYNAME, function() use ($node) {
236 236
 			return $node->getSystemTag()->isUserVisible() ? 'true' : 'false';
237 237
 		});
238 238
 
239
-		$propFind->handle(self::USERASSIGNABLE_PROPERTYNAME, function () use ($node) {
239
+		$propFind->handle(self::USERASSIGNABLE_PROPERTYNAME, function() use ($node) {
240 240
 			// this is the tag's inherent property "is user assignable"
241 241
 			return $node->getSystemTag()->isUserAssignable() ? 'true' : 'false';
242 242
 		});
243 243
 
244
-		$propFind->handle(self::CANASSIGN_PROPERTYNAME, function () use ($node) {
244
+		$propFind->handle(self::CANASSIGN_PROPERTYNAME, function() use ($node) {
245 245
 			// this is the effective permission for the current user
246 246
 			return $this->tagManager->canUserAssignTag($node->getSystemTag(), $this->userSession->getUser()) ? 'true' : 'false';
247 247
 		});
248 248
 
249
-		$propFind->handle(self::GROUPS_PROPERTYNAME, function () use ($node) {
249
+		$propFind->handle(self::GROUPS_PROPERTYNAME, function() use ($node) {
250 250
 			if (!$this->groupManager->isAdmin($this->userSession->getUser()->getUID())) {
251 251
 				// property only available for admins
252 252
 				throw new Forbidden();
@@ -279,7 +279,7 @@  discard block
 block discarded – undo
279 279
 			self::USERVISIBLE_PROPERTYNAME,
280 280
 			self::USERASSIGNABLE_PROPERTYNAME,
281 281
 			self::GROUPS_PROPERTYNAME,
282
-		], function ($props) use ($node) {
282
+		], function($props) use ($node) {
283 283
 			$tag = $node->getSystemTag();
284 284
 			$name = $tag->getName();
285 285
 			$userVisible = $tag->isUserVisible();
Please login to merge, or discard this patch.
Indentation   +274 added lines, -274 removed lines patch added patch discarded remove patch
@@ -49,278 +49,278 @@
 block discarded – undo
49 49
  */
50 50
 class SystemTagPlugin extends \Sabre\DAV\ServerPlugin {
51 51
 
52
-	// namespace
53
-	public const NS_OWNCLOUD = 'http://owncloud.org/ns';
54
-	public const ID_PROPERTYNAME = '{http://owncloud.org/ns}id';
55
-	public const DISPLAYNAME_PROPERTYNAME = '{http://owncloud.org/ns}display-name';
56
-	public const USERVISIBLE_PROPERTYNAME = '{http://owncloud.org/ns}user-visible';
57
-	public const USERASSIGNABLE_PROPERTYNAME = '{http://owncloud.org/ns}user-assignable';
58
-	public const GROUPS_PROPERTYNAME = '{http://owncloud.org/ns}groups';
59
-	public const CANASSIGN_PROPERTYNAME = '{http://owncloud.org/ns}can-assign';
60
-
61
-	/**
62
-	 * @var \Sabre\DAV\Server $server
63
-	 */
64
-	private $server;
65
-
66
-	/**
67
-	 * @var ISystemTagManager
68
-	 */
69
-	protected $tagManager;
70
-
71
-	/**
72
-	 * @var IUserSession
73
-	 */
74
-	protected $userSession;
75
-
76
-	/**
77
-	 * @var IGroupManager
78
-	 */
79
-	protected $groupManager;
80
-
81
-	/**
82
-	 * @param ISystemTagManager $tagManager tag manager
83
-	 * @param IGroupManager $groupManager
84
-	 * @param IUserSession $userSession
85
-	 */
86
-	public function __construct(ISystemTagManager $tagManager,
87
-								IGroupManager $groupManager,
88
-								IUserSession $userSession) {
89
-		$this->tagManager = $tagManager;
90
-		$this->userSession = $userSession;
91
-		$this->groupManager = $groupManager;
92
-	}
93
-
94
-	/**
95
-	 * This initializes the plugin.
96
-	 *
97
-	 * This function is called by \Sabre\DAV\Server, after
98
-	 * addPlugin is called.
99
-	 *
100
-	 * This method should set up the required event subscriptions.
101
-	 *
102
-	 * @param \Sabre\DAV\Server $server
103
-	 * @return void
104
-	 */
105
-	public function initialize(\Sabre\DAV\Server $server) {
106
-		$server->xml->namespaceMap[self::NS_OWNCLOUD] = 'oc';
107
-
108
-		$server->protectedProperties[] = self::ID_PROPERTYNAME;
109
-
110
-		$server->on('propFind', [$this, 'handleGetProperties']);
111
-		$server->on('propPatch', [$this, 'handleUpdateProperties']);
112
-		$server->on('method:POST', [$this, 'httpPost']);
113
-
114
-		$this->server = $server;
115
-	}
116
-
117
-	/**
118
-	 * POST operation on system tag collections
119
-	 *
120
-	 * @param RequestInterface $request request object
121
-	 * @param ResponseInterface $response response object
122
-	 * @return null|false
123
-	 */
124
-	public function httpPost(RequestInterface $request, ResponseInterface $response) {
125
-		$path = $request->getPath();
126
-
127
-		// Making sure the node exists
128
-		$node = $this->server->tree->getNodeForPath($path);
129
-		if ($node instanceof SystemTagsByIdCollection || $node instanceof SystemTagsObjectMappingCollection) {
130
-			$data = $request->getBodyAsString();
131
-
132
-			$tag = $this->createTag($data, $request->getHeader('Content-Type'));
133
-
134
-			if ($node instanceof SystemTagsObjectMappingCollection) {
135
-				// also add to collection
136
-				$node->createFile($tag->getId());
137
-				$url = $request->getBaseUrl() . 'systemtags/';
138
-			} else {
139
-				$url = $request->getUrl();
140
-			}
141
-
142
-			if ($url[strlen($url) - 1] !== '/') {
143
-				$url .= '/';
144
-			}
145
-
146
-			$response->setHeader('Content-Location', $url . $tag->getId());
147
-
148
-			// created
149
-			$response->setStatus(201);
150
-			return false;
151
-		}
152
-	}
153
-
154
-	/**
155
-	 * Creates a new tag
156
-	 *
157
-	 * @param string $data JSON encoded string containing the properties of the tag to create
158
-	 * @param string $contentType content type of the data
159
-	 * @return ISystemTag newly created system tag
160
-	 *
161
-	 * @throws BadRequest if a field was missing
162
-	 * @throws Conflict if a tag with the same properties already exists
163
-	 * @throws UnsupportedMediaType if the content type is not supported
164
-	 */
165
-	private function createTag($data, $contentType = 'application/json') {
166
-		if (explode(';', $contentType)[0] === 'application/json') {
167
-			$data = json_decode($data, true);
168
-		} else {
169
-			throw new UnsupportedMediaType();
170
-		}
171
-
172
-		if (!isset($data['name'])) {
173
-			throw new BadRequest('Missing "name" attribute');
174
-		}
175
-
176
-		$tagName = $data['name'];
177
-		$userVisible = true;
178
-		$userAssignable = true;
179
-
180
-		if (isset($data['userVisible'])) {
181
-			$userVisible = (bool)$data['userVisible'];
182
-		}
183
-
184
-		if (isset($data['userAssignable'])) {
185
-			$userAssignable = (bool)$data['userAssignable'];
186
-		}
187
-
188
-		$groups = [];
189
-		if (isset($data['groups'])) {
190
-			$groups = $data['groups'];
191
-			if (is_string($groups)) {
192
-				$groups = explode('|', $groups);
193
-			}
194
-		}
195
-
196
-		if ($userVisible === false || $userAssignable === false || !empty($groups)) {
197
-			if (!$this->userSession->isLoggedIn() || !$this->groupManager->isAdmin($this->userSession->getUser()->getUID())) {
198
-				throw new BadRequest('Not sufficient permissions');
199
-			}
200
-		}
201
-
202
-		try {
203
-			$tag = $this->tagManager->createTag($tagName, $userVisible, $userAssignable);
204
-			if (!empty($groups)) {
205
-				$this->tagManager->setTagGroups($tag, $groups);
206
-			}
207
-			return $tag;
208
-		} catch (TagAlreadyExistsException $e) {
209
-			throw new Conflict('Tag already exists', 0, $e);
210
-		}
211
-	}
212
-
213
-
214
-	/**
215
-	 * Retrieves system tag properties
216
-	 *
217
-	 * @param PropFind $propFind
218
-	 * @param \Sabre\DAV\INode $node
219
-	 */
220
-	public function handleGetProperties(
221
-		PropFind $propFind,
222
-		\Sabre\DAV\INode $node
223
-	) {
224
-		if (!($node instanceof SystemTagNode) && !($node instanceof SystemTagMappingNode)) {
225
-			return;
226
-		}
227
-
228
-		$propFind->handle(self::ID_PROPERTYNAME, function () use ($node) {
229
-			return $node->getSystemTag()->getId();
230
-		});
231
-
232
-		$propFind->handle(self::DISPLAYNAME_PROPERTYNAME, function () use ($node) {
233
-			return $node->getSystemTag()->getName();
234
-		});
235
-
236
-		$propFind->handle(self::USERVISIBLE_PROPERTYNAME, function () use ($node) {
237
-			return $node->getSystemTag()->isUserVisible() ? 'true' : 'false';
238
-		});
239
-
240
-		$propFind->handle(self::USERASSIGNABLE_PROPERTYNAME, function () use ($node) {
241
-			// this is the tag's inherent property "is user assignable"
242
-			return $node->getSystemTag()->isUserAssignable() ? 'true' : 'false';
243
-		});
244
-
245
-		$propFind->handle(self::CANASSIGN_PROPERTYNAME, function () use ($node) {
246
-			// this is the effective permission for the current user
247
-			return $this->tagManager->canUserAssignTag($node->getSystemTag(), $this->userSession->getUser()) ? 'true' : 'false';
248
-		});
249
-
250
-		$propFind->handle(self::GROUPS_PROPERTYNAME, function () use ($node) {
251
-			if (!$this->groupManager->isAdmin($this->userSession->getUser()->getUID())) {
252
-				// property only available for admins
253
-				throw new Forbidden();
254
-			}
255
-			$groups = [];
256
-			// no need to retrieve groups for namespaces that don't qualify
257
-			if ($node->getSystemTag()->isUserVisible() && !$node->getSystemTag()->isUserAssignable()) {
258
-				$groups = $this->tagManager->getTagGroups($node->getSystemTag());
259
-			}
260
-			return implode('|', $groups);
261
-		});
262
-	}
263
-
264
-	/**
265
-	 * Updates tag attributes
266
-	 *
267
-	 * @param string $path
268
-	 * @param PropPatch $propPatch
269
-	 *
270
-	 * @return void
271
-	 */
272
-	public function handleUpdateProperties($path, PropPatch $propPatch) {
273
-		$node = $this->server->tree->getNodeForPath($path);
274
-		if (!($node instanceof SystemTagNode)) {
275
-			return;
276
-		}
277
-
278
-		$propPatch->handle([
279
-			self::DISPLAYNAME_PROPERTYNAME,
280
-			self::USERVISIBLE_PROPERTYNAME,
281
-			self::USERASSIGNABLE_PROPERTYNAME,
282
-			self::GROUPS_PROPERTYNAME,
283
-		], function ($props) use ($node) {
284
-			$tag = $node->getSystemTag();
285
-			$name = $tag->getName();
286
-			$userVisible = $tag->isUserVisible();
287
-			$userAssignable = $tag->isUserAssignable();
288
-
289
-			$updateTag = false;
290
-
291
-			if (isset($props[self::DISPLAYNAME_PROPERTYNAME])) {
292
-				$name = $props[self::DISPLAYNAME_PROPERTYNAME];
293
-				$updateTag = true;
294
-			}
295
-
296
-			if (isset($props[self::USERVISIBLE_PROPERTYNAME])) {
297
-				$propValue = $props[self::USERVISIBLE_PROPERTYNAME];
298
-				$userVisible = ($propValue !== 'false' && $propValue !== '0');
299
-				$updateTag = true;
300
-			}
301
-
302
-			if (isset($props[self::USERASSIGNABLE_PROPERTYNAME])) {
303
-				$propValue = $props[self::USERASSIGNABLE_PROPERTYNAME];
304
-				$userAssignable = ($propValue !== 'false' && $propValue !== '0');
305
-				$updateTag = true;
306
-			}
307
-
308
-			if (isset($props[self::GROUPS_PROPERTYNAME])) {
309
-				if (!$this->groupManager->isAdmin($this->userSession->getUser()->getUID())) {
310
-					// property only available for admins
311
-					throw new Forbidden();
312
-				}
313
-
314
-				$propValue = $props[self::GROUPS_PROPERTYNAME];
315
-				$groupIds = explode('|', $propValue);
316
-				$this->tagManager->setTagGroups($tag, $groupIds);
317
-			}
318
-
319
-			if ($updateTag) {
320
-				$node->update($name, $userVisible, $userAssignable);
321
-			}
322
-
323
-			return true;
324
-		});
325
-	}
52
+    // namespace
53
+    public const NS_OWNCLOUD = 'http://owncloud.org/ns';
54
+    public const ID_PROPERTYNAME = '{http://owncloud.org/ns}id';
55
+    public const DISPLAYNAME_PROPERTYNAME = '{http://owncloud.org/ns}display-name';
56
+    public const USERVISIBLE_PROPERTYNAME = '{http://owncloud.org/ns}user-visible';
57
+    public const USERASSIGNABLE_PROPERTYNAME = '{http://owncloud.org/ns}user-assignable';
58
+    public const GROUPS_PROPERTYNAME = '{http://owncloud.org/ns}groups';
59
+    public const CANASSIGN_PROPERTYNAME = '{http://owncloud.org/ns}can-assign';
60
+
61
+    /**
62
+     * @var \Sabre\DAV\Server $server
63
+     */
64
+    private $server;
65
+
66
+    /**
67
+     * @var ISystemTagManager
68
+     */
69
+    protected $tagManager;
70
+
71
+    /**
72
+     * @var IUserSession
73
+     */
74
+    protected $userSession;
75
+
76
+    /**
77
+     * @var IGroupManager
78
+     */
79
+    protected $groupManager;
80
+
81
+    /**
82
+     * @param ISystemTagManager $tagManager tag manager
83
+     * @param IGroupManager $groupManager
84
+     * @param IUserSession $userSession
85
+     */
86
+    public function __construct(ISystemTagManager $tagManager,
87
+                                IGroupManager $groupManager,
88
+                                IUserSession $userSession) {
89
+        $this->tagManager = $tagManager;
90
+        $this->userSession = $userSession;
91
+        $this->groupManager = $groupManager;
92
+    }
93
+
94
+    /**
95
+     * This initializes the plugin.
96
+     *
97
+     * This function is called by \Sabre\DAV\Server, after
98
+     * addPlugin is called.
99
+     *
100
+     * This method should set up the required event subscriptions.
101
+     *
102
+     * @param \Sabre\DAV\Server $server
103
+     * @return void
104
+     */
105
+    public function initialize(\Sabre\DAV\Server $server) {
106
+        $server->xml->namespaceMap[self::NS_OWNCLOUD] = 'oc';
107
+
108
+        $server->protectedProperties[] = self::ID_PROPERTYNAME;
109
+
110
+        $server->on('propFind', [$this, 'handleGetProperties']);
111
+        $server->on('propPatch', [$this, 'handleUpdateProperties']);
112
+        $server->on('method:POST', [$this, 'httpPost']);
113
+
114
+        $this->server = $server;
115
+    }
116
+
117
+    /**
118
+     * POST operation on system tag collections
119
+     *
120
+     * @param RequestInterface $request request object
121
+     * @param ResponseInterface $response response object
122
+     * @return null|false
123
+     */
124
+    public function httpPost(RequestInterface $request, ResponseInterface $response) {
125
+        $path = $request->getPath();
126
+
127
+        // Making sure the node exists
128
+        $node = $this->server->tree->getNodeForPath($path);
129
+        if ($node instanceof SystemTagsByIdCollection || $node instanceof SystemTagsObjectMappingCollection) {
130
+            $data = $request->getBodyAsString();
131
+
132
+            $tag = $this->createTag($data, $request->getHeader('Content-Type'));
133
+
134
+            if ($node instanceof SystemTagsObjectMappingCollection) {
135
+                // also add to collection
136
+                $node->createFile($tag->getId());
137
+                $url = $request->getBaseUrl() . 'systemtags/';
138
+            } else {
139
+                $url = $request->getUrl();
140
+            }
141
+
142
+            if ($url[strlen($url) - 1] !== '/') {
143
+                $url .= '/';
144
+            }
145
+
146
+            $response->setHeader('Content-Location', $url . $tag->getId());
147
+
148
+            // created
149
+            $response->setStatus(201);
150
+            return false;
151
+        }
152
+    }
153
+
154
+    /**
155
+     * Creates a new tag
156
+     *
157
+     * @param string $data JSON encoded string containing the properties of the tag to create
158
+     * @param string $contentType content type of the data
159
+     * @return ISystemTag newly created system tag
160
+     *
161
+     * @throws BadRequest if a field was missing
162
+     * @throws Conflict if a tag with the same properties already exists
163
+     * @throws UnsupportedMediaType if the content type is not supported
164
+     */
165
+    private function createTag($data, $contentType = 'application/json') {
166
+        if (explode(';', $contentType)[0] === 'application/json') {
167
+            $data = json_decode($data, true);
168
+        } else {
169
+            throw new UnsupportedMediaType();
170
+        }
171
+
172
+        if (!isset($data['name'])) {
173
+            throw new BadRequest('Missing "name" attribute');
174
+        }
175
+
176
+        $tagName = $data['name'];
177
+        $userVisible = true;
178
+        $userAssignable = true;
179
+
180
+        if (isset($data['userVisible'])) {
181
+            $userVisible = (bool)$data['userVisible'];
182
+        }
183
+
184
+        if (isset($data['userAssignable'])) {
185
+            $userAssignable = (bool)$data['userAssignable'];
186
+        }
187
+
188
+        $groups = [];
189
+        if (isset($data['groups'])) {
190
+            $groups = $data['groups'];
191
+            if (is_string($groups)) {
192
+                $groups = explode('|', $groups);
193
+            }
194
+        }
195
+
196
+        if ($userVisible === false || $userAssignable === false || !empty($groups)) {
197
+            if (!$this->userSession->isLoggedIn() || !$this->groupManager->isAdmin($this->userSession->getUser()->getUID())) {
198
+                throw new BadRequest('Not sufficient permissions');
199
+            }
200
+        }
201
+
202
+        try {
203
+            $tag = $this->tagManager->createTag($tagName, $userVisible, $userAssignable);
204
+            if (!empty($groups)) {
205
+                $this->tagManager->setTagGroups($tag, $groups);
206
+            }
207
+            return $tag;
208
+        } catch (TagAlreadyExistsException $e) {
209
+            throw new Conflict('Tag already exists', 0, $e);
210
+        }
211
+    }
212
+
213
+
214
+    /**
215
+     * Retrieves system tag properties
216
+     *
217
+     * @param PropFind $propFind
218
+     * @param \Sabre\DAV\INode $node
219
+     */
220
+    public function handleGetProperties(
221
+        PropFind $propFind,
222
+        \Sabre\DAV\INode $node
223
+    ) {
224
+        if (!($node instanceof SystemTagNode) && !($node instanceof SystemTagMappingNode)) {
225
+            return;
226
+        }
227
+
228
+        $propFind->handle(self::ID_PROPERTYNAME, function () use ($node) {
229
+            return $node->getSystemTag()->getId();
230
+        });
231
+
232
+        $propFind->handle(self::DISPLAYNAME_PROPERTYNAME, function () use ($node) {
233
+            return $node->getSystemTag()->getName();
234
+        });
235
+
236
+        $propFind->handle(self::USERVISIBLE_PROPERTYNAME, function () use ($node) {
237
+            return $node->getSystemTag()->isUserVisible() ? 'true' : 'false';
238
+        });
239
+
240
+        $propFind->handle(self::USERASSIGNABLE_PROPERTYNAME, function () use ($node) {
241
+            // this is the tag's inherent property "is user assignable"
242
+            return $node->getSystemTag()->isUserAssignable() ? 'true' : 'false';
243
+        });
244
+
245
+        $propFind->handle(self::CANASSIGN_PROPERTYNAME, function () use ($node) {
246
+            // this is the effective permission for the current user
247
+            return $this->tagManager->canUserAssignTag($node->getSystemTag(), $this->userSession->getUser()) ? 'true' : 'false';
248
+        });
249
+
250
+        $propFind->handle(self::GROUPS_PROPERTYNAME, function () use ($node) {
251
+            if (!$this->groupManager->isAdmin($this->userSession->getUser()->getUID())) {
252
+                // property only available for admins
253
+                throw new Forbidden();
254
+            }
255
+            $groups = [];
256
+            // no need to retrieve groups for namespaces that don't qualify
257
+            if ($node->getSystemTag()->isUserVisible() && !$node->getSystemTag()->isUserAssignable()) {
258
+                $groups = $this->tagManager->getTagGroups($node->getSystemTag());
259
+            }
260
+            return implode('|', $groups);
261
+        });
262
+    }
263
+
264
+    /**
265
+     * Updates tag attributes
266
+     *
267
+     * @param string $path
268
+     * @param PropPatch $propPatch
269
+     *
270
+     * @return void
271
+     */
272
+    public function handleUpdateProperties($path, PropPatch $propPatch) {
273
+        $node = $this->server->tree->getNodeForPath($path);
274
+        if (!($node instanceof SystemTagNode)) {
275
+            return;
276
+        }
277
+
278
+        $propPatch->handle([
279
+            self::DISPLAYNAME_PROPERTYNAME,
280
+            self::USERVISIBLE_PROPERTYNAME,
281
+            self::USERASSIGNABLE_PROPERTYNAME,
282
+            self::GROUPS_PROPERTYNAME,
283
+        ], function ($props) use ($node) {
284
+            $tag = $node->getSystemTag();
285
+            $name = $tag->getName();
286
+            $userVisible = $tag->isUserVisible();
287
+            $userAssignable = $tag->isUserAssignable();
288
+
289
+            $updateTag = false;
290
+
291
+            if (isset($props[self::DISPLAYNAME_PROPERTYNAME])) {
292
+                $name = $props[self::DISPLAYNAME_PROPERTYNAME];
293
+                $updateTag = true;
294
+            }
295
+
296
+            if (isset($props[self::USERVISIBLE_PROPERTYNAME])) {
297
+                $propValue = $props[self::USERVISIBLE_PROPERTYNAME];
298
+                $userVisible = ($propValue !== 'false' && $propValue !== '0');
299
+                $updateTag = true;
300
+            }
301
+
302
+            if (isset($props[self::USERASSIGNABLE_PROPERTYNAME])) {
303
+                $propValue = $props[self::USERASSIGNABLE_PROPERTYNAME];
304
+                $userAssignable = ($propValue !== 'false' && $propValue !== '0');
305
+                $updateTag = true;
306
+            }
307
+
308
+            if (isset($props[self::GROUPS_PROPERTYNAME])) {
309
+                if (!$this->groupManager->isAdmin($this->userSession->getUser()->getUID())) {
310
+                    // property only available for admins
311
+                    throw new Forbidden();
312
+                }
313
+
314
+                $propValue = $props[self::GROUPS_PROPERTYNAME];
315
+                $groupIds = explode('|', $propValue);
316
+                $this->tagManager->setTagGroups($tag, $groupIds);
317
+            }
318
+
319
+            if ($updateTag) {
320
+                $node->update($name, $userVisible, $userAssignable);
321
+            }
322
+
323
+            return true;
324
+        });
325
+    }
326 326
 }
Please login to merge, or discard this patch.
apps/dav/lib/Upload/UploadFolder.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -39,7 +39,7 @@
 block discarded – undo
39 39
 	}
40 40
 
41 41
 	public function createDirectory($name) {
42
-		throw new Forbidden('Permission denied to create file (filename ' . $name . ')');
42
+		throw new Forbidden('Permission denied to create file (filename '.$name.')');
43 43
 	}
44 44
 
45 45
 	public function getChild($name) {
Please login to merge, or discard this patch.
Indentation   +64 added lines, -64 removed lines patch added patch discarded remove patch
@@ -30,68 +30,68 @@
 block discarded – undo
30 30
 
31 31
 class UploadFolder implements ICollection {
32 32
 
33
-	/** @var Directory */
34
-	private $node;
35
-	/** @var CleanupService */
36
-	private $cleanupService;
37
-
38
-	public function __construct(Directory $node, CleanupService $cleanupService) {
39
-		$this->node = $node;
40
-		$this->cleanupService = $cleanupService;
41
-	}
42
-
43
-	public function createFile($name, $data = null) {
44
-		// TODO: verify name - should be a simple number
45
-		$this->node->createFile($name, $data);
46
-	}
47
-
48
-	public function createDirectory($name) {
49
-		throw new Forbidden('Permission denied to create file (filename ' . $name . ')');
50
-	}
51
-
52
-	public function getChild($name) {
53
-		if ($name === '.file') {
54
-			return new FutureFile($this->node, '.file');
55
-		}
56
-		return new UploadFile($this->node->getChild($name));
57
-	}
58
-
59
-	public function getChildren() {
60
-		$tmpChildren = $this->node->getChildren();
61
-
62
-		$children = [];
63
-		$children[] = new FutureFile($this->node, '.file');
64
-
65
-		foreach ($tmpChildren as $child) {
66
-			$children[] = new UploadFile($child);
67
-		}
68
-
69
-		return $children;
70
-	}
71
-
72
-	public function childExists($name) {
73
-		if ($name === '.file') {
74
-			return true;
75
-		}
76
-		return $this->node->childExists($name);
77
-	}
78
-
79
-	public function delete() {
80
-		$this->node->delete();
81
-
82
-		// Background cleanup job is not needed anymore
83
-		$this->cleanupService->removeJob($this->getName());
84
-	}
85
-
86
-	public function getName() {
87
-		return $this->node->getName();
88
-	}
89
-
90
-	public function setName($name) {
91
-		throw new Forbidden('Permission denied to rename this folder');
92
-	}
93
-
94
-	public function getLastModified() {
95
-		return $this->node->getLastModified();
96
-	}
33
+    /** @var Directory */
34
+    private $node;
35
+    /** @var CleanupService */
36
+    private $cleanupService;
37
+
38
+    public function __construct(Directory $node, CleanupService $cleanupService) {
39
+        $this->node = $node;
40
+        $this->cleanupService = $cleanupService;
41
+    }
42
+
43
+    public function createFile($name, $data = null) {
44
+        // TODO: verify name - should be a simple number
45
+        $this->node->createFile($name, $data);
46
+    }
47
+
48
+    public function createDirectory($name) {
49
+        throw new Forbidden('Permission denied to create file (filename ' . $name . ')');
50
+    }
51
+
52
+    public function getChild($name) {
53
+        if ($name === '.file') {
54
+            return new FutureFile($this->node, '.file');
55
+        }
56
+        return new UploadFile($this->node->getChild($name));
57
+    }
58
+
59
+    public function getChildren() {
60
+        $tmpChildren = $this->node->getChildren();
61
+
62
+        $children = [];
63
+        $children[] = new FutureFile($this->node, '.file');
64
+
65
+        foreach ($tmpChildren as $child) {
66
+            $children[] = new UploadFile($child);
67
+        }
68
+
69
+        return $children;
70
+    }
71
+
72
+    public function childExists($name) {
73
+        if ($name === '.file') {
74
+            return true;
75
+        }
76
+        return $this->node->childExists($name);
77
+    }
78
+
79
+    public function delete() {
80
+        $this->node->delete();
81
+
82
+        // Background cleanup job is not needed anymore
83
+        $this->cleanupService->removeJob($this->getName());
84
+    }
85
+
86
+    public function getName() {
87
+        return $this->node->getName();
88
+    }
89
+
90
+    public function setName($name) {
91
+        throw new Forbidden('Permission denied to rename this folder');
92
+    }
93
+
94
+    public function getLastModified() {
95
+        return $this->node->getLastModified();
96
+    }
97 97
 }
Please login to merge, or discard this patch.
apps/dav/lib/Upload/FutureFile.php 2 patches
Indentation   +72 added lines, -72 removed lines patch added patch discarded remove patch
@@ -36,87 +36,87 @@
 block discarded – undo
36 36
  */
37 37
 class FutureFile implements \Sabre\DAV\IFile {
38 38
 
39
-	/** @var Directory */
40
-	private $root;
41
-	/** @var string */
42
-	private $name;
39
+    /** @var Directory */
40
+    private $root;
41
+    /** @var string */
42
+    private $name;
43 43
 
44
-	/**
45
-	 * @param Directory $root
46
-	 * @param string $name
47
-	 */
48
-	public function __construct(Directory $root, $name) {
49
-		$this->root = $root;
50
-		$this->name = $name;
51
-	}
44
+    /**
45
+     * @param Directory $root
46
+     * @param string $name
47
+     */
48
+    public function __construct(Directory $root, $name) {
49
+        $this->root = $root;
50
+        $this->name = $name;
51
+    }
52 52
 
53
-	/**
54
-	 * @inheritdoc
55
-	 */
56
-	public function put($data) {
57
-		throw new Forbidden('Permission denied to put into this file');
58
-	}
53
+    /**
54
+     * @inheritdoc
55
+     */
56
+    public function put($data) {
57
+        throw new Forbidden('Permission denied to put into this file');
58
+    }
59 59
 
60
-	/**
61
-	 * @inheritdoc
62
-	 */
63
-	public function get() {
64
-		$nodes = $this->root->getChildren();
65
-		return AssemblyStream::wrap($nodes);
66
-	}
60
+    /**
61
+     * @inheritdoc
62
+     */
63
+    public function get() {
64
+        $nodes = $this->root->getChildren();
65
+        return AssemblyStream::wrap($nodes);
66
+    }
67 67
 
68
-	/**
69
-	 * @inheritdoc
70
-	 */
71
-	public function getContentType() {
72
-		return 'application/octet-stream';
73
-	}
68
+    /**
69
+     * @inheritdoc
70
+     */
71
+    public function getContentType() {
72
+        return 'application/octet-stream';
73
+    }
74 74
 
75
-	/**
76
-	 * @inheritdoc
77
-	 */
78
-	public function getETag() {
79
-		return $this->root->getETag();
80
-	}
75
+    /**
76
+     * @inheritdoc
77
+     */
78
+    public function getETag() {
79
+        return $this->root->getETag();
80
+    }
81 81
 
82
-	/**
83
-	 * @inheritdoc
84
-	 */
85
-	public function getSize() {
86
-		$children = $this->root->getChildren();
87
-		$sizes = array_map(function ($node) {
88
-			/** @var IFile $node */
89
-			return $node->getSize();
90
-		}, $children);
82
+    /**
83
+     * @inheritdoc
84
+     */
85
+    public function getSize() {
86
+        $children = $this->root->getChildren();
87
+        $sizes = array_map(function ($node) {
88
+            /** @var IFile $node */
89
+            return $node->getSize();
90
+        }, $children);
91 91
 
92
-		return array_sum($sizes);
93
-	}
92
+        return array_sum($sizes);
93
+    }
94 94
 
95
-	/**
96
-	 * @inheritdoc
97
-	 */
98
-	public function delete() {
99
-		$this->root->delete();
100
-	}
95
+    /**
96
+     * @inheritdoc
97
+     */
98
+    public function delete() {
99
+        $this->root->delete();
100
+    }
101 101
 
102
-	/**
103
-	 * @inheritdoc
104
-	 */
105
-	public function getName() {
106
-		return $this->name;
107
-	}
102
+    /**
103
+     * @inheritdoc
104
+     */
105
+    public function getName() {
106
+        return $this->name;
107
+    }
108 108
 
109
-	/**
110
-	 * @inheritdoc
111
-	 */
112
-	public function setName($name) {
113
-		throw new Forbidden('Permission denied to rename this file');
114
-	}
109
+    /**
110
+     * @inheritdoc
111
+     */
112
+    public function setName($name) {
113
+        throw new Forbidden('Permission denied to rename this file');
114
+    }
115 115
 
116
-	/**
117
-	 * @inheritdoc
118
-	 */
119
-	public function getLastModified() {
120
-		return $this->root->getLastModified();
121
-	}
116
+    /**
117
+     * @inheritdoc
118
+     */
119
+    public function getLastModified() {
120
+        return $this->root->getLastModified();
121
+    }
122 122
 }
Please login to merge, or discard this patch.
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -84,7 +84,7 @@
 block discarded – undo
84 84
 	 */
85 85
 	public function getSize() {
86 86
 		$children = $this->root->getChildren();
87
-		$sizes = array_map(function ($node) {
87
+		$sizes = array_map(function($node) {
88 88
 			/** @var IFile $node */
89 89
 			return $node->getSize();
90 90
 		}, $children);
Please login to merge, or discard this patch.
apps/dav/appinfo/v1/webdav.php 2 patches
Spacing   +1 added lines, -1 removed lines patch added patch discarded remove patch
@@ -62,7 +62,7 @@
 block discarded – undo
62 62
 
63 63
 $requestUri = \OC::$server->getRequest()->getRequestUri();
64 64
 
65
-$server = $serverFactory->createServer($baseuri, $requestUri, $authPlugin, function () {
65
+$server = $serverFactory->createServer($baseuri, $requestUri, $authPlugin, function() {
66 66
 	// use the view for the logged in user
67 67
 	return \OC\Files\Filesystem::getView();
68 68
 });
Please login to merge, or discard this patch.
Indentation   +22 added lines, -22 removed lines patch added patch discarded remove patch
@@ -32,7 +32,7 @@  discard block
 block discarded – undo
32 32
 
33 33
 // no php execution timeout for webdav
34 34
 if (strpos(@ini_get('disable_functions'), 'set_time_limit') === false) {
35
-	@set_time_limit(0);
35
+    @set_time_limit(0);
36 36
 }
37 37
 ignore_user_abort(true);
38 38
 
@@ -40,40 +40,40 @@  discard block
 block discarded – undo
40 40
 \OC_Util::obEnd();
41 41
 
42 42
 $serverFactory = new \OCA\DAV\Connector\Sabre\ServerFactory(
43
-	\OC::$server->getConfig(),
44
-	\OC::$server->get(LoggerInterface::class),
45
-	\OC::$server->getDatabaseConnection(),
46
-	\OC::$server->getUserSession(),
47
-	\OC::$server->getMountManager(),
48
-	\OC::$server->getTagManager(),
49
-	\OC::$server->getRequest(),
50
-	\OC::$server->getPreviewManager(),
51
-	\OC::$server->getEventDispatcher(),
52
-	\OC::$server->getL10N('dav')
43
+    \OC::$server->getConfig(),
44
+    \OC::$server->get(LoggerInterface::class),
45
+    \OC::$server->getDatabaseConnection(),
46
+    \OC::$server->getUserSession(),
47
+    \OC::$server->getMountManager(),
48
+    \OC::$server->getTagManager(),
49
+    \OC::$server->getRequest(),
50
+    \OC::$server->getPreviewManager(),
51
+    \OC::$server->getEventDispatcher(),
52
+    \OC::$server->getL10N('dav')
53 53
 );
54 54
 
55 55
 // Backends
56 56
 $authBackend = new \OCA\DAV\Connector\Sabre\Auth(
57
-	\OC::$server->getSession(),
58
-	\OC::$server->getUserSession(),
59
-	\OC::$server->getRequest(),
60
-	\OC::$server->getTwoFactorAuthManager(),
61
-	\OC::$server->getBruteForceThrottler(),
62
-	'principals/'
57
+    \OC::$server->getSession(),
58
+    \OC::$server->getUserSession(),
59
+    \OC::$server->getRequest(),
60
+    \OC::$server->getTwoFactorAuthManager(),
61
+    \OC::$server->getBruteForceThrottler(),
62
+    'principals/'
63 63
 );
64 64
 $authPlugin = new \Sabre\DAV\Auth\Plugin($authBackend);
65 65
 $bearerAuthPlugin = new \OCA\DAV\Connector\Sabre\BearerAuth(
66
-	\OC::$server->getUserSession(),
67
-	\OC::$server->getSession(),
68
-	\OC::$server->getRequest()
66
+    \OC::$server->getUserSession(),
67
+    \OC::$server->getSession(),
68
+    \OC::$server->getRequest()
69 69
 );
70 70
 $authPlugin->addBackend($bearerAuthPlugin);
71 71
 
72 72
 $requestUri = \OC::$server->getRequest()->getRequestUri();
73 73
 
74 74
 $server = $serverFactory->createServer($baseuri, $requestUri, $authPlugin, function () {
75
-	// use the view for the logged in user
76
-	return \OC\Files\Filesystem::getView();
75
+    // use the view for the logged in user
76
+    return \OC\Files\Filesystem::getView();
77 77
 });
78 78
 
79 79
 $dispatcher = \OC::$server->getEventDispatcher();
Please login to merge, or discard this patch.
apps/files_sharing/lib/DeleteOrphanedSharesJob.php 2 patches
Indentation   +27 added lines, -27 removed lines patch added patch discarded remove patch
@@ -31,35 +31,35 @@
 block discarded – undo
31 31
  */
32 32
 class DeleteOrphanedSharesJob extends TimedJob {
33 33
 
34
-	/**
35
-	 * Default interval in minutes
36
-	 *
37
-	 * @var int $defaultIntervalMin
38
-	 **/
39
-	protected $defaultIntervalMin = 15;
34
+    /**
35
+     * Default interval in minutes
36
+     *
37
+     * @var int $defaultIntervalMin
38
+     **/
39
+    protected $defaultIntervalMin = 15;
40 40
 
41
-	/**
42
-	 * sets the correct interval for this timed job
43
-	 */
44
-	public function __construct() {
45
-		$this->interval = $this->defaultIntervalMin * 60;
46
-	}
41
+    /**
42
+     * sets the correct interval for this timed job
43
+     */
44
+    public function __construct() {
45
+        $this->interval = $this->defaultIntervalMin * 60;
46
+    }
47 47
 
48
-	/**
49
-	 * Makes the background job do its work
50
-	 *
51
-	 * @param array $argument unused argument
52
-	 */
53
-	public function run($argument) {
54
-		$connection = \OC::$server->getDatabaseConnection();
55
-		$logger = \OC::$server->getLogger();
48
+    /**
49
+     * Makes the background job do its work
50
+     *
51
+     * @param array $argument unused argument
52
+     */
53
+    public function run($argument) {
54
+        $connection = \OC::$server->getDatabaseConnection();
55
+        $logger = \OC::$server->getLogger();
56 56
 
57
-		$sql =
58
-			'DELETE FROM `*PREFIX*share` ' .
59
-			'WHERE `item_type` in (\'file\', \'folder\') ' .
60
-			'AND NOT EXISTS (SELECT `fileid` FROM `*PREFIX*filecache` WHERE `file_source` = `fileid`)';
57
+        $sql =
58
+            'DELETE FROM `*PREFIX*share` ' .
59
+            'WHERE `item_type` in (\'file\', \'folder\') ' .
60
+            'AND NOT EXISTS (SELECT `fileid` FROM `*PREFIX*filecache` WHERE `file_source` = `fileid`)';
61 61
 
62
-		$deletedEntries = $connection->executeUpdate($sql);
63
-		$logger->debug("$deletedEntries orphaned share(s) deleted", ['app' => 'DeleteOrphanedSharesJob']);
64
-	}
62
+        $deletedEntries = $connection->executeUpdate($sql);
63
+        $logger->debug("$deletedEntries orphaned share(s) deleted", ['app' => 'DeleteOrphanedSharesJob']);
64
+    }
65 65
 }
Please login to merge, or discard this patch.
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -55,8 +55,8 @@
 block discarded – undo
55 55
 		$logger = \OC::$server->getLogger();
56 56
 
57 57
 		$sql =
58
-			'DELETE FROM `*PREFIX*share` ' .
59
-			'WHERE `item_type` in (\'file\', \'folder\') ' .
58
+			'DELETE FROM `*PREFIX*share` '.
59
+			'WHERE `item_type` in (\'file\', \'folder\') '.
60 60
 			'AND NOT EXISTS (SELECT `fileid` FROM `*PREFIX*filecache` WHERE `file_source` = `fileid`)';
61 61
 
62 62
 		$deletedEntries = $connection->executeUpdate($sql);
Please login to merge, or discard this patch.
apps/files_external/lib/Lib/StorageConfig.php 2 patches
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -220,7 +220,7 @@  discard block
 block discarded – undo
220 220
 				if (isset($parameters[$key])) {
221 221
 					switch ($parameters[$key]->getType()) {
222 222
 						case \OCA\Files_External\Lib\DefinitionParameter::VALUE_BOOLEAN:
223
-							$value = (bool)$value;
223
+							$value = (bool) $value;
224 224
 							break;
225 225
 					}
226 226
 					$backendOptions[$key] = $value;
@@ -426,7 +426,7 @@  discard block
 block discarded – undo
426 426
 			$result['statusMessage'] = $this->statusMessage;
427 427
 		}
428 428
 		$result['userProvided'] = $this->authMechanism instanceof IUserProvided;
429
-		$result['type'] = ($this->getType() === self::MOUNT_TYPE_PERSONAl) ? 'personal': 'system';
429
+		$result['type'] = ($this->getType() === self::MOUNT_TYPE_PERSONAl) ? 'personal' : 'system';
430 430
 		return $result;
431 431
 	}
432 432
 }
Please login to merge, or discard this patch.
Indentation   +392 added lines, -392 removed lines patch added patch discarded remove patch
@@ -36,396 +36,396 @@
 block discarded – undo
36 36
  * External storage configuration
37 37
  */
38 38
 class StorageConfig implements \JsonSerializable {
39
-	public const MOUNT_TYPE_ADMIN = 1;
40
-	public const MOUNT_TYPE_PERSONAl = 2;
41
-
42
-	/**
43
-	 * Storage config id
44
-	 *
45
-	 * @var int
46
-	 */
47
-	private $id;
48
-
49
-	/**
50
-	 * Backend
51
-	 *
52
-	 * @var Backend
53
-	 */
54
-	private $backend;
55
-
56
-	/**
57
-	 * Authentication mechanism
58
-	 *
59
-	 * @var AuthMechanism
60
-	 */
61
-	private $authMechanism;
62
-
63
-	/**
64
-	 * Backend options
65
-	 *
66
-	 * @var array
67
-	 */
68
-	private $backendOptions = [];
69
-
70
-	/**
71
-	 * Mount point path, relative to the user's "files" folder
72
-	 *
73
-	 * @var string
74
-	 */
75
-	private $mountPoint;
76
-
77
-	/**
78
-	 * Storage status
79
-	 *
80
-	 * @var int
81
-	 */
82
-	private $status;
83
-
84
-	/**
85
-	 * Status message
86
-	 *
87
-	 * @var string
88
-	 */
89
-	private $statusMessage;
90
-
91
-	/**
92
-	 * Priority
93
-	 *
94
-	 * @var int
95
-	 */
96
-	private $priority;
97
-
98
-	/**
99
-	 * List of users who have access to this storage
100
-	 *
101
-	 * @var string[]
102
-	 */
103
-	private $applicableUsers = [];
104
-
105
-	/**
106
-	 * List of groups that have access to this storage
107
-	 *
108
-	 * @var string[]
109
-	 */
110
-	private $applicableGroups = [];
111
-
112
-	/**
113
-	 * Mount-specific options
114
-	 *
115
-	 * @var array
116
-	 */
117
-	private $mountOptions = [];
118
-
119
-	/**
120
-	 * Whether it's a personal or admin mount
121
-	 *
122
-	 * @var int
123
-	 */
124
-	private $type;
125
-
126
-	/**
127
-	 * Creates a storage config
128
-	 *
129
-	 * @param int|string $id config id or null for a new config
130
-	 */
131
-	public function __construct($id = null) {
132
-		$this->id = $id ?? -1;
133
-		$this->mountOptions['enable_sharing'] = false;
134
-	}
135
-
136
-	/**
137
-	 * Returns the configuration id
138
-	 *
139
-	 * @retun int
140
-	 */
141
-	public function getId() {
142
-		return $this->id;
143
-	}
144
-
145
-	/**
146
-	 * Sets the configuration id
147
-	 *
148
-	 * @param int $id configuration id
149
-	 */
150
-	public function setId(int $id): void {
151
-		$this->id = $id;
152
-	}
153
-
154
-	/**
155
-	 * Returns mount point path relative to the user's
156
-	 * "files" folder.
157
-	 *
158
-	 * @return string path
159
-	 */
160
-	public function getMountPoint() {
161
-		return $this->mountPoint;
162
-	}
163
-
164
-	/**
165
-	 * Sets mount point path relative to the user's
166
-	 * "files" folder.
167
-	 * The path will be normalized.
168
-	 *
169
-	 * @param string $mountPoint path
170
-	 */
171
-	public function setMountPoint($mountPoint) {
172
-		$this->mountPoint = \OC\Files\Filesystem::normalizePath($mountPoint);
173
-	}
174
-
175
-	/**
176
-	 * @return Backend
177
-	 */
178
-	public function getBackend() {
179
-		return $this->backend;
180
-	}
181
-
182
-	/**
183
-	 * @param Backend $backend
184
-	 */
185
-	public function setBackend(Backend $backend) {
186
-		$this->backend = $backend;
187
-	}
188
-
189
-	/**
190
-	 * @return AuthMechanism
191
-	 */
192
-	public function getAuthMechanism() {
193
-		return $this->authMechanism;
194
-	}
195
-
196
-	/**
197
-	 * @param AuthMechanism $authMechanism
198
-	 */
199
-	public function setAuthMechanism(AuthMechanism $authMechanism) {
200
-		$this->authMechanism = $authMechanism;
201
-	}
202
-
203
-	/**
204
-	 * Returns the external storage backend-specific options
205
-	 *
206
-	 * @return array backend options
207
-	 */
208
-	public function getBackendOptions() {
209
-		return $this->backendOptions;
210
-	}
211
-
212
-	/**
213
-	 * Sets the external storage backend-specific options
214
-	 *
215
-	 * @param array $backendOptions backend options
216
-	 */
217
-	public function setBackendOptions($backendOptions) {
218
-		if ($this->getBackend() instanceof  Backend) {
219
-			$parameters = $this->getBackend()->getParameters();
220
-			foreach ($backendOptions as $key => $value) {
221
-				if (isset($parameters[$key])) {
222
-					switch ($parameters[$key]->getType()) {
223
-						case \OCA\Files_External\Lib\DefinitionParameter::VALUE_BOOLEAN:
224
-							$value = (bool)$value;
225
-							break;
226
-					}
227
-					$backendOptions[$key] = $value;
228
-				}
229
-			}
230
-		}
231
-
232
-		$this->backendOptions = $backendOptions;
233
-	}
234
-
235
-	/**
236
-	 * @param string $key
237
-	 * @return mixed
238
-	 */
239
-	public function getBackendOption($key) {
240
-		if (isset($this->backendOptions[$key])) {
241
-			return $this->backendOptions[$key];
242
-		}
243
-		return null;
244
-	}
245
-
246
-	/**
247
-	 * @param string $key
248
-	 * @param mixed $value
249
-	 */
250
-	public function setBackendOption($key, $value) {
251
-		$this->backendOptions[$key] = $value;
252
-	}
253
-
254
-	/**
255
-	 * Returns the mount priority
256
-	 *
257
-	 * @return int priority
258
-	 */
259
-	public function getPriority() {
260
-		return $this->priority;
261
-	}
262
-
263
-	/**
264
-	 * Sets the mount priority
265
-	 *
266
-	 * @param int $priority priority
267
-	 */
268
-	public function setPriority($priority) {
269
-		$this->priority = $priority;
270
-	}
271
-
272
-	/**
273
-	 * Returns the users for which to mount this storage
274
-	 *
275
-	 * @return string[] applicable users
276
-	 */
277
-	public function getApplicableUsers() {
278
-		return $this->applicableUsers;
279
-	}
280
-
281
-	/**
282
-	 * Sets the users for which to mount this storage
283
-	 *
284
-	 * @param string[]|null $applicableUsers applicable users
285
-	 */
286
-	public function setApplicableUsers($applicableUsers) {
287
-		if (is_null($applicableUsers)) {
288
-			$applicableUsers = [];
289
-		}
290
-		$this->applicableUsers = $applicableUsers;
291
-	}
292
-
293
-	/**
294
-	 * Returns the groups for which to mount this storage
295
-	 *
296
-	 * @return string[] applicable groups
297
-	 */
298
-	public function getApplicableGroups() {
299
-		return $this->applicableGroups;
300
-	}
301
-
302
-	/**
303
-	 * Sets the groups for which to mount this storage
304
-	 *
305
-	 * @param string[]|null $applicableGroups applicable groups
306
-	 */
307
-	public function setApplicableGroups($applicableGroups) {
308
-		if (is_null($applicableGroups)) {
309
-			$applicableGroups = [];
310
-		}
311
-		$this->applicableGroups = $applicableGroups;
312
-	}
313
-
314
-	/**
315
-	 * Returns the mount-specific options
316
-	 *
317
-	 * @return array mount specific options
318
-	 */
319
-	public function getMountOptions() {
320
-		return $this->mountOptions;
321
-	}
322
-
323
-	/**
324
-	 * Sets the mount-specific options
325
-	 *
326
-	 * @param array $mountOptions applicable groups
327
-	 */
328
-	public function setMountOptions($mountOptions) {
329
-		if (is_null($mountOptions)) {
330
-			$mountOptions = [];
331
-		}
332
-		$this->mountOptions = $mountOptions;
333
-	}
334
-
335
-	/**
336
-	 * @param string $key
337
-	 * @return mixed
338
-	 */
339
-	public function getMountOption($key) {
340
-		if (isset($this->mountOptions[$key])) {
341
-			return $this->mountOptions[$key];
342
-		}
343
-		return null;
344
-	}
345
-
346
-	/**
347
-	 * @param string $key
348
-	 * @param mixed $value
349
-	 */
350
-	public function setMountOption($key, $value) {
351
-		$this->mountOptions[$key] = $value;
352
-	}
353
-
354
-	/**
355
-	 * Gets the storage status, whether the config worked last time
356
-	 *
357
-	 * @return int $status status
358
-	 */
359
-	public function getStatus() {
360
-		return $this->status;
361
-	}
362
-
363
-	/**
364
-	 * Gets the message describing the storage status
365
-	 *
366
-	 * @return string|null
367
-	 */
368
-	public function getStatusMessage() {
369
-		return $this->statusMessage;
370
-	}
371
-
372
-	/**
373
-	 * Sets the storage status, whether the config worked last time
374
-	 *
375
-	 * @param int $status status
376
-	 * @param string|null $message optional message
377
-	 */
378
-	public function setStatus($status, $message = null) {
379
-		$this->status = $status;
380
-		$this->statusMessage = $message;
381
-	}
382
-
383
-	/**
384
-	 * @return int self::MOUNT_TYPE_ADMIN or self::MOUNT_TYPE_PERSONAl
385
-	 */
386
-	public function getType() {
387
-		return $this->type;
388
-	}
389
-
390
-	/**
391
-	 * @param int $type self::MOUNT_TYPE_ADMIN or self::MOUNT_TYPE_PERSONAl
392
-	 */
393
-	public function setType($type) {
394
-		$this->type = $type;
395
-	}
396
-
397
-	/**
398
-	 * Serialize config to JSON
399
-	 */
400
-	public function jsonSerialize(): array {
401
-		$result = [];
402
-		if (!is_null($this->id)) {
403
-			$result['id'] = $this->id;
404
-		}
405
-		$result['mountPoint'] = $this->mountPoint;
406
-		$result['backend'] = $this->backend->getIdentifier();
407
-		$result['authMechanism'] = $this->authMechanism->getIdentifier();
408
-		$result['backendOptions'] = $this->backendOptions;
409
-		if (!is_null($this->priority)) {
410
-			$result['priority'] = $this->priority;
411
-		}
412
-		if (!empty($this->applicableUsers)) {
413
-			$result['applicableUsers'] = $this->applicableUsers;
414
-		}
415
-		if (!empty($this->applicableGroups)) {
416
-			$result['applicableGroups'] = $this->applicableGroups;
417
-		}
418
-		if (!empty($this->mountOptions)) {
419
-			$result['mountOptions'] = $this->mountOptions;
420
-		}
421
-		if (!is_null($this->status)) {
422
-			$result['status'] = $this->status;
423
-		}
424
-		if (!is_null($this->statusMessage)) {
425
-			$result['statusMessage'] = $this->statusMessage;
426
-		}
427
-		$result['userProvided'] = $this->authMechanism instanceof IUserProvided;
428
-		$result['type'] = ($this->getType() === self::MOUNT_TYPE_PERSONAl) ? 'personal': 'system';
429
-		return $result;
430
-	}
39
+    public const MOUNT_TYPE_ADMIN = 1;
40
+    public const MOUNT_TYPE_PERSONAl = 2;
41
+
42
+    /**
43
+     * Storage config id
44
+     *
45
+     * @var int
46
+     */
47
+    private $id;
48
+
49
+    /**
50
+     * Backend
51
+     *
52
+     * @var Backend
53
+     */
54
+    private $backend;
55
+
56
+    /**
57
+     * Authentication mechanism
58
+     *
59
+     * @var AuthMechanism
60
+     */
61
+    private $authMechanism;
62
+
63
+    /**
64
+     * Backend options
65
+     *
66
+     * @var array
67
+     */
68
+    private $backendOptions = [];
69
+
70
+    /**
71
+     * Mount point path, relative to the user's "files" folder
72
+     *
73
+     * @var string
74
+     */
75
+    private $mountPoint;
76
+
77
+    /**
78
+     * Storage status
79
+     *
80
+     * @var int
81
+     */
82
+    private $status;
83
+
84
+    /**
85
+     * Status message
86
+     *
87
+     * @var string
88
+     */
89
+    private $statusMessage;
90
+
91
+    /**
92
+     * Priority
93
+     *
94
+     * @var int
95
+     */
96
+    private $priority;
97
+
98
+    /**
99
+     * List of users who have access to this storage
100
+     *
101
+     * @var string[]
102
+     */
103
+    private $applicableUsers = [];
104
+
105
+    /**
106
+     * List of groups that have access to this storage
107
+     *
108
+     * @var string[]
109
+     */
110
+    private $applicableGroups = [];
111
+
112
+    /**
113
+     * Mount-specific options
114
+     *
115
+     * @var array
116
+     */
117
+    private $mountOptions = [];
118
+
119
+    /**
120
+     * Whether it's a personal or admin mount
121
+     *
122
+     * @var int
123
+     */
124
+    private $type;
125
+
126
+    /**
127
+     * Creates a storage config
128
+     *
129
+     * @param int|string $id config id or null for a new config
130
+     */
131
+    public function __construct($id = null) {
132
+        $this->id = $id ?? -1;
133
+        $this->mountOptions['enable_sharing'] = false;
134
+    }
135
+
136
+    /**
137
+     * Returns the configuration id
138
+     *
139
+     * @retun int
140
+     */
141
+    public function getId() {
142
+        return $this->id;
143
+    }
144
+
145
+    /**
146
+     * Sets the configuration id
147
+     *
148
+     * @param int $id configuration id
149
+     */
150
+    public function setId(int $id): void {
151
+        $this->id = $id;
152
+    }
153
+
154
+    /**
155
+     * Returns mount point path relative to the user's
156
+     * "files" folder.
157
+     *
158
+     * @return string path
159
+     */
160
+    public function getMountPoint() {
161
+        return $this->mountPoint;
162
+    }
163
+
164
+    /**
165
+     * Sets mount point path relative to the user's
166
+     * "files" folder.
167
+     * The path will be normalized.
168
+     *
169
+     * @param string $mountPoint path
170
+     */
171
+    public function setMountPoint($mountPoint) {
172
+        $this->mountPoint = \OC\Files\Filesystem::normalizePath($mountPoint);
173
+    }
174
+
175
+    /**
176
+     * @return Backend
177
+     */
178
+    public function getBackend() {
179
+        return $this->backend;
180
+    }
181
+
182
+    /**
183
+     * @param Backend $backend
184
+     */
185
+    public function setBackend(Backend $backend) {
186
+        $this->backend = $backend;
187
+    }
188
+
189
+    /**
190
+     * @return AuthMechanism
191
+     */
192
+    public function getAuthMechanism() {
193
+        return $this->authMechanism;
194
+    }
195
+
196
+    /**
197
+     * @param AuthMechanism $authMechanism
198
+     */
199
+    public function setAuthMechanism(AuthMechanism $authMechanism) {
200
+        $this->authMechanism = $authMechanism;
201
+    }
202
+
203
+    /**
204
+     * Returns the external storage backend-specific options
205
+     *
206
+     * @return array backend options
207
+     */
208
+    public function getBackendOptions() {
209
+        return $this->backendOptions;
210
+    }
211
+
212
+    /**
213
+     * Sets the external storage backend-specific options
214
+     *
215
+     * @param array $backendOptions backend options
216
+     */
217
+    public function setBackendOptions($backendOptions) {
218
+        if ($this->getBackend() instanceof  Backend) {
219
+            $parameters = $this->getBackend()->getParameters();
220
+            foreach ($backendOptions as $key => $value) {
221
+                if (isset($parameters[$key])) {
222
+                    switch ($parameters[$key]->getType()) {
223
+                        case \OCA\Files_External\Lib\DefinitionParameter::VALUE_BOOLEAN:
224
+                            $value = (bool)$value;
225
+                            break;
226
+                    }
227
+                    $backendOptions[$key] = $value;
228
+                }
229
+            }
230
+        }
231
+
232
+        $this->backendOptions = $backendOptions;
233
+    }
234
+
235
+    /**
236
+     * @param string $key
237
+     * @return mixed
238
+     */
239
+    public function getBackendOption($key) {
240
+        if (isset($this->backendOptions[$key])) {
241
+            return $this->backendOptions[$key];
242
+        }
243
+        return null;
244
+    }
245
+
246
+    /**
247
+     * @param string $key
248
+     * @param mixed $value
249
+     */
250
+    public function setBackendOption($key, $value) {
251
+        $this->backendOptions[$key] = $value;
252
+    }
253
+
254
+    /**
255
+     * Returns the mount priority
256
+     *
257
+     * @return int priority
258
+     */
259
+    public function getPriority() {
260
+        return $this->priority;
261
+    }
262
+
263
+    /**
264
+     * Sets the mount priority
265
+     *
266
+     * @param int $priority priority
267
+     */
268
+    public function setPriority($priority) {
269
+        $this->priority = $priority;
270
+    }
271
+
272
+    /**
273
+     * Returns the users for which to mount this storage
274
+     *
275
+     * @return string[] applicable users
276
+     */
277
+    public function getApplicableUsers() {
278
+        return $this->applicableUsers;
279
+    }
280
+
281
+    /**
282
+     * Sets the users for which to mount this storage
283
+     *
284
+     * @param string[]|null $applicableUsers applicable users
285
+     */
286
+    public function setApplicableUsers($applicableUsers) {
287
+        if (is_null($applicableUsers)) {
288
+            $applicableUsers = [];
289
+        }
290
+        $this->applicableUsers = $applicableUsers;
291
+    }
292
+
293
+    /**
294
+     * Returns the groups for which to mount this storage
295
+     *
296
+     * @return string[] applicable groups
297
+     */
298
+    public function getApplicableGroups() {
299
+        return $this->applicableGroups;
300
+    }
301
+
302
+    /**
303
+     * Sets the groups for which to mount this storage
304
+     *
305
+     * @param string[]|null $applicableGroups applicable groups
306
+     */
307
+    public function setApplicableGroups($applicableGroups) {
308
+        if (is_null($applicableGroups)) {
309
+            $applicableGroups = [];
310
+        }
311
+        $this->applicableGroups = $applicableGroups;
312
+    }
313
+
314
+    /**
315
+     * Returns the mount-specific options
316
+     *
317
+     * @return array mount specific options
318
+     */
319
+    public function getMountOptions() {
320
+        return $this->mountOptions;
321
+    }
322
+
323
+    /**
324
+     * Sets the mount-specific options
325
+     *
326
+     * @param array $mountOptions applicable groups
327
+     */
328
+    public function setMountOptions($mountOptions) {
329
+        if (is_null($mountOptions)) {
330
+            $mountOptions = [];
331
+        }
332
+        $this->mountOptions = $mountOptions;
333
+    }
334
+
335
+    /**
336
+     * @param string $key
337
+     * @return mixed
338
+     */
339
+    public function getMountOption($key) {
340
+        if (isset($this->mountOptions[$key])) {
341
+            return $this->mountOptions[$key];
342
+        }
343
+        return null;
344
+    }
345
+
346
+    /**
347
+     * @param string $key
348
+     * @param mixed $value
349
+     */
350
+    public function setMountOption($key, $value) {
351
+        $this->mountOptions[$key] = $value;
352
+    }
353
+
354
+    /**
355
+     * Gets the storage status, whether the config worked last time
356
+     *
357
+     * @return int $status status
358
+     */
359
+    public function getStatus() {
360
+        return $this->status;
361
+    }
362
+
363
+    /**
364
+     * Gets the message describing the storage status
365
+     *
366
+     * @return string|null
367
+     */
368
+    public function getStatusMessage() {
369
+        return $this->statusMessage;
370
+    }
371
+
372
+    /**
373
+     * Sets the storage status, whether the config worked last time
374
+     *
375
+     * @param int $status status
376
+     * @param string|null $message optional message
377
+     */
378
+    public function setStatus($status, $message = null) {
379
+        $this->status = $status;
380
+        $this->statusMessage = $message;
381
+    }
382
+
383
+    /**
384
+     * @return int self::MOUNT_TYPE_ADMIN or self::MOUNT_TYPE_PERSONAl
385
+     */
386
+    public function getType() {
387
+        return $this->type;
388
+    }
389
+
390
+    /**
391
+     * @param int $type self::MOUNT_TYPE_ADMIN or self::MOUNT_TYPE_PERSONAl
392
+     */
393
+    public function setType($type) {
394
+        $this->type = $type;
395
+    }
396
+
397
+    /**
398
+     * Serialize config to JSON
399
+     */
400
+    public function jsonSerialize(): array {
401
+        $result = [];
402
+        if (!is_null($this->id)) {
403
+            $result['id'] = $this->id;
404
+        }
405
+        $result['mountPoint'] = $this->mountPoint;
406
+        $result['backend'] = $this->backend->getIdentifier();
407
+        $result['authMechanism'] = $this->authMechanism->getIdentifier();
408
+        $result['backendOptions'] = $this->backendOptions;
409
+        if (!is_null($this->priority)) {
410
+            $result['priority'] = $this->priority;
411
+        }
412
+        if (!empty($this->applicableUsers)) {
413
+            $result['applicableUsers'] = $this->applicableUsers;
414
+        }
415
+        if (!empty($this->applicableGroups)) {
416
+            $result['applicableGroups'] = $this->applicableGroups;
417
+        }
418
+        if (!empty($this->mountOptions)) {
419
+            $result['mountOptions'] = $this->mountOptions;
420
+        }
421
+        if (!is_null($this->status)) {
422
+            $result['status'] = $this->status;
423
+        }
424
+        if (!is_null($this->statusMessage)) {
425
+            $result['statusMessage'] = $this->statusMessage;
426
+        }
427
+        $result['userProvided'] = $this->authMechanism instanceof IUserProvided;
428
+        $result['type'] = ($this->getType() === self::MOUNT_TYPE_PERSONAl) ? 'personal': 'system';
429
+        return $result;
430
+    }
431 431
 }
Please login to merge, or discard this patch.