Commit graph

2888 commits

Author SHA1 Message Date
Till 7ec70272d2
Disable NATS Server logging, allow self-signed certificates (#2605)
* Disable NATS Server logs in CI

* Add option to disable TLS validation for NATS
2022-08-02 13:58:08 +02:00
Neil Alexander ca3fa58388
Various roominfo tweaks (#2607) 2022-08-02 12:27:15 +01:00
PiotrKozimor ac556d93d4
Fix presence (#16)
* Send expired presence to clients correctly

* Adjust logging for datadog integration

* Fix tests
2022-08-02 11:54:02 +02:00
Neil Alexander eab87ef07d
Stronger checks for /send_join (#2604) 2022-08-02 10:22:17 +01:00
sergekh2 6b6b420b9f
Fix issue with sync API not advancing. (#2603)
Issue: During conversation, under some conditions, sync cookie is not advanced, and, as a result, client loops on the same sync API call creating high traffic and CPU load.
Fix: pdu component of cookie was updated incorrectly.
2022-08-02 09:43:48 +01:00
Neil Alexander 3d51624fef
Version 0.9.0 (#2602) 2022-08-01 17:34:29 +01:00
Neil Alexander e94ef84aab
De-race CompleteSync (#2601)
The `err` was coming from outside of the goroutine and being written to by concurrent goroutines.
2022-08-01 15:55:56 +01:00
Neil Alexander 119cde3766
De-race types.RoomInfo (#2600) 2022-08-01 15:29:19 +01:00
Neil Alexander 05c83923e3
Optimise checking other servers allowed to see events (#2596)
* Try optimising checking if server is allowed to see event

* Fix error

* Handle case where snapshot NID is 0

* Fix query

* Update SQL

* Clean up `CheckServerAllowedToSeeEvent`

* Not supported on SQLite

* Maybe placate the unit tests

* Review comments
2022-08-01 14:11:00 +01:00
Neil Alexander c7f7aec4d0
Set CORS headers for HTTP 404 and 405 errors (#2599)
* Set CORS headers for the 404s

* Use custom handlers, plus one for HTTP 405 too

* Tweak setup

* Add to muxes too

* Tidy up some more

* Use built-in HTTP 404 handler

* Don't bother setting it for federation-facing
2022-08-01 11:34:27 +01:00
Neil Alexander 645f31ae24
Update NATS Server and nats.go to use upstream 2022-08-01 09:51:13 +01:00
PiotrKozimor b25fa5d683
Expire presence after 5 minutes (#15) 2022-07-26 10:01:01 +02:00
Neil Alexander 962b76da44
Make the User API responsible for sending account data output events (#2592)
* Make the User API responsible for sending account data output events

* Clean up producer

* Review comments
2022-07-25 17:30:07 +01:00
Neil Alexander 497ab4e1b7
Remove goose from Dockerfiles 2022-07-25 14:46:35 +01:00
Neil Alexander ccea23cd40
Remove room_id field from MSC2946 stripped events (closes #2588) 2022-07-25 11:42:22 +01:00
Jonathan Bartlett b836243a24
Add .well-known/matrix/client to clientapi (#2551)
Signed-off-by: Jonathan Bartlett <jonathan@jonnobrow.co.uk>

Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
2022-07-25 10:39:57 +01:00
Till 081f5e7226
Update database migrations, remove goose (#2264)
* Add new db migration

* Update migrations
Remove goose

* Add possibility to test direct upgrades

* Try to fix WASM test

* Add checks for specific migrations

* Remove AddMigration
Use WithTransaction
Add Dendrite version to table

* Fix linter issues

* Update tests

* Update comments, outdent if

* Namespace migrations

* Add direct upgrade tests, skipping over one version

* Split migrations

* Update go version in CI

* Fix copy&paste mistake

* Use contexts in migrations

Co-authored-by: kegsay <kegan@matrix.org>
Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
2022-07-25 10:39:22 +01:00
Neil Alexander c7d978274d
Try to fix HTTP 500s on /members (#2581) 2022-07-22 19:43:48 +01:00
Neil Alexander f0c8a03649
Membership updater refactoring (#2541)
* Membership updater refactoring

* Pass in membership state

* Use membership check rather than referring to state directly

* Delete irrelevant membership states

* We don't need the leave event after all

* Tweaks

* Put a log entry in that I might stand a chance of finding

* Be less panicky

* Tweak invite handling

* Don't freak if we can't find the event NID

* Use event NID from `types.Event`

* Clean up

* Better invite handling

* Placate the almighty linter

* Blacklist a Sytest which is otherwise fine under Complement for reasons I don't understand

* Fix the sytest after all (thanks @S7evinK for the spot)
2022-07-22 14:44:04 +01:00
dependabot[bot] a201b4400d
Bump tzinfo from 1.2.9 to 1.2.10 in /docs (#2584)
Bumps [tzinfo](https://github.com/tzinfo/tzinfo) from 1.2.9 to 1.2.10.
- [Release notes](https://github.com/tzinfo/tzinfo/releases)
- [Changelog](https://github.com/tzinfo/tzinfo/blob/master/CHANGES.md)
- [Commits](https://github.com/tzinfo/tzinfo/compare/v1.2.9...v1.2.10)

---
updated-dependencies:
- dependency-name: tzinfo
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2022-07-22 10:36:10 +01:00
Matt Holt 35ce551c8f
docs: Add build page; correct proxy info; fix Caddy example (#2579)
* Add build page; correct proxy info; fix Caddy example

* Improve Caddyfile example

* Apply review comments; add polylith Caddyfile
2022-07-21 07:08:17 +02:00
Till 9507966ebd
Fix issue with membership event_nid being 0 (#2580) 2022-07-20 12:39:06 +02:00
Tulir Asokan 84a7797883
Explain how SRV works in Matrix and discourage using it (#2577)
* Explain how SRV works in Matrix and discourage using it

* Minor tweaks to formatting

Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
2022-07-19 15:19:03 +01:00
Neil Alexander 5c01306bb5
Add event state key cache (#2576) 2022-07-19 12:15:48 +01:00
Neil Alexander 583b8ea273
Update FAQ 2022-07-19 11:51:46 +01:00
Piotr Kozimor c5cfee4eb5 Log malformed sync token 2022-07-19 11:03:22 +02:00
Piotr Kozimor 1883126657 Allow to clear avatar url 2022-07-19 10:30:58 +02:00
Till Faelligen bcff14adea Set historyVisibility in rowsToStreamEvents 2022-07-18 18:19:44 +02:00
Neil Alexander 99b696e775
Tweak cache counters (#2575)
* Tweak cache counters

This makes the number of counters relative to the
maximum cache size. Since the counters
effectively manage the size of the bloom filter,
larger caches need more counters and smaller
caches need less.

10 counters per 1KB data means that the default
cache size of 1GB should result in a bloom filter
and TinyLRU admission set of about 16MB
estimated.

* Remove line left by accident
2022-07-18 14:49:41 +01:00
Till a7e92f8cb9
History visibility database changes (#2533)
* Add new history_visibility column

* Update SQL queries to include history_visibility

* Store the history visibilty calculated by the roomserver

* Update GMSL

* Update migrations

* Fix migration

* Update GMSL

* Fix `go.sum`

* Update GMSL to use sql.Scanner & sql.Valuer

* Re-order migration/table creation

* Update gomatrixserverlib

* Add history_visibility column to current_room_state

* Fix migrations

* Return error instead of Fatal log

Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
2022-07-18 14:46:15 +02:00
PiotrKozimor 8f9c0901a5
Feature - unread count (#14)
* Pass unread count even when pusher format is event_id_only

* Count distinct roomID in select contifications count

* Fix notifications tests
2022-07-18 09:24:56 +02:00
Maximilian Gaedig c0c909d306
Fix connection_string format in dendrite-sample.polylith.yaml (#2574) 2022-07-17 23:01:52 +01:00
andreever 4ff57993ab
Update 1_createusers.md (#2571)
* Update 1_createusers.md

Added description on how to create user accounts when running in docker.

* Update 1_createusers.md

Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
2022-07-15 16:33:05 +01:00
Neil Alexander 90bf01d8b1
Use sync API database in filterSharedUsers (#2572)
* Add function to the sync API storage package for filtering shared users

* Use the database instead of asking the RS API

* Fix unit tests

* Fix map handling in `filterSharedUsers`
2022-07-15 16:25:26 +01:00
Neil Alexander 69c86295f7
Update sytest-whitelist 2022-07-14 13:51:00 +01:00
Neil Alexander 950659320e
Add a Troubleshooting page 2022-07-14 10:09:26 +01:00
Neil Alexander a1f9b02edf
Pointerise types.RoomInfo in the cache so we can update it in-place in the latest events updater 2022-07-13 10:13:34 +01:00
Neil Alexander 9cd8e9d4b9
Use /v3 to request media from remote servers (update to matrix-org/gomatrixserverlib#324) 2022-07-13 09:32:03 +01:00
Till 09f0ff14c8
Minor SendToDevice fix (#2565)
* Avoid unnecessary marshalling if sending to the local server

* Fix ordering of ToDevice messages

* Revive SendToDevice test
2022-07-12 08:23:58 +02:00
Neil Alexander 3ea21273bc
Ristretto cache (#2563)
* Try Ristretto cache

* Tweak

* It's beautiful

* Update GMSL

* More strict keyable interface

* Fix that some more

* Make less panicky

* Don't enforce mutability checks for now

* Determine mutability using deep equality

* Tweaks

* Namespace keys

* Make federation caches mutable

* Update cost estimation, add metric

* Update GMSL

* Estimate cost for metrics better

* Reduce counters a bit

* Try caching events

* Some guards

* Try again

* Try this

* Use separate caches for hopefully better hash distribution

* Fix bug with admitting events into cache

* Try to fix bugs

* Check nil

* Try that again

* Preserve order jeezo this is messy

* thanks VS Code for doing exactly the wrong thing

* Try this again

* Be more specific

* aaaaargh

* One more time

* That might be better

* Stronger sorting

* Cache expiries, async publishing of EDUs

* Put it back

* Use a shared cache again

* Cost estimation fixes

* Update ristretto

* Reduce counters a bit

* Clean up a bit

* Update GMSL

* 1GB

* Configurable cache sizees

* Tweaks

* Add `config.DataUnit` for specifying friendly cache sizes

* Various tweaks

* Update GMSL

* Add back some lazy loading caching

* Include key in cost

* Include key in cost

* Tweak max age handling, config key name

* Only register prometheus metrics if requested

* Review comments @S7evinK

* Don't return errors when creating caches (it is better just to crash since otherwise we'll `nil`-pointer exception everywhere)

* Review comments

* Update sample configs

* Update GHA Workflow

* Update Complement images to Go 1.18

* Remove the cache test from the federation API as we no longer guarantee immediate cache admission

* Don't check the caches in the renewal test

* Possibly fix the upgrade tests

* Update to matrix-org/gomatrixserverlib#322

* Update documentation to refer to Go 1.18
2022-07-11 14:31:31 +01:00
Neil Alexander eb8dc50a97
Update Pinecone to matrix-org/pinecone@1ce778f 2022-07-08 14:54:08 +01:00
Till f76f28e6db
Fix issue uint64 values with high bit are not supported in presence (#2562)
* Fix issue #2528

* Use gomatrixserverlib.Timestamp

* Use ParseUint instead of ParseInt
2022-07-07 16:29:25 +02:00
Till f3e8a9a4cb
Fix nil pointer access when redacting events (#2560) 2022-07-07 11:40:53 +02:00
Neil Alexander 460dccf93d
Hopefully fix read receipts timestamps (#2557)
This should avoid coercions between signed and unsigned ints which might fix problems like `sql: converting argument $5 type: uint64 values with high bit set are not supported`.
2022-07-05 17:13:26 +01:00
Neil Alexander c0f824d437
Wrap error from SnapshotNIDFromEventID 2022-07-05 15:06:10 +01:00
Neil Alexander d4341a2d97
Return clearer error when no state NID exists for an event (#2555) 2022-07-05 15:01:34 +01:00
Till 5087b36af0
Fix QuerySharedUsers for the SyncAPI keychange consumer (#2554)
* Make more use of base.BaseDendrite

* Fix QuerySharedUsers if no UserIDs are supplied
2022-07-05 14:50:56 +02:00
Till f29cdb26f6
Use new testrig for key changes tests (#2552)
* Use new testrig for tests

* Log the error message
2022-07-05 14:50:24 +02:00
Kabir Kwatra 43147bd654
feat+fix: Ignore unknown keys and verify required fields are present in appservice registration files (#2550)
* fix: ignore unknown keys in appservice configs

fixes matrix-org/dendrite#1567

* feat: verify required fields in appservice configs
2022-07-05 12:53:51 +01:00
PiotrKozimor 1214c6137a
CD with GCP cloud builds (#12)
* Setup CD on GCP

* Squashed commit of the following:

commit 7823481a0e
Author: PiotrKozimor <37144818+PiotrKozimor@users.noreply.github.com>
Date:   Mon Jul 4 17:39:22 2022 +0200

    Merge v0.8.9 (#13)

    Squashed commit of the following:

    commit b5c55faf98
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jul 1 12:00:32 2022 +0100

        Version 0.8.9 (#2549)

        * Version 0.8.9

        * Update changelog

    commit b50a24c666
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jul 1 10:54:07 2022 +0100

        Roomserver producers package (#2546)

        * Give the roomserver a producers package

        * Change init point

        * Populate ACLs API

        * Fix build issues

        * `RoomEventProducer` naming

    commit 89cd0e8fc1
    Author: Till <2353100+S7evinK@users.noreply.github.com>
    Date:   Fri Jul 1 11:49:26 2022 +0200

        Try to fix backfilling (#2548)

        * Try to fix backfilling

        * Return start/end to not confuse clients

        * Update GMSL

        * Update GMSL

    commit 086f182e24
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jul 1 09:50:06 2022 +0100

        Disable WebAssembly builds for now

    commit 54bed4c593
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jul 1 09:37:54 2022 +0100

        Blacklist `Guest users can join guest_access rooms` test until it can be investigated

    commit 561c159ad7
    Author: Till <2353100+S7evinK@users.noreply.github.com>
    Date:   Thu Jun 30 12:34:37 2022 +0200

        Silence presence logs (#2547)

    commit 519bc1124b
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Wed Jun 29 15:29:39 2022 +0100

        Add `evacuateUser` endpoint, use it when deactivating accounts (#2545)

        * Add `evacuateUser` endpoint, use it when deactivating accounts

        * Populate the API

        * Clean up user devices when deactivating

        * Include invites, delete pushers

    commit 2dea466685
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Wed Jun 29 12:32:24 2022 +0100

        Return an error if trying to invite a malformed user ID (#2543)

    commit 2086992caf
    Author: Till <2353100+S7evinK@users.noreply.github.com>
    Date:   Wed Jun 29 10:49:12 2022 +0200

        Don't return `end` if there are not more messages (#2542)

        * Be more spec compliant

        * Move lazyLoadMembers to own method

    commit 920a20821b
    Author: Jean Lucas <jean@4ray.co>
    Date:   Mon Jun 27 04:15:19 2022 -0400

        Fix nats.go commit (#2540)

        Signed-off-by: Jean Lucas <jean@4ray.co>

    commit 7120eb6bc9
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Wed Jun 15 14:27:07 2022 +0100

        Add `InputDeviceListUpdate` to the keyserver, remove old input API (#2536)

        * Add `InputDeviceListUpdate` to the keyserver, remove old input API

        * Fix copyright

        * Log more information when a device list update fails

    commit 1b90cc9536
    Author: Till <2353100+S7evinK@users.noreply.github.com>
    Date:   Wed Jun 15 12:50:02 2022 +0200

        Fix rare panic when returning user devices over federation (#2534)

    commit 4c2a10f1a6
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Mon Jun 13 15:11:10 2022 +0100

        Handle state before, send history visibility in output (#2532)

        * Check state before event

        * Tweaks

        * Refactor a bit, include in output events

        * Don't waste time if soft failed either

        * Tweak control flow, comments, use GMSL history visibility type

    commit c500958583
    Author: Emanuele Aliberti <dev@mtka.eu>
    Date:   Mon Jun 13 13:08:46 2022 +0200

        generic CaddyFile in front of Dendrite (monolith) (#2531)

        for Caddy 2.5.x

        Co-authored-by: emanuele.aliberti <emanuele.aliberti@mtka.eu>

    commit e1136f4d3e
    Author: Till Faelligen <davidf@element.io>
    Date:   Mon Jun 13 11:46:59 2022 +0200

        Make the linter happy again

    commit 0a7f7dc716
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Mon Jun 13 10:16:30 2022 +0100

        Add `--difference` to `resolve-state` tool

    commit 89d2adadbd
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jun 10 10:58:04 2022 +0100

        Attempt to raise the file descriptor limit at startup (#2527)

    commit 1030072285
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jun 10 10:18:32 2022 +0100

        Rename the page to "Optimise your installation"

    commit 16ed1633b6
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jun 10 10:15:14 2022 +0100

        Highlighting in docs

    commit e2a64773ce
    Author: Neil Alexander <neilalexander@users.noreply.github.com>
    Date:   Fri Jun 10 10:14:15 2022 +0100

        Add new next steps page to the documentation

    commit 660f7839f5
    Author: Till <2353100+S7evinK@users.noreply.github.com>
    Date:   Thu Jun 9 18:38:07 2022 +0200

        Correctly redact events over federation (#2526)

        * Ensure we check powerlevel/origin before redacting an event

        * Add passing test

        * Use pl.UserLevel

        * Make check more readable, also check for the sender
2022-07-04 18:07:55 +02:00