123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280 |
- <?php
- /**
- * @file
- * Reusable API for creating and running l10n update batches.
- */
- // module_load_include will not work in batch.
- include_once 'l10n_update.check.inc';
- /**
- * Create a batch to just download files.
- *
- * @param $updates
- * Translations sources to be downloaded.
- * Note: All update sources must have a 'fileurl'.
- * @return array
- * A batch definition for this download.
- */
- function l10n_update_batch_download($updates) {
- foreach ($updates as $update) {
- $id = $update->filename;
- $operations[] = array('_l10n_update_batch_download', array($id, $update));
- }
- return _l10n_update_create_batch($operations);
- }
- /**
- * Create a batch to just import files.
- *
- * All update sources must have a 'uri'.
- *
- * @param $updates
- * Translations sources to be imported.
- * Note: All update sources must have a 'fileurl'.
- * @param $import_mode
- * Import mode. How to treat existing and modified translations.
- * @return array
- * A batch definition for this import.
- */
- function l10n_update_batch_import($updates, $import_mode) {
- foreach ($updates as $update) {
- $id = $update->filename;
- $operations[] = array('_l10n_update_batch_import', array($id, $update, $import_mode));
- }
- return _l10n_update_create_batch($operations);
- }
- /**
- * Create a big batch for multiple projects and languages.
- *
- * @param $updates
- * Array of update sources to be run.
- * @param $mode
- * Import mode. How to treat existing and modified translations.
- * @return array
- */
- function l10n_update_batch_multiple($updates, $import_mode) {
- foreach ($updates as $update) {
- $id = $update->filename;
- if ($update->type == 'download') {
- $operations[] = array('_l10n_update_batch_download', array($id, $update));
- $operations[] = array('_l10n_update_batch_import', array($id, NULL, $import_mode));
- }
- else {
- $operations[] = array('_l10n_update_batch_import', array($id, $update, $import_mode));
- }
- // This one takes always parameters from results.
- $operations[] = array('_l10n_update_batch_history', array($id));
- }
- if (!empty($operations)) {
- return _l10n_update_create_batch($operations);
- }
- }
- /**
- * Create batch stub for this module.
- *
- * @param $operations
- * Operations to perform in this batch.
- * @return array
- * A batch definition:
- * - 'operations': Batch operations
- * - 'title': Batch title.
- * - 'init_message': Initial batch UI message.
- * - 'error_message': Batch error message.
- * - 'file': File containing callback function.
- * - 'finished': Batch completed callback function.
- */
- function _l10n_update_create_batch($operations = array()) {
- $t = get_t();
- $batch = array(
- 'operations' => $operations,
- 'title' => $t('Updating translation.'),
- 'init_message' => $t('Downloading and importing files.'),
- 'error_message' => $t('Error importing interface translations'),
- 'file' => drupal_get_path('module', 'l10n_update') . '/l10n_update.batch.inc',
- 'finished' => '_l10n_update_batch_finished',
- );
- return $batch;
- }
- /**
- * Batch process: Download a file.
- *
- * @param $id
- * Batch id to identify batch results.
- * Result of this batch function are stored in $context['result']
- * identified by this $id.
- * @param $file
- * File to be downloaded.
- * @param $context
- * Batch context array.
- */
- function _l10n_update_batch_download($id, $file, &$context) {
- $t = get_t();
- if (l10n_update_source_download($file)) {
- $context['message'] = $t('Importing: %name.', array('%name' => $file->filename));
- $context['results'][$id] = array('file' => $file);
- }
- else {
- $context['results'][$id] = array('file' => $file, 'fail' => TRUE);
- }
- }
- /**
- * Batch process: Update the download history table.
- *
- * @param $id
- * Batch id to identify batch results.
- * Result of this batch function are stored in $context['result']
- * identified by this $id.
- * @param $context
- * Batch context array.
- */
- function _l10n_update_batch_history($id, &$context) {
- $t = get_t();
- // The batch import is performed in a number of steps. History update is
- // always the last step. The details of the downloaded/imported file are
- // stored in $context['results'] array.
- if (isset($context['results'][$id]['file']) && !isset($context['results'][$id]['fail'])) {
- $file = $context['results'][$id]['file'];
- l10n_update_source_history($file);
- $context['message'] = $t('Imported: %name.', array('%name' => $file->filename));
- }
- }
- /**
- * Batch process: Import translation file.
- *
- * This takes a file parameter or continues from previous batch
- * which should have downloaded a file.
- *
- * @param $id
- * Batch id to identify batch results.
- * Result of this batch function are stored in $context['result']
- * identified by this $id.
- * @param $file
- * File to be imported. If empty, the file will be taken from $context['results'].
- * @param $mode
- * Import mode. How to treat existing and modified translations.
- * @param $context
- * Batch context array.
- */
- function _l10n_update_batch_import($id, $file, $mode, &$context) {
- $t = get_t();
- // The batch import is performed in two or three steps.
- // If import is performed after file download the file details of the download
- // are used which are stored in the $context['results'] array.
- // If a locally stored file is imported, the file details are placed in $file.
- if (empty($file) && isset($context['results'][$id]['file']) && !isset($context['results'][$id]['fail'])) {
- $file = $context['results'][$id]['file'];
- }
- if ($file) {
- // Create a result if none exists yet.
- if (!isset($context['results'][$id])) {
- $context['results'][$id] = array();
- }
- if ($import_result = l10n_update_source_import($file, $mode)) {
- $context['message'] = $t('Imported: %name.', array('%name' => $file->filename));
- $context['results'][$id] = array_merge((array)$context['results'][$id], $import_result, array('file' => $file));
- }
- else {
- $context['results'][$id] = array_merge((array)$context['results'][$id], array('fail' => TRUE), array('file' => $file));
- }
- }
- }
- /**
- * Batch finished callback: Set result message.
- *
- * @param $success
- * TRUE if batch succesfully completed.
- * @param $results
- * Batch results.
- */
- function _l10n_update_batch_finished($success, $results) {
- $totals = array(); // Sum of added, updated and deleted translations.
- $total_skip = 0; // Sum of skipped translations
- $messages = array(); // User feedback messages.
- $project_fail = $project_success = array(); // Project names of succesfull and failed imports.
- $t = get_t();
- if ($success) {
- // Summarize results of added, updated, deleted and skiped translations.
- // Added, updated and deleted are summarized per language to be displayed accordingly.
- foreach ($results as $result) {
- if (isset($result['fail'])) {
- // Collect project names of the failed imports.
- $project_fail[$result['file']->name] = $result['file']->name;
- }
- else {
- $language = $result['language'];
- // Initialize variables to prevent PHP Notices.
- if (!isset($totals[$language])) {
- $totals[$language] = array();
- $totals[$language]['add'] = $totals[$language]['update'] = $totals[$language]['delete'] = 0;
- }
- // Summarize added, updated, deleted and skiped translations.
- $totals[$language]['add'] += $result['add'];
- $totals[$language]['update'] += $result['update'];
- $totals[$language]['delete'] += $result['delete'];
- $total_skip += $result['skip'];
- // Collect project names of the succesfull imports.
- $project_success[$result['file']->name] = $result['file']->name;
- }
- }
- // Messages of succesfull translation update results.
- if ($project_success) {
- $messages[] = format_plural(count($project_success), 'One project updated: @projects.', '@count projects updated: @projects.', array('@projects' => implode(', ', $project_success)));
- $languages = language_list();
- foreach ($totals as $language => $total) {
- $messages[] = $t('%language translation strings added: !add, updated: !update, deleted: !delete.', array(
- '%language' => $languages[$language]->name,
- '!add' => $total['add'],
- '!update' => $total['update'],
- '!delete' => $total['delete'],
- ));
- }
- drupal_set_message(implode("<br />\n", $messages));
- // Warning for disallowed HTML.
- if ($total_skip) {
- drupal_set_message(
- format_plural(
- $total_skip,
- 'One translation string was skipped because it contains disallowed HTML. See !log_messages for details.',
- '@count translation strings were skipped because they contain disallowed HTML. See !log_messages for details.',
- array('!log_messages' => l(t('Recent log messages'), 'admin/reports/dblog'))),
- 'warning');
- }
- // Clear cache and force refresh of JavaScript translations and rebuild
- // the menu as strings may have changed.
- foreach (array_keys($totals) as $langcode) {
- _locale_invalidate_js($langcode);
- }
- cache_clear_all('locale:', 'cache', TRUE);
- menu_rebuild();
- }
- // Error for failed imports.
- if ($project_fail) {
- drupal_set_message(
- format_plural(
- count($project_fail),
- 'Translations of one project were not imported: @projects.',
- 'Translations of @count projects were not imported: @projects',
- array('@projects' => implode(', ', $project_fail))),
- 'error');
- }
- }
- else {
- drupal_set_message($t('Error importing translations.'), 'error');
- }
- }
|