summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2020-07-09 12:16:52 +0200
committerJoas Schilling <coding@schilljs.com>2020-08-19 11:20:36 +0200
commit770381c0c69f43e0efa7e9e803b40a2d0d1b6496 (patch)
treeebff8582fd4f719a207a78a259747fa5b47c3c53 /lib
parent931aca2fee00d6bf55273512212bb21a0300b03e (diff)
downloadnextcloud-server-770381c0c69f43e0efa7e9e803b40a2d0d1b6496.tar.gz
nextcloud-server-770381c0c69f43e0efa7e9e803b40a2d0d1b6496.zip
Correctly return ms delay when at max
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Security/Bruteforce/Throttler.php7
1 files changed, 4 insertions, 3 deletions
diff --git a/lib/private/Security/Bruteforce/Throttler.php b/lib/private/Security/Bruteforce/Throttler.php
index b490c6a4012..d7eb8b44c8a 100644
--- a/lib/private/Security/Bruteforce/Throttler.php
+++ b/lib/private/Security/Bruteforce/Throttler.php
@@ -53,6 +53,7 @@ use OCP\Security\Bruteforce\MaxDelayReached;
class Throttler {
public const LOGIN_ACTION = 'login';
public const MAX_DELAY = 25;
+ public const MAX_DELAY_MS = 25000; // in milliseconds
public const MAX_ATTEMPTS = 10;
/** @var IDBConnection */
@@ -263,12 +264,12 @@ class Throttler {
$firstDelay = 0.1;
if ($attempts > self::MAX_ATTEMPTS) {
// Don't ever overflow. Just assume the maxDelay time:s
- return self::MAX_DELAY;
+ return self::MAX_DELAY_MS;
}
$delay = $firstDelay * 2**$attempts;
if ($delay > self::MAX_DELAY) {
- return self::MAX_DELAY;
+ return self::MAX_DELAY_MS;
}
return (int) \ceil($delay * 1000);
}
@@ -338,7 +339,7 @@ class Throttler {
*/
public function sleepDelayOrThrowOnMax(string $ip, string $action = ''): int {
$delay = $this->getDelay($ip, $action);
- if (($delay === self::MAX_DELAY * 1000) && $this->getAttempts($ip, $action, 0.5) > self::MAX_ATTEMPTS) {
+ if (($delay === self::MAX_DELAY_MS) && $this->getAttempts($ip, $action, 0.5) > self::MAX_ATTEMPTS) {
// If the ip made too many attempts within the last 30 mins we don't execute anymore
throw new MaxDelayReached('Reached maximum delay');
}