You are here

metatag.api.php in Metatag 7

Same filename and directory in other branches
  1. 8 metatag.api.php

API documentation for the Metatag module.

File

metatag.api.php
View source
<?php

/**
 * @file
 * API documentation for the Metatag module.
 */

/**
 * Provides a default configuration for Metatag intances.
 *
 * This hook allows modules to provide their own Metatag instances which can
 * either be used as-is or as a "starter" for users to build from.
 *
 * This hook should be placed in MODULENAME.metatag.inc and it will be auto-
 * loaded. MODULENAME.metatag.inc *must* be in the same directory as the
 * .module file which *must* also contain an implementation of
 * hook_ctools_plugin_api, preferably with the same code as found in
 * metatag_ctools_plugin_api().
 *
 * The $config->disabled boolean attribute indicates whether the Metatag
 * instance should be enabled (FALSE) or disabled (TRUE) by default.
 *
 * @return array
 *   An associative array containing the structures of Metatag instances, as
 *   generated from the Export tab, keyed by the Metatag config name.
 *
 * @see metatag_metatag_config_default()
 * @see metatag_ctools_plugin_api()
 */
function hook_metatag_config_default() {
  $configs = array();
  $config = new stdClass();
  $config->instance = 'config1';
  $config->api_version = 1;
  $config->disabled = FALSE;
  $config->config = array(
    'title' => array(
      'value' => '[current-page:title] | [site:name]',
    ),
    'generator' => array(
      'value' => 'Drupal 7 (https://www.drupal.org)',
    ),
    'canonical' => array(
      'value' => '[current-page:url:absolute]',
    ),
    'shortlink' => array(
      'value' => '[current-page:url:unaliased]',
    ),
  );
  $configs[$config->instance] = $config;
  $config = new stdClass();
  $config->instance = 'config2';
  $config->api_version = 1;
  $config->disabled = FALSE;
  $config->config = array(
    'title' => array(
      'value' => '[user:name] | [site:name]',
    ),
  );
  $configs[$config->instance] = $config;
  return $configs;
}

/**
 * Allow the exported configurations to be changed prior to being cached.
 */
function hook_metatag_config_default_alter(&$config) {
}

/**
 * Internal hook for adding further configuration values in bundled submodules.
 *
 * The defaults provided by the main Metatag module need to be extended by the
 * bundled submodules before they are presented to other modules for altering
 * via hook_metatag_config_default_alter(), in case differences in module
 * weights and loading priorities cause the submodules' settings to run after
 * those of any custom modules.
 *
 * @see hook_metatag_config_default()
 * @see hook_metatag_config_default_alter()
 */
function hook_metatag_bundled_config_alter(&$config) {
}

/**
 * Allow modules to act upon the record insertion.
 */
function hook_metatag_config_instance_info() {
  return array();
}

/**
 * Alter record insertion provided by modules with the previous hook.
 *
 * @see hook_metatag_config_instance_info()
 */
function hook_metatag_config_instance_info_alter(&$info) {
}

/**
 * Allow the Metatag config instance name to be changed.
 *
 * By default, Metatag module define config instance per entity bundle, making
 * it impossible to store set of meta tags based on other criteria. Combining
 * this hook with hook_metatag_config_instance_info_alter() it is possible to
 * alter the logic of how instances are named based on any custom criteria.
 *
 * @param string $instance
 *   The name of the instance generated by default.
 * @param object $entity
 *   The entity object to generate the Metatag instance name for.
 * @param string $entity_type
 *   The entity type of the entity.
 * @param string $bundle
 *   The bundle of the entity.
 */
function hook_metatag_get_entity_metatags_instance_alter(&$instance, $entity, $entity_type, $bundle) {
  if ($entity_type == 'user') {

    // Split config instances based on user roles.
    foreach (array_reverse(user_roles(), TRUE) as $rid => $role) {
      if ($rid == DRUPAL_AUTHENTICATED_RID) {
        continue;
      }
      if (isset($entity->roles[$rid])) {
        $instance = 'user:' . $role;
        break;
      }
    }
  }
}

/**
 * Never triggered?
 *
 * @todo Confirm whether this still exists.
 */
function hook_metatag_config_load() {
}

/**
 * Never triggered?
 *
 * @todo Confirm whether this still exists.
 */
function hook_metatag_config_load_presave() {
}

/**
 * Allow a Metatag configuration to be modified prior to being saved.
 *
 * @param object $config
 *   The configuration object that is about to be saved.
 */
function hook_metatag_config_presave($config) {
}

/**
 * Triggered when a Metatag configuration is created.
 *
 * @param object $config
 *   The configuration object that was created.
 */
function hook_metatag_config_insert($config) {
}

/**
 * Triggered when a Metatag configuration is updated.
 *
 * @param object $config
 *   The configuration object that was modified.
 */
function hook_metatag_config_update($config) {
}

/**
 * Triggered when a Metatag configuration is removed.
 *
 * @param object $config
 *   The name of the configuration object that was removed.
 */
function hook_metatag_config_delete($config) {
}

/**
 * Definition of the meta tags and groups.
 *
 * @return array
 *   A nested array of 'tags' and 'groups', each keyed off the machine name for
 *   their respective structure type, with the following values:
 *   Tags:
 *     'label' - The name for this meta tag.
 *     'description' - An explanation of what this meta tag is used for and what
 *       values are permissible.
 *     'class' - The class name that controls this meta tag.
 *     'weight' - Used to sort the meta tags during output.
 *     'group' - The machine name of a group this meta tag will be contained
 *       within.
 *     'context' - Optionally control the type of configuration the meta tag
 *       will be available from. Possible values are:
 *       [empty] - All meta tags apply to all possible objects, by default.
 *       'global' - This will make it only show in the global meta tag
 *         configuration form.
 *       [entity type] - Makes the meta tag only show for specific entity types.
 *     'header' - Optionally output the meta tag as an HTTP header value.
 *     'element' - Optional attributes for rendering the meta tag. Should
 *       contain the following:
 *       '#theme' - The theming function used to render the meta tag.
 *     'replaces' - An optional array of meta tags that this meta tag replaces.
 *       Used to indicate that these deprecated meta tags will be replaced by
 *       this newer one, their values will be used, upon the next object save
 *       the deprecated tag will be entirely replaced by the new meta tag. While
 *       one meta tag can replace several others, only one of the possible
 *       values will be used, the others will be silently purged upon the next
 *       configuration/object save.
 *     'multiple' - If set to TRUE the output will be comma-separated and output
 *       as multiple tags.
 *     'image' - If set to TRUE some additional effort will be added to attempt
 *       extracting image URLs from the value. Currently limited to matching
 *       the default output of core image theming, i.e. the following string:
 *         src="[URL]" width=
 *     'url' - If set to TRUE, relative paths will be converted to absolute.
 *     'is_language' - If set to TRUE, will not allow the Drupal default
 *       language value "und" to be output.
 *     'maxlength' - If set to a numeric value, meta tag values will be trimmed
 *       to this limit, which may be overridden via the settings page. Note: any
 *       meta tags with this value assigned can have its maxlength controlled,
 *       so setting the attribute to an empty string will allow site builders to
 *       adjust the meta tag lengths as needed.
 *     'select_or_other' - If set to TRUE, form[#type] is set to 'select' and
 *       the "select_or_other" module is available, that module will be used to
 *       provide a text field to manually insert another option.
 *     'form' - Optional items to be passed directly to the form; uses standard
 *       Form API values.
 *     'devel_generate' - Optional values to be passed to the Devel Generate
 *       submodule. Should be an array containing one of the following values:
 *       'type' - One of the following:
 *         'canonical' - The token for the absolute URL for the current page.
 *         'email' - An email address randomly generated at the site's hostname.
 *         'float' - A random floating point number between 0.0 and 999.999.
 *         'image' - A randomly generated image.
 *         'integer' - A random integer between 0 and 999.
 *         'phone' - A phone number in the format 999-999-9999.
 *         'select' - A value randomly selected from the available form options.
 *         'text' - Random text string.
 *         'twitter' - A Twitter username.
 *         'url' - A randomly generated URL on this site.
 *       'maxlength' - The maximum length / number of iterations of this value,
 *         defaults to 10.
 *     'dependencies' - Optional nested array of values to indicate other meta
 *       tags that must be present in order for this meta tag to be visible. See
 *       The Open Graph and Twitter Cards submodules for example usage. Each
 *       dependency must contain the following elements:
 *       'dependency' - The name of the meta tag that is required.
 *       'attribute' - The name of the other meta tag that is to be checked,
 *         most meta tags use "value" as the attribute name.
 *       'condition' - The state condition to be checked against, e.g. "filled"
 *         to check text values, "checked" for a checkbox, "value" to compare
 *         the raw selection; see https://api.drupal.org/drupal_process_states
 *         for more details.
 *       'value' - The field value to check the 'condition' against. see
 *         https://api.drupal.org/drupal_process_states for further details.
 *   Groups:
 *     'label' - The name for this group.
 *     'description' - A detailed explanation of these meta tags.
 *     'form' - Additional items to be passed directly to the form.
 *   Note: 'label', 'description', and any text strings passed in 'form', should
 *   be translated.
 *
 * @see metatag_metatag_info()
 */
function hook_metatag_info() {
  return array();
}

/**
 * Alter record insertion provided by modules with the previous hook.
 *
 * @see hook_metatag_info()
 */
