public function TreeBuilder::buildTree in Token 8
Build a tree array of tokens used for themeing or information.
Parameters
string $token_type: The token type.
array $options: (optional) An associative array of additional options, with the following elements:
- 'flat' (defaults to FALSE): Set to true to generate a flat list of token information. Otherwise, child tokens will be inside the 'children' parameter of a token.
- 'restricted' (defaults to FALSE): Set to true to how restricted tokens.
- 'depth' (defaults to 4): Maximum number of token levels to recurse.
Return value
array The token information constructed in a tree or flat list form depending on $options['flat'].
Overrides TreeBuilderInterface::buildTree
1 call to TreeBuilder::buildTree()
- TreeBuilder::buildRenderable in src/TreeBuilder.php 
- Build a render array with token tree built as per specified options.
File
- src/TreeBuilder.php, line 122 
Class
Namespace
Drupal\tokenCode
public function buildTree($token_type, array $options = []) {
  $options += [
    'restricted' => FALSE,
    'depth' => 4,
    'data' => [],
    'values' => FALSE,
    'flat' => FALSE,
  ];
  // Do not allow past the maximum token information depth.
  $options['depth'] = min($options['depth'], static::MAX_DEPTH);
  // If $token_type is an entity, make sure we are using the actual token type.
  if ($entity_token_type = $this->entityMapper
    ->getTokenTypeForEntityType($token_type)) {
    $token_type = $entity_token_type;
  }
  $langcode = $this->languageManager
    ->getCurrentLanguage()
    ->getId();
  $tree_cid = "token_tree:{$token_type}:{$langcode}:{$options['depth']}";
  // If we do not have this base tree in the static cache, check the cache
  // otherwise generate and store it in the cache.
  if (!isset($this->builtTrees[$tree_cid])) {
    if ($cache = $this->cacheBackend
      ->get($tree_cid)) {
      $this->builtTrees[$tree_cid] = $cache->data;
    }
    else {
      $options['parents'] = [];
      $this->builtTrees[$tree_cid] = $this
        ->getTokenData($token_type, $options);
      $this->cacheBackend
        ->set($tree_cid, $this->builtTrees[$tree_cid], Cache::PERMANENT, [
        Token::TOKEN_INFO_CACHE_TAG,
      ]);
    }
  }
  $tree = $this->builtTrees[$tree_cid];
  // If the user has requested a flat tree, convert it.
  if (!empty($options['flat'])) {
    $tree = $this
      ->flattenTree($tree);
  }
  // Fill in token values.
  if (!empty($options['values'])) {
    $token_values = [];
    foreach ($tree as $token => $token_info) {
      if (!empty($token_info['dynamic']) || !empty($token_info['restricted'])) {
        continue;
      }
      elseif (!isset($token_info['value'])) {
        $token_values[$token_info['token']] = $token;
      }
    }
    if (!empty($token_values)) {
      $token_values = $this->tokenService
        ->generate($token_type, $token_values, $options['data'], [], new BubbleableMetadata());
      foreach ($token_values as $token => $replacement) {
        $tree[$token]['value'] = $replacement;
      }
    }
  }
  return $tree;
}