This repository has been archived by the owner on Apr 26, 2024. It is now read-only.
-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Treat "\u0000" as "\u0020" for the purposes of message search (messag…
…e indexing) (#10820) * add test to check if null code points are being inserted * add logic to detect and replace null code points before insertion into db * lints * add license to test * change approach to null substitution * add type hint for SearchEntry * Add changelog entry Signed-off-by: H.Shay <shaysquared@gmail.com> * updated changelog * update chanelog message * remove duplicate changelog * Update synapse/storage/databases/main/events.py remove extra space Co-authored-by: Patrick Cloke <clokep@users.noreply.github.com> * rename and move test file, update tests, delete old test file * fix typo in comments * update _find_highlights_in_postgres to replace null byte with space * replace null byte in sqlite search insertion * beef up and reorganize test for this pr * update changelog * add type hints and update docstring * check db engine directly vs using env variable * refactor tests to be less repetetive * move rplace logic into seperate function * requested changes * Fix typo. * Update synapse/storage/databases/main/search.py Co-authored-by: reivilibre <olivier@librepush.net> * Update changelog.d/10820.misc Co-authored-by: Aaron Raimist <aaron@raim.ist> Co-authored-by: Patrick Cloke <clokep@users.noreply.github.com> Co-authored-by: reivilibre <olivier@librepush.net> Co-authored-by: Aaron Raimist <aaron@raim.ist>
- Loading branch information
1 parent
03db670
commit f78b68a
Showing
3 changed files
with
100 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Fix a long-standing bug where an `m.room.message` event containing a null byte would cause an internal server error. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
# Copyright 2021 The Matrix.org Foundation C.I.C. | ||
# | ||
# Licensed under the Apache License, Version 2.0 (the "License"); | ||
# you may not use this file except in compliance with the License. | ||
# You may obtain a copy of the License at | ||
# | ||
# http://www.apache.org/licenses/LICENSE-2.0 | ||
# | ||
# Unless required by applicable law or agreed to in writing, software | ||
# distributed under the License is distributed on an "AS IS" BASIS, | ||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
# See the License for the specific language governing permissions and | ||
# limitations under the License. | ||
|
||
import synapse.rest.admin | ||
from synapse.rest.client import login, room | ||
from synapse.storage.engines import PostgresEngine | ||
|
||
from tests.unittest import HomeserverTestCase | ||
|
||
|
||
class NullByteInsertionTest(HomeserverTestCase): | ||
servlets = [ | ||
synapse.rest.admin.register_servlets_for_client_rest_resource, | ||
login.register_servlets, | ||
room.register_servlets, | ||
] | ||
|
||
def test_null_byte(self): | ||
""" | ||
Postgres/SQLite don't like null bytes going into the search tables. Internally | ||
we replace those with a space. | ||
Ensure this doesn't break anything. | ||
""" | ||
|
||
# Register a user and create a room, create some messages | ||
self.register_user("alice", "password") | ||
access_token = self.login("alice", "password") | ||
room_id = self.helper.create_room_as("alice", tok=access_token) | ||
|
||
# Send messages and ensure they don't cause an internal server | ||
# error | ||
for body in ["hi\u0000bob", "another message", "hi alice"]: | ||
response = self.helper.send(room_id, body, tok=access_token) | ||
self.assertIn("event_id", response) | ||
|
||
# Check that search works for the message where the null byte was replaced | ||
store = self.hs.get_datastore() | ||
result = self.get_success( | ||
store.search_msgs([room_id], "hi bob", ["content.body"]) | ||
) | ||
self.assertEquals(result.get("count"), 1) | ||
if isinstance(store.database_engine, PostgresEngine): | ||
self.assertIn("hi", result.get("highlights")) | ||
self.assertIn("bob", result.get("highlights")) | ||
|
||
# Check that search works for an unrelated message | ||
result = self.get_success( | ||
store.search_msgs([room_id], "another", ["content.body"]) | ||
) | ||
self.assertEquals(result.get("count"), 1) | ||
if isinstance(store.database_engine, PostgresEngine): | ||
self.assertIn("another", result.get("highlights")) | ||
|
||
# Check that search works for a search term that overlaps with the message | ||
# containing a null byte and an unrelated message. | ||
result = self.get_success(store.search_msgs([room_id], "hi", ["content.body"])) | ||
self.assertEquals(result.get("count"), 2) | ||
result = self.get_success( | ||
store.search_msgs([room_id], "hi alice", ["content.body"]) | ||
) | ||
if isinstance(store.database_engine, PostgresEngine): | ||
self.assertIn("alice", result.get("highlights")) |