protected function MenuTreeStorage::doSave

protected MenuTreeStorage::doSave(array $link)

Saves a link without clearing caches.

Parameters

array $link: A definition, according to $definitionFields, for a \Drupal\Core\Menu\MenuLinkInterface plugin.

Return value

array The menu names affected by the save operation. This will be one menu name if the link is saved to the sane menu, or two if it is saved to a new menu.

Throws

\Exception Thrown if the storage back-end does not exist and could not be created.

\Drupal\Component\Plugin\Exception\PluginException Thrown if the definition is invalid, for example, if the specified parent would cause the links children to be moved to greater than the maximum depth.

File

core/lib/Drupal/Core/Menu/MenuTreeStorage.php, line 284

Class

MenuTreeStorage
Provides a menu tree storage using the database.

Namespace

Drupal\Core\Menu

Code

protected function doSave(array $link) {
  $original = $this->loadFull($link['id']);
  // @todo Should we just return here if the link values match the original
  //   values completely?
  //   https://www.drupal.org/node/2302137
  $affected_menus = array();

  $transaction = $this->connection->startTransaction();
  try {
    if ($original) {
      $link['mlid'] = $original['mlid'];
      $link['has_children'] = $original['has_children'];
      $affected_menus[$original['menu_name']] = $original['menu_name'];
    }
    else {
      // Generate a new mlid.
      $options = array('return' => Database::RETURN_INSERT_ID) + $this->options;
      $link['mlid'] = $this->connection->insert($this->table, $options)
        ->fields(array('id' => $link['id'], 'menu_name' => $link['menu_name']))
        ->execute();
    }
    $fields = $this->preSave($link, $original);
    // We may be moving the link to a new menu.
    $affected_menus[$fields['menu_name']] = $fields['menu_name'];
    $query = $this->connection->update($this->table, $this->options);
    $query->condition('mlid', $link['mlid']);
    $query->fields($fields)
      ->execute();
    if ($original) {
      $this->updateParentalStatus($original);
    }
    $this->updateParentalStatus($link);
  }
  catch (\Exception $e) {
    $transaction->rollback();
    throw $e;
  }
  return $affected_menus;
}

© 2001–2016 by the original authors
Licensed under the GNU General Public License, version 2 and later.
Drupal is a registered trademark of Dries Buytaert.
https://api.drupal.org/api/drupal/core!lib!Drupal!Core!Menu!MenuTreeStorage.php/function/MenuTreeStorage::doSave/8.1.x