mirror of
https://github.com/nextcloud/server.git
synced 2024-12-29 16:38:28 +00:00
bb598c8451
Bumps [nextcloud/coding-standard](https://github.com/nextcloud/coding-standard) from 1.3.1 to 1.3.2. - [Release notes](https://github.com/nextcloud/coding-standard/releases) - [Changelog](https://github.com/nextcloud/coding-standard/blob/master/CHANGELOG.md) - [Commits](https://github.com/nextcloud/coding-standard/compare/v1.3.1...v1.3.2) --- updated-dependencies: - dependency-name: nextcloud/coding-standard dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> Signed-off-by: provokateurin <kate@provokateurin.de>
57 lines
1.3 KiB
PHP
57 lines
1.3 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
/**
|
|
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
namespace OCP\Security\RateLimiting;
|
|
|
|
use OCP\AppFramework\Http\Attribute\AnonRateLimit;
|
|
use OCP\AppFramework\Http\Attribute\UserRateLimit;
|
|
use OCP\IUser;
|
|
|
|
/**
|
|
* Programmatic rate limiter for web requests that are not handled by an app framework controller
|
|
*
|
|
* @see AnonRateLimit
|
|
* @see UserRateLimit
|
|
*
|
|
* @since 28.0.0
|
|
*/
|
|
interface ILimiter {
|
|
/**
|
|
* Registers attempt for an anonymous request
|
|
*
|
|
* @param string $identifier
|
|
* @param int $anonLimit
|
|
* @param int $anonPeriod in seconds
|
|
* @param string $ip
|
|
* @throws IRateLimitExceededException if limits are reached, which should cause a HTTP 429 response
|
|
* @since 28.0.0
|
|
*
|
|
*/
|
|
public function registerAnonRequest(string $identifier,
|
|
int $anonLimit,
|
|
int $anonPeriod,
|
|
string $ip): void;
|
|
|
|
/**
|
|
* Registers attempt for an authenticated request
|
|
*
|
|
* @param string $identifier
|
|
* @param int $userLimit
|
|
* @param int $userPeriod in seconds
|
|
* @param IUser $user the acting user
|
|
* @throws IRateLimitExceededException if limits are reached, which should cause a HTTP 429 response
|
|
* @since 28.0.0
|
|
*
|
|
*/
|
|
public function registerUserRequest(string $identifier,
|
|
int $userLimit,
|
|
int $userPeriod,
|
|
IUser $user): void;
|
|
}
|