function _update_requirement_check in Drupal 8
Same name and namespace in other branches
- 6 modules/update/update.module \_update_requirement_check()
- 7 modules/update/update.install \_update_requirement_check()
- 9 core/modules/update/update.install \_update_requirement_check()
Fills in the requirements array.
This is shared for both core and contrib to generate the right elements in the array for hook_requirements().
Parameters
$project: Array of information about the project we're testing as returned by update_calculate_project_data().
$type: What kind of project this is ('core' or 'contrib').
Return value
An array to be included in the nested $requirements array.
See also
update_calculate_project_data()
1 call to _update_requirement_check()
- update_requirements in core/
modules/ update/ update.install - Implements hook_requirements().
File
- core/
modules/ update/ update.install, line 113 - Install, update, and uninstall functions for the Update Manager module.
Code
function _update_requirement_check($project, $type) {
$requirement = [];
if ($type == 'core') {
$requirement['title'] = t('Drupal core update status');
}
else {
$requirement['title'] = t('Module and theme update status');
}
$status = $project['status'];
if ($status != UpdateManagerInterface::CURRENT) {
$requirement['reason'] = $status;
$requirement['severity'] = REQUIREMENT_ERROR;
// When updates are available, append the available updates link to the
// message from _update_message_text(), and format the two translated
// strings together in a single paragraph.
$requirement['description'][] = [
'#markup' => _update_message_text($type, $status),
];
if (!in_array($status, [
UpdateFetcherInterface::UNKNOWN,
UpdateFetcherInterface::NOT_CHECKED,
UpdateFetcherInterface::NOT_FETCHED,
UpdateFetcherInterface::FETCH_PENDING,
])) {
if (_update_manager_access()) {
$requirement['description'][] = [
'#prefix' => ' ',
'#markup' => t('See the <a href=":available_updates">available updates</a> page for more information and to install your missing updates.', [
':available_updates' => Url::fromRoute('update.report_update')
->toString(),
]),
];
}
else {
$requirement['description'][] = [
'#prefix' => ' ',
'#markup' => t('See the <a href=":available_updates">available updates</a> page for more information.', [
':available_updates' => Url::fromRoute('update.status')
->toString(),
]),
];
}
}
}
switch ($status) {
case UpdateManagerInterface::NOT_SECURE:
$requirement_label = t('Not secure!');
break;
case UpdateManagerInterface::REVOKED:
$requirement_label = t('Revoked!');
break;
case UpdateManagerInterface::NOT_SUPPORTED:
$requirement_label = t('Unsupported release');
break;
case UpdateManagerInterface::NOT_CURRENT:
$requirement_label = t('Out of date');
$requirement['severity'] = REQUIREMENT_WARNING;
break;
case UpdateFetcherInterface::UNKNOWN:
case UpdateFetcherInterface::NOT_CHECKED:
case UpdateFetcherInterface::NOT_FETCHED:
case UpdateFetcherInterface::FETCH_PENDING:
$requirement_label = isset($project['reason']) ? $project['reason'] : t('Can not determine status');
$requirement['severity'] = REQUIREMENT_WARNING;
break;
default:
$requirement_label = t('Up to date');
}
if ($status != UpdateManagerInterface::CURRENT && $type == 'core' && isset($project['recommended'])) {
$requirement_label .= ' ' . t('(version @version available)', [
'@version' => $project['recommended'],
]);
}
$requirement['value'] = Link::fromTextAndUrl($requirement_label, Url::fromRoute(_update_manager_access() ? 'update.report_update' : 'update.status'))
->toString();
return $requirement;
}