function hook_metatag_info_alter(&$info) {
}

/**
 * Alter raw metatags before being cached.
 *
 * This hook is invoked prior to the meta tags for a given page are converted to
 * a render array and cached.
 *
 * @param array $metatags
 *   All of the meta tags to be output for this page in their raw format, keyed
 *   by tag name. Each tag is an array with a "value" field to hold the
 *   respective value or values.
 * @param string $instance
 *   An identifier for the current page's page type, typically a combination
 *   of the entity name and bundle name, e.g. "node:story".
 * @param array $options
 *   All of the options used to generate the meta tags.
 */
function hook_metatag_metatags_alter(array &$metatags, $instance, array $options) {
  if (isset($metatags['description']['value'])) {
    $metatags['description']['value'] = '0 rly?';
  }
}

/**
 * Alter metatags before being cached.
 *
 * This hook is invoked prior to the meta tags for a given page are cached.
 *
 * @param array $output
 *   All of the meta tags to be output for this page in their render format.
 *   This is a heavily nested array.
 * @param string $instance
 *   An identifier for the current page's page type, typically a combination
 *   of the entity name and bundle name, e.g. "node:story".
 * @param array $options
 *   All of the options used to generate the meta tags.
 */
function hook_metatag_metatags_view_alter(array &$output, $instance, array $options) {
  if (isset($output['description']['#attached']['drupal_add_html_head'][0][0]['#value'])) {
    $output['description']['#attached']['drupal_add_html_head'][0][0]['#value'] = 'O rly?';
  }
}

/**
 * Allow other modules to customize the data to generate the cache ID.
 *
 * @param array $cid_parts
 *   The identifiers used to identify this cache object.
 */
function hook_metatag_page_cache_cid_parts_alter(array &$cid_parts) {
}

/**
 * Allow other modules to alter the meta tags prior to saving.
 *
 * @param array $metatags
 *   The meta tags being saved for this entity.
 * @param string $entity_type
 *   The type of entity being saved.
 * @param int $entity_id
 *   The ID of the entity being saved.
 * @param int $revision_id
 *   The revision ID of the entity being saved.
 * @param string $langcode
 *   The language code for the entity being saved.
 */
function hook_metatag_presave(array &$metatags, $entity_type, $entity_id, $revision_id, $langcode) {
}

/**
 * Allows modules to alter the list of tokens available for replacement.
 *
 * By default only context (for example: global, node, etc...) related tokens
 * are made available to metatag patterns replacements. This hook allows other
 * modules to extend the default declared tokens.
 *
 * @param array $options
 *   (optional) An array of options including the following keys and values:
 *   - token types: An array of token types to be passed to theme_token_tree().
 *   - context: An identifier for the configuration instance type, typically
 *     an entity name or object name, e.g. node, views, taxonomy_term.
 *
 * @see metatag_config_edit_form()
 * @see metatag_field_attach_form()
 */
function hook_metatag_token_types_alter(array &$options) {

  // Watchout: $options['token types'] might be empty.
  if (!isset($options['token types'])) {
    $options['token types'] = array();
  }
  if ($options['context'] == 'config1') {
    $options['token types'] += array(
      'token_type1',
      'token_type2',
    );
  }
  elseif ($options['context'] == 'config2') {
    $options['token types'] += array(
      'token_type3',
      'token_type4',
    );
  }
}

/**
 * Allows modules to alter defined token patterns and values before replacement.
 *
 * The metatag module defines default token patterns replacements depending on
 * the different configuration instances (contexts, such as global, node, ...).
 * This hook provides an opportunity for other modules to alter the patterns or
 * the values for replacements, before tokens are replaced (token_replace).
 *
 * See facetapi and facetapi_bonus modules for an example of implementation.
 *
 * @param string $pattern
 *   A string potentially containing replaceable tokens. The pattern could also
 *   be altered by reference, allowing modules to implement further logic, such
 *   as tokens lists or masks/filters.
 * @param array $types
 *   Corresponds to the 'token data' property of the $options object.
 *   (optional) An array of keyed objects. For simple replacement scenarios
 *   'node', 'user', and others are common keys, with an accompanying node or
 *   user object being the value. Some token types, like 'site', do not require
 *   any explicit information from $data and can be replaced even if it is
 *   empty.
 * @param string $tag_name
 *   The name of the meta tag being altered.
 *
 * @see DrupalTextMetaTag::getValue()
 */
function hook_metatag_pattern_alter(&$pattern, array &$types, $tag_name) {
  if (strpos($pattern, 'token_type1') !== FALSE) {
    $types['token_type1'] = "data to be used in hook_tokens for replacement";
  }
  if (strpos($pattern, 'token_type2') !== FALSE) {

    // Load something or do some operations.
    $types['token_type2'] = array(
      "Then fill in the array with the right data",
    );

    // $pattern could also be altered, for example, strip off [token_type3].
    $pattern = str_replace('[token_type3]', '', $pattern);
  }
}

