annotate modules/update/update.api.php @ 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 * Hooks provided by the Update Manager module.
danielebarchiesi@0 6 */
danielebarchiesi@0 7
danielebarchiesi@0 8 /**
danielebarchiesi@0 9 * @addtogroup hooks
danielebarchiesi@0 10 * @{
danielebarchiesi@0 11 */
danielebarchiesi@0 12
danielebarchiesi@0 13 /**
danielebarchiesi@0 14 * Alter the list of projects before fetching data and comparing versions.
danielebarchiesi@0 15 *
danielebarchiesi@0 16 * Most modules will never need to implement this hook. It is for advanced
danielebarchiesi@0 17 * interaction with the Update Manager module. The primary use-case for this
danielebarchiesi@0 18 * hook is to add projects to the list; for example, to provide update status
danielebarchiesi@0 19 * data on disabled modules and themes. A contributed module might want to hide
danielebarchiesi@0 20 * projects from the list; for example, if there is a site-specific module that
danielebarchiesi@0 21 * doesn't have any official releases, that module could remove itself from this
danielebarchiesi@0 22 * list to avoid "No available releases found" warnings on the available updates
danielebarchiesi@0 23 * report. In rare cases, a module might want to alter the data associated with
danielebarchiesi@0 24 * a project already in the list.
danielebarchiesi@0 25 *
danielebarchiesi@0 26 * @param $projects
danielebarchiesi@0 27 * Reference to an array of the projects installed on the system. This
danielebarchiesi@0 28 * includes all the metadata documented in the comments below for each project
danielebarchiesi@0 29 * (either module or theme) that is currently enabled. The array is initially
danielebarchiesi@0 30 * populated inside update_get_projects() with the help of
danielebarchiesi@0 31 * _update_process_info_list(), so look there for examples of how to populate
danielebarchiesi@0 32 * the array with real values.
danielebarchiesi@0 33 *
danielebarchiesi@0 34 * @see update_get_projects()
danielebarchiesi@0 35 * @see _update_process_info_list()
danielebarchiesi@0 36 */
danielebarchiesi@0 37 function hook_update_projects_alter(&$projects) {
danielebarchiesi@0 38 // Hide a site-specific module from the list.
danielebarchiesi@0 39 unset($projects['site_specific_module']);
danielebarchiesi@0 40
danielebarchiesi@0 41 // Add a disabled module to the list.
danielebarchiesi@0 42 // The key for the array should be the machine-readable project "short name".
danielebarchiesi@0 43 $projects['disabled_project_name'] = array(
danielebarchiesi@0 44 // Machine-readable project short name (same as the array key above).
danielebarchiesi@0 45 'name' => 'disabled_project_name',
danielebarchiesi@0 46 // Array of values from the main .info file for this project.
danielebarchiesi@0 47 'info' => array(
danielebarchiesi@0 48 'name' => 'Some disabled module',
danielebarchiesi@0 49 'description' => 'A module not enabled on the site that you want to see in the available updates report.',
danielebarchiesi@0 50 'version' => '7.x-1.0',
danielebarchiesi@0 51 'core' => '7.x',
danielebarchiesi@0 52 // The maximum file change time (the "ctime" returned by the filectime()
danielebarchiesi@0 53 // PHP method) for all of the .info files included in this project.
danielebarchiesi@0 54 '_info_file_ctime' => 1243888165,
danielebarchiesi@0 55 ),
danielebarchiesi@0 56 // The date stamp when the project was released, if known. If the disabled
danielebarchiesi@0 57 // project was an officially packaged release from drupal.org, this will
danielebarchiesi@0 58 // be included in the .info file as the 'datestamp' field. This only
danielebarchiesi@0 59 // really matters for development snapshot releases that are regenerated,
danielebarchiesi@0 60 // so it can be left undefined or set to 0 in most cases.
danielebarchiesi@0 61 'datestamp' => 1243888185,
danielebarchiesi@0 62 // Any modules (or themes) included in this project. Keyed by machine-
danielebarchiesi@0 63 // readable "short name", value is the human-readable project name printed
danielebarchiesi@0 64 // in the UI.
danielebarchiesi@0 65 'includes' => array(
danielebarchiesi@0 66 'disabled_project' => 'Disabled module',
danielebarchiesi@0 67 'disabled_project_helper' => 'Disabled module helper module',
danielebarchiesi@0 68 'disabled_project_foo' => 'Disabled module foo add-on module',
danielebarchiesi@0 69 ),
danielebarchiesi@0 70 // Does this project contain a 'module', 'theme', 'disabled-module', or
danielebarchiesi@0 71 // 'disabled-theme'?
danielebarchiesi@0 72 'project_type' => 'disabled-module',
danielebarchiesi@0 73 );
danielebarchiesi@0 74 }
danielebarchiesi@0 75
danielebarchiesi@0 76 /**
danielebarchiesi@0 77 * Alter the information about available updates for projects.
danielebarchiesi@0 78 *
danielebarchiesi@0 79 * @param $projects
danielebarchiesi@0 80 * Reference to an array of information about available updates to each
danielebarchiesi@0 81 * project installed on the system.
danielebarchiesi@0 82 *
danielebarchiesi@0 83 * @see update_calculate_project_data()
danielebarchiesi@0 84 */
danielebarchiesi@0 85 function hook_update_status_alter(&$projects) {
danielebarchiesi@0 86 $settings = variable_get('update_advanced_project_settings', array());
danielebarchiesi@0 87 foreach ($projects as $project => $project_info) {
danielebarchiesi@0 88 if (isset($settings[$project]) && isset($settings[$project]['check']) &&
danielebarchiesi@0 89 ($settings[$project]['check'] == 'never' ||
danielebarchiesi@0 90 (isset($project_info['recommended']) &&
danielebarchiesi@0 91 $settings[$project]['check'] === $project_info['recommended']))) {
danielebarchiesi@0 92 $projects[$project]['status'] = UPDATE_NOT_CHECKED;
danielebarchiesi@0 93 $projects[$project]['reason'] = t('Ignored from settings');
danielebarchiesi@0 94 if (!empty($settings[$project]['notes'])) {
danielebarchiesi@0 95 $projects[$project]['extra'][] = array(
danielebarchiesi@0 96 'class' => array('admin-note'),
danielebarchiesi@0 97 'label' => t('Administrator note'),
danielebarchiesi@0 98 'data' => $settings[$project]['notes'],
danielebarchiesi@0 99 );
danielebarchiesi@0 100 }
danielebarchiesi@0 101 }
danielebarchiesi@0 102 }
danielebarchiesi@0 103 }
danielebarchiesi@0 104
danielebarchiesi@0 105 /**
danielebarchiesi@0 106 * Verify an archive after it has been downloaded and extracted.
danielebarchiesi@0 107 *
danielebarchiesi@0 108 * @param string $project
danielebarchiesi@0 109 * The short name of the project that has been downloaded.
danielebarchiesi@0 110 * @param string $archive_file
danielebarchiesi@0 111 * The filename of the unextracted archive.
danielebarchiesi@0 112 * @param string $directory
danielebarchiesi@0 113 * The directory that the archive was extracted into.
danielebarchiesi@0 114 *
danielebarchiesi@0 115 * @return
danielebarchiesi@0 116 * If there are any problems, return an array of error messages. If there are
danielebarchiesi@0 117 * no problems, return an empty array.
danielebarchiesi@0 118 *
danielebarchiesi@0 119 * @see update_manager_archive_verify()
danielebarchiesi@0 120 * @ingroup update_manager_file
danielebarchiesi@0 121 */
danielebarchiesi@0 122 function hook_verify_update_archive($project, $archive_file, $directory) {
danielebarchiesi@0 123 $errors = array();
danielebarchiesi@0 124 if (!file_exists($directory)) {
danielebarchiesi@0 125 $errors[] = t('The %directory does not exist.', array('%directory' => $directory));
danielebarchiesi@0 126 }
danielebarchiesi@0 127 // Add other checks on the archive integrity here.
danielebarchiesi@0 128 return $errors;
danielebarchiesi@0 129 }
danielebarchiesi@0 130
danielebarchiesi@0 131 /**
danielebarchiesi@0 132 * @} End of "addtogroup hooks".
danielebarchiesi@0 133 */