Commit Graph

1045 Commits (face766e0f32481fd97a435f1ed8579d8cfc634c)

Author SHA1 Message Date
Timo Kösters 0066f20bdd Merge branch 'trailingslash' into 'next'
fix: allow trailing slashes for /state/<type>/ again

See merge request famedly/conduit!336
2 years ago
Timo Kösters a5465dfd3e
fix: allow trailing slashes for /state/<type>/ again 2 years ago
Timo Kösters 8086bee146 Merge branch 'show-config' into 'next'
Add show-config admin command

See merge request famedly/conduit!295
2 years ago
Timo Kösters b11a3b80bc Merge branch 'shutdown-msg' into 'next'
Log caught Ctrl+C or SIGTERM for operator feedback

See merge request famedly/conduit!319
2 years ago
Timo Kösters 554146f46e Merge branch 'notify-admin-room-on-user-register' into 'next'
Notify admin room for user registrations, deactivations and password changes

See merge request famedly/conduit!318
2 years ago
Timo Kösters 7bc84dc971 Merge branch 'jplatte/up-axum' into 'next'
Upgrade axum to 0.5

See merge request famedly/conduit!335
2 years ago
Timo Kösters d89141100c Merge branch 'insensitive-login' into 'next'
Case insensitive username login

Closes #248

See merge request famedly/conduit!323
2 years ago
Jonas Platte db0659cb3d
Upgrade axum to 0.5 2 years ago
LordMZTE 4a12a7cbc8
Fix crash when a bad user ID is in the database
To my understanding, a bad user ID can sometimes make it into the
database, which lead to a panic prior to this change.
2 years ago
Andrej Kacian b5b8181851 Notify admin room for user registrations, deactivations and password changes 2 years ago
chenyuqide 5695121f38 Fix wrong associated type in OutgoingKind::Appservice 2 years ago
reti4 8bafdc4623 fixed location of lowercase fn 2 years ago
reti4 9385ea0e7c fmt fix 2 years ago
reti4 9f059ad4c3 make username login case insensitive 2 years ago
Andrej Kacian 65fa4b2ca4 Fix proxy config examples in config/proxy.rs 2 years ago
Andrej Kacian 3b2b35aab7 Log caught Ctrl+C or SIGTERM for operator feedback 2 years ago
Andrej Kacian 196c83939c Add show-config admin room command 2 years ago
Jonathan de Jong 557d119bee change search_events_v3 to search_events::v3 2 years ago
Jonathan de Jong e9f87e1952 update ruma 2 years ago
Timo Kösters b8eaa3be85 Merge branch 'redactfix' into 'next'
Redaction fix

Closes #235

See merge request famedly/conduit!298
2 years ago
Jonas Platte 27692a2f14
Remove useless serde roundtrips 2 years ago
Timo Kösters 6602f6114c
fix: redacts can't error anymore 2 years ago
Jonas Platte 3aece38e9d
Add a not-found route 2 years ago
Jonas Platte aee6bf7e7a Change this to handler 2 years ago
Jonathan de Jong b8d92d3cec take advantage of multiple paths 2 years ago
Timo Kösters 0c4b42ac13 Merge branch 'parse-pdu-command-panic' into 'next'
fix: do not panic on a JSON not containing the PDU

Closes #236

See merge request famedly/conduit!304
2 years ago
M0dEx d4217007fe
fix: do not panic on a JSON not containing the PDU
Do not panic on a JSON not containing the PDU when executing the parse-pdu admin command.
2 years ago
Jonathan de Jong 35b82d51cf fix compilations 2 years ago
Timo Kösters 2b644ef7b7 Merge branch 'tracing-cleanup' into 'next'
Remove unnecessary tracing::instrument attributes

See merge request famedly/conduit!302
2 years ago
Jonas Platte 0ad6eac4f8
Remove all tracing::instrument attributes from database::abstraction::* 2 years ago
Jonas Platte accdb77315
Clean up tracing::instrument attributes
Remove it from request handler since there's already the context of the
request path, added through TraceLayer.
2 years ago
Timo Kösters 914152fcbd Merge branch 'syncfast' into 'next'
improvement: faster /syncs

Closes #231

