You are here

stringoverrides_advanced.module in String Overrides Advanced 7

File

stringoverrides_advanced.module
View source
<?php

/**
 * Implements hook_boot().
 */
function stringoverrides_advanced_boot() {
  global $conf;
  $conf['locale_custom_strings_en'] = new advancedStringOverridesLangcode('en');
}

/**
 * Implements hook_permission().
 */
function stringoverrides_advanced_permission() {
  return array(
    'administer string overrides advanced' => array(
      'title' => t('Administer string overrides advanced'),
    ),
  );
}

/**
 * Implements hook_menu().
 */
function stringoverrides_advanced_menu() {

  // Translation functionality
  $items['admin/config/regional/stringoverrides_advanced'] = array(
    'title' => 'String overrides',
    'description' => 'Translate the built in interface and optionally other text.',
    'page callback' => 'stringoverrides_advanced_translate_seek_screen',
    'access arguments' => array(
      'administer string overrides advanced',
    ),
    'file' => 'stringoverrides_advanced.admin.inc',
  );
  $items['admin/config/regional/stringoverrides_advanced/edit/%'] = array(
    'title' => 'Edit string',
    'page callback' => 'drupal_get_form',
    'page arguments' => array(
      'stringoverrides_advanced_translate_edit_form',
      5,
    ),
    'access arguments' => array(
      'administer string overrides advanced',
    ),
    'file' => 'stringoverrides_advanced.admin.inc',
  );
  $items['admin/config/regional/stringoverrides_advanced/delete/%'] = array(
    'title' => 'Delete string',
    'page callback' => 'stringoverrides_advanced_translate_delete_page',
    'page arguments' => array(
      5,
    ),
    'access arguments' => array(
      'administer string overrides advanced',
    ),
    'file' => 'stringoverrides_advanced.admin.inc',
  );
  return $items;
}

/**
 * Check that a string is safe to be added or imported as a translation.
 *
 * This test can be used to detect possibly bad translation strings. It should
 * not have any false positives. But it is only a test, not a transformation,
 * as it destroys valid HTML. We cannot reliably filter translation strings
 * on import because some strings are irreversibly corrupted. For example,
 * a &amp; in the translation would get encoded to &amp;amp; by filter_xss()
 * before being put in the database, and thus would be displayed incorrectly.
 *
 * The allowed tag list is like filter_xss_admin(), but omitting div and img as
 * not needed for translation and likely to cause layout issues (div) or a
 * possible attack vector (img).
 */
function stringoverrides_advanced_string_is_safe($string) {
  return decode_entities($string) == decode_entities(filter_xss($string, array(
    'a',
    'abbr',
    'acronym',
    'address',
    'b',
    'bdo',
    'big',
    'blockquote',
    'br',
    'caption',
    'cite',
    'code',
    'col',
    'colgroup',
    'dd',
    'del',
    'dfn',
    'dl',
    'dt',
    'em',
    'h1',
    'h2',
    'h3',
    'h4',
    'h5',
    'h6',
    'hr',
    'i',
    'ins',
    'kbd',
    'li',
    'ol',
    'p',
    'pre',
    'q',
    'samp',
    'small',
    'span',
    'strong',
    'sub',
    'sup',
    'table',
    'tbody',
    'td',
    'tfoot',
    'th',
    'thead',
    'tr',
    'tt',
    'ul',
    'var',
  )));
}

Functions

Namesort descending Description
stringoverrides_advanced_boot Implements hook_boot().
stringoverrides_advanced_menu Implements hook_menu().
stringoverrides_advanced_permission Implements hook_permission().
stringoverrides_advanced_string_is_safe Check that a string is safe to be added or imported as a translation.