0
0
Fork 1
mirror of https://mau.dev/maunium/synapse.git synced 2024-12-15 02:23:49 +01:00

SYWEB-48: Better regex for binging on usernames.

This uses /\blocalpart\b|\bdisplayname\b/i which is overall a lot
better than before. This specifically gets @localpart references
which the bug was originally for.
This commit is contained in:
Kegan Dougal 2014-10-29 17:43:18 +00:00
parent beae9acfcc
commit 0f192579ac

View file

@ -58,14 +58,29 @@ function(matrixService, $rootScope, $q, $timeout, mPresence) {
var shouldBing = false; var shouldBing = false;
// case-insensitive name check for user_id OR display_name if they exist // case-insensitive name check for user_id OR display_name if they exist
var userRegex = "";
var myUserId = matrixService.config().user_id; var myUserId = matrixService.config().user_id;
if (myUserId) { if (myUserId) {
myUserId = myUserId.toLocaleLowerCase(); var localpart = getLocalPartFromUserId(myUserId);
if (localpart) {
localpart = localpart.toLocaleLowerCase();
userRegex += "\\b" + localpart + "\\b";
}
} }
var myDisplayName = matrixService.config().display_name; var myDisplayName = matrixService.config().display_name;
if (myDisplayName) { if (myDisplayName) {
myDisplayName = myDisplayName.toLocaleLowerCase(); myDisplayName = myDisplayName.toLocaleLowerCase();
if (userRegex.length > 0) {
userRegex += "|";
} }
userRegex += "\\b" + myDisplayName + "\\b";
}
var r = new RegExp(userRegex, 'i');
if (content.search(r) >= 0) {
shouldBing = true;
}
if ( (myDisplayName && content.toLocaleLowerCase().indexOf(myDisplayName) != -1) || if ( (myDisplayName && content.toLocaleLowerCase().indexOf(myDisplayName) != -1) ||
(myUserId && content.toLocaleLowerCase().indexOf(myUserId) != -1) ) { (myUserId && content.toLocaleLowerCase().indexOf(myUserId) != -1) ) {
shouldBing = true; shouldBing = true;
@ -84,6 +99,18 @@ function(matrixService, $rootScope, $q, $timeout, mPresence) {
return shouldBing; return shouldBing;
}; };
var getLocalPartFromUserId = function(user_id) {
if (!user_id) {
return null;
}
var localpartRegex = /@(.*):\w+/i
var results = localpartRegex.exec(user_id);
if (results && results.length == 2) {
return results[1];
}
return null;
};
var initialSyncDeferred; var initialSyncDeferred;
var reset = function() { var reset = function() {