See merge request famedly/conduit!297
2 years ago
Timo Kösters 2a00c547a1
improvement: faster /syncs 2 years ago
Jonas Platte adeb8ee425
Remove no-op conversions 2 years ago
Jonas Platte d74074ad53
Remove tracing::instrument attribute from util functions
They don't ever log anything, so the extra context is never used.
2 years ago
Timo Kösters 0565b5a6c8 Merge branch 'show-dns-setup-error' into 'next'
Display actual error message from TokioAsyncResolver, if any

See merge request famedly/conduit!296
2 years ago
Timo Kösters f3502beb94 Merge branch 'welcome-message-command-hint' into 'next'
feat: add welcome message command hint

See merge request famedly/conduit!299
2 years ago
Timo Kösters d6b9874b35 Merge branch 'fix-admin-self-commands' into 'next'
Fix admin room processing commands from its own messages

See merge request famedly/conduit!293
2 years ago
Jonas Platte 50b24b37c2
Upgrade Ruma 2 years ago
Jonas Platte 9db0473ed5
Improve error messages in Ruma wrapper FromRequest impl 2 years ago
Jonas Platte 5d8c80b170
Strip quotes from X-Matrix fields 2 years ago
Jonas Platte 21ae63d46b
Rewrite query parameter parsing 2 years ago
Jonas Platte c8951a1d9c
Use axum-server for direct TLS support 2 years ago
Jonas Platte 5fa9190117
Simplify return type of most route handlers 2 years ago
Jonas Platte 77a87881c9
Add message to unsupported HTTP method panic 2 years ago
Jonas Platte 7bf538f549
Fix axum route conflicts 2 years ago
Jonas Platte a5757ab195
Generalize RumaHandler 2 years ago
Jonas Platte d1d2217019
Clean up error handling for server_server::get_server_keys_route 2 years ago
Jonas Platte 1f7b3fa4ac
Port from Rocket to axum 2 years ago
Jonas Platte 5db4c001d1
Remove another unnecessary use of an event enum 2 years ago
Jonas Platte 583ec51f9f
Remove unnecessary use of event enum 2 years ago
M0dEx f602d32aaa
feat: add the actual server name to the welcome message 2 years ago
M0dEx a6976e6d2d
feat: add 'available' to the help command line in the welcome message 2 years ago
M0dEx f2b8aa28f3
feat: add a line with the help command to the welcome message 2 years ago
Andrej Kacian bfbefb0cd2 Display actual error message from TokioAsyncResolver, if any 2 years ago
Andrei Vasiliu 31918bb990 Fix admin room processing commands from its own messages 2 years ago
Timo Kösters d55992dc83 Merge branch 'jemallocfeature' into 'next'
feat: allow disabling jemalloc via feature

See merge request famedly/conduit!285
2 years ago
Timo Kösters eb0b2c429f
fix: crash on empty search 2 years ago
Timo Kösters 8d8edddb2e
feat: allow disabling jemalloc via feature 2 years ago
Timo Kösters 72cd52e57c
fix: lazy loading for /context 2 years ago
Timo Kösters 8db7d2c025 Merge branch 'asonix/encourage-reqwest-reuse' into 'next'
Re-use a basic reqwest client in all possible cases

See merge request famedly/conduit!265
2 years ago
Andrei Vasiliu e1c0dcb6bb Create admin room and hide migration messages on first run 2 years ago
Jonas Platte d23d6fbb37
Upgrade Ruma 2 years ago
Jonas Platte 92571d961f
Remove mutation from default_config and set default log_level to off 2 years ago
Andrei Vasiliu b56efcdc2a Merge remote-tracking branch 'origin/next' into command-refactor
Fixed a small conflict in admin.rs
2 years ago
Andrei Vasiliu 6399a7fe4e Remove dash from admin command help 2 years ago
Jonas Platte 974c10e739
Move Config out of database module 2 years ago
Jonas Platte ce60fc6859
Stop using set_env to configure tracing-subscriber 2 years ago
Jonas Platte abb4b4cf0b
Remove TryFrom, TryInto imports
They are no longer needed in the 2021 edition.
2 years ago
Andrei Vasiliu 4bbff69a24 Merge remote-tracking branch 'origin/next' into command-refactor
Fixed conflict with commit 78502aa6b1
2 years ago
Timo Kösters b4755ba15b Merge branch 'tests' into 'next'
Bug fixes

