annotate modules/system/system.admin.inc @ 13:134d4b2e75f6

updated quicktabs and google analytics modules
author danieleb <danielebarchiesi@me.com>
date Tue, 29 Oct 2013 13:48:59 +0000
parents ff03f76ab3fe
children
rev   line source
danielebarchiesi@0 1 <?php
danielebarchiesi@0 2
danielebarchiesi@0 3 /**
danielebarchiesi@0 4 * @file
danielebarchiesi@0 5 * Admin page callbacks for the system module.
danielebarchiesi@0 6 */
danielebarchiesi@0 7
danielebarchiesi@0 8 /**
danielebarchiesi@0 9 * Menu callback; Provide the administration overview page.
danielebarchiesi@0 10 */
danielebarchiesi@0 11 function system_admin_config_page() {
danielebarchiesi@0 12 // Check for status report errors.
danielebarchiesi@0 13 if (system_status(TRUE) && user_access('administer site configuration')) {
danielebarchiesi@0 14 drupal_set_message(t('One or more problems were detected with your Drupal installation. Check the <a href="@status">status report</a> for more information.', array('@status' => url('admin/reports/status'))), 'error');
danielebarchiesi@0 15 }
danielebarchiesi@0 16 $blocks = array();
danielebarchiesi@0 17 if ($admin = db_query("SELECT menu_name, mlid FROM {menu_links} WHERE link_path = 'admin/config' AND module = 'system'")->fetchAssoc()) {
danielebarchiesi@0 18 $result = db_query("
danielebarchiesi@0 19 SELECT m.*, ml.*
danielebarchiesi@0 20 FROM {menu_links} ml
danielebarchiesi@0 21 INNER JOIN {menu_router} m ON ml.router_path = m.path
danielebarchiesi@0 22 WHERE ml.link_path <> 'admin/help' AND menu_name = :menu_name AND ml.plid = :mlid AND hidden = 0", $admin, array('fetch' => PDO::FETCH_ASSOC));
danielebarchiesi@0 23 foreach ($result as $item) {
danielebarchiesi@0 24 _menu_link_translate($item);
danielebarchiesi@0 25 if (!$item['access']) {
danielebarchiesi@0 26 continue;
danielebarchiesi@0 27 }
danielebarchiesi@0 28 // The link description, either derived from 'description' in hook_menu()
danielebarchiesi@0 29 // or customized via menu module is used as title attribute.
danielebarchiesi@0 30 if (!empty($item['localized_options']['attributes']['title'])) {
danielebarchiesi@0 31 $item['description'] = $item['localized_options']['attributes']['title'];
danielebarchiesi@0 32 unset($item['localized_options']['attributes']['title']);
danielebarchiesi@0 33 }
danielebarchiesi@0 34 $block = $item;
danielebarchiesi@0 35 $block['content'] = '';
danielebarchiesi@0 36 $block['content'] .= theme('admin_block_content', array('content' => system_admin_menu_block($item)));
danielebarchiesi@0 37 if (!empty($block['content'])) {
danielebarchiesi@0 38 $block['show'] = TRUE;
danielebarchiesi@0 39 }
danielebarchiesi@0 40
danielebarchiesi@0 41 // Prepare for sorting as in function _menu_tree_check_access().
danielebarchiesi@0 42 // The weight is offset so it is always positive, with a uniform 5-digits.
danielebarchiesi@0 43 $blocks[(50000 + $item['weight']) . ' ' . $item['title'] . ' ' . $item['mlid']] = $block;
danielebarchiesi@0 44 }
danielebarchiesi@0 45 }
danielebarchiesi@0 46 if ($blocks) {
danielebarchiesi@0 47 ksort($blocks);
danielebarchiesi@0 48 return theme('admin_page', array('blocks' => $blocks));
danielebarchiesi@0 49 }
danielebarchiesi@0 50 else {
danielebarchiesi@0 51 return t('You do not have any administrative items.');
danielebarchiesi@0 52 }
danielebarchiesi@0 53 }
danielebarchiesi@0 54
danielebarchiesi@0 55 /**
danielebarchiesi@0 56 * Provide a single block from the administration menu as a page.
danielebarchiesi@0 57 *
danielebarchiesi@0 58 * This function is often a destination for these blocks.
danielebarchiesi@0 59 * For example, 'admin/structure/types' needs to have a destination to be valid
danielebarchiesi@0 60 * in the Drupal menu system, but too much information there might be
danielebarchiesi@0 61 * hidden, so we supply the contents of the block.
danielebarchiesi@0 62 *
danielebarchiesi@0 63 * @return
danielebarchiesi@0 64 * The output HTML.
danielebarchiesi@0 65 */
danielebarchiesi@0 66 function system_admin_menu_block_page() {
danielebarchiesi@0 67 $item = menu_get_item();
danielebarchiesi@0 68 if ($content = system_admin_menu_block($item)) {
danielebarchiesi@0 69 $output = theme('admin_block_content', array('content' => $content));
danielebarchiesi@0 70 }
danielebarchiesi@0 71 else {
danielebarchiesi@0 72 $output = t('You do not have any administrative items.');
danielebarchiesi@0 73 }
danielebarchiesi@0 74 return $output;
danielebarchiesi@0 75 }
danielebarchiesi@0 76
danielebarchiesi@0 77 /**
danielebarchiesi@0 78 * Menu callback; prints a listing of admin tasks, organized by module.
danielebarchiesi@0 79 */
danielebarchiesi@0 80 function system_admin_index() {
danielebarchiesi@0 81 $module_info = system_get_info('module');
danielebarchiesi@0 82 foreach ($module_info as $module => $info) {
danielebarchiesi@0 83 $module_info[$module] = new stdClass();
danielebarchiesi@0 84 $module_info[$module]->info = $info;
danielebarchiesi@0 85 }
danielebarchiesi@0 86 uasort($module_info, 'system_sort_modules_by_info_name');
danielebarchiesi@0 87 $menu_items = array();
danielebarchiesi@0 88
danielebarchiesi@0 89 foreach ($module_info as $module => $info) {
danielebarchiesi@0 90 // Only display a section if there are any available tasks.
danielebarchiesi@0 91 if ($admin_tasks = system_get_module_admin_tasks($module, $info->info)) {
danielebarchiesi@0 92 // Sort links by title.
danielebarchiesi@0 93 uasort($admin_tasks, 'drupal_sort_title');
danielebarchiesi@0 94 // Move 'Configure permissions' links to the bottom of each section.
danielebarchiesi@0 95 $permission_key = "admin/people/permissions#module-$module";
danielebarchiesi@0 96 if (isset($admin_tasks[$permission_key])) {
danielebarchiesi@0 97 $permission_task = $admin_tasks[$permission_key];
danielebarchiesi@0 98 unset($admin_tasks[$permission_key]);
danielebarchiesi@0 99 $admin_tasks[$permission_key] = $permission_task;
danielebarchiesi@0 100 }
danielebarchiesi@0 101
danielebarchiesi@0 102 $menu_items[$info->info['name']] = array($info->info['description'], $admin_tasks);
danielebarchiesi@0 103 }
danielebarchiesi@0 104 }
danielebarchiesi@0 105 return theme('system_admin_index', array('menu_items' => $menu_items));
danielebarchiesi@0 106 }
danielebarchiesi@0 107
danielebarchiesi@0 108 /**
danielebarchiesi@0 109 * Displays the configuration overview page.
danielebarchiesi@0 110 *
danielebarchiesi@0 111 * This menu callback implementation is a legacy function that used to display
danielebarchiesi@0 112 * the configuration overview page at admin/config. It is currently unused and
danielebarchiesi@0 113 * will be removed in Drupal 8. The page at admin/config is now generated by
danielebarchiesi@0 114 * system_admin_config_page().
danielebarchiesi@0 115 *
danielebarchiesi@0 116 * @deprecated
danielebarchiesi@0 117 * @see system_admin_config_page()
danielebarchiesi@0 118 */
danielebarchiesi@0 119 function system_settings_overview() {
danielebarchiesi@0 120 // Check database setup if necessary
danielebarchiesi@0 121 if (function_exists('db_check_setup') && empty($_POST)) {
danielebarchiesi@0 122 db_check_setup();
danielebarchiesi@0 123 }
danielebarchiesi@0 124
danielebarchiesi@0 125 $item = menu_get_item('admin/config');
danielebarchiesi@0 126 $content = system_admin_menu_block($item);
danielebarchiesi@0 127
danielebarchiesi@0 128 $output = theme('admin_block_content', array('content' => $content));
danielebarchiesi@0 129
danielebarchiesi@0 130 return $output;
danielebarchiesi@0 131 }
danielebarchiesi@0 132
danielebarchiesi@0 133 /**
danielebarchiesi@0 134 * Menu callback; displays a listing of all themes.
danielebarchiesi@0 135 */
danielebarchiesi@0 136 function system_themes_page() {
danielebarchiesi@0 137 // Get current list of themes.
danielebarchiesi@0 138 $themes = system_rebuild_theme_data();
danielebarchiesi@0 139 uasort($themes, 'system_sort_modules_by_info_name');
danielebarchiesi@0 140
danielebarchiesi@0 141 $theme_default = variable_get('theme_default', 'bartik');
danielebarchiesi@0 142 $theme_groups = array();
danielebarchiesi@0 143
danielebarchiesi@0 144 foreach ($themes as &$theme) {
danielebarchiesi@0 145 if (!empty($theme->info['hidden'])) {
danielebarchiesi@0 146 continue;
danielebarchiesi@0 147 }
danielebarchiesi@0 148 $admin_theme_options[$theme->name] = $theme->info['name'];
danielebarchiesi@0 149 $theme->is_default = ($theme->name == $theme_default);
danielebarchiesi@0 150
danielebarchiesi@0 151 // Identify theme screenshot.
danielebarchiesi@0 152 $theme->screenshot = NULL;
danielebarchiesi@0 153 // Create a list which includes the current theme and all its base themes.
danielebarchiesi@0 154 if (isset($themes[$theme->name]->base_themes)) {
danielebarchiesi@0 155 $theme_keys = array_keys($themes[$theme->name]->base_themes);
danielebarchiesi@0 156 $theme_keys[] = $theme->name;
danielebarchiesi@0 157 }
danielebarchiesi@0 158 else {
danielebarchiesi@0 159 $theme_keys = array($theme->name);
danielebarchiesi@0 160 }
danielebarchiesi@0 161 // Look for a screenshot in the current theme or in its closest ancestor.
danielebarchiesi@0 162 foreach (array_reverse($theme_keys) as $theme_key) {
danielebarchiesi@0 163 if (isset($themes[$theme_key]) && file_exists($themes[$theme_key]->info['screenshot'])) {
danielebarchiesi@0 164 $theme->screenshot = array(
danielebarchiesi@0 165 'path' => $themes[$theme_key]->info['screenshot'],
danielebarchiesi@0 166 'alt' => t('Screenshot for !theme theme', array('!theme' => $theme->info['name'])),
danielebarchiesi@0 167 'title' => t('Screenshot for !theme theme', array('!theme' => $theme->info['name'])),
danielebarchiesi@0 168 'attributes' => array('class' => array('screenshot')),
danielebarchiesi@0 169 );
danielebarchiesi@0 170 break;
danielebarchiesi@0 171 }
danielebarchiesi@0 172 }
danielebarchiesi@0 173
danielebarchiesi@0 174 if (empty($theme->status)) {
danielebarchiesi@0 175 // Ensure this theme is compatible with this version of core.
danielebarchiesi@0 176 // Require the 'content' region to make sure the main page
danielebarchiesi@0 177 // content has a common place in all themes.
danielebarchiesi@0 178 $theme->incompatible_core = !isset($theme->info['core']) || ($theme->info['core'] != DRUPAL_CORE_COMPATIBILITY) || (!isset($theme->info['regions']['content']));
danielebarchiesi@0 179 $theme->incompatible_php = version_compare(phpversion(), $theme->info['php']) < 0;
danielebarchiesi@0 180 }
danielebarchiesi@0 181 $query['token'] = drupal_get_token('system-theme-operation-link');
danielebarchiesi@0 182 $theme->operations = array();
danielebarchiesi@0 183 if (!empty($theme->status) || !$theme->incompatible_core && !$theme->incompatible_php) {
danielebarchiesi@0 184 // Create the operations links.
danielebarchiesi@0 185 $query['theme'] = $theme->name;
danielebarchiesi@0 186 if (drupal_theme_access($theme)) {
danielebarchiesi@0 187 $theme->operations[] = array(
danielebarchiesi@0 188 'title' => t('Settings'),
danielebarchiesi@0 189 'href' => 'admin/appearance/settings/' . $theme->name,
danielebarchiesi@0 190 'attributes' => array('title' => t('Settings for !theme theme', array('!theme' => $theme->info['name']))),
danielebarchiesi@0 191 );
danielebarchiesi@0 192 }
danielebarchiesi@0 193 if (!empty($theme->status)) {
danielebarchiesi@0 194 if (!$theme->is_default) {
danielebarchiesi@0 195 $theme->operations[] = array(
danielebarchiesi@0 196 'title' => t('Disable'),
danielebarchiesi@0 197 'href' => 'admin/appearance/disable',
danielebarchiesi@0 198 'query' => $query,
danielebarchiesi@0 199 'attributes' => array('title' => t('Disable !theme theme', array('!theme' => $theme->info['name']))),
danielebarchiesi@0 200 );
danielebarchiesi@0 201 $theme->operations[] = array(
danielebarchiesi@0 202 'title' => t('Set default'),
danielebarchiesi@0 203 'href' => 'admin/appearance/default',
danielebarchiesi@0 204 'query' => $query,
danielebarchiesi@0 205 'attributes' => array('title' => t('Set !theme as default theme', array('!theme' => $theme->info['name']))),
danielebarchiesi@0 206 );
danielebarchiesi@0 207 }
danielebarchiesi@0 208 }
danielebarchiesi@0 209 else {
danielebarchiesi@0 210 $theme->operations[] = array(
danielebarchiesi@0 211 'title' => t('Enable'),
danielebarchiesi@0 212 'href' => 'admin/appearance/enable',
danielebarchiesi@0 213 'query' => $query,
danielebarchiesi@0 214 'attributes' => array('title' => t('Enable !theme theme', array('!theme' => $theme->info['name']))),
danielebarchiesi@0 215 );
danielebarchiesi@0 216 $theme->operations[] = array(
danielebarchiesi@0 217 'title' => t('Enable and set default'),
danielebarchiesi@0 218 'href' => 'admin/appearance/default',
danielebarchiesi@0 219 'query' => $query,
danielebarchiesi@0 220 'attributes' => array('title' => t('Enable !theme as default theme', array('!theme' => $theme->info['name']))),
danielebarchiesi@0 221 );
danielebarchiesi@0 222 }
danielebarchiesi@0 223 }
danielebarchiesi@0 224
danielebarchiesi@0 225 // Add notes to default and administration theme.
danielebarchiesi@0 226 $theme->notes = array();
danielebarchiesi@0 227 $theme->classes = array();
danielebarchiesi@0 228 if ($theme->is_default) {
danielebarchiesi@0 229 $theme->classes[] = 'theme-default';
danielebarchiesi@0 230 $theme->notes[] = t('default theme');
danielebarchiesi@0 231 }
danielebarchiesi@0 232
danielebarchiesi@0 233 // Sort enabled and disabled themes into their own groups.
danielebarchiesi@0 234 $theme_groups[$theme->status ? 'enabled' : 'disabled'][] = $theme;
danielebarchiesi@0 235 }
danielebarchiesi@0 236
danielebarchiesi@0 237 // There are two possible theme groups.
danielebarchiesi@0 238 $theme_group_titles = array(
danielebarchiesi@0 239 'enabled' => format_plural(count($theme_groups['enabled']), 'Enabled theme', 'Enabled themes'),
danielebarchiesi@0 240 );
danielebarchiesi@0 241 if (!empty($theme_groups['disabled'])) {
danielebarchiesi@0 242 $theme_group_titles['disabled'] = format_plural(count($theme_groups['disabled']), 'Disabled theme', 'Disabled themes');
danielebarchiesi@0 243 }
danielebarchiesi@0 244
danielebarchiesi@0 245 uasort($theme_groups['enabled'], 'system_sort_themes');
danielebarchiesi@0 246 drupal_alter('system_themes_page', $theme_groups);
danielebarchiesi@0 247
danielebarchiesi@0 248 $admin_form = drupal_get_form('system_themes_admin_form', $admin_theme_options);
danielebarchiesi@0 249 return theme('system_themes_page', array('theme_groups' => $theme_groups, 'theme_group_titles' => $theme_group_titles)) . drupal_render($admin_form);
danielebarchiesi@0 250 }
danielebarchiesi@0 251
danielebarchiesi@0 252 /**
danielebarchiesi@0 253 * Form to select the administration theme.
danielebarchiesi@0 254 *
danielebarchiesi@0 255 * @ingroup forms
danielebarchiesi@0 256 * @see system_themes_admin_form_submit()
danielebarchiesi@0 257 */
danielebarchiesi@0 258 function system_themes_admin_form($form, &$form_state, $theme_options) {
danielebarchiesi@0 259 // Administration theme settings.
danielebarchiesi@0 260 $form['admin_theme'] = array(
danielebarchiesi@0 261 '#type' => 'fieldset',
danielebarchiesi@0 262 '#title' => t('Administration theme'),
danielebarchiesi@0 263 );
danielebarchiesi@0 264 $form['admin_theme']['admin_theme'] = array(
danielebarchiesi@0 265 '#type' => 'select',
danielebarchiesi@0 266 '#options' => array(0 => t('Default theme')) + $theme_options,
danielebarchiesi@0 267 '#title' => t('Administration theme'),
danielebarchiesi@0 268 '#description' => t('Choose "Default theme" to always use the same theme as the rest of the site.'),
danielebarchiesi@0 269 '#default_value' => variable_get('admin_theme', 0),
danielebarchiesi@0 270 );
danielebarchiesi@0 271 $form['admin_theme']['node_admin_theme'] = array(
danielebarchiesi@0 272 '#type' => 'checkbox',
danielebarchiesi@0 273 '#title' => t('Use the administration theme when editing or creating content'),
danielebarchiesi@0 274 '#default_value' => variable_get('node_admin_theme', '0'),
danielebarchiesi@0 275 );
danielebarchiesi@0 276 $form['admin_theme']['actions'] = array('#type' => 'actions');
danielebarchiesi@0 277 $form['admin_theme']['actions']['submit'] = array(
danielebarchiesi@0 278 '#type' => 'submit',
danielebarchiesi@0 279 '#value' => t('Save configuration'),
danielebarchiesi@0 280 );
danielebarchiesi@0 281 return $form;
danielebarchiesi@0 282 }
danielebarchiesi@0 283
danielebarchiesi@0 284 /**
danielebarchiesi@0 285 * Process system_themes_admin_form form submissions.
danielebarchiesi@0 286 */
danielebarchiesi@0 287 function system_themes_admin_form_submit($form, &$form_state) {
danielebarchiesi@0 288 drupal_set_message(t('The configuration options have been saved.'));
danielebarchiesi@0 289 variable_set('admin_theme', $form_state['values']['admin_theme']);
danielebarchiesi@0 290 variable_set('node_admin_theme', $form_state['values']['node_admin_theme']);
danielebarchiesi@0 291 }
danielebarchiesi@0 292
danielebarchiesi@0 293 /**
danielebarchiesi@0 294 * Menu callback; Enables a theme.
danielebarchiesi@0 295 */
danielebarchiesi@0 296 function system_theme_enable() {
danielebarchiesi@0 297 if (isset($_REQUEST['theme']) && isset($_REQUEST['token']) && drupal_valid_token($_REQUEST['token'], 'system-theme-operation-link')) {
danielebarchiesi@0 298 $theme = $_REQUEST['theme'];
danielebarchiesi@0 299 // Get current list of themes.
danielebarchiesi@0 300 $themes = list_themes();
danielebarchiesi@0 301
danielebarchiesi@0 302 // Check if the specified theme is one recognized by the system.
danielebarchiesi@0 303 if (!empty($themes[$theme])) {
danielebarchiesi@0 304 theme_enable(array($theme));
danielebarchiesi@0 305 drupal_set_message(t('The %theme theme has been enabled.', array('%theme' => $themes[$theme]->info['name'])));
danielebarchiesi@0 306 }
danielebarchiesi@0 307 else {
danielebarchiesi@0 308 drupal_set_message(t('The %theme theme was not found.', array('%theme' => $theme)), 'error');
danielebarchiesi@0 309 }
danielebarchiesi@0 310 drupal_goto('admin/appearance');
danielebarchiesi@0 311 }
danielebarchiesi@0 312 return drupal_access_denied();
danielebarchiesi@0 313 }
danielebarchiesi@0 314
danielebarchiesi@0 315 /**
danielebarchiesi@0 316 * Menu callback; Disables a theme.
danielebarchiesi@0 317 */
danielebarchiesi@0 318 function system_theme_disable() {
danielebarchiesi@0 319 if (isset($_REQUEST['theme']) && isset($_REQUEST['token']) && drupal_valid_token($_REQUEST['token'], 'system-theme-operation-link')) {
danielebarchiesi@0 320 $theme = $_REQUEST['theme'];
danielebarchiesi@0 321 // Get current list of themes.
danielebarchiesi@0 322 $themes = list_themes();
danielebarchiesi@0 323
danielebarchiesi@0 324 // Check if the specified theme is one recognized by the system.
danielebarchiesi@0 325 if (!empty($themes[$theme])) {
danielebarchiesi@0 326 if ($theme == variable_get('theme_default', 'bartik')) {
danielebarchiesi@0 327 // Don't disable the default theme.
danielebarchiesi@0 328 drupal_set_message(t('%theme is the default theme and cannot be disabled.', array('%theme' => $themes[$theme]->info['name'])), 'error');
danielebarchiesi@0 329 }
danielebarchiesi@0 330 else {
danielebarchiesi@0 331 theme_disable(array($theme));
danielebarchiesi@0 332 drupal_set_message(t('The %theme theme has been disabled.', array('%theme' => $themes[$theme]->info['name'])));
danielebarchiesi@0 333 }
danielebarchiesi@0 334 }
danielebarchiesi@0 335 else {
danielebarchiesi@0 336 drupal_set_message(t('The %theme theme was not found.', array('%theme' => $theme)), 'error');
danielebarchiesi@0 337 }
danielebarchiesi@0 338 drupal_goto('admin/appearance');
danielebarchiesi@0 339 }
danielebarchiesi@0 340 return drupal_access_denied();
danielebarchiesi@0 341 }
danielebarchiesi@0 342
danielebarchiesi@0 343 /**
danielebarchiesi@0 344 * Menu callback; Set the default theme.
danielebarchiesi@0 345 */
danielebarchiesi@0 346 function system_theme_default() {
danielebarchiesi@0 347 if (isset($_REQUEST['theme']) && isset($_REQUEST['token']) && drupal_valid_token($_REQUEST['token'], 'system-theme-operation-link')) {
danielebarchiesi@0 348 $theme = $_REQUEST['theme'];
danielebarchiesi@0 349 // Get current list of themes.
danielebarchiesi@0 350 $themes = list_themes();
danielebarchiesi@0 351
danielebarchiesi@0 352 // Check if the specified theme is one recognized by the system.
danielebarchiesi@0 353 if (!empty($themes[$theme])) {
danielebarchiesi@0 354 // Enable the theme if it is currently disabled.
danielebarchiesi@0 355 if (empty($themes[$theme]->status)) {
danielebarchiesi@0 356 theme_enable(array($theme));
danielebarchiesi@0 357 }
danielebarchiesi@0 358 // Set the default theme.
danielebarchiesi@0 359 variable_set('theme_default', $theme);
danielebarchiesi@0 360
danielebarchiesi@0 361 // Rebuild the menu. This duplicates the menu_rebuild() in theme_enable().
danielebarchiesi@0 362 // However, modules must know the current default theme in order to use
danielebarchiesi@0 363 // this information in hook_menu() or hook_menu_alter() implementations,
danielebarchiesi@0 364 // and doing the variable_set() before the theme_enable() could result
danielebarchiesi@0 365 // in a race condition where the theme is default but not enabled.
danielebarchiesi@0 366 menu_rebuild();
danielebarchiesi@0 367
danielebarchiesi@0 368 // The status message depends on whether an admin theme is currently in use:
danielebarchiesi@0 369 // a value of 0 means the admin theme is set to be the default theme.
danielebarchiesi@0 370 $admin_theme = variable_get('admin_theme', 0);
danielebarchiesi@0 371 if ($admin_theme != 0 && $admin_theme != $theme) {
danielebarchiesi@0 372 drupal_set_message(t('Please note that the administration theme is still set to the %admin_theme theme; consequently, the theme on this page remains unchanged. All non-administrative sections of the site, however, will show the selected %selected_theme theme by default.', array(
danielebarchiesi@0 373 '%admin_theme' => $themes[$admin_theme]->info['name'],
danielebarchiesi@0 374 '%selected_theme' => $themes[$theme]->info['name'],
danielebarchiesi@0 375 )));
danielebarchiesi@0 376 }
danielebarchiesi@0 377 else {
danielebarchiesi@0 378 drupal_set_message(t('%theme is now the default theme.', array('%theme' => $themes[$theme]->info['name'])));
danielebarchiesi@0 379 }
danielebarchiesi@0 380 }
danielebarchiesi@0 381 else {
danielebarchiesi@0 382 drupal_set_message(t('The %theme theme was not found.', array('%theme' => $theme)), 'error');
danielebarchiesi@0 383 }
danielebarchiesi@0 384 drupal_goto('admin/appearance');
danielebarchiesi@0 385 }
danielebarchiesi@0 386 return drupal_access_denied();
danielebarchiesi@0 387 }
danielebarchiesi@0 388
danielebarchiesi@0 389 /**
danielebarchiesi@0 390 * Form builder; display theme configuration for entire site and individual themes.
danielebarchiesi@0 391 *
danielebarchiesi@0 392 * @param $key
danielebarchiesi@0 393 * A theme name.
danielebarchiesi@0 394 * @return
danielebarchiesi@0 395 * The form structure.
danielebarchiesi@0 396 * @ingroup forms
danielebarchiesi@0 397 * @see system_theme_settings_submit()
danielebarchiesi@0 398 */
danielebarchiesi@0 399 function system_theme_settings($form, &$form_state, $key = '') {
danielebarchiesi@0 400 // Default settings are defined in theme_get_setting() in includes/theme.inc
danielebarchiesi@0 401 if ($key) {
danielebarchiesi@0 402 $var = 'theme_' . $key . '_settings';
danielebarchiesi@0 403 $themes = list_themes();
danielebarchiesi@0 404 $features = $themes[$key]->info['features'];
danielebarchiesi@0 405 }
danielebarchiesi@0 406 else {
danielebarchiesi@0 407 $var = 'theme_settings';
danielebarchiesi@0 408 }
danielebarchiesi@0 409
danielebarchiesi@0 410 $form['var'] = array('#type' => 'hidden', '#value' => $var);
danielebarchiesi@0 411
danielebarchiesi@0 412 // Toggle settings
danielebarchiesi@0 413 $toggles = array(
danielebarchiesi@0 414 'logo' => t('Logo'),
danielebarchiesi@0 415 'name' => t('Site name'),
danielebarchiesi@0 416 'slogan' => t('Site slogan'),
danielebarchiesi@0 417 'node_user_picture' => t('User pictures in posts'),
danielebarchiesi@0 418 'comment_user_picture' => t('User pictures in comments'),
danielebarchiesi@0 419 'comment_user_verification' => t('User verification status in comments'),
danielebarchiesi@0 420 'favicon' => t('Shortcut icon'),
danielebarchiesi@0 421 'main_menu' => t('Main menu'),
danielebarchiesi@0 422 'secondary_menu' => t('Secondary menu'),
danielebarchiesi@0 423 );
danielebarchiesi@0 424
danielebarchiesi@0 425 // Some features are not always available
danielebarchiesi@0 426 $disabled = array();
danielebarchiesi@0 427 if (!variable_get('user_pictures', 0)) {
danielebarchiesi@0 428 $disabled['toggle_node_user_picture'] = TRUE;
danielebarchiesi@0 429 $disabled['toggle_comment_user_picture'] = TRUE;
danielebarchiesi@0 430 }
danielebarchiesi@0 431 if (!module_exists('comment')) {
danielebarchiesi@0 432 $disabled['toggle_comment_user_picture'] = TRUE;
danielebarchiesi@0 433 $disabled['toggle_comment_user_verification'] = TRUE;
danielebarchiesi@0 434 }
danielebarchiesi@0 435
danielebarchiesi@0 436 $form['theme_settings'] = array(
danielebarchiesi@0 437 '#type' => 'fieldset',
danielebarchiesi@0 438 '#title' => t('Toggle display'),
danielebarchiesi@0 439 '#description' => t('Enable or disable the display of certain page elements.'),
danielebarchiesi@0 440 );
danielebarchiesi@0 441 foreach ($toggles as $name => $title) {
danielebarchiesi@0 442 if ((!$key) || in_array($name, $features)) {
danielebarchiesi@0 443 $form['theme_settings']['toggle_' . $name] = array('#type' => 'checkbox', '#title' => $title, '#default_value' => theme_get_setting('toggle_' . $name, $key));
danielebarchiesi@0 444 // Disable checkboxes for features not supported in the current configuration.
danielebarchiesi@0 445 if (isset($disabled['toggle_' . $name])) {
danielebarchiesi@0 446 $form['theme_settings']['toggle_' . $name]['#disabled'] = TRUE;
danielebarchiesi@0 447 }
danielebarchiesi@0 448 }
danielebarchiesi@0 449 }
danielebarchiesi@0 450
danielebarchiesi@0 451 if (!element_children($form['theme_settings'])) {
danielebarchiesi@0 452 // If there is no element in the theme settings fieldset then do not show
danielebarchiesi@0 453 // it -- but keep it in the form if another module wants to alter.
danielebarchiesi@0 454 $form['theme_settings']['#access'] = FALSE;
danielebarchiesi@0 455 }
danielebarchiesi@0 456
danielebarchiesi@0 457 // Logo settings
danielebarchiesi@0 458 if ((!$key) || in_array('logo', $features)) {
danielebarchiesi@0 459 $form['logo'] = array(
danielebarchiesi@0 460 '#type' => 'fieldset',
danielebarchiesi@0 461 '#title' => t('Logo image settings'),
danielebarchiesi@0 462 '#description' => t('If toggled on, the following logo will be displayed.'),
danielebarchiesi@0 463 '#attributes' => array('class' => array('theme-settings-bottom')),
danielebarchiesi@0 464 );
danielebarchiesi@0 465 $form['logo']['default_logo'] = array(
danielebarchiesi@0 466 '#type' => 'checkbox',
danielebarchiesi@0 467 '#title' => t('Use the default logo'),
danielebarchiesi@0 468 '#default_value' => theme_get_setting('default_logo', $key),
danielebarchiesi@0 469 '#tree' => FALSE,
danielebarchiesi@0 470 '#description' => t('Check here if you want the theme to use the logo supplied with it.')
danielebarchiesi@0 471 );
danielebarchiesi@0 472 $form['logo']['settings'] = array(
danielebarchiesi@0 473 '#type' => 'container',
danielebarchiesi@0 474 '#states' => array(
danielebarchiesi@0 475 // Hide the logo settings when using the default logo.
danielebarchiesi@0 476 'invisible' => array(
danielebarchiesi@0 477 'input[name="default_logo"]' => array('checked' => TRUE),
danielebarchiesi@0 478 ),
danielebarchiesi@0 479 ),
danielebarchiesi@0 480 );
danielebarchiesi@0 481 $form['logo']['settings']['logo_path'] = array(
danielebarchiesi@0 482 '#type' => 'textfield',
danielebarchiesi@0 483 '#title' => t('Path to custom logo'),
danielebarchiesi@0 484 '#description' => t('The path to the file you would like to use as your logo file instead of the default logo.'),
danielebarchiesi@0 485 '#default_value' => theme_get_setting('logo_path', $key),
danielebarchiesi@0 486 );
danielebarchiesi@0 487 $form['logo']['settings']['logo_upload'] = array(
danielebarchiesi@0 488 '#type' => 'file',
danielebarchiesi@0 489 '#title' => t('Upload logo image'),
danielebarchiesi@0 490 '#maxlength' => 40,
danielebarchiesi@0 491 '#description' => t("If you don't have direct file access to the server, use this field to upload your logo.")
danielebarchiesi@0 492 );
danielebarchiesi@0 493 }
danielebarchiesi@0 494
danielebarchiesi@0 495 if ((!$key) || in_array('favicon', $features)) {
danielebarchiesi@0 496 $form['favicon'] = array(
danielebarchiesi@0 497 '#type' => 'fieldset',
danielebarchiesi@0 498 '#title' => t('Shortcut icon settings'),
danielebarchiesi@0 499 '#description' => t("Your shortcut icon, or 'favicon', is displayed in the address bar and bookmarks of most browsers."),
danielebarchiesi@0 500 );
danielebarchiesi@0 501 $form['favicon']['default_favicon'] = array(
danielebarchiesi@0 502 '#type' => 'checkbox',
danielebarchiesi@0 503 '#title' => t('Use the default shortcut icon.'),
danielebarchiesi@0 504 '#default_value' => theme_get_setting('default_favicon', $key),
danielebarchiesi@0 505 '#description' => t('Check here if you want the theme to use the default shortcut icon.')
danielebarchiesi@0 506 );
danielebarchiesi@0 507 $form['favicon']['settings'] = array(
danielebarchiesi@0 508 '#type' => 'container',
danielebarchiesi@0 509 '#states' => array(
danielebarchiesi@0 510 // Hide the favicon settings when using the default favicon.
danielebarchiesi@0 511 'invisible' => array(
danielebarchiesi@0 512 'input[name="default_favicon"]' => array('checked' => TRUE),
danielebarchiesi@0 513 ),
danielebarchiesi@0 514 ),
danielebarchiesi@0 515 );
danielebarchiesi@0 516 $form['favicon']['settings']['favicon_path'] = array(
danielebarchiesi@0 517 '#type' => 'textfield',
danielebarchiesi@0 518 '#title' => t('Path to custom icon'),
danielebarchiesi@0 519 '#description' => t('The path to the image file you would like to use as your custom shortcut icon.'),
danielebarchiesi@0 520 '#default_value' => theme_get_setting('favicon_path', $key),
danielebarchiesi@0 521 );
danielebarchiesi@0 522 $form['favicon']['settings']['favicon_upload'] = array(
danielebarchiesi@0 523 '#type' => 'file',
danielebarchiesi@0 524 '#title' => t('Upload icon image'),
danielebarchiesi@0 525 '#description' => t("If you don't have direct file access to the server, use this field to upload your shortcut icon.")
danielebarchiesi@0 526 );
danielebarchiesi@0 527 }
danielebarchiesi@0 528
danielebarchiesi@0 529 // Inject human-friendly values for logo and favicon.
danielebarchiesi@0 530 foreach (array('logo' => 'logo.png', 'favicon' => 'favicon.ico') as $type => $default) {
danielebarchiesi@0 531 if (isset($form[$type]['settings'][$type . '_path'])) {
danielebarchiesi@0 532 $element = &$form[$type]['settings'][$type . '_path'];
danielebarchiesi@0 533
danielebarchiesi@0 534 // If path is a public:// URI, display the path relative to the files
danielebarchiesi@0 535 // directory; stream wrappers are not end-user friendly.
danielebarchiesi@0 536 $original_path = $element['#default_value'];
danielebarchiesi@0 537 $friendly_path = NULL;
danielebarchiesi@0 538 if (file_uri_scheme($original_path) == 'public') {
danielebarchiesi@0 539 $friendly_path = file_uri_target($original_path);
danielebarchiesi@0 540 $element['#default_value'] = $friendly_path;
danielebarchiesi@0 541 }
danielebarchiesi@0 542 }
danielebarchiesi@0 543 }
danielebarchiesi@0 544
danielebarchiesi@0 545 if ($key) {
danielebarchiesi@0 546 // Call engine-specific settings.
danielebarchiesi@0 547 $function = $themes[$key]->prefix . '_engine_settings';
danielebarchiesi@0 548 if (function_exists($function)) {
danielebarchiesi@0 549 $form['engine_specific'] = array(
danielebarchiesi@0 550 '#type' => 'fieldset',
danielebarchiesi@0 551 '#title' => t('Theme-engine-specific settings'),
danielebarchiesi@0 552 '#description' => t('These settings only exist for the themes based on the %engine theme engine.', array('%engine' => $themes[$key]->prefix)),
danielebarchiesi@0 553 );
danielebarchiesi@0 554 $function($form, $form_state);
danielebarchiesi@0 555 }
danielebarchiesi@0 556
danielebarchiesi@0 557 // Create a list which includes the current theme and all its base themes.
danielebarchiesi@0 558 if (isset($themes[$key]->base_themes)) {
danielebarchiesi@0 559 $theme_keys = array_keys($themes[$key]->base_themes);
danielebarchiesi@0 560 $theme_keys[] = $key;
danielebarchiesi@0 561 }
danielebarchiesi@0 562 else {
danielebarchiesi@0 563 $theme_keys = array($key);
danielebarchiesi@0 564 }
danielebarchiesi@0 565
danielebarchiesi@0 566 // Save the name of the current theme (if any), so that we can temporarily
danielebarchiesi@0 567 // override the current theme and allow theme_get_setting() to work
danielebarchiesi@0 568 // without having to pass the theme name to it.
danielebarchiesi@0 569 $default_theme = !empty($GLOBALS['theme_key']) ? $GLOBALS['theme_key'] : NULL;
danielebarchiesi@0 570 $GLOBALS['theme_key'] = $key;
danielebarchiesi@0 571
danielebarchiesi@0 572 // Process the theme and all its base themes.
danielebarchiesi@0 573 foreach ($theme_keys as $theme) {
danielebarchiesi@0 574 // Include the theme-settings.php file.
danielebarchiesi@0 575 $filename = DRUPAL_ROOT . '/' . str_replace("/$theme.info", '', $themes[$theme]->filename) . '/theme-settings.php';
danielebarchiesi@0 576 if (file_exists($filename)) {
danielebarchiesi@0 577 require_once $filename;
danielebarchiesi@0 578 }
danielebarchiesi@0 579
danielebarchiesi@0 580 // Call theme-specific settings.
danielebarchiesi@0 581 $function = $theme . '_form_system_theme_settings_alter';
danielebarchiesi@0 582 if (function_exists($function)) {
danielebarchiesi@0 583 $function($form, $form_state);
danielebarchiesi@0 584 }
danielebarchiesi@0 585 }
danielebarchiesi@0 586
danielebarchiesi@0 587 // Restore the original current theme.
danielebarchiesi@0 588 if (isset($default_theme)) {
danielebarchiesi@0 589 $GLOBALS['theme_key'] = $default_theme;
danielebarchiesi@0 590 }
danielebarchiesi@0 591 else {
danielebarchiesi@0 592 unset($GLOBALS['theme_key']);
danielebarchiesi@0 593 }
danielebarchiesi@0 594 }
danielebarchiesi@0 595
danielebarchiesi@0 596 $form = system_settings_form($form);
danielebarchiesi@0 597 // We don't want to call system_settings_form_submit(), so change #submit.
danielebarchiesi@0 598 array_pop($form['#submit']);
danielebarchiesi@0 599 $form['#submit'][] = 'system_theme_settings_submit';
danielebarchiesi@0 600 $form['#validate'][] = 'system_theme_settings_validate';
danielebarchiesi@0 601 return $form;
danielebarchiesi@0 602 }
danielebarchiesi@0 603
danielebarchiesi@0 604 /**
danielebarchiesi@0 605 * Validator for the system_theme_settings() form.
danielebarchiesi@0 606 */
danielebarchiesi@0 607 function system_theme_settings_validate($form, &$form_state) {
danielebarchiesi@0 608 // Handle file uploads.
danielebarchiesi@0 609 $validators = array('file_validate_is_image' => array());
danielebarchiesi@0 610
danielebarchiesi@0 611 // Check for a new uploaded logo.
danielebarchiesi@0 612 $file = file_save_upload('logo_upload', $validators);
danielebarchiesi@0 613 if (isset($file)) {
danielebarchiesi@0 614 // File upload was attempted.
danielebarchiesi@0 615 if ($file) {
danielebarchiesi@0 616 // Put the temporary file in form_values so we can save it on submit.
danielebarchiesi@0 617 $form_state['values']['logo_upload'] = $file;
danielebarchiesi@0 618 }
danielebarchiesi@0 619 else {
danielebarchiesi@0 620 // File upload failed.
danielebarchiesi@0 621 form_set_error('logo_upload', t('The logo could not be uploaded.'));
danielebarchiesi@0 622 }
danielebarchiesi@0 623 }
danielebarchiesi@0 624
danielebarchiesi@0 625 $validators = array('file_validate_extensions' => array('ico png gif jpg jpeg apng svg'));
danielebarchiesi@0 626
danielebarchiesi@0 627 // Check for a new uploaded favicon.
danielebarchiesi@0 628 $file = file_save_upload('favicon_upload', $validators);
danielebarchiesi@0 629 if (isset($file)) {
danielebarchiesi@0 630 // File upload was attempted.
danielebarchiesi@0 631 if ($file) {
danielebarchiesi@0 632 // Put the temporary file in form_values so we can save it on submit.
danielebarchiesi@0 633 $form_state['values']['favicon_upload'] = $file;
danielebarchiesi@0 634 }
danielebarchiesi@0 635 else {
danielebarchiesi@0 636 // File upload failed.
danielebarchiesi@0 637 form_set_error('favicon_upload', t('The favicon could not be uploaded.'));
danielebarchiesi@0 638 }
danielebarchiesi@0 639 }
danielebarchiesi@0 640
danielebarchiesi@0 641 // If the user provided a path for a logo or favicon file, make sure a file
danielebarchiesi@0 642 // exists at that path.
danielebarchiesi@0 643 if ($form_state['values']['logo_path']) {
danielebarchiesi@0 644 $path = _system_theme_settings_validate_path($form_state['values']['logo_path']);
danielebarchiesi@0 645 if (!$path) {
danielebarchiesi@0 646 form_set_error('logo_path', t('The custom logo path is invalid.'));
danielebarchiesi@0 647 }
danielebarchiesi@0 648 }
danielebarchiesi@0 649 if ($form_state['values']['favicon_path']) {
danielebarchiesi@0 650 $path = _system_theme_settings_validate_path($form_state['values']['favicon_path']);
danielebarchiesi@0 651 if (!$path) {
danielebarchiesi@0 652 form_set_error('favicon_path', t('The custom favicon path is invalid.'));
danielebarchiesi@0 653 }
danielebarchiesi@0 654 }
danielebarchiesi@0 655 }
danielebarchiesi@0 656
danielebarchiesi@0 657 /**
danielebarchiesi@0 658 * Helper function for the system_theme_settings form.
danielebarchiesi@0 659 *
danielebarchiesi@0 660 * Attempts to validate normal system paths, paths relative to the public files
danielebarchiesi@0 661 * directory, or stream wrapper URIs. If the given path is any of the above,
danielebarchiesi@0 662 * returns a valid path or URI that the theme system can display.
danielebarchiesi@0 663 *
danielebarchiesi@0 664 * @param $path
danielebarchiesi@0 665 * A path relative to the Drupal root or to the public files directory, or
danielebarchiesi@0 666 * a stream wrapper URI.
danielebarchiesi@0 667 * @return mixed
danielebarchiesi@0 668 * A valid path that can be displayed through the theme system, or FALSE if
danielebarchiesi@0 669 * the path could not be validated.
danielebarchiesi@0 670 */
danielebarchiesi@0 671 function _system_theme_settings_validate_path($path) {
danielebarchiesi@0 672 // Absolute local file paths are invalid.
danielebarchiesi@0 673 if (drupal_realpath($path) == $path) {
danielebarchiesi@0 674 return FALSE;
danielebarchiesi@0 675 }
danielebarchiesi@0 676 // A path relative to the Drupal root or a fully qualified URI is valid.
danielebarchiesi@0 677 if (is_file($path)) {
danielebarchiesi@0 678 return $path;
danielebarchiesi@0 679 }
danielebarchiesi@0 680 // Prepend 'public://' for relative file paths within public filesystem.
danielebarchiesi@0 681 if (file_uri_scheme($path) === FALSE) {
danielebarchiesi@0 682 $path = 'public://' . $path;
danielebarchiesi@0 683 }
danielebarchiesi@0 684 if (is_file($path)) {
danielebarchiesi@0 685 return $path;
danielebarchiesi@0 686 }
danielebarchiesi@0 687 return FALSE;
danielebarchiesi@0 688 }
danielebarchiesi@0 689
danielebarchiesi@0 690 /**
danielebarchiesi@0 691 * Process system_theme_settings form submissions.
danielebarchiesi@0 692 */
danielebarchiesi@0 693 function system_theme_settings_submit($form, &$form_state) {
danielebarchiesi@0 694 // Exclude unnecessary elements before saving.
danielebarchiesi@0 695 form_state_values_clean($form_state);
danielebarchiesi@0 696
danielebarchiesi@0 697 $values = $form_state['values'];
danielebarchiesi@0 698
danielebarchiesi@0 699 // Extract the name of the theme from the submitted form values, then remove
danielebarchiesi@0 700 // it from the array so that it is not saved as part of the variable.
danielebarchiesi@0 701 $key = $values['var'];
danielebarchiesi@0 702 unset($values['var']);
danielebarchiesi@0 703
danielebarchiesi@0 704 // If the user uploaded a new logo or favicon, save it to a permanent location
danielebarchiesi@0 705 // and use it in place of the default theme-provided file.
danielebarchiesi@0 706 if ($file = $values['logo_upload']) {
danielebarchiesi@0 707 unset($values['logo_upload']);
danielebarchiesi@0 708 $filename = file_unmanaged_copy($file->uri);
danielebarchiesi@0 709 $values['default_logo'] = 0;
danielebarchiesi@0 710 $values['logo_path'] = $filename;
danielebarchiesi@0 711 $values['toggle_logo'] = 1;
danielebarchiesi@0 712 }
danielebarchiesi@0 713 if ($file = $values['favicon_upload']) {
danielebarchiesi@0 714 unset($values['favicon_upload']);
danielebarchiesi@0 715 $filename = file_unmanaged_copy($file->uri);
danielebarchiesi@0 716 $values['default_favicon'] = 0;
danielebarchiesi@0 717 $values['favicon_path'] = $filename;
danielebarchiesi@0 718 $values['toggle_favicon'] = 1;
danielebarchiesi@0 719 }
danielebarchiesi@0 720
danielebarchiesi@0 721 // If the user entered a path relative to the system files directory for
danielebarchiesi@0 722 // a logo or favicon, store a public:// URI so the theme system can handle it.
danielebarchiesi@0 723 if (!empty($values['logo_path'])) {
danielebarchiesi@0 724 $values['logo_path'] = _system_theme_settings_validate_path($values['logo_path']);
danielebarchiesi@0 725 }
danielebarchiesi@0 726 if (!empty($values['favicon_path'])) {
danielebarchiesi@0 727 $values['favicon_path'] = _system_theme_settings_validate_path($values['favicon_path']);
danielebarchiesi@0 728 }
danielebarchiesi@0 729
danielebarchiesi@0 730 if (empty($values['default_favicon']) && !empty($values['favicon_path'])) {
danielebarchiesi@0 731 $values['favicon_mimetype'] = file_get_mimetype($values['favicon_path']);
danielebarchiesi@0 732 }
danielebarchiesi@0 733
danielebarchiesi@0 734 variable_set($key, $values);
danielebarchiesi@0 735 drupal_set_message(t('The configuration options have been saved.'));
danielebarchiesi@0 736
danielebarchiesi@0 737 cache_clear_all();
danielebarchiesi@0 738 }
danielebarchiesi@0 739
danielebarchiesi@0 740 /**
danielebarchiesi@0 741 * Recursively check compatibility.
danielebarchiesi@0 742 *
danielebarchiesi@0 743 * @param $incompatible
danielebarchiesi@0 744 * An associative array which at the end of the check contains all
danielebarchiesi@0 745 * incompatible files as the keys, their values being TRUE.
danielebarchiesi@0 746 * @param $files
danielebarchiesi@0 747 * The set of files that will be tested.
danielebarchiesi@0 748 * @param $file
danielebarchiesi@0 749 * The file at which the check starts.
danielebarchiesi@0 750 * @return
danielebarchiesi@0 751 * Returns TRUE if an incompatible file is found, NULL (no return value)
danielebarchiesi@0 752 * otherwise.
danielebarchiesi@0 753 */
danielebarchiesi@0 754 function _system_is_incompatible(&$incompatible, $files, $file) {
danielebarchiesi@0 755 if (isset($incompatible[$file->name])) {
danielebarchiesi@0 756 return TRUE;
danielebarchiesi@0 757 }
danielebarchiesi@0 758 // Recursively traverse required modules, looking for incompatible modules.
danielebarchiesi@0 759 foreach ($file->requires as $requires) {
danielebarchiesi@0 760 if (isset($files[$requires]) && _system_is_incompatible($incompatible, $files, $files[$requires])) {
danielebarchiesi@0 761 $incompatible[$file->name] = TRUE;
danielebarchiesi@0 762 return TRUE;
danielebarchiesi@0 763 }
danielebarchiesi@0 764 }
danielebarchiesi@0 765 }
danielebarchiesi@0 766
danielebarchiesi@0 767 /**
danielebarchiesi@0 768 * Menu callback; provides module enable/disable interface.
danielebarchiesi@0 769 *
danielebarchiesi@0 770 * The list of modules gets populated by module.info files, which contain each
danielebarchiesi@0 771 * module's name, description, and information about which modules it requires.
danielebarchiesi@0 772 * See drupal_parse_info_file() for information on module.info descriptors.
danielebarchiesi@0 773 *
danielebarchiesi@0 774 * Dependency checking is performed to ensure that a module:
danielebarchiesi@0 775 * - can not be enabled if there are disabled modules it requires.
danielebarchiesi@0 776 * - can not be disabled if there are enabled modules which depend on it.
danielebarchiesi@0 777 *
danielebarchiesi@0 778 * @param $form_state
danielebarchiesi@0 779 * An associative array containing the current state of the form.
danielebarchiesi@0 780 *
danielebarchiesi@0 781 * @return
danielebarchiesi@0 782 * The form array.
danielebarchiesi@0 783 *
danielebarchiesi@0 784 * @ingroup forms
danielebarchiesi@0 785 * @see theme_system_modules()
danielebarchiesi@0 786 * @see system_modules_submit()
danielebarchiesi@0 787 */
danielebarchiesi@0 788 function system_modules($form, $form_state = array()) {
danielebarchiesi@0 789 // Get current list of modules.
danielebarchiesi@0 790 $files = system_rebuild_module_data();
danielebarchiesi@0 791
danielebarchiesi@0 792 // Remove hidden modules from display list.
danielebarchiesi@0 793 $visible_files = $files;
danielebarchiesi@0 794 foreach ($visible_files as $filename => $file) {
danielebarchiesi@0 795 if (!empty($file->info['hidden'])) {
danielebarchiesi@0 796 unset($visible_files[$filename]);
danielebarchiesi@0 797 }
danielebarchiesi@0 798 }
danielebarchiesi@0 799
danielebarchiesi@0 800 uasort($visible_files, 'system_sort_modules_by_info_name');
danielebarchiesi@0 801
danielebarchiesi@0 802 // If the modules form was submitted, then system_modules_submit() runs first
danielebarchiesi@0 803 // and if there are unfilled required modules, then $form_state['storage'] is
danielebarchiesi@0 804 // filled, triggering a rebuild. In this case we need to display a
danielebarchiesi@0 805 // confirmation form.
danielebarchiesi@0 806 if (!empty($form_state['storage'])) {
danielebarchiesi@0 807 return system_modules_confirm_form($visible_files, $form_state['storage']);
danielebarchiesi@0 808 }
danielebarchiesi@0 809
danielebarchiesi@0 810 $modules = array();
danielebarchiesi@0 811 $form['modules'] = array('#tree' => TRUE);
danielebarchiesi@0 812
danielebarchiesi@0 813 // Used when checking if module implements a help page.
danielebarchiesi@0 814 $help_arg = module_exists('help') ? drupal_help_arg() : FALSE;
danielebarchiesi@0 815
danielebarchiesi@0 816 // Used when displaying modules that are required by the installation profile.
danielebarchiesi@0 817 require_once DRUPAL_ROOT . '/includes/install.inc';
danielebarchiesi@0 818 $distribution_name = check_plain(drupal_install_profile_distribution_name());
danielebarchiesi@0 819
danielebarchiesi@0 820 // Iterate through each of the modules.
danielebarchiesi@0 821 foreach ($visible_files as $filename => $module) {
danielebarchiesi@0 822 $extra = array();
danielebarchiesi@0 823 $extra['enabled'] = (bool) $module->status;
danielebarchiesi@0 824 if (!empty($module->info['required'] )) {
danielebarchiesi@0 825 $extra['disabled'] = TRUE;
danielebarchiesi@0 826 $extra['required_by'][] = $distribution_name . (!empty($module->info['explanation']) ? ' ('. $module->info['explanation'] .')' : '');
danielebarchiesi@0 827 }
danielebarchiesi@0 828
danielebarchiesi@0 829 // If this module requires other modules, add them to the array.
danielebarchiesi@0 830 foreach ($module->requires as $requires => $v) {
danielebarchiesi@0 831 if (!isset($files[$requires])) {
danielebarchiesi@0 832 $extra['requires'][$requires] = t('@module (<span class="admin-missing">missing</span>)', array('@module' => drupal_ucfirst($requires)));
danielebarchiesi@0 833 $extra['disabled'] = TRUE;
danielebarchiesi@0 834 }
danielebarchiesi@0 835 // Only display visible modules.
danielebarchiesi@0 836 elseif (isset($visible_files[$requires])) {
danielebarchiesi@0 837 $requires_name = $files[$requires]->info['name'];
danielebarchiesi@0 838 // Disable this module if it is incompatible with the dependency's version.
danielebarchiesi@0 839 if ($incompatible_version = drupal_check_incompatibility($v, str_replace(DRUPAL_CORE_COMPATIBILITY . '-', '', $files[$requires]->info['version']))) {
danielebarchiesi@0 840 $extra['requires'][$requires] = t('@module (<span class="admin-missing">incompatible with</span> version @version)', array(
danielebarchiesi@0 841 '@module' => $requires_name . $incompatible_version,
danielebarchiesi@0 842 '@version' => $files[$requires]->info['version'],
danielebarchiesi@0 843 ));
danielebarchiesi@0 844 $extra['disabled'] = TRUE;
danielebarchiesi@0 845 }
danielebarchiesi@0 846 // Disable this module if the dependency is incompatible with this
danielebarchiesi@0 847 // version of Drupal core.
danielebarchiesi@0 848 elseif ($files[$requires]->info['core'] != DRUPAL_CORE_COMPATIBILITY) {
danielebarchiesi@0 849 $extra['requires'][$requires] = t('@module (<span class="admin-missing">incompatible with</span> this version of Drupal core)', array(
danielebarchiesi@0 850 '@module' => $requires_name,
danielebarchiesi@0 851 ));
danielebarchiesi@0 852 $extra['disabled'] = TRUE;
danielebarchiesi@0 853 }
danielebarchiesi@0 854 elseif ($files[$requires]->status) {
danielebarchiesi@0 855 $extra['requires'][$requires] = t('@module (<span class="admin-enabled">enabled</span>)', array('@module' => $requires_name));
danielebarchiesi@0 856 }
danielebarchiesi@0 857 else {
danielebarchiesi@0 858 $extra['requires'][$requires] = t('@module (<span class="admin-disabled">disabled</span>)', array('@module' => $requires_name));
danielebarchiesi@0 859 }
danielebarchiesi@0 860 }
danielebarchiesi@0 861 }
danielebarchiesi@0 862 // Generate link for module's help page, if there is one.
danielebarchiesi@0 863 if ($help_arg && $module->status && in_array($filename, module_implements('help'))) {
danielebarchiesi@0 864 if (module_invoke($filename, 'help', "admin/help#$filename", $help_arg)) {
danielebarchiesi@0 865 $extra['links']['help'] = array(
danielebarchiesi@0 866 '#type' => 'link',
danielebarchiesi@0 867 '#title' => t('Help'),
danielebarchiesi@0 868 '#href' => "admin/help/$filename",
danielebarchiesi@0 869 '#options' => array('attributes' => array('class' => array('module-link', 'module-link-help'), 'title' => t('Help'))),
danielebarchiesi@0 870 );
danielebarchiesi@0 871 }
danielebarchiesi@0 872 }
danielebarchiesi@0 873 // Generate link for module's permission, if the user has access to it.
danielebarchiesi@0 874 if ($module->status && user_access('administer permissions') && in_array($filename, module_implements('permission'))) {
danielebarchiesi@0 875 $extra['links']['permissions'] = array(
danielebarchiesi@0 876 '#type' => 'link',
danielebarchiesi@0 877 '#title' => t('Permissions'),
danielebarchiesi@0 878 '#href' => 'admin/people/permissions',
danielebarchiesi@0 879 '#options' => array('fragment' => 'module-' . $filename, 'attributes' => array('class' => array('module-link', 'module-link-permissions'), 'title' => t('Configure permissions'))),
danielebarchiesi@0 880 );
danielebarchiesi@0 881 }
danielebarchiesi@0 882 // Generate link for module's configuration page, if the module provides
danielebarchiesi@0 883 // one.
danielebarchiesi@0 884 if ($module->status && isset($module->info['configure'])) {
danielebarchiesi@0 885 $configure_link = menu_get_item($module->info['configure']);
danielebarchiesi@0 886 if ($configure_link['access']) {
danielebarchiesi@0 887 $extra['links']['configure'] = array(
danielebarchiesi@0 888 '#type' => 'link',
danielebarchiesi@0 889 '#title' => t('Configure'),
danielebarchiesi@0 890 '#href' => $configure_link['href'],
danielebarchiesi@0 891 '#options' => array('attributes' => array('class' => array('module-link', 'module-link-configure'), 'title' => $configure_link['description'])),
danielebarchiesi@0 892 );
danielebarchiesi@0 893 }
danielebarchiesi@0 894 }
danielebarchiesi@0 895
danielebarchiesi@0 896 // If this module is required by other modules, list those, and then make it
danielebarchiesi@0 897 // impossible to disable this one.
danielebarchiesi@0 898 foreach ($module->required_by as $required_by => $v) {
danielebarchiesi@0 899 // Hidden modules are unset already.
danielebarchiesi@0 900 if (isset($visible_files[$required_by])) {
danielebarchiesi@0 901 if ($files[$required_by]->status == 1 && $module->status == 1) {
danielebarchiesi@0 902 $extra['required_by'][] = t('@module (<span class="admin-enabled">enabled</span>)', array('@module' => $files[$required_by]->info['name']));
danielebarchiesi@0 903 $extra['disabled'] = TRUE;
danielebarchiesi@0 904 }
danielebarchiesi@0 905 else {
danielebarchiesi@0 906 $extra['required_by'][] = t('@module (<span class="admin-disabled">disabled</span>)', array('@module' => $files[$required_by]->info['name']));
danielebarchiesi@0 907 }
danielebarchiesi@0 908 }
danielebarchiesi@0 909 }
danielebarchiesi@0 910 $form['modules'][$module->info['package']][$filename] = _system_modules_build_row($module->info, $extra);
danielebarchiesi@0 911 }
danielebarchiesi@0 912
danielebarchiesi@0 913 // Add basic information to the fieldsets.
danielebarchiesi@0 914 foreach (element_children($form['modules']) as $package) {
danielebarchiesi@0 915 $form['modules'][$package] += array(
danielebarchiesi@0 916 '#type' => 'fieldset',
danielebarchiesi@0 917 '#title' => t($package),
danielebarchiesi@0 918 '#collapsible' => TRUE,
danielebarchiesi@0 919 '#theme' => 'system_modules_fieldset',
danielebarchiesi@0 920 '#header' => array(
danielebarchiesi@0 921 array('data' => t('Enabled'), 'class' => array('checkbox')),
danielebarchiesi@0 922 t('Name'),
danielebarchiesi@0 923 t('Version'),
danielebarchiesi@0 924 t('Description'),
danielebarchiesi@0 925 array('data' => t('Operations'), 'colspan' => 3),
danielebarchiesi@0 926 ),
danielebarchiesi@0 927 // Ensure that the "Core" package fieldset comes first.
danielebarchiesi@0 928 '#weight' => $package == 'Core' ? -10 : NULL,
danielebarchiesi@0 929 );
danielebarchiesi@0 930 }
danielebarchiesi@0 931
danielebarchiesi@0 932 // Lastly, sort all fieldsets by title.
danielebarchiesi@0 933 uasort($form['modules'], 'element_sort_by_title');
danielebarchiesi@0 934
danielebarchiesi@0 935 $form['actions'] = array('#type' => 'actions');
danielebarchiesi@0 936 $form['actions']['submit'] = array(
danielebarchiesi@0 937 '#type' => 'submit',
danielebarchiesi@0 938 '#value' => t('Save configuration'),
danielebarchiesi@0 939 );
danielebarchiesi@0 940 $form['#action'] = url('admin/modules/list/confirm');
danielebarchiesi@0 941
danielebarchiesi@0 942 return $form;
danielebarchiesi@0 943 }
danielebarchiesi@0 944
danielebarchiesi@0 945 /**
danielebarchiesi@0 946 * Array sorting callback; sorts modules or themes by their name.
danielebarchiesi@0 947 */
danielebarchiesi@0 948 function system_sort_modules_by_info_name($a, $b) {
danielebarchiesi@0 949 return strcasecmp($a->info['name'], $b->info['name']);
danielebarchiesi@0 950 }
danielebarchiesi@0 951
danielebarchiesi@0 952 /**
danielebarchiesi@0 953 * Array sorting callback; sorts modules or themes by their name.
danielebarchiesi@0 954 */
danielebarchiesi@0 955 function system_sort_themes($a, $b) {
danielebarchiesi@0 956 if ($a->is_default) {
danielebarchiesi@0 957 return -1;
danielebarchiesi@0 958 }
danielebarchiesi@0 959 if ($b->is_default) {
danielebarchiesi@0 960 return 1;
danielebarchiesi@0 961 }
danielebarchiesi@0 962 return strcasecmp($a->info['name'], $b->info['name']);
danielebarchiesi@0 963 }
danielebarchiesi@0 964
danielebarchiesi@0 965 /**
danielebarchiesi@0 966 * Build a table row for the system modules page.
danielebarchiesi@0 967 */
danielebarchiesi@0 968 function _system_modules_build_row($info, $extra) {
danielebarchiesi@0 969 // Add in the defaults.
danielebarchiesi@0 970 $extra += array(
danielebarchiesi@0 971 'requires' => array(),
danielebarchiesi@0 972 'required_by' => array(),
danielebarchiesi@0 973 'disabled' => FALSE,
danielebarchiesi@0 974 'enabled' => FALSE,
danielebarchiesi@0 975 'links' => array(),
danielebarchiesi@0 976 );
danielebarchiesi@0 977 $form = array(
danielebarchiesi@0 978 '#tree' => TRUE,
danielebarchiesi@0 979 );
danielebarchiesi@0 980 // Set the basic properties.
danielebarchiesi@0 981 $form['name'] = array(
danielebarchiesi@0 982 '#markup' => $info['name'],
danielebarchiesi@0 983 );
danielebarchiesi@0 984 $form['description'] = array(
danielebarchiesi@0 985 '#markup' => t($info['description']),
danielebarchiesi@0 986 );
danielebarchiesi@0 987 $form['version'] = array(
danielebarchiesi@0 988 '#markup' => $info['version'],
danielebarchiesi@0 989 );
danielebarchiesi@0 990 $form['#requires'] = $extra['requires'];
danielebarchiesi@0 991 $form['#required_by'] = $extra['required_by'];
danielebarchiesi@0 992
danielebarchiesi@0 993 // Check the compatibilities.
danielebarchiesi@0 994 $compatible = TRUE;
danielebarchiesi@0 995 $status_short = '';
danielebarchiesi@0 996 $status_long = '';
danielebarchiesi@0 997
danielebarchiesi@0 998 // Check the core compatibility.
danielebarchiesi@0 999 if (!isset($info['core']) || $info['core'] != DRUPAL_CORE_COMPATIBILITY) {
danielebarchiesi@0 1000 $compatible = FALSE;
danielebarchiesi@0 1001 $status_short .= t('Incompatible with this version of Drupal core.');
danielebarchiesi@0 1002 $status_long .= t('This version is not compatible with Drupal !core_version and should be replaced.', array('!core_version' => DRUPAL_CORE_COMPATIBILITY));
danielebarchiesi@0 1003 }
danielebarchiesi@0 1004
danielebarchiesi@0 1005 // Ensure this module is compatible with the currently installed version of PHP.
danielebarchiesi@0 1006 if (version_compare(phpversion(), $info['php']) < 0) {
danielebarchiesi@0 1007 $compatible = FALSE;
danielebarchiesi@0 1008 $status_short .= t('Incompatible with this version of PHP');
danielebarchiesi@0 1009 $php_required = $info['php'];
danielebarchiesi@0 1010 if (substr_count($info['php'], '.') < 2) {
danielebarchiesi@0 1011 $php_required .= '.*';
danielebarchiesi@0 1012 }
danielebarchiesi@0 1013 $status_long .= t('This module requires PHP version @php_required and is incompatible with PHP version !php_version.', array('@php_required' => $php_required, '!php_version' => phpversion()));
danielebarchiesi@0 1014 }
danielebarchiesi@0 1015
danielebarchiesi@0 1016 // If this module is compatible, present a checkbox indicating
danielebarchiesi@0 1017 // this module may be installed. Otherwise, show a big red X.
danielebarchiesi@0 1018 if ($compatible) {
danielebarchiesi@0 1019 $form['enable'] = array(
danielebarchiesi@0 1020 '#type' => 'checkbox',
danielebarchiesi@0 1021 '#title' => t('Enable'),
danielebarchiesi@0 1022 '#default_value' => $extra['enabled'],
danielebarchiesi@0 1023 );
danielebarchiesi@0 1024 if ($extra['disabled']) {
danielebarchiesi@0 1025 $form['enable']['#disabled'] = TRUE;
danielebarchiesi@0 1026 }
danielebarchiesi@0 1027 }
danielebarchiesi@0 1028 else {
danielebarchiesi@0 1029 $form['enable'] = array(
danielebarchiesi@0 1030 '#markup' => theme('image', array('path' => 'misc/watchdog-error.png', 'alt' => $status_short, 'title' => $status_short)),
danielebarchiesi@0 1031 );
danielebarchiesi@0 1032 $form['description']['#markup'] .= theme('system_modules_incompatible', array('message' => $status_long));
danielebarchiesi@0 1033 }
danielebarchiesi@0 1034
danielebarchiesi@0 1035 // Build operation links.
danielebarchiesi@0 1036 foreach (array('help', 'permissions', 'configure') as $key) {
danielebarchiesi@0 1037 $form['links'][$key] = (isset($extra['links'][$key]) ? $extra['links'][$key] : array());
danielebarchiesi@0 1038 }
danielebarchiesi@0 1039
danielebarchiesi@0 1040 return $form;
danielebarchiesi@0 1041 }
danielebarchiesi@0 1042
danielebarchiesi@0 1043 /**
danielebarchiesi@0 1044 * Display confirmation form for required modules.
danielebarchiesi@0 1045 *
danielebarchiesi@0 1046 * @param $modules
danielebarchiesi@0 1047 * Array of module file objects as returned from system_rebuild_module_data().
danielebarchiesi@0 1048 * @param $storage
danielebarchiesi@0 1049 * The contents of $form_state['storage']; an array with two
danielebarchiesi@0 1050 * elements: the list of required modules and the list of status
danielebarchiesi@0 1051 * form field values from the previous screen.
danielebarchiesi@0 1052 * @ingroup forms
danielebarchiesi@0 1053 */
danielebarchiesi@0 1054 function system_modules_confirm_form($modules, $storage) {
danielebarchiesi@0 1055 $items = array();
danielebarchiesi@0 1056
danielebarchiesi@0 1057 $form['validation_modules'] = array('#type' => 'value', '#value' => $modules);
danielebarchiesi@0 1058 $form['status']['#tree'] = TRUE;
danielebarchiesi@0 1059
danielebarchiesi@0 1060 foreach ($storage['more_required'] as $info) {
danielebarchiesi@0 1061 $t_argument = array(
danielebarchiesi@0 1062 '@module' => $info['name'],
danielebarchiesi@0 1063 '@required' => implode(', ', $info['requires']),
danielebarchiesi@0 1064 );
danielebarchiesi@0 1065 $items[] = format_plural(count($info['requires']), 'You must enable the @required module to install @module.', 'You must enable the @required modules to install @module.', $t_argument);
danielebarchiesi@0 1066 }
danielebarchiesi@0 1067
danielebarchiesi@0 1068 foreach ($storage['missing_modules'] as $name => $info) {
danielebarchiesi@0 1069 $t_argument = array(
danielebarchiesi@0 1070 '@module' => $name,
danielebarchiesi@0 1071 '@depends' => implode(', ', $info['depends']),
danielebarchiesi@0 1072 );
danielebarchiesi@0 1073 $items[] = format_plural(count($info['depends']), 'The @module module is missing, so the following module will be disabled: @depends.', 'The @module module is missing, so the following modules will be disabled: @depends.', $t_argument);
danielebarchiesi@0 1074 }
danielebarchiesi@0 1075
danielebarchiesi@0 1076 $form['text'] = array('#markup' => theme('item_list', array('items' => $items)));
danielebarchiesi@0 1077
danielebarchiesi@0 1078 if ($form) {
danielebarchiesi@0 1079 // Set some default form values
danielebarchiesi@0 1080 $form = confirm_form(
danielebarchiesi@0 1081 $form,
danielebarchiesi@0 1082 t('Some required modules must be enabled'),
danielebarchiesi@0 1083 'admin/modules',
danielebarchiesi@0 1084 t('Would you like to continue with the above?'),
danielebarchiesi@0 1085 t('Continue'),
danielebarchiesi@0 1086 t('Cancel'));
danielebarchiesi@0 1087 return $form;
danielebarchiesi@0 1088 }
danielebarchiesi@0 1089 }
danielebarchiesi@0 1090
danielebarchiesi@0 1091 /**
danielebarchiesi@0 1092 * Submit callback; handles modules form submission.
danielebarchiesi@0 1093 */
danielebarchiesi@0 1094 function system_modules_submit($form, &$form_state) {
danielebarchiesi@0 1095 include_once DRUPAL_ROOT . '/includes/install.inc';
danielebarchiesi@0 1096
danielebarchiesi@0 1097 // Builds list of modules.
danielebarchiesi@0 1098 $modules = array();
danielebarchiesi@0 1099 // If we're not coming from the confirmation form, build the list of modules.
danielebarchiesi@0 1100 if (empty($form_state['storage'])) {
danielebarchiesi@0 1101 // If we're not coming from the confirmation form, build the module list.
danielebarchiesi@0 1102 foreach ($form_state['values']['modules'] as $group_name => $group) {
danielebarchiesi@0 1103 foreach ($group as $module => $enabled) {
danielebarchiesi@0 1104 $modules[$module] = array('group' => $group_name, 'enabled' => $enabled['enable']);
danielebarchiesi@0 1105 }
danielebarchiesi@0 1106 }
danielebarchiesi@0 1107 }
danielebarchiesi@0 1108 else {
danielebarchiesi@0 1109 // If we are coming from the confirmation form, fetch
danielebarchiesi@0 1110 // the modules out of $form_state.
danielebarchiesi@0 1111 $modules = $form_state['storage']['modules'];
danielebarchiesi@0 1112 }
danielebarchiesi@0 1113
danielebarchiesi@0 1114 // Collect data for all modules to be able to determine dependencies.
danielebarchiesi@0 1115 $files = system_rebuild_module_data();
danielebarchiesi@0 1116
danielebarchiesi@0 1117 // Sorts modules by weight.
danielebarchiesi@0 1118 $sort = array();
danielebarchiesi@0 1119 foreach (array_keys($modules) as $module) {
danielebarchiesi@0 1120 $sort[$module] = $files[$module]->sort;
danielebarchiesi@0 1121 }
danielebarchiesi@0 1122 array_multisort($sort, $modules);
danielebarchiesi@0 1123
danielebarchiesi@0 1124 // Makes sure all required modules are set to be enabled.
danielebarchiesi@0 1125 $more_required = array();
danielebarchiesi@0 1126 $missing_modules = array();
danielebarchiesi@0 1127 foreach ($modules as $name => $module) {
danielebarchiesi@0 1128 if ($module['enabled']) {
danielebarchiesi@0 1129 // Checks that all dependencies are set to be enabled. Stores the ones
danielebarchiesi@0 1130 // that are not in $dependencies variable so that the user can be alerted
danielebarchiesi@0 1131 // in the confirmation form that more modules need to be enabled.
danielebarchiesi@0 1132 $dependencies = array();
danielebarchiesi@0 1133 foreach (array_keys($files[$name]->requires) as $required) {
danielebarchiesi@0 1134 if (empty($modules[$required]['enabled'])) {
danielebarchiesi@0 1135 if (isset($files[$required])) {
danielebarchiesi@0 1136 $dependencies[] = $files[$required]->info['name'];
danielebarchiesi@0 1137 $modules[$required]['enabled'] = TRUE;
danielebarchiesi@0 1138 }
danielebarchiesi@0 1139 else {
danielebarchiesi@0 1140 $missing_modules[$required]['depends'][] = $name;
danielebarchiesi@0 1141 $modules[$name]['enabled'] = FALSE;
danielebarchiesi@0 1142 }
danielebarchiesi@0 1143 }
danielebarchiesi@0 1144 }
danielebarchiesi@0 1145
danielebarchiesi@0 1146 // Stores additional modules that need to be enabled in $more_required.
danielebarchiesi@0 1147 if (!empty($dependencies)) {
danielebarchiesi@0 1148 $more_required[$name] = array(
danielebarchiesi@0 1149 'name' => $files[$name]->info['name'],
danielebarchiesi@0 1150 'requires' => $dependencies,
danielebarchiesi@0 1151 );
danielebarchiesi@0 1152 }
danielebarchiesi@0 1153 }
danielebarchiesi@0 1154 }
danielebarchiesi@0 1155
danielebarchiesi@0 1156 // Redirects to confirmation form if more modules need to be enabled.
danielebarchiesi@0 1157 if ((!empty($more_required) || !empty($missing_modules)) && !isset($form_state['values']['confirm'])) {
danielebarchiesi@0 1158 $form_state['storage'] = array(
danielebarchiesi@0 1159 'more_required' => $more_required,
danielebarchiesi@0 1160 'modules' => $modules,
danielebarchiesi@0 1161 'missing_modules' => $missing_modules,
danielebarchiesi@0 1162 );
danielebarchiesi@0 1163 $form_state['rebuild'] = TRUE;
danielebarchiesi@0 1164 return;
danielebarchiesi@0 1165 }
danielebarchiesi@0 1166
danielebarchiesi@0 1167 // Invokes hook_requirements('install'). If failures are detected, makes sure
danielebarchiesi@0 1168 // the dependent modules aren't installed either.
danielebarchiesi@0 1169 foreach ($modules as $name => $module) {
danielebarchiesi@0 1170 // Only invoke hook_requirements() on modules that are going to be installed.
danielebarchiesi@0 1171 if ($module['enabled'] && drupal_get_installed_schema_version($name) == SCHEMA_UNINSTALLED) {
danielebarchiesi@0 1172 if (!drupal_check_module($name)) {
danielebarchiesi@0 1173 $modules[$name]['enabled'] = FALSE;
danielebarchiesi@0 1174 foreach (array_keys($files[$name]->required_by) as $required_by) {
danielebarchiesi@0 1175 $modules[$required_by]['enabled'] = FALSE;
danielebarchiesi@0 1176 }
danielebarchiesi@0 1177 }
danielebarchiesi@0 1178 }
danielebarchiesi@0 1179 }
danielebarchiesi@0 1180
danielebarchiesi@0 1181 // Initializes array of actions.
danielebarchiesi@0 1182 $actions = array(
danielebarchiesi@0 1183 'enable' => array(),
danielebarchiesi@0 1184 'disable' => array(),
danielebarchiesi@0 1185 'install' => array(),
danielebarchiesi@0 1186 );
danielebarchiesi@0 1187
danielebarchiesi@0 1188 // Builds arrays of modules that need to be enabled, disabled, and installed.
danielebarchiesi@0 1189 foreach ($modules as $name => $module) {
danielebarchiesi@0 1190 if ($module['enabled']) {
danielebarchiesi@0 1191 if (drupal_get_installed_schema_version($name) == SCHEMA_UNINSTALLED) {
danielebarchiesi@0 1192 $actions['install'][] = $name;
danielebarchiesi@0 1193 $actions['enable'][] = $name;
danielebarchiesi@0 1194 }
danielebarchiesi@0 1195 elseif (!module_exists($name)) {
danielebarchiesi@0 1196 $actions['enable'][] = $name;
danielebarchiesi@0 1197 }
danielebarchiesi@0 1198 }
danielebarchiesi@0 1199 elseif (module_exists($name)) {
danielebarchiesi@0 1200 $actions['disable'][] = $name;
danielebarchiesi@0 1201 }
danielebarchiesi@0 1202 }
danielebarchiesi@0 1203
danielebarchiesi@0 1204 // Gets list of modules prior to install process, unsets $form_state['storage']
danielebarchiesi@0 1205 // so we don't get redirected back to the confirmation form.
danielebarchiesi@0 1206 $pre_install_list = module_list();
danielebarchiesi@0 1207 unset($form_state['storage']);
danielebarchiesi@0 1208
danielebarchiesi@0 1209 // Reverse the 'enable' list, to order dependencies before dependents.
danielebarchiesi@0 1210 krsort($actions['enable']);
danielebarchiesi@0 1211
danielebarchiesi@0 1212 // Installs, enables, and disables modules.
danielebarchiesi@0 1213 module_enable($actions['enable'], FALSE);
danielebarchiesi@0 1214 module_disable($actions['disable'], FALSE);
danielebarchiesi@0 1215
danielebarchiesi@0 1216 // Gets module list after install process, flushes caches and displays a
danielebarchiesi@0 1217 // message if there are changes.
danielebarchiesi@0 1218 $post_install_list = module_list(TRUE);
danielebarchiesi@0 1219 if ($pre_install_list != $post_install_list) {
danielebarchiesi@0 1220 drupal_flush_all_caches();
danielebarchiesi@0 1221 drupal_set_message(t('The configuration options have been saved.'));
danielebarchiesi@0 1222 }
danielebarchiesi@0 1223
danielebarchiesi@0 1224 $form_state['redirect'] = 'admin/modules';
danielebarchiesi@0 1225 }
danielebarchiesi@0 1226
danielebarchiesi@0 1227 /**
danielebarchiesi@0 1228 * Uninstall functions
danielebarchiesi@0 1229 */
danielebarchiesi@0 1230
danielebarchiesi@0 1231 /**
danielebarchiesi@0 1232 * Builds a form of currently disabled modules.
danielebarchiesi@0 1233 *
danielebarchiesi@0 1234 * @ingroup forms
danielebarchiesi@0 1235 * @see system_modules_uninstall_validate()
danielebarchiesi@0 1236 * @see system_modules_uninstall_submit()
danielebarchiesi@0 1237 * @param $form_state['values']
danielebarchiesi@0 1238 * Submitted form values.
danielebarchiesi@0 1239 * @return
danielebarchiesi@0 1240 * A form array representing the currently disabled modules.
danielebarchiesi@0 1241 */
danielebarchiesi@0 1242 function system_modules_uninstall($form, $form_state = NULL) {
danielebarchiesi@0 1243 // Make sure the install API is available.
danielebarchiesi@0 1244 include_once DRUPAL_ROOT . '/includes/install.inc';
danielebarchiesi@0 1245
danielebarchiesi@0 1246 // Display the confirm form if any modules have been submitted.
danielebarchiesi@0 1247 if (!empty($form_state['storage']) && $confirm_form = system_modules_uninstall_confirm_form($form_state['storage'])) {
danielebarchiesi@0 1248 return $confirm_form;
danielebarchiesi@0 1249 }
danielebarchiesi@0 1250
danielebarchiesi@0 1251 // Get a list of disabled, installed modules.
danielebarchiesi@0 1252 $all_modules = system_rebuild_module_data();
danielebarchiesi@0 1253 $disabled_modules = array();
danielebarchiesi@0 1254 foreach ($all_modules as $name => $module) {
danielebarchiesi@0 1255 if (empty($module->status) && $module->schema_version > SCHEMA_UNINSTALLED) {
danielebarchiesi@0 1256 $disabled_modules[$name] = $module;
danielebarchiesi@0 1257 }
danielebarchiesi@0 1258 }
danielebarchiesi@0 1259
danielebarchiesi@0 1260 // Only build the rest of the form if there are any modules available to
danielebarchiesi@0 1261 // uninstall.
danielebarchiesi@0 1262 if (!empty($disabled_modules)) {
danielebarchiesi@0 1263 $profile = drupal_get_profile();
danielebarchiesi@0 1264 uasort($disabled_modules, 'system_sort_modules_by_info_name');
danielebarchiesi@0 1265 $form['uninstall'] = array('#tree' => TRUE);
danielebarchiesi@0 1266 foreach ($disabled_modules as $module) {
danielebarchiesi@0 1267 $module_name = $module->info['name'] ? $module->info['name'] : $module->name;
danielebarchiesi@0 1268 $form['modules'][$module->name]['#module_name'] = $module_name;
danielebarchiesi@0 1269 $form['modules'][$module->name]['name']['#markup'] = $module_name;
danielebarchiesi@0 1270 $form['modules'][$module->name]['description']['#markup'] = t($module->info['description']);
danielebarchiesi@0 1271 $form['uninstall'][$module->name] = array(
danielebarchiesi@0 1272 '#type' => 'checkbox',
danielebarchiesi@0 1273 '#title' => t('Uninstall @module module', array('@module' => $module_name)),
danielebarchiesi@0 1274 '#title_display' => 'invisible',
danielebarchiesi@0 1275 );
danielebarchiesi@0 1276 // All modules which depend on this one must be uninstalled first, before
danielebarchiesi@0 1277 // we can allow this module to be uninstalled. (The installation profile
danielebarchiesi@0 1278 // is excluded from this list.)
danielebarchiesi@0 1279 foreach (array_keys($module->required_by) as $dependent) {
danielebarchiesi@0 1280 if ($dependent != $profile && drupal_get_installed_schema_version($dependent) != SCHEMA_UNINSTALLED) {
danielebarchiesi@0 1281 $dependent_name = isset($all_modules[$dependent]->info['name']) ? $all_modules[$dependent]->info['name'] : $dependent;
danielebarchiesi@0 1282 $form['modules'][$module->name]['#required_by'][] = $dependent_name;
danielebarchiesi@0 1283 $form['uninstall'][$module->name]['#disabled'] = TRUE;
danielebarchiesi@0 1284 }
danielebarchiesi@0 1285 }
danielebarchiesi@0 1286 }
danielebarchiesi@0 1287 $form['actions'] = array('#type' => 'actions');
danielebarchiesi@0 1288 $form['actions']['submit'] = array(
danielebarchiesi@0 1289 '#type' => 'submit',
danielebarchiesi@0 1290 '#value' => t('Uninstall'),
danielebarchiesi@0 1291 );
danielebarchiesi@0 1292 $form['#action'] = url('admin/modules/uninstall/confirm');
danielebarchiesi@0 1293 }
danielebarchiesi@0 1294 else {
danielebarchiesi@0 1295 $form['modules'] = array();
danielebarchiesi@0 1296 }
danielebarchiesi@0 1297
danielebarchiesi@0 1298 return $form;
danielebarchiesi@0 1299 }
danielebarchiesi@0 1300
danielebarchiesi@0 1301 /**
danielebarchiesi@0 1302 * Confirm uninstall of selected modules.
danielebarchiesi@0 1303 *
danielebarchiesi@0 1304 * @ingroup forms
danielebarchiesi@0 1305 * @param $storage
danielebarchiesi@0 1306 * An associative array of modules selected to be uninstalled.
danielebarchiesi@0 1307 * @return
danielebarchiesi@0 1308 * A form array representing modules to confirm.
danielebarchiesi@0 1309 */
danielebarchiesi@0 1310 function system_modules_uninstall_confirm_form($storage) {
danielebarchiesi@0 1311 // Nothing to build.
danielebarchiesi@0 1312 if (empty($storage)) {
danielebarchiesi@0 1313 return;
danielebarchiesi@0 1314 }
danielebarchiesi@0 1315
danielebarchiesi@0 1316 // Construct the hidden form elements and list items.
danielebarchiesi@0 1317 foreach (array_filter($storage['uninstall']) as $module => $value) {
danielebarchiesi@0 1318 $info = drupal_parse_info_file(drupal_get_path('module', $module) . '/' . $module . '.info');
danielebarchiesi@0 1319 $uninstall[] = $info['name'];
danielebarchiesi@0 1320 $form['uninstall'][$module] = array('#type' => 'hidden',
danielebarchiesi@0 1321 '#value' => 1,
danielebarchiesi@0 1322 );
danielebarchiesi@0 1323 }
danielebarchiesi@0 1324
danielebarchiesi@0 1325 // Display a confirm form if modules have been selected.
danielebarchiesi@0 1326 if (isset($uninstall)) {
danielebarchiesi@0 1327 $form['#confirmed'] = TRUE;
danielebarchiesi@0 1328 $form['uninstall']['#tree'] = TRUE;
danielebarchiesi@0 1329 $form['modules'] = array('#markup' => '<p>' . t('The following modules will be completely uninstalled from your site, and <em>all data from these modules will be lost</em>!') . '</p>' . theme('item_list', array('items' => $uninstall)));
danielebarchiesi@0 1330 $form = confirm_form(
danielebarchiesi@0 1331 $form,
danielebarchiesi@0 1332 t('Confirm uninstall'),
danielebarchiesi@0 1333 'admin/modules/uninstall',
danielebarchiesi@0 1334 t('Would you like to continue with uninstalling the above?'),
danielebarchiesi@0 1335 t('Uninstall'),
danielebarchiesi@0 1336 t('Cancel'));
danielebarchiesi@0 1337 return $form;
danielebarchiesi@0 1338 }
danielebarchiesi@0 1339 }
danielebarchiesi@0 1340
danielebarchiesi@0 1341 /**
danielebarchiesi@0 1342 * Validates the submitted uninstall form.
danielebarchiesi@0 1343 */
danielebarchiesi@0 1344 function system_modules_uninstall_validate($form, &$form_state) {
danielebarchiesi@0 1345 // Form submitted, but no modules selected.
danielebarchiesi@0 1346 if (!count(array_filter($form_state['values']['uninstall']))) {
danielebarchiesi@0 1347 drupal_set_message(t('No modules selected.'), 'error');
danielebarchiesi@0 1348 drupal_goto('admin/modules/uninstall');
danielebarchiesi@0 1349 }
danielebarchiesi@0 1350 }
danielebarchiesi@0 1351
danielebarchiesi@0 1352 /**
danielebarchiesi@0 1353 * Processes the submitted uninstall form.
danielebarchiesi@0 1354 */
danielebarchiesi@0 1355 function system_modules_uninstall_submit($form, &$form_state) {
danielebarchiesi@0 1356 // Make sure the install API is available.
danielebarchiesi@0 1357 include_once DRUPAL_ROOT . '/includes/install.inc';
danielebarchiesi@0 1358
danielebarchiesi@0 1359 if (!empty($form['#confirmed'])) {
danielebarchiesi@0 1360 // Call the uninstall routine for each selected module.
danielebarchiesi@0 1361 $modules = array_keys($form_state['values']['uninstall']);
danielebarchiesi@0 1362 drupal_uninstall_modules($modules);
danielebarchiesi@0 1363 drupal_set_message(t('The selected modules have been uninstalled.'));
danielebarchiesi@0 1364
danielebarchiesi@0 1365 $form_state['redirect'] = 'admin/modules/uninstall';
danielebarchiesi@0 1366 }
danielebarchiesi@0 1367 else {
danielebarchiesi@0 1368 $form_state['storage'] = $form_state['values'];
danielebarchiesi@0 1369 $form_state['rebuild'] = TRUE;
danielebarchiesi@0 1370 }
danielebarchiesi@0 1371 }
danielebarchiesi@0 1372
danielebarchiesi@0 1373 /**
danielebarchiesi@0 1374 * Menu callback. Display blocked IP addresses.
danielebarchiesi@0 1375 *
danielebarchiesi@0 1376 * @param $default_ip
danielebarchiesi@0 1377 * Optional IP address to be passed on to drupal_get_form() for
danielebarchiesi@0 1378 * use as the default value of the IP address form field.
danielebarchiesi@0 1379 */
danielebarchiesi@0 1380 function system_ip_blocking($default_ip = '') {
danielebarchiesi@0 1381 $rows = array();
danielebarchiesi@0 1382 $header = array(t('Blocked IP addresses'), t('Operations'));
danielebarchiesi@0 1383 $result = db_query('SELECT * FROM {blocked_ips}');
danielebarchiesi@0 1384 foreach ($result as $ip) {
danielebarchiesi@0 1385 $rows[] = array(
danielebarchiesi@0 1386 $ip->ip,
danielebarchiesi@0 1387 l(t('delete'), "admin/config/people/ip-blocking/delete/$ip->iid"),
danielebarchiesi@0 1388 );
danielebarchiesi@0 1389 }
danielebarchiesi@0 1390
danielebarchiesi@0 1391 $build['system_ip_blocking_form'] = drupal_get_form('system_ip_blocking_form', $default_ip);
danielebarchiesi@0 1392
danielebarchiesi@0 1393 $build['system_ip_blocking_table'] = array(
danielebarchiesi@0 1394 '#theme' => 'table',
danielebarchiesi@0 1395 '#header' => $header,
danielebarchiesi@0 1396 '#rows' => $rows,
danielebarchiesi@0 1397 '#empty' => t('No blocked IP addresses available.'),
danielebarchiesi@0 1398 );
danielebarchiesi@0 1399
danielebarchiesi@0 1400 return $build;
danielebarchiesi@0 1401 }
danielebarchiesi@0 1402
danielebarchiesi@0 1403 /**
danielebarchiesi@0 1404 * Define the form for blocking IP addresses.
danielebarchiesi@0 1405 *
danielebarchiesi@0 1406 * @ingroup forms
danielebarchiesi@0 1407 * @see system_ip_blocking_form_validate()
danielebarchiesi@0 1408 * @see system_ip_blocking_form_submit()
danielebarchiesi@0 1409 */
danielebarchiesi@0 1410 function system_ip_blocking_form($form, $form_state, $default_ip) {
danielebarchiesi@0 1411 $form['ip'] = array(
danielebarchiesi@0 1412 '#title' => t('IP address'),
danielebarchiesi@0 1413 '#type' => 'textfield',
danielebarchiesi@0 1414 '#size' => 48,
danielebarchiesi@0 1415 '#maxlength' => 40,
danielebarchiesi@0 1416 '#default_value' => $default_ip,
danielebarchiesi@0 1417 '#description' => t('Enter a valid IP address.'),
danielebarchiesi@0 1418 );
danielebarchiesi@0 1419 $form['actions'] = array('#type' => 'actions');
danielebarchiesi@0 1420 $form['actions']['submit'] = array(
danielebarchiesi@0 1421 '#type' => 'submit',
danielebarchiesi@0 1422 '#value' => t('Add'),
danielebarchiesi@0 1423 );
danielebarchiesi@0 1424 $form['#submit'][] = 'system_ip_blocking_form_submit';
danielebarchiesi@0 1425 $form['#validate'][] = 'system_ip_blocking_form_validate';
danielebarchiesi@0 1426 return $form;
danielebarchiesi@0 1427 }
danielebarchiesi@0 1428
danielebarchiesi@0 1429 function system_ip_blocking_form_validate($form, &$form_state) {
danielebarchiesi@0 1430 $ip = trim($form_state['values']['ip']);
danielebarchiesi@0 1431 if (db_query("SELECT * FROM {blocked_ips} WHERE ip = :ip", array(':ip' => $ip))->fetchField()) {
danielebarchiesi@0 1432 form_set_error('ip', t('This IP address is already blocked.'));
danielebarchiesi@0 1433 }
danielebarchiesi@0 1434 elseif ($ip == ip_address()) {
danielebarchiesi@0 1435 form_set_error('ip', t('You may not block your own IP address.'));
danielebarchiesi@0 1436 }
danielebarchiesi@0 1437 elseif (filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_NO_RES_RANGE) == FALSE) {
danielebarchiesi@0 1438 form_set_error('ip', t('Enter a valid IP address.'));
danielebarchiesi@0 1439 }
danielebarchiesi@0 1440 }
danielebarchiesi@0 1441
danielebarchiesi@0 1442 function system_ip_blocking_form_submit($form, &$form_state) {
danielebarchiesi@0 1443 $ip = trim($form_state['values']['ip']);
danielebarchiesi@0 1444 db_insert('blocked_ips')
danielebarchiesi@0 1445 ->fields(array('ip' => $ip))
danielebarchiesi@0 1446 ->execute();
danielebarchiesi@0 1447 drupal_set_message(t('The IP address %ip has been blocked.', array('%ip' => $ip)));
danielebarchiesi@0 1448 $form_state['redirect'] = 'admin/config/people/ip-blocking';
danielebarchiesi@0 1449 return;
danielebarchiesi@0 1450 }
danielebarchiesi@0 1451
danielebarchiesi@0 1452 /**
danielebarchiesi@0 1453 * IP deletion confirm page.
danielebarchiesi@0 1454 *
danielebarchiesi@0 1455 * @see system_ip_blocking_delete_submit()
danielebarchiesi@0 1456 */
danielebarchiesi@0 1457 function system_ip_blocking_delete($form, &$form_state, $iid) {
danielebarchiesi@0 1458 $form['blocked_ip'] = array(
danielebarchiesi@0 1459 '#type' => 'value',
danielebarchiesi@0 1460 '#value' => $iid,
danielebarchiesi@0 1461 );
danielebarchiesi@0 1462 return confirm_form($form, t('Are you sure you want to delete %ip?', array('%ip' => $iid['ip'])), 'admin/config/people/ip-blocking', t('This action cannot be undone.'), t('Delete'), t('Cancel'));
danielebarchiesi@0 1463 }
danielebarchiesi@0 1464
danielebarchiesi@0 1465 /**
danielebarchiesi@0 1466 * Process system_ip_blocking_delete form submissions.
danielebarchiesi@0 1467 */
danielebarchiesi@0 1468 function system_ip_blocking_delete_submit($form, &$form_state) {
danielebarchiesi@0 1469 $blocked_ip = $form_state['values']['blocked_ip'];
danielebarchiesi@0 1470 db_delete('blocked_ips')
danielebarchiesi@0 1471 ->condition('iid', $blocked_ip['iid'])
danielebarchiesi@0 1472 ->execute();
danielebarchiesi@0 1473 watchdog('user', 'Deleted %ip', array('%ip' => $blocked_ip['ip']));
danielebarchiesi@0 1474 drupal_set_message(t('The IP address %ip was deleted.', array('%ip' => $blocked_ip['ip'])));
danielebarchiesi@0 1475 $form_state['redirect'] = 'admin/config/people/ip-blocking';
danielebarchiesi@0 1476 }
danielebarchiesi@0 1477
danielebarchiesi@0 1478 /**
danielebarchiesi@0 1479 * Form builder; The general site information form.
danielebarchiesi@0 1480 *
danielebarchiesi@0 1481 * @ingroup forms
danielebarchiesi@0 1482 * @see system_settings_form()
danielebarchiesi@0 1483 */
danielebarchiesi@0 1484 function system_site_information_settings() {
danielebarchiesi@0 1485 $form['site_information'] = array(
danielebarchiesi@0 1486 '#type' => 'fieldset',
danielebarchiesi@0 1487 '#title' => t('Site details'),
danielebarchiesi@0 1488 );
danielebarchiesi@0 1489 $form['site_information']['site_name'] = array(
danielebarchiesi@0 1490 '#type' => 'textfield',
danielebarchiesi@0 1491 '#title' => t('Site name'),
danielebarchiesi@0 1492 '#default_value' => variable_get('site_name', 'Drupal'),
danielebarchiesi@0 1493 '#required' => TRUE
danielebarchiesi@0 1494 );
danielebarchiesi@0 1495 $form['site_information']['site_slogan'] = array(
danielebarchiesi@0 1496 '#type' => 'textfield',
danielebarchiesi@0 1497 '#title' => t('Slogan'),
danielebarchiesi@0 1498 '#default_value' => variable_get('site_slogan', ''),
danielebarchiesi@0 1499 '#description' => t("How this is used depends on your site's theme."),
danielebarchiesi@0 1500 );
danielebarchiesi@0 1501 $form['site_information']['site_mail'] = array(
danielebarchiesi@0 1502 '#type' => 'textfield',
danielebarchiesi@0 1503 '#title' => t('E-mail address'),
danielebarchiesi@0 1504 '#default_value' => variable_get('site_mail', ini_get('sendmail_from')),
danielebarchiesi@0 1505 '#description' => t("The <em>From</em> address in automated e-mails sent during registration and new password requests, and other notifications. (Use an address ending in your site's domain to help prevent this e-mail being flagged as spam.)"),
danielebarchiesi@0 1506 '#required' => TRUE,
danielebarchiesi@0 1507 );
danielebarchiesi@0 1508 $form['front_page'] = array(
danielebarchiesi@0 1509 '#type' => 'fieldset',
danielebarchiesi@0 1510 '#title' => t('Front page'),
danielebarchiesi@0 1511 );
danielebarchiesi@0 1512 $form['front_page']['default_nodes_main'] = array(
danielebarchiesi@0 1513 '#type' => 'select', '#title' => t('Number of posts on front page'),
danielebarchiesi@0 1514 '#default_value' => variable_get('default_nodes_main', 10),
danielebarchiesi@0 1515 '#options' => drupal_map_assoc(array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 15, 20, 25, 30)),
danielebarchiesi@0 1516 '#description' => t('The maximum number of posts displayed on overview pages such as the front page.')
danielebarchiesi@0 1517 );
danielebarchiesi@0 1518 $form['front_page']['site_frontpage'] = array(
danielebarchiesi@0 1519 '#type' => 'textfield',
danielebarchiesi@0 1520 '#title' => t('Default front page'),
danielebarchiesi@0 1521 '#default_value' => (variable_get('site_frontpage')!='node'?drupal_get_path_alias(variable_get('site_frontpage', 'node')):''),
danielebarchiesi@0 1522 '#size' => 40,
danielebarchiesi@0 1523 '#description' => t('Optionally, specify a relative URL to display as the front page. Leave blank to display the default content feed.'),
danielebarchiesi@0 1524 '#field_prefix' => url(NULL, array('absolute' => TRUE)) . (variable_get('clean_url', 0) ? '' : '?q='),
danielebarchiesi@0 1525 );
danielebarchiesi@0 1526 $form['error_page'] = array(
danielebarchiesi@0 1527 '#type' => 'fieldset',
danielebarchiesi@0 1528 '#title' => t('Error pages'),
danielebarchiesi@0 1529 );
danielebarchiesi@0 1530 $form['error_page']['site_403'] = array(
danielebarchiesi@0 1531 '#type' => 'textfield',
danielebarchiesi@0 1532 '#title' => t('Default 403 (access denied) page'),
danielebarchiesi@0 1533 '#default_value' => variable_get('site_403', ''),
danielebarchiesi@0 1534 '#size' => 40,
danielebarchiesi@0 1535 '#description' => t('This page is displayed when the requested document is denied to the current user. Leave blank to display a generic "access denied" page.'),
danielebarchiesi@0 1536 '#field_prefix' => url(NULL, array('absolute' => TRUE)) . (variable_get('clean_url', 0) ? '' : '?q=')
danielebarchiesi@0 1537 );
danielebarchiesi@0 1538 $form['error_page']['site_404'] = array(
danielebarchiesi@0 1539 '#type' => 'textfield',
danielebarchiesi@0 1540 '#title' => t('Default 404 (not found) page'),
danielebarchiesi@0 1541 '#default_value' => variable_get('site_404', ''),
danielebarchiesi@0 1542 '#size' => 40,
danielebarchiesi@0 1543 '#description' => t('This page is displayed when no other content matches the requested document. Leave blank to display a generic "page not found" page.'),
danielebarchiesi@0 1544 '#field_prefix' => url(NULL, array('absolute' => TRUE)) . (variable_get('clean_url', 0) ? '' : '?q=')
danielebarchiesi@0 1545 );
danielebarchiesi@0 1546
danielebarchiesi@0 1547 $form['#validate'][] = 'system_site_information_settings_validate';
danielebarchiesi@0 1548
danielebarchiesi@0 1549 return system_settings_form($form);
danielebarchiesi@0 1550 }
danielebarchiesi@0 1551
danielebarchiesi@0 1552 /**
danielebarchiesi@0 1553 * Validates the submitted site-information form.
danielebarchiesi@0 1554 */
danielebarchiesi@0 1555 function system_site_information_settings_validate($form, &$form_state) {
danielebarchiesi@0 1556 // Validate the e-mail address.
danielebarchiesi@0 1557 if ($error = user_validate_mail($form_state['values']['site_mail'])) {
danielebarchiesi@0 1558 form_set_error('site_mail', $error);
danielebarchiesi@0 1559 }
danielebarchiesi@0 1560 // Check for empty front page path.
danielebarchiesi@0 1561 if (empty($form_state['values']['site_frontpage'])) {
danielebarchiesi@0 1562 // Set to default "node".
danielebarchiesi@0 1563 form_set_value($form['front_page']['site_frontpage'], 'node', $form_state);
danielebarchiesi@0 1564 }
danielebarchiesi@0 1565 else {
danielebarchiesi@0 1566 // Get the normal path of the front page.
danielebarchiesi@0 1567 form_set_value($form['front_page']['site_frontpage'], drupal_get_normal_path($form_state['values']['site_frontpage']), $form_state);
danielebarchiesi@0 1568 }
danielebarchiesi@0 1569 // Validate front page path.
danielebarchiesi@0 1570 if (!drupal_valid_path($form_state['values']['site_frontpage'])) {
danielebarchiesi@0 1571 form_set_error('site_frontpage', t("The path '%path' is either invalid or you do not have access to it.", array('%path' => $form_state['values']['site_frontpage'])));
danielebarchiesi@0 1572 }
danielebarchiesi@0 1573 // Get the normal paths of both error pages.
danielebarchiesi@0 1574 if (!empty($form_state['values']['site_403'])) {
danielebarchiesi@0 1575 form_set_value($form['error_page']['site_403'], drupal_get_normal_path($form_state['values']['site_403']), $form_state);
danielebarchiesi@0 1576 }
danielebarchiesi@0 1577 if (!empty($form_state['values']['site_404'])) {
danielebarchiesi@0 1578 form_set_value($form['error_page']['site_404'], drupal_get_normal_path($form_state['values']['site_404']), $form_state);
danielebarchiesi@0 1579 }
danielebarchiesi@0 1580 // Validate 403 error path.
danielebarchiesi@0 1581 if (!empty($form_state['values']['site_403']) && !drupal_valid_path($form_state['values']['site_403'])) {
danielebarchiesi@0 1582 form_set_error('site_403', t("The path '%path' is either invalid or you do not have access to it.", array('%path' => $form_state['values']['site_403'])));
danielebarchiesi@0 1583 }
danielebarchiesi@0 1584 // Validate 404 error path.
danielebarchiesi@0 1585 if (!empty($form_state['values']['site_404']) && !drupal_valid_path($form_state['values']['site_404'])) {
danielebarchiesi@0 1586 form_set_error('site_404', t("The path '%path' is either invalid or you do not have access to it.", array('%path' => $form_state['values']['site_404'])));
danielebarchiesi@0 1587 }
danielebarchiesi@0 1588 }
danielebarchiesi@0 1589
danielebarchiesi@0 1590 /**
danielebarchiesi@0 1591 * Form builder; Cron form.
danielebarchiesi@0 1592 *
danielebarchiesi@0 1593 * @see system_settings_form()
danielebarchiesi@0 1594 * @ingroup forms
danielebarchiesi@0 1595 */
danielebarchiesi@0 1596 function system_cron_settings() {
danielebarchiesi@0 1597 global $base_url;
danielebarchiesi@0 1598 $form['description'] = array(
danielebarchiesi@0 1599 '#markup' => '<p>' . t('Cron takes care of running periodic tasks like checking for updates and indexing content for search.') . '</p>',
danielebarchiesi@0 1600 );
danielebarchiesi@0 1601 $form['run'] = array(
danielebarchiesi@0 1602 '#type' => 'submit',
danielebarchiesi@0 1603 '#value' => t('Run cron'),
danielebarchiesi@0 1604 '#submit' => array('system_run_cron_submit'),
danielebarchiesi@0 1605 );
danielebarchiesi@0 1606 $status = '<p>' . t('Last run: %cron-last ago.', array('%cron-last' => format_interval(REQUEST_TIME - variable_get('cron_last')),)) . '</p>';
danielebarchiesi@0 1607 $form['status'] = array(
danielebarchiesi@0 1608 '#markup' => $status,
danielebarchiesi@0 1609 );
danielebarchiesi@0 1610
danielebarchiesi@0 1611 $form['cron_url'] = array(
danielebarchiesi@0 1612 '#markup' => '<p>' . t('To run cron from outside the site, go to <a href="!cron">!cron</a>', array('!cron' => url($base_url . '/cron.php', array('external' => TRUE, 'query' => array('cron_key' => variable_get('cron_key', 'drupal')))))) . '</p>',
danielebarchiesi@0 1613 );
danielebarchiesi@0 1614
danielebarchiesi@0 1615 $form['cron'] = array(
danielebarchiesi@0 1616 '#type' => 'fieldset',
danielebarchiesi@0 1617 );
danielebarchiesi@0 1618 $form['cron']['cron_safe_threshold'] = array(
danielebarchiesi@0 1619 '#type' => 'select',
danielebarchiesi@0 1620 '#title' => t('Run cron every'),
danielebarchiesi@0 1621 '#default_value' => variable_get('cron_safe_threshold', DRUPAL_CRON_DEFAULT_THRESHOLD),
danielebarchiesi@0 1622 '#options' => array(0 => t('Never')) + drupal_map_assoc(array(3600, 10800, 21600, 43200, 86400, 604800), 'format_interval'),
danielebarchiesi@0 1623 );
danielebarchiesi@0 1624
danielebarchiesi@0 1625 return system_settings_form($form);
danielebarchiesi@0 1626 }
danielebarchiesi@0 1627
danielebarchiesi@0 1628 /**
danielebarchiesi@0 1629 * Submit callback; run cron.
danielebarchiesi@0 1630 *
danielebarchiesi@0 1631 * @ingroup forms
danielebarchiesi@0 1632 */
danielebarchiesi@0 1633 function system_run_cron_submit($form, &$form_state) {
danielebarchiesi@0 1634 // Run cron manually from Cron form.
danielebarchiesi@0 1635 if (drupal_cron_run()) {
danielebarchiesi@0 1636 drupal_set_message(t('Cron run successfully.'));
danielebarchiesi@0 1637 }
danielebarchiesi@0 1638 else {
danielebarchiesi@0 1639 drupal_set_message(t('Cron run failed.'), 'error');
danielebarchiesi@0 1640 }
danielebarchiesi@0 1641
danielebarchiesi@0 1642 drupal_goto('admin/config/system/cron');
danielebarchiesi@0 1643 }
danielebarchiesi@0 1644
danielebarchiesi@0 1645 /**
danielebarchiesi@0 1646 * Form builder; Configure error reporting settings.
danielebarchiesi@0 1647 *
danielebarchiesi@0 1648 * @ingroup forms
danielebarchiesi@0 1649 * @see system_settings_form()
danielebarchiesi@0 1650 */
danielebarchiesi@0 1651 function system_logging_settings() {
danielebarchiesi@0 1652 $form['error_level'] = array(
danielebarchiesi@0 1653 '#type' => 'radios',
danielebarchiesi@0 1654 '#title' => t('Error messages to display'),
danielebarchiesi@0 1655 '#default_value' => variable_get('error_level', ERROR_REPORTING_DISPLAY_ALL),
danielebarchiesi@0 1656 '#options' => array(
danielebarchiesi@0 1657 ERROR_REPORTING_HIDE => t('None'),
danielebarchiesi@0 1658 ERROR_REPORTING_DISPLAY_SOME => t('Errors and warnings'),
danielebarchiesi@0 1659 ERROR_REPORTING_DISPLAY_ALL => t('All messages'),
danielebarchiesi@0 1660 ),
danielebarchiesi@0 1661 '#description' => t('It is recommended that sites running on production environments do not display any errors.'),
danielebarchiesi@0 1662 );
danielebarchiesi@0 1663
danielebarchiesi@0 1664 return system_settings_form($form);
danielebarchiesi@0 1665 }
danielebarchiesi@0 1666
danielebarchiesi@0 1667 /**
danielebarchiesi@0 1668 * Form builder; Configure site performance settings.
danielebarchiesi@0 1669 *
danielebarchiesi@0 1670 * @ingroup forms
danielebarchiesi@0 1671 * @see system_settings_form()
danielebarchiesi@0 1672 */
danielebarchiesi@0 1673 function system_performance_settings() {
danielebarchiesi@0 1674 drupal_add_js(drupal_get_path('module', 'system') . '/system.js');
danielebarchiesi@0 1675
danielebarchiesi@0 1676 $form['clear_cache'] = array(
danielebarchiesi@0 1677 '#type' => 'fieldset',
danielebarchiesi@0 1678 '#title' => t('Clear cache'),
danielebarchiesi@0 1679 );
danielebarchiesi@0 1680
danielebarchiesi@0 1681 $form['clear_cache']['clear'] = array(
danielebarchiesi@0 1682 '#type' => 'submit',
danielebarchiesi@0 1683 '#value' => t('Clear all caches'),
danielebarchiesi@0 1684 '#submit' => array('system_clear_cache_submit'),
danielebarchiesi@0 1685 );
danielebarchiesi@0 1686
danielebarchiesi@0 1687 $form['caching'] = array(
danielebarchiesi@0 1688 '#type' => 'fieldset',
danielebarchiesi@0 1689 '#title' => t('Caching'),
danielebarchiesi@0 1690 );
danielebarchiesi@0 1691
danielebarchiesi@0 1692 $cache = variable_get('cache', 0);
danielebarchiesi@0 1693 $form['caching']['cache'] = array(
danielebarchiesi@0 1694 '#type' => 'checkbox',
danielebarchiesi@0 1695 '#title' => t('Cache pages for anonymous users'),
danielebarchiesi@0 1696 '#default_value' => $cache,
danielebarchiesi@0 1697 '#weight' => -2,
danielebarchiesi@0 1698 );
danielebarchiesi@0 1699 $period = drupal_map_assoc(array(0, 60, 180, 300, 600, 900, 1800, 2700, 3600, 10800, 21600, 32400, 43200, 86400), 'format_interval');
danielebarchiesi@0 1700 $period[0] = '<' . t('none') . '>';
danielebarchiesi@0 1701 $form['caching']['cache_lifetime'] = array(
danielebarchiesi@0 1702 '#type' => 'select',
danielebarchiesi@0 1703 '#title' => t('Minimum cache lifetime'),
danielebarchiesi@0 1704 '#default_value' => variable_get('cache_lifetime', 0),
danielebarchiesi@0 1705 '#options' => $period,
danielebarchiesi@0 1706 '#description' => t('Cached pages will not be re-created until at least this much time has elapsed.')
danielebarchiesi@0 1707 );
danielebarchiesi@0 1708 $form['caching']['page_cache_maximum_age'] = array(
danielebarchiesi@0 1709 '#type' => 'select',
danielebarchiesi@0 1710 '#title' => t('Expiration of cached pages'),
danielebarchiesi@0 1711 '#default_value' => variable_get('page_cache_maximum_age', 0),
danielebarchiesi@0 1712 '#options' => $period,
danielebarchiesi@0 1713 '#description' => t('The maximum time an external cache can use an old version of a page.')
danielebarchiesi@0 1714 );
danielebarchiesi@0 1715
danielebarchiesi@0 1716 $directory = 'public://';
danielebarchiesi@0 1717 $is_writable = is_dir($directory) && is_writable($directory);
danielebarchiesi@0 1718 $disabled = !$is_writable;
danielebarchiesi@0 1719 $disabled_message = '';
danielebarchiesi@0 1720 if (!$is_writable) {
danielebarchiesi@0 1721 $disabled_message = ' ' . t('<strong class="error">Set up the <a href="!file-system">public files directory</a> to make these optimizations available.</strong>', array('!file-system' => url('admin/config/media/file-system')));
danielebarchiesi@0 1722 }
danielebarchiesi@0 1723
danielebarchiesi@0 1724 $form['bandwidth_optimization'] = array(
danielebarchiesi@0 1725 '#type' => 'fieldset',
danielebarchiesi@0 1726 '#title' => t('Bandwidth optimization'),
danielebarchiesi@0 1727 '#description' => t('External resources can be optimized automatically, which can reduce both the size and number of requests made to your website.') . $disabled_message,
danielebarchiesi@0 1728 );
danielebarchiesi@0 1729
danielebarchiesi@0 1730 $js_hide = $cache ? '' : ' class="js-hide"';
danielebarchiesi@0 1731 $form['bandwidth_optimization']['page_compression'] = array(
danielebarchiesi@0 1732 '#type' => 'checkbox',
danielebarchiesi@0 1733 '#title' => t('Compress cached pages.'),
danielebarchiesi@0 1734 '#default_value' => variable_get('page_compression', TRUE),
danielebarchiesi@0 1735 '#prefix' => '<div id="page-compression-wrapper"' . $js_hide . '>',
danielebarchiesi@0 1736 '#suffix' => '</div>',
danielebarchiesi@0 1737 );
danielebarchiesi@0 1738 $form['bandwidth_optimization']['preprocess_css'] = array(
danielebarchiesi@0 1739 '#type' => 'checkbox',
danielebarchiesi@0 1740 '#title' => t('Aggregate and compress CSS files.'),
danielebarchiesi@0 1741 '#default_value' => intval(variable_get('preprocess_css', 0) && $is_writable),
danielebarchiesi@0 1742 '#disabled' => $disabled,
danielebarchiesi@0 1743 );
danielebarchiesi@0 1744 $form['bandwidth_optimization']['preprocess_js'] = array(
danielebarchiesi@0 1745 '#type' => 'checkbox',
danielebarchiesi@0 1746 '#title' => t('Aggregate JavaScript files.'),
danielebarchiesi@0 1747 '#default_value' => intval(variable_get('preprocess_js', 0) && $is_writable),
danielebarchiesi@0 1748 '#disabled' => $disabled,
danielebarchiesi@0 1749 );
danielebarchiesi@0 1750
danielebarchiesi@0 1751 $form['#submit'][] = 'drupal_clear_css_cache';
danielebarchiesi@0 1752 $form['#submit'][] = 'drupal_clear_js_cache';
danielebarchiesi@0 1753 // This form allows page compression settings to be changed, which can
danielebarchiesi@0 1754 // invalidate the page cache, so it needs to be cleared on form submit.
danielebarchiesi@0 1755 $form['#submit'][] = 'system_clear_page_cache_submit';
danielebarchiesi@0 1756
danielebarchiesi@0 1757 return system_settings_form($form);
danielebarchiesi@0 1758 }
danielebarchiesi@0 1759
danielebarchiesi@0 1760 /**
danielebarchiesi@0 1761 * Submit callback; clear system caches.
danielebarchiesi@0 1762 *
danielebarchiesi@0 1763 * @ingroup forms
danielebarchiesi@0 1764 */
danielebarchiesi@0 1765 function system_clear_cache_submit($form, &$form_state) {
danielebarchiesi@0 1766 drupal_flush_all_caches();
danielebarchiesi@0 1767 drupal_set_message(t('Caches cleared.'));
danielebarchiesi@0 1768 }
danielebarchiesi@0 1769
danielebarchiesi@0 1770 /**
danielebarchiesi@0 1771 * Submit callback; clear the page cache.
danielebarchiesi@0 1772 *
danielebarchiesi@0 1773 * @ingroup forms
danielebarchiesi@0 1774 */
danielebarchiesi@0 1775 function system_clear_page_cache_submit($form, &$form_state) {
danielebarchiesi@0 1776 cache_clear_all('*', 'cache_page', TRUE);
danielebarchiesi@0 1777 }
danielebarchiesi@0 1778
danielebarchiesi@0 1779 /**
danielebarchiesi@0 1780 * Form builder; Configure the site file handling.
danielebarchiesi@0 1781 *
danielebarchiesi@0 1782 * @ingroup forms
danielebarchiesi@0 1783 * @see system_settings_form()
danielebarchiesi@0 1784 */
danielebarchiesi@0 1785 function system_file_system_settings() {
danielebarchiesi@0 1786 $form['file_public_path'] = array(
danielebarchiesi@0 1787 '#type' => 'textfield',
danielebarchiesi@0 1788 '#title' => t('Public file system path'),
danielebarchiesi@0 1789 '#default_value' => variable_get('file_public_path', conf_path() . '/files'),
danielebarchiesi@0 1790 '#maxlength' => 255,
danielebarchiesi@0 1791 '#description' => t('A local file system path where public files will be stored. This directory must exist and be writable by Drupal. This directory must be relative to the Drupal installation directory and be accessible over the web.'),
danielebarchiesi@0 1792 '#after_build' => array('system_check_directory'),
danielebarchiesi@0 1793 );
danielebarchiesi@0 1794
danielebarchiesi@0 1795 $form['file_private_path'] = array(
danielebarchiesi@0 1796 '#type' => 'textfield',
danielebarchiesi@0 1797 '#title' => t('Private file system path'),
danielebarchiesi@0 1798 '#default_value' => variable_get('file_private_path', ''),
danielebarchiesi@0 1799 '#maxlength' => 255,
danielebarchiesi@0 1800 '#description' => t('An existing local file system path for storing private files. It should be writable by Drupal and not accessible over the web. See the online handbook for <a href="@handbook">more information about securing private files</a>.', array('@handbook' => 'http://drupal.org/documentation/modules/file')),
danielebarchiesi@0 1801 '#after_build' => array('system_check_directory'),
danielebarchiesi@0 1802 );
danielebarchiesi@0 1803
danielebarchiesi@0 1804 $form['file_temporary_path'] = array(
danielebarchiesi@0 1805 '#type' => 'textfield',
danielebarchiesi@0 1806 '#title' => t('Temporary directory'),
danielebarchiesi@0 1807 '#default_value' => variable_get('file_temporary_path', file_directory_temp()),
danielebarchiesi@0 1808 '#maxlength' => 255,
danielebarchiesi@0 1809 '#description' => t('A local file system path where temporary files will be stored. This directory should not be accessible over the web.'),
danielebarchiesi@0 1810 '#after_build' => array('system_check_directory'),
danielebarchiesi@0 1811 );
danielebarchiesi@0 1812 // Any visible, writeable wrapper can potentially be used for the files
danielebarchiesi@0 1813 // directory, including a remote file system that integrates with a CDN.
danielebarchiesi@0 1814 foreach (file_get_stream_wrappers(STREAM_WRAPPERS_WRITE_VISIBLE) as $scheme => $info) {
danielebarchiesi@0 1815 $options[$scheme] = check_plain($info['description']);
danielebarchiesi@0 1816 }
danielebarchiesi@0 1817
danielebarchiesi@0 1818 if (!empty($options)) {
danielebarchiesi@0 1819 $form['file_default_scheme'] = array(
danielebarchiesi@0 1820 '#type' => 'radios',
danielebarchiesi@0 1821 '#title' => t('Default download method'),
danielebarchiesi@0 1822 '#default_value' => variable_get('file_default_scheme', isset($options['public']) ? 'public' : key($options)),
danielebarchiesi@0 1823 '#options' => $options,
danielebarchiesi@0 1824 '#description' => t('This setting is used as the preferred download method. The use of public files is more efficient, but does not provide any access control.'),
danielebarchiesi@0 1825 );
danielebarchiesi@0 1826 }
danielebarchiesi@0 1827
danielebarchiesi@0 1828 return system_settings_form($form);
danielebarchiesi@0 1829 }
danielebarchiesi@0 1830
danielebarchiesi@0 1831 /**
danielebarchiesi@0 1832 * Form builder; Configure site image toolkit usage.
danielebarchiesi@0 1833 *
danielebarchiesi@0 1834 * @ingroup forms
danielebarchiesi@0 1835 * @see system_settings_form()
danielebarchiesi@0 1836 */
danielebarchiesi@0 1837 function system_image_toolkit_settings() {
danielebarchiesi@0 1838 $toolkits_available = image_get_available_toolkits();
danielebarchiesi@0 1839 $current_toolkit = image_get_toolkit();
danielebarchiesi@0 1840
danielebarchiesi@0 1841 if (count($toolkits_available) == 0) {
danielebarchiesi@0 1842 variable_del('image_toolkit');
danielebarchiesi@0 1843 $form['image_toolkit_help'] = array(
danielebarchiesi@0 1844 '#markup' => t("No image toolkits were detected. Drupal includes support for <a href='!gd-link'>PHP's built-in image processing functions</a> but they were not detected on this system. You should consult your system administrator to have them enabled, or try using a third party toolkit.", array('gd-link' => url('http://php.net/gd'))),
danielebarchiesi@0 1845 );
danielebarchiesi@0 1846 return $form;
danielebarchiesi@0 1847 }
danielebarchiesi@0 1848
danielebarchiesi@0 1849 if (count($toolkits_available) > 1) {
danielebarchiesi@0 1850 $form['image_toolkit'] = array(
danielebarchiesi@0 1851 '#type' => 'radios',
danielebarchiesi@0 1852 '#title' => t('Select an image processing toolkit'),
danielebarchiesi@0 1853 '#default_value' => variable_get('image_toolkit', $current_toolkit),
danielebarchiesi@0 1854 '#options' => $toolkits_available
danielebarchiesi@0 1855 );
danielebarchiesi@0 1856 }
danielebarchiesi@0 1857 else {
danielebarchiesi@0 1858 variable_set('image_toolkit', key($toolkits_available));
danielebarchiesi@0 1859 }
danielebarchiesi@0 1860
danielebarchiesi@0 1861 // Get the toolkit's settings form.
danielebarchiesi@0 1862 $function = 'image_' . $current_toolkit . '_settings';
danielebarchiesi@0 1863 if (function_exists($function)) {
danielebarchiesi@0 1864 $form['image_toolkit_settings'] = $function();
danielebarchiesi@0 1865 }
danielebarchiesi@0 1866
danielebarchiesi@0 1867 return system_settings_form($form);
danielebarchiesi@0 1868 }
danielebarchiesi@0 1869
danielebarchiesi@0 1870 /**
danielebarchiesi@0 1871 * Form builder; Configure how the site handles RSS feeds.
danielebarchiesi@0 1872 *
danielebarchiesi@0 1873 * @ingroup forms
danielebarchiesi@0 1874 * @see system_settings_form()
danielebarchiesi@0 1875 */
danielebarchiesi@0 1876 function system_rss_feeds_settings() {
danielebarchiesi@0 1877 $form['feed_description'] = array(
danielebarchiesi@0 1878 '#type' => 'textarea',
danielebarchiesi@0 1879 '#title' => t('Feed description'),
danielebarchiesi@0 1880 '#default_value' => variable_get('feed_description', ''),
danielebarchiesi@0 1881 '#description' => t('Description of your site, included in each feed.')
danielebarchiesi@0 1882 );
danielebarchiesi@0 1883 $form['feed_default_items'] = array(
danielebarchiesi@0 1884 '#type' => 'select',
danielebarchiesi@0 1885 '#title' => t('Number of items in each feed'),
danielebarchiesi@0 1886 '#default_value' => variable_get('feed_default_items', 10),
danielebarchiesi@0 1887 '#options' => drupal_map_assoc(array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 15, 20, 25, 30)),
danielebarchiesi@0 1888 '#description' => t('Default number of items to include in each feed.')
danielebarchiesi@0 1889 );
danielebarchiesi@0 1890 $form['feed_item_length'] = array(
danielebarchiesi@0 1891 '#type' => 'select',
danielebarchiesi@0 1892 '#title' => t('Feed content'),
danielebarchiesi@0 1893 '#default_value' => variable_get('feed_item_length', 'fulltext'),
danielebarchiesi@0 1894 '#options' => array('title' => t('Titles only'), 'teaser' => t('Titles plus teaser'), 'fulltext' => t('Full text')),
danielebarchiesi@0 1895 '#description' => t('Global setting for the default display of content items in each feed.')
danielebarchiesi@0 1896 );
danielebarchiesi@0 1897
danielebarchiesi@0 1898 return system_settings_form($form);
danielebarchiesi@0 1899 }
danielebarchiesi@0 1900
danielebarchiesi@0 1901 /**
danielebarchiesi@0 1902 * Form builder; Configure the site regional settings.
danielebarchiesi@0 1903 *
danielebarchiesi@0 1904 * @ingroup forms
danielebarchiesi@0 1905 * @see system_settings_form()
danielebarchiesi@0 1906 * @see system_regional_settings_submit()
danielebarchiesi@0 1907 */
danielebarchiesi@0 1908 function system_regional_settings() {
danielebarchiesi@0 1909 include_once DRUPAL_ROOT . '/includes/locale.inc';
danielebarchiesi@0 1910 $countries = country_get_list();
danielebarchiesi@0 1911
danielebarchiesi@0 1912 // Date settings:
danielebarchiesi@0 1913 $zones = system_time_zones();
danielebarchiesi@0 1914
danielebarchiesi@0 1915 $form['locale'] = array(
danielebarchiesi@0 1916 '#type' => 'fieldset',
danielebarchiesi@0 1917 '#title' => t('Locale'),
danielebarchiesi@0 1918 );
danielebarchiesi@0 1919
danielebarchiesi@0 1920 $form['locale']['site_default_country'] = array(
danielebarchiesi@0 1921 '#type' => 'select',
danielebarchiesi@0 1922 '#title' => t('Default country'),
danielebarchiesi@0 1923 '#empty_value' => '',
danielebarchiesi@0 1924 '#default_value' => variable_get('site_default_country', ''),
danielebarchiesi@0 1925 '#options' => $countries,
danielebarchiesi@0 1926 '#attributes' => array('class' => array('country-detect')),
danielebarchiesi@0 1927 );
danielebarchiesi@0 1928
danielebarchiesi@0 1929 $form['locale']['date_first_day'] = array(
danielebarchiesi@0 1930 '#type' => 'select',
danielebarchiesi@0 1931 '#title' => t('First day of week'),
danielebarchiesi@0 1932 '#default_value' => variable_get('date_first_day', 0),
danielebarchiesi@0 1933 '#options' => array(0 => t('Sunday'), 1 => t('Monday'), 2 => t('Tuesday'), 3 => t('Wednesday'), 4 => t('Thursday'), 5 => t('Friday'), 6 => t('Saturday')),
danielebarchiesi@0 1934 );
danielebarchiesi@0 1935
danielebarchiesi@0 1936 $form['timezone'] = array(
danielebarchiesi@0 1937 '#type' => 'fieldset',
danielebarchiesi@0 1938 '#title' => t('Time zones'),
danielebarchiesi@0 1939 );
danielebarchiesi@0 1940
danielebarchiesi@0 1941 $form['timezone']['date_default_timezone'] = array(
danielebarchiesi@0 1942 '#type' => 'select',
danielebarchiesi@0 1943 '#title' => t('Default time zone'),
danielebarchiesi@0 1944 '#default_value' => variable_get('date_default_timezone', date_default_timezone_get()),
danielebarchiesi@0 1945 '#options' => $zones,
danielebarchiesi@0 1946 );
danielebarchiesi@0 1947
danielebarchiesi@0 1948 $configurable_timezones = variable_get('configurable_timezones', 1);
danielebarchiesi@0 1949 $form['timezone']['configurable_timezones'] = array(
danielebarchiesi@0 1950 '#type' => 'checkbox',
danielebarchiesi@0 1951 '#title' => t('Users may set their own time zone.'),
danielebarchiesi@0 1952 '#default_value' => $configurable_timezones,
danielebarchiesi@0 1953 );
danielebarchiesi@0 1954
danielebarchiesi@0 1955 $form['timezone']['configurable_timezones_wrapper'] = array(
danielebarchiesi@0 1956 '#type' => 'container',
danielebarchiesi@0 1957 '#states' => array(
danielebarchiesi@0 1958 // Hide the user configured timezone settings when users are forced to use
danielebarchiesi@0 1959 // the default setting.
danielebarchiesi@0 1960 'invisible' => array(
danielebarchiesi@0 1961 'input[name="configurable_timezones"]' => array('checked' => FALSE),
danielebarchiesi@0 1962 ),
danielebarchiesi@0 1963 ),
danielebarchiesi@0 1964 );
danielebarchiesi@0 1965 $form['timezone']['configurable_timezones_wrapper']['empty_timezone_message'] = array(
danielebarchiesi@0 1966 '#type' => 'checkbox',
danielebarchiesi@0 1967 '#title' => t('Remind users at login if their time zone is not set.'),
danielebarchiesi@0 1968 '#default_value' => variable_get('empty_timezone_message', 0),
danielebarchiesi@0 1969 '#description' => t('Only applied if users may set their own time zone.')
danielebarchiesi@0 1970 );
danielebarchiesi@0 1971
danielebarchiesi@0 1972 $form['timezone']['configurable_timezones_wrapper']['user_default_timezone'] = array(
danielebarchiesi@0 1973 '#type' => 'radios',
danielebarchiesi@0 1974 '#title' => t('Time zone for new users'),
danielebarchiesi@0 1975 '#default_value' => variable_get('user_default_timezone', DRUPAL_USER_TIMEZONE_DEFAULT),
danielebarchiesi@0 1976 '#options' => array(
danielebarchiesi@0 1977 DRUPAL_USER_TIMEZONE_DEFAULT => t('Default time zone.'),
danielebarchiesi@0 1978 DRUPAL_USER_TIMEZONE_EMPTY => t('Empty time zone.'),
danielebarchiesi@0 1979 DRUPAL_USER_TIMEZONE_SELECT => t('Users may set their own time zone at registration.'),
danielebarchiesi@0 1980 ),
danielebarchiesi@0 1981 '#description' => t('Only applied if users may set their own time zone.')
danielebarchiesi@0 1982 );
danielebarchiesi@0 1983
danielebarchiesi@0 1984 return system_settings_form($form);
danielebarchiesi@0 1985 }
danielebarchiesi@0 1986
danielebarchiesi@0 1987 /**
danielebarchiesi@0 1988 * Form builder; Configure the site date and time settings.
danielebarchiesi@0 1989 *
danielebarchiesi@0 1990 * @ingroup forms
danielebarchiesi@0 1991 * @see system_settings_form()
danielebarchiesi@0 1992 */
danielebarchiesi@0 1993 function system_date_time_settings() {
danielebarchiesi@0 1994 // Get list of all available date types.
danielebarchiesi@0 1995 drupal_static_reset('system_get_date_types');
danielebarchiesi@0 1996 $format_types = system_get_date_types();
danielebarchiesi@0 1997
danielebarchiesi@0 1998 // Get list of all available date formats.
danielebarchiesi@0 1999 $all_formats = array();
danielebarchiesi@0 2000 drupal_static_reset('system_get_date_formats');
danielebarchiesi@0 2001 $date_formats = system_get_date_formats(); // Call this to rebuild the list, and to have default list.
danielebarchiesi@0 2002 foreach ($date_formats as $type => $format_info) {
danielebarchiesi@0 2003 $all_formats = array_merge($all_formats, $format_info);
danielebarchiesi@0 2004 }
danielebarchiesi@0 2005 $custom_formats = system_get_date_formats('custom');
danielebarchiesi@0 2006 if (!empty($format_types)) {
danielebarchiesi@0 2007 foreach ($format_types as $type => $type_info) {
danielebarchiesi@0 2008 // If a system type, only show the available formats for that type and
danielebarchiesi@0 2009 // custom ones.
danielebarchiesi@0 2010 if ($type_info['locked'] == 1) {
danielebarchiesi@0 2011 $formats = system_get_date_formats($type);
danielebarchiesi@0 2012 if (empty($formats)) {
danielebarchiesi@0 2013 $formats = $all_formats;
danielebarchiesi@0 2014 }
danielebarchiesi@0 2015 elseif (!empty($custom_formats)) {
danielebarchiesi@0 2016 $formats = array_merge($formats, $custom_formats);
danielebarchiesi@0 2017 }
danielebarchiesi@0 2018 }
danielebarchiesi@0 2019 // If a user configured type, show all available date formats.
danielebarchiesi@0 2020 else {
danielebarchiesi@0 2021 $formats = $all_formats;
danielebarchiesi@0 2022 }
danielebarchiesi@0 2023
danielebarchiesi@0 2024 $choices = array();
danielebarchiesi@0 2025 foreach ($formats as $f => $format) {
danielebarchiesi@0 2026 $choices[$f] = format_date(REQUEST_TIME, 'custom', $f);
danielebarchiesi@0 2027 }
danielebarchiesi@0 2028 reset($formats);
danielebarchiesi@0 2029 $default = variable_get('date_format_' . $type, key($formats));
danielebarchiesi@0 2030
danielebarchiesi@0 2031 // Get date type info for this date type.
danielebarchiesi@0 2032 $type_info = system_get_date_types($type);
danielebarchiesi@0 2033 $form['formats']['#theme'] = 'system_date_time_settings';
danielebarchiesi@0 2034
danielebarchiesi@0 2035 // Show date format select list.
danielebarchiesi@0 2036 $form['formats']['format']['date_format_' . $type] = array(
danielebarchiesi@0 2037 '#type' => 'select',
danielebarchiesi@0 2038 '#title' => check_plain($type_info['title']),
danielebarchiesi@0 2039 '#attributes' => array('class' => array('date-format')),
danielebarchiesi@0 2040 '#default_value' => (isset($choices[$default]) ? $default : 'custom'),
danielebarchiesi@0 2041 '#options' => $choices,
danielebarchiesi@0 2042 );
danielebarchiesi@0 2043
danielebarchiesi@0 2044 // If this isn't a system provided type, allow the user to remove it from
danielebarchiesi@0 2045 // the system.
danielebarchiesi@0 2046 if ($type_info['locked'] == 0) {
danielebarchiesi@0 2047 $form['formats']['delete']['date_format_' . $type . '_delete'] = array(
danielebarchiesi@0 2048 '#type' => 'link',
danielebarchiesi@0 2049 '#title' => t('delete'),
danielebarchiesi@0 2050 '#href' => 'admin/config/regional/date-time/types/' . $type . '/delete',
danielebarchiesi@0 2051 );
danielebarchiesi@0 2052 }
danielebarchiesi@0 2053 }
danielebarchiesi@0 2054 }
danielebarchiesi@0 2055
danielebarchiesi@0 2056 // Display a message if no date types configured.
danielebarchiesi@0 2057 $form['#empty_text'] = t('No date types available. <a href="@link">Add date type</a>.', array('@link' => url('admin/config/regional/date-time/types/add')));
danielebarchiesi@0 2058
danielebarchiesi@0 2059 return system_settings_form($form);
danielebarchiesi@0 2060 }
danielebarchiesi@0 2061
danielebarchiesi@0 2062 /**
danielebarchiesi@0 2063 * Returns HTML for the date settings form.
danielebarchiesi@0 2064 *
danielebarchiesi@0 2065 * @param $variables
danielebarchiesi@0 2066 * An associative array containing:
danielebarchiesi@0 2067 * - form: A render element representing the form.
danielebarchiesi@0 2068 *
danielebarchiesi@0 2069 * @ingroup themeable
danielebarchiesi@0 2070 */
danielebarchiesi@0 2071 function theme_system_date_time_settings($variables) {
danielebarchiesi@0 2072 $form = $variables['form'];
danielebarchiesi@0 2073 $header = array(
danielebarchiesi@0 2074 t('Date type'),
danielebarchiesi@0 2075 t('Format'),
danielebarchiesi@0 2076 t('Operations'),
danielebarchiesi@0 2077 );
danielebarchiesi@0 2078
danielebarchiesi@0 2079 foreach (element_children($form['format']) as $key) {
danielebarchiesi@0 2080 $delete_key = $key . '_delete';
danielebarchiesi@0 2081 $row = array();
danielebarchiesi@0 2082 $row[] = $form['format'][$key]['#title'];
danielebarchiesi@0 2083 $form['format'][$key]['#title_display'] = 'invisible';
danielebarchiesi@0 2084 $row[] = array('data' => drupal_render($form['format'][$key]));
danielebarchiesi@0 2085 $row[] = array('data' => drupal_render($form['delete'][$delete_key]));
danielebarchiesi@0 2086 $rows[] = $row;
danielebarchiesi@0 2087 }
danielebarchiesi@0 2088
danielebarchiesi@0 2089 $output = theme('table', array('header' => $header, 'rows' => $rows, 'attributes' => array('id' => 'system-date-types')));
danielebarchiesi@0 2090 $output .= drupal_render_children($form);
danielebarchiesi@0 2091
danielebarchiesi@0 2092 return $output;
danielebarchiesi@0 2093 }
danielebarchiesi@0 2094
danielebarchiesi@0 2095
danielebarchiesi@0 2096 /**
danielebarchiesi@0 2097 * Add new date type.
danielebarchiesi@0 2098 *
danielebarchiesi@0 2099 * @ingroup forms
danielebarchiesi@0 2100 * @ingroup system_add_date_format_type_form_validate()
danielebarchiesi@0 2101 * @ingroup system_add_date_format_type_form_submit()
danielebarchiesi@0 2102 */
danielebarchiesi@0 2103 function system_add_date_format_type_form($form, &$form_state) {
danielebarchiesi@0 2104 $form['date_type'] = array(
danielebarchiesi@0 2105 '#title' => t('Date type'),
danielebarchiesi@0 2106 '#type' => 'textfield',
danielebarchiesi@0 2107 '#required' => TRUE,
danielebarchiesi@0 2108 );
danielebarchiesi@0 2109 $form['machine_name'] = array(
danielebarchiesi@0 2110 '#type' => 'machine_name',
danielebarchiesi@0 2111 '#machine_name' => array(
danielebarchiesi@0 2112 'exists' => 'system_get_date_types',
danielebarchiesi@0 2113 'source' => array('date_type'),
danielebarchiesi@0 2114 ),
danielebarchiesi@0 2115 );
danielebarchiesi@0 2116
danielebarchiesi@0 2117 // Get list of all available date formats.
danielebarchiesi@0 2118 $formats = array();
danielebarchiesi@0 2119 drupal_static_reset('system_get_date_formats');
danielebarchiesi@0 2120 $date_formats = system_get_date_formats(); // Call this to rebuild the list, and to have default list.
danielebarchiesi@0 2121 foreach ($date_formats as $type => $format_info) {
danielebarchiesi@0 2122 $formats = array_merge($formats, $format_info);
danielebarchiesi@0 2123 }
danielebarchiesi@0 2124 $custom_formats = system_get_date_formats('custom');
danielebarchiesi@0 2125 if (!empty($custom_formats)) {
danielebarchiesi@0 2126 $formats = array_merge($formats, $custom_formats);
danielebarchiesi@0 2127 }
danielebarchiesi@0 2128 $choices = array();
danielebarchiesi@0 2129 foreach ($formats as $f => $format) {
danielebarchiesi@0 2130 $choices[$f] = format_date(REQUEST_TIME, 'custom', $f);
danielebarchiesi@0 2131 }
danielebarchiesi@0 2132 // Show date format select list.
danielebarchiesi@0 2133 $form['date_format'] = array(
danielebarchiesi@0 2134 '#type' => 'select',
danielebarchiesi@0 2135 '#title' => t('Date format'),
danielebarchiesi@0 2136 '#attributes' => array('class' => array('date-format')),
danielebarchiesi@0 2137 '#options' => $choices,
danielebarchiesi@0 2138 '#required' => TRUE,
danielebarchiesi@0 2139 );
danielebarchiesi@0 2140
danielebarchiesi@0 2141 $form['actions'] = array('#type' => 'actions');
danielebarchiesi@0 2142 $form['actions']['submit'] = array(
danielebarchiesi@0 2143 '#type' => 'submit',
danielebarchiesi@0 2144 '#value' => t('Add date type'),
danielebarchiesi@0 2145 );
danielebarchiesi@0 2146
danielebarchiesi@0 2147 $form['#validate'][] = 'system_add_date_format_type_form_validate';
danielebarchiesi@0 2148 $form['#submit'][] = 'system_add_date_format_type_form_submit';
danielebarchiesi@0 2149
danielebarchiesi@0 2150 return $form;
danielebarchiesi@0 2151 }
danielebarchiesi@0 2152
danielebarchiesi@0 2153 /**
danielebarchiesi@0 2154 * Validate system_add_date_format_type form submissions.
danielebarchiesi@0 2155 */
danielebarchiesi@0 2156 function system_add_date_format_type_form_validate($form, &$form_state) {
danielebarchiesi@0 2157 if (!empty($form_state['values']['machine_name']) && !empty($form_state['values']['date_type'])) {
danielebarchiesi@0 2158 if (!preg_match("/^[a-zA-Z0-9_]+$/", trim($form_state['values']['machine_name']))) {
danielebarchiesi@0 2159 form_set_error('machine_name', t('The date type must contain only alphanumeric characters and underscores.'));
danielebarchiesi@0 2160 }
danielebarchiesi@0 2161 $types = system_get_date_types();
danielebarchiesi@0 2162 if (in_array(trim($form_state['values']['machine_name']), array_keys($types))) {
danielebarchiesi@0 2163 form_set_error('machine_name', t('This date type already exists. Enter a unique type.'));
danielebarchiesi@0 2164 }
danielebarchiesi@0 2165 }
danielebarchiesi@0 2166 }
danielebarchiesi@0 2167
danielebarchiesi@0 2168 /**
danielebarchiesi@0 2169 * Process system_add_date_format_type form submissions.
danielebarchiesi@0 2170 */
danielebarchiesi@0 2171 function system_add_date_format_type_form_submit($form, &$form_state) {
danielebarchiesi@0 2172 $machine_name = trim($form_state['values']['machine_name']);
danielebarchiesi@0 2173
danielebarchiesi@0 2174 $format_type = array();
danielebarchiesi@0 2175 $format_type['title'] = trim($form_state['values']['date_type']);
danielebarchiesi@0 2176 $format_type['type'] = $machine_name;
danielebarchiesi@0 2177 $format_type['locked'] = 0;
danielebarchiesi@0 2178 $format_type['is_new'] = 1;
danielebarchiesi@0 2179 system_date_format_type_save($format_type);
danielebarchiesi@0 2180 variable_set('date_format_' . $machine_name, $form_state['values']['date_format']);
danielebarchiesi@0 2181
danielebarchiesi@0 2182 drupal_set_message(t('New date type added successfully.'));
danielebarchiesi@0 2183 $form_state['redirect'] = 'admin/config/regional/date-time';
danielebarchiesi@0 2184 }
danielebarchiesi@0 2185
danielebarchiesi@0 2186 /**
danielebarchiesi@0 2187 * Return the date for a given format string via Ajax.
danielebarchiesi@0 2188 */
danielebarchiesi@0 2189 function system_date_time_lookup() {
danielebarchiesi@0 2190 $result = format_date(REQUEST_TIME, 'custom', $_GET['format']);
danielebarchiesi@0 2191 drupal_json_output($result);
danielebarchiesi@0 2192 }
danielebarchiesi@0 2193
danielebarchiesi@0 2194 /**
danielebarchiesi@0 2195 * Form builder; Configure the site's maintenance status.
danielebarchiesi@0 2196 *
danielebarchiesi@0 2197 * @ingroup forms
danielebarchiesi@0 2198 * @see system_settings_form()
danielebarchiesi@0 2199 */
danielebarchiesi@0 2200 function system_site_maintenance_mode() {
danielebarchiesi@0 2201 $form['maintenance_mode'] = array(
danielebarchiesi@0 2202 '#type' => 'checkbox',
danielebarchiesi@0 2203 '#title' => t('Put site into maintenance mode'),
danielebarchiesi@0 2204 '#default_value' => variable_get('maintenance_mode', 0),
danielebarchiesi@0 2205 '#description' => t('When enabled, only users with the "Use the site in maintenance mode" <a href="@permissions-url">permission</a> are able to access your site to perform maintenance; all other visitors see the maintenance mode message configured below. Authorized users can log in directly via the <a href="@user-login">user login</a> page.', array('@permissions-url' => url('admin/people/permissions'), '@user-login' => url('user'))),
danielebarchiesi@0 2206 );
danielebarchiesi@0 2207 $form['maintenance_mode_message'] = array(
danielebarchiesi@0 2208 '#type' => 'textarea',
danielebarchiesi@0 2209 '#title' => t('Maintenance mode message'),
danielebarchiesi@0 2210 '#default_value' => variable_get('maintenance_mode_message', t('@site is currently under maintenance. We should be back shortly. Thank you for your patience.', array('@site' => variable_get('site_name', 'Drupal')))),
danielebarchiesi@0 2211 '#description' => t('Message to show visitors when the site is in maintenance mode.')
danielebarchiesi@0 2212 );
danielebarchiesi@0 2213
danielebarchiesi@0 2214 return system_settings_form($form);
danielebarchiesi@0 2215 }
danielebarchiesi@0 2216
danielebarchiesi@0 2217 /**
danielebarchiesi@0 2218 * Form builder; Configure clean URL settings.
danielebarchiesi@0 2219 *
danielebarchiesi@0 2220 * @ingroup forms
danielebarchiesi@0 2221 * @see system_settings_form()
danielebarchiesi@0 2222 */
danielebarchiesi@0 2223 function system_clean_url_settings($form, &$form_state) {
danielebarchiesi@0 2224 $available = FALSE;
danielebarchiesi@0 2225 $conflict = FALSE;
danielebarchiesi@0 2226
danielebarchiesi@0 2227 // If the request URI is a clean URL, clean URLs must be available.
danielebarchiesi@0 2228 // Otherwise, run a test.
danielebarchiesi@0 2229 if (strpos(request_uri(), '?q=') === FALSE && strpos(request_uri(), '&q=') === FALSE) {
danielebarchiesi@0 2230 $available = TRUE;
danielebarchiesi@0 2231 }
danielebarchiesi@0 2232 else {
danielebarchiesi@0 2233 $request = drupal_http_request($GLOBALS['base_url'] . '/admin/config/search/clean-urls/check');
danielebarchiesi@0 2234 // If the request returns HTTP 200, clean URLs are available.
danielebarchiesi@0 2235 if (isset($request->code) && $request->code == 200) {
danielebarchiesi@0 2236 $available = TRUE;
danielebarchiesi@0 2237 // If the user started the clean URL test, provide explicit feedback.
danielebarchiesi@0 2238 if (isset($form_state['input']['clean_url_test_execute'])) {
danielebarchiesi@0 2239 drupal_set_message(t('The clean URL test passed.'));
danielebarchiesi@0 2240 }
danielebarchiesi@0 2241 }
danielebarchiesi@0 2242 else {
danielebarchiesi@0 2243 // If the test failed while clean URLs are enabled, make sure clean URLs
danielebarchiesi@0 2244 // can be disabled.
danielebarchiesi@0 2245 if (variable_get('clean_url', 0)) {
danielebarchiesi@0 2246 $conflict = TRUE;
danielebarchiesi@0 2247 // Warn the user of a conflicting situation, unless after processing
danielebarchiesi@0 2248 // a submitted form.
danielebarchiesi@0 2249 if (!isset($form_state['input']['op'])) {
danielebarchiesi@0 2250 drupal_set_message(t('Clean URLs are enabled, but the clean URL test failed. Uncheck the box below to disable clean URLs.'), 'warning');
danielebarchiesi@0 2251 }
danielebarchiesi@0 2252 }
danielebarchiesi@0 2253 // If the user started the clean URL test, provide explicit feedback.
danielebarchiesi@0 2254 elseif (isset($form_state['input']['clean_url_test_execute'])) {
danielebarchiesi@0 2255 drupal_set_message(t('The clean URL test failed.'), 'warning');
danielebarchiesi@0 2256 }
danielebarchiesi@0 2257 }
danielebarchiesi@0 2258 }
danielebarchiesi@0 2259
danielebarchiesi@0 2260 // Show the enable/disable form if clean URLs are available or if the user
danielebarchiesi@0 2261 // must be able to resolve a conflicting setting.
danielebarchiesi@0 2262 if ($available || $conflict) {
danielebarchiesi@0 2263 $form['clean_url'] = array(
danielebarchiesi@0 2264 '#type' => 'checkbox',
danielebarchiesi@0 2265 '#title' => t('Enable clean URLs'),
danielebarchiesi@0 2266 '#default_value' => variable_get('clean_url', 0),
danielebarchiesi@0 2267 '#description' => t('Use URLs like <code>example.com/user</code> instead of <code>example.com/?q=user</code>.'),
danielebarchiesi@0 2268 );
danielebarchiesi@0 2269 $form = system_settings_form($form);
danielebarchiesi@0 2270 if ($conflict) {
danielebarchiesi@0 2271 // $form_state['redirect'] needs to be set to the non-clean URL,
danielebarchiesi@0 2272 // otherwise the setting is not saved.
danielebarchiesi@0 2273 $form_state['redirect'] = url('', array('query' => array('q' => '/admin/config/search/clean-urls')));
danielebarchiesi@0 2274 }
danielebarchiesi@0 2275 }
danielebarchiesi@0 2276 // Show the clean URLs test form.
danielebarchiesi@0 2277 else {
danielebarchiesi@0 2278 drupal_add_js(drupal_get_path('module', 'system') . '/system.js');
danielebarchiesi@0 2279
danielebarchiesi@0 2280 $form_state['redirect'] = url('admin/config/search/clean-urls');
danielebarchiesi@0 2281 $form['clean_url_description'] = array(
danielebarchiesi@0 2282 '#type' => 'markup',
danielebarchiesi@0 2283 '#markup' => '<p>' . t('Use URLs like <code>example.com/user</code> instead of <code>example.com/?q=user</code>.'),
danielebarchiesi@0 2284 );
danielebarchiesi@0 2285 // Explain why the user is seeing this page and what to expect after
danielebarchiesi@0 2286 // clicking the 'Run the clean URL test' button.
danielebarchiesi@0 2287 $form['clean_url_test_result'] = array(
danielebarchiesi@0 2288 '#type' => 'markup',
danielebarchiesi@0 2289 '#markup' => '<p>' . t('Clean URLs cannot be enabled. If you are directed to this page or to a <em>Page not found (404)</em> error after testing for clean URLs, see the <a href="@handbook">online handbook</a>.', array('@handbook' => 'http://drupal.org/node/15365')) . '</p>',
danielebarchiesi@0 2290 );
danielebarchiesi@0 2291 $form['actions'] = array(
danielebarchiesi@0 2292 '#type' => 'actions',
danielebarchiesi@0 2293 'clean_url_test' => array(
danielebarchiesi@0 2294 '#type' => 'submit',
danielebarchiesi@0 2295 '#value' => t('Run the clean URL test'),
danielebarchiesi@0 2296 ),
danielebarchiesi@0 2297 );
danielebarchiesi@0 2298 $form['clean_url_test_execute'] = array(
danielebarchiesi@0 2299 '#type' => 'hidden',
danielebarchiesi@0 2300 '#value' => 1,
danielebarchiesi@0 2301 );
danielebarchiesi@0 2302 }
danielebarchiesi@0 2303
danielebarchiesi@0 2304 return $form;
danielebarchiesi@0 2305 }
danielebarchiesi@0 2306
danielebarchiesi@0 2307 /**
danielebarchiesi@0 2308 * Menu callback: displays the site status report. Can also be used as a pure check.
danielebarchiesi@0 2309 *
danielebarchiesi@0 2310 * @param $check
danielebarchiesi@0 2311 * If true, only returns a boolean whether there are system status errors.
danielebarchiesi@0 2312 */
danielebarchiesi@0 2313 function system_status($check = FALSE) {
danielebarchiesi@0 2314 // Load .install files
danielebarchiesi@0 2315 include_once DRUPAL_ROOT . '/includes/install.inc';
danielebarchiesi@0 2316 drupal_load_updates();
danielebarchiesi@0 2317
danielebarchiesi@0 2318 // Check run-time requirements and status information.
danielebarchiesi@0 2319 $requirements = module_invoke_all('requirements', 'runtime');
danielebarchiesi@0 2320 usort($requirements, '_system_sort_requirements');
danielebarchiesi@0 2321
danielebarchiesi@0 2322 if ($check) {
danielebarchiesi@0 2323 return drupal_requirements_severity($requirements) == REQUIREMENT_ERROR;
danielebarchiesi@0 2324 }
danielebarchiesi@0 2325 // MySQL import might have set the uid of the anonymous user to autoincrement
danielebarchiesi@0 2326 // value. Let's try fixing it. See http://drupal.org/node/204411
danielebarchiesi@0 2327 db_update('users')
danielebarchiesi@0 2328 ->expression('uid', 'uid - uid')
danielebarchiesi@0 2329 ->condition('name', '')
danielebarchiesi@0 2330 ->condition('pass', '')
danielebarchiesi@0 2331 ->condition('status', 0)
danielebarchiesi@0 2332 ->execute();
danielebarchiesi@0 2333 return theme('status_report', array('requirements' => $requirements));
danielebarchiesi@0 2334 }
danielebarchiesi@0 2335
danielebarchiesi@0 2336 /**
danielebarchiesi@0 2337 * Menu callback: run cron manually.
danielebarchiesi@0 2338 */
danielebarchiesi@0 2339 function system_run_cron() {
danielebarchiesi@0 2340 // Run cron manually
danielebarchiesi@0 2341 if (drupal_cron_run()) {
danielebarchiesi@0 2342 drupal_set_message(t('Cron ran successfully.'));
danielebarchiesi@0 2343 }
danielebarchiesi@0 2344 else {
danielebarchiesi@0 2345 drupal_set_message(t('Cron run failed.'), 'error');
danielebarchiesi@0 2346 }
danielebarchiesi@0 2347
danielebarchiesi@0 2348 drupal_goto('admin/reports/status');
danielebarchiesi@0 2349 }
danielebarchiesi@0 2350
danielebarchiesi@0 2351 /**
danielebarchiesi@0 2352 * Menu callback: return information about PHP.
danielebarchiesi@0 2353 */
danielebarchiesi@0 2354 function system_php() {
danielebarchiesi@0 2355 phpinfo();
danielebarchiesi@0 2356 drupal_exit();
danielebarchiesi@0 2357 }
danielebarchiesi@0 2358
danielebarchiesi@0 2359 /**
danielebarchiesi@0 2360 * Default page callback for batches.
danielebarchiesi@0 2361 */
danielebarchiesi@0 2362 function system_batch_page() {
danielebarchiesi@0 2363 require_once DRUPAL_ROOT . '/includes/batch.inc';
danielebarchiesi@0 2364 $output = _batch_page();
danielebarchiesi@0 2365
danielebarchiesi@0 2366 if ($output === FALSE) {
danielebarchiesi@0 2367 drupal_access_denied();
danielebarchiesi@0 2368 }
danielebarchiesi@0 2369 elseif (isset($output)) {
danielebarchiesi@0 2370 // Force a page without blocks or messages to
danielebarchiesi@0 2371 // display a list of collected messages later.
danielebarchiesi@0 2372 drupal_set_page_content($output);
danielebarchiesi@0 2373 $page = element_info('page');
danielebarchiesi@0 2374 $page['#show_messages'] = FALSE;
danielebarchiesi@0 2375 return $page;
danielebarchiesi@0 2376 }
danielebarchiesi@0 2377 }
danielebarchiesi@0 2378
danielebarchiesi@0 2379 /**
danielebarchiesi@0 2380 * Returns HTML for an administrative block for display.
danielebarchiesi@0 2381 *
danielebarchiesi@0 2382 * @param $variables
danielebarchiesi@0 2383 * An associative array containing:
danielebarchiesi@0 2384 * - block: An array containing information about the block:
danielebarchiesi@0 2385 * - show: A Boolean whether to output the block. Defaults to FALSE.
danielebarchiesi@0 2386 * - title: The block's title.
danielebarchiesi@0 2387 * - content: (optional) Formatted content for the block.
danielebarchiesi@0 2388 * - description: (optional) Description of the block. Only output if
danielebarchiesi@0 2389 * 'content' is not set.
danielebarchiesi@0 2390 *
danielebarchiesi@0 2391 * @ingroup themeable
danielebarchiesi@0 2392 */
danielebarchiesi@0 2393 function theme_admin_block($variables) {
danielebarchiesi@0 2394 $block = $variables['block'];
danielebarchiesi@0 2395 $output = '';
danielebarchiesi@0 2396
danielebarchiesi@0 2397 // Don't display the block if it has no content to display.
danielebarchiesi@0 2398 if (empty($block['show'])) {
danielebarchiesi@0 2399 return $output;
danielebarchiesi@0 2400 }
danielebarchiesi@0 2401
danielebarchiesi@0 2402 $output .= '<div class="admin-panel">';
danielebarchiesi@0 2403 if (!empty($block['title'])) {
danielebarchiesi@0 2404 $output .= '<h3>' . $block['title'] . '</h3>';
danielebarchiesi@0 2405 }
danielebarchiesi@0 2406 if (!empty($block['content'])) {
danielebarchiesi@0 2407 $output .= '<div class="body">' . $block['content'] . '</div>';
danielebarchiesi@0 2408 }
danielebarchiesi@0 2409 else {
danielebarchiesi@0 2410 $output .= '<div class="description">' . $block['description'] . '</div>';
danielebarchiesi@0 2411 }
danielebarchiesi@0 2412 $output .= '</div>';
danielebarchiesi@0 2413
danielebarchiesi@0 2414 return $output;
danielebarchiesi@0 2415 }
danielebarchiesi@0 2416
danielebarchiesi@0 2417 /**
danielebarchiesi@0 2418 * Returns HTML for the content of an administrative block.
danielebarchiesi@0 2419 *
danielebarchiesi@0 2420 * @param $variables
danielebarchiesi@0 2421 * An associative array containing:
danielebarchiesi@0 2422 * - content: An array containing information about the block. Each element
danielebarchiesi@0 2423 * of the array represents an administrative menu item, and must at least
danielebarchiesi@0 2424 * contain the keys 'title', 'href', and 'localized_options', which are
danielebarchiesi@0 2425 * passed to l(). A 'description' key may also be provided.
danielebarchiesi@0 2426 *
danielebarchiesi@0 2427 * @ingroup themeable
danielebarchiesi@0 2428 */
danielebarchiesi@0 2429 function theme_admin_block_content($variables) {
danielebarchiesi@0 2430 $content = $variables['content'];
danielebarchiesi@0 2431 $output = '';
danielebarchiesi@0 2432
danielebarchiesi@0 2433 if (!empty($content)) {
danielebarchiesi@0 2434 $class = 'admin-list';
danielebarchiesi@0 2435 if ($compact = system_admin_compact_mode()) {
danielebarchiesi@0 2436 $class .= ' compact';
danielebarchiesi@0 2437 }
danielebarchiesi@0 2438 $output .= '<dl class="' . $class . '">';
danielebarchiesi@0 2439 foreach ($content as $item) {
danielebarchiesi@0 2440 $output .= '<dt>' . l($item['title'], $item['href'], $item['localized_options']) . '</dt>';
danielebarchiesi@0 2441 if (!$compact && isset($item['description'])) {
danielebarchiesi@0 2442 $output .= '<dd>' . filter_xss_admin($item['description']) . '</dd>';
danielebarchiesi@0 2443 }
danielebarchiesi@0 2444 }
danielebarchiesi@0 2445 $output .= '</dl>';
danielebarchiesi@0 2446 }
danielebarchiesi@0 2447 return $output;
danielebarchiesi@0 2448 }
danielebarchiesi@0 2449
danielebarchiesi@0 2450 /**
danielebarchiesi@0 2451 * Returns HTML for an administrative page.
danielebarchiesi@0 2452 *
danielebarchiesi@0 2453 * @param $variables
danielebarchiesi@0 2454 * An associative array containing:
danielebarchiesi@0 2455 * - blocks: An array of blocks to display. Each array should include a
danielebarchiesi@0 2456 * 'title', a 'description', a formatted 'content' and a 'position' which
danielebarchiesi@0 2457 * will control which container it will be in. This is usually 'left' or
danielebarchiesi@0 2458 * 'right'.
danielebarchiesi@0 2459 *
danielebarchiesi@0 2460 * @ingroup themeable
danielebarchiesi@0 2461 */
danielebarchiesi@0 2462 function theme_admin_page($variables) {
danielebarchiesi@0 2463 $blocks = $variables['blocks'];
danielebarchiesi@0 2464
danielebarchiesi@0 2465 $stripe = 0;
danielebarchiesi@0 2466 $container = array();
danielebarchiesi@0 2467
danielebarchiesi@0 2468 foreach ($blocks as $block) {
danielebarchiesi@0 2469 if ($block_output = theme('admin_block', array('block' => $block))) {
danielebarchiesi@0 2470 if (empty($block['position'])) {
danielebarchiesi@0 2471 // perform automatic striping.
danielebarchiesi@0 2472 $block['position'] = ++$stripe % 2 ? 'left' : 'right';
danielebarchiesi@0 2473 }
danielebarchiesi@0 2474 if (!isset($container[$block['position']])) {
danielebarchiesi@0 2475 $container[$block['position']] = '';
danielebarchiesi@0 2476 }
danielebarchiesi@0 2477 $container[$block['position']] .= $block_output;
danielebarchiesi@0 2478 }
danielebarchiesi@0 2479 }
danielebarchiesi@0 2480
danielebarchiesi@0 2481 $output = '<div class="admin clearfix">';
danielebarchiesi@0 2482 $output .= theme('system_compact_link');
danielebarchiesi@0 2483
danielebarchiesi@0 2484 foreach ($container as $id => $data) {
danielebarchiesi@0 2485 $output .= '<div class="' . $id . ' clearfix">';
danielebarchiesi@0 2486 $output .= $data;
danielebarchiesi@0 2487 $output .= '</div>';
danielebarchiesi@0 2488 }
danielebarchiesi@0 2489 $output .= '</div>';
danielebarchiesi@0 2490 return $output;
danielebarchiesi@0 2491 }
danielebarchiesi@0 2492
danielebarchiesi@0 2493 /**
danielebarchiesi@0 2494 * Returns HTML for the output of the dashboard page.
danielebarchiesi@0 2495 *
danielebarchiesi@0 2496 * @param $variables
danielebarchiesi@0 2497 * An associative array containing:
danielebarchiesi@0 2498 * - menu_items: An array of modules to be displayed.
danielebarchiesi@0 2499 *
danielebarchiesi@0 2500 * @ingroup themeable
danielebarchiesi@0 2501 */
danielebarchiesi@0 2502 function theme_system_admin_index($variables) {
danielebarchiesi@0 2503 $menu_items = $variables['menu_items'];
danielebarchiesi@0 2504
danielebarchiesi@0 2505 $stripe = 0;
danielebarchiesi@0 2506 $container = array('left' => '', 'right' => '');
danielebarchiesi@0 2507 $flip = array('left' => 'right', 'right' => 'left');
danielebarchiesi@0 2508 $position = 'left';
danielebarchiesi@0 2509
danielebarchiesi@0 2510 // Iterate over all modules.
danielebarchiesi@0 2511 foreach ($menu_items as $module => $block) {
danielebarchiesi@0 2512 list($description, $items) = $block;
danielebarchiesi@0 2513
danielebarchiesi@0 2514 // Output links.
danielebarchiesi@0 2515 if (count($items)) {
danielebarchiesi@0 2516 $block = array();
danielebarchiesi@0 2517 $block['title'] = $module;
danielebarchiesi@0 2518 $block['content'] = theme('admin_block_content', array('content' => $items));
danielebarchiesi@0 2519 $block['description'] = t($description);
danielebarchiesi@0 2520 $block['show'] = TRUE;
danielebarchiesi@0 2521
danielebarchiesi@0 2522 if ($block_output = theme('admin_block', array('block' => $block))) {
danielebarchiesi@0 2523 if (!isset($block['position'])) {
danielebarchiesi@0 2524 // Perform automatic striping.
danielebarchiesi@0 2525 $block['position'] = $position;
danielebarchiesi@0 2526 $position = $flip[$position];
danielebarchiesi@0 2527 }
danielebarchiesi@0 2528 $container[$block['position']] .= $block_output;
danielebarchiesi@0 2529 }
danielebarchiesi@0 2530 }
danielebarchiesi@0 2531 }
danielebarchiesi@0 2532
danielebarchiesi@0 2533 $output = '<div class="admin clearfix">';
danielebarchiesi@0 2534 $output .= theme('system_compact_link');
danielebarchiesi@0 2535 foreach ($container as $id => $data) {
danielebarchiesi@0 2536 $output .= '<div class="' . $id . ' clearfix">';
danielebarchiesi@0 2537 $output .= $data;
danielebarchiesi@0 2538 $output .= '</div>';
danielebarchiesi@0 2539 }
danielebarchiesi@0 2540 $output .= '</div>';
danielebarchiesi@0 2541
danielebarchiesi@0 2542 return $output;
danielebarchiesi@0 2543 }
danielebarchiesi@0 2544
danielebarchiesi@0 2545 /**
danielebarchiesi@0 2546 * Returns HTML for the status report.
danielebarchiesi@0 2547 *
danielebarchiesi@0 2548 * @param $variables
danielebarchiesi@0 2549 * An associative array containing:
danielebarchiesi@0 2550 * - requirements: An array of requirements.
danielebarchiesi@0 2551 *
danielebarchiesi@0 2552 * @ingroup themeable
danielebarchiesi@0 2553 */
danielebarchiesi@0 2554 function theme_status_report($variables) {
danielebarchiesi@0 2555 $requirements = $variables['requirements'];
danielebarchiesi@0 2556 $severities = array(
danielebarchiesi@0 2557 REQUIREMENT_INFO => array(
danielebarchiesi@0 2558 'title' => t('Info'),
danielebarchiesi@0 2559 'class' => 'info',
danielebarchiesi@0 2560 ),
danielebarchiesi@0 2561 REQUIREMENT_OK => array(
danielebarchiesi@0 2562 'title' => t('OK'),
danielebarchiesi@0 2563 'class' => 'ok',
danielebarchiesi@0 2564 ),
danielebarchiesi@0 2565 REQUIREMENT_WARNING => array(
danielebarchiesi@0 2566 'title' => t('Warning'),
danielebarchiesi@0 2567 'class' => 'warning',
danielebarchiesi@0 2568 ),
danielebarchiesi@0 2569 REQUIREMENT_ERROR => array(
danielebarchiesi@0 2570 'title' => t('Error'),
danielebarchiesi@0 2571 'class' => 'error',
danielebarchiesi@0 2572 ),
danielebarchiesi@0 2573 );
danielebarchiesi@0 2574 $output = '<table class="system-status-report">';
danielebarchiesi@0 2575
danielebarchiesi@0 2576 foreach ($requirements as $requirement) {
danielebarchiesi@0 2577 if (empty($requirement['#type'])) {
danielebarchiesi@0 2578 $severity = $severities[isset($requirement['severity']) ? (int) $requirement['severity'] : 0];
danielebarchiesi@0 2579 $severity['icon'] = '<div title="' . $severity['title'] . '"><span class="element-invisible">' . $severity['title'] . '</span></div>';
danielebarchiesi@0 2580
danielebarchiesi@0 2581 // Output table row(s)
danielebarchiesi@0 2582 if (!empty($requirement['description'])) {
danielebarchiesi@0 2583 $output .= '<tr class="' . $severity['class'] . ' merge-down"><td class="status-icon">' . $severity['icon'] . '</td><td class="status-title">' . $requirement['title'] . '</td><td class="status-value">' . $requirement['value'] . '</td></tr>';
danielebarchiesi@0 2584 $output .= '<tr class="' . $severity['class'] . ' merge-up"><td colspan="3" class="status-description">' . $requirement['description'] . '</td></tr>';
danielebarchiesi@0 2585 }
danielebarchiesi@0 2586 else {
danielebarchiesi@0 2587 $output .= '<tr class="' . $severity['class'] . '"><td class="status-icon">' . $severity['icon'] . '</td><td class="status-title">' . $requirement['title'] . '</td><td class="status-value">' . $requirement['value'] . '</td></tr>';
danielebarchiesi@0 2588 }
danielebarchiesi@0 2589 }
danielebarchiesi@0 2590 }
danielebarchiesi@0 2591
danielebarchiesi@0 2592 $output .= '</table>';
danielebarchiesi@0 2593 return $output;
danielebarchiesi@0 2594 }
danielebarchiesi@0 2595
danielebarchiesi@0 2596 /**
danielebarchiesi@0 2597 * Returns HTML for the modules form.
danielebarchiesi@0 2598 *
danielebarchiesi@0 2599 * @param $variables
danielebarchiesi@0 2600 * An associative array containing:
danielebarchiesi@0 2601 * - form: A render element representing the form.
danielebarchiesi@0 2602 *
danielebarchiesi@0 2603 * @ingroup themeable
danielebarchiesi@0 2604 */
danielebarchiesi@0 2605 function theme_system_modules_fieldset($variables) {
danielebarchiesi@0 2606 $form = $variables['form'];
danielebarchiesi@0 2607
danielebarchiesi@0 2608 // Individual table headers.
danielebarchiesi@0 2609 $rows = array();
danielebarchiesi@0 2610 // Iterate through all the modules, which are
danielebarchiesi@0 2611 // children of this fieldset.
danielebarchiesi@0 2612 foreach (element_children($form) as $key) {
danielebarchiesi@0 2613 // Stick it into $module for easier accessing.
danielebarchiesi@0 2614 $module = $form[$key];
danielebarchiesi@0 2615 $row = array();
danielebarchiesi@0 2616 unset($module['enable']['#title']);
danielebarchiesi@0 2617 $row[] = array('class' => array('checkbox'), 'data' => drupal_render($module['enable']));
danielebarchiesi@0 2618 $label = '<label';
danielebarchiesi@0 2619 if (isset($module['enable']['#id'])) {
danielebarchiesi@0 2620 $label .= ' for="' . $module['enable']['#id'] . '"';
danielebarchiesi@0 2621 }
danielebarchiesi@0 2622 $row[] = $label . '><strong>' . drupal_render($module['name']) . '</strong></label>';
danielebarchiesi@0 2623 $row[] = drupal_render($module['version']);
danielebarchiesi@0 2624 // Add the description, along with any modules it requires.
danielebarchiesi@0 2625 $description = drupal_render($module['description']);
danielebarchiesi@0 2626 if ($module['#requires']) {
danielebarchiesi@0 2627 $description .= '<div class="admin-requirements">' . t('Requires: !module-list', array('!module-list' => implode(', ', $module['#requires']))) . '</div>';
danielebarchiesi@0 2628 }
danielebarchiesi@0 2629 if ($module['#required_by']) {
danielebarchiesi@0 2630 $description .= '<div class="admin-requirements">' . t('Required by: !module-list', array('!module-list' => implode(', ', $module['#required_by']))) . '</div>';
danielebarchiesi@0 2631 }
danielebarchiesi@0 2632 $row[] = array('data' => $description, 'class' => array('description'));
danielebarchiesi@0 2633 // Display links (such as help or permissions) in their own columns.
danielebarchiesi@0 2634 foreach (array('help', 'permissions', 'configure') as $key) {
danielebarchiesi@0 2635 $row[] = array('data' => drupal_render($module['links'][$key]), 'class' => array($key));
danielebarchiesi@0 2636 }
danielebarchiesi@0 2637 $rows[] = $row;
danielebarchiesi@0 2638 }
danielebarchiesi@0 2639
danielebarchiesi@0 2640 return theme('table', array('header' => $form['#header'], 'rows' => $rows));
danielebarchiesi@0 2641 }
danielebarchiesi@0 2642
danielebarchiesi@0 2643 /**
danielebarchiesi@0 2644 * Returns HTML for a message about incompatible modules.
danielebarchiesi@0 2645 *
danielebarchiesi@0 2646 * @param $variables
danielebarchiesi@0 2647 * An associative array containing:
danielebarchiesi@0 2648 * - message: The form array representing the currently disabled modules.
danielebarchiesi@0 2649 *
danielebarchiesi@0 2650 * @ingroup themeable
danielebarchiesi@0 2651 */
danielebarchiesi@0 2652 function theme_system_modules_incompatible($variables) {
danielebarchiesi@0 2653 return '<div class="incompatible">' . $variables['message'] . '</div>';
danielebarchiesi@0 2654 }
danielebarchiesi@0 2655
danielebarchiesi@0 2656 /**
danielebarchiesi@0 2657 * Returns HTML for a table of currently disabled modules.
danielebarchiesi@0 2658 *
danielebarchiesi@0 2659 * @param $variables
danielebarchiesi@0 2660 * An associative array containing:
danielebarchiesi@0 2661 * - form: A render element representing the form.
danielebarchiesi@0 2662 *
danielebarchiesi@0 2663 * @ingroup themeable
danielebarchiesi@0 2664 */
danielebarchiesi@0 2665 function theme_system_modules_uninstall($variables) {
danielebarchiesi@0 2666 $form = $variables['form'];
danielebarchiesi@0 2667
danielebarchiesi@0 2668 // No theming for the confirm form.
danielebarchiesi@0 2669 if (isset($form['confirm'])) {
danielebarchiesi@0 2670 return drupal_render($form);
danielebarchiesi@0 2671 }
danielebarchiesi@0 2672
danielebarchiesi@0 2673 // Table headers.
danielebarchiesi@0 2674 $header = array(t('Uninstall'),
danielebarchiesi@0 2675 t('Name'),
danielebarchiesi@0 2676 t('Description'),
danielebarchiesi@0 2677 );
danielebarchiesi@0 2678
danielebarchiesi@0 2679 // Display table.
danielebarchiesi@0 2680 $rows = array();
danielebarchiesi@0 2681 foreach (element_children($form['modules']) as $module) {
danielebarchiesi@0 2682 if (!empty($form['modules'][$module]['#required_by'])) {
danielebarchiesi@0 2683 $disabled_message = format_plural(count($form['modules'][$module]['#required_by']),
danielebarchiesi@0 2684 'To uninstall @module, the following module must be uninstalled first: @required_modules',
danielebarchiesi@0 2685 'To uninstall @module, the following modules must be uninstalled first: @required_modules',
danielebarchiesi@0 2686 array('@module' => $form['modules'][$module]['#module_name'], '@required_modules' => implode(', ', $form['modules'][$module]['#required_by'])));
danielebarchiesi@0 2687 $disabled_message = '<div class="admin-requirements">' . $disabled_message . '</div>';
danielebarchiesi@0 2688 }
danielebarchiesi@0 2689 else {
danielebarchiesi@0 2690 $disabled_message = '';
danielebarchiesi@0 2691 }
danielebarchiesi@0 2692 $rows[] = array(
danielebarchiesi@0 2693 array('data' => drupal_render($form['uninstall'][$module]), 'align' => 'center'),
danielebarchiesi@0 2694 '<strong><label for="' . $form['uninstall'][$module]['#id'] . '">' . drupal_render($form['modules'][$module]['name']) . '</label></strong>',
danielebarchiesi@0 2695 array('data' => drupal_render($form['modules'][$module]['description']) . $disabled_message, 'class' => array('description')),
danielebarchiesi@0 2696 );
danielebarchiesi@0 2697 }
danielebarchiesi@0 2698
danielebarchiesi@0 2699 $output = theme('table', array('header' => $header, 'rows' => $rows, 'empty' => t('No modules are available to uninstall.')));
danielebarchiesi@0 2700 $output .= drupal_render_children($form);
danielebarchiesi@0 2701
danielebarchiesi@0 2702 return $output;
danielebarchiesi@0 2703 }
danielebarchiesi@0 2704
danielebarchiesi@0 2705 /**
danielebarchiesi@0 2706 * Returns HTML for the Appearance page.
danielebarchiesi@0 2707 *
danielebarchiesi@0 2708 * @param $variables
danielebarchiesi@0 2709 * An associative array containing:
danielebarchiesi@0 2710 * - theme_groups: An associative array containing groups of themes.
danielebarchiesi@0 2711 *
danielebarchiesi@0 2712 * @ingroup themeable
danielebarchiesi@0 2713 */
danielebarchiesi@0 2714 function theme_system_themes_page($variables) {
danielebarchiesi@0 2715 $theme_groups = $variables['theme_groups'];
danielebarchiesi@0 2716
danielebarchiesi@0 2717 $output = '<div id="system-themes-page">';
danielebarchiesi@0 2718
danielebarchiesi@0 2719 foreach ($variables['theme_group_titles'] as $state => $title) {
danielebarchiesi@0 2720 if (!count($theme_groups[$state])) {
danielebarchiesi@0 2721 // Skip this group of themes if no theme is there.
danielebarchiesi@0 2722 continue;
danielebarchiesi@0 2723 }
danielebarchiesi@0 2724 // Start new theme group.
danielebarchiesi@0 2725 $output .= '<div class="system-themes-list system-themes-list-'. $state .' clearfix"><h2>'. $title .'</h2>';
danielebarchiesi@0 2726
danielebarchiesi@0 2727 foreach ($theme_groups[$state] as $theme) {
danielebarchiesi@0 2728
danielebarchiesi@0 2729 // Theme the screenshot.
danielebarchiesi@0 2730 $screenshot = $theme->screenshot ? theme('image', $theme->screenshot) : '<div class="no-screenshot">' . t('no screenshot') . '</div>';
danielebarchiesi@0 2731
danielebarchiesi@0 2732 // Localize the theme description.
danielebarchiesi@0 2733 $description = t($theme->info['description']);
danielebarchiesi@0 2734
danielebarchiesi@0 2735 // Style theme info
danielebarchiesi@0 2736 $notes = count($theme->notes) ? ' (' . join(', ', $theme->notes) . ')' : '';
danielebarchiesi@0 2737 $theme->classes[] = 'theme-selector';
danielebarchiesi@0 2738 $theme->classes[] = 'clearfix';
danielebarchiesi@0 2739 $output .= '<div class="'. join(' ', $theme->classes) .'">' . $screenshot . '<div class="theme-info"><h3>' . $theme->info['name'] . ' ' . (isset($theme->info['version']) ? $theme->info['version'] : '') . $notes . '</h3><div class="theme-description">' . $description . '</div>';
danielebarchiesi@0 2740
danielebarchiesi@0 2741 // Make sure to provide feedback on compatibility.
danielebarchiesi@0 2742 if (!empty($theme->incompatible_core)) {
danielebarchiesi@0 2743 $output .= '<div class="incompatible">' . t('This version is not compatible with Drupal !core_version and should be replaced.', array('!core_version' => DRUPAL_CORE_COMPATIBILITY)) . '</div>';
danielebarchiesi@0 2744 }
danielebarchiesi@0 2745 elseif (!empty($theme->incompatible_php)) {
danielebarchiesi@0 2746 if (substr_count($theme->info['php'], '.') < 2) {
danielebarchiesi@0 2747 $theme->info['php'] .= '.*';
danielebarchiesi@0 2748 }
danielebarchiesi@0 2749 $output .= '<div class="incompatible">' . t('This theme requires PHP version @php_required and is incompatible with PHP version !php_version.', array('@php_required' => $theme->info['php'], '!php_version' => phpversion())) . '</div>';
danielebarchiesi@0 2750 }
danielebarchiesi@0 2751 else {
danielebarchiesi@0 2752 $output .= theme('links', array('links' => $theme->operations, 'attributes' => array('class' => array('operations', 'clearfix'))));
danielebarchiesi@0 2753 }
danielebarchiesi@0 2754 $output .= '</div></div>';
danielebarchiesi@0 2755 }
danielebarchiesi@0 2756 $output .= '</div>';
danielebarchiesi@0 2757 }
danielebarchiesi@0 2758 $output .= '</div>';
danielebarchiesi@0 2759
danielebarchiesi@0 2760 return $output;
danielebarchiesi@0 2761 }
danielebarchiesi@0 2762
danielebarchiesi@0 2763 /**
danielebarchiesi@0 2764 * Menu callback; present a form for deleting a date format.
danielebarchiesi@0 2765 */
danielebarchiesi@0 2766 function system_date_delete_format_form($form, &$form_state, $dfid) {
danielebarchiesi@0 2767 $form['dfid'] = array(
danielebarchiesi@0 2768 '#type' => 'value',
danielebarchiesi@0 2769 '#value' => $dfid,
danielebarchiesi@0 2770 );
danielebarchiesi@0 2771 $format = system_get_date_format($dfid);
danielebarchiesi@0 2772
danielebarchiesi@0 2773 $output = confirm_form($form,
danielebarchiesi@0 2774 t('Are you sure you want to remove the format %format?', array('%format' => format_date(REQUEST_TIME, 'custom', $format->format))),
danielebarchiesi@0 2775 'admin/config/regional/date-time/formats',
danielebarchiesi@0 2776 t('This action cannot be undone.'),
danielebarchiesi@0 2777 t('Remove'), t('Cancel'),
danielebarchiesi@0 2778 'confirm'
danielebarchiesi@0 2779 );
danielebarchiesi@0 2780
danielebarchiesi@0 2781 return $output;
danielebarchiesi@0 2782 }
danielebarchiesi@0 2783
danielebarchiesi@0 2784 /**
danielebarchiesi@0 2785 * Delete a configured date format.
danielebarchiesi@0 2786 */
danielebarchiesi@0 2787 function system_date_delete_format_form_submit($form, &$form_state) {
danielebarchiesi@0 2788 if ($form_state['values']['confirm']) {
danielebarchiesi@0 2789 $format = system_get_date_format($form_state['values']['dfid']);
danielebarchiesi@0 2790 system_date_format_delete($form_state['values']['dfid']);
danielebarchiesi@0 2791 drupal_set_message(t('Removed date format %format.', array('%format' => format_date(REQUEST_TIME, 'custom', $format->format))));
danielebarchiesi@0 2792 $form_state['redirect'] = 'admin/config/regional/date-time/formats';
danielebarchiesi@0 2793 }
danielebarchiesi@0 2794 }
danielebarchiesi@0 2795
danielebarchiesi@0 2796 /**
danielebarchiesi@0 2797 * Menu callback; present a form for deleting a date type.
danielebarchiesi@0 2798 */
danielebarchiesi@0 2799 function system_delete_date_format_type_form($form, &$form_state, $format_type) {
danielebarchiesi@0 2800 $form['format_type'] = array(
danielebarchiesi@0 2801 '#type' => 'value',
danielebarchiesi@0 2802 '#value' => $format_type,
danielebarchiesi@0 2803 );
danielebarchiesi@0 2804 $type_info = system_get_date_types($format_type);
danielebarchiesi@0 2805
danielebarchiesi@0 2806 $output = confirm_form($form,
danielebarchiesi@0 2807 t('Are you sure you want to remove the date type %type?', array('%type' => $type_info['title'])),
danielebarchiesi@0 2808 'admin/config/regional/date-time',
danielebarchiesi@0 2809 t('This action cannot be undone.'),
danielebarchiesi@0 2810 t('Remove'), t('Cancel'),
danielebarchiesi@0 2811 'confirm'
danielebarchiesi@0 2812 );
danielebarchiesi@0 2813
danielebarchiesi@0 2814 return $output;
danielebarchiesi@0 2815 }
danielebarchiesi@0 2816
danielebarchiesi@0 2817 /**
danielebarchiesi@0 2818 * Delete a configured date type.
danielebarchiesi@0 2819 */
danielebarchiesi@0 2820 function system_delete_date_format_type_form_submit($form, &$form_state) {
danielebarchiesi@0 2821 if ($form_state['values']['confirm']) {
danielebarchiesi@0 2822 $type_info = system_get_date_types($form_state['values']['format_type']);
danielebarchiesi@0 2823 system_date_format_type_delete($form_state['values']['format_type']);
danielebarchiesi@0 2824 drupal_set_message(t('Removed date type %type.', array('%type' => $type_info['title'])));
danielebarchiesi@0 2825 $form_state['redirect'] = 'admin/config/regional/date-time';
danielebarchiesi@0 2826 }
danielebarchiesi@0 2827 }
danielebarchiesi@0 2828
danielebarchiesi@0 2829
danielebarchiesi@0 2830 /**
danielebarchiesi@0 2831 * Displays the date format strings overview page.
danielebarchiesi@0 2832 */
danielebarchiesi@0 2833 function system_date_time_formats() {
danielebarchiesi@0 2834 $header = array(t('Format'), array('data' => t('Operations'), 'colspan' => '2'));
danielebarchiesi@0 2835 $rows = array();
danielebarchiesi@0 2836
danielebarchiesi@0 2837 drupal_static_reset('system_get_date_formats');
danielebarchiesi@0 2838 $formats = system_get_date_formats('custom');
danielebarchiesi@0 2839 if (!empty($formats)) {
danielebarchiesi@0 2840 foreach ($formats as $format) {
danielebarchiesi@0 2841 $row = array();
danielebarchiesi@0 2842 $row[] = array('data' => format_date(REQUEST_TIME, 'custom', $format['format']));
danielebarchiesi@0 2843 $row[] = array('data' => l(t('edit'), 'admin/config/regional/date-time/formats/' . $format['dfid'] . '/edit'));
danielebarchiesi@0 2844 $row[] = array('data' => l(t('delete'), 'admin/config/regional/date-time/formats/' . $format['dfid'] . '/delete'));
danielebarchiesi@0 2845 $rows[] = $row;
danielebarchiesi@0 2846 }
danielebarchiesi@0 2847 }
danielebarchiesi@0 2848
danielebarchiesi@0 2849 $build['date_formats_table'] = array(
danielebarchiesi@0 2850 '#theme' => 'table',
danielebarchiesi@0 2851 '#header' => $header,
danielebarchiesi@0 2852 '#rows' => $rows,
danielebarchiesi@0 2853 '#empty' => t('No custom date formats available. <a href="@link">Add date format</a>.', array('@link' => url('admin/config/regional/date-time/formats/add'))),
danielebarchiesi@0 2854 );
danielebarchiesi@0 2855
danielebarchiesi@0 2856 return $build;
danielebarchiesi@0 2857 }
danielebarchiesi@0 2858
danielebarchiesi@0 2859 /**
danielebarchiesi@0 2860 * Allow users to add additional date formats.
danielebarchiesi@0 2861 */
danielebarchiesi@0 2862 function system_configure_date_formats_form($form, &$form_state, $dfid = 0) {
danielebarchiesi@0 2863 $js_settings = array(
danielebarchiesi@0 2864 'type' => 'setting',
danielebarchiesi@0 2865 'data' => array(
danielebarchiesi@0 2866 'dateTime' => array(
danielebarchiesi@0 2867 'date-format' => array(
danielebarchiesi@0 2868 'text' => t('Displayed as'),
danielebarchiesi@0 2869 'lookup' => url('admin/config/regional/date-time/formats/lookup'),
danielebarchiesi@0 2870 ),
danielebarchiesi@0 2871 ),
danielebarchiesi@0 2872 ),
danielebarchiesi@0 2873 );
danielebarchiesi@0 2874
danielebarchiesi@0 2875 if ($dfid) {
danielebarchiesi@0 2876 $form['dfid'] = array(
danielebarchiesi@0 2877 '#type' => 'value',
danielebarchiesi@0 2878 '#value' => $dfid,
danielebarchiesi@0 2879 );
danielebarchiesi@0 2880 $format = system_get_date_format($dfid);
danielebarchiesi@0 2881 }
danielebarchiesi@0 2882
danielebarchiesi@0 2883 $now = ($dfid ? t('Displayed as %date', array('%date' => format_date(REQUEST_TIME, 'custom', $format->format))) : '');
danielebarchiesi@0 2884
danielebarchiesi@0 2885 $form['date_format'] = array(
danielebarchiesi@0 2886 '#type' => 'textfield',
danielebarchiesi@0 2887 '#title' => t('Format string'),
danielebarchiesi@0 2888 '#maxlength' => 100,
danielebarchiesi@0 2889 '#description' => t('A user-defined date format. See the <a href="@url">PHP manual</a> for available options.', array('@url' => 'http://php.net/manual/function.date.php')),
danielebarchiesi@0 2890 '#default_value' => ($dfid ? $format->format : ''),
danielebarchiesi@0 2891 '#field_suffix' => ' <small id="edit-date-format-suffix">' . $now . '</small>',
danielebarchiesi@0 2892 '#attached' => array(
danielebarchiesi@0 2893 'js' => array(drupal_get_path('module', 'system') . '/system.js', $js_settings),
danielebarchiesi@0 2894 ),
danielebarchiesi@0 2895 '#required' => TRUE,
danielebarchiesi@0 2896 );
danielebarchiesi@0 2897
danielebarchiesi@0 2898 $form['actions'] = array('#type' => 'actions');
danielebarchiesi@0 2899 $form['actions']['update'] = array(
danielebarchiesi@0 2900 '#type' => 'submit',
danielebarchiesi@0 2901 '#value' => ($dfid ? t('Save format') : t('Add format')),
danielebarchiesi@0 2902 );
danielebarchiesi@0 2903
danielebarchiesi@0 2904 $form['#validate'][] = 'system_add_date_formats_form_validate';
danielebarchiesi@0 2905 $form['#submit'][] = 'system_add_date_formats_form_submit';
danielebarchiesi@0 2906
danielebarchiesi@0 2907 return $form;
danielebarchiesi@0 2908 }
danielebarchiesi@0 2909
danielebarchiesi@0 2910 /**
danielebarchiesi@0 2911 * Validate new date format string submission.
danielebarchiesi@0 2912 */
danielebarchiesi@0 2913 function system_add_date_formats_form_validate($form, &$form_state) {
danielebarchiesi@0 2914 $formats = system_get_date_formats('custom');
danielebarchiesi@0 2915 $format = trim($form_state['values']['date_format']);
danielebarchiesi@0 2916 if (!empty($formats) && in_array($format, array_keys($formats)) && (!isset($form_state['values']['dfid']) || $form_state['values']['dfid'] != $formats[$format]['dfid'])) {
danielebarchiesi@0 2917 form_set_error('date_format', t('This format already exists. Enter a unique format string.'));
danielebarchiesi@0 2918 }
danielebarchiesi@0 2919 }
danielebarchiesi@0 2920
danielebarchiesi@0 2921 /**
danielebarchiesi@0 2922 * Process new date format string submission.
danielebarchiesi@0 2923 */
danielebarchiesi@0 2924 function system_add_date_formats_form_submit($form, &$form_state) {
danielebarchiesi@0 2925 $format = array();
danielebarchiesi@0 2926 $format['format'] = trim($form_state['values']['date_format']);
danielebarchiesi@0 2927 $format['type'] = 'custom';
danielebarchiesi@0 2928 $format['locked'] = 0;
danielebarchiesi@0 2929 if (!empty($form_state['values']['dfid'])) {
danielebarchiesi@0 2930 system_date_format_save($format, $form_state['values']['dfid']);
danielebarchiesi@0 2931 drupal_set_message(t('Custom date format updated.'));
danielebarchiesi@0 2932 }
danielebarchiesi@0 2933 else {
danielebarchiesi@0 2934 $format['is_new'] = 1;
danielebarchiesi@0 2935 system_date_format_save($format);
danielebarchiesi@0 2936 drupal_set_message(t('Custom date format added.'));
danielebarchiesi@0 2937 }
danielebarchiesi@0 2938
danielebarchiesi@0 2939 $form_state['redirect'] = 'admin/config/regional/date-time/formats';
danielebarchiesi@0 2940 }
danielebarchiesi@0 2941
danielebarchiesi@0 2942 /**
danielebarchiesi@0 2943 * Menu callback; Displays an overview of available and configured actions.
danielebarchiesi@0 2944 */
danielebarchiesi@0 2945 function system_actions_manage() {
danielebarchiesi@0 2946 actions_synchronize();
danielebarchiesi@0 2947 $actions = actions_list();
danielebarchiesi@0 2948 $actions_map = actions_actions_map($actions);
danielebarchiesi@0 2949 $options = array();
danielebarchiesi@0 2950 $unconfigurable = array();
danielebarchiesi@0 2951
danielebarchiesi@0 2952 foreach ($actions_map as $key => $array) {
danielebarchiesi@0 2953 if ($array['configurable']) {
danielebarchiesi@0 2954 $options[$key] = $array['label'] . '...';
danielebarchiesi@0 2955 }
danielebarchiesi@0 2956 else {
danielebarchiesi@0 2957 $unconfigurable[] = $array;
danielebarchiesi@0 2958 }
danielebarchiesi@0 2959 }
danielebarchiesi@0 2960
danielebarchiesi@0 2961 $row = array();
danielebarchiesi@0 2962 $instances_present = db_query("SELECT aid FROM {actions} WHERE parameters <> ''")->fetchField();
danielebarchiesi@0 2963 $header = array(
danielebarchiesi@0 2964 array('data' => t('Action type'), 'field' => 'type'),
danielebarchiesi@0 2965 array('data' => t('Label'), 'field' => 'label'),
danielebarchiesi@0 2966 array('data' => $instances_present ? t('Operations') : '', 'colspan' => '2')
danielebarchiesi@0 2967 );
danielebarchiesi@0 2968 $query = db_select('actions')->extend('PagerDefault')->extend('TableSort');
danielebarchiesi@0 2969 $result = $query
danielebarchiesi@0 2970 ->fields('actions')
danielebarchiesi@0 2971 ->limit(50)
danielebarchiesi@0 2972 ->orderByHeader($header)
danielebarchiesi@0 2973 ->execute();
danielebarchiesi@0 2974
danielebarchiesi@0 2975 foreach ($result as $action) {
danielebarchiesi@0 2976 $row[] = array(
danielebarchiesi@0 2977 array('data' => $action->type),
danielebarchiesi@0 2978 array('data' => check_plain($action->label)),
danielebarchiesi@0 2979 array('data' => $action->parameters ? l(t('configure'), "admin/config/system/actions/configure/$action->aid") : ''),
danielebarchiesi@0 2980 array('data' => $action->parameters ? l(t('delete'), "admin/config/system/actions/delete/$action->aid") : '')
danielebarchiesi@0 2981 );
danielebarchiesi@0 2982 }
danielebarchiesi@0 2983
danielebarchiesi@0 2984 if ($row) {
danielebarchiesi@0 2985 $pager = theme('pager');
danielebarchiesi@0 2986 if (!empty($pager)) {
danielebarchiesi@0 2987 $row[] = array(array('data' => $pager, 'colspan' => '3'));
danielebarchiesi@0 2988 }
danielebarchiesi@0 2989 $build['system_actions_header'] = array('#markup' => '<h3>' . t('Available actions:') . '</h3>');
danielebarchiesi@0 2990 $build['system_actions_table'] = array('#markup' => theme('table', array('header' => $header, 'rows' => $row)));
danielebarchiesi@0 2991 }
danielebarchiesi@0 2992
danielebarchiesi@0 2993 if ($actions_map) {
danielebarchiesi@0 2994 $build['system_actions_manage_form'] = drupal_get_form('system_actions_manage_form', $options);
danielebarchiesi@0 2995 }
danielebarchiesi@0 2996
danielebarchiesi@0 2997 return $build;
danielebarchiesi@0 2998 }
danielebarchiesi@0 2999
danielebarchiesi@0 3000 /**
danielebarchiesi@0 3001 * Define the form for the actions overview page.
danielebarchiesi@0 3002 *
danielebarchiesi@0 3003 * @param $form_state
danielebarchiesi@0 3004 * An associative array containing the current state of the form; not used.
danielebarchiesi@0 3005 * @param $options
danielebarchiesi@0 3006 * An array of configurable actions.
danielebarchiesi@0 3007 * @return
danielebarchiesi@0 3008 * Form definition.
danielebarchiesi@0 3009 *
danielebarchiesi@0 3010 * @ingroup forms
danielebarchiesi@0 3011 * @see system_actions_manage_form_submit()
danielebarchiesi@0 3012 */
danielebarchiesi@0 3013 function system_actions_manage_form($form, &$form_state, $options = array()) {
danielebarchiesi@0 3014 $form['parent'] = array(
danielebarchiesi@0 3015 '#type' => 'fieldset',
danielebarchiesi@0 3016 '#title' => t('Create an advanced action'),
danielebarchiesi@0 3017 '#attributes' => array('class' => array('container-inline')),
danielebarchiesi@0 3018 );
danielebarchiesi@0 3019 $form['parent']['action'] = array(
danielebarchiesi@0 3020 '#type' => 'select',
danielebarchiesi@0 3021 '#title' => t('Action'),
danielebarchiesi@0 3022 '#title_display' => 'invisible',
danielebarchiesi@0 3023 '#options' => $options,
danielebarchiesi@0 3024 '#empty_option' => t('Choose an advanced action'),
danielebarchiesi@0 3025 );
danielebarchiesi@0 3026 $form['parent']['actions'] = array('#type' => 'actions');
danielebarchiesi@0 3027 $form['parent']['actions']['submit'] = array(
danielebarchiesi@0 3028 '#type' => 'submit',
danielebarchiesi@0 3029 '#value' => t('Create'),
danielebarchiesi@0 3030 );
danielebarchiesi@0 3031 return $form;
danielebarchiesi@0 3032 }
danielebarchiesi@0 3033
danielebarchiesi@0 3034 /**
danielebarchiesi@0 3035 * Process system_actions_manage form submissions.
danielebarchiesi@0 3036 *
danielebarchiesi@0 3037 * @see system_actions_manage_form()
danielebarchiesi@0 3038 */
danielebarchiesi@0 3039 function system_actions_manage_form_submit($form, &$form_state) {
danielebarchiesi@0 3040 if ($form_state['values']['action']) {
danielebarchiesi@0 3041 $form_state['redirect'] = 'admin/config/system/actions/configure/' . $form_state['values']['action'];
danielebarchiesi@0 3042 }
danielebarchiesi@0 3043 }
danielebarchiesi@0 3044
danielebarchiesi@0 3045 /**
danielebarchiesi@0 3046 * Menu callback; Creates the form for configuration of a single action.
danielebarchiesi@0 3047 *
danielebarchiesi@0 3048 * We provide the "Description" field. The rest of the form is provided by the
danielebarchiesi@0 3049 * action. We then provide the Save button. Because we are combining unknown
danielebarchiesi@0 3050 * form elements with the action configuration form, we use an 'actions_' prefix
danielebarchiesi@0 3051 * on our elements.
danielebarchiesi@0 3052 *
danielebarchiesi@0 3053 * @param $action
danielebarchiesi@0 3054 * Hash of an action ID or an integer. If it is a hash, we are
danielebarchiesi@0 3055 * creating a new instance. If it is an integer, we are editing an existing
danielebarchiesi@0 3056 * instance.
danielebarchiesi@0 3057 * @return
danielebarchiesi@0 3058 * A form definition.
danielebarchiesi@0 3059 *
danielebarchiesi@0 3060 * @see system_actions_configure_validate()
danielebarchiesi@0 3061 * @see system_actions_configure_submit()
danielebarchiesi@0 3062 */
danielebarchiesi@0 3063 function system_actions_configure($form, &$form_state, $action = NULL) {
danielebarchiesi@0 3064 if ($action === NULL) {
danielebarchiesi@0 3065 drupal_goto('admin/config/system/actions');
danielebarchiesi@0 3066 }
danielebarchiesi@0 3067
danielebarchiesi@0 3068 $actions_map = actions_actions_map(actions_list());
danielebarchiesi@0 3069 $edit = array();
danielebarchiesi@0 3070
danielebarchiesi@0 3071 // Numeric action denotes saved instance of a configurable action.
danielebarchiesi@0 3072 if (is_numeric($action)) {
danielebarchiesi@0 3073 $aid = $action;
danielebarchiesi@0 3074 // Load stored parameter values from database.
danielebarchiesi@0 3075 $data = db_query("SELECT * FROM {actions} WHERE aid = :aid", array(':aid' => $aid))->fetch();
danielebarchiesi@0 3076 $edit['actions_label'] = $data->label;
danielebarchiesi@0 3077 $edit['actions_type'] = $data->type;
danielebarchiesi@0 3078 $function = $data->callback;
danielebarchiesi@0 3079 $action = drupal_hash_base64($data->callback);
danielebarchiesi@0 3080 $params = unserialize($data->parameters);
danielebarchiesi@0 3081 if ($params) {
danielebarchiesi@0 3082 foreach ($params as $name => $val) {
danielebarchiesi@0 3083 $edit[$name] = $val;
danielebarchiesi@0 3084 }
danielebarchiesi@0 3085 }
danielebarchiesi@0 3086 }
danielebarchiesi@0 3087 // Otherwise, we are creating a new action instance.
danielebarchiesi@0 3088 else {
danielebarchiesi@0 3089 $function = $actions_map[$action]['callback'];
danielebarchiesi@0 3090 $edit['actions_label'] = $actions_map[$action]['label'];
danielebarchiesi@0 3091 $edit['actions_type'] = $actions_map[$action]['type'];
danielebarchiesi@0 3092 }
danielebarchiesi@0 3093
danielebarchiesi@0 3094 $form['actions_label'] = array(
danielebarchiesi@0 3095 '#type' => 'textfield',
danielebarchiesi@0 3096 '#title' => t('Label'),
danielebarchiesi@0 3097 '#default_value' => $edit['actions_label'],
danielebarchiesi@0 3098 '#maxlength' => '255',
danielebarchiesi@0 3099 '#description' => t('A unique label for this advanced action. This label will be displayed in the interface of modules that integrate with actions, such as Trigger module.'),
danielebarchiesi@0 3100 '#weight' => -10
danielebarchiesi@0 3101 );
danielebarchiesi@0 3102 $action_form = $function . '_form';
danielebarchiesi@0 3103 $form = array_merge($form, $action_form($edit));
danielebarchiesi@0 3104 $form['actions_type'] = array(
danielebarchiesi@0 3105 '#type' => 'value',
danielebarchiesi@0 3106 '#value' => $edit['actions_type'],
danielebarchiesi@0 3107 );
danielebarchiesi@0 3108 $form['actions_action'] = array(
danielebarchiesi@0 3109 '#type' => 'hidden',
danielebarchiesi@0 3110 '#value' => $action,
danielebarchiesi@0 3111 );
danielebarchiesi@0 3112 // $aid is set when configuring an existing action instance.
danielebarchiesi@0 3113 if (isset($aid)) {
danielebarchiesi@0 3114 $form['actions_aid'] = array(
danielebarchiesi@0 3115 '#type' => 'hidden',
danielebarchiesi@0 3116 '#value' => $aid,
danielebarchiesi@0 3117 );
danielebarchiesi@0 3118 }
danielebarchiesi@0 3119 $form['actions_configured'] = array(
danielebarchiesi@0 3120 '#type' => 'hidden',
danielebarchiesi@0 3121 '#value' => '1',
danielebarchiesi@0 3122 );
danielebarchiesi@0 3123 $form['actions'] = array('#type' => 'actions');
danielebarchiesi@0 3124 $form['actions']['submit'] = array(
danielebarchiesi@0 3125 '#type' => 'submit',
danielebarchiesi@0 3126 '#value' => t('Save'),
danielebarchiesi@0 3127 '#weight' => 13
danielebarchiesi@0 3128 );
danielebarchiesi@0 3129
danielebarchiesi@0 3130 return $form;
danielebarchiesi@0 3131 }
danielebarchiesi@0 3132
danielebarchiesi@0 3133 /**
danielebarchiesi@0 3134 * Validate system_actions_configure() form submissions.
danielebarchiesi@0 3135 */
danielebarchiesi@0 3136 function system_actions_configure_validate($form, &$form_state) {
danielebarchiesi@0 3137 $function = actions_function_lookup($form_state['values']['actions_action']) . '_validate';
danielebarchiesi@0 3138 // Hand off validation to the action.
danielebarchiesi@0 3139 if (function_exists($function)) {
danielebarchiesi@0 3140 $function($form, $form_state);
danielebarchiesi@0 3141 }
danielebarchiesi@0 3142 }
danielebarchiesi@0 3143
danielebarchiesi@0 3144 /**
danielebarchiesi@0 3145 * Process system_actions_configure() form submissions.
danielebarchiesi@0 3146 */
danielebarchiesi@0 3147 function system_actions_configure_submit($form, &$form_state) {
danielebarchiesi@0 3148 $function = actions_function_lookup($form_state['values']['actions_action']);
danielebarchiesi@0 3149 $submit_function = $function . '_submit';
danielebarchiesi@0 3150
danielebarchiesi@0 3151 // Action will return keyed array of values to store.
danielebarchiesi@0 3152 $params = $submit_function($form, $form_state);
danielebarchiesi@0 3153 $aid = isset($form_state['values']['actions_aid']) ? $form_state['values']['actions_aid'] : NULL;
danielebarchiesi@0 3154
danielebarchiesi@0 3155 actions_save($function, $form_state['values']['actions_type'], $params, $form_state['values']['actions_label'], $aid);
danielebarchiesi@0 3156 drupal_set_message(t('The action has been successfully saved.'));
danielebarchiesi@0 3157
danielebarchiesi@0 3158 $form_state['redirect'] = 'admin/config/system/actions/manage';
danielebarchiesi@0 3159 }
danielebarchiesi@0 3160
danielebarchiesi@0 3161 /**
danielebarchiesi@0 3162 * Create the form for confirmation of deleting an action.
danielebarchiesi@0 3163 *
danielebarchiesi@0 3164 * @see system_actions_delete_form_submit()
danielebarchiesi@0 3165 * @ingroup forms
danielebarchiesi@0 3166 */
danielebarchiesi@0 3167 function system_actions_delete_form($form, &$form_state, $action) {
danielebarchiesi@0 3168 $form['aid'] = array(
danielebarchiesi@0 3169 '#type' => 'hidden',
danielebarchiesi@0 3170 '#value' => $action->aid,
danielebarchiesi@0 3171 );
danielebarchiesi@0 3172 return confirm_form($form,
danielebarchiesi@0 3173 t('Are you sure you want to delete the action %action?', array('%action' => $action->label)),
danielebarchiesi@0 3174 'admin/config/system/actions/manage',
danielebarchiesi@0 3175 t('This cannot be undone.'),
danielebarchiesi@0 3176 t('Delete'),
danielebarchiesi@0 3177 t('Cancel')
danielebarchiesi@0 3178 );
danielebarchiesi@0 3179 }
danielebarchiesi@0 3180
danielebarchiesi@0 3181 /**
danielebarchiesi@0 3182 * Process system_actions_delete form submissions.
danielebarchiesi@0 3183 *
danielebarchiesi@0 3184 * Post-deletion operations for action deletion.
danielebarchiesi@0 3185 */
danielebarchiesi@0 3186 function system_actions_delete_form_submit($form, &$form_state) {
danielebarchiesi@0 3187 $aid = $form_state['values']['aid'];
danielebarchiesi@0 3188 $action = actions_load($aid);
danielebarchiesi@0 3189 actions_delete($aid);
danielebarchiesi@0 3190 watchdog('user', 'Deleted action %aid (%action)', array('%aid' => $aid, '%action' => $action->label));
danielebarchiesi@0 3191 drupal_set_message(t('Action %action was deleted', array('%action' => $action->label)));
danielebarchiesi@0 3192 $form_state['redirect'] = 'admin/config/system/actions/manage';
danielebarchiesi@0 3193 }
danielebarchiesi@0 3194
danielebarchiesi@0 3195 /**
danielebarchiesi@0 3196 * Post-deletion operations for deleting action orphans.
danielebarchiesi@0 3197 *
danielebarchiesi@0 3198 * @param $orphaned
danielebarchiesi@0 3199 * An array of orphaned actions.
danielebarchiesi@0 3200 */
danielebarchiesi@0 3201 function system_action_delete_orphans_post($orphaned) {
danielebarchiesi@0 3202 foreach ($orphaned as $callback) {
danielebarchiesi@0 3203 drupal_set_message(t("Deleted orphaned action (%action).", array('%action' => $callback)));
danielebarchiesi@0 3204 }
danielebarchiesi@0 3205 }
danielebarchiesi@0 3206
danielebarchiesi@0 3207 /**
danielebarchiesi@0 3208 * Remove actions that are in the database but not supported by any enabled module.
danielebarchiesi@0 3209 */
danielebarchiesi@0 3210 function system_actions_remove_orphans() {
danielebarchiesi@0 3211 actions_synchronize(TRUE);
danielebarchiesi@0 3212 drupal_goto('admin/config/system/actions/manage');
danielebarchiesi@0 3213 }