forked from MirrorHub/synapse
Merge branch 'release-v1.38' into develop
This commit is contained in:
commit
4358f51bb6
36 changed files with 89 additions and 66 deletions
61
.github/workflows/docs.yaml
vendored
61
.github/workflows/docs.yaml
vendored
|
@ -7,6 +7,8 @@ on:
|
||||||
- develop
|
- develop
|
||||||
# For documentation specific to a release
|
# For documentation specific to a release
|
||||||
- 'release-v*'
|
- 'release-v*'
|
||||||
|
# stable docs
|
||||||
|
- master
|
||||||
|
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
|
@ -30,40 +32,35 @@ jobs:
|
||||||
mdbook build
|
mdbook build
|
||||||
cp book/welcome_and_overview.html book/index.html
|
cp book/welcome_and_overview.html book/index.html
|
||||||
|
|
||||||
# Deploy to the latest documentation directories
|
# Figure out the target directory.
|
||||||
- name: Deploy latest documentation
|
#
|
||||||
|
# The target directory depends on the name of the branch
|
||||||
|
#
|
||||||
|
- name: Get the target directory name
|
||||||
|
id: vars
|
||||||
|
run: |
|
||||||
|
# first strip the 'refs/heads/' prefix with some shell foo
|
||||||
|
branch="${GITHUB_REF#refs/heads/}"
|
||||||
|
|
||||||
|
case $branch in
|
||||||
|
release-*)
|
||||||
|
# strip 'release-' from the name for release branches.
|
||||||
|
branch="${branch#release-}"
|
||||||
|
;;
|
||||||
|
master)
|
||||||
|
# deploy to "latest" for the master branch.
|
||||||
|
branch="latest"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# finally, set the 'branch-version' var.
|
||||||
|
echo "::set-output name=branch-version::$branch"
|
||||||
|
|
||||||
|
# Deploy to the target directory.
|
||||||
|
- name: Deploy to gh pages
|
||||||
uses: peaceiris/actions-gh-pages@068dc23d9710f1ba62e86896f84735d869951305 # v3.8.0
|
uses: peaceiris/actions-gh-pages@068dc23d9710f1ba62e86896f84735d869951305 # v3.8.0
|
||||||
with:
|
with:
|
||||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
github_token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
keep_files: true
|
keep_files: true
|
||||||
publish_dir: ./book
|
publish_dir: ./book
|
||||||
destination_dir: ./develop
|
destination_dir: ./${{ steps.vars.outputs.branch-version }}
|
||||||
|
|
||||||
- name: Get the current Synapse version
|
|
||||||
id: vars
|
|
||||||
# The $GITHUB_REF value for a branch looks like `refs/heads/release-v1.2`. We do some
|
|
||||||
# shell magic to remove the "refs/heads/release-v" bit from this, to end up with "1.2",
|
|
||||||
# our major/minor version number, and set this to a var called `branch-version`.
|
|
||||||
#
|
|
||||||
# We then use some python to get Synapse's full version string, which may look
|
|
||||||
# like "1.2.3rc4". We set this to a var called `synapse-version`. We use this
|
|
||||||
# to determine if this release is still an RC, and if so block deployment.
|
|
||||||
run: |
|
|
||||||
echo ::set-output name=branch-version::${GITHUB_REF#refs/heads/release-v}
|
|
||||||
echo ::set-output name=synapse-version::`python3 -c 'import synapse; print(synapse.__version__)'`
|
|
||||||
|
|
||||||
# Deploy to the version-specific directory
|
|
||||||
- name: Deploy release-specific documentation
|
|
||||||
# We only carry out this step if we're running on a release branch,
|
|
||||||
# and the current Synapse version does not have "rc" in the name.
|
|
||||||
#
|
|
||||||
# The result is that only full releases are deployed, but can be
|
|
||||||
# updated if the release branch gets retroactive fixes.
|
|
||||||
if: ${{ startsWith( github.ref, 'refs/heads/release-v' ) && !contains( steps.vars.outputs.synapse-version, 'rc') }}
|
|
||||||
uses: peaceiris/actions-gh-pages@v3
|
|
||||||
with:
|
|
||||||
github_token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
keep_files: true
|
|
||||||
publish_dir: ./book
|
|
||||||
# The resulting documentation will end up in a directory named `vX.Y`.
|
|
||||||
destination_dir: ./v${{ steps.vars.outputs.branch-version }}
|
|
||||||
|
|
51
CHANGES.md
51
CHANGES.md
|
@ -1,7 +1,54 @@
|
||||||
Synapse 1.38.0 (**UNRELEASED**)
|
Synapse 1.38.0rc1 (2021-07-06)
|
||||||
===============================
|
==============================
|
||||||
|
|
||||||
This release includes a database schema update which could result in elevated disk usage. See the [upgrade notes](https://matrix-org.github.io/synapse/develop/upgrade.md#upgrading-to-v1380) for more information.
|
This release includes a database schema update which could result in elevated disk usage. See the [upgrade notes](https://matrix-org.github.io/synapse/develop/upgrade.md#upgrading-to-v1380) for more information.
|
||||||
|
|
||||||
|
Features
|
||||||
|
--------
|
||||||
|
|
||||||
|
- Implement refresh tokens as specified by [MSC2918](https://github.com/matrix-org/matrix-doc/pull/2918). ([\#9450](https://github.com/matrix-org/synapse/issues/9450))
|
||||||
|
- Add support for evicting cache entries based on last access time. ([\#10205](https://github.com/matrix-org/synapse/issues/10205))
|
||||||
|
- Omit empty fields from the `/sync` response. Contributed by @deepbluev7. ([\#10214](https://github.com/matrix-org/synapse/issues/10214))
|
||||||
|
- Improve validation on federation `send_{join,leave,knock}` endpoints. ([\#10225](https://github.com/matrix-org/synapse/issues/10225), [\#10243](https://github.com/matrix-org/synapse/issues/10243))
|
||||||
|
- Add SSO `external_ids` to the Query User Account admin API. ([\#10261](https://github.com/matrix-org/synapse/issues/10261))
|
||||||
|
- Mark events received over federation which fail a spam check as "soft-failed". ([\#10263](https://github.com/matrix-org/synapse/issues/10263))
|
||||||
|
- Add metrics for new inbound federation staging area. ([\#10284](https://github.com/matrix-org/synapse/issues/10284))
|
||||||
|
- Add script to print information about recently registered users. ([\#10290](https://github.com/matrix-org/synapse/issues/10290))
|
||||||
|
|
||||||
|
|
||||||
|
Bugfixes
|
||||||
|
--------
|
||||||
|
|
||||||
|
- Fix a long-standing bug which meant that invite rejections and knocks were not sent out over federation in a timely manner. ([\#10223](https://github.com/matrix-org/synapse/issues/10223))
|
||||||
|
- Fix a bug introduced in v1.26.0 where only users who have set profile information could be deactivated with erasure enabled. ([\#10252](https://github.com/matrix-org/synapse/issues/10252))
|
||||||
|
- Fix a long-standing bug where Synapse would return errors after 2<sup>31</sup> events were handled by the server. ([\#10264](https://github.com/matrix-org/synapse/issues/10264), [\#10267](https://github.com/matrix-org/synapse/issues/10267), [\#10282](https://github.com/matrix-org/synapse/issues/10282), [\#10286](https://github.com/matrix-org/synapse/issues/10286), [\#10291](https://github.com/matrix-org/synapse/issues/10291), [\#10314](https://github.com/matrix-org/synapse/issues/10314))
|
||||||
|
- Fix the prometheus `synapse_federation_server_pdu_process_time` metric. Broke in v1.37.1. ([\#10279](https://github.com/matrix-org/synapse/issues/10279))
|
||||||
|
- Ensure that inbound events from federation that were being processed when Synapse was restarted get promptly processed on start up. ([\#10303](https://github.com/matrix-org/synapse/issues/10303))
|
||||||
|
|
||||||
|
|
||||||
|
Improved Documentation
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
- Move the upgrade notes to [docs/upgrade.md](https://github.com/matrix-org/synapse/blob/develop/docs/upgrade.md) and convert them to markdown. ([\#10166](https://github.com/matrix-org/synapse/issues/10166))
|
||||||
|
- Choose Welcome & Overview as the default page for synapse documentation website. ([\#10242](https://github.com/matrix-org/synapse/issues/10242))
|
||||||
|
- Adjust the URL in the README.rst file to point to irc.libera.chat. ([\#10258](https://github.com/matrix-org/synapse/issues/10258))
|
||||||
|
- Fix homeserver config option name in presence router documentation. ([\#10288](https://github.com/matrix-org/synapse/issues/10288))
|
||||||
|
- Fix link pointing at the wrong section in the modules documentation page. ([\#10302](https://github.com/matrix-org/synapse/issues/10302))
|
||||||
|
|
||||||
|
|
||||||
|
Internal Changes
|
||||||
|
----------------
|
||||||
|
|
||||||
|
- Drop `Origin` and `Accept` from the value of the `Access-Control-Allow-Headers` response header. ([\#10114](https://github.com/matrix-org/synapse/issues/10114))
|
||||||
|
- Add type hints to the federation servlets. ([\#10213](https://github.com/matrix-org/synapse/issues/10213))
|
||||||
|
- Improve the reliability of auto-joining remote rooms. ([\#10237](https://github.com/matrix-org/synapse/issues/10237))
|
||||||
|
- Update the release script to use the semver terminology and determine the release branch based on the next version. ([\#10239](https://github.com/matrix-org/synapse/issues/10239))
|
||||||
|
- Fix type hints for computing auth events. ([\#10253](https://github.com/matrix-org/synapse/issues/10253))
|
||||||
|
- Improve the performance of the spaces summary endpoint by only recursing into spaces (and not rooms in general). ([\#10256](https://github.com/matrix-org/synapse/issues/10256))
|
||||||
|
- Move event authentication methods from `Auth` to `EventAuthHandler`. ([\#10268](https://github.com/matrix-org/synapse/issues/10268))
|
||||||
|
- Re-enable a SyTest after it has been fixed. ([\#10292](https://github.com/matrix-org/synapse/issues/10292))
|
||||||
|
|
||||||
|
|
||||||
Synapse 1.37.1 (2021-06-30)
|
Synapse 1.37.1 (2021-06-30)
|
||||||
===========================
|
===========================
|
||||||
|
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
Drop Origin and Accept from the value of the Access-Control-Allow-Headers response header.
|
|
|
@ -1 +0,0 @@
|
||||||
Move the upgrade notes to [docs/upgrade.md](https://github.com/matrix-org/synapse/blob/develop/docs/upgrade.md) and convert them to markdown.
|
|
|
@ -1 +0,0 @@
|
||||||
Add support for evicting cache entries based on last access time.
|
|
|
@ -1 +0,0 @@
|
||||||
Add type hints to the federation servlets.
|
|
|
@ -1 +0,0 @@
|
||||||
Omit empty fields from the `/sync` response. Contributed by @deepbluev7.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix a long-standing bug which meant that invite rejections and knocks were not sent out over federation in a timely manner.
|
|
|
@ -1 +0,0 @@
|
||||||
Improve validation on federation `send_{join,leave,knock}` endpoints.
|
|
|
@ -1 +0,0 @@
|
||||||
Improve the reliability of auto-joining remote rooms.
|
|
|
@ -1 +0,0 @@
|
||||||
Update the release script to use the semver terminology and determine the release branch based on the next version.
|
|
|
@ -1 +0,0 @@
|
||||||
Choose Welcome & Overview as the default page for synapse documentation website.
|
|
|
@ -1 +0,0 @@
|
||||||
Improve validation on federation `send_{join,leave,knock}` endpoints.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix a bug introduced in v1.26.0 where only users who have set profile information could be deactivated with erasure enabled.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix type hints for computing auth events.
|
|
|
@ -1 +0,0 @@
|
||||||
Improve the performance of the spaces summary endpoint by only recursing into spaces (and not rooms in general).
|
|
|
@ -1 +0,0 @@
|
||||||
Adjust the URL in the README.rst file to point to irc.libera.chat.
|
|
|
@ -1 +0,0 @@
|
||||||
Add SSO `external_ids` to the Query User Account admin API.
|
|
|
@ -1 +0,0 @@
|
||||||
Mark events received over federation which fail a spam check as "soft-failed".
|
|
|
@ -1 +0,0 @@
|
||||||
Fix a long-standing bug where Synapse would return errors after 2<sup>31</sup> events were handled by the server.
|
|
|
@ -1 +0,0 @@
|
||||||
Move event authentication methods from `Auth` to `EventAuthHandler`.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix the prometheus `synapse_federation_server_pdu_process_time` metric. Broke in v1.37.1.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix a long-standing bug where Synapse would return errors after 2<sup>31</sup> events were handled by the server.
|
|
|
@ -1 +0,0 @@
|
||||||
Add metrics for new inbound federation staging area.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix a long-standing bug where Synapse would return errors after 2<sup>31</sup> events were handled by the server.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix homeserver config option name in presence router documentation.
|
|
|
@ -1 +0,0 @@
|
||||||
Add script to print information about recently registered users.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix a long-standing bug where Synapse would return errors after 2<sup>31</sup> events were handled by the server.
|
|
|
@ -1 +0,0 @@
|
||||||
Reenable a SyTest after it has been fixed.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix link pointing at the wrong section in the modules documentation page.
|
|
|
@ -1 +0,0 @@
|
||||||
Ensure that inbound events from federation that were being processed when Synapse was restarted get promptly processed on start up.
|
|
|
@ -1 +0,0 @@
|
||||||
Fix a long-standing bug where Synapse would return errors after 2<sup>31</sup> events were handled by the server.
|
|
|
@ -1 +0,0 @@
|
||||||
Implement refresh tokens as specified by [MSC2918](https://github.com/matrix-org/matrix-doc/pull/2918).
|
|
|
@ -47,7 +47,7 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
__version__ = "1.37.1"
|
__version__ = "1.38.0rc1"
|
||||||
|
|
||||||
if bool(os.environ.get("SYNAPSE_TEST_PATCH_LOG_CONTEXTS", False)):
|
if bool(os.environ.get("SYNAPSE_TEST_PATCH_LOG_CONTEXTS", False)):
|
||||||
# We import here so that we don't have to install a bunch of deps when
|
# We import here so that we don't have to install a bunch of deps when
|
||||||
|
|
|
@ -1146,6 +1146,16 @@ class EventsBackgroundUpdatesStore(SQLBaseStore):
|
||||||
logger.info("completing stream_ordering migration: %s", sql)
|
logger.info("completing stream_ordering migration: %s", sql)
|
||||||
txn.execute(sql)
|
txn.execute(sql)
|
||||||
|
|
||||||
|
# ANALYZE the new column to build stats on it, to encourage PostgreSQL to use the
|
||||||
|
# indexes on it.
|
||||||
|
# We need to pass execute a dummy function to handle the txn's result otherwise
|
||||||
|
# it tries to call fetchall() on it and fails because there's no result to fetch.
|
||||||
|
await self.db_pool.execute(
|
||||||
|
"background_analyze_new_stream_ordering_column",
|
||||||
|
lambda txn: None,
|
||||||
|
"ANALYZE events(stream_ordering2)",
|
||||||
|
)
|
||||||
|
|
||||||
await self.db_pool.runInteraction(
|
await self.db_pool.runInteraction(
|
||||||
"_background_replace_stream_ordering_column", process
|
"_background_replace_stream_ordering_column", process
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue