/scripts/events.php (7e6fe2b376154299afa78ed27d04e5f479375ffe) (5547 bytes) (mode 100644) (type blob)
<?php
// This is called by cron, and is persistent.
// It takes care of any background job received.
// It will receive signals using a UNIX socket.
// TODO: This will obsolete q.php
error_reporting(E_ALL);
ini_set("track_errors", "On");
set_time_limit(0);
$_s = microtime(TRUE);
require_once("/etc/rocketgit/config.php");
$INC = dirname(__FILE__) . "/../inc";
require_once($INC . "/init.inc.php");
require_once($INC . "/log.inc.php");
require_once($INC . "/sql.inc.php");
require_once($INC . "/struct.inc.php");
require_once($INC . "/events.inc.php");
require_once($INC . "/repo.inc.php");
require_once($INC . "/prof.inc.php");
require_once($INC . "/mr.inc.php");
require_once($INC . "/keys.inc.php");
require_once($INC . "/user.inc.php");
require_once($INC . "/bug.inc.php");
require_once($INC . "/fixes.inc.php");
require_once($INC . "/plan.inc.php");
require_once($INC . "/apikeys.inc.php");
require_once($INC . "/admin.inc.php");
require_once($INC . "/ver.php");
function rg_destroy($key)
{
global $conn_table;
if (isset($conn_table['r'][$key]))
unset($conn_table['r'][$key]);
if (isset($conn_table['w'][$key]))
unset($conn_table['w'][$key]);
if (isset($conn_table['conns'][$key]['socket']))
if (is_resource($conn_table['conns'][$key]['socket']))
socket_close($conn_table['conns'][$key]['socket']);
unset($conn_table['conns'][$key]);
}
function rg_event_send($key, $buf)
{
global $conn_table;
$s = &$conn_table['conns'][$key];
$s['send'] .= $buf;
$conn_table['w'][$key] = $s['socket'];
}
rg_prof_start("MAIN");
rg_log_set_file($rg_log_dir . "/events.log");
rg_log_set_sid("000000"); // to spread the logs
// We must disable cache, else, we will not receive the updates because
// of the core cache. Do not forget that we are a long live process.
$rg_cache_core_enable = FALSE;
rg_log("Start (ver=$rocketgit_version)...");
rg_sql_app("rg-events");
$db = rg_sql_open($rg_sql);
if ($db === FALSE) {
rg_internal_error("Cannot connect to database!");
exit(1);
}
if (rg_struct_ok($db) === FALSE)
exit(0);
// Remove the socket, else we will get error
if (file_exists($rg_event_socket))
unlink($rg_event_socket);
// Prepare socket for signaling
$socket = @socket_create(AF_UNIX, SOCK_STREAM, 0);
if ($socket === FALSE) {
rg_internal_error("Cannot create events socket!");
exit(1);
}
$r = @socket_bind($socket, $rg_event_socket);
if ($r === FALSE) {
rg_internal_error("Cannot bind socket!");
exit(1);
}
$r = @socket_listen($socket, 128);
if ($r === FALSE) {
rg_internal_error("Cannot set queue length on socket!");
exit(1);
}
socket_set_nonblock($socket);
$r = chmod($rg_event_socket, 0600);
if ($r === FALSE) {
rg_internal_error("Cannot set rights on event socket!");
exit(1);
}
$conn_table = array('r' => array(), 'w' => array(), 'conns' => array());
$conn_table['r']['master'] = $socket;
$original_mtime = @filemtime(__FILE__);
$notify_list = array();
do {
rg_log_buffer_clear();
// Check our mtime so we can upgrade the software and this script
// will restart.
clearstatcache();
$mtime = @filemtime(__FILE__);
rg_log("mtime=$mtime, original_mtime=$original_mtime");
if ($mtime != $original_mtime) {
rg_log("File changed. Exiting...");
break;
}
$r = 0;
do {
// check machine load - if too big we will delay
$load = rg_load();
if ($load > 10) {
rg_log("Load too big! Skip queue processing.");
break;
}
$r = rg_event_process_queue($db, $notify_list);
if ($r === FALSE)
break;
} while ($r > 0);
if ($r === FALSE)
break;
// Wait for signal
rg_log("Waiting for signal...");
$r2 = $conn_table['r'];
$w2 = $conn_table['w'];
$e2 = array();
$r = @socket_select($r2, $w2, $e2, 10);
if ($r === FALSE)
rg_fatal('Cannot select: '
. socket_strerror(socket_last_error()));
if ($r == 0)
continue;
//rg_log_ml('conn_table: ' . print_r($conn_table, TRUE));
foreach ($r2 as $key => $sock) {
if (strcmp($key, "master") == 0) {
$client = @socket_accept($sock);
if ($client === FALSE) {
rg_log("Connection seems broken!");
continue;
}
socket_set_nonblock($client);
$key = intval($client);
$conn_table['conns'][$key] = array(
'socket' => $client,
'send' => '',
'recv' => '');
$conn_table['r'][$key] = $client;
continue;
}
$r = @socket_recv($sock, $buf, 1024, 0);
if ($r === FALSE) {
rg_log('Error in recv: '
. socket_strerror(socket_last_error()));
rg_destroy($key);
continue;
}
if ($r === 0) { // remote close the connection
rg_log("Remote closed the connection (received 0).");
rg_destroy($key);
continue;
}
$s = &$conn_table['conns'][$key];
$s['recv'] .= $buf;
if (!strstr($buf, "\n"))
continue;
rg_log('RECEIVED: ' . $s['recv']);
if (strncmp($s['recv'], 'NOTIFY ', 7) == 0) {
$ev_id = trim(substr($s['recv'], 7));
$notify_list[$ev_id][] = array(
'priv' => $key,
'func' => 'rg_event_send');
}
$s['recv'] = '';
}
foreach ($w2 as $key => $sock) {
if (!isset($conn_table['conns'][$key]))
continue;
$s = &$conn_table['conns'][$key];
$ret = @socket_send($s['socket'], $s['send'], strlen($s['send']), 0);
if ($ret === FALSE) {
rg_log("Cannot send: " . socket_strerror(socket_last_error()));
rg_destroy($key);
continue;
}
$s['send'] = substr($s['send'], $ret);
if (empty($s['send']))
unset($conn_table['w'][$key]);
}
//rg_log_ml("e2: " . print_r($e2, TRUE));
foreach ($e2 as $key => $sock)
rg_destroy($key);
} while (1);
@socket_close($socket);
rg_log("Exiting...");
rg_prof_end("MAIN");
rg_prof_log();
?>
Mode |
Type |
Size |
Ref |
File |
100644 |
blob |
9 |
f3c7a7c5da68804a1bdf391127ba34aed33c3cca |
.exclude |
100644 |
blob |
102 |
eaeb7d777062c60a55cdd4b5734902cdf6e1790c |
.gitignore |
100644 |
blob |
289 |
fabbff669e768c05d6cfab4d9aeb651bf623e174 |
AUTHORS |
100644 |
blob |
1132 |
dd65951315f3de6d52d52a82fca59889d1d95187 |
Certs.txt |
100644 |
blob |
549 |
41c3bdbba8ec2523fe24b84bdd46777fc13e8345 |
History.txt |
100644 |
blob |
34520 |
dba13ed2ddf783ee8118c6a581dbf75305f816a3 |
LICENSE |
100644 |
blob |
2951 |
226558b1fda039bba95b2b45fb7b06650b73b938 |
Makefile.in |
100644 |
blob |
4875 |
6495c3c9c6c961ed663393ac1b2fb4c5b6b01630 |
README |
100644 |
blob |
117285 |
84be9e79d1f0bae063a919d5ccda29899e5df9e5 |
TODO |
100644 |
blob |
1294 |
f22911eb777f0695fcf81ad686eac133eb11fcc4 |
TODO-plans |
100644 |
blob |
203 |
a2863c67c3da44126b61a15a6f09738c25e0fbe0 |
TODO.perf |
100644 |
blob |
994 |
76399724a83bdbf5a2b3b03d3d66e6de8598b9cd |
TODO.vm |
040000 |
tree |
- |
21928e906ad2907a55c2e81c2a8b0502b586b8a0 |
artwork |
100644 |
blob |
4207 |
693a5395a40ac2505dcfe58b9a97cb459b85484f |
compare.csv |
100755 |
blob |
30 |
92c4bc48245c00408cd7e1fd89bc1a03058f4ce4 |
configure |
040000 |
tree |
- |
1624fa67631f0dd10772e19016ffcd9af8e44773 |
debian |
040000 |
tree |
- |
3c08a24a998b6e80be5f4af4ac3599ab6acacba3 |
docker |
040000 |
tree |
- |
f67d3605efbd6422a8acdd953578991139266391 |
docs |
100755 |
blob |
16711 |
924262b2f8dbf3bbe02358e7f404175732e970d1 |
duilder |
100644 |
blob |
536 |
72848129097eebf24573546ff7ff39e6e5f965ea |
duilder.conf |
040000 |
tree |
- |
c503cf29ce2337a771fdfdbf4225b35d8e81ab98 |
hooks |
040000 |
tree |
- |
045287182877fccd219b11876f0b9e453ba4b5cc |
inc |
040000 |
tree |
- |
ab5cc695f620de9abecc84af49866a45612067c6 |
misc |
100644 |
blob |
3900 |
5815fe0a43dc0b8bd3201ed90428969a48d71c90 |
rocketgit.spec.in |
040000 |
tree |
- |
4af07d65f3fdd29ce2b4e31f5cb18d9adeea452b |
root |
040000 |
tree |
- |
b01e48f452a1989e5ae78db779ad41d9a745f9c6 |
samples |
040000 |
tree |
- |
dadefbcdcd82cedbce7279cf8003cbc1da8112e0 |
scripts |
040000 |
tree |
- |
00c52dce99b99f5f59800512ffd8e145d5ffe2c9 |
selinux |
100755 |
blob |
256 |
462ccd108c431f54e380cdac2329129875a318b5 |
spell_check.sh |
040000 |
tree |
- |
cb54e074b3ca35943edfcda9dd9cfcd281bcd9e7 |
techdocs |
040000 |
tree |
- |
8dc2eef38a20c5606d686dac4871778f1bb76f50 |
tests |
040000 |
tree |
- |
63f68e921ac8d6a62ea9c3d180e072c7c4725b7d |
tools |
Hints:
Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"
Clone this repository using HTTP(S):
git clone https://rocketgit.com/user/catalinux/rocketgit
Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@ssh.rocketgit.com/user/catalinux/rocketgit
Clone this repository using git:
git clone git://git.rocketgit.com/user/catalinux/rocketgit
You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a
merge request:
... clone the repository ...
... make some changes and some commits ...
git push origin main