summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2016-02-09 16:35:23 +0100
committerThomas Müller <thomas.mueller@tmit.eu>2016-02-09 16:35:23 +0100
commit29820176825c41acef30fa6942922aeb36cfcec3 (patch)
tree968fb14092999ae38aed3f2eb9af4defcbeba620 /lib
parentd89ddba3a2a1960da35db41ee8912bc5e0f5f23c (diff)
parentbbc86e0756429b4c51e245d6dcf3ad5a5a1785eb (diff)
downloadnextcloud-server-29820176825c41acef30fa6942922aeb36cfcec3.tar.gz
nextcloud-server-29820176825c41acef30fa6942922aeb36cfcec3.zip
Merge pull request #22228 from owncloud/comments-limit-message
Limit comment message to 1k chars
Diffstat (limited to 'lib')
-rw-r--r--lib/private/comments/comment.php8
-rw-r--r--lib/public/comments/icomment.php5
-rw-r--r--lib/public/comments/messagetoolongexception.php27
3 files changed, 39 insertions, 1 deletions
diff --git a/lib/private/comments/comment.php b/lib/private/comments/comment.php
index 36189d9523b..27e63c98555 100644
--- a/lib/private/comments/comment.php
+++ b/lib/private/comments/comment.php
@@ -22,6 +22,7 @@ namespace OC\Comments;
use OCP\Comments\IComment;
use OCP\Comments\IllegalIDChangeException;
+use OCP\Comments\MessageTooLongException;
class Comment implements IComment {
@@ -184,13 +185,18 @@ class Comment implements IComment {
*
* @param string $message
* @return IComment
+ * @throws MessageTooLongException
* @since 9.0.0
*/
public function setMessage($message) {
if(!is_string($message)) {
throw new \InvalidArgumentException('String expected.');
}
- $this->data['message'] = trim($message);
+ $message = trim($message);
+ if(mb_strlen($message, 'UTF-8') > IComment::MAX_MESSAGE_LENGTH) {
+ throw new MessageTooLongException('Comment message must not exceed ' . IComment::MAX_MESSAGE_LENGTH . ' characters');
+ }
+ $this->data['message'] = $message;
return $this;
}
diff --git a/lib/public/comments/icomment.php b/lib/public/comments/icomment.php
index e695b5193f2..a7f4b4c6171 100644
--- a/lib/public/comments/icomment.php
+++ b/lib/public/comments/icomment.php
@@ -29,6 +29,7 @@ namespace OCP\Comments;
* @since 9.0.0
*/
interface IComment {
+ const MAX_MESSAGE_LENGTH = 1000;
/**
* returns the ID of the comment
@@ -119,8 +120,12 @@ interface IComment {
/**
* sets the message of the comment and returns itself
*
+ * When the given message length exceeds MAX_MESSAGE_LENGTH an
+ * MessageTooLongException shall be thrown.
+ *
* @param string $message
* @return IComment
+ * @throws MessageTooLongException
* @since 9.0.0
*/
public function setMessage($message);
diff --git a/lib/public/comments/messagetoolongexception.php b/lib/public/comments/messagetoolongexception.php
new file mode 100644
index 00000000000..054cecf320f
--- /dev/null
+++ b/lib/public/comments/messagetoolongexception.php
@@ -0,0 +1,27 @@
+<?php
+/**
+ * @author Arthur Schiwon <blizzz@owncloud.com>
+ *
+ * @copyright Copyright (c) 2016, ownCloud, Inc.
+ * @license AGPL-3.0
+ *
+ * This code is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License, version 3,
+ * along with this program. If not, see <http://www.gnu.org/licenses/>
+ *
+ */
+namespace OCP\Comments;
+
+/**
+ * Exception thrown when a comment message exceeds the allowed character limit
+ * @since 9.0.0
+ */
+class MessageTooLongException extends \OverflowException {}