Skip to content

Commit

Permalink
Merge pull request phpbb#6765 from iMattPro/ticket/17457
Browse files Browse the repository at this point in the history
[ticket/17457] Cache manifest file
  • Loading branch information
marc1706 authored Dec 25, 2024
2 parents 688dbb0 + 0bf195c commit db70b3b
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 21 deletions.
1 change: 0 additions & 1 deletion phpBB/config/default/container/services.yml
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,6 @@ services:
class: phpbb\manifest
arguments:
- '@config'
- '@language'
- '@path_helper'
- '@event_dispatcher'
- '@user'
Expand Down
37 changes: 18 additions & 19 deletions phpBB/phpbb/manifest.php
Original file line number Diff line number Diff line change
Expand Up @@ -15,19 +15,13 @@

use phpbb\config\config;
use phpbb\event\dispatcher_interface;
use phpbb\exception\http_exception;
use phpbb\language\language;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\HttpFoundation\Response;

class manifest
{
/** @var config */
protected $config;

/** @var language */
protected $language;

/** @var path_helper */
protected $path_helper;

Expand All @@ -41,17 +35,15 @@ class manifest
* Constructor for manifest controller
*
* @param config $config
* @param language $language
* @param path_helper $path_helper
* @param dispatcher_interface $phpbb_dispatcher
* @param user $user
*/
public function __construct(config $config, language $language, path_helper $path_helper, dispatcher_interface $phpbb_dispatcher, user $user)
public function __construct(config $config, path_helper $path_helper, dispatcher_interface $phpbb_dispatcher, user $user)
{
$this->config = $config;
$this->path_helper = $path_helper;
$this->phpbb_dispatcher = $phpbb_dispatcher;
$this->language = $language;
$this->user = $user;
}

Expand All @@ -62,11 +54,6 @@ public function __construct(config $config, language $language, path_helper $pat
*/
public function handle(): JsonResponse
{
if ($this->user->data['is_bot'])
{
throw new http_exception(Response::HTTP_FORBIDDEN, 'NO_AUTH_OPERATION');
}

$board_path = $this->config['force_server_vars'] ? $this->config['script_path'] : $this->path_helper->get_web_root_path();

$sitename = html_entity_decode($this->config['sitename'], ENT_QUOTES, 'UTF-8');
Expand All @@ -77,7 +64,6 @@ public function handle(): JsonResponse
'short_name' => $sitename_short ?: utf8_substr($sitename, 0, 12),
'display' => 'standalone',
'orientation' => 'portrait',
'dir' => $this->language->lang('DIRECTION'),
'start_url' => $board_path,
'scope' => $board_path,
];
Expand All @@ -86,13 +72,26 @@ public function handle(): JsonResponse
* Event to modify manifest data before it is outputted
*
* @event core.modify_manifest
* @var array manifest Array of manifest members
* @var string board_path Path to the board root
* @var array manifest Array of manifest members
* @var string board_path Path to the board root
* @var string sitename Full name of the board
* @var string sitename_short Shortened name of the board
* @since 4.0.0-a1
*/
$vars = array('manifest', 'board_path');
$vars = ['manifest', 'board_path', 'sitename', 'sitename_short'];
extract($this->phpbb_dispatcher->trigger_event('core.modify_manifest', compact($vars)));

return new JsonResponse($manifest);
$response = new JsonResponse($manifest);
$response->setPublic();
$response->setMaxAge(3600);
$response->headers->addCacheControlDirective('must-revalidate', true);

if (!empty($this->user->data['is_bot']))
{
// Let reverse proxies know we detected a bot.
$response->headers->set('X-PHPBB-IS-BOT', 'yes');
}

return $response;
}
}
1 change: 0 additions & 1 deletion tests/functional/manifest_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ public function test_manifest()
'short_name' => 'yourdomain',
'display' => 'standalone',
'orientation' => 'portrait',
'dir' => 'ltr',
'start_url' => $url_path,
'scope' => $url_path,
];
Expand Down

0 comments on commit db70b3b

Please sign in to comment.