2016-01-07 05:26:29 +01:00
|
|
|
# Copyright 2014-2016 OpenMarket Ltd
|
2023-02-27 21:08:18 +01:00
|
|
|
# Copyright 2018-2019 New Vector Ltd
|
|
|
|
# Copyright 2023 The Matrix.org Foundation C.I.C.
|
2014-08-12 16:10:52 +02:00
|
|
|
#
|
|
|
|
# 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.
|
2014-08-13 04:14:34 +02:00
|
|
|
|
2023-02-27 21:08:18 +01:00
|
|
|
""" This is an implementation of a Matrix homeserver.
|
2014-08-12 16:10:52 +02:00
|
|
|
"""
|
2014-08-22 13:06:50 +02:00
|
|
|
|
2019-09-27 16:11:14 +02:00
|
|
|
import os
|
2019-06-12 13:31:59 +02:00
|
|
|
import sys
|
2023-03-22 18:15:34 +01:00
|
|
|
from typing import Any, Dict
|
2019-06-12 13:31:59 +02:00
|
|
|
|
2023-08-30 13:17:26 +02:00
|
|
|
from PIL import ImageFile
|
|
|
|
|
2022-09-12 12:03:42 +02:00
|
|
|
from synapse.util.rust import check_rust_lib_up_to_date
|
2022-10-07 16:19:59 +02:00
|
|
|
from synapse.util.stringutils import strtobool
|
2022-09-12 12:03:42 +02:00
|
|
|
|
2023-08-30 13:17:26 +02:00
|
|
|
# Allow truncated JPEG images to be thumbnailed.
|
|
|
|
ImageFile.LOAD_TRUNCATED_IMAGES = True
|
|
|
|
|
2019-06-12 13:31:59 +02:00
|
|
|
# Check that we're not running on an unsupported Python version.
|
2023-08-15 14:11:20 +02:00
|
|
|
#
|
|
|
|
# Note that we use an (unneeded) variable here so that pyupgrade doesn't nuke the
|
|
|
|
# if-statement completely.
|
|
|
|
py_version = sys.version_info
|
|
|
|
if py_version < (3, 8):
|
2023-07-06 01:45:42 +02:00
|
|
|
print("Synapse requires Python 3.8 or above.")
|
2019-06-12 13:31:59 +02:00
|
|
|
sys.exit(1)
|
|
|
|
|
2022-03-08 14:23:18 +01:00
|
|
|
# Allow using the asyncio reactor via env var.
|
2022-10-07 16:19:59 +02:00
|
|
|
if strtobool(os.environ.get("SYNAPSE_ASYNC_IO_REACTOR", "0")):
|
|
|
|
from incremental import Version
|
2022-03-08 14:23:18 +01:00
|
|
|
|
2022-10-07 16:19:59 +02:00
|
|
|
import twisted
|
2022-03-08 14:23:18 +01:00
|
|
|
|
2022-10-07 16:19:59 +02:00
|
|
|
# We need a bugfix that is included in Twisted 21.2.0:
|
|
|
|
# https://twistedmatrix.com/trac/ticket/9787
|
|
|
|
if twisted.version < Version("Twisted", 21, 2, 0):
|
|
|
|
print("Using asyncio reactor requires Twisted>=21.2.0")
|
|
|
|
sys.exit(1)
|
2022-03-08 14:23:18 +01:00
|
|
|
|
2022-10-07 16:19:59 +02:00
|
|
|
import asyncio
|
2022-03-08 14:23:18 +01:00
|
|
|
|
2022-10-07 16:19:59 +02:00
|
|
|
from twisted.internet import asyncioreactor
|
2022-03-08 14:23:18 +01:00
|
|
|
|
2022-10-07 16:19:59 +02:00
|
|
|
asyncioreactor.install(asyncio.get_event_loop())
|
2022-03-08 14:23:18 +01:00
|
|
|
|
2020-07-28 16:28:59 +02:00
|
|
|
# Twisted and canonicaljson will fail to import when this file is executed to
|
|
|
|
# get the __version__ during a fresh install. That's OK and subsequent calls to
|
|
|
|
# actually start Synapse will import these libraries fine.
|
2018-09-13 11:59:32 +02:00
|
|
|
try:
|
|
|
|
from twisted.internet import protocol
|
|
|
|
from twisted.internet.protocol import Factory
|
|
|
|
from twisted.names.dns import DNSDatagramProtocol
|
2019-06-20 11:32:02 +02:00
|
|
|
|
2018-09-13 11:59:32 +02:00
|
|
|
protocol.Factory.noisy = False
|
|
|
|
Factory.noisy = False
|
|
|
|
DNSDatagramProtocol.noisy = False
|
|
|
|
except ImportError:
|
|
|
|
pass
|
|
|
|
|
2023-03-22 18:15:34 +01:00
|
|
|
# Teach canonicaljson how to serialise immutabledicts.
|
2020-07-28 16:28:59 +02:00
|
|
|
try:
|
2023-03-22 18:15:34 +01:00
|
|
|
from canonicaljson import register_preserialisation_callback
|
|
|
|
from immutabledict import immutabledict
|
|
|
|
|
|
|
|
def _immutabledict_cb(d: immutabledict) -> Dict[str, Any]:
|
|
|
|
try:
|
|
|
|
return d._dict
|
|
|
|
except Exception:
|
|
|
|
# Paranoia: fall back to a `dict()` call, in case a future version of
|
|
|
|
# immutabledict removes `_dict` from the implementation.
|
|
|
|
return dict(d)
|
|
|
|
|
|
|
|
register_preserialisation_callback(immutabledict, _immutabledict_cb)
|
2020-07-28 16:28:59 +02:00
|
|
|
except ImportError:
|
|
|
|
pass
|
|
|
|
|
2023-08-15 14:11:20 +02:00
|
|
|
import synapse.util # noqa: E402
|
2022-06-07 16:24:11 +02:00
|
|
|
|
|
|
|
__version__ = synapse.util.SYNAPSE_VERSION
|
2019-09-27 16:11:14 +02:00
|
|
|
|
|
|
|
if bool(os.environ.get("SYNAPSE_TEST_PATCH_LOG_CONTEXTS", False)):
|
2019-10-10 12:16:26 +02:00
|
|
|
# We import here so that we don't have to install a bunch of deps when
|
|
|
|
# running the packaging tox test.
|
|
|
|
from synapse.util.patch_inline_callbacks import do_patch
|
|
|
|
|
2019-09-27 16:11:14 +02:00
|
|
|
do_patch()
|
2022-09-12 12:03:42 +02:00
|
|
|
|
|
|
|
|
|
|
|
check_rust_lib_up_to_date()
|