Bachir Soussi Chiadmi b3221c71e2 security updates
have to check views and entityreference for custom patches
2015-04-19 20:45:16 +02:00

360 lines
9.9 KiB
Plaintext

<?php
/**
* @file
* Displays Printer-friendly versions of Drupal pages.
*
* This is the core module of the PF package, with the Drupal hooks
* and other administrative functions.
*
* @ingroup print
*/
define('PRINT_VIEW_MODE', 'print');
define('PRINT_LOGO_OPTIONS_DEFAULT', 1);
define('PRINT_LOGO_URL_DEFAULT', '');
define('PRINT_FOOTER_OPTIONS_DEFAULT', 1);
define('PRINT_FOOTER_USER_DEFAULT', '');
define('PRINT_CSS_DEFAULT', '');
define('PRINT_KEEP_THEME_CSS_DEFAULT', 0);
define('PRINT_URLS_DEFAULT', 1);
define('PRINT_URLS_ANCHORS_DEFAULT', 0);
define('PRINT_COMMENTS_DEFAULT', 0);
define('PRINT_NEWWINDOW_DEFAULT', 1);
define('PRINT_TYPE_URLLIST_DEFAULT', 1);
define('PRINT_TYPE_SYS_URLLIST_DEFAULT', 0);
define('PRINT_TYPE_LINK_TEXT_ENABLED_DEFAULT', 0);
define('PRINT_HTML_NEW_WINDOW_DEFAULT', 0);
define('PRINT_HTML_SENDTOPRINTER_DEFAULT', 0);
define('PRINT_HTML_WINDOWCLOSE_DEFAULT', 1);
define('PRINT_SOURCEURL_ENABLED_DEFAULT', 1);
define('PRINT_SOURCEURL_DATE_DEFAULT', 0);
define('PRINT_SOURCEURL_FORCENODE_DEFAULT', 0);
define('PRINT_ROBOTS_NOINDEX_DEFAULT', 1);
define('PRINT_ROBOTS_NOFOLLOW_DEFAULT', 1);
define('PRINT_ROBOTS_NOARCHIVE_DEFAULT', 0);
define('PRINT_LIB_PATH', 'sites/all/libraries');
/**
* Implements hook_print_link().
*/
function print_print_link() {
return array(
'format' => 'html',
'text' => t('Printer-friendly version'),
'description' => t('Display a printer-friendly version of this page.'),
'path' => 'print',
'class' => 'print-page',
'icon' => 'print_icon.png',
'module' => 'print',
);
}
/**
* Implements hook_print_new_window_alter().
*/
function print_print_new_window_alter(&$new_window, $format) {
$new_window = variable_get('print_html_new_window', PRINT_HTML_NEW_WINDOW_DEFAULT);
}
/**
* Implements hook_permission().
*/
function print_permission() {
return array(
'administer print' => array(
'title' => t('Administer the module'),
'description' => t('Perform maintenance tasks for the print module.'),
),
'access print' => array(
'title' => t('Access the printer-friendly page'),
'description' => t('View the printer-friendly pages and the links to them in the original pages.'),
),
);
}
/**
* Implements hook_theme().
*/
function print_theme() {
return array(
'print' => array(
'variables' => array('node' => NULL, 'query' => NULL, 'format' => '', 'expand_css' => FALSE, 'message' => ''),
'template' => 'print',
'file' => 'print.pages.inc',
),
'print_published' => array(
'variables' => array(),
'file' => 'print.pages.inc',
),
'print_breadcrumb' => array(
'variables' => array('node' => NULL),
'file' => 'print.pages.inc',
),
'print_footer' => array(
'variables' => array(),
'file' => 'print.pages.inc',
),
'print_sourceurl' => array(
'variables' => array('url' => '', 'node' => NULL, 'cid' => NULL),
'file' => 'print.pages.inc',
),
'print_url_list' => array(
'variables' => array(),
'file' => 'print.pages.inc',
),
);
}
/**
* Implements hook_preprocess_HOOK().
*/
function print_preprocess_node(&$variables) {
if (($variables['elements']['#view_mode'] == PRINT_VIEW_MODE) && isset($variables['elements']['#print_format'])) {
$type = $variables['elements']['#node']->type;
$format = $variables['elements']['#print_format'];
$nid = $variables['elements']['#node']->nid;
$variables['theme_hook_suggestions'][] = "node__print";
$variables['theme_hook_suggestions'][] = "node__print__{$format}";
$variables['theme_hook_suggestions'][] = "node__print__{$format}__node__{$type}";
$variables['theme_hook_suggestions'][] = "node__print__{$format}__node__{$nid}";
}
}
/**
* Implements hook_menu().
*/
function print_menu() {
$link = print_print_link();
$items = array();
$items[$link['path']] = array(
'title' => 'Printer-friendly',
'page callback' => 'print_controller_html',
'access arguments' => array('access print'),
'type' => MENU_CALLBACK,
'file' => 'print.pages.inc',
);
$items[$link['path'] . '/' . $link['path']] = array(
'access callback' => FALSE,
);
$items['admin/config/user-interface/print'] = array(
'title' => 'Printer, email and PDF versions',
'description' => 'Adds a printer-friendly version link to content and administrative pages.',
'page callback' => 'drupal_get_form',
'page arguments' => array('print_html_settings'),
'access arguments' => array('administer print'),
'file' => 'print.admin.inc',
);
$items['admin/config/user-interface/print/html'] = array(
'title' => 'Web page',
'weight' => 1,
'type' => MENU_DEFAULT_LOCAL_TASK,
);
$items['admin/config/user-interface/print/common'] = array(
'title' => 'Settings',
'description' => 'Settings for the common functionalities for all the print sub-modules.',
'page callback' => 'drupal_get_form',
'page arguments' => array('print_main_settings'),
'access arguments' => array('administer print'),
'weight' => 10,
'type' => MENU_LOCAL_TASK,
'file' => 'print.admin.inc',
);
return $items;
}
/**
* Implements hook_variable_info().
*/
function print_variable_info($options) {
$link = print_print_link();
$variable['print_html_link_text'] = array(
'title' => t('Printer-friendly version'),
'description' => t('Text used in the link to the printer-friendly version.'),
'type' => 'string',
'default' => t($link['text']),
);
return $variable;
}
/**
* Implements hook_block_info().
*/
function print_block_info() {
$block['print-top']['info'] = t('Most printed');
$block['print-top']['cache'] = DRUPAL_CACHE_GLOBAL;
return $block;
}
/**
* Implements hook_block_view().
*/
function print_block_view($delta = '') {
$block = array();
switch ($delta) {
case 'print-top':
$block['subject'] = t('Most printed');
$result = db_query_range("SELECT path FROM {print_page_counter} LEFT JOIN {node} n ON path = CONCAT('node/', n.nid) WHERE status <> 0 OR status IS NULL ORDER BY totalcount DESC", 0, 3)
->fetchAll();
if (count($result)) {
$items = array();
foreach ($result as $obj) {
$items[] = l(_print_get_title($obj->path), $obj->path);
}
$block['content'] = theme('item_list', array('items' => $items, 'type' => 'ul'));
}
break;
}
return $block;
}
/**
* Implements hook_help().
*/
function print_help($path, $arg) {
switch ($path) {
case 'admin/help#print':
// Return a line-break version of the module README
return _filter_autop(file_get_contents(drupal_get_path('module', 'print') . '/README.txt'));
}
}
/**
* Implements hook_node_delete().
*/
function print_node_delete($node) {
db_delete('print_page_counter')
->condition('path', 'node/' . $node->nid)
->execute();
}
/**
* Implements hook_entity_info_alter().
*/
function print_entity_info_alter(&$info) {
// Add the 'Print' view mode for nodes.
$info['node']['view modes'] += array(
PRINT_VIEW_MODE => array(
'label' => t('Print'),
'custom settings' => FALSE,
),
);
// Add the 'Print' view mode for field_collections
if (module_exists('field_collection')) {
$info['field_collection_item']['view modes'] += array(
PRINT_VIEW_MODE => array(
'label' => t('Print'),
'custom settings' => FALSE,
),
);
}
}
/**
* Auxiliary function to discover a given page's title
*
* @param string $path
* path of the page being identified
*
* @return string
* string with the page's title
*/
function _print_get_title($path) {
$path = drupal_get_normal_path($path);
$nid = preg_replace('!^node/!', '', $path);
if (ctype_digit($nid)) {
return db_query("SELECT title FROM {node} WHERE nid = :nid", array(':nid' => $nid))
->fetchField();
}
else {
// Not a node, try to get title from the menu system
$menu_item = menu_get_item($path);
if (!empty($menu_item['title'])) {
return $menu_item['title'];
}
elseif (drupal_substr($menu_item['page_callback'], 0, 6) == 'views_') {
// It's a view, load the view to have access to the title
$view = views_get_view($menu_item['page_arguments']['0']);
return $view->get_title();
}
else {
return NULL;
}
}
}
/**
* Auxiliary function to display a formatted Printer-friendly link
*
* Function made available so that developers may call this function from
* their defined pages/blocks.
*
* @param string $path
* path to be used in the link. If not specified, the current URL is used.
* @param object $node
* node object, to be used in checking node access. If the path argument is
* not provided, the path used will be node/nid.
* @param string $location
* where in the page where the link is being inserted ('link', 'corner',
* 'block', 'help').
*
* @return string
* HTML link to the printer-friendly page
*
* @ingroup print_api
*/
function print_insert_link($path = NULL, $node = NULL, $location = '') {
if (function_exists('print_ui_insert_link')) {
return print_ui_insert_link(print_print_link(), array('path' => $path, 'node' => $node, 'location' => $location));
}
else {
return FALSE;
}
}
/**
* Check if the link to the PF version is allowed depending on the settings
*
* @param array $args
* array containing the possible parameters:
* view_mode, node, type, path
*
* @return bool
* FALSE if not allowed, TRUE otherwise
*/
function print_link_allowed($args) {
return (user_access('access print'));
}
/**
* Implements hook_contextual_links_view_alter().
*/
function print_contextual_links_view_alter(&$element, $items) {
// Hide all contextual links
if (preg_match('!^print!', $_GET['q'])) {
unset($element['#links']);
}
}
/**
* Implements hook_views_api().
*/
function print_views_api() {
return array(
'api' => 2.0,
'path' => drupal_get_path('module', 'print'),
);
}