Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/server.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'apps/dav/lib/Connector/PublicAuth.php')
-rw-r--r--apps/dav/lib/Connector/PublicAuth.php16
1 files changed, 15 insertions, 1 deletions
diff --git a/apps/dav/lib/Connector/PublicAuth.php b/apps/dav/lib/Connector/PublicAuth.php
index 0aab95b8158..7d805b34d5c 100644
--- a/apps/dav/lib/Connector/PublicAuth.php
+++ b/apps/dav/lib/Connector/PublicAuth.php
@@ -31,6 +31,7 @@
namespace OCA\DAV\Connector;
+use OC\Security\Bruteforce\Throttler;
use OCP\IRequest;
use OCP\ISession;
use OCP\Share\Exceptions\ShareNotFound;
@@ -44,6 +45,7 @@ use Sabre\DAV\Auth\Backend\AbstractBasic;
* @package OCA\DAV\Connector
*/
class PublicAuth extends AbstractBasic {
+ private const BRUTEFORCE_ACTION = 'public_webdav_auth';
/** @var \OCP\Share\IShare */
private $share;
@@ -57,17 +59,23 @@ class PublicAuth extends AbstractBasic {
/** @var IRequest */
private $request;
+ /** @var Throttler */
+ private $throttler;
+
/**
* @param IRequest $request
* @param IManager $shareManager
* @param ISession $session
+ * @param Throttler $throttler
*/
public function __construct(IRequest $request,
IManager $shareManager,
- ISession $session) {
+ ISession $session,
+ Throttler $throttler) {
$this->request = $request;
$this->shareManager = $shareManager;
$this->session = $session;
+ $this->throttler = $throttler;
// setup realm
$defaults = new \OCP\Defaults();
@@ -87,9 +95,12 @@ class PublicAuth extends AbstractBasic {
* @throws \Sabre\DAV\Exception\NotAuthenticated
*/
protected function validateUserPass($username, $password) {
+ $this->throttler->sleepDelayOrThrowOnMax($this->request->getRemoteAddress(), self::BRUTEFORCE_ACTION);
+
try {
$share = $this->shareManager->getShareByToken($username);
} catch (ShareNotFound $e) {
+ $this->throttler->registerAttempt(self::BRUTEFORCE_ACTION, $this->request->getRemoteAddress());
return false;
}
@@ -114,11 +125,14 @@ class PublicAuth extends AbstractBasic {
header('WWW-Authenticate: DummyBasic realm="' . $this->realm . '"');
throw new \Sabre\DAV\Exception\NotAuthenticated('Cannot authenticate over ajax calls');
}
+
+ $this->throttler->registerAttempt(self::BRUTEFORCE_ACTION, $this->request->getRemoteAddress());
return false;
}
} elseif ($share->getShareType() === IShare::TYPE_REMOTE) {
return true;
} else {
+ $this->throttler->registerAttempt(self::BRUTEFORCE_ACTION, $this->request->getRemoteAddress());
return false;
}
} else {