public function UnitAddAccessCheck::access in Booking and Availability Management Tools for Drupal 8
Checks access to the unit add page for the unit type.
Parameters
\Drupal\Core\Session\AccountInterface $account: The currently logged in account.
\Drupal\bat_unit\UnitBundleInterface $unit_bundle: (optional) The unit bundle. If not specified, access is allowed if there exists at least one unit bundle for which the user may create a unit.
Return value
\Drupal\Core\Access\AccessResultInterface The access result.
File
- modules/
bat_unit/ src/ Access/ UnitAddAccessCheck.php, line 50 - Contains \Drupal\bat_unit\Access\UnitAddAccessCheck.
Class
- UnitAddAccessCheck
- Determines access to for unit add pages.
Namespace
Drupal\bat_unit\AccessCode
public function access(AccountInterface $account, UnitBundleInterface $unit_bundle = NULL) {
$access_control_handler = $this->entityTypeManager
->getAccessControlHandler('bat_unit');
if ($account
->hasPermission('administer bat_unit_bundle entities')) {
// There are no type bundles defined that the user has permission to
// create, but the user does have the permission to administer the content
// types, so grant them access to the page anyway.
return AccessResult::allowed();
}
if ($unit_bundle) {
return $access_control_handler
->createAccess($unit_bundle
->id(), $account, [], TRUE);
}
$bundles = bat_unit_get_bundles();
foreach ($bundles as $bundle) {
if (bat_unit_access(bat_unit_create([
'type' => $bundle
->id(),
'uid' => 0,
]), 'create', $account
->getAccount())
->isAllowed()) {
return AccessResult::allowed();
}
}
return AccessResult::forbidden();
}