pyproject.toml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349
  1. [tool.towncrier]
  2. package = "synapse"
  3. filename = "CHANGES.md"
  4. directory = "changelog.d"
  5. issue_format = "[\\#{issue}](https://github.com/matrix-org/synapse/issues/{issue})"
  6. [[tool.towncrier.type]]
  7. directory = "feature"
  8. name = "Features"
  9. showcontent = true
  10. [[tool.towncrier.type]]
  11. directory = "bugfix"
  12. name = "Bugfixes"
  13. showcontent = true
  14. [[tool.towncrier.type]]
  15. directory = "docker"
  16. name = "Updates to the Docker image"
  17. showcontent = true
  18. [[tool.towncrier.type]]
  19. directory = "doc"
  20. name = "Improved Documentation"
  21. showcontent = true
  22. [[tool.towncrier.type]]
  23. directory = "removal"
  24. name = "Deprecations and Removals"
  25. showcontent = true
  26. [[tool.towncrier.type]]
  27. directory = "misc"
  28. name = "Internal Changes"
  29. showcontent = true
  30. [tool.black]
  31. target-version = ['py37', 'py38', 'py39', 'py310']
  32. # black ignores everything in .gitignore by default, see
  33. # https://black.readthedocs.io/en/stable/usage_and_configuration/file_collection_and_discovery.html#gitignore
  34. # Use `extend-exclude` if you want to exclude something in addition to this.
  35. [tool.isort]
  36. line_length = 88
  37. sections = ["FUTURE", "STDLIB", "THIRDPARTY", "TWISTED", "FIRSTPARTY", "TESTS", "LOCALFOLDER"]
  38. default_section = "THIRDPARTY"
  39. known_first_party = ["synapse"]
  40. known_tests = ["tests"]
  41. known_twisted = ["twisted", "OpenSSL"]
  42. multi_line_output = 3
  43. include_trailing_comma = true
  44. combine_as_imports = true
  45. skip_gitignore = true
  46. [tool.maturin]
  47. manifest-path = "rust/Cargo.toml"
  48. [tool.poetry]
  49. name = "matrix-synapse"
  50. version = "1.74.0"
  51. description = "Homeserver for the Matrix decentralised comms protocol"
  52. authors = ["Matrix.org Team and Contributors <packages@matrix.org>"]
  53. license = "Apache-2.0"
  54. readme = "README.rst"
  55. repository = "https://github.com/matrix-org/synapse"
  56. packages = [
  57. { include = "synapse" },
  58. ]
  59. classifiers = [
  60. "Development Status :: 5 - Production/Stable",
  61. "Topic :: Communications :: Chat",
  62. ]
  63. include = [
  64. { path = "AUTHORS.rst", format = "sdist" },
  65. { path = "book.toml", format = "sdist" },
  66. { path = "changelog.d", format = "sdist" },
  67. { path = "CHANGES.md", format = "sdist" },
  68. { path = "CONTRIBUTING.md", format = "sdist" },
  69. { path = "demo", format = "sdist" },
  70. { path = "docs", format = "sdist" },
  71. { path = "INSTALL.md", format = "sdist" },
  72. { path = "mypy.ini", format = "sdist" },
  73. { path = "scripts-dev", format = "sdist" },
  74. { path = "synmark", format="sdist" },
  75. { path = "sytest-blacklist", format = "sdist" },
  76. { path = "tests", format = "sdist" },
  77. { path = "UPGRADE.rst", format = "sdist" },
  78. { path = "Cargo.toml", format = "sdist" },
  79. { path = "Cargo.lock", format = "sdist" },
  80. { path = "rust/Cargo.toml", format = "sdist" },
  81. { path = "rust/build.rs", format = "sdist" },
  82. { path = "rust/src/**", format = "sdist" },
  83. ]
  84. exclude = [
  85. { path = "synapse/*.so", format = "sdist"}
  86. ]
  87. build = "build_rust.py"
  88. [tool.poetry.scripts]
  89. synapse_homeserver = "synapse.app.homeserver:main"
  90. synapse_worker = "synapse.app.generic_worker:main"
  91. synctl = "synapse._scripts.synctl:main"
  92. export_signing_key = "synapse._scripts.export_signing_key:main"
  93. generate_config = "synapse._scripts.generate_config:main"
  94. generate_log_config = "synapse._scripts.generate_log_config:main"
  95. generate_signing_key = "synapse._scripts.generate_signing_key:main"
  96. hash_password = "synapse._scripts.hash_password:main"
  97. register_new_matrix_user = "synapse._scripts.register_new_matrix_user:main"
  98. synapse_port_db = "synapse._scripts.synapse_port_db:main"
  99. synapse_review_recent_signups = "synapse._scripts.review_recent_signups:main"
  100. update_synapse_database = "synapse._scripts.update_synapse_database:main"
  101. [tool.poetry.dependencies]
  102. python = "^3.7.1"
  103. # Mandatory Dependencies
  104. # ----------------------
  105. # we use the TYPE_CHECKER.redefine method added in jsonschema 3.0.0
  106. jsonschema = ">=3.0.0"
  107. # frozendict 2.1.2 is broken on Debian 10: https://github.com/Marco-Sulla/python-frozendict/issues/41
  108. frozendict = ">=1,!=2.1.2"
  109. # We require 2.1.0 or higher for type hints. Previous guard was >= 1.1.0
  110. unpaddedbase64 = ">=2.1.0"
  111. # We require 1.5.0 to work around an issue when running against the C implementation of
  112. # frozendict: https://github.com/matrix-org/python-canonicaljson/issues/36
  113. canonicaljson = "^1.5.0"
  114. # we use the type definitions added in signedjson 1.1.
  115. signedjson = "^1.1.0"
  116. # validating SSL certs for IP addresses requires service_identity 18.1.
  117. service-identity = ">=18.1.0"
  118. # Twisted 18.9 introduces some logger improvements that the structured
  119. # logger utilises
  120. Twisted = {extras = ["tls"], version = ">=18.9.0"}
  121. treq = ">=15.1"
  122. # Twisted has required pyopenssl 16.0 since about Twisted 16.6.
  123. pyOpenSSL = ">=16.0.0"
  124. PyYAML = ">=3.11"
  125. pyasn1 = ">=0.1.9"
  126. pyasn1-modules = ">=0.0.7"
  127. bcrypt = ">=3.1.7"
  128. Pillow = ">=5.4.0"
  129. # We use SortedDict.peekitem(), which was added in sortedcontainers 1.5.2.
  130. sortedcontainers = ">=1.5.2"
  131. pymacaroons = ">=0.13.0"
  132. msgpack = ">=0.5.2"
  133. phonenumbers = ">=8.2.0"
  134. # we use GaugeHistogramMetric, which was added in prom-client 0.4.0.
  135. prometheus-client = ">=0.4.0"
  136. # we use `order`, which arrived in attrs 19.2.0.
  137. # Note: 21.1.0 broke `/sync`, see #9936
  138. attrs = ">=19.2.0,!=21.1.0"
  139. netaddr = ">=0.7.18"
  140. # Jinja 2.x is incompatible with MarkupSafe>=2.1. To ensure that admins do not
  141. # end up with a broken installation, with recent MarkupSafe but old Jinja, we
  142. # add a lower bound to the Jinja2 dependency.
  143. Jinja2 = ">=3.0"
  144. bleach = ">=1.4.3"
  145. # We use `ParamSpec` and `Concatenate`, which were added in `typing-extensions` 3.10.0.0.
  146. # Additionally we need https://github.com/python/typing/pull/817 to allow types to be
  147. # generic over ParamSpecs.
  148. typing-extensions = ">=3.10.0.1"
  149. # We enforce that we have a `cryptography` version that bundles an `openssl`
  150. # with the latest security patches.
  151. cryptography = ">=3.4.7"
  152. # ijson 3.1.4 fixes a bug with "." in property names
  153. ijson = ">=3.1.4"
  154. matrix-common = "^1.3.0"
  155. # We need packaging.requirements.Requirement, added in 16.1.
  156. packaging = ">=16.1"
  157. # At the time of writing, we only use functions from the version `importlib.metadata`
  158. # which shipped in Python 3.8. This corresponds to version 1.4 of the backport.
  159. importlib_metadata = { version = ">=1.4", python = "<3.8" }
  160. # This is the most recent version of Pydantic with available on common distros.
  161. pydantic = ">=1.7.4"
  162. # This is for building the rust components during "poetry install", which
  163. # currently ignores the `build-system.requires` directive (c.f.
  164. # https://github.com/python-poetry/poetry/issues/6154). Both `pip install` and
  165. # `poetry build` do the right thing without this explicit dependency.
  166. #
  167. # This isn't really a dev-dependency, as `poetry install --no-dev` will fail,
  168. # but the alternative is to add it to the main list of deps where it isn't
  169. # needed.
  170. setuptools_rust = ">=1.3"
  171. # Optional Dependencies
  172. # ---------------------
  173. matrix-synapse-ldap3 = { version = ">=0.1", optional = true }
  174. psycopg2 = { version = ">=2.8", markers = "platform_python_implementation != 'PyPy'", optional = true }
  175. psycopg2cffi = { version = ">=2.8", markers = "platform_python_implementation == 'PyPy'", optional = true }
  176. psycopg2cffi-compat = { version = "==1.1", markers = "platform_python_implementation == 'PyPy'", optional = true }
  177. pysaml2 = { version = ">=4.5.0", optional = true }
  178. authlib = { version = ">=0.15.1", optional = true }
  179. # systemd-python is necessary for logging to the systemd journal via
  180. # `systemd.journal.JournalHandler`, as is documented in
  181. # `contrib/systemd/log_config.yaml`.
  182. # Note: systemd-python 231 appears to have been yanked from pypi
  183. systemd-python = { version = ">=231", optional = true }
  184. lxml = { version = ">=4.2.0", optional = true }
  185. sentry-sdk = { version = ">=0.7.2", optional = true }
  186. opentracing = { version = ">=2.2.0", optional = true }
  187. jaeger-client = { version = ">=4.0.0", optional = true }
  188. txredisapi = { version = ">=1.4.7", optional = true }
  189. hiredis = { version = "*", optional = true }
  190. Pympler = { version = "*", optional = true }
  191. parameterized = { version = ">=0.7.4", optional = true }
  192. idna = { version = ">=2.5", optional = true }
  193. pyicu = { version = ">=2.10.2", optional = true }
  194. [tool.poetry.extras]
  195. # NB: Packages that should be part of `pip install matrix-synapse[all]` need to be specified
  196. # twice: once here, and once in the `all` extra.
  197. matrix-synapse-ldap3 = ["matrix-synapse-ldap3"]
  198. postgres = ["psycopg2", "psycopg2cffi", "psycopg2cffi-compat"]
  199. saml2 = ["pysaml2"]
  200. oidc = ["authlib"]
  201. # systemd-python is necessary for logging to the systemd journal via
  202. # `systemd.journal.JournalHandler`, as is documented in
  203. # `contrib/systemd/log_config.yaml`.
  204. systemd = ["systemd-python"]
  205. url-preview = ["lxml"]
  206. sentry = ["sentry-sdk"]
  207. opentracing = ["jaeger-client", "opentracing"]
  208. jwt = ["authlib"]
  209. # hiredis is not a *strict* dependency, but it makes things much faster.
  210. # (if it is not installed, we fall back to slow code.)
  211. redis = ["txredisapi", "hiredis"]
  212. # Required to use experimental `caches.track_memory_usage` config option.
  213. cache-memory = ["pympler"]
  214. test = ["parameterized", "idna"]
  215. # Allows for better search for international characters in the user directory. This
  216. # requires libicu's development headers installed on the system (e.g. libicu-dev on
  217. # Debian-based distributions).
  218. user-search = ["pyicu"]
  219. # The duplication here is awful. I hate hate hate hate hate it. However, for now I want
  220. # to ensure you can still `pip install matrix-synapse[all]` like today. Two motivations:
  221. # 1) for new installations, I want instructions in existing documentation and tutorials
  222. # out there to still work.
  223. # 2) I don't want to hard-code a list of extras into CI if I can help it. The ideal
  224. # solution here would be something like https://github.com/python-poetry/poetry/issues/3413
  225. # Poetry 1.2's dependency groups might make this easier. But I'm not trying that out
  226. # until there's a stable release of 1.2.
  227. #
  228. # NB: the strings in this list must be *package* names, not extra names.
  229. # Some of our extra names _are_ package names, which can lead to great confusion.
  230. all = [
  231. # matrix-synapse-ldap3
  232. "matrix-synapse-ldap3",
  233. # postgres
  234. "psycopg2", "psycopg2cffi", "psycopg2cffi-compat",
  235. # saml2
  236. "pysaml2",
  237. # oidc and jwt
  238. "authlib",
  239. # url-preview
  240. "lxml",
  241. # sentry
  242. "sentry-sdk",
  243. # opentracing
  244. "jaeger-client", "opentracing",
  245. # redis
  246. "txredisapi", "hiredis",
  247. # cache-memory
  248. "pympler",
  249. # improved user search
  250. "pyicu",
  251. # omitted:
  252. # - test: it's useful to have this separate from dev deps in the olddeps job
  253. # - systemd: this is a system-based requirement
  254. ]
  255. [tool.poetry.dev-dependencies]
  256. ## We pin black so that our tests don't start failing on new releases.
  257. isort = ">=5.10.1"
  258. black = ">=22.3.0"
  259. flake8-comprehensions = "*"
  260. flake8-bugbear = ">=21.3.2"
  261. flake8 = "*"
  262. # Typechecking
  263. mypy = "*"
  264. mypy-zope = "*"
  265. types-bleach = ">=4.1.0"
  266. types-commonmark = ">=0.9.2"
  267. types-jsonschema = ">=3.2.0"
  268. types-opentracing = ">=2.4.2"
  269. types-Pillow = ">=8.3.4"
  270. types-psycopg2 = ">=2.9.9"
  271. types-pyOpenSSL = ">=20.0.7"
  272. types-PyYAML = ">=5.4.10"
  273. types-requests = ">=2.26.0"
  274. types-setuptools = ">=57.4.0"
  275. # Dependencies which are exclusively required by unit test code. This is
  276. # NOT a list of all modules that are necessary to run the unit tests.
  277. # Tests assume that all optional dependencies are installed.
  278. # parameterized<0.7.4 can create classes with names that would normally be invalid
  279. # identifiers. trial really does not like this when running with multiple workers.
  280. parameterized = ">=0.7.4"
  281. idna = ">=2.5"
  282. # The following are used by the release script
  283. click = ">=8.1.3"
  284. # GitPython was == 3.1.14; bumped to 3.1.20, the first release with type hints.
  285. GitPython = ">=3.1.20"
  286. commonmark = ">=0.9.1"
  287. pygithub = ">=1.55"
  288. # The following are executed as commands by the release script.
  289. twine = "*"
  290. # Towncrier min version comes from #3425. Rationale unclear.
  291. towncrier = ">=18.6.0rc1"
  292. [build-system]
  293. # The upper bounds here are defensive, intended to prevent situations like
  294. # #13849 and #14079 where we see buildtime or runtime errors caused by build
  295. # system changes.
  296. # We are happy to raise these upper bounds upon request,
  297. # provided we check that it's safe to do so (i.e. that CI passes).
  298. requires = ["poetry-core>=1.0.0,<=1.3.2", "setuptools_rust>=1.3,<=1.5.2"]
  299. build-backend = "poetry.core.masonry.api"
  300. [tool.cibuildwheel]
  301. # Skip unsupported platforms (by us or by Rust).
  302. skip = "cp36* *-musllinux_i686 pp*aarch64 *-musllinux_aarch64"
  303. # We need a rust compiler
  304. before-all = "curl https://sh.rustup.rs -sSf | sh -s -- --default-toolchain stable -y --profile minimal"
  305. environment= { PATH = "$PATH:$HOME/.cargo/bin" }
  306. # For some reason if we don't manually clean the build directory we
  307. # can end up polluting the next build with a .so that is for the wrong
  308. # Python version.
  309. before-build = "rm -rf {project}/build"
  310. build-frontend = "build"
  311. test-command = "python -c 'from synapse.synapse_rust import sum_as_string; print(sum_as_string(1, 2))'"
  312. [tool.cibuildwheel.linux]
  313. # Wrap the repair command to correctly rename the built cpython wheels as ABI3.
  314. repair-wheel-command = "./.ci/scripts/auditwheel_wrapper.py -w {dest_dir} {wheel}"
  315. [tool.cibuildwheel.macos]
  316. # Wrap the repair command to correctly rename the built cpython wheels as ABI3.
  317. repair-wheel-command = "./.ci/scripts/auditwheel_wrapper.py --require-archs {delocate_archs} -w {dest_dir} {wheel}"