2021-06-03 12:20:40 -04:00
|
|
|
# Introduction
|
|
|
|
|
2023-12-13 10:41:11 -05:00
|
|
|
Welcome to the documentation repository for Synapse, a
|
2023-11-20 14:22:46 -05:00
|
|
|
[Matrix](https://matrix.org) homeserver implementation developed by Element.
|
2021-10-06 13:09:35 -04:00
|
|
|
|
|
|
|
## Installing and using Synapse
|
|
|
|
|
|
|
|
This documentation covers topics for **installation**, **configuration** and
|
2022-05-18 07:29:32 -04:00
|
|
|
**maintenance** of your Synapse process:
|
2021-10-06 13:09:35 -04:00
|
|
|
|
|
|
|
* Learn how to [install](setup/installation.md) and
|
2022-05-18 07:29:32 -04:00
|
|
|
[configure](usage/configuration/config_documentation.md) your own instance, perhaps with [Single
|
2021-10-06 13:09:35 -04:00
|
|
|
Sign-On](usage/configuration/user_authentication/index.html).
|
|
|
|
|
|
|
|
* See how to [upgrade](upgrade.md) between Synapse versions.
|
|
|
|
|
|
|
|
* Administer your instance using the [Admin
|
|
|
|
API](usage/administration/admin_api/index.html), installing [pluggable
|
|
|
|
modules](modules/index.html), or by accessing the [manhole](manhole.md).
|
|
|
|
|
|
|
|
* Learn how to [read log lines](usage/administration/request_log.md), configure
|
|
|
|
[logging](usage/configuration/logging_sample_config.md) or set up [structured
|
|
|
|
logging](structured_logging.md).
|
|
|
|
|
|
|
|
* Scale Synapse through additional [worker processes](workers.md).
|
|
|
|
|
|
|
|
* Set up [monitoring and metrics](metrics-howto.md) to keep an eye on your
|
|
|
|
Synapse instance's performance.
|
|
|
|
|
|
|
|
## Developing on Synapse
|
|
|
|
|
|
|
|
Contributions are welcome! Synapse is primarily written in
|
|
|
|
[Python](https://python.org). As a developer, you may be interested in the
|
|
|
|
following documentation:
|
|
|
|
|
|
|
|
* Read the [Contributing Guide](development/contributing_guide.md). It is meant
|
|
|
|
to walk new contributors through the process of developing and submitting a
|
|
|
|
change to the Synapse codebase (which is [hosted on
|
2023-12-13 11:37:10 -05:00
|
|
|
GitHub](https://github.com/element-hq/synapse)).
|
2021-10-06 13:09:35 -04:00
|
|
|
|
|
|
|
* Set up your [development
|
|
|
|
environment](development/contributing_guide.md#2-what-do-i-need), then learn
|
|
|
|
how to [lint](development/contributing_guide.md#run-the-linters) and
|
|
|
|
[test](development/contributing_guide.md#8-test-test-test) your code.
|
|
|
|
|
2023-12-13 11:37:10 -05:00
|
|
|
* Look at [the issue tracker](https://github.com/element-hq/synapse/issues) for
|
2021-10-06 13:09:35 -04:00
|
|
|
bugs to fix or features to add. If you're new, it may be best to start with
|
|
|
|
those labeled [good first
|
2023-12-13 11:37:10 -05:00
|
|
|
issue](https://github.com/element-hq/synapse/issues?q=is%3Aissue+is%3Aopen+label%3A%22good+first+issue%22).
|
2021-10-06 13:09:35 -04:00
|
|
|
|
|
|
|
* Understand [how Synapse is
|
|
|
|
built](development/internal_documentation/index.html), how to [migrate
|
|
|
|
database schemas](development/database_schema.md), learn about
|
|
|
|
[federation](federate.md) and how to [set up a local
|
|
|
|
federation](federate.md#running-a-demo-federation-of-synapses) for development.
|
|
|
|
|
|
|
|
* We like to keep our `git` history clean. [Learn](development/git.md) how to
|
|
|
|
do so!
|
|
|
|
|
|
|
|
* And finally, contribute to this documentation! The source for which is
|
2023-12-13 11:37:10 -05:00
|
|
|
[located here](https://github.com/element-hq/synapse/tree/develop/docs).
|
2021-10-06 13:09:35 -04:00
|
|
|
|
|
|
|
## Reporting a security vulnerability
|
|
|
|
|
2024-06-25 10:58:30 -04:00
|
|
|
If you've found a security issue in Synapse or any other Element project,
|
|
|
|
please report it to us in accordance with our [Security Disclosure
|
|
|
|
Policy](https://element.io/security/security-disclosure-policy). Thank you!
|