Skip to content

Commit

Permalink
Update BNF server content view permissions.
Browse files Browse the repository at this point in the history
This view should only be available if the `bnf_server`
module is enabled.
  • Loading branch information
rasben committed Jan 13, 2025
1 parent dfeabc8 commit 77c50ea
Show file tree
Hide file tree
Showing 3 changed files with 75 additions and 6 deletions.
9 changes: 3 additions & 6 deletions config/sync/views.view.importable_content.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,11 @@ dependencies:
- taxonomy.vocabulary.categories
- taxonomy.vocabulary.tags
module:
- dpl_admin
- link
- media
- node
- taxonomy
- user
id: importable_content
label: 'Importable content'
module: views
Expand Down Expand Up @@ -657,9 +657,8 @@ display:
sort_asc_label: Asc
sort_desc_label: Desc
access:
type: perm
options:
perm: 'access content overview'
type: bnf_server_access
options: { }
cache:
type: tag
options: { }
Expand Down Expand Up @@ -1044,7 +1043,6 @@ display:
- url
- url.query_args
- 'user.node_grants:view'
- user.permissions
tags:
- 'config:field.storage.node.field_canonical_url'
- 'config:field.storage.node.field_subtitle'
Expand All @@ -1066,7 +1064,6 @@ display:
- url
- url.query_args
- 'user.node_grants:view'
- user.permissions
tags:
- 'config:field.storage.node.field_canonical_url'
- 'config:field.storage.node.field_subtitle'
Expand Down
9 changes: 9 additions & 0 deletions web/modules/custom/dpl_admin/dpl_admin.services.yml
Original file line number Diff line number Diff line change
@@ -1,3 +1,12 @@
---
services:

Check failure on line 3 in web/modules/custom/dpl_admin/dpl_admin.services.yml

View workflow job for this annotation

GitHub Actions / Lint Drupal assets

Delete `⏎`
dpl_admin.version_helper:
class: Drupal\dpl_admin\Services\VersionHelper
dpl_admin.bnf_server_access:
class: Drupal\dpl_admin\Plugin\views\access\BnfServerEnabledAccess
arguments:
$configuration: []
$plugin_id: 'dpl_admin.bnf_server_access'
$plugin_definition: []
$module_handler: '@module_handler'
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
<?php

namespace Drupal\dpl_admin\Plugin\views\access;

use Drupal\Core\Access\AccessResult;
use Drupal\Core\Extension\ModuleHandlerInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\views\Plugin\views\access\AccessPluginBase;
use Psr\Container\ContainerInterface;
use Symfony\Component\Routing\Route;

/**
* A custom access handler, that returns Allowed if bnf_server is enabled.
*
* This is necessary as we have views and content that should only be available
* on the BNF server.
*
* @ingroup views_access_plugins
*
* @ViewsAccess(
* id = "bnf_server_access",
* title = @Translation("Allowed if bnf_server is enabled.")
* )
*/
class BnfServerEnabledAccess extends AccessPluginBase {

/**
* {@inheritDoc}
*/
public function __construct(array $configuration, $plugin_id, $plugin_definition, protected ModuleHandlerInterface $module_handler) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->moduleHandler = $module_handler;

Check failure on line 32 in web/modules/custom/dpl_admin/src/Plugin/views/access/BnfServerEnabledAccess.php

View workflow job for this annotation

GitHub Actions / Analyse code using PHPStan

Access to an undefined property Drupal\dpl_admin\Plugin\views\access\BnfServerEnabledAccess::$moduleHandler.
}

/**
* {@inheritDoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static(
$configuration,
$plugin_id,
$plugin_definition,
$container->get('module_handler'),
);
}

/**
* {@inheritDoc}
*/
public function access(AccountInterface $account) {
$hasAccess = $this->moduleHandler->moduleExists('bnf_server');

Check failure on line 51 in web/modules/custom/dpl_admin/src/Plugin/views/access/BnfServerEnabledAccess.php

View workflow job for this annotation

GitHub Actions / Analyse code using PHPStan

Access to an undefined property Drupal\dpl_admin\Plugin\views\access\BnfServerEnabledAccess::$moduleHandler.

return AccessResult::allowedIf($hasAccess);

Check failure on line 53 in web/modules/custom/dpl_admin/src/Plugin/views/access/BnfServerEnabledAccess.php

View workflow job for this annotation

GitHub Actions / Analyse code using PHPStan

Method Drupal\dpl_admin\Plugin\views\access\BnfServerEnabledAccess::access() should return bool but returns Drupal\Core\Access\AccessResultAllowed|Drupal\Core\Access\AccessResultNeutral.
}

/**
* {@inheritDoc}
*/
public function alterRouteDefinition(Route $route) {

Check failure on line 59 in web/modules/custom/dpl_admin/src/Plugin/views/access/BnfServerEnabledAccess.php

View workflow job for this annotation

GitHub Actions / Analyse code using PHPStan

Method Drupal\dpl_admin\Plugin\views\access\BnfServerEnabledAccess::alterRouteDefinition() has no return type specified.
$route->setRequirement('_custom_access', 'dpl_admin.bnf_server_access:access');
}

}

0 comments on commit 77c50ea

Please sign in to comment.