<?php
/**
- * @copyright Copyright (C) 2010-2021, the Friendica project
+ * @copyright Copyright (C) 2010-2022, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
*
* @throws HTTPException\ForbiddenException
*/
- public function run(array $request = []): ResponseInterface
+ public function run(array $request = [], bool $scopecheck = true): ResponseInterface
{
- switch ($this->server['REQUEST_METHOD'] ?? Router::GET) {
- case Router::DELETE:
- case Router::PATCH:
- case Router::POST:
- case Router::PUT:
- self::checkAllowedScope(self::SCOPE_WRITE);
-
- if (!self::getCurrentUserID()) {
- throw new HTTPException\ForbiddenException($this->t('Permission denied.'));
- }
- break;
+ if ($scopecheck) {
+ switch ($this->args->getMethod()) {
+ case Router::DELETE:
+ case Router::PATCH:
+ case Router::POST:
+ case Router::PUT:
+ self::checkAllowedScope(self::SCOPE_WRITE);
+
+ if (!self::getCurrentUserID()) {
+ throw new HTTPException\ForbiddenException($this->t('Permission denied.'));
+ }
+ break;
+ }
}
return parent::run($request);