File .gitignore added (mode: 100644) (index 0000000..cfce1ad) | |||
1 | *.log | ||
2 |
File TODO changed (mode: 100644) (index a195890..61e6efc) | |||
4 | 4 | [ ] Validate user names. | [ ] Validate user names. |
5 | 5 | [ ] XSS protection for every cell. | [ ] XSS protection for every cell. |
6 | 6 | [ ] You cannot admin rights of a repository if is not yours. | [ ] You cannot admin rights of a repository if is not yours. |
7 | [ ] In Admin section we must check if the user has access! | ||
7 | 8 | [ ] | [ ] |
8 | 9 | ||
9 | 10 | == Low priority == | == Low priority == |
11 | [ ] We should make a repo dirty ony if user pushed something with success. | ||
12 | [ ] <link rel="icon" type="image/png" id="favicon" href="%2F9hAAAACGFjVEwAAAASAAAAAJNtBPIAAAAaZmNUTAAAAAAAAAAQAAAAEAAAAAAAAAAALuAD6AABhIDeugAAALhJREFUOI2Nk8sNxCAMRDlGohauXFOMpfTiAlxICqAELltHLqlgctg1InzMRhpFAc%2BLGWTnmoeZYamt78zXdZmaQtQMADlnU0OIAlbmJUBEcO4bRKQY2rUXIPmAGnDuG%2FBx3%2FfvOPVaDUg%2BoAPUf1PArIMCSD5glMEsUGaG%2BkyAFWIBaCsKuA%2BHGCNijLgP133XgOEtaPFMy2vUolEGJoCIzBmoRUR9%2B7rxj16DZaW%2FmgtmxnJ8V3oAnApQwNS5zpcAAAAaZmNUTAAAAAEAAAAQAAAAEAAAAAAAAAAAAB4D6AIB52fclgAAACpmZEFUAAAAAjiNY2AYBVhBc3Pzf2LEcGreqcbwH1kDNjHauWAUjAJyAADymxf9WF%2Bu8QAAABpmY1RMAAAAAwAAABAAAAAQAAAAAAAAAAAAHgPoAgEK8Q9%2FAAAAFmZkQVQAAAAEOI1jYBgFo2AUjAIIAAAEEAAB0xIn4wAAABpmY1RMAAAABQAAABAAAAAQAAAAAAAAAAAAHgPoAgHnO30FAAAAQGZkQVQAAAAGOI1jYBieYKcaw39ixHCC%2F6cwFWMTw2rz%2F1MM%2F6Vu%2Ff%2F%2F%2FxTD%2F51qEIwuRjsXILuEGLFRMApgAADhNCsVfozYcAAAABpmY1RMAAAABwAAABAAAAAQAAAAAAAAAAAAHgPoAgEKra7sAAAAFmZkQVQAAAAIOI1jYBgFo2AUjAIIAAAEEAABM9s3hAAAABpmY1RMAAAACQAAABAAAAAQAAAAAAAAAAAAHgPoAgHn3p%2BwAAAAKmZkQVQAAAAKOI1jYBgFWEFzc%2FN%2FYsRwat6pxvAfWQM2Mdq5YBSMAnIAAPKbF%2F1BhPl6AAAAGmZjVEwAAAALAAAAEAAAABAAAAAAAAAAAAAeA%2BgCAQpITFkAAAAWZmRBVAAAAAw4jWNrgAWjYBSMArgAAAQQAAHaszpmAAAAGmZjVEwAAAANAAAAEAAAABAAAAAAAAAAAAAeA%2BgCAeeCPiMAAABAZmRBVAAAAA44jWNrgJ5gpxrDf2LEcIL%2FpzAVYxPDavP%2FUwz%2FpW79%2F%2F%2F%2FFMP%2FnWoQjC5GOxcgu4QYsVEwCmAAAOE0KxUmBL0KAAAAGmZjVEwAAAAPAAAAEAAAABAAAAAAAAAAAAAeA%2BgCAQoU7coAAAAWZmRBVAAAABA4jWNrgAWjYBSMArgAAAQQAAEpOBELAAAAGmZjVEwAAAARAAAAEAAAABAAAAAAAAAAAAAeA%2BgCAeYVWtoAAAAqZmRBVAAAABI4jWNrgAVYQXNz839ixHBq3qnG8B9ZAzYx2rlgFIwCcgAA8psX%2FWvpAecAAAAaZmNUTAAAABMAAAAQAAAAEAAAAAAAAAAAAB4D6AIBC4OJMwAAABZmZEFUAAAAFDiNY2AYBaNgFIwCCAAABBAAAcBQHOkAAAAaZmNUTAAAABUAAAAQAAAAEAAAAAAAAAAAAB4D6AIB5kn7SQAAAEBmZEFUAAAAFjiNY2AYnmCnGsN%2FYsRwgv%2BnMBVjE8Nq8%2F9TDP%2Blbv3%2F%2F%2F8Uw%2F%2BdahCMLkY7FyC7hBixUTAKYAAA4TQrFc%2BcEoQAAAAaZmNUTAAAABcAAAAQAAAAEAAAAAAAAAAAAB4D6AIBC98ooAAAABZmZEFUAAAAGDiNY2AYBaNgFIwCCAAABBAAASCZDI4AAAAaZmNUTAAAABkAAAAQAAAAEAAAAAAAAAAAAB4D6AIB5qwZ%2FAAAACpmZEFUAAAAGjiNY2AYBVhBc3Pzf2LEcGreqcbwH1kDNjHauWAUjAJyAADymxf9cjJWbAAAABpmY1RMAAAAGwAAABAAAAAQAAAAAAAAAAAAHgPoAgELOsoVAAAAFmZkQVQAAAAcOI1jYBgFo2AUjAIIAAAEEAAByfEBbAAAABpmY1RMAAAAHQAAABAAAAAQAAAAAAAAAAAAHgPoAgHm8LhvAAAAQGZkQVQAAAAeOI1jYBieYKcaw39ixHCC%2F6cwFWMTw2rz%2F1MM%2F6Vu%2Ff%2F%2F%2FxTD%2F51qEIwuRjsXILuEGLFRMApgAADhNCsVlxR3%2FgAAABpmY1RMAAAAHwAAABAAAAAQAAAAAAAAAAAAHgPoAgELZmuGAAAAFmZkQVQAAAAgOI1jYBgFo2AUjAIIAAAEEAABHP5cFQAAABpmY1RMAAAAIQAAABAAAAAQAAAAAAAAAAAAHgPoAgHlgtAOAAAAKmZkQVQAAAAiOI1jYBgFWEFzc%2FN%2FYsRwat6pxvAfWQM2Mdq5YBSMAnIAAPKbF%2F0%2FMvDdAAAAAElFTkSuQmCC"/> | ||
13 | [ ] Add key form may be joined with list keys command! | ||
10 | 14 | [ ] Allow to recover a deleted repository. | [ ] Allow to recover a deleted repository. |
11 | 15 | [ ] Deny access in all functions to deleted repositories. | [ ] Deny access in all functions to deleted repositories. |
12 | 16 | [ ] Count the numbers of clones/pushes/pulls. | [ ] Count the numbers of clones/pushes/pulls. |
34 | 38 | [ ] Timeout for connections (ssh/git-daemon/etc.)! | [ ] Timeout for connections (ssh/git-daemon/etc.)! |
35 | 39 | [ ] Check if we have to respect 4HEXA also on SSH. I think not. | [ ] Check if we have to respect 4HEXA also on SSH. I think not. |
36 | 40 | [ ] Limit number of simultaneously connection per repo and per user. Maybe also the time! | [ ] Limit number of simultaneously connection per repo and per user. Maybe also the time! |
37 | [ ] Add /var/run/gg to spec file, to be created at instalation. | ||
41 | [ ] Add /var/run/rg to spec file, to be created at instalation. | ||
38 | 42 | [ ] We should add a dependency on php-process? | [ ] We should add a dependency on php-process? |
39 | [ ] Make everywhere present a "Make a suggestion" area. | ||
43 | [ ] Make everywhere present a "Make a surgestion" area. | ||
44 | [ ] On rocketgit website, add "Feedback" area. | ||
45 | [ ] Do not forget to pack /etc/httpd/conf.d/rg.conf. | ||
46 | [ ] Allow multipl virtual hosts, with different configurations. | ||
40 | 47 | [ ] | [ ] |
File admin/sql.php changed (mode: 100644) (index 31f33cb..96db998) | |||
1 | 1 | <?php | <?php |
2 | 2 | error_reporting(E_ALL); | error_reporting(E_ALL); |
3 | 3 | ||
4 | require_once("/etc/gg/config.php"); | ||
4 | require_once("/etc/rg/config.php"); | ||
5 | 5 | ||
6 | 6 | $INC = dirname(__FILE__) . "/../inc"; | $INC = dirname(__FILE__) . "/../inc"; |
7 | require_once($INC . "/xlog.inc.php"); | ||
7 | require_once($INC . "/log.inc.php"); | ||
8 | 8 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
9 | 9 | require_once($INC . "/db/struct.inc.php"); | require_once($INC . "/db/struct.inc.php"); |
10 | 10 | require_once($INC . "/repo.inc.php"); | require_once($INC . "/repo.inc.php"); |
11 | 11 | ||
12 | $db = sql_open($gg_db); | ||
12 | $db = rg_sql_open($rg_db); | ||
13 | 13 | if ($db === FALSE) | if ($db === FALSE) |
14 | 14 | fatal("Internal error (db)!"); | fatal("Internal error (db)!"); |
15 | 15 | ||
16 | gg_db_struct_run($db, TRUE); | ||
16 | rg_db_struct_run($db, TRUE); | ||
17 | 17 | ||
18 | 18 | echo "Done!\n"; | echo "Done!\n"; |
19 | 19 | ?> | ?> |
File artwork/rocketgit v1.svg changed (mode: 100644) (index c25dfd6..f8c426a) | |||
57 | 57 | id="path3786" | id="path3786" |
58 | 58 | inkscape:connector-curvature="0" | inkscape:connector-curvature="0" |
59 | 59 | sodipodi:nodetypes="cccccccccccccccc" | sodipodi:nodetypes="cccccccccccccccc" |
60 | inkscape:export-filename="/home/catab/Desktop/gg/text2995.png" | ||
60 | inkscape:export-filename="/home/catab/Desktop/rg/text2995.png" | ||
61 | 61 | inkscape:export-xdpi="90" | inkscape:export-xdpi="90" |
62 | 62 | inkscape:export-ydpi="90" /> | inkscape:export-ydpi="90" /> |
63 | 63 | <path | <path |
66 | 66 | id="path2993" | id="path2993" |
67 | 67 | inkscape:connector-curvature="0" | inkscape:connector-curvature="0" |
68 | 68 | sodipodi:nodetypes="ccccccccc" | sodipodi:nodetypes="ccccccccc" |
69 | inkscape:export-filename="/home/catab/Desktop/gg/text2995.png" | ||
69 | inkscape:export-filename="/home/catab/Desktop/rg/text2995.png" | ||
70 | 70 | inkscape:export-xdpi="90" | inkscape:export-xdpi="90" |
71 | 71 | inkscape:export-ydpi="90" /> | inkscape:export-ydpi="90" /> |
72 | 72 | <text | <text |
File inc/admin/admin.php changed (mode: 100644) (index 9e60be1..d4b0c70) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/admin"); | ||
2 | rg_log("/inc/admin"); | ||
3 | 3 | ||
4 | if ($gg_ui['is_admin'] != 1) { | ||
5 | $_admin = "You do not have access here!"; | ||
4 | $_admin = ""; | ||
5 | |||
6 | if ($rg_ui['is_admin'] != 1) { | ||
7 | $_admin .= "You do not have access here!"; | ||
6 | 8 | return; | return; |
7 | 9 | } | } |
8 | 10 | ||
9 | $subop = @intval($_REQUEST['subop']); | ||
10 | 11 | ||
11 | 12 | // menu | // menu |
12 | $_admin_url = $_SERVER['PHP_SELF'] . "?op=$op"; | ||
13 | $_admin_url = rg_re_url($op); | ||
13 | 14 | $_admin_menu = ""; | $_admin_menu = ""; |
14 | 15 | $_admin_menu .= "[<a href=\"$_admin_url&subop=1\">Users</a>]"; | $_admin_menu .= "[<a href=\"$_admin_url&subop=1\">Users</a>]"; |
15 | 16 | $_admin_menu .= " [<a href=\"$_admin_url&subop=2\">Repos</a>]"; | $_admin_menu .= " [<a href=\"$_admin_url&subop=2\">Repos</a>]"; |
16 | 17 | $_admin_menu .= "<br />\n"; | $_admin_menu .= "<br />\n"; |
17 | 18 | ||
19 | |||
18 | 20 | $_admin_body = ""; | $_admin_body = ""; |
19 | 21 | ||
20 | 22 | switch ($subop) { | switch ($subop) { |
... | ... | case 2: // repos | |
29 | 31 | break; | break; |
30 | 32 | } | } |
31 | 33 | ||
32 | $_admin = $_admin_menu . $_admin_body; | ||
34 | $_admin .= $_admin_menu . $_admin_body; | ||
33 | 35 | ?> | ?> |
File inc/admin/repos/repos.php changed (mode: 100644) (index 23d21f7..980e841) | |||
1 | 1 | <?php | <?php |
2 | xlog("/admin/repos"); | ||
2 | rg_log("/admin/repos"); | ||
3 | 3 | ||
4 | $subsubop = @intval($_REQUEST['subsubop']); | ||
5 | 4 | ||
6 | 5 | // menu | // menu |
7 | 6 | $_admin_repos_url = $_admin_url . "&subop=$subop"; | $_admin_repos_url = $_admin_url . "&subop=$subop"; |
... | ... | $_admin_repos_menu .= "[<a href=\"$_admin_repos_url&subsubop=1\">List</a>]"; | |
11 | 10 | $_admin_repos_menu .= "<br />\n"; | $_admin_repos_menu .= "<br />\n"; |
12 | 11 | $_admin_repos_menu .= "<br />\n"; | $_admin_repos_menu .= "<br />\n"; |
13 | 12 | ||
13 | |||
14 | 14 | $_admin_repos_body = ""; | $_admin_repos_body = ""; |
15 | 15 | ||
16 | 16 | switch ($subsubop) { | switch ($subsubop) { |
17 | 17 | case 1: // list | case 1: // list |
18 | 18 | $_uid = 0; | $_uid = 0; |
19 | $_admin_repos_body .= repo_list($db, $_admin_repos_url . "&subsubop=$subsubop", $_uid); | ||
19 | $_admin_repos_body .= rg_repo_list($db, $_admin_repos_url . "&subsubop=$subsubop", $_uid); | ||
20 | 20 | break; | break; |
21 | 21 | } | } |
22 | 22 |
File inc/admin/users/add.form.php changed (mode: 100644) (index e42bdc2..d74db8f) | |||
1 | 1 | <?php | <?php |
2 | 2 | ||
3 | 3 | $_form = ' | $_form = ' |
4 | <form type="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
4 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
5 | 5 | <input type="hidden" name="op" value="' . $op . '"> | <input type="hidden" name="op" value="' . $op . '"> |
6 | 6 | <input type="hidden" name="subop" value="' . $subop . '"> | <input type="hidden" name="subop" value="' . $subop . '"> |
7 | 7 | <input type="hidden" name="subsubop" value="' . $subsubop . '"> | <input type="hidden" name="subsubop" value="' . $subsubop . '"> |
File inc/admin/users/add.php changed (mode: 100644) (index 38d55a2..1bad4b9) | |||
1 | 1 | <?php | <?php |
2 | xlog("/admin/users/add"); | ||
2 | rg_log("/admin/users/add"); | ||
3 | 3 | ||
4 | 4 | $_user_add = ""; | $_user_add = ""; |
5 | 5 | ||
6 | 6 | if ($doit == 1) { | if ($doit == 1) { |
7 | $xuser = @$_REQUEST['xuser']; | ||
8 | $email = @$_REQUEST['email']; | ||
9 | $xpass = @$_REQUEST['xpass']; | ||
10 | $is_admin = @intval($_REQUEST['is_admin']); | ||
7 | $xuser = rg_var_str("xuser"); | ||
8 | $email = rg_var_str("email"); | ||
9 | $xpass = rg_var_str("xpass"); | ||
10 | $is_admin = rg_var_uint("is_admin"); | ||
11 | 11 | ||
12 | $_ui = user_info($db, 0, $xuser, ""); | ||
12 | $_ui = rg_user_info($db, 0, $xuser, ""); | ||
13 | 13 | if ($_ui['ok'] == 0) { | if ($_ui['ok'] == 0) { |
14 | 14 | $_user_add .= "Error: Internal error!"; | $_user_add .= "Error: Internal error!"; |
15 | 15 | } else if ($_ui['exists'] == 0) { | } else if ($_ui['exists'] == 0) { |
16 | if (user_add($db, $xuser, $xpass, $email, $is_admin)) { | ||
16 | if (rg_user_add($db, $xuser, $xpass, $email, $is_admin)) { | ||
17 | 17 | $_user_add .= "OK!<br />"; | $_user_add .= "OK!<br />"; |
18 | 18 | } | } |
19 | 19 | } else { | } else { |
20 | xlog("User already in use!"); | ||
20 | rg_log("User already in use!"); | ||
21 | 21 | $_user_add .= "Error: User already taken!"; | $_user_add .= "Error: User already taken!"; |
22 | 22 | } | } |
23 | 23 | } else { | } else { |
File inc/admin/users/users.php changed (mode: 100644) (index c45c3ba..23e12c3) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/admin/users"); | ||
2 | rg_log("/inc/admin/users"); | ||
3 | 3 | ||
4 | $subsubop = @intval($_REQUEST['subsubop']); | ||
5 | 4 | ||
6 | 5 | // menu | // menu |
7 | 6 | $_admin_users_url = $_admin_url . "&subop=$subop"; | $_admin_users_url = $_admin_url . "&subop=$subop"; |
... | ... | $_admin_users_menu .= " [<a href=\"$_admin_users_url&subsubop=2\">Add</ | |
11 | 10 | $_admin_users_menu .= "<br />\n"; | $_admin_users_menu .= "<br />\n"; |
12 | 11 | $_admin_users_menu .= "<br />\n"; | $_admin_users_menu .= "<br />\n"; |
13 | 12 | ||
13 | |||
14 | 14 | $_admin_users_body = ""; | $_admin_users_body = ""; |
15 | 15 | ||
16 | 16 | switch ($subsubop) { | switch ($subsubop) { |
17 | 17 | case 1: // list | case 1: // list |
18 | $_admin_users_body .= user_list($db, $_admin_users_url . "&subsubop=$subsubop"); | ||
18 | $_admin_users_body .= rg_user_list($db, $_admin_users_url . "&subsubop=$subsubop"); | ||
19 | 19 | break; | break; |
20 | 20 | ||
21 | 21 | case 2: //add | case 2: //add |
File inc/bye/bye.php added (mode: 100644) (index 0000000..a028bc8) | |||
1 | <?php | ||
2 | rg_log("/inc/bye/bye.php"); | ||
3 | |||
4 | $_bye = ""; | ||
5 | |||
6 | $_bye .= "Bye!"; | ||
7 | |||
8 | ?> |
File inc/db.inc.php changed (mode: 100644) (index f3d5de1..510a17a) | |||
1 | 1 | <?php | <?php |
2 | require_once($INC . "/xlog.inc.php"); | ||
2 | require_once($INC . "/log.inc.php"); | ||
3 | 3 | ||
4 | $sql_debug = 0; | ||
4 | $rg_sql_debug = 0; | ||
5 | 5 | ||
6 | $sql_error = ""; | ||
6 | $rg_sql_error = ""; | ||
7 | 7 | ||
8 | 8 | /* | /* |
9 | 9 | * Set error string | * Set error string |
10 | 10 | */ | */ |
11 | function sql_set_error($str) | ||
11 | function rg_sql_set_error($str) | ||
12 | 12 | { | { |
13 | global $sql_error; | ||
13 | global $rg_sql_error; | ||
14 | 14 | ||
15 | xlog("\tError: $str"); | ||
16 | $sql_error = $str; | ||
15 | rg_log("\tError: $str"); | ||
16 | $rg_sql_error = $str; | ||
17 | 17 | } | } |
18 | 18 | ||
19 | function sql_error() | ||
19 | function rg_sql_error() | ||
20 | 20 | { | { |
21 | global $sql_error; | ||
21 | global $rg_sql_error; | ||
22 | 22 | ||
23 | return $sql_error; | ||
23 | return $rg_sql_error; | ||
24 | 24 | } | } |
25 | 25 | ||
26 | 26 | /* | /* |
27 | 27 | * Connect to database | * Connect to database |
28 | 28 | */ | */ |
29 | function sql_open($str) | ||
29 | function rg_sql_open($str) | ||
30 | 30 | { | { |
31 | global $sql_debug; | ||
31 | global $rg_sql_debug; | ||
32 | 32 | ||
33 | if ($sql_debug > 0) | ||
34 | xlog("DB: opening [$str]..."); | ||
33 | if ($rg_sql_debug > 0) | ||
34 | rg_log("DB: opening [$str]..."); | ||
35 | 35 | ||
36 | 36 | if (strncmp($str, "sqlite:", 7) != 0) { | if (strncmp($str, "sqlite:", 7) != 0) { |
37 | 37 | sql_set_error("$str connect string not supported"); | sql_set_error("$str connect string not supported"); |
... | ... | function sql_open($str) | |
42 | 42 | ||
43 | 43 | $db = new SQLite3($file); | $db = new SQLite3($file); |
44 | 44 | if ($db === FALSE) { | if ($db === FALSE) { |
45 | sql_set_error("Cannot connect to database $file: " . $db->lastErrorMsg()); | ||
45 | rg_sql_set_error("Cannot connect to database $file: " . $db->lastErrorMsg()); | ||
46 | 46 | return FALSE; | return FALSE; |
47 | 47 | } | } |
48 | 48 | ||
... | ... | function sql_open($str) | |
52 | 52 | /* | /* |
53 | 53 | * Escaping | * Escaping |
54 | 54 | */ | */ |
55 | function sql_escape($db, $str) | ||
55 | function rg_sql_escape($db, $str) | ||
56 | 56 | { | { |
57 | 57 | return $db->escapeString($str); | return $db->escapeString($str); |
58 | 58 | } | } |
... | ... | function sql_escape($db, $str) | |
60 | 60 | /* | /* |
61 | 61 | * Do a query | * Do a query |
62 | 62 | */ | */ |
63 | function sql_query($db, $sql) | ||
63 | function rg_sql_query($db, $sql) | ||
64 | 64 | { | { |
65 | global $sql_debug; | ||
65 | global $rg_sql_debug; | ||
66 | 66 | ||
67 | if ($sql_debug > 0) | ||
68 | xlog("DB: running [$sql]..."); | ||
67 | if ($rg_sql_debug > 0) | ||
68 | rg_log("DB: running [$sql]..."); | ||
69 | 69 | ||
70 | 70 | $res = $db->query($sql); | $res = $db->query($sql); |
71 | 71 | if ($res === FALSE) { | if ($res === FALSE) { |
72 | sql_set_error("$sql: " . $db->lastErrorMsg()); | ||
72 | rg_sql_set_error("$sql: " . $db->lastErrorMsg()); | ||
73 | 73 | return FALSE; | return FALSE; |
74 | 74 | } | } |
75 | 75 | ||
... | ... | function sql_query($db, $sql) | |
79 | 79 | /* | /* |
80 | 80 | * Close database | * Close database |
81 | 81 | */ | */ |
82 | function sql_close($db) | ||
82 | function rg_sql_close($db) | ||
83 | 83 | { | { |
84 | 84 | $db->close(); | $db->close(); |
85 | 85 | } | } |
... | ... | function sql_close($db) | |
87 | 87 | /* | /* |
88 | 88 | * Free results | * Free results |
89 | 89 | */ | */ |
90 | function sql_free_result($res) | ||
90 | function rg_sql_free_result($res) | ||
91 | 91 | { | { |
92 | 92 | $res->finalize(); | $res->finalize(); |
93 | 93 | } | } |
... | ... | function sql_free_result($res) | |
95 | 95 | /* | /* |
96 | 96 | * Returns a row as an associated array | * Returns a row as an associated array |
97 | 97 | */ | */ |
98 | function sql_fetch_array($res) | ||
98 | function rg_sql_fetch_array($res) | ||
99 | 99 | { | { |
100 | 100 | return $res->fetchArray(SQLITE3_ASSOC); | return $res->fetchArray(SQLITE3_ASSOC); |
101 | 101 | } | } |
102 | 102 | ||
103 | function sql_last_id($db) | ||
103 | function rg_sql_last_id($db) | ||
104 | 104 | { | { |
105 | 105 | return $db->lastInsertRowID(); | return $db->lastInsertRowID(); |
106 | 106 | } | } |
File inc/db/struct.inc.php changed (mode: 100644) (index e113643..8fbc9fd) | |||
1 | 1 | <?php | <?php |
2 | 2 | error_reporting(E_ALL); | error_reporting(E_ALL); |
3 | 3 | ||
4 | $gg_db_struct = array(); | ||
4 | $rg_db_struct = array(); | ||
5 | 5 | ||
6 | $gg_db_struct[0] = array( | ||
6 | $rg_db_struct[0] = array( | ||
7 | 7 | "repos" => "CREATE TABLE repos" | "repos" => "CREATE TABLE repos" |
8 | 8 | . " (repo_id INTEGER PRIMARY KEY" | . " (repo_id INTEGER PRIMARY KEY" |
9 | 9 | . ", name TEXT" | . ", name TEXT" |
... | ... | $gg_db_struct[0] = array( | |
28 | 28 | "keys" => "CREATE TABLE keys" | "keys" => "CREATE TABLE keys" |
29 | 29 | . " (key_id INTEGER PRIMARY KEY" | . " (key_id INTEGER PRIMARY KEY" |
30 | 30 | . ", itime INTEGER" | . ", itime INTEGER" |
31 | . ", uid INTEGER, key TEXT)", | ||
31 | . ", uid INTEGER" | ||
32 | . ", key TEXT)", | ||
32 | 33 | "users" => "CREATE TABLE users" | "users" => "CREATE TABLE users" |
33 | 34 | . " (uid INTEGER PRIMARY KEY" | . " (uid INTEGER PRIMARY KEY" |
34 | 35 | . ", user TEXT" | . ", user TEXT" |
... | ... | $gg_db_struct[0] = array( | |
58 | 59 | /* | /* |
59 | 60 | * Generate structure | * Generate structure |
60 | 61 | */ | */ |
61 | function gg_db_struct_run($db, $ignore_errors) | ||
62 | function rg_db_struct_run($db, $ignore_errors) | ||
62 | 63 | { | { |
63 | global $gg_db_struct; | ||
64 | global $rg_db_struct; | ||
64 | 65 | ||
65 | foreach ($gg_db_struct as $index => $sqls) { | ||
66 | foreach ($rg_db_struct as $index => $sqls) { | ||
66 | 67 | foreach ($sqls as $table => $sql) { | foreach ($sqls as $table => $sql) { |
67 | echo "[$table] Running [$sql]...\n"; | ||
68 | $res = sql_query($db, $sql); | ||
68 | //echo "[$table] Running [$sql]...\n"; | ||
69 | $res = rg_sql_query($db, $sql); | ||
69 | 70 | if ($res === FALSE) { | if ($res === FALSE) { |
70 | echo "WARN: Cannot create '$table' table!\n"; | ||
71 | echo "WARN: Cannot create '$table' table ($sql)!\n"; | ||
71 | 72 | if (!$ignore_errors) | if (!$ignore_errors) |
72 | 73 | return FALSE; | return FALSE; |
73 | 74 | } | } |
File inc/dispatch/dispatch.php added (mode: 100644) (index 0000000..f21d460) | |||
1 | <?php | ||
2 | rg_log("/dispatch/dispatch.php"); | ||
3 | |||
4 | $new_op = ""; | ||
5 | |||
6 | switch ($op) { | ||
7 | case 'home': | ||
8 | include($INC . "/home/home.php"); | ||
9 | $body .= $_home; | ||
10 | break; | ||
11 | |||
12 | case 'login': | ||
13 | include($INC . "/login/login.php"); | ||
14 | $body .= $_login; | ||
15 | break; | ||
16 | |||
17 | case 'logout': | ||
18 | if (rg_sess_destroy($db, $sid, $rg_ui)) { | ||
19 | $new_op = "bye"; | ||
20 | } else { | ||
21 | $body .= "Not OK!"; | ||
22 | } | ||
23 | break; | ||
24 | |||
25 | case 'repo': | ||
26 | include($INC . "/repo/repo.php"); | ||
27 | $body .= $_repo; | ||
28 | break; | ||
29 | |||
30 | case 'repopage': | ||
31 | include($INC . "/repo/repo_page.php"); | ||
32 | $body .= $_repo; | ||
33 | break; | ||
34 | |||
35 | case 'admin': | ||
36 | include($INC . "/admin/admin.php"); | ||
37 | $body .= $_admin; | ||
38 | break; | ||
39 | |||
40 | case 'keys': | ||
41 | include($INC . "/keys/keys.php"); | ||
42 | $body .= $_keys; | ||
43 | break; | ||
44 | |||
45 | case 'forgotlink': // forgot pass link | ||
46 | include($INC . "/user/forgot.php"); | ||
47 | $body .= $_forgot; | ||
48 | break; | ||
49 | |||
50 | case 'forgotmail': // forgot pass - send mail | ||
51 | include($INC . "/user/forgot_mail.php"); | ||
52 | $body .= $_forgot; | ||
53 | break; | ||
54 | |||
55 | case 'bye': | ||
56 | include($INC . "/bye/bye.php"); | ||
57 | $body .= $_bye; | ||
58 | break; | ||
59 | } | ||
60 | |||
61 | $op = $new_op; | ||
62 | rg_log("new op=$op."); | ||
63 | ?> |
File inc/git.inc.php changed (mode: 100644) (index 71b60d9..aa6e299) | |||
1 | 1 | <?php | <?php |
2 | 2 | require_once($INC . "/util.inc.php"); | require_once($INC . "/util.inc.php"); |
3 | require_once($INC . "/xlog.inc.php"); | ||
3 | require_once($INC . "/log.inc.php"); | ||
4 | 4 | ||
5 | function gg_git_set_error($str) | ||
5 | $rg_git_error = ""; | ||
6 | |||
7 | function rg_git_set_error($str) | ||
6 | 8 | { | { |
7 | global $_gg_git_error; | ||
9 | global $rg_git_error; | ||
8 | 10 | ||
9 | xlog("\tError: $str"); | ||
10 | $_gg_git_error = $str; | ||
11 | rg_log("\tError: $str"); | ||
12 | $rg_git_error = $str; | ||
11 | 13 | } | } |
12 | 14 | ||
13 | function gg_git_error() | ||
15 | function rg_git_error() | ||
14 | 16 | { | { |
15 | global $_gg_git_error; | ||
16 | return $_gg_git_error; | ||
17 | global $rg_git_error; | ||
18 | return $rg_git_error; | ||
17 | 19 | } | } |
18 | 20 | ||
19 | function git_install_hooks($dst) | ||
21 | function rg_git_install_hooks($dst) | ||
20 | 22 | { | { |
21 | xlog("git_install_hooks: dst=$dst..."); | ||
23 | rg_log("git_install_hooks: dst=$dst..."); | ||
22 | 24 | ||
23 | xlog("\tNot yet implemented!"); | ||
25 | rg_log("\tNot yet implemented!"); | ||
24 | 26 | return TRUE; | return TRUE; |
25 | 27 | } | } |
26 | 28 | ||
27 | function gg_git_init($dst) | ||
29 | function rg_git_init($dst) | ||
28 | 30 | { | { |
29 | xlog("git_init: dst=$dst..."); | ||
31 | rg_log("git_init: dst=$dst..."); | ||
30 | 32 | ||
31 | 33 | $dir = dirname($dst); | $dir = dirname($dst); |
32 | 34 | if (!file_exists($dir)) { | if (!file_exists($dir)) { |
33 | 35 | $r = @mkdir($dir, 0755, TRUE); | $r = @mkdir($dir, 0755, TRUE); |
34 | 36 | if ($r === FALSE) { | if ($r === FALSE) { |
35 | xlog("\tCannot create dir [$dir] ($php_errormsg)!"); | ||
37 | rg_log("\tCannot create dir [$dir] ($php_errormsg)!"); | ||
36 | 38 | return FALSE; | return FALSE; |
37 | 39 | } | } |
38 | 40 | } | } |
39 | 41 | ||
40 | if (file_exists($dst . "/gg")) { | ||
41 | xlog("\tGit repo was created OK. Skip cloning."); | ||
42 | if (file_exists($dst . "/rg")) { | ||
43 | rg_log("\tGit repo was created OK. Skip cloning."); | ||
42 | 44 | } else { | } else { |
43 | 45 | $cmd = "git init --bare '" . escapeshellcmd($dst) . "'"; | $cmd = "git init --bare '" . escapeshellcmd($dst) . "'"; |
44 | xlog("\texec $cmd..."); | ||
46 | rg_log("\texec $cmd..."); | ||
45 | 47 | $a = exec($cmd, $output, $err); | $a = exec($cmd, $output, $err); |
46 | 48 | if ($err != 0) { | if ($err != 0) { |
47 | xlog("\tError $err (" . implode("|", $output) . " ($a)!"); | ||
49 | rg_log("\tError $err (" . implode("|", $output) . " ($a)!"); | ||
48 | 50 | return FALSE; | return FALSE; |
49 | 51 | } | } |
50 | 52 | ||
51 | if (!@mkdir($dst . "/gg")) { | ||
52 | xlog("\tCannot create gg dir ($php_errormsg)!"); | ||
53 | if (!@mkdir($dst . "/rg")) { | ||
54 | rg_log("\tCannot create rg dir ($php_errormsg)!"); | ||
53 | 55 | return FALSE; | return FALSE; |
54 | 56 | } | } |
55 | 57 | } | } |
56 | 58 | ||
57 | if (git_install_hooks($dst) === FALSE) | ||
59 | if (rg_git_install_hooks($dst) === FALSE) | ||
58 | 60 | return FALSE; | return FALSE; |
59 | 61 | ||
60 | 62 | return TRUE; | return TRUE; |
61 | 63 | } | } |
62 | 64 | ||
63 | function gg_git_clone($src, $dst) | ||
65 | function rg_git_clone($src, $dst) | ||
64 | 66 | { | { |
65 | xlog("git_clone: src=$src, dst=$dst..."); | ||
67 | rg_log("git_clone: src=$src, dst=$dst..."); | ||
66 | 68 | ||
67 | 69 | $dir = dirname($dst); | $dir = dirname($dst); |
68 | 70 | if (!file_exists($dir)) { | if (!file_exists($dir)) { |
69 | 71 | $r = @mkdir($dir, 0755, TRUE); | $r = @mkdir($dir, 0755, TRUE); |
70 | 72 | if ($r === FALSE) { | if ($r === FALSE) { |
71 | xlog("\tCannot create dir [$dir] ($php_errormsg)!"); | ||
73 | rg_log("\tCannot create dir [$dir] ($php_errormsg)!"); | ||
72 | 74 | return FALSE; | return FALSE; |
73 | 75 | } | } |
74 | 76 | } | } |
75 | 77 | ||
76 | if (file_exists($dst . "/gg")) { | ||
77 | xlog("\tGit repo was created OK. Skip cloning."); | ||
78 | if (file_exists($dst . "/rg")) { | ||
79 | rg_log("\tGit repo was created OK. Skip cloning."); | ||
78 | 80 | } else { | } else { |
79 | 81 | $cmd = "git clone --bare '" . escapeshellcmd($src) . "'" | $cmd = "git clone --bare '" . escapeshellcmd($src) . "'" |
80 | 82 | . " '" . escapeshellcmd($dst) . "'"; | . " '" . escapeshellcmd($dst) . "'"; |
81 | xlog("\texec $cmd..."); | ||
83 | rg_log("\texec $cmd..."); | ||
82 | 84 | $a = exec($cmd); | $a = exec($cmd); |
83 | 85 | if ($err != 0) { | if ($err != 0) { |
84 | xlog("\tError $err (" . implode("|", $output) . " ($a)!"); | ||
86 | rg_log("\tError $err (" . implode("|", $output) . " ($a)!"); | ||
85 | 87 | return FALSE; | return FALSE; |
86 | 88 | } | } |
87 | 89 | ||
88 | if (!@mkdir($dst . "/gg")) { | ||
89 | xlog("\tCannot create gg dir ($php_errormsg)!"); | ||
90 | if (!@mkdir($dst . "/rg")) { | ||
91 | rg_log("\tCannot create rg dir ($php_errormsg)!"); | ||
90 | 92 | return FALSE; | return FALSE; |
91 | 93 | } | } |
92 | 94 | } | } |
93 | 95 | ||
94 | if (git_install_hooks($dst) === FALSE) | ||
96 | if (rg_git_install_hooks($dst) === FALSE) | ||
95 | 97 | return FALSE; | return FALSE; |
96 | 98 | ||
97 | 99 | return TRUE; | return TRUE; |
File inc/home/home.php added (mode: 100644) (index 0000000..c05b12a) | |||
1 | <?php | ||
2 | rg_log("/home/home.php"); | ||
3 | |||
4 | $_home = ""; | ||
5 | |||
6 | $_home .= "Bau!"; | ||
7 | |||
8 | ?> | ||
9 |
File inc/keys.inc.php changed (mode: 100644) (index 92fd4d2..ddb0b09) | |||
2 | 2 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
3 | 3 | require_once($INC . "/state.inc.php"); | require_once($INC . "/state.inc.php"); |
4 | 4 | ||
5 | $keys_error = ""; | ||
5 | $rg_keys_error = ""; | ||
6 | 6 | ||
7 | function keys_set_error($str) | ||
7 | function rg_keys_set_error($str) | ||
8 | 8 | { | { |
9 | global $keys_error; | ||
9 | global $rg_keys_error; | ||
10 | 10 | ||
11 | xlog("\tError: $str"); | ||
12 | $keys_error = $str; | ||
11 | rg_log("\tError: $str"); | ||
12 | $rg_keys_error = $str; | ||
13 | 13 | } | } |
14 | 14 | ||
15 | function keys_error() | ||
15 | function rg_keys_error() | ||
16 | 16 | { | { |
17 | global $keys_error; | ||
18 | return $keys_error; | ||
17 | global $rg_keys_error; | ||
18 | return $rg_keys_error; | ||
19 | 19 | } | } |
20 | 20 | ||
21 | 21 | /* | /* |
22 | * Generates the fingerprint of a key | ||
22 | * Validate key | ||
23 | 23 | */ | */ |
24 | function keys_fingerprint($key) | ||
24 | function rg_keys_valid($s) | ||
25 | 25 | { | { |
26 | $v = explode(" ", $key); | ||
26 | $v = explode(" ", $s); | ||
27 | if (!isset($v[1])) { | ||
28 | rg_keys_set_error("Malformed input (missing fields)"); | ||
29 | return FALSE; | ||
30 | } | ||
27 | 31 | ||
28 | 32 | $decoded = base64_decode(trim($v[1])); | $decoded = base64_decode(trim($v[1])); |
33 | if ($decoded === FALSE) { | ||
34 | rg_keys_set_error("Malformed input (base64 failed)"); | ||
35 | return FALSE; | ||
36 | } | ||
37 | |||
38 | return $decoded; | ||
39 | } | ||
40 | |||
41 | /* | ||
42 | * Generates the fingerprint of a key | ||
43 | */ | ||
44 | function rg_keys_fingerprint($key) | ||
45 | { | ||
46 | $decoded = rg_keys_valid($key); | ||
47 | if ($decoded === FALSE) | ||
48 | return rg_keys_error(); | ||
49 | |||
29 | 50 | $digest = md5($decoded); | $digest = md5($decoded); |
30 | 51 | ||
31 | 52 | $a = array(); | $a = array(); |
... | ... | function keys_fingerprint($key) | |
38 | 59 | /* | /* |
39 | 60 | * Remove a key from database | * Remove a key from database |
40 | 61 | */ | */ |
41 | function keys_remove($db, $uid, $key_id) | ||
62 | function rg_keys_remove($db, $rg_ui, $key_id) | ||
42 | 63 | { | { |
43 | 64 | // mark dirty | // mark dirty |
44 | state_set($db, "authorized_keys", 1); | ||
65 | rg_state_set($db, "authorized_keys", 1); | ||
45 | 66 | ||
46 | $e_uid = sprintf("%u", $uid); | ||
67 | // TODO: move this to caller? | ||
47 | 68 | $e_key_id = sprintf("%u", $key_id); | $e_key_id = sprintf("%u", $key_id); |
48 | 69 | ||
49 | 70 | $sql = "DELETE FROM keys" | $sql = "DELETE FROM keys" |
50 | . " WHERE uid = $e_uid" | ||
71 | . " WHERE uid = " . $rg_ui['uid'] | ||
51 | 72 | . " AND key_id = $e_key_id"; | . " AND key_id = $e_key_id"; |
52 | $res = sql_query($db, $sql); | ||
73 | $res = rg_sql_query($db, $sql); | ||
53 | 74 | if ($res === FALSE) { | if ($res === FALSE) { |
54 | keys_set_error("Cannot delete key $key_id (" . sql_error() . ")"); | ||
75 | rg_keys_set_error("Cannot delete key $key_id (" . rg_sql_error() . ")"); | ||
55 | 76 | return FALSE; | return FALSE; |
56 | 77 | } | } |
57 | sql_free_result($res); | ||
78 | rg_sql_free_result($res); | ||
58 | 79 | ||
59 | 80 | return TRUE; | return TRUE; |
60 | 81 | } | } |
... | ... | function keys_remove($db, $uid, $key_id) | |
63 | 84 | * Add a key | * Add a key |
64 | 85 | * Returns the key_id of the key. | * Returns the key_id of the key. |
65 | 86 | */ | */ |
66 | function keys_add($db, $uid, $key) | ||
87 | function rg_keys_add($db, $rg_ui, $key) | ||
67 | 88 | { | { |
68 | 89 | $itime = time(); | $itime = time(); |
69 | $e_uid = sprintf("%u", $uid); | ||
70 | $e_key = sql_escape($db, $key); | ||
90 | $e_key = rg_sql_escape($db, $key); | ||
91 | |||
92 | if (rg_keys_valid($key) === FALSE) | ||
93 | return FALSE; | ||
71 | 94 | ||
72 | 95 | // set dirty | // set dirty |
73 | if (state_set($db, "authorized_keys", 1) === FALSE) | ||
96 | if (rg_state_set($db, "authorized_keys", 1) === FALSE) | ||
74 | 97 | return FALSE; | return FALSE; |
75 | 98 | ||
76 | 99 | $sql = "INSERT INTO keys (itime, uid, key)" | $sql = "INSERT INTO keys (itime, uid, key)" |
77 | . " VALUES ($itime, $e_uid, '$e_key')"; | ||
78 | $res = sql_query($db, $sql); | ||
100 | . " VALUES ($itime, " . $rg_ui['uid'] . ", '$e_key')"; | ||
101 | $res = rg_sql_query($db, $sql); | ||
79 | 102 | if ($res === FALSE) { | if ($res === FALSE) { |
80 | keys_set_error("Cannot insert key (" . sql_error() . ")"); | ||
103 | rg_keys_set_error("Cannot insert key (" . rg_sql_error() . ")"); | ||
81 | 104 | return FALSE; | return FALSE; |
82 | 105 | } | } |
83 | sql_free_result($res); | ||
106 | rg_sql_free_result($res); | ||
84 | 107 | ||
85 | return sql_last_id($db); | ||
108 | return rg_sql_last_id($db); | ||
86 | 109 | } | } |
87 | 110 | ||
88 | 111 | /* | /* |
89 | 112 | * Regenerates authorized_keys files | * Regenerates authorized_keys files |
90 | 113 | */ | */ |
91 | function keys_regen($db) | ||
114 | function rg_keys_regen($db) | ||
92 | 115 | { | { |
93 | global $gg_keys_file; | ||
94 | global $gg_scripts; | ||
116 | global $rg_keys_file; | ||
117 | global $rg_scripts; | ||
95 | 118 | ||
96 | $dirty = state_get($db, "authorized_keys"); | ||
119 | $dirty = rg_state_get($db, "authorized_keys"); | ||
97 | 120 | if ($dirty == 0) | if ($dirty == 0) |
98 | 121 | return TRUE; | return TRUE; |
99 | 122 | ||
100 | $tmp = $gg_keys_file . ".tmp"; | ||
123 | $tmp = $rg_keys_file . ".tmp"; | ||
101 | 124 | $f = @fopen($tmp, "w"); | $f = @fopen($tmp, "w"); |
102 | 125 | if ($f === FALSE) { | if ($f === FALSE) { |
103 | keys_set_error("Cannot open file $tmp ($php_errormsg)!"); | ||
126 | rg_keys_set_error("Cannot open file $tmp ($php_errormsg)!"); | ||
104 | 127 | return FALSE; | return FALSE; |
105 | 128 | } | } |
106 | 129 | ||
107 | 130 | if (chmod($tmp, 0600) === FALSE) { | if (chmod($tmp, 0600) === FALSE) { |
108 | keys_set_error("Cannot chmod tmp file ($php_errmsg)!"); | ||
131 | rg_keys_set_error("Cannot chmod tmp file ($php_errmsg)!"); | ||
109 | 132 | return FALSE; | return FALSE; |
110 | 133 | } | } |
111 | 134 | ||
112 | 135 | $sql = "SELECT uid, key FROM keys"; | $sql = "SELECT uid, key FROM keys"; |
113 | $res = sql_query($db, $sql); | ||
136 | $res = rg_sql_query($db, $sql); | ||
114 | 137 | if ($res === FALSE) { | if ($res === FALSE) { |
115 | keys_set_error("Cannot query (" . sql_error() . ")"); | ||
138 | rg_keys_set_error("Cannot query (" . rg_sql_error() . ")"); | ||
116 | 139 | return FALSE; | return FALSE; |
117 | 140 | } | } |
118 | while (($row = sql_fetch_array($res))) { | ||
119 | $buf = "command=\"/usr/bin/php " . $gg_scripts . "/ssh.php " . $row['uid'] . "\"" | ||
141 | while (($row = rg_sql_fetch_array($res))) { | ||
142 | $buf = "command=\"/usr/bin/php " . $rg_scripts . "/ssh.php " . $row['uid'] . "\"" | ||
120 | 143 | . ",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty" | . ",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty" |
121 | 144 | . " " . $row['key'] . "\n"; | . " " . $row['key'] . "\n"; |
122 | 145 | if (@fwrite($f, $buf) === FALSE) { | if (@fwrite($f, $buf) === FALSE) { |
123 | keys_set_error("Cannot write. Disk space problems? ($php_errormsg)"); | ||
146 | rg_keys_set_error("Cannot write. Disk space problems? ($php_errormsg)"); | ||
124 | 147 | fclose($f); | fclose($f); |
125 | 148 | unlink($tmp); | unlink($tmp); |
126 | sql_free_result($res); | ||
149 | rg_sql_free_result($res); | ||
127 | 150 | return FALSE; | return FALSE; |
128 | 151 | } | } |
129 | 152 | } | } |
130 | sql_free_result($res); | ||
153 | rg_sql_free_result($res); | ||
131 | 154 | ||
132 | 155 | fclose($f); | fclose($f); |
133 | 156 | ||
134 | if (@rename($tmp, $gg_keys_file) === FALSE) { | ||
135 | keys_set_error("Cannot rename $tmp to $gg_keys_file ($php_errormsg)!"); | ||
157 | if (@rename($tmp, $rg_keys_file) === FALSE) { | ||
158 | rg_keys_set_error("Cannot rename $tmp to $rg_keys_file ($php_errormsg)!"); | ||
136 | 159 | unlink($tmp); | unlink($tmp); |
137 | 160 | return FALSE; | return FALSE; |
138 | 161 | } | } |
139 | 162 | ||
140 | 163 | // mark file as clean | // mark file as clean |
141 | state_set($db, "authorized_keys", 0); | ||
164 | rg_state_set($db, "authorized_keys", 0); | ||
142 | 165 | ||
143 | 166 | return TRUE; | return TRUE; |
144 | 167 | } | } |
... | ... | function keys_regen($db) | |
146 | 169 | /* | /* |
147 | 170 | * List keys | * List keys |
148 | 171 | */ | */ |
149 | function keys_list($db, $uid, $url) | ||
172 | function rg_keys_list($db, $rg_ui, $url) | ||
150 | 173 | { | { |
151 | xlog("keys_list: uid=$uid, url=$url..."); | ||
174 | rg_log("keys_list: rg_uid=" . $rg_ui['uid'] . ", url=$url..."); | ||
152 | 175 | ||
153 | $sql = "SELECT * FROM keys WHERE uid = $uid"; | ||
154 | $res = sql_query($db, $sql); | ||
176 | $sql = "SELECT * FROM keys WHERE uid = " . $rg_ui['uid']; | ||
177 | $res = rg_sql_query($db, $sql); | ||
155 | 178 | if ($res === FALSE) { | if ($res === FALSE) { |
156 | keys_set_error("Cannot query (" . sql_error() . ")"); | ||
179 | rg_keys_set_error("Cannot query (" . rg_sql_error() . ")"); | ||
157 | 180 | return FALSE; | return FALSE; |
158 | 181 | } | } |
159 | 182 | ||
... | ... | function keys_list($db, $uid, $url) | |
163 | 186 | $ret .= " <th>Fingerprint</th>\n"; | $ret .= " <th>Fingerprint</th>\n"; |
164 | 187 | $ret .= " <th>Operations</th>\n"; | $ret .= " <th>Operations</th>\n"; |
165 | 188 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
166 | while (($row = sql_fetch_array($res))) { | ||
189 | while (($row = rg_sql_fetch_array($res))) { | ||
167 | 190 | $ret .= "<tr>\n"; | $ret .= "<tr>\n"; |
168 | 191 | $ret .= " <td>" . gmdate("Y-m-d H:i:s", $row['itime']) . "</td>\n"; | $ret .= " <td>" . gmdate("Y-m-d H:i:s", $row['itime']) . "</td>\n"; |
169 | $ret .= " <td>" . keys_fingerprint($row['key']) . "</td>\n"; | ||
192 | $ret .= " <td>" . rg_keys_fingerprint($row['key']) . "</td>\n"; | ||
170 | 193 | ||
171 | 194 | $oper = ""; | $oper = ""; |
172 | 195 | $oper = "[<a href=\"$url&key_id=" . $row['key_id'] | $oper = "[<a href=\"$url&key_id=" . $row['key_id'] |
... | ... | function keys_list($db, $uid, $url) | |
175 | 198 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
176 | 199 | } | } |
177 | 200 | $ret .= "</table>\n"; | $ret .= "</table>\n"; |
178 | sql_free_result($res); | ||
201 | rg_sql_free_result($res); | ||
179 | 202 | ||
180 | 203 | return $ret; | return $ret; |
181 | 204 | } | } |
File inc/keys/add.form.php changed (mode: 100644) (index f1896b0..641cf91) | |||
1 | 1 | <?php | <?php |
2 | 2 | ||
3 | 3 | $_form = ' | $_form = ' |
4 | <form type="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
4 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
5 | 5 | <input type="hidden" name="op" value="' . $op . '"> | <input type="hidden" name="op" value="' . $op . '"> |
6 | 6 | <input type="hidden" name="subop" value="' . $subop . '"> | <input type="hidden" name="subop" value="' . $subop . '"> |
7 | 7 | <input type="hidden" name="doit" value="1"> | <input type="hidden" name="doit" value="1"> |
File inc/keys/keys.php changed (mode: 100644) (index ee46f0a..a0368e5) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/keys/keys.php"); | ||
2 | rg_log("/inc/keys/keys.php"); | ||
3 | 3 | ||
4 | if ($gg_uid == 0) { | ||
5 | $_body = "You do not have access here!"; | ||
4 | $_keys = ""; | ||
5 | |||
6 | if ($rg_ui['uid'] == 0) { | ||
7 | $_keys .= "You do not have access here!"; | ||
6 | 8 | return; | return; |
7 | 9 | } | } |
8 | 10 | ||
9 | $subop = @intval($_REQUEST['subop']); | ||
10 | $key = @$_REQUEST['key']; | ||
11 | $key = rg_var_str("key"); | ||
11 | 12 | $key = preg_replace("|[^/A-Za-z0-9 @/+_\.\=,-]|", "", $key); | $key = preg_replace("|[^/A-Za-z0-9 @/+_\.\=,-]|", "", $key); |
12 | $key_id = @intval($_REQUEST['key_id']); | ||
13 | $key_id = rg_var_uint("key_id"); | ||
13 | 14 | ||
14 | 15 | // menu | // menu |
15 | $_url = $_SERVER['PHP_SELF'] . "?op=$op"; | ||
16 | $_url = rg_re_url($op); | ||
16 | 17 | $_menu = ""; | $_menu = ""; |
17 | 18 | $_menu .= "[<a href=\"$_url&subop=1\">Add</a>]"; | $_menu .= "[<a href=\"$_url&subop=1\">Add</a>]"; |
18 | 19 | $_menu .= " [<a href=\"$_url&subop=2\">List</a>]"; | $_menu .= " [<a href=\"$_url&subop=2\">List</a>]"; |
... | ... | $_body = ""; | |
24 | 25 | switch ($subop) { | switch ($subop) { |
25 | 26 | case 1: // add | case 1: // add |
26 | 27 | if ($doit == 1) { | if ($doit == 1) { |
27 | $_r = keys_add($db, $gg_uid, $key); | ||
28 | $_r = rg_keys_add($db, $rg_ui, $key); | ||
28 | 29 | if ($_r === FALSE) | if ($_r === FALSE) |
29 | $_body .= keys_error(); | ||
30 | $_body .= rg_keys_error(); | ||
30 | 31 | else | else |
31 | 32 | $_body = "OK!"; | $_body = "OK!"; |
32 | } else { | ||
33 | include($INC . "/keys/add.form.php"); | ||
34 | $_body .= $_form; | ||
35 | 33 | } | } |
34 | |||
35 | include($INC . "/keys/add.form.php"); | ||
36 | $_body .= $_form; | ||
36 | 37 | break; | break; |
37 | 38 | ||
38 | 39 | case 2: // list | case 2: // list |
39 | if (@$_REQUEST['delete'] == 1) { | ||
40 | if (keys_remove($db, $gg_uid, $key_id) === FALSE) | ||
41 | $_body .= "Bad: " . keys_error() . "!<br />\n"; | ||
40 | if (rg_var_uint("delete") == 1) { | ||
41 | if (rg_keys_remove($db, $rg_ui, $key_id) === FALSE) | ||
42 | $_body .= "Bad: " . rg_keys_error() . "!<br />\n"; | ||
42 | 43 | } | } |
43 | 44 | ||
44 | $_body .= keys_list($db, $gg_uid, $_url . "&subop=2"); | ||
45 | $_body .= rg_keys_list($db, $rg_ui, $_url . "&subop=2"); | ||
45 | 46 | break; | break; |
46 | 47 | ||
47 | 48 | } | } |
48 | 49 | ||
49 | $_keys = $_menu . $_body; | ||
50 | $_keys .= $_menu . $_body; | ||
50 | 51 | ?> | ?> |
File inc/log.inc.php added (mode: 100644) (index 0000000..11c8ca3) | |||
1 | <?php | ||
2 | require_once($INC . "/util.inc.php"); | ||
3 | |||
4 | $rg_log_file = "/tmp/rg.log"; | ||
5 | $rg_log_fd = FALSE; | ||
6 | $rg_log_sid = rg_id(6); | ||
7 | |||
8 | function rg_log_set_file($file) | ||
9 | { | ||
10 | global $rg_log_file; | ||
11 | |||
12 | $rg_log_file = $file; | ||
13 | } | ||
14 | |||
15 | function rg_log($str) | ||
16 | { | ||
17 | global $rg_log_file; | ||
18 | global $rg_log_fd; | ||
19 | global $rg_log_sid; | ||
20 | |||
21 | if ($rg_log_fd === FALSE) { | ||
22 | $rg_log_fd = @fopen($rg_log_file, "a+"); | ||
23 | if ($rg_log_fd === FALSE) | ||
24 | return; | ||
25 | // write an empty line | ||
26 | fwrite($rg_log_fd, "\n"); | ||
27 | } | ||
28 | |||
29 | $t = gettimeofday(); | ||
30 | $buf = gmdate("Y-m-d H:i:s", $t['sec']) . "." . sprintf("%06d", $t['usec']); | ||
31 | $buf .= " " . $rg_log_sid . " " . $str . "\n"; | ||
32 | |||
33 | fwrite($rg_log_fd, $buf); | ||
34 | } | ||
35 | |||
36 | ?> |
File inc/login/login.form.php changed (mode: 100644) (index 26ea6eb..29827c0) | |||
1 | 1 | <?php | <?php |
2 | 2 | $_form = ''; | $_form = ''; |
3 | 3 | ||
4 | if (!empty($error)) | ||
5 | $_form .= "<font color=red>$error</font>\n"; | ||
4 | if (count($errmsg) > 0) | ||
5 | $_form .= "<font color=red>" . implode("<br />\n", $errmsg) . "</font>\n"; | ||
6 | 6 | ||
7 | 7 | $_form .= ' | $_form .= ' |
8 | 8 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> |
... | ... | Password: <input type="password" name="pass" value="' . $pass . '"><br /> | |
17 | 17 | ||
18 | 18 | Forgot your password?<br /> | Forgot your password?<br /> |
19 | 19 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> |
20 | <input type="hidden" name="op" value="7"> | ||
20 | <input type="hidden" name="op" value="forgotmail"> | ||
21 | 21 | <input type="hidden" name="doit" value="1"> | <input type="hidden" name="doit" value="1"> |
22 | 22 | ||
23 | 23 | E-mail: <input type="text" name="email" value=""><br /> | E-mail: <input type="text" name="email" value=""><br /> |
File inc/login/login.php changed (mode: 100644) (index d677c0c..b5edbcd) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/login/login.php"); | ||
2 | rg_log("/inc/login/login.php"); | ||
3 | 3 | ||
4 | $doit = @intval($_REQUEST['doit']); | ||
5 | $user = @$_COOKIE['user']; | ||
6 | $pass = ""; | ||
4 | $user = rg_var_str("user"); | ||
5 | $pass = rg_var_str("pass"); | ||
7 | 6 | ||
8 | 7 | $_login = "<br />\n"; | $_login = "<br />\n"; |
9 | 8 | ||
10 | $error = ""; | ||
11 | if ($doit == 1) | ||
12 | $error = "Invalid user and/or pass."; | ||
9 | $show_form = 1; | ||
13 | 10 | ||
14 | include($INC . "/login/login.form.php"); | ||
15 | $_login .= $_form; | ||
11 | $errmsg = array(); | ||
16 | 12 | ||
17 | ?> | ||
13 | if ($doit == 1) { | ||
14 | $r = rg_user_login_by_user_pass($db, $user, $pass, $rg_ui); | ||
15 | if ($r === FALSE) { | ||
16 | $errmsg[] = rg_user_error(); | ||
17 | } else { | ||
18 | $show_form = 0; | ||
19 | $new_op = "home"; // redirect to home page | ||
20 | } | ||
21 | } | ||
22 | |||
23 | if ($show_form == 1) { | ||
24 | include($INC . "/login/login.form.php"); | ||
25 | $_login .= $_form; | ||
26 | } | ||
27 | |||
28 | ?> |
File inc/repo.inc.php changed (mode: 100644) (index bd1ce29..c641892) | |||
1 | 1 | <?php | <?php |
2 | 2 | require_once($INC . "/util.inc.php"); | require_once($INC . "/util.inc.php"); |
3 | require_once($INC . "/xlog.inc.php"); | ||
3 | require_once($INC . "/log.inc.php"); | ||
4 | 4 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
5 | 5 | require_once($INC . "/user.inc.php"); | require_once($INC . "/user.inc.php"); |
6 | 6 | require_once($INC . "/git.inc.php"); | require_once($INC . "/git.inc.php"); |
7 | 7 | ||
8 | $gg_repo_error = ""; | ||
8 | $rg_repo_error = ""; | ||
9 | 9 | ||
10 | $gg_repo_rights = array("A" => "Admin", | ||
10 | $rg_repo_rights = array("A" => "Admin", | ||
11 | 11 | "F" => "Fetch", | "F" => "Fetch", |
12 | 12 | "P" => "Push", | "P" => "Push", |
13 | 13 | "D" => "Delete branch"); | "D" => "Delete branch"); |
14 | 14 | ||
15 | function gg_repo_set_error($str) | ||
15 | function rg_repo_set_error($str) | ||
16 | 16 | { | { |
17 | global $gg_repo_error; | ||
17 | global $rg_repo_error; | ||
18 | 18 | ||
19 | xlog("\tError: $str"); | ||
20 | $gg_repo_error = $str; | ||
19 | rg_log("\tError: $str"); | ||
20 | $rg_repo_error = $str; | ||
21 | 21 | } | } |
22 | 22 | ||
23 | function gg_repo_error() | ||
23 | function rg_repo_error() | ||
24 | 24 | { | { |
25 | global $gg_repo_error; | ||
26 | return $gg_repo_error; | ||
25 | global $rg_repo_error; | ||
26 | return $rg_repo_error; | ||
27 | } | ||
28 | |||
29 | /* | ||
30 | * Enforce name | ||
31 | */ | ||
32 | function rg_repo_ok($repo) | ||
33 | { | ||
34 | global $rg_repo_allow; | ||
35 | global $rg_repo_max_len; | ||
36 | |||
37 | if (rg_chars_allow($repo, $rg_repo_allow) === FALSE) { | ||
38 | rg_repo_set_error("Invalid repository name"); | ||
39 | return FALSE; | ||
40 | } | ||
41 | |||
42 | if (preg_match('/\.\./', $repo)) { | ||
43 | rg_repo_set_error("Invalid repository name"); | ||
44 | return FALSE; | ||
45 | } | ||
46 | |||
47 | if (strlen($repo) > $rg_repo_max_len) { | ||
48 | rg_repo_set_error("Repository name is too long"); | ||
49 | return FALSE; | ||
50 | } | ||
51 | |||
52 | return TRUE; | ||
27 | 53 | } | } |
28 | 54 | ||
29 | 55 | /* | /* |
30 | 56 | * Returns the path to a repository based on repo_id | * Returns the path to a repository based on repo_id |
31 | 57 | */ | */ |
32 | function repo_id2base($repo_id) | ||
58 | function rg_repo_id2base($repo_id) | ||
33 | 59 | { | { |
34 | global $gg_base_repo; | ||
60 | global $rg_base_repo; | ||
35 | 61 | ||
36 | 62 | $r3 = sprintf("%03u", $repo_id % 1000); | $r3 = sprintf("%03u", $repo_id % 1000); |
37 | 63 | ||
38 | return $gg_base_repo . "/" | ||
64 | return $rg_base_repo . "/" | ||
39 | 65 | . $r3[0] . "/" . $r3[1] . "/" . $r3[2] . "/"; | . $r3[0] . "/" . $r3[1] . "/" . $r3[2] . "/"; |
40 | 66 | } | } |
41 | 67 | ||
42 | 68 | /* | /* |
43 | 69 | * Return info about a repo | * Return info about a repo |
44 | 70 | */ | */ |
45 | function repo_info($db, $repo_id, $repo) | ||
71 | function rg_repo_info($db, $repo_id, $repo) | ||
46 | 72 | { | { |
47 | xlog("repo_info: repo_id=$repo_id, repo=$repo..."); | ||
73 | rg_log("repo_info: repo_id=$repo_id, repo=$repo..."); | ||
48 | 74 | ||
49 | 75 | $ret['ok'] = 0; | $ret['ok'] = 0; |
50 | 76 | $ret['exists'] = 0; | $ret['exists'] = 0; |
... | ... | function repo_info($db, $repo_id, $repo) | |
52 | 78 | if ($repo_id > 0) { | if ($repo_id > 0) { |
53 | 79 | $add = " AND repo_id = $repo_id"; | $add = " AND repo_id = $repo_id"; |
54 | 80 | } else if (!empty($repo)) { | } else if (!empty($repo)) { |
55 | $e_repo = sql_escape($db, $repo); | ||
81 | $e_repo = rg_sql_escape($db, $repo); | ||
56 | 82 | $add = " AND name = '$e_repo'"; | $add = " AND name = '$e_repo'"; |
57 | 83 | } else { | } else { |
58 | 84 | $ret['errmsg'] = "No repo_id or name specified!"; | $ret['errmsg'] = "No repo_id or name specified!"; |
... | ... | function repo_info($db, $repo_id, $repo) | |
60 | 86 | } | } |
61 | 87 | ||
62 | 88 | $sql = "SELECT * FROM repos WHERE 1 = 1" . $add; | $sql = "SELECT * FROM repos WHERE 1 = 1" . $add; |
63 | $res = sql_query($db, $sql); | ||
89 | $res = rg_sql_query($db, $sql); | ||
64 | 90 | if ($res === FALSE) { | if ($res === FALSE) { |
65 | $ret['errmsg'] = "Cannot query (" . sql_error() . ")"; | ||
66 | xlog("\t" . $ret['errmsg']); | ||
91 | $ret['errmsg'] = "Cannot query (" . rg_sql_error() . ")"; | ||
92 | rg_log("\t" . $ret['errmsg']); | ||
67 | 93 | return $ret; | return $ret; |
68 | 94 | } | } |
69 | 95 | $ret['ok'] = 1; | $ret['ok'] = 1; |
70 | $row = sql_fetch_array($res); | ||
71 | sql_free_result($res); | ||
96 | $row = rg_sql_fetch_array($res); | ||
97 | rg_sql_free_result($res); | ||
72 | 98 | if (!isset($row['repo_id'])) { | if (!isset($row['repo_id'])) { |
73 | xlog("\tRepo not found!"); | ||
99 | rg_log("\tRepo not found!"); | ||
74 | 100 | return $ret; | return $ret; |
75 | 101 | } | } |
76 | 102 | ||
... | ... | function repo_info($db, $repo_id, $repo) | |
82 | 108 | /* | /* |
83 | 109 | * Check if a uid has access to repository | * Check if a uid has access to repository |
84 | 110 | */ | */ |
85 | function repo_allow($db, $ri, $uid, $needed_rights) | ||
111 | function rg_repo_allow($db, $ri, $rg_ui, $needed_rights) | ||
86 | 112 | { | { |
87 | xlog("repo_allow: uid=$uid, needed_rights=$needed_rights..."); | ||
113 | rg_log("repo_allow: rg_uid=" . $rg_ui['uid'] | ||
114 | . ", needed_rights=$needed_rights..."); | ||
115 | |||
116 | if ($rg_ui['is_admin'] == 1) | ||
117 | return TRUE; | ||
88 | 118 | ||
89 | 119 | if (empty($needed_rights)) { | if (empty($needed_rights)) { |
90 | xlog("\tNo perms passed!"); | ||
120 | rg_log("\tNo perms passed!"); | ||
91 | 121 | return FALSE; | return FALSE; |
92 | 122 | } | } |
93 | 123 | ||
94 | $rr = gg_repo_rights_get($db, $ri, $uid); | ||
124 | $rr = rg_repo_rights_get($db, $ri, $rg_ui['uid']); | ||
95 | 125 | if ($rr['ok'] != 1) { | if ($rr['ok'] != 1) { |
96 | gg_repo_set_error("No access!"); | ||
126 | rg_repo_set_error("No access!"); | ||
97 | 127 | return FALSE; | return FALSE; |
98 | 128 | } | } |
99 | xlog("\tdb rights: " . $rr['rights']); | ||
129 | rg_log("\tdb rights: " . $rr['rights']); | ||
100 | 130 | ||
101 | 131 | $len = strlen($needed_rights); | $len = strlen($needed_rights); |
102 | 132 | for ($i = 0; $i < $len; $i++) { | for ($i = 0; $i < $len; $i++) { |
103 | 133 | if (!strstr($rr['rights'], $needed_rights[$i])) { | if (!strstr($rr['rights'], $needed_rights[$i])) { |
104 | gg_repo_set_error("No rights (" . $needed_rights[$i] . ")"); | ||
134 | rg_repo_set_error("No rights (" . $needed_rights[$i] . ")"); | ||
105 | 135 | return FALSE; | return FALSE; |
106 | 136 | } | } |
107 | 137 | } | } |
108 | 138 | ||
109 | xlog("\tAllow access!"); | ||
139 | rg_log("\tAllow access!"); | ||
110 | 140 | ||
111 | 141 | return TRUE; | return TRUE; |
112 | 142 | } | } |
... | ... | function repo_allow($db, $ri, $uid, $needed_rights) | |
114 | 144 | /* | /* |
115 | 145 | * Add a repository | * Add a repository |
116 | 146 | * @master - makes sense only for clones - who is the master. | * @master - makes sense only for clones - who is the master. |
147 | * TODO: put all fields into an array! | ||
117 | 148 | */ | */ |
118 | function repo_create($db, $master, $gg_uid, $name, $max_commit_size, $desc, | ||
149 | function rg_repo_create($db, $master, $rg_ui, $name, $max_commit_size, $desc, | ||
119 | 150 | $rights) | $rights) |
120 | 151 | { | { |
121 | 152 | // TODO: reorder parameters - are not logical | // TODO: reorder parameters - are not logical |
122 | xlog("repo_create: gg_uid=$gg_uid, name=[$name], master=$master" | ||
153 | rg_log("repo_create: rg_uid=" . $rg_ui['uid'] | ||
154 | . ", name=[$name], master=$master" | ||
123 | 155 | . ", max_commit_size=$max_commit_size, desc=[$desc]" | . ", max_commit_size=$max_commit_size, desc=[$desc]" |
124 | 156 | . ", rights=$rights..."); | . ", rights=$rights..."); |
125 | 157 | ||
158 | if (rg_repo_ok($name) === FALSE) | ||
159 | return FALSE; | ||
160 | |||
126 | 161 | // First, test if it already exists | // First, test if it already exists |
127 | $ri = repo_info($db, 0, $name); | ||
162 | $ri = rg_repo_info($db, 0, $name); | ||
128 | 163 | if ($ri['ok'] != 1) | if ($ri['ok'] != 1) |
129 | 164 | return FALSE; | return FALSE; |
130 | 165 | if ($ri['exists'] == 1) { | if ($ri['exists'] == 1) { |
131 | gg_repo_set_error("Repository already exists."); | ||
166 | rg_repo_set_error("Repository already exists."); | ||
132 | 167 | return FALSE; | return FALSE; |
133 | 168 | } | } |
134 | 169 | ||
135 | // XSS protection | ||
136 | $name = gg_xss($name); | ||
137 | $desc = gg_xss($desc); | ||
170 | // XSS protection - TODO: be more specific | ||
171 | $name = rg_xss($name); | ||
172 | $desc = rg_xss($desc); | ||
138 | 173 | ||
139 | $e_name = sql_escape($db, $name); | ||
140 | $e_desc = sql_escape($db, $desc); | ||
174 | $e_name = rg_sql_escape($db, $name); | ||
175 | $e_desc = rg_sql_escape($db, $desc); | ||
141 | 176 | ||
142 | 177 | $itime = time(); | $itime = time(); |
143 | 178 | ||
144 | 179 | $sql = "INSERT INTO repos (uid, master, name, itime" | $sql = "INSERT INTO repos (uid, master, name, itime" |
145 | 180 | . ", max_commit_size, desc, git_dir_done, default_rights)" | . ", max_commit_size, desc, git_dir_done, default_rights)" |
146 | . " VALUES ($gg_uid, $master, '$e_name', $itime" | ||
181 | . " VALUES (" . $rg_ui['uid'] . ", $master, '$e_name', $itime" | ||
147 | 182 | . ", $max_commit_size, '$e_desc', 0, '$rights')"; | . ", $max_commit_size, '$e_desc', 0, '$rights')"; |
148 | $res = sql_query($db, $sql); | ||
183 | $res = rg_sql_query($db, $sql); | ||
149 | 184 | if ($res === FALSE) { | if ($res === FALSE) { |
150 | gg_repo_set_error("Cannot insert (" . sql_error() . ")"); | ||
185 | rg_repo_set_error("Cannot insert (" . rg_sql_error() . ")"); | ||
151 | 186 | return FALSE; | return FALSE; |
152 | 187 | } | } |
153 | sql_free_result($res); | ||
188 | rg_sql_free_result($res); | ||
154 | 189 | ||
155 | 190 | // git repo creation will be delayed for serialization reasons | // git repo creation will be delayed for serialization reasons |
156 | 191 | // and for permission reasons (we are apache here) | // and for permission reasons (we are apache here) |
... | ... | function repo_create($db, $master, $gg_uid, $name, $max_commit_size, $desc, | |
161 | 196 | /* | /* |
162 | 197 | * Delete a repo | * Delete a repo |
163 | 198 | */ | */ |
164 | function gg_repo_delete($db, $repo_id, $gg_uid) | ||
199 | function rg_repo_delete($db, $repo_id, $rg_ui) | ||
165 | 200 | { | { |
166 | xlog("repo_delete: gg_uid=$gg_uid, repo_id=$repo_id"); | ||
201 | rg_log("repo_delete: rg_uid=" . $rg_ui['uid'] . ", repo_id=$repo_id"); | ||
167 | 202 | ||
168 | 203 | // TODO: Check rights | // TODO: Check rights |
169 | 204 | ||
170 | 205 | // Only mark it as such, deletion will happen in background | // Only mark it as such, deletion will happen in background |
171 | 206 | $sql = "UPDATE repos SET deleted = 1 WHERE repo_id = $repo_id"; | $sql = "UPDATE repos SET deleted = 1 WHERE repo_id = $repo_id"; |
172 | $res = sql_query($db, $sql); | ||
207 | $res = rg_sql_query($db, $sql); | ||
173 | 208 | if ($res === FALSE) { | if ($res === FALSE) { |
174 | gg_repo_set_error("Cannot delete (" . sql_error() . ")"); | ||
209 | rg_repo_set_error("Cannot delete (" . rg_sql_error() . ")"); | ||
175 | 210 | return FALSE; | return FALSE; |
176 | 211 | } | } |
177 | sql_free_result($res); | ||
212 | rg_sql_free_result($res); | ||
178 | 213 | ||
179 | 214 | return TRUE; | return TRUE; |
180 | 215 | } | } |
... | ... | function gg_repo_delete($db, $repo_id, $gg_uid) | |
183 | 218 | * Update a repository | * Update a repository |
184 | 219 | * TODO: check rights - also for create? | * TODO: check rights - also for create? |
185 | 220 | */ | */ |
186 | function gg_repo_update($db, $repo_id, $gg_uid, $name, $max_commit_size, $desc, | ||
187 | $rights) | ||
221 | function rg_repo_update($db, &$new) | ||
188 | 222 | { | { |
189 | xlog("repo_update: repo_id=$repo_id, gg_uid=$gg_uid, name=[$name]" | ||
190 | . ", max_commit_size=$max_commit_size, desc=[$desc]" | ||
191 | . ", rights=$rights..."); | ||
223 | rg_log("repo_update: repo_id=" . $new['repo_id'] | ||
224 | . ", name=[" . $new['name'] . "]" | ||
225 | . ", max_commit_size=" . $new['max_commit_size'] | ||
226 | . ", desc=[" . $new['desc'] . "]" | ||
227 | . ", default_rights=" . $new['default_rights']); | ||
228 | |||
229 | if (rg_repo_ok($new['name']) === FALSE) | ||
230 | return FALSE; | ||
192 | 231 | ||
193 | 232 | // First, test if it already exists | // First, test if it already exists |
194 | $ri = repo_info($db, 0, $name); | ||
233 | $ri = rg_repo_info($db, 0, $new['name']); | ||
195 | 234 | if ($ri['ok'] != 1) | if ($ri['ok'] != 1) |
196 | 235 | return FALSE; | return FALSE; |
197 | if (($ri['exists'] == 1) && ($ri['repo_id'] != $repo_id)) { | ||
198 | gg_repo_set_error("Name already taken."); | ||
236 | if (($ri['exists'] == 1) && ($ri['repo_id'] != $new['repo_id'])) { | ||
237 | rg_repo_set_error("Name already taken."); | ||
199 | 238 | return FALSE; | return FALSE; |
200 | 239 | } | } |
201 | 240 | ||
202 | // Second, test if we repo_id is valid | ||
203 | $ri = repo_info($db, $repo_id, ""); | ||
241 | // Second, test if repo_id is valid | ||
242 | $ri = rg_repo_info($db, $new['repo_id'], ""); | ||
204 | 243 | if ($ri['ok'] != 1) | if ($ri['ok'] != 1) |
205 | 244 | return FALSE; | return FALSE; |
206 | 245 | if ($ri['exists'] == 0) { | if ($ri['exists'] == 0) { |
207 | gg_repo_set_error("Repo $repo_id does not eists."); | ||
246 | rg_repo_set_error("Repo " . $new['repo_id'] . " does not exists."); | ||
208 | 247 | return FALSE; | return FALSE; |
209 | 248 | } | } |
210 | 249 | ||
211 | // XSS protection | ||
212 | $name = gg_xss($name); | ||
213 | $desc = gg_xss($desc); | ||
250 | // XSS protection - TODO: move this to the caller! | ||
251 | $new['name'] = rg_xss($new['name']); | ||
252 | $new['desc'] = rg_xss($new['desc']); | ||
214 | 253 | ||
215 | $e_name = sql_escape($db, $name); | ||
216 | $e_desc = sql_escape($db, $desc); | ||
254 | $e_name = rg_sql_escape($db, $new['name']); | ||
255 | $e_desc = rg_sql_escape($db, $new['desc']); | ||
217 | 256 | ||
218 | 257 | $sql = "UPDATE repos SET name = '$e_name'" | $sql = "UPDATE repos SET name = '$e_name'" |
219 | . ", max_commit_size = $max_commit_size" | ||
258 | . ", max_commit_size = " . $new['max_commit_size'] | ||
220 | 259 | . ", desc = '$e_desc'" | . ", desc = '$e_desc'" |
221 | . ", default_rights = '$rights'" | ||
222 | . " WHERE repo_id = $repo_id"; | ||
223 | $res = sql_query($db, $sql); | ||
260 | . ", default_rights = '" . $new['default_rights'] . "'" | ||
261 | . " WHERE repo_id = " . $new['repo_id']; | ||
262 | $res = rg_sql_query($db, $sql); | ||
224 | 263 | if ($res === FALSE) { | if ($res === FALSE) { |
225 | gg_repo_set_error("Cannot update (" . sql_error() . ")"); | ||
264 | rg_repo_set_error("Cannot update (" . rg_sql_error() . ")"); | ||
226 | 265 | return FALSE; | return FALSE; |
227 | 266 | } | } |
228 | sql_free_result($res); | ||
267 | rg_sql_free_result($res); | ||
229 | 268 | ||
230 | 269 | return TRUE; | return TRUE; |
231 | 270 | } | } |
... | ... | function gg_repo_update($db, $repo_id, $gg_uid, $name, $max_commit_size, $desc, | |
233 | 272 | /* | /* |
234 | 273 | * List repositories | * List repositories |
235 | 274 | */ | */ |
236 | function repo_list_query($db, $url, $sql) | ||
275 | function rg_repo_list_query($db, $url, $sql) | ||
237 | 276 | { | { |
238 | xlog("repo_list_query: url=$url, sql=$sql..."); | ||
277 | rg_log("repo_list_query: url=$url, sql=$sql..."); | ||
239 | 278 | ||
240 | $res = sql_query($db, $sql); | ||
279 | $res = rg_sql_query($db, $sql); | ||
241 | 280 | if ($res === FALSE) | if ($res === FALSE) |
242 | 281 | return FALSE; | return FALSE; |
243 | 282 | ||
... | ... | function repo_list_query($db, $url, $sql) | |
251 | 290 | $ret .= " <th>Disk current/max</th>\n"; | $ret .= " <th>Disk current/max</th>\n"; |
252 | 291 | $ret .= " <th>Max commit size</th>\n"; | $ret .= " <th>Max commit size</th>\n"; |
253 | 292 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
254 | while (($row = sql_fetch_array($res))) { | ||
293 | while (($row = rg_sql_fetch_array($res))) { | ||
255 | 294 | $ret .= "<tr>\n"; | $ret .= "<tr>\n"; |
256 | $ret .= " <td><a href=\"" . $_SERVER['PHP_SELF'] . "?op=10&repo_id=" . $row['repo_id'] . "\">" . $row['name'] . "</a></td>\n"; | ||
295 | $_link = rg_re_repopage($row['repo_id'], $row['name']); | ||
296 | $ret .= " <td><a href=\"$_link\">" . $row['name'] . "</a></td>\n"; | ||
257 | 297 | $ret .= " <td><small>" . nl2br($row['desc']) . "</small></td>\n"; | $ret .= " <td><small>" . nl2br($row['desc']) . "</small></td>\n"; |
258 | 298 | if ($row['master'] > 0) { | if ($row['master'] > 0) { |
259 | 299 | $master_repo = "?"; | $master_repo = "?"; |
260 | $_mi = repo_info($db, $row['master'], ""); | ||
300 | $_mi = rg_repo_info($db, $row['master'], ""); | ||
261 | 301 | if ($_mi['exists'] = 1) | if ($_mi['exists'] = 1) |
262 | 302 | $master_repo = $_mi['name']; | $master_repo = $_mi['name']; |
263 | 303 | } | } |
... | ... | function repo_list_query($db, $url, $sql) | |
265 | 305 | $ret .= " <td>" . gmdate("Y-m-d H:i:s", $row['itime']) . "</td>\n"; | $ret .= " <td>" . gmdate("Y-m-d H:i:s", $row['itime']) . "</td>\n"; |
266 | 306 | ||
267 | 307 | // rights | // rights |
268 | $_r = implode(", ", gg_repo_rights_text($row['default_rights'])); | ||
308 | $_r = implode(", ", rg_repo_rights_text($row['default_rights'])); | ||
269 | 309 | $ret .= " <td>" . $_r . "</td>\n"; | $ret .= " <td>" . $_r . "</td>\n"; |
270 | 310 | ||
271 | 311 | $_max = "ulimited"; | $_max = "ulimited"; |
272 | 312 | if ($row['disk_quota_mb'] > 0) | if ($row['disk_quota_mb'] > 0) |
273 | $_max = gg_1024($row['disk_quota_mb']); | ||
313 | $_max = rg_1024($row['disk_quota_mb']); | ||
274 | 314 | $ret .= " <td>" . $row['disk_mb'] . "/" . $_max . "</td>\n"; | $ret .= " <td>" . $row['disk_mb'] . "/" . $_max . "</td>\n"; |
275 | 315 | ||
276 | 316 | $_v = "ulimited"; | $_v = "ulimited"; |
277 | 317 | if ($row['max_commit_size'] > 0) | if ($row['max_commit_size'] > 0) |
278 | $_v = gg_1024($row['max_commit_size']); | ||
318 | $_v = rg_1024($row['max_commit_size']); | ||
279 | 319 | $ret .= " <td>" . $_v . "</td>\n"; | $ret .= " <td>" . $_v . "</td>\n"; |
280 | 320 | ||
281 | 321 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
282 | 322 | } | } |
283 | 323 | $ret .= "</table>\n"; | $ret .= "</table>\n"; |
284 | sql_free_result($res); | ||
324 | rg_sql_free_result($res); | ||
285 | 325 | ||
286 | 326 | return $ret; | return $ret; |
287 | 327 | } | } |
... | ... | function repo_list_query($db, $url, $sql) | |
289 | 329 | /* | /* |
290 | 330 | * | * |
291 | 331 | */ | */ |
292 | function repo_list($db, $url, $uid) | ||
332 | function rg_repo_list($db, $url, $rg_ui) | ||
293 | 333 | { | { |
294 | xlog("repo_list: url=$url, uid=$uid..."); | ||
334 | rg_log("repo_list: url=$url, rg_uid=" . $rg_ui['uid']); | ||
295 | 335 | ||
296 | 336 | $add = ""; | $add = ""; |
297 | if ($uid > 0) | ||
298 | $add = " AND uid = $uid"; | ||
337 | if ($rg_ui['uid'] > 0) | ||
338 | $add = " AND uid = " . $rg_ui['uid']; | ||
299 | 339 | ||
300 | 340 | $sql = "SELECT * FROM repos" | $sql = "SELECT * FROM repos" |
301 | 341 | . " WHERE deleted = 0" | . " WHERE deleted = 0" |
302 | 342 | . $add | . $add |
303 | 343 | . " ORDER BY name"; | . " ORDER BY name"; |
304 | 344 | ||
305 | return repo_list_query($db, $url, $sql); | ||
345 | return rg_repo_list_query($db, $url, $sql); | ||
306 | 346 | } | } |
307 | 347 | ||
308 | 348 | /* | /* |
309 | 349 | * | * |
310 | 350 | */ | */ |
311 | function repo_search($db, $q, $masters) | ||
351 | function rg_repo_search($db, $q, $masters) | ||
312 | 352 | { | { |
313 | xlog("repo_search: q=$q, masters=$masters..."); | ||
353 | rg_log("repo_search: q=$q, masters=$masters..."); | ||
314 | 354 | ||
315 | 355 | $add = ""; | $add = ""; |
316 | 356 | if ($masters == 1) | if ($masters == 1) |
317 | 357 | $add = " AND master = 0"; | $add = " AND master = 0"; |
318 | 358 | ||
319 | $e_q = sql_escape($db, $q); | ||
359 | $e_q = rg_sql_escape($db, $q); | ||
320 | 360 | ||
321 | 361 | $sql = "SELECT * FROM repos" | $sql = "SELECT * FROM repos" |
322 | 362 | . " WHERE deleted = 0" | . " WHERE deleted = 0" |
... | ... | function repo_search($db, $q, $masters) | |
325 | 365 | . " ORDER BY name" | . " ORDER BY name" |
326 | 366 | . " LIMIT 10"; | . " LIMIT 10"; |
327 | 367 | ||
328 | return repo_list_query($db, "", $sql); | ||
368 | return rg_repo_list_query($db, "", $sql); | ||
329 | 369 | } | } |
330 | 370 | ||
331 | 371 | /* | /* |
332 | 372 | * Computes the size of a repository | * Computes the size of a repository |
333 | 373 | */ | */ |
334 | function repo_disk_mb($path) | ||
374 | function rg_repo_disk_mb($path) | ||
335 | 375 | { | { |
336 | xlog("repo_disk_mb: path=$path..."); | ||
376 | rg_log("repo_disk_mb: path=$path..."); | ||
337 | 377 | ||
338 | 378 | // TODO | // TODO |
339 | 379 | ||
... | ... | function repo_disk_mb($path) | |
343 | 383 | /* | /* |
344 | 384 | * Mark a git repo as done | * Mark a git repo as done |
345 | 385 | */ | */ |
346 | function repo_git_done($db, $repo_id) | ||
386 | function rg_repo_git_done($db, $repo_id) | ||
347 | 387 | { | { |
348 | xlog("repo_git_done: repo_id=$repo_id..."); | ||
388 | rg_log("repo_git_done: repo_id=$repo_id..."); | ||
349 | 389 | ||
350 | 390 | $sql = "UPDATE repos SET git_dir_done = 1" | $sql = "UPDATE repos SET git_dir_done = 1" |
351 | 391 | . " WHERE repo_id = $repo_id"; | . " WHERE repo_id = $repo_id"; |
352 | $res = sql_query($db, $sql); | ||
392 | $res = rg_sql_query($db, $sql); | ||
353 | 393 | if ($res === FALSE) { | if ($res === FALSE) { |
354 | gg_repo_set_error("Cannot query (" . sql_error() . ")"); | ||
394 | rg_repo_set_error("Cannot query (" . rg_sql_error() . ")"); | ||
355 | 395 | return FALSE; | return FALSE; |
356 | 396 | } | } |
357 | sql_free_result($res); | ||
397 | rg_sql_free_result($res); | ||
358 | 398 | ||
359 | 399 | return TRUE; | return TRUE; |
360 | 400 | } | } |
... | ... | function repo_git_done($db, $repo_id) | |
365 | 405 | /* | /* |
366 | 406 | * Combine two repo rights strings | * Combine two repo rights strings |
367 | 407 | */ | */ |
368 | function gg_repo_rights_combine($a, $b) | ||
408 | function rg_repo_rights_combine($a, $b) | ||
369 | 409 | { | { |
370 | 410 | $len = strlen($b); | $len = strlen($b); |
371 | 411 | for ($i = 0; $i < $len; $i++) | for ($i = 0; $i < $len; $i++) |
... | ... | function gg_repo_rights_combine($a, $b) | |
378 | 418 | /* | /* |
379 | 419 | * Get rights for a user | * Get rights for a user |
380 | 420 | */ | */ |
381 | function gg_repo_rights_get($db, $ri, $uid) | ||
421 | function rg_repo_rights_get($db, $ri, $uid) | ||
382 | 422 | { | { |
383 | global $gg_repo_rights; | ||
423 | global $rg_repo_rights; | ||
384 | 424 | ||
385 | xlog("gg_repo_rights_get: repo_id=" . $ri['repo_id'] . ", uid=$uid..."); | ||
425 | rg_log("rg_repo_rights_get: repo_id=" . $ri['repo_id'] . ", uid=$uid..."); | ||
386 | 426 | ||
387 | 427 | $ret = array(); | $ret = array(); |
388 | 428 | $ret['ok'] = 0; | $ret['ok'] = 0; |
... | ... | function gg_repo_rights_get($db, $ri, $uid) | |
390 | 430 | $ret['rights'] = ""; | $ret['rights'] = ""; |
391 | 431 | ||
392 | 432 | $repo_id = $ri['repo_id']; | $repo_id = $ri['repo_id']; |
393 | $dr = $ri['default_rights']; | ||
394 | 433 | ||
395 | 434 | // Give all rights to owner | // Give all rights to owner |
435 | $dr = $ri['default_rights']; | ||
396 | 436 | if ($ri['uid'] == $uid) { | if ($ri['uid'] == $uid) { |
397 | foreach ($gg_repo_rights as $letter => $junk) | ||
398 | $dr = gg_repo_rights_combine($dr, $letter); | ||
437 | foreach ($rg_repo_rights as $letter => $junk) | ||
438 | $dr = rg_repo_rights_combine($dr, $letter); | ||
399 | 439 | } | } |
400 | 440 | ||
401 | 441 | $sql = "SELECT rights FROM repo_rights" | $sql = "SELECT rights FROM repo_rights" |
402 | 442 | . " WHERE repo_id = $repo_id" | . " WHERE repo_id = $repo_id" |
403 | 443 | . " AND uid = $uid" | . " AND uid = $uid" |
404 | 444 | . " LIMIT 1"; | . " LIMIT 1"; |
405 | $res = sql_query($db, $sql); | ||
445 | $res = rg_sql_query($db, $sql); | ||
406 | 446 | if ($res === FALSE) { | if ($res === FALSE) { |
407 | gg_repo_set_error("Cannot get info (" . sql_error() . ")!"); | ||
447 | rg_repo_set_error("Cannot get info (" . rg_sql_error() . ")!"); | ||
408 | 448 | return $ret; | return $ret; |
409 | 449 | } | } |
410 | 450 | ||
411 | 451 | $ret['ok'] = 1; | $ret['ok'] = 1; |
412 | $row = sql_fetch_array($res); | ||
413 | sql_free_result($res); | ||
452 | $row = rg_sql_fetch_array($res); | ||
453 | rg_sql_free_result($res); | ||
414 | 454 | if (isset($row['rights'])) { | if (isset($row['rights'])) { |
415 | 455 | $ret['rights'] = $row['rights']; | $ret['rights'] = $row['rights']; |
416 | 456 | $ret['exists'] = 1; | $ret['exists'] = 1; |
417 | 457 | } | } |
418 | 458 | ||
419 | $ret['rights'] = gg_repo_rights_combine($dr, $ret['rights']); | ||
459 | $ret['rights'] = rg_repo_rights_combine($dr, $ret['rights']); | ||
460 | rg_log("\tDEBUG rights=" . $ret['rights']); | ||
420 | 461 | ||
421 | 462 | return $ret; | return $ret; |
422 | 463 | } | } |
... | ... | function gg_repo_rights_get($db, $ri, $uid) | |
424 | 465 | /* | /* |
425 | 466 | * Add rights for a repo | * Add rights for a repo |
426 | 467 | */ | */ |
427 | function gg_repo_rights_set($db, $ri, $uid, $rights) | ||
468 | function rg_repo_rights_set($db, $ri, $uid, $rights) | ||
428 | 469 | { | { |
429 | xlog("gg_repo_rights_set: repo_id=" . $ri['repo_id'] | ||
470 | rg_log("rg_repo_rights_set: repo_id=" . $ri['repo_id'] | ||
430 | 471 | . ", uid=$uid, rights=$rights..."); | . ", uid=$uid, rights=$rights..."); |
431 | 472 | ||
432 | 473 | $repo_id = $ri['repo_id']; | $repo_id = $ri['repo_id']; |
... | ... | function gg_repo_rights_set($db, $ri, $uid, $rights) | |
436 | 477 | . " WHERE repo_id = $repo_id" | . " WHERE repo_id = $repo_id" |
437 | 478 | . " AND uid = $uid"; | . " AND uid = $uid"; |
438 | 479 | } else { | } else { |
439 | $e_rights = sql_escape($db, $rights); | ||
480 | $e_rights = rg_sql_escape($db, $rights); | ||
440 | 481 | ||
441 | $rr = gg_repo_rights_get($db, $ri, $repo_id); | ||
442 | if ($rr === FALSE) | ||
482 | $rr = rg_repo_rights_get($db, $ri, $uid); | ||
483 | if ($rr === FALSE) | ||
443 | 484 | return $rr; | return $rr; |
485 | rg_log("rr: " . print_r($rr, TRUE)); | ||
444 | 486 | ||
445 | 487 | if ($rr['exists'] == 1) { | if ($rr['exists'] == 1) { |
446 | 488 | $sql = "UPDATE repo_rights" | $sql = "UPDATE repo_rights" |
... | ... | function gg_repo_rights_set($db, $ri, $uid, $rights) | |
457 | 499 | } | } |
458 | 500 | } | } |
459 | 501 | ||
460 | $res = sql_query($db, $sql); | ||
502 | $res = rg_sql_query($db, $sql); | ||
461 | 503 | if ($res === FALSE) { | if ($res === FALSE) { |
462 | gg_repo_set_error("Cannot alter rights (" . sql_error() . ")!"); | ||
504 | rg_repo_set_error("Cannot alter rights (" . rg_sql_error() . ")!"); | ||
463 | 505 | return FALSE; | return FALSE; |
464 | 506 | } | } |
465 | sql_free_result($res); | ||
507 | rg_sql_free_result($res); | ||
466 | 508 | ||
467 | 509 | return TRUE; | return TRUE; |
468 | 510 | } | } |
... | ... | function gg_repo_rights_set($db, $ri, $uid, $rights) | |
470 | 512 | /* | /* |
471 | 513 | * List rights for a repo | * List rights for a repo |
472 | 514 | */ | */ |
473 | function gg_repo_rights_list($db, $repo_id) | ||
515 | function rg_repo_rights_list($db, $repo_id, $url) | ||
474 | 516 | { | { |
475 | xlog("gg_repo_rights: repo_id=$repo_id"); | ||
517 | rg_log("rg_repo_rights_list: repo_id=$repo_id url=$url"); | ||
476 | 518 | ||
477 | 519 | $ret = ""; | $ret = ""; |
478 | 520 | ||
479 | 521 | $sql = "SELECT * FROM repo_rights WHERE repo_id = $repo_id"; | $sql = "SELECT * FROM repo_rights WHERE repo_id = $repo_id"; |
480 | $res = sql_query($db, $sql); | ||
522 | $res = rg_sql_query($db, $sql); | ||
481 | 523 | if ($res === FALSE) { | if ($res === FALSE) { |
482 | gg_repo_set_error("Cannot get info (" . sql_error() . ")!"); | ||
524 | rg_repo_set_error("Cannot get info (" . rg_sql_error() . ")!"); | ||
483 | 525 | return FALSE; | return FALSE; |
484 | 526 | } | } |
485 | 527 | ||
... | ... | function gg_repo_rights_list($db, $repo_id) | |
489 | 531 | $ret .= " <th>Rights</th>\n"; | $ret .= " <th>Rights</th>\n"; |
490 | 532 | $ret .= " <th>Operations</th>\n"; | $ret .= " <th>Operations</th>\n"; |
491 | 533 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
492 | while (($row = sql_fetch_array($res))) { | ||
534 | while (($row = rg_sql_fetch_array($res))) { | ||
493 | 535 | $ret .= "<tr>\n"; | $ret .= "<tr>\n"; |
494 | 536 | ||
495 | 537 | $_u = $row['uid']; | $_u = $row['uid']; |
496 | $_ui = user_info($db, $row['uid'], "", ""); | ||
538 | $_ui = rg_user_info($db, $row['uid'], "", ""); | ||
497 | 539 | if ($_ui['exists'] == 1) | if ($_ui['exists'] == 1) |
498 | 540 | $_u = $_ui['user']; | $_u = $_ui['user']; |
499 | 541 | ||
500 | 542 | $ret .= " <td>" . $_u . "</td>\n"; | $ret .= " <td>" . $_u . "</td>\n"; |
501 | 543 | ||
502 | $_r = gg_repo_rights_text($row['rights']); | ||
544 | $_r = rg_repo_rights_text($row['rights']); | ||
503 | 545 | $_r = implode("<br />\n", $_r); | $_r = implode("<br />\n", $_r); |
504 | 546 | $ret .= " <td>" . $_r . "</td>\n"; | $ret .= " <td>" . $_r . "</td>\n"; |
505 | 547 | ||
506 | 548 | // operations | // operations |
507 | // suspend | ||
549 | // remove | ||
508 | 550 | $ret .= " <td>"; | $ret .= " <td>"; |
509 | /*TODO | ||
510 | $_url = $url . "&xuid=" . $row['uid']; | ||
511 | $v = 1; $t = "Suspend"; | ||
512 | if ($row['suspended'] > 0) { | ||
513 | $t = "Unsuspend"; | ||
514 | $v = 0; | ||
515 | } | ||
516 | $ret .= "[<a href=\"$_url&suspend=$v\">$t</a>]"; | ||
517 | // admin | ||
518 | $v = 1; $t = "Admin"; | ||
519 | if ($row['is_admin'] == 1) { | ||
520 | $t = "Remove admin"; | ||
521 | $v = 0; | ||
522 | } | ||
523 | $ret .= "[<a href=\"$_url&admin=$v\">$t</a>]"; | ||
524 | */ | ||
551 | $_url = $url . "&subop=2"; | ||
552 | $v = $row['uid']; | ||
553 | $ret .= "[<a href=\"$_url&remove_uid=$v\">Remove</a>]"; | ||
525 | 554 | $ret .= " </td>"; | $ret .= " </td>"; |
526 | 555 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
527 | 556 | } | } |
528 | 557 | $ret .= "</table>\n"; | $ret .= "</table>\n"; |
529 | sql_free_result($res); | ||
558 | rg_sql_free_result($res); | ||
530 | 559 | ||
531 | 560 | return $ret; | return $ret; |
532 | 561 | } | } |
... | ... | function gg_repo_rights_list($db, $repo_id) | |
534 | 563 | /* | /* |
535 | 564 | * Rights -> form | * Rights -> form |
536 | 565 | */ | */ |
537 | function gg_repo_rights_checkboxes($def_rights) | ||
566 | function rg_repo_rights_checkboxes($def_rights) | ||
538 | 567 | { | { |
539 | global $gg_repo_rights; | ||
568 | global $rg_repo_rights; | ||
540 | 569 | ||
541 | 570 | $ret = ""; | $ret = ""; |
542 | foreach ($gg_repo_rights as $right => $info) { | ||
571 | foreach ($rg_repo_rights as $right => $info) { | ||
543 | 572 | $add = ""; | $add = ""; |
544 | 573 | if (strstr($def_rights, $right)) | if (strstr($def_rights, $right)) |
545 | 574 | $add = " checked"; | $add = " checked"; |
... | ... | function gg_repo_rights_checkboxes($def_rights) | |
553 | 582 | /* | /* |
554 | 583 | * List rights as text | * List rights as text |
555 | 584 | */ | */ |
556 | function gg_repo_rights_text($rights) | ||
585 | function rg_repo_rights_text($rights) | ||
557 | 586 | { | { |
558 | global $gg_repo_rights; | ||
587 | global $rg_repo_rights; | ||
559 | 588 | ||
560 | 589 | $ret = array(); | $ret = array(); |
561 | 590 | ||
... | ... | function gg_repo_rights_text($rights) | |
564 | 593 | return array("None"); | return array("None"); |
565 | 594 | ||
566 | 595 | for ($i = 0; $i < $len; $i++) { | for ($i = 0; $i < $len; $i++) { |
567 | if (isset($gg_repo_rights[$rights[$i]])) | ||
568 | $ret[] = $gg_repo_rights[$rights[$i]]; | ||
596 | if (isset($rg_repo_rights[$rights[$i]])) | ||
597 | $ret[] = $rg_repo_rights[$rights[$i]]; | ||
569 | 598 | else | else |
570 | 599 | $ret[] = "?" . $rights[$i] . "?"; | $ret[] = "?" . $rights[$i] . "?"; |
571 | 600 | } | } |
... | ... | function gg_repo_rights_text($rights) | |
576 | 605 | /* | /* |
577 | 606 | * Transforms rights array into a string | * Transforms rights array into a string |
578 | 607 | */ | */ |
579 | function gg_repo_rights_a2s($a) | ||
608 | function rg_repo_rights_a2s($a) | ||
580 | 609 | { | { |
581 | 610 | $rights = ""; | $rights = ""; |
582 | 611 |
File inc/repo/repo.form.php changed (mode: 100644) (index 7c8e9ff..7ebcd93) | |||
1 | 1 | <?php | <?php |
2 | 2 | ||
3 | 3 | $_form = ' | $_form = ' |
4 | <form type="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
4 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
5 | 5 | <input type="hidden" name="op" value="' . $op . '"> | <input type="hidden" name="op" value="' . $op . '"> |
6 | 6 | <input type="hidden" name="subop" value="' . $subop . '"> | <input type="hidden" name="subop" value="' . $subop . '"> |
7 | 7 | <input type="hidden" name="repo_id" value="' . $repo_id . '"> | <input type="hidden" name="repo_id" value="' . $repo_id . '"> |
... | ... | $_form .= ' | |
44 | 44 | <tr> | <tr> |
45 | 45 | <td>Default rights:</td> | <td>Default rights:</td> |
46 | 46 | <td> | <td> |
47 | ' . gg_repo_rights_checkboxes($rights) . ' | ||
47 | ' . rg_repo_rights_checkboxes($rights) . ' | ||
48 | 48 | </td> | </td> |
49 | 49 | </tr> | </tr> |
50 | 50 |
File inc/repo/repo.php changed (mode: 100644) (index 61e3d2d..8b5d91a) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/repo/repo.php"); | ||
2 | rg_log("/inc/repo/repo.php"); | ||
3 | 3 | ||
4 | if ($gg_uid == 0) { | ||
5 | $_body = "You do not have access here!"; | ||
4 | $_repo = ""; | ||
5 | |||
6 | if ($rg_ui['uid'] == 0) { | ||
7 | $_repo .= "You do not have access here!"; | ||
6 | 8 | return; | return; |
7 | 9 | } | } |
8 | 10 | ||
9 | $subop = @intval($_REQUEST['subop']); | ||
10 | $name = @$_REQUEST['name']; | ||
11 | $max_commit_size = @intval($_REQUEST['max_commit_size']); | ||
12 | $desc = @$_REQUEST['desc']; | ||
13 | $master_repo_id = sprintf("%u", @$_REQUEST['master_repo_id']); | ||
14 | $rights = @$_REQUEST['rights']; | ||
15 | $rights = gg_repo_rights_a2s($rights); | ||
16 | $repo_id = @intval($_REQUEST['repo_id']); | ||
17 | $q = @$_REQUEST['q']; | ||
18 | $masters = @intval($_REQUEST['masters']); | ||
11 | $name = rg_var_str("name"); | ||
12 | $max_commit_size = rg_var_uint("max_commit_size"); | ||
13 | $desc = rg_var_str("desc"); | ||
14 | $master_repo_id = rg_var_uint("master_repo_id"); | ||
15 | $rights = rg_var_str("rights"); | ||
16 | $rights = rg_repo_rights_a2s($rights); | ||
17 | $repo_id = rg_var_uint("repo_id"); | ||
18 | $q = rg_var_str("q"); | ||
19 | $masters = rg_var_uint("masters"); | ||
19 | 20 | ||
20 | 21 | ||
21 | 22 | // menu | // menu |
22 | $_url = $_SERVER['PHP_SELF'] . "?op=$op"; | ||
23 | $_url = rg_re_url($op); | ||
23 | 24 | $_menu = ""; | $_menu = ""; |
24 | 25 | $_menu .= "[<a href=\"$_url&subop=1\">Create</a>]"; | $_menu .= "[<a href=\"$_url&subop=1\">Create</a>]"; |
25 | 26 | $_menu .= " [<a href=\"$_url&subop=2\">List</a>]"; | $_menu .= " [<a href=\"$_url&subop=2\">List</a>]"; |
... | ... | $_body = ""; | |
32 | 33 | switch ($subop) { | switch ($subop) { |
33 | 34 | case 1: // create | case 1: // create |
34 | 35 | if ($doit == 1) { | if ($doit == 1) { |
35 | $_r = repo_create($db, $master_repo_id, $gg_uid, $name, | ||
36 | $_r = rg_repo_create($db, $master_repo_id, $rg_ui, $name, | ||
36 | 37 | $max_commit_size, $desc, $rights); | $max_commit_size, $desc, $rights); |
37 | 38 | if ($_r === FALSE) | if ($_r === FALSE) |
38 | $_body .= gg_repo_error(); | ||
39 | $_body .= rg_repo_error(); | ||
39 | 40 | else | else |
40 | 41 | $_body .= "OK!"; | $_body .= "OK!"; |
41 | 42 | } else { | } else { |
... | ... | case 1: // create | |
46 | 47 | break; | break; |
47 | 48 | ||
48 | 49 | case 2: // list | case 2: // list |
49 | $_body .= repo_list($db, "", $gg_uid); | ||
50 | $_body .= rg_repo_list($db, "", $rg_ui); | ||
50 | 51 | break; | break; |
51 | 52 | ||
52 | 53 | case 3: // search | case 3: // search |
53 | 54 | if ($doit == 1) { | if ($doit == 1) { |
54 | $_body .= repo_search($db, $q, $masters); | ||
55 | $_body .= rg_repo_search($db, $q, $masters); | ||
55 | 56 | } else { | } else { |
56 | 57 | include($INC . "/repo/search.form.php"); | include($INC . "/repo/search.form.php"); |
57 | 58 | $_body .= $_form; | $_body .= $_form; |
... | ... | case 3: // search | |
59 | 60 | break; | break; |
60 | 61 | } | } |
61 | 62 | ||
62 | $_repo = $_menu . $_body; | ||
63 | $_repo .= $_menu . $_body; | ||
63 | 64 | ?> | ?> |
File inc/repo/repo_page.php changed (mode: 100644) (index a7f40ec..9fb21c7) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/repo/repo_page.php"); | ||
3 | |||
4 | $repo_id = @intval($_REQUEST['repo_id']); | ||
5 | |||
6 | $subop = @intval($_REQUEST['subop']); | ||
7 | $name = @$_REQUEST['name']; | ||
8 | $max_commit_size = @intval($_REQUEST['max_commit_size']); | ||
9 | $desc = @$_REQUEST['desc']; | ||
10 | $rights = @$_REQUEST['rights']; | ||
11 | $rights = gg_repo_rights_a2s($rights); | ||
12 | $user = @gg_user_fix($_REQUEST['user']); | ||
2 | rg_log("/inc/repo/repo_page.php"); | ||
3 | |||
4 | $repo = rg_var_str("repo"); | ||
5 | $repo_id = rg_var_uint("repo_id"); | ||
6 | $name = rg_var_str("name"); | ||
7 | $max_commit_size = rg_var_uint("max_commit_size"); | ||
8 | $desc = rg_var_str("desc"); | ||
9 | $rights = @rg_repo_rights_a2s($_REQUEST['rights']); | ||
10 | $user = rg_user_fix(rg_var_str("user")); | ||
13 | 11 | $master_repo_id = 0; | $master_repo_id = 0; |
14 | 12 | ||
15 | 13 | // menu | // menu |
16 | $_url = $_SERVER['PHP_SELF'] . "?op=$op&repo_id=$repo_id"; | ||
14 | $_url = rg_re_repopage($repo_id, $repo); | ||
17 | 15 | $_menu = ""; | $_menu = ""; |
18 | 16 | $_menu .= "[<a href=\"$_url&subop=1\">Edit</a>]"; | $_menu .= "[<a href=\"$_url&subop=1\">Edit</a>]"; |
19 | 17 | $_menu .= " [<a href=\"$_url&subop=2\">Rights</a>]"; | $_menu .= " [<a href=\"$_url&subop=2\">Rights</a>]"; |
... | ... | $_menu .= "<br />\n"; | |
23 | 21 | ||
24 | 22 | $_body = ""; | $_body = ""; |
25 | 23 | ||
26 | $ri = repo_info($db, $repo_id, ""); | ||
24 | $ri = rg_repo_info($db, $repo_id, $repo); | ||
27 | 25 | if (($ri['ok'] != 1) || ($ri['deleted'] == 1)) { | if (($ri['ok'] != 1) || ($ri['deleted'] == 1)) { |
28 | 26 | $_body .= "Invalid repository!"; | $_body .= "Invalid repository!"; |
29 | 27 | // force subop 0 | // force subop 0 |
30 | 28 | $subop = 0; | $subop = 0; |
31 | 29 | } | } |
30 | // we need it in forms | ||
31 | $repo_id = $ri['repo_id']; | ||
32 | 32 | ||
33 | $_body .= "Repo <b>" . $ri['name'] . "</b><br />\n"; | ||
34 | if (!empty($ri['desc'])) | ||
35 | $_body .= "<small>" . $ri['desc'] . "</small><br />\n"; | ||
36 | $_dr = gg_repo_rights_text($ri['default_rights']); | ||
37 | $_body .= "Default rights: " . implode(", ", $_dr) . "<br /><br />\n"; | ||
38 | $_body .= "Maxim commit size: " . gg_1024($ri['max_commit_size']) . "<br />\n"; | ||
39 | $_body .= "<br />\n"; | ||
40 | |||
33 | $show_repo_info = 1; | ||
41 | 34 | switch ($subop) { | switch ($subop) { |
42 | 35 | case 1: // edit | case 1: // edit |
43 | 36 | if ($doit == 1) { | if ($doit == 1) { |
44 | $_r = gg_repo_update($db, $repo_id, $gg_uid, $name, | ||
45 | $max_commit_size, $desc, $rights); | ||
46 | if ($_r === FALSE) | ||
47 | $_body .= gg_repo_error(); | ||
48 | else | ||
37 | while (1) { | ||
38 | if (rg_repo_allow($db, $ri, $rg_ui, "A") === FALSE) { | ||
39 | $_body .= "Not allowed!<br />\n"; | ||
40 | break; | ||
41 | } | ||
42 | |||
43 | $ri['name'] = $name; // TODO: filter name! | ||
44 | $ri['max_commit_size'] = $max_commit_size; | ||
45 | $ri['desc'] = $desc; // TODO: filter | ||
46 | $ri['default_rights'] = $rights; // TODO: filter | ||
47 | $_r = rg_repo_update($db, $ri); | ||
48 | if ($_r === FALSE) { | ||
49 | $_body .= rg_repo_error(); | ||
50 | break; | ||
51 | } | ||
52 | |||
49 | 53 | $_body .= "OK!"; | $_body .= "OK!"; |
54 | break; | ||
55 | } | ||
50 | 56 | } else { | } else { |
51 | 57 | // load variables | // load variables |
52 | 58 | $name = $ri['name']; | $name = $ri['name']; |
... | ... | case 1: // edit | |
61 | 67 | break; | break; |
62 | 68 | ||
63 | 69 | case 2: // rights | case 2: // rights |
64 | $errmsg = ""; | ||
65 | $_errors = 0; | ||
70 | $errmsg = array(); | ||
71 | |||
72 | $remove_uid = rg_var_uint("remove_uid"); | ||
73 | rg_log("\tDEBUG remove_uid=$remove_uid"); | ||
74 | |||
75 | if ($remove_uid + $doit > 0) { | ||
76 | if (rg_repo_allow($db, $ri, $rg_ui, "A") === FALSE) { | ||
77 | $errmsg[] = "Not allowed!"; | ||
78 | // cancel further checking | ||
79 | $doit = 0; | ||
80 | $remove_uid = 0; | ||
81 | } | ||
82 | } | ||
83 | |||
84 | while ($remove_uid > 0) { | ||
85 | $e = rg_repo_rights_set($db, $ri, $remove_uid, ""); | ||
86 | if ($e === FALSE) { | ||
87 | $errmsg[] = rg_repo_error(); | ||
88 | break; | ||
89 | } | ||
90 | |||
91 | break; | ||
92 | } | ||
66 | 93 | ||
67 | 94 | while ($doit == 1) { | while ($doit == 1) { |
68 | 95 | // lookup user | // lookup user |
69 | $_ui = user_info($db, 0, $user, ""); | ||
96 | $_ui = rg_user_info($db, 0, $user, ""); | ||
70 | 97 | if ($_ui['exists'] != 1) { | if ($_ui['exists'] != 1) { |
71 | $errmsg .= "User does not exists!"; | ||
72 | $_errors++; | ||
98 | $errmsg[] = "User <b>$user</b> does not exists!"; | ||
73 | 99 | break; | break; |
74 | 100 | } | } |
75 | 101 | ||
76 | // TODO: Check if user is allowed to give rights | ||
77 | |||
78 | $e = gg_repo_rights_set($db, $ri, $_ui['uid'], $rights); | ||
102 | $e = rg_repo_rights_set($db, $ri, $_ui['uid'], $rights); | ||
79 | 103 | if ($e === FALSE) { | if ($e === FALSE) { |
80 | $errmsg .= gg_repo_error(); | ||
81 | $_errors++; | ||
104 | $errmsg[] = rg_repo_error(); | ||
82 | 105 | break; | break; |
83 | 106 | } | } |
84 | 107 | ||
... | ... | case 2: // rights | |
86 | 109 | } | } |
87 | 110 | ||
88 | 111 | // list rights | // list rights |
89 | $_body .= gg_repo_rights_list($db, $repo_id); | ||
112 | $_url = rg_re_repopage($ri['repo_id'], $ri['name']); | ||
113 | $_body .= rg_repo_rights_list($db, $repo_id, $_url); | ||
90 | 114 | ||
91 | // give rights form | ||
92 | 115 | $_body .= "<br />\n"; | $_body .= "<br />\n"; |
93 | 116 | ||
94 | 117 | include($INC . "/repo/rights.form.php"); | include($INC . "/repo/rights.form.php"); |
95 | 118 | $_body .= $_form; | $_body .= $_form; |
96 | 119 | break; | break; |
97 | 120 | ||
98 | case 3: //delete | ||
99 | $r = gg_repo_delete($db, $repo_id, $gg_uid); | ||
100 | if ($r === FALSE) { | ||
101 | $_body .= "Error: " . gg_repo_error(); | ||
121 | case 3: // delete | ||
122 | $errmsg = array(); | ||
123 | |||
124 | while (1) { | ||
125 | if (rg_repo_allow($db, $ri, $rg_ui, "A") === FALSE) { | ||
126 | $errmsg[] = "Not allowed!"; | ||
127 | break; | ||
128 | } | ||
129 | |||
130 | $r = rg_repo_delete($db, $repo_id, $rg_ui); | ||
131 | if ($r === FALSE) { | ||
132 | $errmsg[] = "Error: " . rg_repo_error(); | ||
133 | break; | ||
134 | } | ||
135 | |||
136 | break; | ||
137 | } | ||
138 | |||
139 | $_err = implode("<br />\n", $errmsg); | ||
140 | if (!empty($_err)) { | ||
141 | $_body .= $_err; | ||
102 | 142 | } else { | } else { |
103 | $_body .= "OK!"; | ||
143 | $_body .= "OK"; | ||
144 | $show_repo_info = 0; | ||
104 | 145 | } | } |
105 | 146 | ||
106 | 147 | break; | break; |
107 | 148 | } | } |
108 | 149 | ||
109 | $_repo = $_menu . $_body; | ||
150 | $_rt = ""; | ||
151 | if ($show_repo_info == 1) { | ||
152 | $_rt = "Repo <b>" . $ri['name'] . "</b><br />\n"; | ||
153 | if (!empty($ri['desc'])) | ||
154 | $_rt .= "<small>" . $ri['desc'] . "</small><br />\n"; | ||
155 | $_rt .= "<br />\n"; | ||
156 | $_dr = rg_repo_rights_text($ri['default_rights']); | ||
157 | $_rt .= "Default rights: " . implode(", ", $_dr) . "<br />\n"; | ||
158 | $_rt .= "Maxim commit size: " . rg_1024($ri['max_commit_size']) . "<br />\n"; | ||
159 | $_rt .= "Git URL: git://" . $_SERVER['HTTP_HOST'] . "/" . $ri['name'] . ".git<br />\n"; | ||
160 | $_rt .= "<br />\n"; | ||
161 | } | ||
162 | |||
163 | $_repo = $_menu . $_rt . $_body; | ||
110 | 164 | ?> | ?> |
File inc/repo/rights.form.php changed (mode: 100644) (index c9d07b5..3b7e7ef) | |||
1 | 1 | <?php | <?php |
2 | 2 | ||
3 | 3 | $_form = ' | $_form = ' |
4 | <font color="red">' . $errmsg . '</font><br /> | ||
5 | <form type="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
4 | <font color="red">' . implode("<br />\n", $errmsg) . '</font><br /> | ||
5 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
6 | 6 | <input type="hidden" name="op" value="' . $op . '"> | <input type="hidden" name="op" value="' . $op . '"> |
7 | 7 | <input type="hidden" name="subop" value="' . $subop . '"> | <input type="hidden" name="subop" value="' . $subop . '"> |
8 | 8 | <input type="hidden" name="repo_id" value="' . $repo_id . '"> | <input type="hidden" name="repo_id" value="' . $repo_id . '"> |
... | ... | $_form = ' | |
19 | 19 | <tr> | <tr> |
20 | 20 | <td>Rights:</td> | <td>Rights:</td> |
21 | 21 | <td> | <td> |
22 | ' . gg_repo_rights_checkboxes($rights) . ' | ||
22 | ' . rg_repo_rights_checkboxes($rights) . ' | ||
23 | 23 | </td> | </td> |
24 | 24 | </tr> | </tr> |
25 | 25 |
File inc/repo/search.form.php changed (mode: 100644) (index 2491cea..cec795a) | |||
1 | 1 | <?php | <?php |
2 | 2 | ||
3 | 3 | $_form = ' | $_form = ' |
4 | <form type="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
4 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
5 | 5 | <input type="hidden" name="op" value="' . $op . '"> | <input type="hidden" name="op" value="' . $op . '"> |
6 | 6 | <input type="hidden" name="subop" value="' . $subop . '"> | <input type="hidden" name="subop" value="' . $subop . '"> |
7 | 7 | <input type="hidden" name="doit" value="1"> | <input type="hidden" name="doit" value="1"> |
File inc/sess.inc.php changed (mode: 100644) (index ef6bff1..81ed5af) | |||
1 | 1 | <?php | <?php |
2 | require_once($INC . "/xlog.inc.php"); | ||
2 | require_once($INC . "/log.inc.php"); | ||
3 | 3 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
4 | 4 | ||
5 | 5 | /* | /* |
6 | 6 | * Add a session | * Add a session |
7 | 7 | */ | */ |
8 | function sess_add($db, $uid, $sid, $session_time) | ||
8 | function rg_sess_add($db, $uid, $sid, $session_time) | ||
9 | 9 | { | { |
10 | xlog("sess_add: uid=$uid, sid=$sid, session_time=$session_time."); | ||
10 | rg_log("sess_add: uid=$uid, sid=$sid, session_time=$session_time."); | ||
11 | 11 | ||
12 | 12 | $ip = @$_SERVER['REMOTE_ADDR']; | $ip = @$_SERVER['REMOTE_ADDR']; |
13 | 13 | $now = time(); | $now = time(); |
... | ... | function sess_add($db, $uid, $sid, $session_time) | |
15 | 15 | $sql = "INSERT INTO sess (sid, uid, expire, session_time, ip)" | $sql = "INSERT INTO sess (sid, uid, expire, session_time, ip)" |
16 | 16 | . " VALUES ('$sid', $uid" | . " VALUES ('$sid', $uid" |
17 | 17 | . ", " . ($now + $session_time) . ", $session_time, '$ip')"; | . ", " . ($now + $session_time) . ", $session_time, '$ip')"; |
18 | $res = sql_query($db, $sql); | ||
18 | $res = rg_sql_query($db, $sql); | ||
19 | 19 | if ($res === FALSE) { | if ($res === FALSE) { |
20 | xlog("\tCannot insert (" . sql_error() . ")!"); | ||
20 | rg_log("\tCannot insert (" . rg_sql_error() . ")!"); | ||
21 | 21 | return FALSE; | return FALSE; |
22 | 22 | } | } |
23 | sql_free_result($res); | ||
23 | rg_sql_free_result($res); | ||
24 | 24 | ||
25 | 25 | return TRUE; | return TRUE; |
26 | 26 | } | } |
... | ... | function sess_add($db, $uid, $sid, $session_time) | |
28 | 28 | /* | /* |
29 | 29 | * Returns if a session is still valid. Will return FALSE or uid | * Returns if a session is still valid. Will return FALSE or uid |
30 | 30 | */ | */ |
31 | function sess_valid($db, $sid) | ||
31 | function rg_sess_valid($db, $sid) | ||
32 | 32 | { | { |
33 | xlog("sess_valid: sid=$sid..."); | ||
33 | rg_log("sess_valid: sid=$sid..."); | ||
34 | 34 | ||
35 | if (empty($sid)) | ||
36 | return FALSE; | ||
37 | |||
38 | $now = time(); | ||
39 | 35 | $uid = FALSE; | $uid = FALSE; |
40 | 36 | ||
41 | $e_sid = sql_escape($db, $sid); | ||
37 | $e_sid = rg_sql_escape($db, $sid); | ||
42 | 38 | ||
43 | 39 | $sql = "SELECT uid, expire FROM sess WHERE sid = '$e_sid'"; | $sql = "SELECT uid, expire FROM sess WHERE sid = '$e_sid'"; |
44 | $res = sql_query($db, $sql); | ||
40 | $res = rg_sql_query($db, $sql); | ||
45 | 41 | if ($res === FALSE) { | if ($res === FALSE) { |
46 | xlog("\tCannot select (" . sql_error() . ")!"); | ||
42 | rg_log("\tCannot select (" . rg_sql_error() . ")!"); | ||
47 | 43 | return FALSE; | return FALSE; |
48 | 44 | } | } |
49 | $row = sql_fetch_array($res); | ||
50 | sql_free_result($res); | ||
45 | $row = rg_sql_fetch_array($res); | ||
46 | rg_sql_free_result($res); | ||
51 | 47 | if (isset($row['uid'])) { | if (isset($row['uid'])) { |
48 | $now = time(); | ||
52 | 49 | if ($row['expire'] >= $now) { | if ($row['expire'] >= $now) { |
53 | 50 | $uid = $row['uid']; | $uid = $row['uid']; |
54 | xlog("\tSession valid, uid=$uid, expire=+" . ($row['expire'] - $now)); | ||
51 | rg_log("\tSession valid, uid=$uid, expire=+" . ($row['expire'] - $now)); | ||
55 | 52 | } else { | } else { |
56 | xlog("\tSession too old (" . ($now - $row['expire']) . "s)"); | ||
53 | rg_log("\tSession too old (" . ($now - $row['expire']) . "s)"); | ||
57 | 54 | } | } |
58 | 55 | } else { | } else { |
59 | xlog("\tSession not found!"); | ||
56 | rg_log("\tSession not found!"); | ||
60 | 57 | } | } |
61 | 58 | ||
62 | 59 | return $uid; | return $uid; |
... | ... | function sess_valid($db, $sid) | |
65 | 62 | /* | /* |
66 | 63 | * Refresh a session | * Refresh a session |
67 | 64 | */ | */ |
68 | function sess_update($db, $sid) | ||
65 | function rg_sess_update($db, $sid) | ||
69 | 66 | { | { |
70 | xlog("sess_update: sid=$sid..."); | ||
67 | rg_log("sess_update: sid=$sid..."); | ||
71 | 68 | ||
72 | $e_sid = sql_escape($db, $sid); | ||
69 | $e_sid = rg_sql_escape($db, $sid); | ||
73 | 70 | ||
74 | 71 | $sql = "UPDATE sess SET expire = " . time() . " + session_time" | $sql = "UPDATE sess SET expire = " . time() . " + session_time" |
75 | 72 | . " WHERE sid = '$e_sid'"; | . " WHERE sid = '$e_sid'"; |
76 | $res = sql_query($db, $sql); | ||
73 | $res = rg_sql_query($db, $sql); | ||
77 | 74 | if ($res === FALSE) { | if ($res === FALSE) { |
78 | xlog("\tCannot update (" . sql_error() . ")!"); | ||
75 | rg_log("\tCannot update (" . rg_sql_error() . ")!"); | ||
79 | 76 | return FALSE; | return FALSE; |
80 | 77 | } | } |
81 | sql_free_result($res); | ||
78 | rg_sql_free_result($res); | ||
82 | 79 | ||
83 | 80 | return TRUE; | return TRUE; |
84 | 81 | } | } |
... | ... | function sess_update($db, $sid) | |
86 | 83 | /* | /* |
87 | 84 | * Destroy session | * Destroy session |
88 | 85 | */ | */ |
89 | function sess_destroy($db, $sid) | ||
86 | function rg_sess_destroy($db, $sid, &$rg_ui) | ||
90 | 87 | { | { |
91 | xlog("sess_destroy: sid=$sid..."); | ||
88 | rg_log("sess_destroy: sid=$sid..."); | ||
92 | 89 | ||
93 | $e_sid = sql_escape($db, $sid); | ||
90 | $e_sid = rg_sql_escape($db, $sid); | ||
94 | 91 | ||
95 | 92 | $sql = "DELETE FROM sess WHERE sid = '$e_sid'"; | $sql = "DELETE FROM sess WHERE sid = '$e_sid'"; |
96 | $res = sql_query($db, $sql); | ||
93 | $res = rg_sql_query($db, $sql); | ||
97 | 94 | if ($res === FALSE) { | if ($res === FALSE) { |
98 | xlog("\tCannot delete (" . sql_error() . ")!"); | ||
95 | rg_log("\tCannot delete (" . rg_sql_error() . ")!"); | ||
99 | 96 | return FALSE; | return FALSE; |
100 | 97 | } | } |
101 | sql_free_result($res); | ||
98 | rg_sql_free_result($res); | ||
99 | |||
100 | $rg_ui = array(); | ||
101 | $rg_ui['uid'] = 0; | ||
102 | $rg_ui['is_admin'] = 0; | ||
102 | 103 | ||
103 | 104 | return TRUE; | return TRUE; |
104 | 105 | } | } |
File inc/state.inc.php changed (mode: 100644) (index 66b2342..6ab5899) | |||
... | ... | require_once($INC . "/db.inc.php"); | |
4 | 4 | /* | /* |
5 | 5 | * Set state | * Set state |
6 | 6 | */ | */ |
7 | function state_set($db, $var, $value) | ||
7 | function rg_state_set($db, $var, $value) | ||
8 | 8 | { | { |
9 | $e_var = sql_escape($db, $var); | ||
10 | $e_value = sql_escape($db, $value); | ||
9 | $e_var = rg_sql_escape($db, $var); | ||
10 | $e_value = rg_sql_escape($db, $value); | ||
11 | 11 | ||
12 | 12 | $sql = "UPDATE state SET value = '$e_value'" | $sql = "UPDATE state SET value = '$e_value'" |
13 | 13 | . " WHERE var = '$e_var'"; | . " WHERE var = '$e_var'"; |
14 | $res = sql_query($db, $sql); | ||
14 | $res = rg_sql_query($db, $sql); | ||
15 | 15 | if ($res === FALSE) | if ($res === FALSE) |
16 | 16 | return FALSE; | return FALSE; |
17 | sql_free_result($res); | ||
17 | rg_sql_free_result($res); | ||
18 | 18 | ||
19 | 19 | return TRUE; | return TRUE; |
20 | 20 | } | } |
... | ... | function state_set($db, $var, $value) | |
22 | 22 | /* | /* |
23 | 23 | * Get state | * Get state |
24 | 24 | */ | */ |
25 | function state_get($db, $var) | ||
25 | function rg_state_get($db, $var) | ||
26 | 26 | { | { |
27 | $e_var = sql_escape($db, $var); | ||
27 | $e_var = rg_sql_escape($db, $var); | ||
28 | 28 | ||
29 | 29 | $sql = "SELECT value FROM state WHERE var = '$e_var'"; | $sql = "SELECT value FROM state WHERE var = '$e_var'"; |
30 | $res = sql_query($db, $sql); | ||
30 | $res = rg_sql_query($db, $sql); | ||
31 | 31 | if ($res === FALSE) | if ($res === FALSE) |
32 | 32 | return FALSE; | return FALSE; |
33 | 33 | ||
34 | $row = sql_fetch_array($res); | ||
34 | $row = rg_sql_fetch_array($res); | ||
35 | 35 | if (!isset($row['value'])) | if (!isset($row['value'])) |
36 | 36 | return FALSE; | return FALSE; |
37 | 37 | ||
38 | sql_free_result($res); | ||
38 | rg_sql_free_result($res); | ||
39 | 39 | ||
40 | 40 | return $row['value']; | return $row['value']; |
41 | 41 | } | } |
File inc/user.inc.php changed (mode: 100644) (index 4fd43cb..eea1ece) | |||
1 | 1 | <?php | <?php |
2 | 2 | require_once($INC . "/util.inc.php"); | require_once($INC . "/util.inc.php"); |
3 | require_once($INC . "/xlog.inc.php"); | ||
3 | require_once($INC . "/log.inc.php"); | ||
4 | 4 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
5 | 5 | require_once($INC . "/sess.inc.php"); | require_once($INC . "/sess.inc.php"); |
6 | 6 | ||
7 | function gg_user_set_error($str) | ||
7 | function rg_user_set_error($str) | ||
8 | 8 | { | { |
9 | global $_gg_user_error; | ||
9 | global $_rg_user_error; | ||
10 | 10 | ||
11 | xlog("\tError: $str"); | ||
12 | $_gg_user_error = $str; | ||
11 | rg_log("\tError: $str"); | ||
12 | $_rg_user_error = $str; | ||
13 | 13 | } | } |
14 | 14 | ||
15 | function gg_user_error() | ||
15 | function rg_user_error() | ||
16 | 16 | { | { |
17 | global $_gg_user_error; | ||
18 | return $_gg_user_error; | ||
17 | global $_rg_user_error; | ||
18 | return $_rg_user_error; | ||
19 | } | ||
20 | |||
21 | /* | ||
22 | * Returns true if the user is ok | ||
23 | */ | ||
24 | function rg_user_ok($user) | ||
25 | { | ||
26 | global $rg_user_allow; | ||
27 | global $rg_user_max_len; | ||
28 | |||
29 | if (rg_chars_allow($user, $rg_user_allow) === FALSE) { | ||
30 | rg_user_set_error("Invalid user name"); | ||
31 | return FALSE; | ||
32 | } | ||
33 | |||
34 | if (strlen($user) > $rg_user_max_len) { | ||
35 | rg_user_set_error("User name too long"); | ||
36 | return FALSE; | ||
37 | } | ||
38 | |||
39 | return TRUE; | ||
19 | 40 | } | } |
20 | 41 | ||
21 | 42 | /* | /* |
22 | 43 | * Add a user | * Add a user |
23 | 44 | */ | */ |
24 | function user_add($db, $user, $pass, $email, $is_admin) | ||
45 | function rg_user_add($db, $user, $pass, $email, $is_admin) | ||
25 | 46 | { | { |
26 | global $gg_session_time; | ||
47 | global $rg_session_time; | ||
27 | 48 | ||
28 | xlog("user_add: user=$user, pass=$pass, email=$email, is_admin=$is_admin..."); | ||
49 | rg_log("user_add: user=$user, pass=$pass, email=$email, is_admin=$is_admin..."); | ||
50 | |||
51 | if (rg_user_ok($user) === FALSE) | ||
52 | return FALSE; | ||
29 | 53 | ||
30 | 54 | $itime = time(); | $itime = time(); |
31 | $e_salt = gg_id(40); | ||
55 | $e_salt = rg_id(40); | ||
32 | 56 | $e_sha1pass = sha1($e_salt . "===" . $pass); | $e_sha1pass = sha1($e_salt . "===" . $pass); |
33 | $session_time = $gg_session_time; | ||
57 | $session_time = $rg_session_time; | ||
34 | 58 | ||
35 | $e_user = sql_escape($db, $user); | ||
36 | $e_email = sql_escape($db, $email); | ||
59 | $e_user = rg_sql_escape($db, $user); | ||
60 | $e_email = rg_sql_escape($db, $email); | ||
37 | 61 | ||
38 | 62 | $sql = "INSERT INTO users (user, salt, pass, email, itime, is_admin, session_time)" | $sql = "INSERT INTO users (user, salt, pass, email, itime, is_admin, session_time)" |
39 | 63 | . " VALUES ('$e_user', '$e_salt', '$e_sha1pass', '$e_email'" | . " VALUES ('$e_user', '$e_salt', '$e_sha1pass', '$e_email'" |
40 | 64 | . ", $itime, $is_admin, $session_time)"; | . ", $itime, $is_admin, $session_time)"; |
41 | $res = sql_query($db, $sql); | ||
65 | $res = rg_sql_query($db, $sql); | ||
42 | 66 | if ($res === FALSE) { | if ($res === FALSE) { |
43 | gg_user_set_error("Cannot insert user (" . sql_error() . ")!"); | ||
67 | rg_user_set_error("Cannot insert user (" . rg_sql_error() . ")!"); | ||
44 | 68 | return FALSE; | return FALSE; |
45 | 69 | } | } |
46 | sql_free_result($res); | ||
70 | rg_sql_free_result($res); | ||
47 | 71 | ||
48 | 72 | return TRUE; | return TRUE; |
49 | 73 | } | } |
... | ... | function user_add($db, $user, $pass, $email, $is_admin) | |
51 | 75 | /* | /* |
52 | 76 | * Delete a user | * Delete a user |
53 | 77 | */ | */ |
54 | function user_remove($db, $uid) | ||
78 | function rg_user_remove($db, $uid) | ||
55 | 79 | { | { |
56 | 80 | $uid = sprintf("%u", $uid); | $uid = sprintf("%u", $uid); |
57 | 81 | ||
58 | 82 | $sql = "DELETE FROM users WHERE uid = $uid"; | $sql = "DELETE FROM users WHERE uid = $uid"; |
59 | $res = sql_query($db, $sql); | ||
83 | $res = rg_sql_query($db, $sql); | ||
60 | 84 | if ($res === FALSE) { | if ($res === FALSE) { |
61 | gg_user_set_error("Cannot remove user $uid (" . sql_error() . ")!"); | ||
85 | rg_user_set_error("Cannot remove user $uid (" . rg_sql_error() . ")!"); | ||
62 | 86 | return FALSE; | return FALSE; |
63 | 87 | } | } |
64 | sql_free_result($res); | ||
88 | rg_sql_free_result($res); | ||
65 | 89 | ||
66 | 90 | return TRUE; | return TRUE; |
67 | 91 | } | } |
68 | 92 | ||
69 | 93 | /* | /* |
70 | * Returns info about a user (by uid or user fields) | ||
94 | * Returns info about a user (by uid, user or e-mail) | ||
71 | 95 | */ | */ |
72 | function user_info($db, $uid, $user, $email) | ||
96 | function rg_user_info($db, $uid, $user, $email) | ||
73 | 97 | { | { |
74 | xlog("user_info: uid=[$uid], user=[$user], email=[$email]..."); | ||
98 | rg_log("user_info: uid=[$uid], user=[$user], email=[$email]..."); | ||
75 | 99 | ||
76 | 100 | $ret = array(); | $ret = array(); |
77 | 101 | $ret['ok'] = 0; | $ret['ok'] = 0; |
78 | 102 | $ret['exists'] = 0; | $ret['exists'] = 0; |
103 | $ret['uid'] = 0; | ||
104 | $ret['is_admin'] = 0; | ||
79 | 105 | ||
80 | 106 | if ($uid > 0) { | if ($uid > 0) { |
81 | 107 | $add = " AND uid = " . sprintf("%u", $uid); | $add = " AND uid = " . sprintf("%u", $uid); |
82 | 108 | } else if (!empty($user)) { | } else if (!empty($user)) { |
83 | $e_user = sql_escape($db, $user); | ||
109 | $e_user = rg_sql_escape($db, $user); | ||
84 | 110 | $add = " AND user = '$e_user'"; | $add = " AND user = '$e_user'"; |
85 | 111 | } else if (!empty($email)) { | } else if (!empty($email)) { |
86 | $e_email = sql_escape($db, $email); | ||
112 | $e_email = rg_sql_escape($db, $email); | ||
87 | 113 | $add = " AND email = '$e_email'"; | $add = " AND email = '$e_email'"; |
88 | 114 | } else { | } else { |
89 | 115 | return FALSE; | return FALSE; |
90 | 116 | } | } |
91 | 117 | ||
92 | 118 | $sql = "SELECT * FROM users WHERE 1 = 1" . $add; | $sql = "SELECT * FROM users WHERE 1 = 1" . $add; |
93 | $res = sql_query($db, $sql); | ||
119 | $res = rg_sql_query($db, $sql); | ||
94 | 120 | if ($res === FALSE) { | if ($res === FALSE) { |
95 | gg_user_set_error("Cannot get info (" . sql_error() . ")!"); | ||
121 | rg_user_set_error("Cannot get info (" . rg_sql_error() . ")!"); | ||
96 | 122 | return $ret; | return $ret; |
97 | 123 | } | } |
98 | 124 | ||
99 | 125 | $ret['ok'] = 1; | $ret['ok'] = 1; |
100 | $row = sql_fetch_array($res); | ||
101 | sql_free_result($res); | ||
126 | $row = rg_sql_fetch_array($res); | ||
127 | rg_sql_free_result($res); | ||
102 | 128 | if (!isset($row['user'])) { | if (!isset($row['user'])) { |
103 | gg_user_set_error("User not found!"); | ||
129 | rg_user_set_error("User not found!"); | ||
104 | 130 | return $ret; | return $ret; |
105 | 131 | } | } |
106 | 132 | ||
107 | 133 | $row['ok'] = 1; | $row['ok'] = 1; |
108 | 134 | $row['exists'] = 1; | $row['exists'] = 1; |
135 | rg_log("\tUser found."); | ||
109 | 136 | return $row; | return $row; |
110 | 137 | } | } |
111 | 138 | ||
112 | 139 | /* | /* |
113 | * Test if login is OK | ||
140 | * Loads rg_ui based on sid, if possible | ||
114 | 141 | */ | */ |
115 | function user_login($db, $sid, &$ui) | ||
142 | function rg_user_login_by_sid($db, $sid, &$rg_ui) | ||
116 | 143 | { | { |
117 | xlog("user_login: sid=$sid..."); | ||
144 | rg_log("user_login_by_sid: sid=$sid..."); | ||
118 | 145 | ||
119 | if (($uid = sess_valid($db, $sid))) { | ||
120 | $ui = user_info($db, $uid, "", ""); | ||
121 | sess_update($db, $sid); | ||
122 | return $uid; | ||
123 | } | ||
146 | // Make sure it is not passed by client | ||
147 | $rg_ui = array(); | ||
148 | $rg_ui['uid'] = 0; | ||
149 | $rg_ui['is_admin'] = 0; | ||
150 | |||
151 | if (empty($sid)) | ||
152 | return FALSE; | ||
124 | 153 | ||
125 | xlog("No sid! Try with user..."); | ||
126 | $user = @$_REQUEST['user']; | ||
127 | $pass = @$_REQUEST['pass']; | ||
128 | if (empty($user) || empty($pass)) | ||
154 | $uid = rg_sess_valid($db, $sid); | ||
155 | if ($uid == 0) | ||
129 | 156 | return FALSE; | return FALSE; |
130 | 157 | ||
131 | $ui = user_info($db, 0, $user, ""); | ||
132 | if ($ui['ok'] == 0) { | ||
133 | gg_user_set_error("Internal error"); | ||
158 | $rg_ui = rg_user_info($db, $uid, "", ""); | ||
159 | if ($rg_ui['exists'] != 1) | ||
160 | rg_user_set_error("Invalid uid!"); | ||
161 | return FALSE; | ||
162 | rg_sess_update($db, $sid); | ||
163 | return TRUE; | ||
164 | } | ||
165 | |||
166 | /* | ||
167 | * Test if login is OK | ||
168 | */ | ||
169 | function rg_user_login_by_user_pass($db, $user, $pass, &$rg_ui) | ||
170 | { | ||
171 | rg_log("user_login: user=$user, pass=$pass..."); | ||
172 | |||
173 | $rg_ui = array(); | ||
174 | $rg_ui['uid'] = 0; | ||
175 | $rg_ui['is_admin'] = 0; | ||
176 | |||
177 | if (empty($user) || empty($pass)) { | ||
178 | rg_user_set_error("Invalid user or pass!"); | ||
134 | 179 | return FALSE; | return FALSE; |
135 | 180 | } | } |
136 | 181 | ||
137 | if ($ui['exists'] == 0) { | ||
138 | gg_user_set_error("Invalid user or pass!"); | ||
182 | $rg_ui = rg_user_info($db, 0, $user, ""); | ||
183 | if ($rg_ui['exists'] != 1) { | ||
184 | rg_user_set_error("Invalid user or pass!"); | ||
139 | 185 | return FALSE; | return FALSE; |
140 | 186 | } | } |
141 | xlog("\tui: " . print_r($ui, TRUE)); | ||
187 | rg_log("\trg_ui: " . print_r($rg_ui, TRUE)); | ||
142 | 188 | ||
143 | $sha1pass = sha1($ui['salt'] . "===" . $pass); | ||
144 | if (strcmp($sha1pass, $ui['pass']) != 0) { | ||
145 | gg_user_set_error("Invalid user or pass!"); | ||
189 | $sha1pass = sha1($rg_ui['salt'] . "===" . $pass); | ||
190 | if (strcmp($sha1pass, $rg_ui['pass']) != 0) { | ||
191 | rg_user_set_error("Invalid user or pass!"); | ||
146 | 192 | return FALSE; | return FALSE; |
147 | 193 | } | } |
148 | 194 | ||
149 | $sid = gg_id(40); | ||
150 | sess_add($db, $ui['uid'], $sid, $ui['session_time']); | ||
195 | $sid = rg_id(40); | ||
196 | rg_sess_add($db, $rg_ui['uid'], $sid, $rg_ui['session_time']); | ||
151 | 197 | setcookie("sid", $sid, 0); | setcookie("sid", $sid, 0); |
152 | 198 | ||
153 | return $ui['uid']; | ||
199 | return TRUE; | ||
154 | 200 | } | } |
155 | 201 | ||
156 | 202 | /* | /* |
157 | 203 | * Suspend an account | * Suspend an account |
158 | 204 | * 1=suspend, 0=unsuspend | * 1=suspend, 0=unsuspend |
159 | 205 | */ | */ |
160 | function user_suspend($db, $uid, $op) | ||
206 | function rg_user_suspend($db, $uid, $op) | ||
161 | 207 | { | { |
162 | xlog("user_suspend: uid=$uid, op=$op"); | ||
208 | rg_log("user_suspend: uid=$uid, op=$op"); | ||
163 | 209 | ||
164 | 210 | $now = time(); | $now = time(); |
165 | 211 | ||
... | ... | function user_suspend($db, $uid, $op) | |
169 | 215 | $v = 0; | $v = 0; |
170 | 216 | ||
171 | 217 | $sql = "UPDATE users SET suspended = $v WHERE uid = $uid"; | $sql = "UPDATE users SET suspended = $v WHERE uid = $uid"; |
172 | $res = sql_query($db, $sql); | ||
218 | $res = rg_sql_query($db, $sql); | ||
173 | 219 | if ($res === FALSE) | if ($res === FALSE) |
174 | 220 | return FALSE; | return FALSE; |
175 | sql_free_result($res); | ||
221 | rg_sql_free_result($res); | ||
176 | 222 | ||
177 | 223 | return TRUE; | return TRUE; |
178 | 224 | } | } |
... | ... | function user_suspend($db, $uid, $op) | |
181 | 227 | * Make/remove admin | * Make/remove admin |
182 | 228 | * 1=make, 0=remove | * 1=make, 0=remove |
183 | 229 | */ | */ |
184 | function user_admin($db, $uid, $op) | ||
230 | function rg_user_admin($db, $uid, $op) | ||
185 | 231 | { | { |
186 | xlog("user_admin: uid=$uid, op=$op"); | ||
232 | rg_log("user_admin: uid=$uid, op=$op"); | ||
187 | 233 | ||
188 | 234 | $now = time(); | $now = time(); |
189 | 235 | ||
190 | 236 | $sql = "UPDATE users SET is_admin = $op WHERE uid = $uid"; | $sql = "UPDATE users SET is_admin = $op WHERE uid = $uid"; |
191 | $res = sql_query($db, $sql); | ||
237 | $res = rg_sql_query($db, $sql); | ||
192 | 238 | if ($res === FALSE) | if ($res === FALSE) |
193 | 239 | return FALSE; | return FALSE; |
194 | sql_free_result($res); | ||
240 | rg_sql_free_result($res); | ||
195 | 241 | ||
196 | 242 | return TRUE; | return TRUE; |
197 | 243 | } | } |
... | ... | function user_admin($db, $uid, $op) | |
199 | 245 | /* | /* |
200 | 246 | * List users | * List users |
201 | 247 | */ | */ |
202 | function user_list($db, $url) | ||
248 | function rg_user_list($db, $url) | ||
203 | 249 | { | { |
204 | xlog("user_list, url=$url..."); | ||
250 | rg_log("user_list, url=$url..."); | ||
205 | 251 | ||
206 | 252 | $ret = ""; | $ret = ""; |
207 | 253 | ||
208 | $xuid = sprintf("%u", @$_REQUEST['xuid']); | ||
254 | $xuid = rg_var_uint("xuid"); | ||
209 | 255 | ||
210 | if (isset($_REQUEST['suspend'])) { | ||
211 | if (!user_suspend($db, $xuid, $_REQUEST['suspend'])) | ||
256 | $suspend = rg_var_uint("suspend"); | ||
257 | if ($suspend == 1) { | ||
258 | if (!rg_user_suspend($db, $xuid, 1)) | ||
212 | 259 | $ret .= "<font color=red>Cannot suspend!</font><br />"; | $ret .= "<font color=red>Cannot suspend!</font><br />"; |
213 | 260 | } | } |
214 | 261 | ||
215 | if (isset($_REQUEST['admin'])) { | ||
216 | if (!user_admin($db, $xuid, $_REQUEST['admin'])) | ||
262 | $unsuspend = rg_var_uint("unsuspend"); | ||
263 | if ($unsuspend == 1) { | ||
264 | if (!rg_user_suspend($db, $xuid, 0)) | ||
265 | $ret .= "<font color=red>Cannot unsuspend!</font><br />"; | ||
266 | } | ||
267 | |||
268 | $make_admin = rg_var_uint("make_admin"); | ||
269 | if ($make_admin == 1) { | ||
270 | if (!rg_user_admin($db, $xuid, 1)) | ||
217 | 271 | $ret .= "<font color=red>Cannot make admin!</font><br />"; | $ret .= "<font color=red>Cannot make admin!</font><br />"; |
218 | 272 | } | } |
219 | 273 | ||
220 | if (isset($_REQUEST['remove'])) { | ||
221 | if (!user_remove($db, $xuid)) | ||
274 | $remove_admin = rg_var_uint("remove_admin"); | ||
275 | if ($remove_admin == 1) { | ||
276 | if (!rg_user_admin($db, $xuid, 0)) | ||
277 | $ret .= "<font color=red>Cannot remove admin!</font><br />"; | ||
278 | } | ||
279 | |||
280 | $remove = rg_var_uint("remove"); | ||
281 | if ($remove > 0) { | ||
282 | if (!rg_user_remove($db, $xuid)) | ||
222 | 283 | $ret .= "<font color=red>Cannot remove!</font><br />"; | $ret .= "<font color=red>Cannot remove!</font><br />"; |
223 | 284 | } | } |
224 | 285 | ||
225 | 286 | $sql = "SELECT * FROM users ORDER BY user"; | $sql = "SELECT * FROM users ORDER BY user"; |
226 | $res = sql_query($db, $sql); | ||
287 | $res = rg_sql_query($db, $sql); | ||
227 | 288 | if ($res === FALSE) { | if ($res === FALSE) { |
228 | gg_user_set_error("Cannot get info (" . sql_error() . ")!"); | ||
289 | rg_user_set_error("Cannot get info (" . rg_sql_error() . ")!"); | ||
229 | 290 | return FALSE; | return FALSE; |
230 | 291 | } | } |
231 | 292 | ||
... | ... | function user_list($db, $url) | |
241 | 302 | $ret .= " <th>Last seen (UTC)</th>\n"; | $ret .= " <th>Last seen (UTC)</th>\n"; |
242 | 303 | $ret .= " <th>Operations</th>\n"; | $ret .= " <th>Operations</th>\n"; |
243 | 304 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
244 | while (($row = sql_fetch_array($res))) { | ||
305 | while (($row = rg_sql_fetch_array($res))) { | ||
245 | 306 | $ret .= "<tr>\n"; | $ret .= "<tr>\n"; |
246 | 307 | $ret .= " <td>" . $row['user'] . "</td>\n"; | $ret .= " <td>" . $row['user'] . "</td>\n"; |
247 | 308 | $ret .= " <td>" . $row['email'] . "</td>\n"; | $ret .= " <td>" . $row['email'] . "</td>\n"; |
... | ... | function user_list($db, $url) | |
249 | 310 | $ret .= " <td>" . gmdate("Y-m-d H:i:s", $row['itime']) . "</td>\n"; | $ret .= " <td>" . gmdate("Y-m-d H:i:s", $row['itime']) . "</td>\n"; |
250 | 311 | $_v = "unlimited"; | $_v = "unlimited"; |
251 | 312 | if ($row['disk_quota_mb'] > 0) | if ($row['disk_quota_mb'] > 0) |
252 | $_v = gg_1024($row['disk_quota_mb']); | ||
313 | $_v = rg_1024($row['disk_quota_mb']); | ||
253 | 314 | $ret .= " <td>" . $_v . "</td>\n"; | $ret .= " <td>" . $_v . "</td>\n"; |
254 | 315 | $ret .= " <td>" . ($row['suspended'] == 0 ? "No" : "Yes") . "</th>\n"; | $ret .= " <td>" . ($row['suspended'] == 0 ? "No" : "Yes") . "</th>\n"; |
255 | 316 | $ret .= " <td>" . $row['session_time'] . "s</td>\n"; | $ret .= " <td>" . $row['session_time'] . "s</td>\n"; |
... | ... | function user_list($db, $url) | |
258 | 319 | // suspend | // suspend |
259 | 320 | $ret .= " <td>"; | $ret .= " <td>"; |
260 | 321 | $_url = $url . "&xuid=" . $row['uid']; | $_url = $url . "&xuid=" . $row['uid']; |
261 | $v = 1; $t = "Suspend"; | ||
322 | $v = "suspend=1"; $t = "Suspend"; | ||
262 | 323 | if ($row['suspended'] > 0) { | if ($row['suspended'] > 0) { |
263 | 324 | $t = "Unsuspend"; | $t = "Unsuspend"; |
264 | $v = 0; | ||
325 | $v = "unsuspend=1"; | ||
265 | 326 | } | } |
266 | $ret .= "[<a href=\"$_url&suspend=$v\">$t</a>]"; | ||
327 | $ret .= "[<a href=\"$_url&$v\">$t</a>]"; | ||
267 | 328 | // admin | // admin |
268 | $v = 1; $t = "Admin"; | ||
329 | $v = "make_admin=1"; $t = "Make admin"; | ||
269 | 330 | if ($row['is_admin'] == 1) { | if ($row['is_admin'] == 1) { |
270 | 331 | $t = "Remove admin"; | $t = "Remove admin"; |
271 | $v = 0; | ||
332 | $v = "remove_admin=1"; | ||
272 | 333 | } | } |
273 | $ret .= "[<a href=\"$_url&admin=$v\">$t</a>]"; | ||
334 | $ret .= "[<a href=\"$_url&$v\">$t</a>]"; | ||
274 | 335 | // remove | // remove |
275 | 336 | if ($row['suspended'] > 0) | if ($row['suspended'] > 0) |
276 | 337 | $ret .= "[<a href=\"$_url&remove=1\">Remove!</a>]"; | $ret .= "[<a href=\"$_url&remove=1\">Remove!</a>]"; |
... | ... | function user_list($db, $url) | |
278 | 339 | $ret .= "</tr>\n"; | $ret .= "</tr>\n"; |
279 | 340 | } | } |
280 | 341 | $ret .= "</table>\n"; | $ret .= "</table>\n"; |
281 | sql_free_result($res); | ||
342 | rg_sql_free_result($res); | ||
282 | 343 | ||
283 | 344 | return $ret; | return $ret; |
284 | 345 | } | } |
... | ... | function user_list($db, $url) | |
286 | 347 | /* | /* |
287 | 348 | * Returns uid by token, if not expired | * Returns uid by token, if not expired |
288 | 349 | */ | */ |
289 | function user_forgot_pass_uid($db, $token) | ||
350 | function rg_user_forgot_pass_uid($db, $token) | ||
290 | 351 | { | { |
291 | 352 | $ret = array(); | $ret = array(); |
292 | 353 | $ret['ok'] = 0; | $ret['ok'] = 0; |
293 | 354 | $ret['uid'] = 0; | $ret['uid'] = 0; |
294 | 355 | ||
295 | xlog("user_forgot_pass_uid: token=$token"); | ||
356 | rg_log("user_forgot_pass_uid: token=$token"); | ||
296 | 357 | ||
297 | 358 | $now = time(); | $now = time(); |
298 | $e_token = sql_escape($db, $token); | ||
359 | $e_token = rg_sql_escape($db, $token); | ||
299 | 360 | ||
300 | 361 | $sql = "SELECT uid FROM forgot_pass" | $sql = "SELECT uid FROM forgot_pass" |
301 | 362 | . " WHERE token = '$e_token'" | . " WHERE token = '$e_token'" |
302 | 363 | . " AND expire > $now"; | . " AND expire > $now"; |
303 | $res = sql_query($db, $sql); | ||
364 | $res = rg_sql_query($db, $sql); | ||
304 | 365 | if ($res === FALSE) | if ($res === FALSE) |
305 | 366 | return $ret; | return $ret; |
306 | 367 | ||
307 | 368 | $ret['ok'] = 1; | $ret['ok'] = 1; |
308 | 369 | ||
309 | $row = sql_fetch_array($res); | ||
310 | sql_free_result($res); | ||
370 | $row = rg_sql_fetch_array($res); | ||
371 | rg_sql_free_result($res); | ||
311 | 372 | if (!isset($row['uid'])) | if (!isset($row['uid'])) |
312 | 373 | return $ret; | return $ret; |
313 | 374 | ||
... | ... | function user_forgot_pass_uid($db, $token) | |
319 | 380 | /* | /* |
320 | 381 | * Reset password function (send mail) | * Reset password function (send mail) |
321 | 382 | */ | */ |
322 | function user_forgot_pass_mail($db, $email) | ||
383 | function rg_user_forgot_pass_mail($db, $email) | ||
323 | 384 | { | { |
324 | xlog("user_forgot_pass_mail: email=$email"); | ||
385 | rg_log("user_forgot_pass_mail: email=$email"); | ||
325 | 386 | ||
326 | 387 | $expire = time() + 24 * 3600; | $expire = time() + 24 * 3600; |
327 | $token = gg_id(40); | ||
388 | $token = rg_id(40); | ||
328 | 389 | ||
329 | $r = user_info($db, 0, "", $email); | ||
390 | $r = rg_user_info($db, 0, "", $email); | ||
330 | 391 | if ($r['ok'] == 0) | if ($r['ok'] == 0) |
331 | 392 | return FALSE; | return FALSE; |
332 | 393 | if ($r['exists'] == 0) | if ($r['exists'] == 0) |
... | ... | function user_forgot_pass_mail($db, $email) | |
336 | 397 | // store token in database | // store token in database |
337 | 398 | $sql = "INSERT INTO forgot_pass (token, uid, expire)" | $sql = "INSERT INTO forgot_pass (token, uid, expire)" |
338 | 399 | . " VALUES ('$token', $uid, $expire)"; | . " VALUES ('$token', $uid, $expire)"; |
339 | $res = sql_query($db, $sql); | ||
400 | $res = rg_sql_query($db, $sql); | ||
340 | 401 | if ($res === FALSE) { | if ($res === FALSE) { |
341 | gg_user_set_error("Cannot query!"); | ||
402 | rg_user_set_error("Cannot query!"); | ||
342 | 403 | return FALSE; | return FALSE; |
343 | 404 | } | } |
344 | sql_free_result($res); | ||
405 | rg_sql_free_result($res); | ||
345 | 406 | ||
346 | 407 | if (!mail($email, "Forgot password", | if (!mail($email, "Forgot password", |
347 | 408 | "Hello!\nIf you want to reset the password, follow:\n" | "Hello!\nIf you want to reset the password, follow:\n" |
348 | 409 | . "http://" . $_SERVER['SERVER_NAME'] . "/" . $_SERVER['PHP_SELF'] . "?op=6&token=$token")) { | . "http://" . $_SERVER['SERVER_NAME'] . "/" . $_SERVER['PHP_SELF'] . "?op=6&token=$token")) { |
349 | gg_user_set_error("Cannot send mail!"); | ||
410 | rg_user_set_error("Cannot send mail!"); | ||
350 | 411 | return FALSE; | return FALSE; |
351 | 412 | } | } |
352 | 413 | ||
... | ... | function user_forgot_pass_mail($db, $email) | |
356 | 417 | /* | /* |
357 | 418 | * After reseting the pass, we have to destroy all 'reset pass' requests | * After reseting the pass, we have to destroy all 'reset pass' requests |
358 | 419 | */ | */ |
359 | function user_forgot_pass_destroy($db, $uid) | ||
420 | function rg_user_forgot_pass_destroy($db, $uid) | ||
360 | 421 | { | { |
361 | xlog("user_forgot_pass_destroy: token=$token"); | ||
422 | rg_log("user_forgot_pass_destroy: token=$token"); | ||
362 | 423 | ||
363 | 424 | $sql = "DELETE FROM forgot_pass WHERE uid = $uid"; | $sql = "DELETE FROM forgot_pass WHERE uid = $uid"; |
364 | $res = sql_query($db, $sql); | ||
425 | $res = rg_sql_query($db, $sql); | ||
365 | 426 | if ($res === FALSE) { | if ($res === FALSE) { |
366 | gg_user_set_error("Cannot query!"); | ||
427 | rg_user_set_error("Cannot query!"); | ||
367 | 428 | return FALSE; | return FALSE; |
368 | 429 | } | } |
369 | sql_free_result($res); | ||
430 | rg_sql_free_result($res); | ||
370 | 431 | ||
371 | 432 | return TRUE; | return TRUE; |
372 | 433 | } | } |
373 | 434 | ||
374 | function user_set_pass($db, $uid, $pass) | ||
435 | function rg_user_set_pass($db, $uid, $pass) | ||
375 | 436 | { | { |
376 | xlog("user_set_pass..."); | ||
437 | rg_log("user_set_pass..."); | ||
377 | 438 | ||
378 | $e_salt = gg_id(40); | ||
439 | $e_salt = rg_id(40); | ||
379 | 440 | $e_sha1pass = sha1($e_salt . "===" . $pass); | $e_sha1pass = sha1($e_salt . "===" . $pass); |
380 | 441 | ||
381 | 442 | $sql = "UPDATE users SET" | $sql = "UPDATE users SET" |
382 | 443 | ." salt = '$e_salt'" | ." salt = '$e_salt'" |
383 | 444 | . ", pass = '$e_sha1pass'" | . ", pass = '$e_sha1pass'" |
384 | 445 | . " WHERE uid = " . $uid; | . " WHERE uid = " . $uid; |
385 | $res = sql_query($db, $sql); | ||
446 | $res = rg_sql_query($db, $sql); | ||
386 | 447 | if ($res === FALSE) | if ($res === FALSE) |
387 | 448 | return FALSE; | return FALSE; |
388 | sql_free_result($res); | ||
449 | rg_sql_free_result($res); | ||
389 | 450 | ||
390 | 451 | return TRUE; | return TRUE; |
391 | 452 | } | } |
392 | 453 | ||
393 | /* | ||
394 | * Remove forbidden chars | ||
395 | */ | ||
396 | function gg_user_fix($user) | ||
397 | { | ||
398 | return preg_replace("/[^A-Za-z0-9_.-]/", "", $user); | ||
399 | } | ||
400 | |||
401 | 454 | ?> | ?> |
File inc/user/forgot.form.php changed (mode: 100644) (index c4b1021..e70b08a) | |||
... | ... | if (!empty($error)) | |
6 | 6 | $_forgot_form .= "<font color=red>$error</font><br />\n"; | $_forgot_form .= "<font color=red>$error</font><br />\n"; |
7 | 7 | ||
8 | 8 | $_forgot_form .= ' | $_forgot_form .= ' |
9 | <form type="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
9 | <form method="post" action="' . $_SERVER['PHP_SELF'] . '"> | ||
10 | 10 | <input type="hidden" name="op" value="' . $op . '"> | <input type="hidden" name="op" value="' . $op . '"> |
11 | <input type="hidden" name="token" value="' . $_REQUEST['token'] . '"> | ||
11 | <input type="hidden" name="token" value="' . rg_var_str("token") . '"> | ||
12 | 12 | <input type="hidden" name="doit" value="1"> | <input type="hidden" name="doit" value="1"> |
13 | 13 | ||
14 | 14 | <table> | <table> |
File inc/user/forgot.php changed (mode: 100644) (index 7138b70..d9aa318) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/user/forgot.php"); | ||
2 | rg_log("/inc/user/forgot.php"); | ||
3 | 3 | ||
4 | $token = @$_REQUEST['token']; | ||
5 | $pass1 = @$_REQUEST['pass1']; | ||
6 | $pass2 = @$_REQUEST['pass2']; | ||
4 | $token = rg_var_str("token"); | ||
5 | $pass1 = rg_var_str("pass1"); | ||
6 | $pass2 = rg_var_str("pass2"); | ||
7 | 7 | ||
8 | 8 | $_forgot = "<br />\n"; | $_forgot = "<br />\n"; |
9 | 9 | ||
... | ... | if ($doit == 1) { | |
22 | 22 | } else { | } else { |
23 | 23 | if (user_set_pass($db, $r['uid'], $pass1)) { | if (user_set_pass($db, $r['uid'], $pass1)) { |
24 | 24 | user_forgot_pass_destroy($db, $r['uid']); | user_forgot_pass_destroy($db, $r['uid']); |
25 | // auto-login | ||
26 | $rg_ui = user_info($db, $r['uid'], "", ""); | ||
25 | 27 | $_forgot .= "OK!"; | $_forgot .= "OK!"; |
26 | 28 | $_hide_form = 1; | $_hide_form = 1; |
27 | 29 | } else { | } else { |
File inc/user/forgot_mail.php changed (mode: 100644) (index 597f7f1..ca8df55) | |||
1 | 1 | <?php | <?php |
2 | xlog("/inc/user/forgot_mail.php"); | ||
2 | rg_log("/inc/user/forgot_mail.php"); | ||
3 | 3 | ||
4 | $email = @$_REQUEST['email']; | ||
4 | $email = rg_var_str("email"); | ||
5 | 5 | ||
6 | 6 | $_forgot = "<br />\n"; | $_forgot = "<br />\n"; |
7 | 7 |
File inc/util.inc.php changed (mode: 100644) (index b2b6d1f..bcb394b) | |||
1 | 1 | <?php | <?php |
2 | 2 | ||
3 | function gg_1024($v) | ||
3 | function rg_1024($v) | ||
4 | 4 | { | { |
5 | 5 | if ($v <= 9999) | if ($v <= 9999) |
6 | 6 | return number_format($v); | return number_format($v); |
... | ... | function gg_1024($v) | |
24 | 24 | /* | /* |
25 | 25 | * Unique ID generator | * Unique ID generator |
26 | 26 | */ | */ |
27 | function gg_id($len) | ||
27 | function rg_id($len) | ||
28 | 28 | { | { |
29 | 29 | $id = ""; | $id = ""; |
30 | 30 | ||
... | ... | function gg_id($len) | |
45 | 45 | /* | /* |
46 | 46 | * XSS protection | * XSS protection |
47 | 47 | */ | */ |
48 | function gg_xss($v) | ||
48 | function rg_xss($v) | ||
49 | 49 | { | { |
50 | 50 | return htmlspecialchars($v, ENT_QUOTES); | return htmlspecialchars($v, ENT_QUOTES); |
51 | 51 | } | } |
52 | 52 | ||
53 | 53 | $_lock = FALSE; | $_lock = FALSE; |
54 | function gg_lock_or_exit($file) | ||
54 | function rg_lock_or_exit($file) | ||
55 | 55 | { | { |
56 | 56 | global $_lock; | global $_lock; |
57 | 57 | ||
58 | 58 | if ($_lock !== FALSE) { | if ($_lock !== FALSE) { |
59 | xlog("\tYou already have a lock on $file! Bad!"); | ||
59 | rg_log("\tYou already have a lock on $file! Bad!"); | ||
60 | 60 | exit(1); | exit(1); |
61 | 61 | } | } |
62 | 62 | ||
63 | 63 | $_lock = @fopen($file, "w"); | $_lock = @fopen($file, "w"); |
64 | 64 | if ($_lock === FALSE) { | if ($_lock === FALSE) { |
65 | xlog("\tCannot open $file!"); | ||
65 | rg_log("\tCannot open $file!"); | ||
66 | 66 | exit(1); | exit(1); |
67 | 67 | } | } |
68 | 68 | ||
... | ... | function gg_lock_or_exit($file) | |
74 | 74 | fwrite($_lock, getmypid() . "\n"); | fwrite($_lock, getmypid() . "\n"); |
75 | 75 | } | } |
76 | 76 | ||
77 | function gg_load() | ||
77 | function rg_load() | ||
78 | 78 | { | { |
79 | 79 | return intval(file_get_contents("/proc/loadavg")); | return intval(file_get_contents("/proc/loadavg")); |
80 | 80 | } | } |
81 | |||
82 | /* | ||
83 | * Builds URLs | ||
84 | */ | ||
85 | function rg_re_url($op) | ||
86 | { | ||
87 | if (isset($_REQUEST['rewrite_engine'])) | ||
88 | return "/+" . $op; | ||
89 | |||
90 | return $_SERVER['PHP_SELF'] . "?op=" . $op; | ||
91 | } | ||
92 | |||
93 | function rg_re_repopage($repo_id, $repo_name) | ||
94 | { | ||
95 | if (isset($_REQUEST['rewrite_engine'])) | ||
96 | return "/" . $repo_name; | ||
97 | |||
98 | return $_SERVER['PHP_SELF'] . "?op=repo&subop=2&repo_id=" . $repo_id; | ||
99 | } | ||
100 | |||
101 | function rg_var_str($name) | ||
102 | { | ||
103 | $ret = ""; | ||
104 | |||
105 | if (isset($_COOKIE[$name])) | ||
106 | $ret = $_COOKIE[$name]; | ||
107 | |||
108 | if (isset($_POST[$name])) | ||
109 | $ret = $_POST[$name]; | ||
110 | |||
111 | if (isset($_GET[$name])) | ||
112 | $ret = $_GET[$name]; | ||
113 | |||
114 | return htmlspecialchars($ret, ENT_QUOTES); | ||
115 | } | ||
116 | |||
117 | function rg_var_int($name) | ||
118 | { | ||
119 | return sprintf("%d", rg_var_str($name)); | ||
120 | } | ||
121 | |||
122 | function rg_var_uint($name) | ||
123 | { | ||
124 | return sprintf("%u", rg_var_str($name)); | ||
125 | } | ||
126 | |||
127 | /* | ||
128 | * Enforce chars in a name. It is used for user and repo. | ||
129 | */ | ||
130 | function rg_chars_allow($name, $allowed_chars) | ||
131 | { | ||
132 | if (preg_match($allowed_chars, $name) === FALSE) | ||
133 | return FALSE; | ||
134 | |||
135 | return TRUE; | ||
136 | } | ||
81 | 137 | ?> | ?> |
File inc/xlog.inc.php deleted (index b2cd414..0000000) | |||
1 | <?php | ||
2 | require_once($INC . "/util.inc.php"); | ||
3 | |||
4 | $_xlog_file = "/tmp/gg.log"; | ||
5 | $_xlog_fd = FALSE; | ||
6 | $_xlog_sid = gg_id(6); | ||
7 | |||
8 | function xlog_set_file($file) | ||
9 | { | ||
10 | global $_xlog_file; | ||
11 | |||
12 | $_xlog_file = $file; | ||
13 | } | ||
14 | |||
15 | function xlog($str) | ||
16 | { | ||
17 | global $_xlog_file; | ||
18 | global $_xlog_fd; | ||
19 | global $_xlog_sid; | ||
20 | |||
21 | if ($_xlog_fd === FALSE) { | ||
22 | $_xlog_fd = @fopen($_xlog_file, "a+"); | ||
23 | if ($_xlog_fd === FALSE) | ||
24 | return; | ||
25 | // write an empty line | ||
26 | fwrite($_xlog_fd, "\n"); | ||
27 | } | ||
28 | |||
29 | $t = gettimeofday(); | ||
30 | $buf = gmdate("Y-m-d H:i:s", $t['sec']) . "." . sprintf("%06d", $t['usec']); | ||
31 | $buf .= " " . $_xlog_sid . " " . $str . "\n"; | ||
32 | |||
33 | fwrite($_xlog_fd, $buf); | ||
34 | } | ||
35 | |||
36 | ?> |
File root/index.php changed (mode: 100644) (index 4c64719..33792ef) | |||
1 | 1 | <?php | <?php |
2 | 2 | error_reporting(E_ALL); | error_reporting(E_ALL); |
3 | //phpinfo(); | ||
3 | 4 | ||
4 | 5 | $_s = microtime(TRUE); | $_s = microtime(TRUE); |
5 | 6 | ||
... | ... | $ROOT = dirname(__FILE__); | |
8 | 9 | ||
9 | 10 | $THEME = $ROOT . "/themes/default"; | $THEME = $ROOT . "/themes/default"; |
10 | 11 | ||
11 | require_once("/etc/gg/config.php"); | ||
12 | require_once($INC . "/xlog.inc.php"); | ||
12 | require_once("/etc/rg/config.php"); | ||
13 | require_once($INC . "/log.inc.php"); | ||
13 | 14 | include_once($INC . "/db.inc.php"); | include_once($INC . "/db.inc.php"); |
14 | 15 | include_once($INC . "/user.inc.php"); | include_once($INC . "/user.inc.php"); |
15 | 16 | include_once($INC . "/repo.inc.php"); | include_once($INC . "/repo.inc.php"); |
16 | 17 | include_once($INC . "/keys.inc.php"); | include_once($INC . "/keys.inc.php"); |
17 | 18 | ||
18 | xlog_set_file("/tmp/gg_web.log"); | ||
19 | rg_log_set_file("/tmp/rg_web.log"); | ||
19 | 20 | ||
20 | $sql_debug = $gg_db_debug; | ||
21 | $rg_sql_debug = $rg_db_debug; | ||
21 | 22 | ||
22 | $op = 0; | ||
23 | if (isset($_REQUEST['op'])) | ||
24 | $op = intval($_REQUEST['op']); | ||
25 | $doit = @intval($_REQUEST['doit']); | ||
26 | $sid = @$_COOKIE['sid']; | ||
27 | if (empty($sid)) | ||
28 | $sid = @$_REQUEST['sid']; | ||
23 | // TODO: make subop and subsubop as strings | ||
24 | $op = rg_var_str("op"); | ||
25 | $subop = rg_var_uint("subop"); | ||
26 | $subsubop = rg_var_uint("subsubop"); | ||
27 | $doit = rg_var_uint("doit"); | ||
28 | $sid = rg_var_str("sid"); | ||
29 | 29 | ||
30 | xlog("IP: " . @$_SERVER['REMOTE_ADDR']); | ||
31 | xlog("_REQUEST: " . print_r($_REQUEST, TRUE)); | ||
32 | xlog("_COOKIE: " . print_r($_COOKIE, TRUE)); | ||
33 | xlog("Start! op=$op, doit=$doit, sid=$sid..."); | ||
30 | rg_log("IP: " . @$_SERVER['REMOTE_ADDR']); | ||
31 | rg_log("_REQUEST: " . trim(print_r($_REQUEST, TRUE))); | ||
32 | rg_log("_COOKIE: " . trim(print_r($_COOKIE, TRUE))); | ||
33 | rg_log("Start! op=$op/$subop/$subsubop, doit=$doit, sid=$sid..."); | ||
34 | 34 | ||
35 | 35 | ||
36 | 36 | $head = ""; | $head = ""; |
... | ... | $head .= "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\"" | |
38 | 38 | . " \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n"; | . " \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">\n"; |
39 | 39 | $head .= "<html xmlns=\"http://www.w3.org/1999/xhtml\">\n"; | $head .= "<html xmlns=\"http://www.w3.org/1999/xhtml\">\n"; |
40 | 40 | $head .= "<head>\n"; | $head .= "<head>\n"; |
41 | $head .= " <title>GG</title>\n"; | ||
41 | $head .= " <title>RocketGit</title>\n"; | ||
42 | 42 | $head .= " <meta content=\"text/html; charset=UTF-8\" http-equiv=\"content-type\" />\n"; | $head .= " <meta content=\"text/html; charset=UTF-8\" http-equiv=\"content-type\" />\n"; |
43 | 43 | $css = preg_replace("/\n/", " ", @file_get_contents($THEME . "/main.css")); | $css = preg_replace("/\n/", " ", @file_get_contents($THEME . "/main.css")); |
44 | 44 | $head .= " <style type=\"text/css\">" . $css . "</style>\n"; | $head .= " <style type=\"text/css\">" . $css . "</style>\n"; |
... | ... | $head .= "<body>\n"; | |
47 | 47 | ||
48 | 48 | ||
49 | 49 | // database connection | // database connection |
50 | $db = sql_open($gg_db); | ||
50 | $db = rg_sql_open($rg_db); | ||
51 | 51 | if ($db === FALSE) | if ($db === FALSE) |
52 | 52 | die("Cannot open database!"); | die("Cannot open database!"); |
53 | 53 | ||
54 | // deal with login | ||
55 | $gg_uid = user_login($db, $sid, $gg_ui); | ||
56 | if (($op == 1) && ($doit == 1) && ($gg_uid > 0)) | ||
57 | $op = 0; | ||
54 | rg_user_login_by_sid($db, $sid, $rg_ui); | ||
55 | rg_log("After login_by_sid, rg_ui=" . print_r($rg_ui, TRUE)); | ||
58 | 56 | ||
59 | // deal with logout | ||
60 | if ($op == 9) { | ||
61 | sess_destroy($db, $sid); | ||
62 | $gg_uid = 0; | ||
63 | $gg_ui = FALSE; | ||
64 | } | ||
57 | $body = ""; | ||
58 | // Chain dispatching | ||
59 | do { | ||
60 | include($INC . "/dispatch/dispatch.php"); | ||
61 | } while (strcmp($op, "") != 0); | ||
65 | 62 | ||
66 | // auto-login user by forgot-pass token | ||
67 | if ($op == 6) { | ||
68 | // TODO | ||
69 | } | ||
63 | $tail = "</body>\n"; | ||
64 | $tail .= "</html>\n"; | ||
70 | 65 | ||
71 | // menu | ||
72 | $url = $_SERVER['PHP_SELF'] . "?a=1"; | ||
73 | $menu = ""; | ||
74 | $menu .= "[<a href=\"$url&op=1\">Login</a>]"; | ||
75 | if (isset($gg_ui['user'])) { | ||
76 | $menu .= " [<a href=\"$url&op=4\">Keys</a>]\n"; | ||
77 | $menu .= " [<a href=\"$url&op=2\">My repositories</a>]\n"; | ||
78 | if ($gg_ui['is_admin'] == 1) | ||
79 | $menu .= " [<a href=\"$url&op=3\">Admin</a>]\n"; | ||
80 | 66 | ||
81 | $menu .= " [<a href=\"$url&op=9\">Logout</a>]\n"; | ||
67 | // menu | ||
68 | $amenu = array( | ||
69 | "login" => array("text" => "Login"), | ||
70 | "repo" => array("text" => "My repositories"), | ||
71 | "keys" => array("text" => "SSH keys"), | ||
72 | "admin" => array("text" => "Admin", "needs_admin" => 1), | ||
73 | "logout" => array("text" => "Logout") | ||
74 | ); | ||
82 | 75 | ||
83 | $menu .= " [" . $gg_ui['user'] . "]\n"; | ||
76 | $menu = ""; | ||
77 | $add = ""; | ||
78 | foreach ($amenu as $_op => $_info) { | ||
79 | if (isset($_info['needs_admin']) && ($rg_ui['is_admin'] == 0)) | ||
80 | continue; | ||
81 | |||
82 | $_text = $_info['text']; | ||
83 | if (strcmp($_op, $op) == 0) { | ||
84 | $menu .= $add . "[$_text]\n"; | ||
85 | } else { | ||
86 | $menu .= $add . "[<a href=\"" | ||
87 | . rg_re_url($_op) . "\">$_text</a>]\n"; | ||
88 | } | ||
89 | $add = " "; | ||
84 | 90 | } | } |
85 | $menu .= "<br />\n"; | ||
86 | |||
87 | 91 | ||
88 | $body = ""; | ||
89 | switch ($op) { | ||
90 | case 1: | ||
91 | include($INC . "/login/login.php"); | ||
92 | $body .= $_login; | ||
93 | break; | ||
94 | |||
95 | case 2: | ||
96 | include($INC . "/repo/repo.php"); | ||
97 | $body .= $_repo; | ||
98 | break; | ||
99 | |||
100 | case 3: | ||
101 | include($INC . "/admin/admin.php"); | ||
102 | $body .= $_admin; | ||
103 | break; | ||
104 | |||
105 | case 4: // keys | ||
106 | include($INC . "/keys/keys.php"); | ||
107 | $body .= $_keys; | ||
108 | break; | ||
109 | |||
110 | case 6: // forgot pass link | ||
111 | include($INC . "/user/forgot.php"); | ||
112 | $body .= $_forgot; | ||
113 | break; | ||
114 | |||
115 | case 7: // forgot pass - send mail | ||
116 | include($INC . "/user/forgot_mail.php"); | ||
117 | $body .= $_forgot; | ||
118 | break; | ||
119 | |||
120 | case 10: // repo page | ||
121 | include($INC . "/repo/repo_page.php"); | ||
122 | $body .= $_repo; | ||
123 | break; | ||
124 | } | ||
92 | if (isset($rg_ui['user'])) | ||
93 | $menu .= " [" . $rg_ui['user'] . "]\n"; | ||
94 | $menu .= "<br />\n"; | ||
125 | 95 | ||
126 | $body .= "</body>\n"; | ||
127 | $body .= "</html>\n"; | ||
128 | 96 | ||
129 | echo $head . $menu . $body; | ||
97 | echo $head . $menu . $body . $tail; | ||
130 | 98 | ||
131 | 99 | $_diff = sprintf("%u", (microtime(TRUE) - $_s) * 1000); | $_diff = sprintf("%u", (microtime(TRUE) - $_s) * 1000); |
132 | xlog("Done in $_diff ms."); | ||
100 | rg_log("Done in $_diff ms."); | ||
133 | 101 | ?> | ?> |
File samples/config.php changed (mode: 100644) (index de5fe71..ca0dee9) | |||
1 | 1 | <?php | <?php |
2 | 2 | // Base | // Base |
3 | $gg_base = "/home/gg"; | ||
3 | $rg_base = "/home/rg"; | ||
4 | 4 | ||
5 | 5 | // Base for repositories | // Base for repositories |
6 | $gg_base_repo = $gg_base . "/repositories"; | ||
6 | $rg_base_repo = $rg_base . "/repositories"; | ||
7 | 7 | ||
8 | 8 | // Database | // Database |
9 | $gg_db = "sqlite:/tmp/gg.sqlite"; | ||
10 | $gg_db_debug = 1; | ||
9 | $rg_db = "sqlite:/tmp/rg.sqlite"; | ||
10 | $rg_db_debug = 1; | ||
11 | 11 | ||
12 | 12 | // Session | // Session |
13 | $gg_session_time = 3600; | ||
13 | $rg_session_time = 3600; | ||
14 | 14 | ||
15 | 15 | // Keys | // Keys |
16 | $gg_keys_file = $gg_base . "/.ssh/authorized_keys"; | ||
16 | $rg_keys_file = $rg_base . "/.ssh/authorized_keys"; | ||
17 | 17 | ||
18 | 18 | // Scripts | // Scripts |
19 | $gg_scripts = "/BIG1T/sync1/Dev/gg/scripts"; | ||
19 | $rg_scripts = "/BIG1T/sync1/Dev/rg/scripts"; | ||
20 | |||
21 | // Allowed repo names (regular expression) | ||
22 | $rg_repo_allow = '/^[^A-Za-z0-9_.-]$/'; | ||
23 | |||
24 | // Allowed repo name length | ||
25 | $rg_repo_max_len = 16; | ||
26 | |||
27 | // Allowed user names (regular expression) | ||
28 | $rg_user_allow = '/^[^A-Za-z0-9_.-]$/'; | ||
29 | |||
30 | // Allowed user name length | ||
31 | $rg_user_max_len = 16; | ||
20 | 32 | ||
21 | 33 | ?> | ?> |
File samples/cron changed (mode: 100644) (index f8ea8c6..a57ca50) | |||
1 | * * * * * gg php /BIG1T/sync1/Dev/gg/scripts/cron.php | ||
2 | * * * * * gg php /BIG1T/sync1/Dev/gg/scripts/q.php | ||
1 | * * * * * rg php /BIG1T/sync1/Dev/rg/scripts/cron.php | ||
2 | * * * * * rg php /BIG1T/sync1/Dev/rg/scripts/q.php |
File samples/rg renamed from samples/gg (similarity 78%) (mode: 100644) (index d8f2712..bff94f3) | |||
... | ... | service git | |
8 | 8 | disable = no | disable = no |
9 | 9 | socket_type = stream | socket_type = stream |
10 | 10 | wait = no | wait = no |
11 | user = gg | ||
11 | user = rg | ||
12 | 12 | server = /usr/bin/php | server = /usr/bin/php |
13 | server_args = /BIG1T/sync1/Dev/gg/scripts/ssh.php | ||
13 | server_args = /BIG1T/sync1/Dev/rg/scripts/ssh.php | ||
14 | 14 | log_on_failure += USERID | log_on_failure += USERID |
15 | 15 | } | } |
File samples/rg.conf added (mode: 100644) (index 0000000..0e3b045) | |||
1 | # This is the apache configuration file for RocketGit | ||
2 | |||
3 | <VirtualHost *:80> | ||
4 | ServerName rg.embedromix.ro | ||
5 | ServerAlias rg | ||
6 | DocumentRoot /BIG1T/sync1/Dev/rg/root/ | ||
7 | |||
8 | <Directory "/BIG1T/sync1/Dev/rg/root"> | ||
9 | AllowOverride All | ||
10 | Order allow,deny | ||
11 | Allow from all | ||
12 | </Directory> | ||
13 | |||
14 | RewriteEngine On | ||
15 | RewriteLog /var/log/httpd/rg-Rewrite.log | ||
16 | RewriteLogLevel 3 | ||
17 | |||
18 | # Allow .ico and 'themes' folder | ||
19 | RewriteCond %{REQUEST_URI} ^/(favicon\.ico|themes) | ||
20 | RewriteRule .* - [L] | ||
21 | |||
22 | # index.php is special | ||
23 | RewriteCond %{REQUEST_URI} ^/index\.php | ||
24 | RewriteRule .* /index.php?rewrite_engine=1 [L,QSA] | ||
25 | |||
26 | RewriteCond %{REQUEST_URI} ^/\+ | ||
27 | RewriteRule ^/\+(.*) /index.php?rewrite_engine=1&op=$1 [L,QSA] | ||
28 | |||
29 | RewriteCond %{REQUEST_URI} ^/.+ | ||
30 | RewriteRule ^/(.+) /index.php?rewrite_engine=1&op=repopage&repo=$1 [L,QSA] | ||
31 | |||
32 | # Compress | ||
33 | AddOutputFilterByType DEFLATE text/html text/plain text/xml text/css text/javascript application/javascript application/x-javascript | ||
34 | DeflateBufferSize 81920 | ||
35 | |||
36 | # Cache at will | ||
37 | <FilesMatch "(?i)^.*\.(ico|flv|jpg|jpeg|png|gif|js|css|swf)$"> | ||
38 | FileETag MTime Size | ||
39 | </FilesMatch> | ||
40 | |||
41 | <IfModule mod_expires.c> | ||
42 | ExpiresActive On | ||
43 | ExpiresByType image/png "access plus 1 day" | ||
44 | ExpiresByType text/css "access plus 1 day" | ||
45 | ExpiresByType text/javascript "access plus 1 day" | ||
46 | ExpiresByType application/javascript "access plus 1 day" | ||
47 | ExpiresByType application/x-javascript "access plus 1 day" | ||
48 | </IfModule> | ||
49 | </VirtualHost> |
File scripts/cron.php changed (mode: 100644) (index 5bd0f77..f98d4cc) | |||
... | ... | ini_set("track_errors", "On"); | |
5 | 5 | ||
6 | 6 | $now = time(); | $now = time(); |
7 | 7 | ||
8 | require_once("/etc/gg/config.php"); | ||
8 | require_once("/etc/rg/config.php"); | ||
9 | 9 | ||
10 | 10 | $INC = dirname(__FILE__) . "/../inc"; | $INC = dirname(__FILE__) . "/../inc"; |
11 | require_once($INC . "/xlog.inc.php"); | ||
11 | require_once($INC . "/log.inc.php"); | ||
12 | 12 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
13 | 13 | require_once($INC . "/repo.inc.php"); | require_once($INC . "/repo.inc.php"); |
14 | 14 | require_once($INC . "/keys.inc.php"); | require_once($INC . "/keys.inc.php"); |
15 | 15 | ||
16 | xlog_set_file("/tmp/gg_cron.log"); | ||
16 | rg_log_set_file("/tmp/rg_cron.log"); | ||
17 | 17 | ||
18 | 18 | // locking | // locking |
19 | $lock = "/var/run/gg/cron.lock"; | ||
20 | gg_lock_or_exit($lock); | ||
19 | $lock = "/var/run/rg/cron.lock"; | ||
20 | rg_lock_or_exit($lock); | ||
21 | 21 | ||
22 | $sql_debug = $gg_db_debug; | ||
22 | $sql_debug = $rg_db_debug; | ||
23 | 23 | ||
24 | xlog("Start: euid=" . posix_geteuid() . "..."); | ||
24 | rg_log("Start: euid=" . posix_geteuid() . "..."); | ||
25 | 25 | ||
26 | $db = sql_open($gg_db); | ||
26 | $db = sql_open($rg_db); | ||
27 | 27 | if ($db === FALSE) { | if ($db === FALSE) { |
28 | xlog("Cannot connect to database!"); | ||
28 | rg_log("Cannot connect to database!"); | ||
29 | 29 | // TODO: inform admin - already by e-mail? | // TODO: inform admin - already by e-mail? |
30 | 30 | exit(1); | exit(1); |
31 | 31 | } | } |
32 | 32 | ||
33 | 33 | if (date("H") == 0) { | if (date("H") == 0) { |
34 | xlog("Compute repository sizes if dirty..."); | ||
34 | rg_log("Compute repository sizes if dirty..."); | ||
35 | 35 | // delete 'dirty' files | // delete 'dirty' files |
36 | 36 | $sql = "SELECT * FROM repos"; | $sql = "SELECT * FROM repos"; |
37 | 37 | $res = sql_query($db, $sql); | $res = sql_query($db, $sql); |
38 | 38 | if ($res === FALSE) { | if ($res === FALSE) { |
39 | xlog("Cannot run query (" . sql_error() . ")!"); | ||
39 | rg_log("Cannot run query (" . rg_sql_error() . ")!"); | ||
40 | 40 | } else { | } else { |
41 | 41 | while (($row = sql_fetch_array($res))) { | while (($row = sql_fetch_array($res))) { |
42 | xlog("Processing repository [" . $row['name'] . "]..."); | ||
42 | rg_log("Processing repository [" . $row['name'] . "]..."); | ||
43 | 43 | $repo_path = repo_id2base($row['repo_id']) . $row['name'] . ".git"; | $repo_path = repo_id2base($row['repo_id']) . $row['name'] . ".git"; |
44 | 44 | $disk_mb = repo_disk_mb($repo_path); | $disk_mb = repo_disk_mb($repo_path); |
45 | 45 | $sql = "UPDATE repos SET disk_mb = $disk_mb" | $sql = "UPDATE repos SET disk_mb = $disk_mb" |
46 | 46 | . " WHERE repo_id = " . $row['repo_id']; | . " WHERE repo_id = " . $row['repo_id']; |
47 | 47 | $res2 = sql_query($db, $sql); | $res2 = sql_query($db, $sql); |
48 | 48 | if ($res2 === FALSE) { | if ($res2 === FALSE) { |
49 | xlog("Cannot run query!"); | ||
49 | rg_log("Cannot run query!"); | ||
50 | 50 | } else { | } else { |
51 | @unlink($repo_path . "/gg/dirty"); | ||
51 | @unlink($repo_path . "/rg/dirty"); | ||
52 | 52 | sql_free_result($res2); | sql_free_result($res2); |
53 | 53 | } | } |
54 | 54 | } | } |
... | ... | if (date("H") == 0) { | |
57 | 57 | } | } |
58 | 58 | ||
59 | 59 | // TODO | // TODO |
60 | //xlog("Update user quota..."); | ||
60 | //rg_log("Update user quota..."); | ||
61 | 61 | ||
62 | 62 | // TODO | // TODO |
63 | //xlog("Sending notifications..."); | ||
63 | //rg_log("Sending notifications..."); | ||
64 | 64 | ||
65 | 65 | if (date("H") == 0) { | if (date("H") == 0) { |
66 | xlog("Clean old forget_pass entries..."); | ||
66 | rg_log("Clean old forget_pass entries..."); | ||
67 | 67 | $sql = "DELETE FROM forgot_pass WHERE expire < $now"; | $sql = "DELETE FROM forgot_pass WHERE expire < $now"; |
68 | 68 | $res = sql_query($db, $sql); | $res = sql_query($db, $sql); |
69 | 69 | sql_free_result($res); | sql_free_result($res); |
70 | 70 | } | } |
71 | 71 | ||
72 | 72 | if (date("H") == 1) { | if (date("H") == 1) { |
73 | xlog("Clean old sess entries..."); | ||
73 | rg_log("Clean old sess entries..."); | ||
74 | 74 | $sql = "DELETE FROM sess WHERE expire < $now"; | $sql = "DELETE FROM sess WHERE expire < $now"; |
75 | 75 | $res = sql_query($db, $sql); | $res = sql_query($db, $sql); |
76 | 76 | sql_free_result($res); | sql_free_result($res); |
77 | 77 | } | } |
78 | 78 | ||
79 | xlog("Regenerate keys..."); | ||
79 | rg_log("Regenerate keys..."); | ||
80 | 80 | keys_regen($db); | keys_regen($db); |
81 | 81 | ||
82 | 82 | // Arhive deleted repositories | // Arhive deleted repositories |
83 | 83 | if (date("H") == 23) { | if (date("H") == 23) { |
84 | //TODO: xlog("Delete repositories..."); | ||
84 | //TODO: rg_log("Delete repositories..."); | ||
85 | 85 | } | } |
86 | 86 | ||
87 | 87 | // this has to be the last thing that touches the database | // this has to be the last thing that touches the database |
88 | 88 | if (date("H") == 0) { | if (date("H") == 0) { |
89 | xlog("Run VACUUM on database..."); | ||
89 | rg_log("Run VACUUM on database..."); | ||
90 | 90 | $sql = "VACUUM"; | $sql = "VACUUM"; |
91 | 91 | $res = sql_query($db, $sql); | $res = sql_query($db, $sql); |
92 | 92 | sql_free_result($res); | sql_free_result($res); |
93 | 93 | ||
94 | xlog("Run ANALYZE on database..."); | ||
94 | rg_log("Run ANALYZE on database..."); | ||
95 | 95 | $sql = "ANALYZE"; | $sql = "ANALYZE"; |
96 | 96 | $res = sql_query($db, $sql); | $res = sql_query($db, $sql); |
97 | 97 | sql_free_result($res); | sql_free_result($res); |
98 | 98 | } | } |
99 | 99 | ||
100 | xlog("Done!"); | ||
100 | rg_log("Done!"); | ||
101 | 101 | ?> | ?> |
File scripts/q.php changed (mode: 100644) (index a8ad2c9..23e6bc8) | |||
... | ... | ini_set("track_errors", "On"); | |
7 | 7 | $now = time(); | $now = time(); |
8 | 8 | $_s = microtime(TRUE); | $_s = microtime(TRUE); |
9 | 9 | ||
10 | require_once("/etc/gg/config.php"); | ||
10 | require_once("/etc/rg/config.php"); | ||
11 | 11 | ||
12 | 12 | $INC = dirname(__FILE__) . "/../inc"; | $INC = dirname(__FILE__) . "/../inc"; |
13 | require_once($INC . "/xlog.inc.php"); | ||
13 | require_once($INC . "/log.inc.php"); | ||
14 | 14 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
15 | 15 | require_once($INC . "/repo.inc.php"); | require_once($INC . "/repo.inc.php"); |
16 | 16 | ||
17 | xlog_set_file("/tmp/gg_q.log"); | ||
17 | rg_log_set_file("/tmp/rg_q.log"); | ||
18 | 18 | ||
19 | 19 | // locking | // locking |
20 | $lock = "/var/run/gg/q.lock"; | ||
21 | gg_lock_or_exit($lock); | ||
20 | $lock = "/var/run/rg/q.lock"; | ||
21 | rg_lock_or_exit($lock); | ||
22 | 22 | ||
23 | $sql_debug = $gg_db_debug; | ||
23 | $rg_sql_debug = $rg_db_debug; | ||
24 | 24 | ||
25 | xlog("Start: euid=" . posix_geteuid() . "..."); | ||
25 | rg_log("Start: euid=" . posix_geteuid() . "..."); | ||
26 | 26 | ||
27 | $db = sql_open($gg_db); | ||
27 | $db = rg_sql_open($rg_db); | ||
28 | 28 | if ($db === FALSE) { | if ($db === FALSE) { |
29 | xlog("Cannot connect to database!"); | ||
29 | rg_log("Cannot connect to database!"); | ||
30 | 30 | // TODO: inform admin - already by e-mail? | // TODO: inform admin - already by e-mail? |
31 | 31 | exit(1); | exit(1); |
32 | 32 | } | } |
... | ... | $runs = 1; | |
37 | 37 | while ($runs-- > 0) { | while ($runs-- > 0) { |
38 | 38 | // check machine load - if too big we will delay | // check machine load - if too big we will delay |
39 | 39 | while (1) { | while (1) { |
40 | $load = gg_load(); | ||
40 | $load = rg_load(); | ||
41 | 41 | if ($load < 10) | if ($load < 10) |
42 | 42 | break; | break; |
43 | 43 | ||
44 | xlog("\tLoad too big!"); | ||
44 | rg_log("\tLoad too big!"); | ||
45 | 45 | sleep(10); | sleep(10); |
46 | 46 | } | } |
47 | 47 | ||
48 | xlog("Check to create not-yet-created repos..."); | ||
48 | rg_log("Check to create not-yet-created repos..."); | ||
49 | 49 | // Ordered by master to create masters first | // Ordered by master to create masters first |
50 | 50 | $sql = "SELECT repo_id, master, name FROM repos" | $sql = "SELECT repo_id, master, name FROM repos" |
51 | 51 | . " WHERE deleted = 0" | . " WHERE deleted = 0" |
52 | 52 | . " AND git_dir_done = 0" | . " AND git_dir_done = 0" |
53 | 53 | . " ORDER BY master"; | . " ORDER BY master"; |
54 | $res = sql_query($db, $sql); | ||
54 | $res = rg_sql_query($db, $sql); | ||
55 | 55 | if ($res === FALSE) { | if ($res === FALSE) { |
56 | xlog("\tCannot query!"); | ||
56 | rg_log("\tCannot query!"); | ||
57 | 57 | exit(1); | exit(1); |
58 | 58 | } | } |
59 | while (($row = sql_fetch_array($res))) { | ||
60 | xlog("\tProcess repo " . $row['name'] . "..."); | ||
59 | while (($row = rg_sql_fetch_array($res))) { | ||
60 | rg_log("\tProcess repo " . $row['name'] . "..."); | ||
61 | 61 | ||
62 | $dst = repo_id2base($row['repo_id']) . $row['name'] . ".git"; | ||
62 | $dst = rg_repo_id2base($row['repo_id']) . $row['name'] . ".git"; | ||
63 | 63 | if ($row['master'] == 0) { | if ($row['master'] == 0) { |
64 | $r = gg_git_init($dst); | ||
64 | $r = rg_git_init($dst); | ||
65 | 65 | if ($r === FALSE) { | if ($r === FALSE) { |
66 | xlog("\tCannot init master!"); | ||
66 | rg_log("\tCannot init master!"); | ||
67 | 67 | } else { | } else { |
68 | repo_git_done($db, $row['repo_id']); | ||
68 | rg_repo_git_done($db, $row['repo_id']); | ||
69 | 69 | } | } |
70 | 70 | } else { | } else { |
71 | $mi = repo_info($db, $row['master'], ""); | ||
71 | $mi = rg_repo_info($db, $row['master'], ""); | ||
72 | 72 | if ($mi['exists'] != 1) { | if ($mi['exists'] != 1) { |
73 | xlog("\tCannot find master!"); | ||
73 | rg_log("\tCannot find master!"); | ||
74 | 74 | } else { | } else { |
75 | $src = repo_id2base($mi['repo_id']) . $mi['name'] . ".git"; | ||
76 | $r = gg_git_clone($src, $dst); | ||
75 | $src = rg_repo_id2base($mi['repo_id']) . $mi['name'] . ".git"; | ||
76 | $r = rg_git_clone($src, $dst); | ||
77 | 77 | if ($r === FALSE) { | if ($r === FALSE) { |
78 | xlog("\tCould not create repo!"); | ||
78 | rg_log("\tCould not create repo!"); | ||
79 | 79 | } else { | } else { |
80 | repo_git_done($db, $row['repo_id']); | ||
80 | rg_repo_git_done($db, $row['repo_id']); | ||
81 | 81 | } | } |
82 | 82 | } | } |
83 | 83 | } | } |
84 | 84 | } | } |
85 | sql_free_result($res); | ||
85 | rg_sql_free_result($res); | ||
86 | 86 | ||
87 | 87 | sleep(10); | sleep(10); |
88 | 88 | } | } |
89 | 89 | ||
90 | 90 | $_diff = sprintf("%u", microtime(TRUE) - $_s); | $_diff = sprintf("%u", microtime(TRUE) - $_s); |
91 | xlog("Done in " . $_diff . "s!"); | ||
91 | rg_log("Done in " . $_diff . "s!"); | ||
92 | 92 | ?> | ?> |
File scripts/ssh.php changed (mode: 100644) (index c5d1555..06ee476) | |||
... | ... | ini_set("track_errors", "On"); | |
5 | 5 | ||
6 | 6 | $_start = microtime(TRUE); | $_start = microtime(TRUE); |
7 | 7 | ||
8 | require_once("/etc/gg/config.php"); | ||
8 | require_once("/etc/rg/config.php"); | ||
9 | 9 | ||
10 | 10 | $INC = dirname(__FILE__) . "/../inc"; | $INC = dirname(__FILE__) . "/../inc"; |
11 | 11 | require_once($INC . "/util.inc.php"); | require_once($INC . "/util.inc.php"); |
12 | require_once($INC . "/xlog.inc.php"); | ||
12 | require_once($INC . "/log.inc.php"); | ||
13 | 13 | require_once($INC . "/db.inc.php"); | require_once($INC . "/db.inc.php"); |
14 | 14 | require_once($INC . "/repo.inc.php"); | require_once($INC . "/repo.inc.php"); |
15 | 15 | ||
16 | $sql_debug = $gg_db_debug; | ||
16 | $rg_sql_debug = $rg_db_debug; | ||
17 | 17 | ||
18 | 18 | function fatal($str) | function fatal($str) |
19 | 19 | { | { |
20 | 20 | global $access_type; | global $access_type; |
21 | 21 | ||
22 | xlog("Sending error: " . $str); | ||
22 | rg_log("Sending error: " . $str); | ||
23 | 23 | $str2 = "FATAL ERROR: " . $str . "\n"; | $str2 = "FATAL ERROR: " . $str . "\n"; |
24 | if ($access_type == 2) { //git | ||
24 | if ($access_type == 2) { // git | ||
25 | 25 | $str3 = "\n" . $str2; | $str3 = "\n" . $str2; |
26 | 26 | $len = strlen($str3) + 4; | $len = strlen($str3) + 4; |
27 | 27 | $str4 = sprintf("%04x", $len) . $str3; | $str4 = sprintf("%04x", $len) . $str3; |
... | ... | function fatal($str) | |
32 | 32 | exit(1); | exit(1); |
33 | 33 | } | } |
34 | 34 | ||
35 | xlog("Start: euid=" . posix_geteuid() . "..."); | ||
36 | //xlog("_SERVER: " . print_r($_SERVER, TRUE)); | ||
35 | rg_log("Start: euid=" . posix_geteuid() . "..."); | ||
36 | //rg_log("_SERVER: " . print_r($_SERVER, TRUE)); | ||
37 | 37 | ||
38 | 38 | umask(0022); | umask(0022); |
39 | 39 | ||
40 | 40 | if (isset($_SERVER['SSH_CONNECTION'])) { | if (isset($_SERVER['SSH_CONNECTION'])) { |
41 | xlog("SSH connection: " . @$_SERVER['SSH_CONNECTION']); | ||
41 | rg_log("SSH connection: " . @$_SERVER['SSH_CONNECTION']); | ||
42 | 42 | $access_type = 1; | $access_type = 1; |
43 | 43 | ||
44 | 44 | // we do not have host info | // we do not have host info |
... | ... | if (isset($_SERVER['SSH_CONNECTION'])) { | |
48 | 48 | $uid = @$_SERVER['argv'][1]; | $uid = @$_SERVER['argv'][1]; |
49 | 49 | if (empty($uid)) | if (empty($uid)) |
50 | 50 | fatal("uid not provided!"); | fatal("uid not provided!"); |
51 | xlog("\tuid is $uid."); | ||
51 | rg_log("\tuid is $uid."); | ||
52 | 52 | ||
53 | 53 | $cmd_repo = trim(@$_SERVER['SSH_ORIGINAL_COMMAND']); | $cmd_repo = trim(@$_SERVER['SSH_ORIGINAL_COMMAND']); |
54 | 54 | if (empty($cmd_repo)) | if (empty($cmd_repo)) |
55 | 55 | fatal("No SSH_ORIGINAL_COMMAND provided!"); | fatal("No SSH_ORIGINAL_COMMAND provided!"); |
56 | 56 | } else { | } else { |
57 | xlog("git-daemon connection..."); | ||
57 | rg_log("git-daemon connection..."); | ||
58 | 58 | $access_type = 2; | $access_type = 2; |
59 | 59 | ||
60 | 60 | // we have no client info | // we have no client info |
... | ... | $repo = trim($repo, "' "); | |
99 | 99 | $repo = ltrim($repo, "/"); | $repo = ltrim($repo, "/"); |
100 | 100 | $repo = preg_replace('/\.git$/' , '', $repo); | $repo = preg_replace('/\.git$/' , '', $repo); |
101 | 101 | ||
102 | xlog("host=[$host] cmd=[$cmd] repo=[$repo] perms=[$perms]."); | ||
102 | rg_log("host=[$host] cmd=[$cmd] repo=[$repo] perms=[$perms]."); | ||
103 | 103 | ||
104 | 104 | // validity/security checks | // validity/security checks |
105 | 105 | if (empty($repo)) | if (empty($repo)) |
... | ... | if (preg_match('/\.\./', $repo)) | |
109 | 109 | if (preg_match('/\//', $repo)) | if (preg_match('/\//', $repo)) |
110 | 110 | fatal("Repo must not contain [/]!"); | fatal("Repo must not contain [/]!"); |
111 | 111 | ||
112 | $db = sql_open($gg_db); | ||
112 | $db = rg_sql_open($rg_db); | ||
113 | 113 | if ($db === FALSE) | if ($db === FALSE) |
114 | 114 | fatal("Internal error (db)!"); | fatal("Internal error (db)!"); |
115 | 115 | ||
116 | 116 | // load info about the repository | // load info about the repository |
117 | $ri = repo_info($db, 0, $repo); | ||
117 | $ri = rg_repo_info($db, 0, $repo); | ||
118 | 118 | if ($ri['ok'] != 1) | if ($ri['ok'] != 1) |
119 | 119 | fatal("Temporary error!"); | fatal("Temporary error!"); |
120 | 120 | if ($ri['exists'] != 1) | if ($ri['exists'] != 1) |
... | ... | if ($ri['exists'] != 1) | |
122 | 122 | if ($ri['deleted'] == 1) | if ($ri['deleted'] == 1) |
123 | 123 | fatal("Repo was deleted!"); | fatal("Repo was deleted!"); |
124 | 124 | ||
125 | if (!repo_allow($db, $ri, $uid, $perms)) | ||
125 | if (!rg_repo_allow($db, $ri, $uid, $perms)) | ||
126 | 126 | fatal("You do not have this type of access to this repository!"); | fatal("You do not have this type of access to this repository!"); |
127 | 127 | ||
128 | 128 | // TODO: limit per connection | // TODO: limit per connection |
129 | 129 | ||
130 | 130 | // TODO: limit time and/or cpu | // TODO: limit time and/or cpu |
131 | 131 | ||
132 | $repo_base = repo_id2base($ri['repo_id']); | ||
132 | $repo_base = rg_repo_id2base($ri['repo_id']); | ||
133 | 133 | $repo_path = $repo_base . $repo . ".git"; | $repo_path = $repo_base . $repo . ".git"; |
134 | xlog("repo_path=$repo_path."); | ||
134 | rg_log("repo_path=$repo_path."); | ||
135 | 135 | ||
136 | 136 | $run = "git-shell -c \"" . $cmd . " '" . escapeshellcmd($repo_path) . "'\""; | $run = "git-shell -c \"" . $cmd . " '" . escapeshellcmd($repo_path) . "'\""; |
137 | xlog("Running [$run]..."); | ||
137 | rg_log("Running [$run]..."); | ||
138 | 138 | passthru($run, $ret); | passthru($run, $ret); |
139 | xlog("[$run] returned $ret."); | ||
139 | rg_log("[$run] returned $ret."); | ||
140 | 140 | ||
141 | 141 | $diff = sprintf("%u", (microtime(TRUE) - $_start) * 1000); | $diff = sprintf("%u", (microtime(TRUE) - $_start) * 1000); |
142 | xlog("Took " . $diff . "ms."); | ||
142 | rg_log("Took " . $diff . "ms."); | ||
143 | 143 | ||
144 | @file_put_contents($repo_path . "/gg/last_access", | ||
144 | @file_put_contents($repo_path . "/rg/last_access", | ||
145 | 145 | "repo: " . $repo . " ($repo_path)" | "repo: " . $repo . " ($repo_path)" |
146 | 146 | . "\nat: " . sprintf("%u", $_start) | . "\nat: " . sprintf("%u", $_start) |
147 | 147 | . "\nuid: " . $uid | . "\nuid: " . $uid |
... | ... | xlog("Took " . $diff . "ms."); | |
151 | 151 | ||
152 | 152 | // Mark repository dirty for disk statistics and other stuff | // Mark repository dirty for disk statistics and other stuff |
153 | 153 | if (strcmp($cmd, "git-receive-pack") == 0) | if (strcmp($cmd, "git-receive-pack") == 0) |
154 | @file_put_contents($gg_path . "/dirty", ""); | ||
154 | @file_put_contents($rg_path . "/dirty", ""); | ||
155 | 155 | ?> | ?> |
File tests/Makefile changed (mode: 100644) (index 7b3aaa8..bd9be3b) | |||
1 | .PHONY: test | ||
2 | test: | ||
1 | tests := util db keys repo | ||
2 | .PHONY: $(tests) | ||
3 | |||
4 | all: $(tests) | ||
5 | |||
6 | util: | ||
3 | 7 | php util.php | php util.php |
8 | |||
9 | db: | ||
4 | 10 | php db.php | php db.php |
11 | |||
12 | keys: | ||
5 | 13 | php keys.php | php keys.php |
14 | |||
15 | repo: | ||
6 | 16 | php repo.php | php repo.php |
File tests/db.php changed (mode: 100644) (index 0ab593c..6f060e6) | |||
... | ... | require_once($INC . "/db.inc.php"); | |
6 | 6 | ||
7 | 7 | @unlink("test.sqlite"); | @unlink("test.sqlite"); |
8 | 8 | ||
9 | $db = sql_open("sqlite:test.sqlite"); | ||
9 | $db = rg_sql_open("sqlite:test.sqlite"); | ||
10 | 10 | if ($db === FALSE) { | if ($db === FALSE) { |
11 | echo "Cannot create a database (" . sql_error() . ")!"; | ||
11 | echo "Cannot create a database (" . rg_sql_error() . ")!"; | ||
12 | 12 | exit(1); | exit(1); |
13 | 13 | } | } |
14 | 14 | ||
15 | 15 | // test creation | // test creation |
16 | 16 | $sql = "CREATE TABLE test (id TEXT PRIMARY KEY)"; | $sql = "CREATE TABLE test (id TEXT PRIMARY KEY)"; |
17 | $res = sql_query($db, $sql); | ||
17 | $res = rg_sql_query($db, $sql); | ||
18 | 18 | if ($res === FALSE) { | if ($res === FALSE) { |
19 | 19 | echo "Cannot create table!"; | echo "Cannot create table!"; |
20 | 20 | exit(1); | exit(1); |
... | ... | if ($res === FALSE) { | |
22 | 22 | ||
23 | 23 | // test insert | // test insert |
24 | 24 | $sql = "INSERT INTO test (id) VALUES ('aaa')"; | $sql = "INSERT INTO test (id) VALUES ('aaa')"; |
25 | $res = sql_query($db, $sql); | ||
25 | $res = rg_sql_query($db, $sql); | ||
26 | 26 | if ($res === FALSE) { | if ($res === FALSE) { |
27 | 27 | echo "Cannot insert!"; | echo "Cannot insert!"; |
28 | 28 | exit(1); | exit(1); |
... | ... | if ($res === FALSE) { | |
30 | 30 | ||
31 | 31 | // test insert with the same key | // test insert with the same key |
32 | 32 | $sql = "INSERT INTO test (id) VALUES ('aaa')"; | $sql = "INSERT INTO test (id) VALUES ('aaa')"; |
33 | $res = @sql_query($db, $sql); | ||
33 | $res = @rg_sql_query($db, $sql); | ||
34 | 34 | if ($res !== FALSE) { | if ($res !== FALSE) { |
35 | 35 | echo "I can do double insert!"; | echo "I can do double insert!"; |
36 | 36 | exit(1); | exit(1); |
... | ... | if ($res !== FALSE) { | |
38 | 38 | ||
39 | 39 | // test delete | // test delete |
40 | 40 | $sql = "DELETE FROM test WHERE id = 'aaa'"; | $sql = "DELETE FROM test WHERE id = 'aaa'"; |
41 | $res = sql_query($db, $sql); | ||
41 | $res = rg_sql_query($db, $sql); | ||
42 | 42 | if ($res === FALSE) { | if ($res === FALSE) { |
43 | 43 | echo "Cannot delete!"; | echo "Cannot delete!"; |
44 | 44 | exit(1); | exit(1); |
45 | 45 | } | } |
46 | 46 | ||
47 | sql_close($db); | ||
47 | rg_sql_close($db); | ||
48 | 48 | ||
49 | 49 | @unlink("test.sqlite"); | @unlink("test.sqlite"); |
50 | 50 | ||
51 | echo "OK!\n"; | ||
51 | 52 | ?> | ?> |
File tests/keys.php changed (mode: 100644) (index d5e9cee..ec7d3db) | |||
... | ... | require_once($INC . "/db/struct.inc.php"); | |
7 | 7 | ||
8 | 8 | @unlink("keys.sqlite"); | @unlink("keys.sqlite"); |
9 | 9 | ||
10 | $db = sql_open("sqlite:keys.sqlite"); | ||
10 | $db = rg_sql_open("sqlite:keys.sqlite"); | ||
11 | 11 | if ($db === FALSE) { | if ($db === FALSE) { |
12 | echo "Cannot create a database (" . sql_error() . ")!"; | ||
12 | echo "Cannot create a database (" . rg_sql_error() . ")!"; | ||
13 | 13 | exit(1); | exit(1); |
14 | 14 | } | } |
15 | 15 | ||
16 | 16 | // state table | // state table |
17 | $r = gg_db_struct_run($db, FALSE); | ||
17 | $r = rg_db_struct_run($db, FALSE); | ||
18 | 18 | if ($r === FALSE) { | if ($r === FALSE) { |
19 | 19 | echo "Cannot create tables!"; | echo "Cannot create tables!"; |
20 | 20 | exit(1); | exit(1); |
21 | 21 | } | } |
22 | 22 | ||
23 | 23 | // insert a key | // insert a key |
24 | $uid = 1; | ||
25 | $key = "aaa'bbb'ccc"; | ||
26 | $key_id = keys_add($db, $uid, $key); | ||
24 | $rg_ui = array("uid" => 1, "is_admin" => 0); | ||
25 | $key = "aaa 'bbb' ccc"; | ||
26 | $key_id = rg_keys_add($db, $rg_ui, $key); | ||
27 | 27 | if ($key_id === FALSE) { | if ($key_id === FALSE) { |
28 | echo "Cannot add key!"; | ||
28 | echo "Cannot add key (" . rg_keys_error() . ")!\n"; | ||
29 | 29 | exit(1); | exit(1); |
30 | 30 | } | } |
31 | 31 | ||
32 | 32 | // delete a key | // delete a key |
33 | $uid = 1; | ||
34 | $key = "aaa'bbb'ccc"; | ||
35 | $r = keys_remove($db, $uid, $key_id); | ||
33 | $rg_ui = array("uid" => 1, "is_admin" => 0); | ||
34 | $r = rg_keys_remove($db, $rg_ui, $key_id); | ||
36 | 35 | if ($r === FALSE) { | if ($r === FALSE) { |
37 | 36 | echo "Cannot remove key (" . keys_error() . ")!"; | echo "Cannot remove key (" . keys_error() . ")!"; |
38 | 37 | exit(1); | exit(1); |
39 | 38 | } | } |
40 | 39 | ||
41 | 40 | // test key file generation | // test key file generation |
42 | $gg_keys_file = "afile.txt"; | ||
43 | $r = keys_regen($db); | ||
41 | $rg_keys_file = "afile.txt"; | ||
42 | $r = rg_keys_regen($db); | ||
44 | 43 | if ($r === FALSE) { | if ($r === FALSE) { |
45 | 44 | echo "Cannot regenerate keys (" . keys_error() . ")!"; | echo "Cannot regenerate keys (" . keys_error() . ")!"; |
46 | 45 | exit(1); | exit(1); |
47 | 46 | } | } |
48 | 47 | @unlink("afile.txt"); | @unlink("afile.txt"); |
49 | 48 | ||
50 | sql_close($db); | ||
49 | rg_sql_close($db); | ||
51 | 50 | ||
52 | 51 | @unlink("keys.sqlite"); | @unlink("keys.sqlite"); |
53 | 52 | ||
53 | echo "OK\n"; | ||
54 | 54 | ?> | ?> |
File tests/repo.php changed (mode: 100644) (index 882e6ec..43b75be) | |||
... | ... | $INC = "../inc"; | |
5 | 5 | require_once($INC . "/repo.inc.php"); | require_once($INC . "/repo.inc.php"); |
6 | 6 | require_once($INC . "/db/struct.inc.php"); | require_once($INC . "/db/struct.inc.php"); |
7 | 7 | ||
8 | xlog_set_file(__FILE__ . ".log"); | ||
8 | rg_log_set_file(__FILE__ . ".log"); | ||
9 | 9 | ||
10 | 10 | @unlink("repo.sqlite"); | @unlink("repo.sqlite"); |
11 | 11 | ||
12 | $db = sql_open("sqlite:repo.sqlite"); | ||
12 | $db = rg_sql_open("sqlite:repo.sqlite"); | ||
13 | 13 | if ($db === FALSE) { | if ($db === FALSE) { |
14 | echo "Cannot create a database (" . sql_error() . ")!\n"; | ||
14 | echo "Cannot create a database (" . rg_sql_error() . ")!\n"; | ||
15 | 15 | exit(1); | exit(1); |
16 | 16 | } | } |
17 | 17 | ||
18 | $r = gg_db_struct_run($db, FALSE); | ||
18 | $r = rg_db_struct_run($db, FALSE); | ||
19 | 19 | if ($r === FALSE) { | if ($r === FALSE) { |
20 | 20 | echo "Cannot create struct!\n"; | echo "Cannot create struct!\n"; |
21 | 21 | exit(1); | exit(1); |
... | ... | $sql = "INSERT INTO repos (repo_id, name, uid, itime" | |
25 | 25 | . ", disk_quota_mb, max_commit_size" | . ", disk_quota_mb, max_commit_size" |
26 | 26 | . ", master, desc, git_dir_done, default_rights)" | . ", master, desc, git_dir_done, default_rights)" |
27 | 27 | . " VALUES (1, 'repo1', 1, 0, 0, 0, 0, 'bla bla desc', 1, '')"; | . " VALUES (1, 'repo1', 1, 0, 0, 0, 0, 'bla bla desc', 1, '')"; |
28 | $res = sql_query($db, $sql); | ||
28 | $res = rg_sql_query($db, $sql); | ||
29 | 29 | if ($res === FALSE) { | if ($res === FALSE) { |
30 | 30 | echo "Cannot insert a user!\n"; | echo "Cannot insert a user!\n"; |
31 | 31 | exit(1); | exit(1); |
32 | 32 | } | } |
33 | 33 | ||
34 | 34 | $repo_id = 1; | $repo_id = 1; |
35 | $ri = repo_info($db, $repo_id, ""); | ||
35 | $ri = rg_repo_info($db, $repo_id, ""); | ||
36 | 36 | $uid = 10; | $uid = 10; |
37 | $v = gg_repo_rights_set($db, $ri, $uid, "F"); | ||
37 | $v = rg_repo_rights_set($db, $ri, $uid, "F"); | ||
38 | 38 | if ($v === FALSE) { | if ($v === FALSE) { |
39 | 39 | echo "Cannot give rights (1)!\n"; | echo "Cannot give rights (1)!\n"; |
40 | 40 | exit(1); | exit(1); |
41 | 41 | } | } |
42 | 42 | ||
43 | @unlink("repo.sqlite"); | ||
44 | |||
43 | 45 | $a = "AF"; $b = "AD"; $e = "AFD"; | $a = "AF"; $b = "AD"; $e = "AFD"; |
44 | $r = gg_repo_rights_combine($a, $b); | ||
46 | $r = rg_repo_rights_combine($a, $b); | ||
45 | 47 | if (strcmp($r, $e) != 0) { | if (strcmp($r, $e) != 0) { |
46 | 48 | echo "Combine rights error1 ([$r] vs [$e])\n"; | echo "Combine rights error1 ([$r] vs [$e])\n"; |
47 | 49 | exit(1); | exit(1); |
48 | 50 | } | } |
49 | 51 | ||
50 | 52 | $a = ""; $b = ""; $e = ""; | $a = ""; $b = ""; $e = ""; |
51 | $r = gg_repo_rights_combine($a, $b); | ||
53 | $r = rg_repo_rights_combine($a, $b); | ||
52 | 54 | if (strcmp($r, $e) != 0) { | if (strcmp($r, $e) != 0) { |
53 | 55 | echo "Combine rights error1 ([$r] vs [$e])\n"; | echo "Combine rights error1 ([$r] vs [$e])\n"; |
54 | 56 | exit(1); | exit(1); |
55 | 57 | } | } |
56 | 58 | ||
57 | 59 | $a = "AXUJUNFUUFU"; $b = ""; $e = $a; | $a = "AXUJUNFUUFU"; $b = ""; $e = $a; |
58 | $r = gg_repo_rights_combine($a, $b); | ||
60 | $r = rg_repo_rights_combine($a, $b); | ||
59 | 61 | if (strcmp($r, $e) != 0) { | if (strcmp($r, $e) != 0) { |
60 | 62 | echo "Combine rights error1 ([$r] vs [$e])\n"; | echo "Combine rights error1 ([$r] vs [$e])\n"; |
61 | 63 | exit(1); | exit(1); |
62 | 64 | } | } |
63 | 65 | ||
64 | @unlink("repo.sqlite"); | ||
66 | // test if repo_allow works correctly | ||
67 | $rg_repo_allow = '/^[^A-Za-z0-9]*$/'; | ||
68 | $v = "eyhtmcmet_"; | ||
69 | $c = rg_repo_ok($v); | ||
70 | if ($c !== FALSE) { | ||
71 | echo "repo_allow problem for '_' ($c).\n"; | ||
72 | exit(1); | ||
73 | } | ||
74 | |||
75 | $rg_repo_allow = '/^[^A-Za-z0-9_.-]*$/'; | ||
76 | $v = ".e&y.h-tmcmet&_.-"; | ||
77 | $c = rg_repo_ok($v); | ||
78 | if ($c !== FALSE) { | ||
79 | echo "repo_allow problem for '&'.\n"; | ||
80 | exit(1); | ||
81 | } | ||
82 | |||
83 | // check if we allow '..' | ||
84 | $rg_repo_allow = '/^[^A-Za-z0-9_.-]*$/'; | ||
85 | $v = "a..b"; | ||
86 | $c = rg_repo_ok($v); | ||
87 | if ($c !== FALSE) { | ||
88 | echo "repo_allow problem for '..'.\n"; | ||
89 | exit(1); | ||
90 | } | ||
91 | |||
92 | // check len | ||
93 | $v = "0123456789A"; | ||
94 | $rg_repo_allow = '/^[^A-Za-z0-9]*$/'; | ||
95 | $rg_repo_max_len = 10; | ||
96 | $c = rg_repo_ok($v); | ||
97 | if ($c !== FALSE) { | ||
98 | echo "repo_ok: max length is not enforced!\n"; | ||
99 | exit(1); | ||
100 | } | ||
101 | |||
102 | echo "OK\n"; | ||
65 | 103 | ?> | ?> |
File tests/user.php changed (mode: 100644) (index ce01c95..da193d8) | |||
... | ... | require_once($INC . "/db/struct.inc.php"); | |
7 | 7 | ||
8 | 8 | @unlink("user.sqlite"); | @unlink("user.sqlite"); |
9 | 9 | ||
10 | $db = sql_open("sqlite:user.sqlite"); | ||
10 | $db = rg_sql_open("sqlite:user.sqlite"); | ||
11 | 11 | if ($db === FALSE) { | if ($db === FALSE) { |
12 | echo "Cannot create a database (" . sql_error() . ")!"; | ||
12 | echo "Cannot create a database (" . rg_sql_error() . ")!"; | ||
13 | 13 | exit(1); | exit(1); |
14 | 14 | } | } |
15 | 15 | ||
16 | $r = gg_db_struct_run($db, FALSE); | ||
16 | $r = rg_db_struct_run($db, FALSE); | ||
17 | 17 | if ($r === FALSE) { | if ($r === FALSE) { |
18 | 18 | echo "Cannot create structure!"; | echo "Cannot create structure!"; |
19 | 19 | exit(1); | exit(1); |
20 | 20 | } | } |
21 | 21 | ||
22 | $sql = "INSERT INTO users VALUES ('gg@localhost', '', 0)"; | ||
23 | $res = sql_query($db, $sql); | ||
22 | $sql = "INSERT INTO users VALUES ('rg@localhost', '', 0)"; | ||
23 | $res = rg_sql_query($db, $sql); | ||
24 | 24 | if ($res === FALSE) { | if ($res === FALSE) { |
25 | 25 | echo "Cannot insert a user!"; | echo "Cannot insert a user!"; |
26 | 26 | exit(1); | exit(1); |
27 | 27 | } | } |
28 | 28 | ||
29 | $v = user_forgot_pass_mail($db, "gg@localhost"); | ||
29 | $v = rg_user_forgot_pass_mail($db, "rg@localhost"); | ||
30 | 30 | if ($v === FALSE) { | if ($v === FALSE) { |
31 | 31 | echo "Error: " . user_error() . "!\n"; | echo "Error: " . user_error() . "!\n"; |
32 | 32 | exit(1); | exit(1); |
33 | 33 | } | } |
34 | 34 | ||
35 | 35 | @unlink("user.sqlite"); | @unlink("user.sqlite"); |
36 | |||
37 | echo "OK\n"; | ||
36 | 38 | ?> | ?> |
File tests/util.php changed (mode: 100644) (index bbbbba8..070f43a) | |||
... | ... | error_reporting(E_ALL | E_STRICT); | |
4 | 4 | $INC = "../inc"; | $INC = "../inc"; |
5 | 5 | require_once($INC . "/util.inc.php"); | require_once($INC . "/util.inc.php"); |
6 | 6 | ||
7 | $id = gg_id(16); | ||
7 | $id = rg_id(16); | ||
8 | 8 | if (strlen($id) != 16) { | if (strlen($id) != 16) { |
9 | 9 | echo "Cannot generate an id!\n"; | echo "Cannot generate an id!\n"; |
10 | 10 | exit(1); | exit(1); |
11 | 11 | } | } |
12 | |||
13 | echo "OK\n"; | ||
12 | 14 | ?> | ?> |