prefix}icl_core_status"); mysql_query("TRUNCATE TABLE {$wpdb->prefix}icl_content_status"); mysql_query("TRUNCATE TABLE {$wpdb->prefix}icl_string_status"); mysql_query("TRUNCATE TABLE {$wpdb->prefix}icl_node"); mysql_query("TRUNCATE TABLE {$wpdb->prefix}icl_reminders"); echo ""; exit; case 'ghost_clean': // clean the icl_translations table $orphans = $wpdb->get_col(" SELECT t.translation_id FROM {$wpdb->prefix}icl_translations t LEFT JOIN {$wpdb->posts} p ON t.element_id = p.ID WHERE t.element_id IS NOT NULL AND t.element_type LIKE 'post\\_%' AND p.ID IS NULL "); if(!empty($orphans)){ $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translations WHERE translation_id IN (".join(',',$orphans).")"); } $orphans = $wpdb->get_col(" SELECT t.translation_id FROM {$wpdb->prefix}icl_translations t LEFT JOIN {$wpdb->comments} c ON t.element_id = c.comment_ID WHERE t.element_type = 'comment' AND c.comment_ID IS NULL "); echo mysql_error(); if(!empty($orphans)){ $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translations WHERE translation_id IN (".join(',',$orphans).")"); } $orphans = $wpdb->get_col(" SELECT t.translation_id FROM {$wpdb->prefix}icl_translations t LEFT JOIN {$wpdb->term_taxonomy} p ON t.element_id = p.term_taxonomy_id WHERE t.element_id IS NOT NULL AND t.element_type LIKE 'tax\\_%' AND p.term_taxonomy_id IS NULL"); if(!empty($orphans)){ $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translations WHERE translation_id IN (".join(',',$orphans).")"); } global $wp_taxonomies; if (is_array($wp_taxonomies)) { foreach ($wp_taxonomies as $t => $v) { $orphans = $wpdb->get_col(" SELECT t.translation_id FROM {$wpdb->prefix}icl_translations t LEFT JOIN {$wpdb->term_taxonomy} p ON t.element_id = p.term_taxonomy_id WHERE t.element_type = 'tax_{$t}' AND p.taxonomy <> '{$t}' "); if (!empty($orphans)) { $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translations WHERE translation_id IN (".join(',',$orphans).")"); } } } // remove ghost translations // get unlinked rids $rids = $wpdb->get_col("SELECT rid FROM {$wpdb->prefix}icl_translation_status WHERE translation_id NOT IN (SELECT translation_id FROM {$wpdb->prefix}icl_translations)"); $jids = $wpdb->get_col("SELECT job_id FROM {$wpdb->prefix}icl_translate_job WHERE rid IN (".join(',', $rids).")"); $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translate WHERE job_id IN (".join(',', $jids).")"); $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translate_job WHERE job_id IN (".join(',', $jids).")"); $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translation_status WHERE rid IN (".join(',', $rids).")"); // remove any duplicates in icl_translations $trs = $wpdb->get_results("SELECT element_id, GROUP_CONCAT(translation_id) AS tids FROM {$wpdb->prefix}icl_translations WHERE element_id > 0 AND element_type LIKE 'post\\_%' GROUP BY element_id"); foreach($trs as $r){ $exp = explode(',', $r->tids); if(count($exp) > 1){ $maxtid = max($exp); foreach($exp as $e){ if($e != $maxtid){ $wpdb->query($wpdb->prepare("DELETE FROM {$wpdb->prefix}icl_translations WHERE translation_id=%d", $e)); } } } } exit; break; case 'icl_sync_jobs': $iclq = new ICanLocalizeQuery($sitepress_settings['site_id'], $sitepress_settings['access_key']); $requests = $iclq->cms_requests_all(); if(!empty($requests)) foreach($requests as $request){ $source_language = ICL_Pro_Translation::server_languages_map($request['language_name'], true); $target_language = ICL_Pro_Translation::server_languages_map($request['target']['language_name'], true); $source_language = $wpdb->get_var($wpdb->prepare("SELECT code FROM {$wpdb->prefix}icl_languages WHERE english_name=%s", $source_language)); $target_language = $wpdb->get_var($wpdb->prepare("SELECT code FROM {$wpdb->prefix}icl_languages WHERE english_name=%s", $target_language)); // only handle old-style cms_id values if(!is_numeric($request['cms_id'])) continue; $tr = $wpdb->get_row($wpdb->prepare("SELECT * FROM {$wpdb->prefix}icl_translations WHERE translation_id=%d", $request['cms_id'])); if(empty($tr)){ $trs = $wpdb->get_row($wpdb->prepare("SELECT * FROM {$wpdb->prefix}icl_translation_status WHERE translation_id=%d", $request['cms_id'])); if(!empty($trs)){ $tpack = unserialize($trs->translation_package); $original_id = $tpack['contents']['original_id']['data']; list($trid, $element_type) = $wpdb->get_row(" SELECT trid, element_type FROM {$wpdb->prefix}icl_translations WHERE element_id={$original_id} AND element_type LIKE 'post\\_%' ", ARRAY_N); if($trid){ $wpdb->query("DELETE FROM {$wpdb->prefix}icl_translations WHERE trid={$trid} AND language_code='{$target_language}'"); $recover = array( 'translation_id' => $request['cms_id'], 'element_type' => $element_type, //'element_id' => this is NULL 'trid' => $trid, 'language_code' => $target_language, 'source_language_code' => $source_language ); $wpdb->insert($wpdb->prefix . 'icl_translations', $recover); } } } } // Do a check to see if the icl_translation_status is consistant. // There was a problem with the cancel logic leaving it in a status where // Translations couldn't be sent. global $iclTranslationManagement; $res = $wpdb->get_results($wpdb->prepare(" SELECT rid, status, needs_update, md5, translation_package FROM {$wpdb->prefix}icl_translation_status" )); foreach($res as $row){ if ($row->status == ICL_TM_NOT_TRANSLATED || $row->needs_update == 1) { $tpack = unserialize($row->translation_package); $original_id = $tpack['contents']['original_id']['data']; $post_md5 = $iclTranslationManagement->post_md5($original_id); if ($post_md5 == $row->md5) { // The md5 shouldn't be the same if it's not translated or needs update. // Add a dummy md5 and mark it as needs_update. $data = array('needs_update' => 1, 'md5' => 'XXXX'); $wpdb->update($wpdb->prefix.'icl_translation_status', $data, array('rid'=>$row->rid)); } } } exit; //break; case 'icl_cms_id_fix': $iclq = new ICanLocalizeQuery($sitepress_settings['site_id'], $sitepress_settings['access_key']); $p = $wpdb->get_row("SELECT t.* FROM {$wpdb->prefix}icl_translations t JOIN {$wpdb->prefix}icl_translation_status s ON t.translation_id=s.translation_id WHERE t.element_type LIKE 'post\\_%' AND t.source_language_code IS NOT NULL AND s.translation_service='icanlocalize' LIMIT {$_REQUEST['offset']}, 1"); if(!empty($p)){ $original_id = $wpdb->get_var($wpdb->prepare("SELECT element_id FROM {$wpdb->prefix}icl_translations WHERE trid=%d AND source_language_code IS NULL", $p->trid)); if($p->element_type=='post_page'){ $permalink = get_option('home') . '?page_id=' . $original_id; }else{ $permalink = get_option('home') . '?p=' . $original_id; } $_lang_details = $sitepress->get_language_details($p->source_language_code); $from_language = ICL_Pro_Translation::server_languages_map($_lang_details['english_name']); $_lang_details = $sitepress->get_language_details($p->language_code); $to_language = ICL_Pro_Translation::server_languages_map($_lang_details['english_name']); $cms_id = sprintf('%s_%d_%s_%s', preg_replace('#^post_#','',$p->element_type), $original_id, $p->source_language_code, $p->language_code); $ret = $iclq->update_cms_id(compact('permalink', 'from_language', 'to_language', 'cms_id')); if($ret != $cms_id && $iclq->error()){ echo json_encode(array('errors'=>1, 'message'=>$iclq->error(), 'cont'=>0)); }else{ echo json_encode(array('errors'=>0, 'message'=>'OK', 'cont'=>1)); } }else{ echo json_encode(array('errors'=>0, 'message'=>__('Done', 'sitepress'), 'cont'=>0)); } exit; //break; case 'icl_cleanup': global $sitepress, $wpdb, $wp_post_types; $post_types = array_keys($wp_post_types); foreach($post_types as $pt){ $types[] = 'post_' . $pt; } /* * Messed up on 2.0 upgrade */ // fix source_language_code // all source documents must have null $wpdb->query($wpdb->prepare("UPDATE {$wpdb->prefix}icl_translations SET source_language_code = NULL WHERE element_type IN('".join("','", $types)."') AND source_language_code = '' AND language_code='%s'", $sitepress->get_default_language())); // get translated documents with missing source language $res = $wpdb->get_results($wpdb->prepare(" SELECT translation_id, trid, language_code FROM {$wpdb->prefix}icl_translations WHERE (source_language_code = '' OR source_language_code IS NULL) AND element_type IN('".join("','", $types)."') AND language_code <> %s ", $sitepress->get_default_language() )); foreach($res as $row){ $wpdb->query($wpdb->prepare("UPDATE {$wpdb->prefix}icl_translations SET source_language_code = '%s' WHERE translation_id=%d", $sitepress->get_default_language(), $row->translation_id)); } break; case 'sync_cancelled': $iclq = new ICanLocalizeQuery($sitepress_settings['site_id'], $sitepress_settings['access_key']); $requests = $iclq->cms_requests_all(); if($requests === false) { echo json_encode(array('errors'=>1, 'message'=>'Failed fetching jobs list from the server.')); exit; } $cms_ids = array(); if(!empty($requests)) foreach($requests as $request){ $cms_ids[] = $request['cms_id']; } // get jobs that are in progress $translations = $wpdb->get_results(" SELECT t.element_id, t.element_type, t.language_code, t.source_language_code, t.trid, s.rid, s._prevstate, s.translation_id FROM {$wpdb->prefix}icl_translation_status s JOIN {$wpdb->prefix}icl_translations t ON t.translation_id = s.translation_id WHERE s.translation_service='icanlocalize' AND s.status = ".ICL_TM_IN_PROGRESS." "); $job2delete = $rids2cancel = array(); foreach($translations as $t){ $original_id = $wpdb->get_var($wpdb->prepare("SELECT element_id FROM {$wpdb->prefix}icl_translations WHERE trid=%d AND source_language_code IS NULL", $t->trid)); $cms_id = sprintf('%s_%d_%s_%s', preg_replace('#^post_#','', $t->element_type), $original_id, $t->source_language_code, $t->language_code); if(!in_array($cms_id, $cms_ids)){ $_lang_details = $sitepress->get_language_details($t->source_language_code); $lang_from = $_lang_details['english_name']; $_lang_details = $sitepress->get_language_details($t->language_code); $lang_to = $_lang_details['english_name']; $jobs2delete[] = ''.get_the_title($original_id).'' . sprintf(' - from %s to %s', $lang_from, $lang_to); $translations2cancel[] = $t; } } if(!empty($jobs2delete)){ echo json_encode(array('errors'=>0, 'message'=> '
', 'data' => array('t2c'=>serialize($translations2cancel)) ) ); }else{ echo json_encode(array('errors'=>0, 'message'=> 'Nothing to cancel.')); } exit; case 'sync_cancelled_do_delete': $translations = unserialize(stripslashes($_POST['t2c'])); if(is_array($translations)) foreach($translations as $t){ $job_id = $wpdb->get_var($wpdb->prepare("SELECT job_id FROM {$wpdb->prefix}icl_translate_job WHERE rid=%d AND revision IS NULL", $t->rid)); if($job_id){ $wpdb->query($wpdb->prepare("DELETE FROM {$wpdb->prefix}icl_translate_job WHERE job_id=%d", $job_id)); $wpdb->query($wpdb->prepare("DELETE FROM {$wpdb->prefix}icl_translate WHERE job_id=%d", $job_id)); $wpdb->query($wpdb->prepare("UPDATE {$wpdb->prefix}icl_translate_job SET revision = NULL WHERE rid=%d ORDER BY job_id DESC LIMIT 1", $t->rid)); } if(!empty($t->_prevstate)){ $_prevstate = unserialize($t->_prevstate); $wpdb->update($wpdb->prefix . 'icl_translation_status', array( 'status' => $_prevstate['status'], 'translator_id' => $_prevstate['translator_id'], 'status' => $_prevstate['status'], 'needs_update' => $_prevstate['needs_update'], 'md5' => $_prevstate['md5'], 'translation_service' => $_prevstate['translation_service'], 'translation_package' => $_prevstate['translation_package'], 'timestamp' => $_prevstate['timestamp'], 'links_fixed' => $_prevstate['links_fixed'] ), array('translation_id'=>$t->translation_id) ); $wpdb->query($wpdb->prepare("UPDATE {$wpdb->prefix}icl_translation_status SET _prevstate = NULL WHERE translation_id=%d",$t->translation_id)); }else{ $wpdb->update($wpdb->prefix . 'icl_translation_status', array('status'=>ICL_TM_NOT_TRANSLATED, 'needs_update'=>0), array('translation_id'=>$t->translation_id)); } } echo json_encode(array('errors'=>0, 'message'=> 'OK')); exit; case 'icl_ts_add_missing_language': $ptypes = array_keys($sitepress->get_translatable_documents()); $posts = $wpdb->get_results("SELECT * FROM {$wpdb->posts} WHERE post_type IN ('".join("','", $ptypes)."')"); foreach($posts as $p){ $tid = $wpdb->get_var($wpdb->prepare(" SELECT translation_id FROM {$wpdb->prefix}icl_translations WHERE element_type=%s AND element_id=%d ", 'post_' . $p->post_type, $p->ID)); if(!$tid){ $sitepress->set_element_language_details($p->ID, 'post_' . $p->post_type, null, $sitepress->get_default_language()); } } $ttypes = array(); foreach($ptypes as $ptype){ $ttypes = array_merge($sitepress->get_translatable_taxonomies(true, $ptype), $ttypes); } $ttypes = array_unique($ttypes); $taxs = $wpdb->get_results("SELECT * FROM {$wpdb->term_taxonomy} WHERE taxonomy IN ('".join("','", $ttypes)."')"); foreach($taxs as $t){ $tid = $wpdb->get_var($wpdb->prepare(" SELECT translation_id FROM {$wpdb->prefix}icl_translations WHERE element_type=%s AND element_id=%d ", 'tax_' . $t->taxonomy, $t->term_taxonomy_id)); if(!$tid){ $sitepress->set_element_language_details($t->term_taxonomy_id, 'tax_' . $t->taxonomy, null, $sitepress->get_default_language()); } } $cids = $wpdb->get_col("SELECT c.comment_ID FROM {$wpdb->comments} c LEFT JOIN {$wpdb->prefix}icl_translations t ON t.element_id = c.comment_id AND t.element_type='comment' WHERE t.element_id IS NULL"); foreach($cids as $cid){ $sitepress->set_element_language_details($cid, 'comment', null, $sitepress->get_default_language()); } exit; } } /* DEBUG ACTION */ $icl_tables = array( $wpdb->prefix . 'icl_languages', $wpdb->prefix . 'icl_languages_translations', $wpdb->prefix . 'icl_translations', $wpdb->prefix . 'icl_translation_status', $wpdb->prefix . 'icl_translate_job', $wpdb->prefix . 'icl_translate', $wpdb->prefix . 'icl_locale_map', $wpdb->prefix . 'icl_flags', $wpdb->prefix . 'icl_content_status', $wpdb->prefix . 'icl_core_status', $wpdb->prefix . 'icl_node', $wpdb->prefix . 'icl_strings', $wpdb->prefix . 'icl_string_translations', $wpdb->prefix . 'icl_string_status', $wpdb->prefix . 'icl_string_positions', $wpdb->prefix . 'icl_message_status', $wpdb->prefix . 'icl_reminders', ); if( (isset($_POST['icl_reset_allnonce']) && $_POST['icl_reset_allnonce']==wp_create_nonce('icl_reset_all'))){ if($_POST['icl-reset-all']=='on'){ icl_reset_wpml(); echo ''; } } ?>'.__('Not found!', 'sitepress').'
'; }else{ $results = $wpdb->get_results("DESCRIBE {$icl_table}", ARRAY_A); $keys = array_keys($results[0]); ?>
Removes entries from the WPML tables that are not linked properly. Cleans the table off entries left over upgrades, bug fixes or undetermined factors.
Fixes links between translation entries in the database and ICanLocalize.
', $wpdb->get_var("SELECT COUNT(*) FROM {$wpdb->prefix}icl_translations t JOIN {$wpdb->prefix}icl_translation_status s ON t.translation_id=s.translation_id WHERE t.element_type LIKE 'post\\_%' AND t.source_language_code IS NOT NULL AND s.translation_service='icanlocalize'")) ?>
Updates translation in progress with new style identifiers for documents. The new identifiers depend on the document being translated and the languages so it's not possible to get out of sync when translations are being deleted locally.
Sets source language to NULL in the icl_translations table.
When using the translation pickup mode cancelled jobs on ICanLocalize need to be synced manually.
Adds language information to posts and taxonomies that are missing this information.