droy | 010bf7f | 2008-04-08 14:07:44 +0000 | [diff] [blame] | 1 | <?php |
| 2 | |
| 3 | /******************************************************************************* |
| 4 | * Copyright (c) 2008 Eclipse Foundation and others. |
| 5 | * All rights reserved. This program and the accompanying materials |
| 6 | * are made available under the terms of the Eclipse Public License v1.0 |
| 7 | * which accompanies this distribution, and is available at |
| 8 | * http://www.eclipse.org/legal/epl-v10.html |
| 9 | * |
| 10 | * Contributors: |
| 11 | * Eclipse Foundation - Initial API and implementation |
| 12 | *******************************************************************************/ |
| 13 | |
| 14 | /* |
| 15 | * This is a cronjob-driven database maintenance script |
| 16 | * It is run every 15 minutes |
| 17 | */ |
| 18 | |
droy | 0fed43f | 2009-02-02 20:10:21 +0000 | [diff] [blame] | 19 | require_once(dirname(__FILE__) . "/../system/backend_functions.php"); |
atoulme | 3ac5261 | 2009-02-02 13:14:39 +0000 | [diff] [blame] | 20 | global $addon; |
| 21 | $context = $addon->callHook('context'); |
droy | 010bf7f | 2008-04-08 14:07:44 +0000 | [diff] [blame] | 22 | |
atoulme | 843359e | 2009-02-03 13:28:54 +0000 | [diff] [blame] | 23 | require(dirname(__FILE__) . "/../system/dbconnection.class.php"); |
droy | 010bf7f | 2008-04-08 14:07:44 +0000 | [diff] [blame] | 24 | |
atoulme | 3ac5261 | 2009-02-02 13:14:39 +0000 | [diff] [blame] | 25 | |
droy | 010bf7f | 2008-04-08 14:07:44 +0000 | [diff] [blame] | 26 | if($context == "") { |
| 27 | $context = "staging"; |
| 28 | } |
| 29 | $dbc = new DBConnection(); |
| 30 | $dbh = $dbc->connect(); |
| 31 | |
| 32 | |
droy | dc29484 | 2008-05-21 17:38:57 +0000 | [diff] [blame] | 33 | # refresh the scoreboard -- not every 15 minutes! |
droy | 4da49d2 | 2008-10-08 20:33:50 +0000 | [diff] [blame] | 34 | $forceRefresh = strcasecmp(getenv("FORCE_BABEL_REFRESH"), "true"); |
droy | e77ad17 | 2009-05-04 17:35:56 +0000 | [diff] [blame] | 35 | if(rand(1, 100) < 25 || $forceRefresh) { |
atoulme | d5c6d61 | 2009-02-03 13:30:01 +0000 | [diff] [blame] | 36 | require_once(dirname(__FILE__) . "/../system/scoreboard.class.php"); |
droy | b156beb | 2008-05-15 17:16:44 +0000 | [diff] [blame] | 37 | $sb = new Scoreboard(); |
| 38 | $sb->refresh(); |
droy | dc29484 | 2008-05-21 17:38:57 +0000 | [diff] [blame] | 39 | |
| 40 | # Refresh file progress |
| 41 | # This only needs to happen once in a while too. |
| 42 | # See also: babel-setup.sql |
droy | 55f7a26 | 2009-06-04 19:26:06 +0000 | [diff] [blame] | 43 | $sql = "select f.file_id, l.language_id, IF(COUNT(s.string_id) > 0, COUNT(t.string_id)/COUNT(s.string_id)*100,100) AS translate_percent |
droy | dc29484 | 2008-05-21 17:38:57 +0000 | [diff] [blame] | 44 | FROM files AS f |
| 45 | INNER JOIN languages as l ON l.is_active = 1 |
droy | 898d37d | 2008-09-24 15:08:23 +0000 | [diff] [blame] | 46 | LEFT JOIN strings as s ON (s.file_id = f.file_id AND s.is_active AND s.value <> '' AND s.non_translatable <> 1) |
droy | dc29484 | 2008-05-21 17:38:57 +0000 | [diff] [blame] | 47 | LEFT JOIN translations AS t ON (s.string_id = t.string_id |
| 48 | AND t.language_id = l.language_id AND t.is_active = 1) |
| 49 | WHERE f.is_active = 1 |
droy | 55f7a26 | 2009-06-04 19:26:06 +0000 | [diff] [blame] | 50 | GROUP BY f.file_id, l.language_id |
| 51 | HAVING translate_percent > 0"; |
| 52 | $rs = mysql_query($sql, $dbh); |
| 53 | while($myrow = mysql_fetch_assoc($rs)) { |
| 54 | mysql_query("INSERT INTO file_progress (file_id, language_id, pct_complete) |
| 55 | VALUES(" . $myrow['file_id'] . ", " . $myrow['language_id'] . ", " . $myrow['translate_percent'] . ") |
| 56 | ON DUPLICATE KEY UPDATE pct_complete=" . $myrow['translate_percent'], $dbh); |
| 57 | } |
droy | dc29484 | 2008-05-21 17:38:57 +0000 | [diff] [blame] | 58 | mysql_query("DELETE FROM file_progress WHERE pct_complete = 0", $dbh); |
droy | b156beb | 2008-05-15 17:16:44 +0000 | [diff] [blame] | 59 | } |
| 60 | |
| 61 | # Update project/version/language progress |
| 62 | $sql = "SELECT * FROM project_progress WHERE is_stale"; |
| 63 | $rs = mysql_query($sql, $dbh); |
| 64 | while($myrow = mysql_fetch_assoc($rs)) { |
| 65 | mysql_query("LOCK TABLES project_progress WRITE, |
| 66 | project_versions AS v READ, |
| 67 | files AS f READ, |
| 68 | strings AS s READ, |
| 69 | translations AS t READ, |
| 70 | languages AS l READ |
| 71 | ", $dbh); |
| 72 | $sql = "DELETE /* dbmaintenance_15min.php */ FROM project_progress where project_id = '" . addslashes($myrow['project_id']) . "' |
| 73 | AND version = '" . addslashes($myrow['version']) . "' |
| 74 | AND language_id = " . $myrow['language_id']; |
| 75 | mysql_query($sql, $dbh); |
| 76 | |
| 77 | $sql = "INSERT /* dbmaintenance_15min.php */ INTO project_progress SET project_id = '" . addslashes($myrow['project_id']) . "', |
| 78 | version = '" . addslashes($myrow['version']) . "', |
| 79 | language_id = " . $myrow['language_id'] . ", |
| 80 | is_stale = 0, |
| 81 | pct_complete = ( |
| 82 | SELECT IF(COUNT(s.string_id) > 0, ROUND(COUNT(t.string_id)/COUNT(s.string_id) * 100, 2), 0) AS pct_complete |
| 83 | FROM project_versions AS v |
| 84 | INNER JOIN files AS f |
| 85 | ON (f.project_id = v.project_id AND f.version = v.version AND f.is_active) |
| 86 | INNER JOIN strings AS s |
droy | 1ddae59 | 2008-07-28 14:13:03 +0000 | [diff] [blame] | 87 | ON (s.file_id = f.file_id AND s.is_active AND s.value <> '' AND s.non_translatable = 0) |
droy | b156beb | 2008-05-15 17:16:44 +0000 | [diff] [blame] | 88 | INNER JOIN languages AS l ON l.language_id = " . $myrow['language_id'] . " |
| 89 | LEFT JOIN translations AS t |
| 90 | ON (t.string_id = s.string_id AND t.language_id = l.language_id AND t.is_active) |
| 91 | WHERE |
droy | 1ddae59 | 2008-07-28 14:13:03 +0000 | [diff] [blame] | 92 | v.project_id = '" . addslashes($myrow['project_id']) . "' |
droy | b156beb | 2008-05-15 17:16:44 +0000 | [diff] [blame] | 93 | AND v.version = '" . addslashes($myrow['version']) . "' |
| 94 | )"; |
droy | b156beb | 2008-05-15 17:16:44 +0000 | [diff] [blame] | 95 | mysql_query($sql, $dbh); |
| 96 | echo mysql_error(); |
| 97 | |
| 98 | # Let's lock and unlock in the loop to allow other queries to go through. There's no rush on completing these stats. |
| 99 | mysql_query("UNLOCK TABLES", $dbh); |
| 100 | sleep(2); |
| 101 | } |
droy | 4da49d2 | 2008-10-08 20:33:50 +0000 | [diff] [blame] | 102 | ?> |