aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2018-10-12 14:25:46 +0200
committerJoas Schilling <coding@schilljs.com>2018-11-07 12:33:44 +0100
commit10ba0bed8a6a3f43526c36768feea522325d4a80 (patch)
tree291b31e55b28624c7a58c8d161eb214e5347875a
parentc26d847d19c967aa5bc99f9bc15c27c7e95ee55f (diff)
downloadnextcloud-server-10ba0bed8a6a3f43526c36768feea522325d4a80.tar.gz
nextcloud-server-10ba0bed8a6a3f43526c36768feea522325d4a80.zip
Match mentions when the username is wrapped in quotes
Signed-off-by: Joas Schilling <coding@schilljs.com>
-rw-r--r--lib/private/Comments/Comment.php4
-rw-r--r--tests/lib/Comments/CommentTest.php7
2 files changed, 7 insertions, 4 deletions
diff --git a/lib/private/Comments/Comment.php b/lib/private/Comments/Comment.php
index 94c43be622b..76c6e1d1f6b 100644
--- a/lib/private/Comments/Comment.php
+++ b/lib/private/Comments/Comment.php
@@ -225,14 +225,14 @@ class Comment implements IComment {
*
*/
public function getMentions() {
- $ok = preg_match_all("/\B(?<![^a-z0-9_\-@\.\'\s])@[a-z0-9_\-@\.\']+/i", $this->getMessage(), $mentions);
+ $ok = preg_match_all("/\B(?<![^a-z0-9_\-@\.\'\s])@(\"[a-z0-9_\-@\.\' ]+\"|[a-z0-9_\-@\.\']+)/i", $this->getMessage(), $mentions);
if(!$ok || !isset($mentions[0]) || !is_array($mentions[0])) {
return [];
}
$uids = array_unique($mentions[0]);
$result = [];
foreach ($uids as $uid) {
- $result[] = ['type' => 'user', 'id' => substr($uid, 1)];
+ $result[] = ['type' => 'user', 'id' => trim(substr($uid, 1), '"')];
}
return $result;
}
diff --git a/tests/lib/Comments/CommentTest.php b/tests/lib/Comments/CommentTest.php
index 15dd9120e44..5fb19396d84 100644
--- a/tests/lib/Comments/CommentTest.php
+++ b/tests/lib/Comments/CommentTest.php
@@ -150,8 +150,11 @@ class CommentTest extends TestCase {
['foobar', 'barfoo', 'foo@bar.com', 'bar@foo.org@foobar.io', '23452-4333-54353-2342', 'yolo']
],
[
- '@@chef is also a valid mention, no matter how strange it looks', ['@chef']
- ]
+ '@@chef is also a valid mention, no matter how strange it looks', ['@chef']
+ ],
+ [
+ 'Also @"user with spaces" are now supported', ['user with spaces']
+ ],
];
}