/**
 * Allow modules to override whether entity types are enabled for use.
 *
 * By default the system only support entities that are not configuration
 * entities, have multiple view modes (excluding those created by the ical,
 * diff and token modules), are fieldable, and are not one of the following:
 * - field_collection_item (from the Field Collection module)
 * - paragraphs_item (from the Paragraphs module)
 *
 * @param bool $suitable
 *   Whether or not the entity type is enabled for use with Metatag.
 * @param string $entity_type
 *   The machine name of the entity type.
 * @param array $entity_info
 *   The full specifications for this entity type, as returned by
 *   entity_get_info().
 */
function hook_metatag_entity_type_is_supported_alter(&$suitable, $entity_type, array $entity_info) {

  // Enable Metatag support for a custom entity that might otherwise be
  // ignored, e.g. it doesn't allow fields.
  if ($entity_type == 'my_entity') {
    $suitable = TRUE;
  }
}

/**
 * Identify the entity type provided by a specific view.
 *
 * When a view is used to display a page it can be difficult to identify what
 * entity type is being managed. Use this hook to inform Metatag what type of
 * entity is being displayed.
 *
 * @param object $view
 *   The view object being displayed.
 *
 * @return string|null
 *   Should return a string indicating an entity type that will be paired with
 *   the views' first argument ($view->args[0]) to load that entity.
 */
function hook_metatag_views_post_render_get_entity($view) {
  $display = $view->display[$view->current_display];
  if ($display->display_options['path'] == 'coolpage/%') {
    return 'my_entity';
  }
}

/**
 * Allow the context string passed to i18n_string to be changed before use.
 *
 * If the string is set to an empty value it will cause this meta tag to not
 * be translated.
 *
 * @param string $context
 *   The context string being passed into i18n_string. Will usually be in the
 *   format "[category]:[path-identifier]", e.g. "[node:123]", "[page:contact]",
 *   etc.
 * @param string $tag_name
 *   The name of the meta tag being translated.
 */
function hook_metatag_i18n_context_alter(&$context, $tag_name) {

  // Don't bother translating the canonical URL.
  if ($tag_name == 'canonical') {
    $context = '';
  }
}

/**
 * Allow modules to overide the expiration of metatag caches.
 *
 * By default Metatag caches everything as CACHE_PERMANENT, this alter allows to
 * change that.
 *
 * @param int $expire
 *   The expire value to change.
 * @param string $cid
 *   The cid about to be cached.
 * @param array $data
 *   The data to be cached.
 */
function hook_metatag_cache_set_expire_alter(&$expire, $cid, array $data) {
  $expire = CACHE_TEMPORARY;
}

Functions

Namesort descending Description
hook_metatag_bundled_config_alter Internal hook for adding further configuration values in bundled submodules.
hook_metatag_cache_set_expire_alter Allow modules to overide the expiration of metatag caches.
hook_metatag_config_default Provides a default configuration for Metatag intances.
hook_metatag_config_default_alter Allow the exported configurations to be changed prior to being cached.
hook_metatag_config_delete Triggered when a Metatag configuration is removed.
hook_metatag_config_insert Triggered when a Metatag configuration is created.
hook_metatag_config_instance_info Allow modules to act upon the record insertion.
hook_metatag_config_instance_info_alter Alter record insertion provided by modules with the previous hook.
hook_metatag_config_load Never triggered?
hook_metatag_config_load_presave Never triggered?
hook_metatag_config_presave Allow a Metatag configuration to be modified prior to being saved.
hook_metatag_config_update Triggered when a Metatag configuration is updated.
hook_metatag_entity_type_is_supported_alter Allow modules to override whether entity types are enabled for use.
hook_metatag_get_entity_metatags_instance_alter Allow the Metatag config instance name to be changed.
hook_metatag_i18n_context_alter Allow the context string passed to i18n_string to be changed before use.
hook_metatag_info Definition of the meta tags and groups.
hook_metatag_info_alter Alter record insertion provided by modules with the previous hook.
hook_metatag_metatags_alter Alter raw metatags before being cached.
hook_metatag_metatags_view_alter Alter metatags before being cached.
hook_metatag_page_cache_cid_parts_alter Allow other modules to customize the data to generate the cache ID.
hook_metatag_pattern_alter Allows modules to alter defined token patterns and values before replacement.
hook_metatag_presave Allow other modules to alter the meta tags prior to saving.
hook_metatag_token_types_alter Allows modules to alter the list of tokens available for replacement.
hook_metatag_views_post_render_get_entity Identify the entity type provided by a specific view.