See merge request famedly/conduit!278
2 years ago
Timo Kösters 9ef3abacd4
fix: initial state deserialize->serialize error 2 years ago
Andrei Vasiliu 87225e70c3 Parse admin command body templates from doc comments 2 years ago
Timo Kösters a5f004d7e9
fix: signature mismatch on odd send_join servers 2 years ago
Timo Kösters caf9834e50
feat: cache capacity modifier 2 years ago
Timo Kösters 23aecb78c7
fix: use to_lowercase on /register/available username 2 years ago
Timo Kösters e17bbdd42d
tests 2 years ago
Torsten Flammiger 28d3b348d2 Return the ID of the appservice that was created by register_appservice 2 years ago
Torsten Flammiger 78502aa6b1 add error handling for register_appservice too 2 years ago
Torsten Flammiger cc13112592 Cleanup appservice events after removing the appservice 2 years ago
Andrei Vasiliu 677f044d13 Refactor admin code to always defer command processing 2 years ago
Aode (lion) b39ddf7be9 Rename reqwest clients, mention cheap client clones in comment 2 years ago
Andrej Kacian 529e88c7f9 Do not copy mxc string unnecessarily in db.get_thumbnail() 2 years ago
Aode (lion) 1059f35fdc use pre-constructed client for well-known requests also 2 years ago
Aode (Lion) f8d1c1a8af Re-use a basic request in all possible cases 2 years ago
Andrej Kacian 0f6d232cb1 Style fixes from 'cargo fmt' 2 years ago
Andrej Kacian ccfc243c2c Make get_remote_content() return Result instead of ConduitResult 2 years ago
Timo Kösters f7148def90 Merge branch 'up-ruma' into 'next'
Upgrade Ruma

See merge request famedly/conduit!268
2 years ago
Timo Kösters 63309e52f8 Merge branch 'media-download-with-filename' into 'next'
Media download with filename

See merge request famedly/conduit!266
2 years ago
Andrej Kacian c4317a7a96 Reduce code duplication in media download route handlers 2 years ago
Jonas Platte 9c2000cb89
Upgrade Ruma 2 years ago
Andrej Kacian 52873c88b7 Fix incorrect HTTP method in doc comments of two media routes 2 years ago
Andrej Kacian 8472eff277 Implement media download with custom filename 2 years ago
Andrei Vasiliu 7505548b94 Merge remote-tracking branch 'refs/remotes/origin/next' into command-refactor
Resolved conflict for the new list_local_users command
2 years ago
Timo Kösters f50bdb6010 Merge branch 'list_local_users' into 'next'
Implement list_local_users command

See merge request famedly/conduit!260
2 years ago
Timo Kösters f88523988e
improvement: use jemalloc for lower memory usage 2 years ago
Andrei Vasiliu 57979da28c Change structopt to clap, remove markdown dependency 2 years ago
Timo Kösters 5d3ba5c628 Merge branch 'WIP_persy_batch_next' into 'next'
feat: Integration with persy using background ops

