Commit graph

17 commits

Author SHA1 Message Date
Hinaloe
ae5f2716a5 Fix undefined method error () 2019-05-28 15:31:51 +03:00
mayaeh
a08bfea202 Fix undefined method error. () 2019-05-28 05:42:04 +02:00
ThibG
875faa1da6 Improve rate limiting ()
* Rate limit based on remote address IP, not on potential reverse proxy

* Limit rate of unauthenticated API requests further

* Rate-limit paging requests to one every 3 seconds
2019-05-27 21:57:49 +02:00
Eugen Rochko
1ed2c9c16e Add rate limit for media proxy requests ()
30 per 30 minutes, like media uploads
2019-04-07 04:26:43 +02:00
Eugen Rochko
9bf5658885 Add tight rate-limit for API deletions ()
Deletions take a lot of resources to execute and cause a lot of
federation traffic, so it makes sense to decrease the number
someone can queue up through the API.

30 per 30 minutes
2019-02-14 06:27:54 +01:00
Eugen Rochko
bbf9f4f93b Add REST API for creating an account ()
* Add REST API for creating an account

The method is available to apps with a token obtained via the client
credentials grant. It creates a user and account records, as well as
an access token for the app that initiated the request. The user is
unconfirmed, and an e-mail is sent as usual.

The method returns the access token, which the app should save for
later. The REST API is not available to users with unconfirmed
accounts, so the app must be smart to wait for the user to click a
link in their e-mail inbox.

The method is rate-limited by IP to 5 requests per 30 minutes.

* Redirect users back to app from confirmation if they were created with an app

* Add tests

* Return 403 on the method if registrations are not open

* Require agreement param to be true in the API when creating an account
2018-12-24 19:12:38 +01:00
aus-social
c883b1ffc9 lint pass 2 ()
* Code quality pass

* Typofix

* Update applications_controller_spec.rb

* Update applications_controller_spec.rb
2018-10-04 17:38:04 +02:00
Akihiko Odaki
854d974499 Add a missing question mark in rack_attack.rb () 2018-05-03 18:51:00 +02:00
Akihiko Odaki
5cddff0795 Throttle media post ()
The previous rate limit allowed to post media so fast that it is possible
to fill up the disk space even before an administrator notices. The new
rate limit is configured so that it takes 24 hours to eat 10 gigabytes:
10 * 1024 / 8 / (24 * 60 / 30) = 27 (which rounded to 30)

The period is set long so that it does not prevent from attaching several
media to one post, which would happen in a short period. For example,
if the period is 5 minutes, the rate limit would be:
10 * 1024 / 8 / (24 * 60 / 5) = 4

This long period allows to lift the limit up.
2018-05-03 17:32:00 +02:00
Eugen Rochko
b7b0f630a0 Increase rate limit on protected paths ()
Previously each protected path had a separate rate limit. Now they're all in the same bucket, so people are more likely to hit one with register->login. Increasing to 25 per 5 minutes should be fine.
2018-01-09 17:07:54 +01:00
Eugen Rochko
31fe0d067b Apply a 25x rate limit by IP even to authenticated requests () 2017-12-11 15:32:29 +01:00
Naoki Kosaka
77660c4624 Missing require 'authorization_decorator'. () 2017-12-09 15:12:10 +01:00
Eugen Rochko
87af0bf6cf Rate limit by user instead of IP when API user is authenticated ()
* Fix  - Rate limit by user instead of IP when API user is authenticated

* Fix code style issue

* Use request decorator provided by Doorkeeper
2017-12-09 14:20:02 +01:00
unarist
527eacf403 Add Content-Type header on throttled response to fix mojibake ()
application/json only allows Unicode, so this prevents from wrong charset detection.
2017-08-08 15:47:35 +02:00
alpaca-tc
62738bf1a9 Localize 'throttled' () 2017-05-03 23:36:19 +02:00
Tristan Mahé
19881e24fe allow localhost to bypass the ratelimit () 2017-04-30 00:27:49 +02:00
Eugen
e47b32072f Add rate limits for logins and sign-ups by IP (5 in 5 minutes) ()
* Add rate limits for logins and sign-ups by IP (5 in 5 minutes)
Should be enough for normal attempts

* Add rate limit for forgotten password form as well
2017-04-18 22:29:14 +02:00
Renamed from config/initializers/rack-attack.rb (Browse further)