Commit Graph

141 Commits (f6d090fdf5912f390c3d1fe5b43f15c1f0704bd3)

Author SHA1 Message Date
Emelia Smith 7490019535
Fix support for IPv6 redis connections in streaming (#31229) 5 months ago
Emelia Smith c953dca1de
Streaming: use pgPool.query instead of manually acquiring & releasing a connection (#30964) 6 months ago
Emelia Smith d436696f46
Streaming: Fix incorrect type definitions (#30977) 6 months ago
Essem 54cc204473
Use WebSocketServer instead of WebSocket.Server in streaming (#30788) 6 months ago
Renaud Chaput 899eac1a92
Use modern ES syntax rather than `.call` (#29368) 10 months ago
Renaud Chaput 036f5a05e3
Convert the streaming server to ESM (#29389)
Co-authored-by: Claire <claire.github-309c@sitedethib.com>
10 months ago
Emelia Smith 491dd97642
Streaming: refactor to custom Error classes (#28632)
Co-authored-by: Renaud Chaput <renchap@gmail.com>
Co-authored-by: Claire <claire.github-309c@sitedethib.com>
10 months ago
Emelia Smith 881e8c113c
Refactor: fix streaming postgresql and redis typing issues (#28747) 11 months ago
Emelia Smith 3fbf01918f
Streaming: Move more methods to the utils from the main file (#28825) 11 months ago
Emelia Smith 1335083bed
Streaming: replace npmlog with pino & pino-http (#27828) 12 months ago
Emelia Smith 58830be943
Streaming: Rework websocket server initialisation & authentication code (#28631) 12 months ago
Emelia Smith 9826b7780a
Streaming: use standard cors package instead of custom implementation (#28523) 1 year ago
Emelia Smith a4de0e364b
Refactor streaming to simplify for logging change (#28056) 1 year ago
Emelia Smith 15b2d7eec5
Split streaming server from web server (#24702) 1 year ago
Renaud Chaput 774e1189d2
Change `eslint` config to autofix missing comma and indentation in JS files (#26711) 1 year ago
Emelia Smith f68d540271
Fix websocket connections being incorrectly decremented twice on errors (#27238) 1 year ago
Emelia Smith fbfceb9c77
Add additional metrics for streaming (#26945) 1 year ago
Gabriel Simmer be991f1d18
Move to ioredis for streaming (#26581)
Co-authored-by: Emelia Smith <ThisIsMissEm@users.noreply.github.com>
1 year ago
Emelia Smith 6375e390af
Fix: support both DATABASE_URL and DB_PASS (#26295) 1 year ago
Emelia Smith 65096c1ccd
Change streaming `/metrics` to include additional metrics (#26299) 1 year ago
Renaud Chaput 3554c52795
Fix missing return values in streaming (#26233) 1 year ago
Claire 446821a0dc
Swap debug statements in streaming server (#26231) 1 year ago
Emelia Smith 81cdc0f972
Fix: Streaming server memory leak in HTTP EventSource cleanup (#26228) 1 year ago
Emelia Smith ddaf200c78
Refactor streaming's filtering logic & improve documentation (#26213) 1 year ago
Claire 1814990a3d
Fix wrong filters sometimes applying in streaming (#26159) 1 year ago
Emelia Smith 215081240f
Add logging of websocket send errors (#25280) 2 years ago
Emelia Smith c81f59583c
Fix logging of messages that are binary before closing their connection (#25361) 2 years ago
Emelia Smith 16dd3f08c1
Fix performance of streaming by parsing message JSON once (#25278) 2 years ago
Renaud Chaput d27216dc46
Enforce import order with ESLint (#25096) 2 years ago
Nick Schonning f22b4e556c
Add eslint-plugin-jsdoc (#24719) 2 years ago
Emelia Smith 301e03eb8c
Remove clustering from streaming API (#24655) 2 years ago
Claire 174352716a
Disable anonymous access to the streaming API (#23989) 2 years ago
Eugen Rochko be1792e1d4
Fix streaming API not being usable without `DATABASE_URL` (#23960) 2 years ago
Ramūns Usovs 0872f3e3d7
Allow streaming to connect to postgress with self-signed certs (#21431) 2 years ago
emilweth 7c45145430
fix metrics format (#23520) 2 years ago
emilweth c1b823368c
dot is not allowed (#23519) 2 years ago
Eugen Rochko c5a4d8c82d
Add information about database pool to metrics endpoint in streaming API (#23469) 2 years ago
Eugen Rochko 4cb7647516
Add database pool configuration over `DB_POOL` to streaming API (#23470)
Add connection timeout of 15s
2 years ago
Eugen Rochko 01584f03e8
Add metrics endpoint to streaming API (#23388) 2 years ago
Nick Schonning 06b68490d1
Enable eslint:recommended ruleset (#22433)
* Enable ESLint recommended ruleset

* Disable failing ESLint recommended rules

* Remove rules shadowed by eslint:recommended
2 years ago
Claire 8c3c6dcae9
Fix filters from other users being used in the streaming service (#20719) 2 years ago
Claire cd5e98dbdb
Fix public/local timeline posts not being properly filtered (#20567)
* Fix streaming server using wrong property name for matching filters

Late in the PR, the `filter_results` property has been renamed to `filtered`,
but the change has not been reflected in the streaming server code.

* Fix filter_action attribute being an integer instead of a string
2 years ago
Eugen Rochko e7aa2be828
Change how hashtags are normalized (#18795)
* Change how hashtags are normalized

* Fix tests
3 years ago
Claire 02851848e9
Revamp post filtering system (#18058)
* Add model for custom filter keywords

* Use CustomFilterKeyword internally

Does not change the API

* Fix /filters/edit and /filters/new

* Add migration tests

* Remove whole_word column from custom_filters (covered by custom_filter_keywords)

* Redesign /filters

Instead of a list, present a card that displays more information and handles
multiple keywords per filter.

* Redesign /filters/new and /filters/edit to add and remove keywords

This adds a new gem dependency: cocoon, as well as a npm dependency:
cocoon-js-vanilla. Those are used to easily populate and remove form fields
from the user interface when manipulating multiple keyword filters at once.

* Add /api/v2/filters to edit filter with multiple keywords

Entities:
- `Filter`: `id`, `title`, `filter_action` (either `hide` or `warn`), `context`
  `keywords`
- `FilterKeyword`: `id`, `keyword`, `whole_word`

API endpoits:
- `GET /api/v2/filters` to list filters (including keywords)
- `POST /api/v2/filters` to create a new filter
  `keywords_attributes` can also be passed to create keywords in one request
- `GET /api/v2/filters/:id` to read a particular filter
- `PUT /api/v2/filters/:id` to update a new filter
  `keywords_attributes` can also be passed to edit, delete or add keywords in
   one request
- `DELETE /api/v2/filters/:id` to delete a particular filter
- `GET /api/v2/filters/:id/keywords` to list keywords for a filter
- `POST /api/v2/filters/:filter_id/keywords/:id` to add a new keyword to a
   filter
- `GET /api/v2/filter_keywords/:id` to read a particular keyword
- `PUT /api/v2/filter_keywords/:id` to edit a particular keyword
- `DELETE /api/v2/filter_keywords/:id` to delete a particular keyword

* Change from `irreversible` boolean to `action` enum

* Remove irrelevent `irreversible_must_be_within_context` check

* Fix /filters/new and /filters/edit with update for filter_action

* Fix Rubocop/Codeclimate complaining about task names

* Refactor FeedManager#phrase_filtered?

This moves regexp building and filter caching to the `CustomFilter` class.

This does not change the functional behavior yet, but this changes how the
cache is built, doing per-custom_filter regexps so that filters can be matched
independently, while still offering caching.

* Perform server-side filtering and output result in REST API

* Fix numerous filters_changed events being sent when editing multiple keywords at once

* Add some tests

* Use the new API in the WebUI

- use client-side logic for filters we have fetched rules for.
  This is so that filter changes can be retroactively applied without
  reloading the UI.
- use server-side logic for filters we haven't fetched rules for yet
  (e.g. network error, or initial timeline loading)

* Minor optimizations and refactoring

* Perform server-side filtering on the streaming server

* Change the wording of filter action labels

* Fix issues pointed out by linter

* Change design of “Show anyway” link in accordence to review comments

* Drop “irreversible” filtering behavior

* Move /api/v2/filter_keywords to /api/v1/filters/keywords

* Rename `filter_results` attribute to `filtered`

* Rename REST::LegacyFilterSerializer to REST::V1::FilterSerializer

* Fix systemChannelId value in streaming server

* Simplify code by removing client-side filtering code

The simplifcation comes at a cost though: filters aren't retroactively
applied anymore.
3 years ago
Yamagishi Kazutoshi 5781d1db84
Fix parsing `TRUSTED_PROXY_IP` (#18051) 3 years ago
Claire f29458da1d
Fix streaming server sometimes silently dropping subscriptions (#17841) 3 years ago
Claire 6ea80ba2a2
Change streaming server error messages when failing to parse client input (#17559)
Fixes #17541

- prefix JSON parsing error message by “Error parsing message from …”
- output user id if a user is logged in, IP address otherwise
- reduce log level from error to warning when a user is logged in, and to silly
  otherwise
3 years ago
Claire bc066d8936
Fix timeline streaming stopping for multiple sessions instead of one (#17259)
* Fix timeline streaming stopping for multiple sessions instead of one

Fixes #17256.

In updating the code for a newer version of node-redis, #17183 also broke
redis subscription management when multiple streaming clients subscribe to the
same channel.

This commit restores the redis subscription management code.

* Let node-redis actually handle the subscriptions
3 years ago
Lerk 4d1eaf3e6e
Finish update of node-redis (#17183)
* fix streaming redis client

* use console.error instead of console.log

* follow node-redis migration guide

https://github.com/redis/node-redis/blob/master/docs/v3-to-v4.md

* fix config options for node-redis

* keep indentation

* Update streaming/index.js

Co-authored-by: Yamagishi Kazutoshi <ykzts@desire.sh>

Co-authored-by: Yamagishi Kazutoshi <ykzts@desire.sh>
3 years ago
Sasha Sorokin 6c88ebfd4b
fix(streaming): req.scopes can be nullable (#16823)
When checking for required OAuth scopes, an unexpected error could
happen due to missing (null-y) req.scopes. This commit fixes that by
checking if req.scopes are present before checking if any required
scopes are present, otherwise it skips that straight to rejection.
3 years ago