function lingotek_admin_cleanup_form_submit in Lingotek Translation 7.7
Same name and namespace in other branches
- 7.5 lingotek.admin.inc \lingotek_admin_cleanup_form_submit()
- 7.6 lingotek.admin.inc \lingotek_admin_cleanup_form_submit()
Attempt to execute each of the cleanup functions selected by the requester.
_state
Parameters
array $form:
1 string reference to 'lingotek_admin_cleanup_form_submit'
- lingotek_admin_cleanup_form in ./
lingotek.admin.inc - Utilities form.
File
- ./
lingotek.admin.inc, line 2877
Code
function lingotek_admin_cleanup_form_submit($form, &$form_state) {
// All cleanup-related batch functions should exist in lingotek.util.inc
// and their return value should be a set batch.
$cleanup_batch = array(
'title' => t('Lingotek Cleanup Utility Batch'),
'operations' => array(
array(
'lingotek_cleanup_batch_init',
array(),
),
),
'file' => 'lingotek.util.inc',
);
batch_set($cleanup_batch);
foreach ($form_state['values']['grid'] as $cleanup_function) {
if (!$cleanup_function) {
// Function was not selected to run.
continue;
}
if (!function_exists($cleanup_function)) {
LingotekLog::error('Attempted to run non-existent cleanup function: @function', array(
'@function' => $cleanup_function,
));
continue;
}
try {
if ($cleanup_function === 'lingotek_cleanup_entity_references') {
$entity_reference_date = isset($form_state['input']['ltk_entity_reference_date']) ? $form_state['input']['ltk_entity_reference_date'] : NULL;
$cleanup_function($entity_reference_date);
}
else {
$cleanup_function();
}
} catch (Exception $e) {
LingotekLog::error('Failed to run cleanup function "@function". Error was: @error', array(
'@function' => $cleanup_function,
'@error' => $e
->getMessage(),
));
continue;
}
}
// Execute all set batches and then return.
batch_process();
}