2015-04-19 16:46:59 +02:00

93 lines
2.4 KiB
PHP

<?php
// $Id: xmlsitemap.api.php,v 1.4 2009/12/23 22:29:16 davereid Exp $
/**
* @file
* Hooks provided by the XML sitemap module.
*
* @ingroup xmlsitemap
*/
/**
* @addtogroup hooks
* @{
*/
/**
* Provide information on the type of links this module provides.
*/
function hook_xmlsitemap_link_info() {
return array(
'mymodule' => array(
'purge' => TRUE, // A boolean if this link type can be purged during a rebuild.
),
);
}
/**
* Retrieve a array of links to include in the sitemap.
*
* @return
* An array of link arrays with the following keys and values:
* - 'type' => The type of link (node, user, kitten, etc.).
* - 'id' => The ID of the link ($node->nid, $user->uid, etc.).
* - 'loc' => The un-aliased Drupal path to the item.
* - 'lastmod' => The UNIX timestmap of when the item was last modified.
* - 'changefreq' => The interval, in seconds, between the last set of changes.
* - 'priority' => An optional priority value between 0.0 and 1.0.
*/
function hook_xmlsitemap_links() {
$links = array();
$links[] = array(
'type' => 'mymodule',
'id' => 1,
'loc' => 'mymodule/menu/path',
'lastmod' => 346245692,
'changefreq' => 4600,
);
return $links;
}
/**
* Provide batch information for hook_xmlsitemap_links().
*
* It is highly recommended that if your module has a lot of items that could
* be sitemap links, that you implement this hook.
*
* All you need to do to implement this hook is add the required $context
* information.
*
* The optional current value will provide the offset parameter to
* hook_xmlsitemap_links() and should get records that are greater than this
* value. The default value is 0.
*
* The max (count) value will allow the batch to know when it is finished. This
* value is required.
*/
function hook_xmlsitemap_links_batch_info() {
return array(
'current' => 0,
// This value is used to start selecting items (WHERE id > current).
'max' => db_query("SELECT COUNT(id) FROM {mymodule}")->fetchField(),
// This should be the total number of items to process.
);
}
/**
* Alter the data of a sitemap link before the link is saved.
*
* @param $link
* An array with the data of the sitemap link.
*/
function hook_xmlsitemap_link_alter(&$link) {
if ($link['type'] == 'mymodule') {
$link['priority'] += 0.5;
}
}
/**
* @} End of "addtogroup hooks".
*/