Skip to content
This repository has been archived by the owner on Apr 26, 2024. It is now read-only.

Commit

Permalink
Merge tag 'v0.33.3rc2' into matrix-org-hotfixes
Browse files Browse the repository at this point in the history
Bugfixes
--------

- Fix bug in v0.33.3rc1 which caused infinite loops and OOMs
([\#3723](#3723))
  • Loading branch information
hera committed Aug 21, 2018
2 parents 5678631 + 3b5b64a commit d1065e6
Show file tree
Hide file tree
Showing 55 changed files with 181 additions and 85 deletions.
73 changes: 73 additions & 0 deletions CHANGES.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,76 @@
Synapse 0.33.3rc2 (2018-08-21)
==============================

Bugfixes
--------

- Fix bug in v0.33.3rc1 which caused infinite loops and OOMs ([\#3723](https://github.com/matrix-org/synapse/issues/3723))


Synapse 0.33.3rc1 (2018-08-21)
==============================

Features
--------

- Add support for the SNI extension to federation TLS connections ([\#1491](https://github.com/matrix-org/synapse/issues/1491))
- Add /_media/r0/config ([\#3184](https://github.com/matrix-org/synapse/issues/3184))
- speed up /members API and add `at` and `membership` params as per MSC1227 ([\#3568](https://github.com/matrix-org/synapse/issues/3568))
- implement `summary` block in /sync response as per MSC688 ([\#3574](https://github.com/matrix-org/synapse/issues/3574))
- Add lazy-loading support to /messages as per MSC1227 ([\#3589](https://github.com/matrix-org/synapse/issues/3589))
- Add ability to limit number of monthly active users on the server ([\#3633](https://github.com/matrix-org/synapse/issues/3633))
- Support more federation endpoints on workers ([\#3653](https://github.com/matrix-org/synapse/issues/3653))
- Basic support for room versioning ([\#3654](https://github.com/matrix-org/synapse/issues/3654))
- Ability to disable client/server Synapse via conf toggle ([\#3655](https://github.com/matrix-org/synapse/issues/3655))
- Ability to whitelist specific threepids against monthly active user limiting ([\#3662](https://github.com/matrix-org/synapse/issues/3662))
- Add some metrics for the appservice and federation event sending loops ([\#3664](https://github.com/matrix-org/synapse/issues/3664))
- Where server is disabled, block ability for locked out users to read new messages ([\#3670](https://github.com/matrix-org/synapse/issues/3670))
- set admin uri via config, to be used in error messages where the user should contact the administrator ([\#3687](https://github.com/matrix-org/synapse/issues/3687))
- Synapse's presence functionality can now be disabled with the "use_presence" configuration option. ([\#3694](https://github.com/matrix-org/synapse/issues/3694))
- For resource limit blocked users, prevent writing into rooms ([\#3708](https://github.com/matrix-org/synapse/issues/3708))


Bugfixes
--------

- Fix occasional glitches in the synapse_event_persisted_position metric ([\#3658](https://github.com/matrix-org/synapse/issues/3658))
- Fix bug on deleting 3pid when using identity servers that don't support unbind API ([\#3661](https://github.com/matrix-org/synapse/issues/3661))
- Make the tests pass on Twisted < 18.7.0 ([\#3676](https://github.com/matrix-org/synapse/issues/3676))
- Don’t ship recaptcha_ajax.js, use it directly from Google ([\#3677](https://github.com/matrix-org/synapse/issues/3677))
- Fixes test_reap_monthly_active_users so it passes under postgres ([\#3681](https://github.com/matrix-org/synapse/issues/3681))
- Fix mau blocking calulation bug on login ([\#3689](https://github.com/matrix-org/synapse/issues/3689))
- Fix missing yield in synapse.storage.monthly_active_users.initialise_reserved_users ([\#3692](https://github.com/matrix-org/synapse/issues/3692))
- Improve HTTP request logging to include all requests ([\#3700](https://github.com/matrix-org/synapse/issues/3700))
- Avoid timing out requests while we are streaming back the response ([\#3701](https://github.com/matrix-org/synapse/issues/3701))
- Support more federation endpoints on workers ([\#3705](https://github.com/matrix-org/synapse/issues/3705), [\#3713](https://github.com/matrix-org/synapse/issues/3713))
- Fix "Starting db txn 'get_all_updated_receipts' from sentinel context" warning ([\#3710](https://github.com/matrix-org/synapse/issues/3710))
- Fix bug where `state_cache` cache factor ignored environment variables ([\#3719](https://github.com/matrix-org/synapse/issues/3719))


Deprecations and Removals
-------------------------

- The Shared-Secret registration method of the legacy v1/register REST endpoint has been removed. For a replacement, please see [the admin/register API documentation](https://github.com/matrix-org/synapse/blob/master/docs/admin_api/register_api.rst). ([\#3703](https://github.com/matrix-org/synapse/issues/3703))


Internal Changes
----------------

- The test suite now can run under PostgreSQL. ([\#3423](https://github.com/matrix-org/synapse/issues/3423))
- Refactor HTTP replication endpoints to reduce code duplication ([\#3632](https://github.com/matrix-org/synapse/issues/3632))
- Tests now correctly execute on Python 3. ([\#3647](https://github.com/matrix-org/synapse/issues/3647))
- Sytests can now be run inside a Docker container. ([\#3660](https://github.com/matrix-org/synapse/issues/3660))
- Port over enough to Python 3 to allow the sytests to start. ([\#3668](https://github.com/matrix-org/synapse/issues/3668))
- Update docker base image from alpine 3.7 to 3.8. ([\#3669](https://github.com/matrix-org/synapse/issues/3669))
- Rename synapse.util.async to synapse.util.async_helpers to mitigate async becoming a keyword on Python 3.7. ([\#3678](https://github.com/matrix-org/synapse/issues/3678))
- Synapse's tests are now formatted with the black autoformatter. ([\#3679](https://github.com/matrix-org/synapse/issues/3679))
- Implemented a new testing base class to reduce test boilerplate. ([\#3684](https://github.com/matrix-org/synapse/issues/3684))
- Rename MAU prometheus metrics ([\#3690](https://github.com/matrix-org/synapse/issues/3690))
- add new error type ResourceLimit ([\#3707](https://github.com/matrix-org/synapse/issues/3707))
- Logcontexts for replication command handlers ([\#3709](https://github.com/matrix-org/synapse/issues/3709))
- Update admin register API documentation to reference a real user ID. ([\#3712](https://github.com/matrix-org/synapse/issues/3712))


Synapse 0.33.2 (2018-08-09)
===========================

Expand Down
1 change: 0 additions & 1 deletion changelog.d/1491.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3184.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3423.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3568.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3574.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3589.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3632.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3633.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3647.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3653.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3654.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3655.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3658.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3660.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3661.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3662.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3664.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3669.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3670.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3676.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3677.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3678.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3679.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3681.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3684.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3687.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3689.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3690.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3692.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3694.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3700.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3701.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3703.removal

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3705.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3707.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3708.feature

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3709.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3710.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3712.misc

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3713.bugfix

This file was deleted.

1 change: 0 additions & 1 deletion changelog.d/3719.bugfix

This file was deleted.

2 changes: 1 addition & 1 deletion synapse/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,4 +17,4 @@
""" This is a reference implementation of a Matrix home server.
"""

__version__ = "0.33.2"
__version__ = "0.33.3rc2"
14 changes: 7 additions & 7 deletions synapse/api/auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -211,7 +211,7 @@ def get_user_by_req(self, request, allow_guest=False, rights="access"):
user_agent = request.requestHeaders.getRawHeaders(
b"User-Agent",
default=[b""]
)[0]
)[0].decode('ascii', 'surrogateescape')
if user and access_token and ip_addr:
yield self.store.insert_client_ip(
user_id=user.to_string(),
Expand Down Expand Up @@ -682,7 +682,7 @@ def has_access_token(request):
Returns:
bool: False if no access_token was given, True otherwise.
"""
query_params = request.args.get("access_token")
query_params = request.args.get(b"access_token")
auth_headers = request.requestHeaders.getRawHeaders(b"Authorization")
return bool(query_params) or bool(auth_headers)

Expand All @@ -698,7 +698,7 @@ def get_access_token_from_request(request, token_not_found_http_status=401):
401 since some of the old clients depended on auth errors returning
403.
Returns:
str: The access_token
unicode: The access_token
Raises:
AuthError: If there isn't an access_token in the request.
"""
Expand All @@ -720,9 +720,9 @@ def get_access_token_from_request(request, token_not_found_http_status=401):
"Too many Authorization headers.",
errcode=Codes.MISSING_TOKEN,
)
parts = auth_headers[0].split(" ")
if parts[0] == "Bearer" and len(parts) == 2:
return parts[1]
parts = auth_headers[0].split(b" ")
if parts[0] == b"Bearer" and len(parts) == 2:
return parts[1].decode('ascii')
else:
raise AuthError(
token_not_found_http_status,
Expand All @@ -738,7 +738,7 @@ def get_access_token_from_request(request, token_not_found_http_status=401):
errcode=Codes.MISSING_TOKEN
)

return query_params[0]
return query_params[0].decode('ascii')

@defer.inlineCallbacks
def check_in_room_or_world_readable(self, room_id, user_id):
Expand Down
2 changes: 1 addition & 1 deletion synapse/api/ratelimiting.py
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ def send_message(self, user_id, time_now_s, msg_rate_hz, burst_count, update=Tru
return allowed, time_allowed

def prune_message_counts(self, time_now_s):
for user_id in self.message_counts.keys():
for user_id in list(self.message_counts.keys()):
message_count, time_start, msg_rate_hz = (
self.message_counts[user_id]
)
Expand Down
3 changes: 2 additions & 1 deletion synapse/config/logger.py
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,8 @@ def setup_logging(config, use_worker_options=False):
if log_file:
# TODO: Customisable file size / backup count
handler = logging.handlers.RotatingFileHandler(
log_file, maxBytes=(1000 * 1000 * 100), backupCount=3
log_file, maxBytes=(1000 * 1000 * 100), backupCount=3,
encoding='utf8'
)

def sighup(signum, stack):
Expand Down
56 changes: 42 additions & 14 deletions synapse/http/servlet.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ def parse_integer(request, name, default=None, required=False):
Args:
request: the twisted HTTP request.
name (str): the name of the query parameter.
name (bytes/unicode): the name of the query parameter.
default (int|None): value to use if the parameter is absent, defaults
to None.
required (bool): whether to raise a 400 SynapseError if the
Expand All @@ -46,6 +46,10 @@ def parse_integer(request, name, default=None, required=False):


def parse_integer_from_args(args, name, default=None, required=False):

if not isinstance(name, bytes):
name = name.encode('ascii')

if name in args:
try:
return int(args[name][0])
Expand All @@ -65,7 +69,7 @@ def parse_boolean(request, name, default=None, required=False):
Args:
request: the twisted HTTP request.
name (str): the name of the query parameter.
name (bytes/unicode): the name of the query parameter.
default (bool|None): value to use if the parameter is absent, defaults
to None.
required (bool): whether to raise a 400 SynapseError if the
Expand All @@ -83,11 +87,15 @@ def parse_boolean(request, name, default=None, required=False):


def parse_boolean_from_args(args, name, default=None, required=False):

if not isinstance(name, bytes):
name = name.encode('ascii')

if name in args:
try:
return {
"true": True,
"false": False,
b"true": True,
b"false": False,
}[args[name][0]]
except Exception:
message = (
Expand All @@ -104,36 +112,52 @@ def parse_boolean_from_args(args, name, default=None, required=False):


def parse_string(request, name, default=None, required=False,
allowed_values=None, param_type="string"):
"""Parse a string parameter from the request query string.
allowed_values=None, param_type="string", encoding='ascii'):
"""
Parse a string parameter from the request query string.
If encoding is not None, the content of the query param will be
decoded to Unicode using the encoding, otherwise it will be encoded
Args:
request: the twisted HTTP request.
name (str): the name of the query parameter.
default (str|None): value to use if the parameter is absent, defaults
to None.
name (bytes/unicode): the name of the query parameter.
default (bytes/unicode|None): value to use if the parameter is absent,
defaults to None. Must be bytes if encoding is None.
required (bool): whether to raise a 400 SynapseError if the
parameter is absent, defaults to False.
allowed_values (list[str]): List of allowed values for the string,
or None if any value is allowed, defaults to None
allowed_values (list[bytes/unicode]): List of allowed values for the
string, or None if any value is allowed, defaults to None. Must be
the same type as name, if given.
encoding: The encoding to decode the name to, and decode the string
content with.
Returns:
str|None: A string value or the default.
bytes/unicode|None: A string value or the default. Unicode if encoding
was given, bytes otherwise.
Raises:
SynapseError if the parameter is absent and required, or if the
parameter is present, must be one of a list of allowed values and
is not one of those allowed values.
"""
return parse_string_from_args(
request.args, name, default, required, allowed_values, param_type,
request.args, name, default, required, allowed_values, param_type, encoding
)


def parse_string_from_args(args, name, default=None, required=False,
allowed_values=None, param_type="string"):
allowed_values=None, param_type="string", encoding='ascii'):

if not isinstance(name, bytes):
name = name.encode('ascii')

if name in args:
value = args[name][0]

if encoding:
value = value.decode(encoding)

if allowed_values is not None and value not in allowed_values:
message = "Query parameter %r must be one of [%s]" % (
name, ", ".join(repr(v) for v in allowed_values)
Expand All @@ -146,6 +170,10 @@ def parse_string_from_args(args, name, default=None, required=False,
message = "Missing %s query parameter %r" % (param_type, name)
raise SynapseError(400, message, errcode=Codes.MISSING_PARAM)
else:

if encoding and isinstance(default, bytes):
return default.decode(encoding)

return default


Expand Down
12 changes: 9 additions & 3 deletions synapse/http/site.py
Original file line number Diff line number Diff line change
Expand Up @@ -182,7 +182,7 @@ def connectionLost(self, reason):
# the client disconnects.
with PreserveLoggingContext(self.logcontext):
logger.warn(
"Error processing request: %s %s", reason.type, reason.value,
"Error processing request %r: %s %s", self, reason.type, reason.value,
)

if not self._is_processing:
Expand Down Expand Up @@ -219,6 +219,12 @@ def _finished_processing(self):
"""Log the completion of this request and update the metrics
"""

if self.logcontext is None:
# this can happen if the connection closed before we read the
# headers (so render was never called). In that case we'll already
# have logged a warning, so just bail out.
return

usage = self.logcontext.get_resource_usage()

if self._processing_finished_time is None:
Expand All @@ -235,7 +241,7 @@ def _finished_processing(self):
# need to decode as it could be raw utf-8 bytes
# from a IDN servname in an auth header
authenticated_entity = self.authenticated_entity
if authenticated_entity is not None:
if authenticated_entity is not None and isinstance(authenticated_entity, bytes):
authenticated_entity = authenticated_entity.decode("utf-8", "replace")

# ...or could be raw utf-8 bytes in the User-Agent header.
Expand Down Expand Up @@ -328,7 +334,7 @@ def __init__(self, logger_name, site_tag, config, resource,
proxied = config.get("x_forwarded", False)
self.requestFactory = SynapseRequestFactory(self, proxied)
self.access_logger = logging.getLogger(logger_name)
self.server_version_string = server_version_string
self.server_version_string = server_version_string.encode('ascii')

def log(self, request):
pass
Loading

0 comments on commit d1065e6

Please sign in to comment.