See merge request famedly/conduit!231
2 years ago
Torsten Flammiger 960ba8bd99 Merged current next 2 years ago
Torsten Flammiger ba6d72f3f9 Reformatted 2 years ago
Andrei Vasiliu cc3ef1a8be Improve help text for admin commands 2 years ago
Andrei Vasiliu f244c0e2ce Merge remote-tracking branch 'refs/remotes/origin/next' into command-refactor 2 years ago
Andrei Vasiliu e378bc4a2c Refactor admin commands to use structopt 2 years ago
Jonas Platte 6bb1081b71
Use BTreeMap::into_values
Stable under new MSRV.
2 years ago
Jonas Platte 756a41f22d
Fix rustc / clippy warnings 2 years ago
Jonas Platte a0fc5eba72
Remove unnecessary Result 2 years ago
Jonas Platte c6277c72a1
Fix warnings in database::abstraction 2 years ago
Jonas Platte 13a48c4577
Clean up mod and use statements in lib.rs and main.rs 2 years ago
Timo Kösters 53de350908
fix: less load when lazy loading 2 years ago
Torsten Flammiger fd6427a83f Update/Revert code comment 2 years ago
Torsten Flammiger fc39b3447c Little bit of refactoring 2 years ago
Torsten Flammiger 4aefc29650 Merge branch 'list_local_users_test' into list_local_users 2 years ago
Timo Kösters 03b174335c
improvement: lower default pdu cache capacity 2 years ago
Timo Kösters 8c90e7adfb
refactor: fix warnings 2 years ago
Timo Kösters ee8e72f7a8
feat: implement server ACLs 2 years ago
Torsten Flammiger 50430cf4ab Name function after command: list_local_users 2 years ago
Torsten Flammiger 52284ef9e2 Add some debug/info if user was found 2 years ago
Torsten Flammiger 3e79d15495 Updated function documentation 2 years ago
Andrei Vasiliu 13ae036ca0 Move and refactor admin commands into admin module 2 years ago
Torsten Flammiger 9205c07048 Update get_local_users description 2 years ago
Torsten Flammiger c03bf6ef11 name the function after its purpose: iter_locals -> get_local_users 2 years ago
Torsten Flammiger 91eb6c4d08 Return a Result instead of a vector 2 years ago
Torsten Flammiger fb19114bd9 rename iter_locals to get_local_users; make get_local_users skip on parse errors; remove deprecated function count_local_users 2 years ago
Tglman f9977ca64f fix: changes to update to the last database engine trait definition 2 years ago
Tglman 1cc41937bd refactor:use generic watcher in persy implementation 2 years ago
Tglman ab15ec6c32 feat: Integration with persy using background ops 2 years ago
Timo Kösters d434dfb3a5
feat: config option for rocksdb max open files 3 years ago
Timo Kösters 80e51986c4
improvement: better default cache capacity 3 years ago
Timo Kösters 16f826773b
refactor: fix warnings 3 years ago
Timo Kösters 6fa01aa982
fix: remove dbg 3 years ago
Timo Kösters a336027b0e
fix: better memory usage message 3 years ago
Timo Kösters 447639054e
improvement: higher default pdu capacity 3 years ago
Timo Kösters 9e77f7617c
fix: disable direct IO again 3 years ago
Timo Kösters 7f27af032b
improvement: optimize rocksdb for spinning disks 3 years ago
Timo Kösters b96822b617
fix: use db options for column families too 3 years ago
Timo Kösters 0bb7d76dec
improvement: rocksdb configuration 3 years ago
Timo Kösters 077e9ad438
improvement: memory usage for caches 3 years ago
Andrej Kacian 68ee1a5408
Add rocksdb implementation of memory_usage() 3 years ago
Andrej Kacian ff243870f8
Add "database_memory_usage" AdminCommand 3 years ago
Andrej Kacian 71431f330a
Add memory_usage() to DatabaseEngine trait 3 years ago
Timo Kösters fa6d7f7ccd
feat: database backend selection at runtime 3 years ago
Timo Kösters 4f39d36e98
docs: lazy loading 3 years ago
Timo Kösters c6d88359d7
fix: incremental lazy loading 3 years ago
Timo Kösters f285c89006
fix: make incremental sync efficient again 3 years ago
Timo Kösters 93d225fd1e
improvement: faster way to load required state 3 years ago
Timo Kösters 1bd9fd74b3
feat: partially support sync filters 3 years ago
Timo Kösters 68e910bb77
feat: lazy loading 3 years ago
Timo Kösters 5bcc1324ed
fix: auth event fetch order 3 years ago
Timo Kösters 54f4d39e3e
improvement: don't fetch event multiple times 3 years ago
Timo Kösters b1d9ec3efc
fix: atomic increment 3 years ago
Timo Kösters ee3d2db8e0
improvement, maybe not safe 3 years ago
Timo Kösters 83a9095cdc
fix? 3 years ago
Timo Kösters 74951cb239
dbg 3 years ago
Timo Kösters 4b4afea2ab
fix auth event fetching 3 years ago
Timo Kösters c9c9974641
fix: stack overflows when fetching auth events 3 years ago
Timo Kösters a30b588ede
rocksdb as default 3 years ago
Timo Kösters 1d647a1a9a
improvement: allow rocksdb again 3 years ago
Timo Kösters b25354c747 Merge branch 'add_remove_appservice' into 'next'
Add ability to remove an appservice

See merge request famedly/conduit!236
3 years ago
Torsten Flammiger eecd664c43 Reformat code 3 years ago
Jonas Platte bcf4ede0bc
Restore compatibility with Rust 1.53 3 years ago
Jonas Platte 84862352ba
Replace to_string calls on string literals with to_owned 3 years ago
Jonas Platte cf54185a1c
Use struct literals for consistency 3 years ago
Jonas Platte 349865d3cc
Upgrade Ruma 3 years ago
Timo Kösters 8e12b47df4 Merge branch 'no-passwords-in-db' into 'next'
Do not store uiaa requests in database

