class OgMenuInstanceController in Organic Groups Menu (OG Menu) 8
Class OgMenuInstanceController.
@package Drupal\og_menu\Controller
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\og_menu\Controller\OgMenuInstanceController
Expanded class hierarchy of OgMenuInstanceController
File
- src/
Controller/ OgMenuInstanceController.php, line 28 - Contains Drupal\og_menu\Controller\OgMenuInstanceController.
Namespace
Drupal\og_menu\ControllerView source
class OgMenuInstanceController extends ControllerBase {
/**
* The OG membership manager service.
*
* @var \Drupal\og\MembershipManagerInterface
*/
protected $membershipManager;
/**
* Constructs an OgMenuInstanceController object.
*
* @param \Drupal\og\MembershipManagerInterface $membership_manager
* The OG membership manager service.
*/
public function __construct(MembershipManagerInterface $membership_manager) {
$this->membershipManager = $membership_manager;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('og.membership_manager'));
}
/**
* Controller for the create menu instance form.
*
* Depending on whether the menu instance already exists, the user will be
* redirected to the entity create or edit form.
*
* @param \Drupal\og_menu\Entity\OgMenu $ogmenu
* The OG Menu that is associated with the menu instance.
* @param \Drupal\Core\Entity\EntityInterface $og_group
* The group that is associated with the menu instance.
*
* @return \Symfony\Component\HttpFoundation\RedirectResponse
* The response.
*/
public function createMenuInstance(OgMenu $ogmenu, EntityInterface $og_group) {
$values = [
'type' => $ogmenu
->id(),
OgGroupAudienceHelperInterface::DEFAULT_FIELD => $og_group
->id(),
];
// Menu exists, redirect to edit form.
$instances = $this
->entityTypeManager()
->getStorage('ogmenu_instance')
->loadByProperties($values);
if ($instances) {
$instance = array_pop($instances);
return $this
->redirect('entity.ogmenu_instance.edit_form', [
'ogmenu_instance' => $instance
->id(),
]);
}
// Create new menu instance.
$entity = OgMenuInstance::create($values);
$entity
->save();
if ($entity
->id()) {
return $this
->redirect('entity.ogmenu_instance.edit_form', [
'ogmenu_instance' => $entity
->id(),
]);
}
throw new Exception('Unable to save menu instance.');
}
/**
* Provides the menu link creation form.
*
* @param \Drupal\og_menu\OgMenuInstanceInterface $ogmenu_instance
* An entity representing a custom menu.
*
* @return array
* Returns the menu link creation form.
*/
public function addLink(OgMenuInstanceInterface $ogmenu_instance) {
$menu_link = $this
->entityTypeManager()
->getStorage('menu_link_content')
->create(array(
'id' => '',
'parent' => '',
'menu_name' => 'ogmenu-' . $ogmenu_instance
->id(),
'bundle' => 'menu_link_content',
));
return $this
->entityFormBuilder()
->getForm($menu_link);
}
/**
* Route title callback.
*
* @param \Drupal\og_menu\OgMenuInstanceInterface $ogmenu_instance
* The OG Menu instance that is being edited.
*
* @return array
* The title as a render array.
*/
public function editFormTitle(OgMenuInstanceInterface $ogmenu_instance) {
return [
'#markup' => t('Edit menu %menu of %group', [
'%menu' => $ogmenu_instance
->bundle(),
'%group' => $ogmenu_instance
->label(),
]),
'#allowed_tags' => Xss::getHtmlTagList(),
];
}
/**
* Access callback for the "add link" route.
*
* @param \Drupal\og_menu\Entity\OgMenuInstance $ogmenu_instance
* The OG Menu instance for which to determine access.
* @param \Drupal\Core\Session\AccountInterface $account
* The user for which to determine access.
*
* @return \Drupal\Core\Access\AccessResult
* The access result.
*/
public function addLinkAccess(OgMenuInstance $ogmenu_instance, AccountInterface $account) {
// @todo Add per-bundle permissions. You might want to give users access to
// add links to a particular OG Menu, but not all of them.
$permission = 'add new links to og menu instance entities';
// If the user has the global permission, allow access immediately.
if ($account
->hasPermission($permission)) {
return AccessResult::allowed();
}
// Retrieve the associated group from the menu instance.
$og_groups = $this->membershipManager
->getGroups($ogmenu_instance);
// A menu should only be associated with a single group.
$group_entity_type = key($og_groups);
$og_group = reset($og_groups[$group_entity_type]);
// If the group could not be found, access could not be determined.
if (empty($og_group)) {
return AccessResult::neutral();
}
$membership = $this->membershipManager
->getMembership($og_group, $account
->id());
// If the membership can not be found, access can not be determined.
if (empty($membership)) {
return AccessResult::neutral();
}
return AccessResult::allowedIf($membership
->hasPermission($permission));
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ControllerBase:: |
protected | property | The configuration factory. | |
ControllerBase:: |
protected | property | The current user service. | 1 |
ControllerBase:: |
protected | property | The entity form builder. | |
ControllerBase:: |
protected | property | The entity manager. | |
ControllerBase:: |
protected | property | The entity type manager. | |
ControllerBase:: |
protected | property | The form builder. | 2 |
ControllerBase:: |
protected | property | The key-value storage. | 1 |
ControllerBase:: |
protected | property | The language manager. | 1 |
ControllerBase:: |
protected | property | The module handler. | 2 |
ControllerBase:: |
protected | property | The state service. | |
ControllerBase:: |
protected | function | Returns the requested cache bin. | |
ControllerBase:: |
protected | function | Retrieves a configuration object. | |
ControllerBase:: |
private | function | Returns the service container. | |
ControllerBase:: |
protected | function | Returns the current user. | 1 |
ControllerBase:: |
protected | function | Retrieves the entity form builder. | |
ControllerBase:: |
protected | function | Retrieves the entity manager service. | |
ControllerBase:: |
protected | function | Retrieves the entity type manager. | |
ControllerBase:: |
protected | function | Returns the form builder service. | 2 |
ControllerBase:: |
protected | function | Returns a key/value storage collection. | 1 |
ControllerBase:: |
protected | function | Returns the language manager service. | 1 |
ControllerBase:: |
protected | function | Returns the module handler. | 2 |
ControllerBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
ControllerBase:: |
protected | function | Returns the state storage service. | |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
OgMenuInstanceController:: |
protected | property | The OG membership manager service. | |
OgMenuInstanceController:: |
public | function | Provides the menu link creation form. | |
OgMenuInstanceController:: |
public | function | Access callback for the "add link" route. | |
OgMenuInstanceController:: |
public static | function |
Instantiates a new instance of this class. Overrides ControllerBase:: |
|
OgMenuInstanceController:: |
public | function | Controller for the create menu instance form. | |
OgMenuInstanceController:: |
public | function | Route title callback. | |
OgMenuInstanceController:: |
public | function | Constructs an OgMenuInstanceController object. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |