Mageia build system status'; $robots = 'index,nofollow,nosnippet,noarchive'; if ($g_user) { $title .= ' for ' . $g_user . "'s packages"; $robots = 'no' . $robots; } $tz = new DateTimeZone('UTC'); $date_gen = date('c'); # Temporary until initial mirror is ready chdir("data"); $nb_rpm = shell_exec('rpm -qp --qf "%{SOURCERPM}\n" /distrib/bootstrap/distrib/cauldron/i586/media/core/release/*.rpm | sort -u | tee src.txt | wc -l'); $nb_rpm_mga = shell_exec('grep mga src.txt | tee src.mga.txt | wc -l'); shell_exec('grep -v mga src.txt > src.mdv.txt'); ######################################### chdir($upload_dir); $all_files = shell_exec("find \( -name '*.rpm' -o -name '*.src.rpm.info' -o -name '*.youri' -o -name '*.lock' -o -name '*.done' \) ! -ctime $max_modified -printf \"%p\t%T@\\n\""); $re = "!^\./(\w+)/((\w+)/(\w+)/(\w+)/(\d+)\.(\w+)\.(\w+)\.(\d+))_?(.+)(\.src\.rpm(?:\.info)?|\.youri|\.lock|\.done)\s+(\d+\.\d+)$!m"; $r = preg_match_all($re, $all_files, $matches, PREG_SET_ORDER); $pkgs = array(); foreach ($matches as $val) { if ($_GET['user'] && ($_GET['user'] != $val[7])) { continue; } $key = $val[6] . $val[7]; if (!is_array($pkgs[$key])) { $pkgs[$key] = array( 'status' => array(), 'path' => $val[2], 'version' => $val[3], 'media' => $val[4], 'section' => $val[5], 'user' => $val[7], 'host' => $val[8], 'job' => $val[9] ); } $status = $val[1]; $data = $val[10]; $pkgs[$key]['status'][$status] = 1; $ext = $val[11]; if ($ext == '.src.rpm.info') { preg_match("!^(?:@\d+:)?(.*)!", $data, $name); $pkgs[$key]['package'] = $name[1]; } else if ($ext == '.src') { $pkgs[$key]['status']['src'] = 1; } else if ($ext == '.youri') { $pkgs[$key]['status']['youri'] = 1; } else if ($ext == '.lock') { // parse build bot from $data $pkgs[$key]['status']['build'] = 1; } else if ($ext == '.done') { $pkgs[$key]['buildtime']['start'] = key2timestamp($val[6]); $pkgs[$key]['buildtime']['end'] = round($val[12]); $pkgs[$key]['buildtime']['diff'] = $pkgs[$key]['buildtime']['end'] - $pkgs[$key]['buildtime']['start']; } } // sort by key in reverse order to have more recent pkgs first krsort($pkgs); /** * @param array $pkg * * @return string */ function pkg_gettype($pkg) { if (array_key_exists("rejected", $pkg["status"])) return "rejected"; if (array_key_exists("youri", $pkg["status"])) { if (array_key_exists("src", $pkg["status"])) return "youri"; else return "uploaded"; } if (array_key_exists("failure", $pkg["status"])) return "failure"; if (array_key_exists("done", $pkg["status"])) return "partial"; if (array_key_exists("build", $pkg["status"])) return "building"; if (array_key_exists("todo", $pkg["status"])) return "todo"; return "unknown"; } /** * @param integer $num * * @return string */ function plural($num) { if ($num > 1) return "s"; } /** * Return timestamp from package key * @param string $key package submission key * * @return integer */ function key2timestamp($key) { global $tz; $date = DateTime::createFromFormat("YmdHis", $key+0, $tz); if ($date <= 0) return null; return $date->getTimestamp(); } function key2date($key, $diff = null) { /** * Return human-readable time difference: * - against $key (YmdHis expected format) * - using only $diff (takes precedence over $key if provided) * * @param string $key past date to diff against from now * @param integer $diff time difference in seconds * * @return string */ global $tz; if (is_null($diff) || $diff <= 0) { $t = key2timestamp($key); if (is_null($t)) return null; $diff = time() - $t; } if ($diff<60) return $diff . " second" . plural($diff); $diff = round($diff/60); if ($diff<60) return $diff . " minute" . plural($diff); $diff = round($diff/60); if ($diff<24) return $diff . " hour" . plural($diff); $diff = round($diff/24); return $diff . " day" . plural($diff); } ?> <?php echo strip_tags($title); ?>

« Back to full list'; # Temporary until initial mirror is ready echo sprintf( '

%d src.rpm rebuilt for Mageia out of %d (list of Mandriva packages still present).

', 'data/src.mga.txt', $nb_rpm_mga, 'data/src.txt', $nb_rpm, 'data/src.mdv.txt' ); ######################################### $s = ''; $tmpl = << %s %s %s %s %s/%s T; // count all packages statuses $stats = array( 'uploaded' => 0, 'failure' => 0, 'todo' => 0, 'building' => 0, 'partial' => 0, 'built' => 0, ); $total = count($pkgs); // count users' packages $users = array(); // feedback labels $badges = array( 'uploaded' => 'Congrats %s! \o/', 'failure' => 'Booooo! /o\\', 'todo' => '', 'building' => '', 'partial' => '', 'built' => '' ); if ($total > 0) { foreach ($pkgs as $key => $p) { $p['type'] = pkg_gettype($p); $stats[$p['type']] += 1; if (!array_key_exists($p['user'], $users)) $users[$p['user']] = 1; else $users[$p['user']] += 1; $s .= sprintf($tmpl, $p['type'], key2date($key) . ' ago', $p['user'], $p['user'], $p['package'], $p['version'], $p['media'], $p['section'] ); $typelink = ''; if ($p['type'] == 'failure') { $typelink = '/uploads/' . $p['type'] . '/' . $p['path']; } elseif ($p['type'] == 'rejected') { $typelink = '/uploads/' . $p['type'] . '/' . $p['path'] . '.youri'; } $s .= ''; $s .= ($typelink != '') ? sprintf('%s', $typelink, $p['type']) : $p['type']; $s .= ''; if ($p['type'] == 'uploaded') $s .= key2date(null, $p['buildtime']['diff']); $s .= ''; //$s .= '' . sprintf($badges[$p['type']], $p['user']) . ''; $s .= ''; } // Table echo '', '', '', $s, '
Packages submitted in the past ', $max_modified * 24, ' hours.
SubmittedUserPackageTargetMediaStatus
'; // Stats $s = '
'; $score = round($stats['uploaded']/$total * 100); $s .= sprintf('

Score: %d/100

', $score, $score); $s .= ''; foreach ($stats as $k => $v) { $s .= sprintf('', $k, $k, $v, round($v/$total*100)); } $s .= '
Stats.
StatusCount%
%s%d%d%%

'; $s .= ''; foreach ($users as $k => $v) $s .= sprintf('', $k, $k, $v); $s .= '
Packagers
UserPackages
%s%d
'; $s .= '
'; echo $s; } else { echo sprintf('

No package has been submitted in the past %d hours.

', $max_modified * 24); } ?>

Generated at .