<?php
/**
- * @copyright Copyright (C) 2010-2022, the Friendica project
+ * @copyright Copyright (C) 2010-2023, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
use Friendica\Model\Post;
use Friendica\Model\User;
use Friendica\Module\Api\ApiResponse;
+use Friendica\Module\Special\HTTPException as ModuleHTTPException;
use Friendica\Network\HTTPException;
use Friendica\Security\BasicAuth;
use Friendica\Security\OAuth;
*
* @throws HTTPException\ForbiddenException
*/
- public function run(array $request = [], bool $scopecheck = true): ResponseInterface
+ public function run(ModuleHTTPException $httpException, array $request = [], bool $scopecheck = true): ResponseInterface
{
if ($scopecheck) {
switch ($this->args->getMethod()) {
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);
+ return parent::run($httpException, $request);
}
/**
}
/**
- * Set the "link" header with "next" and "prev" links
- * @return void
+ * Get the "link" header with "next" and "prev" links
+ * @return string
*/
- protected static function setLinkHeader()
+ protected static function getLinkHeader(): string
{
if (empty(self::$boundaries)) {
- return;
+ return '';
}
$request = self::$request;
$prev = $command . '?' . http_build_query($prev_request);
$next = $command . '?' . http_build_query($next_request);
- header('Link: <' . $next . '>; rel="next", <' . $prev . '>; rel="prev"');
+ return 'Link: <' . $next . '>; rel="next", <' . $prev . '>; rel="prev"';
+ }
+
+ /**
+ * Set the "link" header with "next" and "prev" links
+ * @return void
+ */
+ protected static function setLinkHeader()
+ {
+ $header = self::getLinkHeader();
+ if (!empty($header)) {
+ header($header);
+ }
+ }
+
+ /**
+ * Check if the app is known to support quoted posts
+ *
+ * @return bool
+ */
+ public static function appSupportsQuotes(): bool
+ {
+ $token = self::getCurrentApplication();
+ return (!empty($token['name']) && in_array($token['name'], ['Fedilab']));
}
/**