ResetTranslatorOfAutomaticJobs.php
1.68 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<?php
namespace WPML\TM\Upgrade\Commands;
class ResetTranslatorOfAutomaticJobs implements \IWPML_Upgrade_Command {
/** @var bool $result */
private $result = false;
public function run_admin() {
global $wpdb;
$automatic_column_exists = $wpdb->get_var(
"SHOW COLUMNS
FROM `{$wpdb->prefix}icl_translate_job`
LIKE 'automatic'"
);
if ( ! $automatic_column_exists ) {
// No need to reset translator of automatic jobs
// as this site never used automatic translation.
// Return true to mark this upgrade as done.
return true;
}
$subquery = "
SELECT job_id, rid
FROM {$wpdb->prefix}icl_translate_job
WHERE job_id IN (
SELECT MAX(job_id)
FROM {$wpdb->prefix}icl_translate_job
GROUP BY rid
) AND automatic = 1
";
$rowsToUpdate = $wpdb->get_results( $subquery );
if ( count( $rowsToUpdate ) ) {
$rids = \wpml_prepare_in( array_column( $rowsToUpdate, 'rid' ), '%d' );
$sql = "
UPDATE {$wpdb->prefix}icl_translation_status translation_status
SET translation_status.translator_id = 0
WHERE translation_status.rid IN ( $rids )
";
$wpdb->query( $sql );
$jobIds = \wpml_prepare_in( array_column( $rowsToUpdate, 'job_id' ), '%d' );
$sql = "
UPDATE {$wpdb->prefix}icl_translate_job
SET translator_id = 0
WHERE job_id IN ( $jobIds )
";
$wpdb->query( $sql );
}
$this->result = true;
return $this->result;
}
/**
* Unused.
*
* @return null
*/
public function run_ajax() {
return null;
}
/**
* Unused.
*
* @return null
*/
public function run_frontend() {
return null;
}
/**
* @return bool
*/
public function get_results() {
return $this->result;
}
}