AccountSwitcherInterface.php

Same filename and directory in other branches
  1. 8.9.x core/lib/Drupal/Core/Session/AccountSwitcherInterface.php
  2. 10 core/lib/Drupal/Core/Session/AccountSwitcherInterface.php
  3. 11.x core/lib/Drupal/Core/Session/AccountSwitcherInterface.php

Namespace

Drupal\Core\Session

File

core/lib/Drupal/Core/Session/AccountSwitcherInterface.php

View source
<?php

namespace Drupal\Core\Session;


/**
 * Defines an interface for a service for safe account switching.
 *
 * @ingroup user_api
 */
interface AccountSwitcherInterface {
    
    /**
     * Safely switches to another account.
     *
     * Each invocation of AccountSwitcherInterface::switchTo() must be
     * matched by a corresponding invocation of
     * AccountSwitcherInterface::switchBack() in the same function.
     *
     * @param \Drupal\Core\Session\AccountInterface $account
     *   The account to switch to.
     *
     * @return $this
     *   $this.
     */
    public function switchTo(AccountInterface $account);
    
    /**
     * Reverts to a previous account after switching.
     *
     * @return $this
     *   $this.
     *
     * @throws \RuntimeException
     *   When there are no more account switches to revert.
     */
    public function switchBack();

}

Interfaces

Title Deprecated Summary
AccountSwitcherInterface Defines an interface for a service for safe account switching.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.