See merge request famedly/conduit!219
3 years ago
Timo Kösters 0ec26b7e96 Merge branch 'next' into 'next'
refactor:moved key watch wake logic to specific module

See merge request famedly/conduit!238
3 years ago
Torsten Flammiger 8d51359668 Fix typo and remove unneeded newline 3 years ago
Torsten Flammiger a69eb277d4 Update count users: It's now list_local_users and contains the number and the usernames 3 years ago
Torsten Flammiger 39787b41cb Rename admin command CountUsers -> CountLocalUsers; Update comments 3 years ago
Torsten Flammiger 2281bcefc6 Finalize count_local_users function 3 years ago
Torsten Flammiger d21030566c Rename/Add count methods to count_local_users 3 years ago
Torsten Flammiger 567cf6dbe9 Add command count_local_users to database/rooms.rs 3 years ago
Torsten Flammiger 7c1b2625cf Prepare to add an option to list local user accounts from your homeserver 3 years ago
Tglman a889e884e6 refactor:moved key watch wake logic to specific module 3 years ago
Jonas Platte aba95b20f3
Upgrade Ruma 3 years ago
Moritz Bitsch c4a438460e Use Box to store UserID and DeviceID
Userid and DeviceID are of unknown size, use Box to be able to store
them into the userdevicesessionid_uiaarequest BTreeMap
3 years ago
Torsten Flammiger 7f2445be6c On unregister_appservice(service_name), remove the appservice service_name from cache too 3 years ago
Torsten Flammiger b6c9582cf4 Fix doc style comment according to Rust; VSCode added line breaks 3 years ago
Torsten Flammiger 7857da8a0b Add ability to remove an appservice 3 years ago
Moritz Bitsch 720a54b3bb Use String to store UserId for uiaa request
Fixes compilation error after ruma upgrade
3 years ago
Moritz Bitsch 0725b69abb Clean up userdevicesessionid_uiaarequest BTreeMap
There is no need to encode or decode anything as we are not
saving to disk
3 years ago
Moritz Bitsch fe8cfe0556 Add database migration to remove stored passwords
uiaarequests can contain plaintext passwords, which were stored on disk
3 years ago
Moritz Bitsch 3d25d46dc5 Use simple BTreeMap to store uiaa requests
some uiaa requests contain plaintext passwords which should never be
persisted to disk.

Currently there is no cleanup implemented (you have to restart conduit)
3 years ago
Jonas Platte 34d3f74f36
Use Arc for EventIds in PDUs
Upgrades Ruma again to make this work.
3 years ago
Jonas Platte 0183d003d0
Revert rename of Ruma<_> parameters 3 years ago
Jonas Platte f712455047
Reduce EventId copying 3 years ago
Jonas Platte 58ea081762
Use int! macro instead of Int::from 3 years ago
Jonas Platte bffddbd487
Simplify identifier parsing code 3 years ago
Jonas Platte 41fef1da64
Remove unnecessary .to_string() calls 3 years ago
Jonas Platte 892a0525f2
Upgrade Ruma 3 years ago
Jonas Platte 1fc616320a
Use struct init shorthand 3 years ago
Moritz Bitsch 9fccbb014a Implement TURN server authentication with hmac
This is a prefered method to allow limited access to the TURN server
3 years ago
Moritz Bitsch 109892b4b7 Implement turn server settings
this fills out the infos in /_matrix/client/r0/voip/turnServer with
values specified in the server config
3 years ago
Jonas Platte 24a835647c Merge branch 'nyaaori/fix-room-creation' into 'next'
Make createRoom follow spec for m.room.create, allowing creation of spaces

See merge request famedly/conduit!220
3 years ago
Nyaaori c4bce1d0c7
Cleanup room.rs; replace unwraps with map_err 3 years ago
Nyaaori 86177faae7
Fix join panic bug 3 years ago
Nyaaori d5d25fb064
Preserve all m.room.create entries when performing room upgrades 3 years ago
Nyaaori 8087a26a35
Make createRoom follow spec for m.room.create, allowing creation of spaces 3 years ago
Nyaaori bbe16f8467
Update Ruma 3 years ago
Nyaaori 50f931a2fd
Cleanup and fix validation in report.rs, lower max report length, better html 3 years ago
Nyaaori 1541b93f45
Make reports look nicer and reduce spam potential, increase max report length to 1000 characters 3 years ago