--- /dev/null
+<?php
+
+/**
+ * @file
+ * Hooks provided by the Update Manager module.
+ */
+
+/**
+ * @addtogroup hooks
+ * @{
+ */
+
+/**
+ * Alter the list of projects before fetching data and comparing versions.
+ *
+ * Most modules will never need to implement this hook. It is for advanced
+ * interaction with the Update Manager module. The primary use-case for this
+ * hook is to add projects to the list; for example, to provide update status
+ * data on disabled modules and themes. A contributed module might want to hide
+ * projects from the list; for example, if there is a site-specific module that
+ * doesn't have any official releases, that module could remove itself from this
+ * list to avoid "No available releases found" warnings on the available updates
+ * report. In rare cases, a module might want to alter the data associated with
+ * a project already in the list.
+ *
+ * @param $projects
+ * Reference to an array of the projects installed on the system. This
+ * includes all the metadata documented in the comments below for each project
+ * (either module or theme) that is currently enabled. The array is initially
+ * populated inside \Drupal\Update\UpdateManager::getProjects() with the help
+ * of \Drupal\Core\Utility\ProjectInfo->processInfoList(), so look there for
+ * examples of how to populate the array with real values.
+ *
+ * @see \Drupal\Update\UpdateManager::getProjects()
+ * @see \Drupal\Core\Utility\ProjectInfo::processInfoList()
+ */
+function hook_update_projects_alter(&$projects) {
+ // Hide a site-specific module from the list.
+ unset($projects['site_specific_module']);
+
+ // Add a disabled module to the list.
+ // The key for the array should be the machine-readable project "short name".
+ $projects['disabled_project_name'] = [
+ // Machine-readable project short name (same as the array key above).
+ 'name' => 'disabled_project_name',
+ // Array of values from the main .info.yml file for this project.
+ 'info' => [
+ 'name' => 'Some disabled module',
+ 'description' => 'A module not enabled on the site that you want to see in the available updates report.',
+ 'version' => '8.x-1.0',
+ 'core' => '8.x',
+ // The maximum file change time (the "ctime" returned by the filectime()
+ // PHP method) for all of the .info.yml files included in this project.
+ '_info_file_ctime' => 1243888165,
+ ],
+ // The date stamp when the project was released, if known. If the disabled
+ // project was an officially packaged release from drupal.org, this will
+ // be included in the .info.yml file as the 'datestamp' field. This only
+ // really matters for development snapshot releases that are regenerated,
+ // so it can be left undefined or set to 0 in most cases.
+ 'datestamp' => 1243888185,
+ // Any modules (or themes) included in this project. Keyed by machine-
+ // readable "short name", value is the human-readable project name printed
+ // in the UI.
+ 'includes' => [
+ 'disabled_project' => 'Disabled module',
+ 'disabled_project_helper' => 'Disabled module helper module',
+ 'disabled_project_foo' => 'Disabled module foo add-on module',
+ ],
+ // Does this project contain a 'module', 'theme', 'disabled-module', or
+ // 'disabled-theme'?
+ 'project_type' => 'disabled-module',
+ ];
+}
+
+/**
+ * Alter the information about available updates for projects.
+ *
+ * @param $projects
+ * Reference to an array of information about available updates to each
+ * project installed on the system.
+ *
+ * @see update_calculate_project_data()
+ */
+function hook_update_status_alter(&$projects) {
+ $settings = \Drupal::config('update_advanced.settings')->get('projects');
+ foreach ($projects as $project => $project_info) {
+ if (isset($settings[$project]) && isset($settings[$project]['check']) &&
+ ($settings[$project]['check'] == 'never' ||
+ (isset($project_info['recommended']) &&
+ $settings[$project]['check'] === $project_info['recommended']))) {
+ $projects[$project]['status'] = UPDATE_NOT_CHECKED;
+ $projects[$project]['reason'] = t('Ignored from settings');
+ if (!empty($settings[$project]['notes'])) {
+ $projects[$project]['extra'][] = [
+ 'class' => ['admin-note'],
+ 'label' => t('Administrator note'),
+ 'data' => $settings[$project]['notes'],
+ ];
+ }
+ }
+ }
+}
+
+/**
+ * Verify an archive after it has been downloaded and extracted.
+ *
+ * @param string $project
+ * The short name of the project that has been downloaded.
+ * @param string $archive_file
+ * The filename of the unextracted archive.
+ * @param string $directory
+ * The directory that the archive was extracted into.
+ *
+ * @return
+ * If there are any problems, return an array of error messages. If there are
+ * no problems, return an empty array.
+ *
+ * @see update_manager_archive_verify()
+ * @ingroup update_manager_file
+ */
+function hook_verify_update_archive($project, $archive_file, $directory) {
+ $errors = [];
+ if (!file_exists($directory)) {
+ $errors[] = t('The %directory does not exist.', ['%directory' => $directory]);
+ }
+ // Add other checks on the archive integrity here.
+ return $errors;
+}
+
+/**
+ * @} End of "addtogroup hooks".
+ */