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