|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| | Signed-off-by: Dan Callahan <danc@element.io> | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | Part of #9744
Removes all redundant `# -*- coding: utf-8 -*-` lines from files, as python 3 automatically reads source code as utf-8 now.
`Signed-off-by: Jonathan de Jong <jonathan@automatia.nl>` | 
| | 
| 
| 
| | Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
Co-authored-by: Andrew Morgan <1342360+anoadragon453@users.noreply.github.com> | 
| | 
| 
| | Signed-off-by: Dan Callahan <danc@element.io> | 
| | 
| 
| | By providing the additional build tag for `msc2946`. | 
| |\ |  | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | (#9735)
When joining a room with join rules set to 'restricted', check if the
user is a member of the spaces defined in the 'allow' key of the join rules.
This only applies to an experimental room version, as defined in MSC3083. | 
| |/ |  | 
| |\ |  | 
| | | |  | 
| |/  
|   
|   
|   
|   
|   
| | This PR rewrites the original complement.sh script with a number of improvements:
* We can now use a local checkout of Complement (configurable with `COMPLEMENT_DIR`), though the default behaviour still downloads the master branch.
* You can now specify a regex of test names to run, or just run all tests.
* We now use the Synapse test blacklist tag (so all tests will pass). | 
| | 
| 
| | For it's obvious performance benefits. `dmypy` support landed in #9692. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | using /usr/bin/env (#9689)
On NixOS, `bash` isn't under `/bin/bash` but rather in some directory in `$PATH`. Locally, I've been patching those scripts to make them work.
`/usr/bin/env` seems to be the only [portable way](https://unix.stackexchange.com/questions/29608/why-is-it-better-to-use-usr-bin-env-name-instead-of-path-to-name-as-my) to use binaries from the PATH as interpreters.
Signed-off-by: Quentin Gliech <quentingliech@gmail.com> | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | I noticed that I'd occasionally have `scripts-dev/lint.sh` fail when messing about with config options in my PR. The script calls `scripts-dev/config-lint.sh`, which attempts some validation on the sample config.
 It does this by using `sed` to edit the sample_config, and then seeing if the file changed using `git diff`.
The problem is: if you changed the sample_config as part of your commit, this script will error regardless.
This PR attempts to change the check so that existing, unstaged changes to the sample_config will not cause the script to report an invalid file. | 
| | 
| 
| 
| 
| 
| 
| | - Update black version to the latest
 - Run black auto formatting over the codebase
    - Run autoformatting according to [`docs/code_style.md
`](https://github.com/matrix-org/synapse/blob/80d6dc9783aa80886a133756028984dbf8920168/docs/code_style.md)
 - Update `code_style.md` docs around installing black to use the correct version | 
| | 
| 
| 
| 
| 
| 
| | (#9003)
Remove conflicting sqlite tables that throw sqlite3.OperationalError: object name reserved for internal use: event_search_content when running the twisted unit tests.
Fix #8996 | 
| | 
| 
| 
| 
| | (#9191)
The lists of source directories to lint between `tox.ini` and `lint.sh` became out of sync. This PR tightens them up and adds some comments reminding any future readers to keep the list in sync. | 
| | |  | 
| | |  | 
| | 
| 
| | Cached functions accept an `on_invalidate` function, which we failed to add to the type signature. It's rarely used in the files that we have typed, which is why we haven't noticed it before. | 
| | 
| 
| 
| 
| 
| 
| | This modifies the configuration of structured logging to be usable from
the standard Python logging configuration.
This also separates the formatting of logs from the transport allowing
JSON logs to files or standard logs to sockets. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | git commit (#8472)
This PR makes several changes to the `./scripts-dev/lint.sh` script, which lints the codebase with a number of tools:
* Adds usage information, with `-h` flag to show it. Otherwise it will show when providing an unknown flag.
* Adds option `-d` which will check both staged and unstaged files that have changed since the last commit and add them to the list of files to lint.
  - Note that only files without an extension, or with a `.py` extension will be allowed. This prevents editing bash scripts causing the linters to break on non-python files.
* Improves the print-out of which files/directories are being linted. | 
| |\ |  | 
| | | |  | 
| |/  
|   
| | https://github.com/matrix-org/synapse/tree/develop/docs/sphinx doesn't seem to really be utilised or changed recently since the initial commit. I like the idea of exportable documentation of the codebase, but at the moment after running through the build instructions the generated website wasn't very useful... | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This PR adds a script that:
* Builds the local Synapse checkout using our existing `docker/Dockerfile` image.
* Downloads [Complement](https://github.com/matrix-org/complement/)'s source code.
* Builds the [Synapse.Dockerfile](https://github.com/matrix-org/complement/blob/master/dockerfiles/Synapse.Dockerfile) using the above dockerfile as a base.
* Builds and runs Complement against it.
This set up differs slightly from [that of the dendrite repo](https://github.com/matrix-org/dendrite/blob/master/build/scripts/complement.sh) (`complement.sh`, `Complement.Dockerfile`), which instead stores a separate, but slightly modified, dockerfile in Dendrite's repo rather than running the one stored in Complement's repo. That synapse equivalent to that dockerfile (`Synapse.Dockerfile`) in Complement's repo is just based on top of `matrixdotorg/synapse:latest`, which we opt to build here locally.
Thus copying over the files from Complement's repo wouldn't change any functionality, and would result in two instances of the same files. So just using the dockerfile in Complement's repo was decided upon instead. | 
| | 
| 
| 
| 
| 
| 
| | This converts calls like super(Foo, self) -> super().
Generated with:
    sed -i "" -Ee 's/super\([^\(]+\)/super()/g' **/*.py | 
| | |  | 
| | |  | 
| | 
| 
| | This requires adding a mypy plugin to fiddle with the type signatures a bit. | 
| | 
| 
| 
| | Now that the server supports streaming back JSON responses, it would be nice to
show the response as it is streamed, in the test tool. | 
| | |  | 
| | 
| 
| 
| 
| 
| | This PR:
* Reduces the amount of noise in the `check-newsfragment` CI output by hiding the dependency installation output by default.
* Prints a link to the changelog/debian changelog section of the contributing guide if an error is found. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | If there are *no* files with CRLF line endings, then the xargs exits with a
non-zero exit code (as expected), but then, since that is the last thing to
happen in the script, the script as a whole exits non-zero, making the whole
thing fail.
using `if/then/fi` instead of `&& (...)` means that the script exits with a
zero exit code. | 
| | 
| 
| 
| 
| | This PRs adds a script to check for unix-line terminators in the repo. It will be used to address https://github.com/matrix-org/synapse/issues/7943 by adding the check to CI.
I've changed the original script slightly as proposed in https://github.com/matrix-org/pipelines/pull/81#discussion_r460580664 | 
| | 
| 
| 
| 
| 
| 
| | script (#7914)
Run `isort`, `flake8` and `black` over the `contrib/` directory and `synctl` script. The latter was already being done in CI, but now the linting script does it too.
Fixes https://github.com/matrix-org/synapse/issues/7910 | 
| | |  | 
| | 
| 
| | The CI appears to use the latest version of isort, which is a problem when isort gets a major version bump. Rather than try to pin the version, I've done the necessary to make isort5 happy with synapse. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| |\ |  | 
| | | |  | 
| |/  
|   
|   
| | this is no longer needed on python 3 | 
| | 
| 
| 
| | Ensure good comprehension hygiene using flake8-comprehensions. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * Raise an exception if there are pending background updates
So we return with a non-0 code
* Changelog
* Port synapse_port_db to async/await
* Port update_database to async/await
* Add version string to mocked homeservers
* Remove unused imports
* Convert overseen bits to async/await
* Fixup logging contexts
* Fix imports
* Add a way to print an error without raising an exception
* Incorporate review | 
| | |  | 
| | 
| 
| 
| 
| | This encapsulates config for a given database and is the way to get new
connections. | 
| |\  
| | 
| | | Move database config from apps into HomeServer object | 
| | | |  | 
| |/ |  | 
| | |  | 
| | |  | 
| |\ |  | 
| | | |  | 
| | | |  | 
| | | |  | 
| |/  
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
| | This adds:
* a test sqlite database
* a configuration file for the sqlite database
* a configuration file for a postgresql database (using the credentials in `.buildkite/docker-compose.pyXX.pgXX.yaml`)
as well as a new script named `.buildkite/scripts/test_synapse_port_db.sh` that:
1. installs Synapse
2. updates the test sqlite database to the latest schema and runs background updates on it
3. creates an empty postgresql database
4. run the `synapse_port_db` script to migrate the test sqlite database to the empty postgresql database (with coverage)
Step `2` is done via a new script located at `scripts-dev/update_database`.
The test sqlite database is extracted from a SyTest run, so that it can be considered as an actual homeserver's database with actual data in it. | 
| | 
| 
| 
| 
| | Add a linting script that enforces all boolean values in the default config be lowercase.
This has annoyed me for a while so I decided to fix it. | 
| | 
| 
| 
| | This doesn't work, and afaict hasn't been used since 2015. | 
| | 
| 
| | Add a dev script to cover all the different linting steps. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| | * py3 fixes for federation_client
* .well-known support for federation_client | 
| | |  | 
| | |  | 
| |\  
| | 
| | | Fix yaml warnings by using safe_load | 
| | | |  | 
| |/ |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | * Fix check-newsfragment script
I previously broke this so that it always succeeded...
* more fixes
* fix newsfiles | 
| | 
| 
| 
| 
| | * You need an entry in the debian changelog (and not a regular newsfragment)
  for debian packaging changes.
* Regular newsfragments must end in full stops. | 
| | |  | 
| | 
| 
| 
| | Rewrite this in python so that it can be run in parallel. | 
| |\  
| | 
| | 
| | 
| | | matrix-org/babolivier/federation-client-content-type
Add a Content-Type header on POST requests to the federation client script | 
| | | |  | 
| |/ |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Broadly three things here:
* disable W504 which seems a bit whacko
* remove a bunch of `as e` expressions from exception handlers that don't use
  them
* use `r""` for strings which include backslashes
Also, we don't use pep8 any more, so we can get rid of the duplicate config
there. | 
| | 
| 
| 
| | on py3) (#4068) | 
| | |  | 
| | 
| 
| 
| | Signed-off-by: Schnuffle  <schnuffle@github.com> | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | * changelog
* reduce circleci config
* plus a handy script
* fix regex | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The problem with this script is that it is largely untested, entirely
unmaintained, and running it is likely to make your synapse blow up in
exciting ways.
For example, it leaves a bunch of tables with dead values in it, like
event_to_state_groups.
Having it here sends a message that it is a supported part of
synapse, which is absolutely not the case. | 
| | 
| 
| 
| 
| 
| | This appears to have stopped working since matrix.org moved to cloudflare. The
Host header should match the name of the server, not whatever is in the SRV
record. | 
| |\  
| | 
| | | nuke-room-from-db.sh: fix deletion from search table | 
| | | |  | 
| | | |  | 
| |/ |  | 
| | |  | 
| | 
| 
| 
| | so that you don't necessarily need a config file. | 
| | 
| 
| 
| | Make it read the config file, primarily. | 
| | 
| 
| 
| | Signed-off-by: Christian W. Zuckschwerdt <christian@zuckschwerdt.org> | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | synapse
This is necessary for replicating the data in synapse to be visible to a
separate service because presence and typing notifications aren't stored
in a database so won't be visible to another process.
This API can be used to either get the raw data by requesting the tables
themselves or to just receive notifications for updates by following the
streams meta-stream.
Returns updates for each table requested a JSON array of arrays with a
row for each row in the table.
Each table is prefixed by a header row with the: name of the table,
current stream_id position for the table, number of rows, number of
columns and the names of the columns.
This is followed by the rows that have been added to the server since
the requester last asked.
The API has a timeout and is hooked up to the notifier so that a slave
can long poll for updates. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| | functions that aren't called at all | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
|  |  |