t('Meta tags'), 'description' => t('Generated by the Metatag module, may not be used to fill in other meta tags.'), ); $metatag_info = metatag_get_info(); foreach ($metatag_info['tags'] as $value) { if (isset($value['group'], $metatag_info['groups'][$value['group']], $metatag_info['groups'][$value['group']]['label'])) { $label = $metatag_info['groups'][$value['group']]['label'] . ': ' . $value['label']; } else { $label = t('Basic tags') . ': ' . $value['label']; } $info['tokens']['metatag'][$value['name']] = array( 'name' => $label, 'description' => isset($value['description']) ? $value['description'] : '', ); } if (module_exists('taxonomy')) { $info['tokens']['term']['metatag'] = array( 'name' => t('Meta tags'), 'description' => t('Meta tags for this taxonomy term.'), 'type' => 'metatag', ); } if (module_exists('node')) { $info['tokens']['node']['metatag'] = array( 'name' => t('Meta tags'), 'description' => t('Meta tags for this node.'), 'type' => 'metatag', ); } if (module_exists('user')) { $info['tokens']['user']['metatag'] = array( 'name' => t('Meta tags'), 'description' => t('Meta tags for this user.'), 'type' => 'metatag', ); } // A custom pager. $pager = variable_get('metatag_pager_string', 'Page PAGER | '); $page = str_replace('PAGER', 12, $pager); $info['tokens']['current-page']['pager'] = array( 'name' => t('Custom pager'), 'description' => t('A custom pager (from the Metatag module). Currently set to "@pager" which would be output as e.g. "@page".', array('@pager' => $pager, '@page' => $page)), ); // Custom summary tokens for each long text field. $supported_types = array('text_long', 'text_with_summary'); if (variable_get('metatag_summary_text_field', FALSE)) { $supported_types[] = 'text'; } $trim_length = variable_get('metatag_summary_length', 200); foreach (field_read_fields() as $field_name => $field) { if (!empty($field['module'])) { if (in_array($field['type'], $supported_types)) { $instances = field_read_instances(array('field_name' => $field_name)); foreach ($instances as $instance) { if (!empty($instance['entity_type']) && !empty($instance['label'])) { $info['tokens'][$instance['entity_type']][$field_name . '-summary'] = array( 'name' => t('@label (summary)', array('@label' => $instance['label'])), 'description' => t('A summary of the @label field, trimmed to @length characters.', array('@label' => $instance['label'], '@length' => $trim_length)), ); } } } } } return $info; } /** * Implements hook_tokens(). */ function metatag_tokens($type, $tokens, array $data = array(), array $options = array()) { $replacements = array(); $sanitize = !empty($options['sanitize']); // Metatag tokens. if ($type == 'metatag' && !empty($data['metatag'])) { $metatag = $data['metatag']; foreach ($tokens as $name => $original) { if (isset($metatag[$name])) { $replacements[$original] = $sanitize ? filter_xss($metatag[$name]) : $metatag[$name]; } } } // Token tokens. if ($type == 'term' && !empty($data['term'])) { $term = $data['term']; if ($metatag_tokens = token_find_with_prefix($tokens, 'metatag')) { $result = metatag_token_generate_array($term, 'taxonomy_term', $term->vocabulary_machine_name); $replacements += token_generate('metatag', $metatag_tokens, array('metatag' => $result), $options); } } // Node tokens. if ($type == 'node' && !empty($data['node'])) { $node = $data['node']; if ($metatag_tokens = token_find_with_prefix($tokens, 'metatag')) { $result = metatag_token_generate_array($node, 'node', $node->type); $replacements += token_generate('metatag', $metatag_tokens, array('metatag' => $result), $options); } } // User tokens. if ($type == 'user' && !empty($data['user'])) { $account = $data['user']; if ($metatag_tokens = token_find_with_prefix($tokens, 'metatag')) { $result = metatag_token_generate_array($account, 'user', 'user'); $replacements += token_generate('metatag', $metatag_tokens, array('metatag' => $result), $options); } } // Custom pager. if ($type == 'current-page') { foreach ($tokens as $name => $original) { switch ($name) { case 'pager': $pager = metatag_get_current_pager(); if (!empty($pager)) { $replacements[$original] = $pager; } break; } } } // Summary tokens. It is safe to rely upon an "entity" token type here because // it is added by the Token module. if ($type == 'entity' && isset($options['entity'], $options['entity_type'])) { $trim_length = variable_get('metatag_summary_length', 200); foreach ($tokens as $name => $original) { if (substr($name, -8) == '-summary') { // The field name is the token name minus "-summary". $field_name = substr($name, 0, -8); // Work out the requested language, if appropriate. if (isset($options['language'])) { $language_code = $options['language']->language; } else { $language_code = NULL; } $entity = $options['entity']; $entity_type = $options['entity_type']; list($entity_id, $revision_id, $bundle) = entity_extract_ids($entity_type, $entity); $items = field_get_items($entity_type, $entity, $field_name, $language_code); if (!empty($items)) { $instance = field_info_instance($entity_type, $field_name, $bundle); $field_langcode = field_language($entity_type, $entity, $field_name, $language_code); // If the summary was filled in it is not empty, use it. if (!empty($items[0]['summary'])) { $output = $sanitize ? _text_sanitize($instance, $field_langcode, $items[0], 'summary') : $items[0]['summary']; } // Attempt to provide a suitable version of the 'body' field. else { $output = $sanitize ? _text_sanitize($instance, $field_langcode, $items[0], 'value') : $items[0]['value']; } if (!empty($output)) { // Trim the summary. $output = text_summary($output, $instance['settings']['text_processing'] ? $items[0]['format'] : NULL, $trim_length); if (!empty($output)) { $replacements[$original] = $output; } } } } } } return $replacements; } /** * Generate an array of meta tags for a given entity. */ function metatag_token_generate_array($entity, $entity_type, $bundle) { if (metatag_entity_supports_metatags($entity_type, $bundle)) { $token_type = token_get_entity_mapping('entity', $entity_type); $instance = metatag_get_entity_metatags_instance($entity, $entity_type, $bundle); $options = array(); $options['token data'][$token_type] = $entity; $options['entity'] = $entity; $metatags = array(); if (!empty($entity->metatags)) { $language = metatag_entity_get_language($entity_type, $entity); if (!empty($entity->metatags[$language])) { $metatags = $entity->metatags[$language]; } } $metatags += metatag_config_load_with_defaults($instance); // Process it for entity metatag replacement to avoid infinite recursion. $metatags = _metatag_token_process_metatag($metatags, $token_type); $result = array(); foreach ($metatags as $metatag => $data) { if ($metatag_instance = metatag_get_instance($metatag, $data)) { $result[$metatag] = $metatag_instance->getValue($options); } } return $result; } return NULL; } /** * Loop through metatags to avoid recursion on entity tokens. It will replace * entity metatag token to its actual entity metatag field value. * * @param array $metatags * An array of entity metatag tokens. * @param string $token_type * The entity token type, such as 'node' or 'term'. * * @return array * Return metatags array with entity metatag tokens replaced. */ function _metatag_token_process_metatag($metatags, $token_type) { foreach ($metatags as $metatag => $data) { // Skip values that are not strings. if (!is_string($data['value'])) { continue; } // Explode all metatag token in field. $data_tokens = token_scan($data['value']); if (isset($data_tokens[$token_type])) { foreach ($data_tokens[$token_type] as $key => $value) { $metatag_parts = explode(':', $key); // Check entity metatag token. Like [:metatag:]. if ($metatag_parts[0] == 'metatag') { $entity_field = implode(':', array_slice($metatag_parts, 1)); // If a value is not set here it will trigger an infinite loop. $metatags[$metatag]['value'] = ''; // If the meta tag was defined then try parsing it. if (!empty($metatags[$entity_field]['value'])) { // Entity metatag field may contain other entity metatag token // that need to be replaced too. $replaced_value = metatag_token_entitymetatagtoken_replace($metatags, $metatags[$entity_field]['value'], $token_type); $metatags[$metatag]['value'] = str_replace($value, $replaced_value, $metatags[$metatag]['value']); } } } } } return $metatags; } /** * Replace entity metatag token with actual entity metatag field value. * * @param array $metatags * An array entity metatag tokens. * @param string $token * A token to be replaced. * @param string $token_type * The entity token type, such as 'node' or 'term'. * @param array $search_tokens * An array of tokens to search for. * @param array $replace_tokens * An array of tokens to be replaced. * * @return string * The replaced value of $token. */ function metatag_token_entitymetatagtoken_replace($metatags, $token, $token_type, $search_tokens = array(), $replace_tokens = array()) { $data_tokens = token_scan($token); // Check field has tokens. if (isset($data_tokens[$token_type])) { // Go through each token in field and find entity metatag tokens. foreach ($data_tokens[$token_type] as $key => $value) { $metatag_parts = explode(':', $key); if ($metatag_parts[0] == 'metatag' && !in_array($value, $search_tokens)) { // Entity metatag field value. $entity_field = implode(':', array_slice($metatag_parts, 1)); $replaced_value = metatag_token_entitymetatagtoken_replace($metatags, $metatags[$entity_field]['value'], $token_type, $replace_tokens, $search_tokens); $replace_tokens[] = $replaced_value; $search_tokens[] = $value; } } return str_replace($search_tokens, $replace_tokens, $token); } else { return $token; } }