File inc/personal/personal.php deleted (index 6c62b95..0000000) |
1 |
|
<?php |
|
2 |
|
rg_log("/inc/personal/personal"); |
|
3 |
|
|
|
4 |
|
$_personal = ""; |
|
5 |
|
|
|
6 |
|
if ($rg_ui['uid'] == 0) { |
|
7 |
|
$_personal .= "You do not have access here!"; |
|
8 |
|
return; |
|
9 |
|
} |
|
10 |
|
|
|
11 |
|
// menu |
|
12 |
|
$second_menu = array( |
|
13 |
|
"edit_info" => array( |
|
14 |
|
"text" => "Edit info", |
|
15 |
|
"url" => "&subop=1" |
|
16 |
|
), |
|
17 |
|
"change_pass" => array( |
|
18 |
|
"text" => "Change password", |
|
19 |
|
"url" => "&subop=2" |
|
20 |
|
) |
|
21 |
|
); |
|
22 |
|
|
|
23 |
|
$errmsg = array(); |
|
24 |
|
$_body = ""; |
|
25 |
|
|
|
26 |
|
switch ($subop) { |
|
27 |
|
case 1: // edit info |
|
28 |
|
$uid = $rg_ui['uid']; |
|
29 |
|
|
|
30 |
|
if ($doit == 1) { |
|
31 |
|
// TODO: Check if user has the right to edit this info! |
|
32 |
|
if (!rg_token_valid($db, $sid, $token)) { |
|
33 |
|
$_body .= "Invalid token. Try again."; |
|
34 |
|
return; |
|
35 |
|
} |
|
36 |
|
|
|
37 |
|
$xuser = rg_var_str("xuser"); |
|
38 |
|
$email = rg_var_str("email"); |
|
39 |
|
$is_admin = $rg_ui['is_admin']; // TODO: doesn't seems too elegant |
|
40 |
|
$disk_quota_mb = $rg_ui['disk_quota_mb']; |
|
41 |
|
$rights = $rg_ui['rights']; |
|
42 |
|
$session_time = rg_var_uint("session_time"); |
|
43 |
|
|
|
44 |
|
while (1) { |
|
45 |
|
$xpass = ""; |
|
46 |
|
if (!rg_user_edit($db, $rg_ui['uid'], $xuser, $email, $xpass, |
|
47 |
|
$is_admin, $disk_quota_mb, $rights, $session_time, "")) { |
|
48 |
|
$errmsg[] = "Cannot change info (" . rg_user_error() . ")."; |
|
49 |
|
break; |
|
50 |
|
} |
|
51 |
|
|
|
52 |
|
$_body .= "OK!<br />"; |
|
53 |
|
break; |
|
54 |
|
} |
|
55 |
|
} else { |
|
56 |
|
$xuser = $rg_ui['username']; |
|
57 |
|
$email = $rg_ui['email']; |
|
58 |
|
$is_admin = $rg_ui['is_admin']; |
|
59 |
|
$disk_quota_mb = $rg_ui['disk_quota_mb']; |
|
60 |
|
$rights = $rg_ui['rights']; |
|
61 |
|
$session_time = $rg_ui['session_time']; |
|
62 |
|
} |
|
63 |
|
|
|
64 |
|
$admin_mode = 0; |
|
65 |
|
$pass_mode = 0; |
|
66 |
|
include($INC . "/admin/users/user.form.php"); |
|
67 |
|
$_body .= $_form; |
|
68 |
|
break; |
|
69 |
|
|
|
70 |
|
case 2: // change password |
|
71 |
|
$show_form = 1; |
|
72 |
|
if ($doit == 1) { |
|
73 |
|
$old_pass = rg_var_str("old_pass"); |
|
74 |
|
$pass1 = rg_var_str("pass1"); |
|
75 |
|
$pass2 = rg_var_str("pass2"); |
|
76 |
|
|
|
77 |
|
while (1) { |
|
78 |
|
if (!rg_token_valid($db, $sid, $token)) { |
|
79 |
|
$errmsg[] = "Invalid token. Try again."; |
|
80 |
|
break; |
|
81 |
|
} |
|
82 |
|
|
|
83 |
|
if (strcmp($pass1, $pass2) != 0) { |
|
84 |
|
$errmsg[] = "Passwords does not match!"; |
|
85 |
|
break; |
|
86 |
|
} |
|
87 |
|
|
|
88 |
|
if (!rg_user_pass_valid($db, $rg_ui['uid'], $old_pass)) { |
|
89 |
|
$errmsg[] = "Old password is invalid!"; |
|
90 |
|
break; |
|
91 |
|
} |
|
92 |
|
|
|
93 |
|
if (!rg_user_set_pass($db, $rg_ui['uid'], $pass1)) { |
|
94 |
|
$errmsg[] = rg_user_error(); |
|
95 |
|
break; |
|
96 |
|
} |
|
97 |
|
|
|
98 |
|
$_body .= "OK!<br />"; |
|
99 |
|
$show_form = 0; |
|
100 |
|
break; |
|
101 |
|
} |
|
102 |
|
} |
|
103 |
|
|
|
104 |
|
if ($show_form == 1) { |
|
105 |
|
include($INC . "/personal/pass.form.php"); |
|
106 |
|
$_body .= $_chpass_form; |
|
107 |
|
} |
|
108 |
|
|
|
109 |
|
break; |
|
110 |
|
} |
|
111 |
|
|
|
112 |
|
$_personal .= $_body; |
|
113 |
|
?> |
|
File inc/user/home-page.php added (mode: 100644) (index 0000000..363b011) |
|
1 |
|
<?php |
|
2 |
|
rg_log("/inc/user/home-page"); |
|
3 |
|
|
|
4 |
|
$user = rg_var_str("user"); |
|
5 |
|
|
|
6 |
|
$_home = ""; |
|
7 |
|
|
|
8 |
|
$ui = rg_user_info($db, 0, $user, ""); |
|
9 |
|
if ($ui === FALSE) { |
|
10 |
|
$_home .= "Invalid user!"; |
|
11 |
|
return; |
|
12 |
|
} |
|
13 |
|
|
|
14 |
|
// menu |
|
15 |
|
if ($ui['uid'] == $rg_ui['uid']) { |
|
16 |
|
$second_menu = array( |
|
17 |
|
"edit_info" => array( |
|
18 |
|
"text" => "Edit info", |
|
19 |
|
"url" => "&subop=edit_info" |
|
20 |
|
), |
|
21 |
|
"change_pass" => array( |
|
22 |
|
"text" => "Change password", |
|
23 |
|
"url" => "&subop=change_pass" |
|
24 |
|
), |
|
25 |
|
"keys" => array( |
|
26 |
|
"text" => "SSH keys", |
|
27 |
|
"url" => "&subop=keys" |
|
28 |
|
) |
|
29 |
|
); |
|
30 |
|
} |
|
31 |
|
|
|
32 |
|
$_home .= "<h1>" . htmlspecialchars($user) . "</h1>\n"; |
|
33 |
|
|
|
34 |
|
// list of repositories |
|
35 |
|
$_home .= rg_repo_list($db, "", $ui); |
|
36 |
|
|
|
37 |
|
// allow operations if the page is owned by the user visiting it |
|
38 |
|
if ($ui['uid'] == $rg_ui['uid']) { |
|
39 |
|
$errmsg = array(); |
|
40 |
|
|
|
41 |
|
switch ($subop) { |
|
42 |
|
case 'edit_info': |
|
43 |
|
include($INC . "/user/info/info.php"); |
|
44 |
|
$_home .= $_info; |
|
45 |
|
break; |
|
46 |
|
|
|
47 |
|
case 'change_pass': |
|
48 |
|
include($INC . "/user/pass/pass.php"); |
|
49 |
|
$_home .= $_pass; |
|
50 |
|
break; |
|
51 |
|
|
|
52 |
|
case 'keys': |
|
53 |
|
include($INC . "/user/keys/keys.php"); |
|
54 |
|
$_home .= $_keys; |
|
55 |
|
break; |
|
56 |
|
} |
|
57 |
|
} |
|
58 |
|
|
|
59 |
|
?> |
|
60 |
|
|
File inc/user/info/info.php added (mode: 100644) (index 0000000..50174b3) |
|
1 |
|
<?php |
|
2 |
|
rg_log("/inc/user/info/info"); |
|
3 |
|
|
|
4 |
|
$errmsg = array(); |
|
5 |
|
|
|
6 |
|
$_info = ""; |
|
7 |
|
|
|
8 |
|
if ($doit == 1) { |
|
9 |
|
if (!rg_token_valid($db, $sid, $token)) { |
|
10 |
|
$_info .= "Invalid token. Try again."; |
|
11 |
|
return; |
|
12 |
|
} |
|
13 |
|
|
|
14 |
|
$xuser = rg_var_str("xuser"); |
|
15 |
|
$email = rg_var_str("email"); |
|
16 |
|
$is_admin = $rg_ui['is_admin']; // TODO: doesn't seems too elegant |
|
17 |
|
$disk_quota_mb = $rg_ui['disk_quota_mb']; |
|
18 |
|
$rights = $rg_ui['rights']; |
|
19 |
|
$session_time = rg_var_uint("session_time"); |
|
20 |
|
|
|
21 |
|
while (1) { |
|
22 |
|
$xpass = ""; |
|
23 |
|
if (!rg_user_edit($db, $rg_ui['uid'], $xuser, $email, $xpass, |
|
24 |
|
$is_admin, $disk_quota_mb, $rights, $session_time, "")) { |
|
25 |
|
$errmsg[] = "Cannot change info (" . rg_user_error() . ")."; |
|
26 |
|
break; |
|
27 |
|
} |
|
28 |
|
|
|
29 |
|
$_info .= "OK!<br />"; |
|
30 |
|
break; |
|
31 |
|
} |
|
32 |
|
} else { |
|
33 |
|
$xuser = $rg_ui['username']; |
|
34 |
|
$email = $rg_ui['email']; |
|
35 |
|
$is_admin = $rg_ui['is_admin']; |
|
36 |
|
$disk_quota_mb = $rg_ui['disk_quota_mb']; |
|
37 |
|
$rights = $rg_ui['rights']; |
|
38 |
|
$session_time = $rg_ui['session_time']; |
|
39 |
|
} |
|
40 |
|
|
|
41 |
|
$admin_mode = 0; |
|
42 |
|
$pass_mode = 0; |
|
43 |
|
include($INC . "/admin/users/user.form.php"); |
|
44 |
|
$_info .= $_form; |
|
45 |
|
|
|
46 |
|
?> |
File inc/user/pass/pass.form.php renamed from inc/personal/pass.form.php (similarity 94%) (mode: 100644) (index 5206d86..fa19357) |
... |
... |
if (count($errmsg) > 0) |
5 |
5 |
$_chpass_form .= '<span class="error">' . implode("<br />\n", $errmsg) . '</span><br /><br />' . "\n"; |
$_chpass_form .= '<span class="error">' . implode("<br />\n", $errmsg) . '</span><br /><br />' . "\n"; |
6 |
6 |
|
|
7 |
7 |
$_chpass_form .= ' |
$_chpass_form .= ' |
8 |
|
<form method="post" action="' . $_SERVER['PHP_SELF'] . '"> |
|
|
8 |
|
<form method="post" action="' . rg_re_post($op) . '"> |
9 |
9 |
<input type="hidden" name="op" value="' . $op . '" /> |
<input type="hidden" name="op" value="' . $op . '" /> |
10 |
10 |
<input type="hidden" name="doit" value="1" /> |
<input type="hidden" name="doit" value="1" /> |
11 |
11 |
<input type="hidden" name="token" value="' . rg_token_get($db, $sid) . '" /> |
<input type="hidden" name="token" value="' . rg_token_get($db, $sid) . '" /> |
File inc/user/pass/pass.php added (mode: 100644) (index 0000000..1c039ca) |
|
1 |
|
<?php |
|
2 |
|
rg_log("/inc/user/pass/pass"); |
|
3 |
|
|
|
4 |
|
$errmsg = array(); |
|
5 |
|
|
|
6 |
|
$_pass = ""; |
|
7 |
|
|
|
8 |
|
$show_form = 1; |
|
9 |
|
if ($doit == 1) { |
|
10 |
|
$old_pass = rg_var_str("old_pass"); |
|
11 |
|
$pass1 = rg_var_str("pass1"); |
|
12 |
|
$pass2 = rg_var_str("pass2"); |
|
13 |
|
|
|
14 |
|
while (1) { |
|
15 |
|
if (!rg_token_valid($db, $sid, $token)) { |
|
16 |
|
$errmsg[] = "Invalid token. Try again."; |
|
17 |
|
break; |
|
18 |
|
} |
|
19 |
|
|
|
20 |
|
if (strcmp($pass1, $pass2) != 0) { |
|
21 |
|
$errmsg[] = "Passwords does not match!"; |
|
22 |
|
break; |
|
23 |
|
} |
|
24 |
|
|
|
25 |
|
if (!rg_user_pass_valid($db, $rg_ui['uid'], $old_pass)) { |
|
26 |
|
$errmsg[] = "Old password is invalid!"; |
|
27 |
|
break; |
|
28 |
|
} |
|
29 |
|
|
|
30 |
|
if (!rg_user_set_pass($db, $rg_ui['uid'], $pass1)) { |
|
31 |
|
$errmsg[] = rg_user_error(); |
|
32 |
|
break; |
|
33 |
|
} |
|
34 |
|
|
|
35 |
|
$_pass .= "OK!<br />"; |
|
36 |
|
$show_form = 0; |
|
37 |
|
break; |
|
38 |
|
} |
|
39 |
|
} |
|
40 |
|
|
|
41 |
|
if ($show_form == 1) { |
|
42 |
|
include($INC . "/user/pass/pass.form.php"); |
|
43 |
|
$_pass .= $_chpass_form; |
|
44 |
|
} |
|
45 |
|
|
|
46 |
|
?> |
|
47 |
|
|
File inc/user/repo-page.php added (mode: 100644) (index 0000000..430eeca) |
|
1 |
|
<?php |
|
2 |
|
rg_log("/inc/user/repo-page"); |
|
3 |
|
|
|
4 |
|
$user = rg_var_str("user"); |
|
5 |
|
$repo = rg_var_str("repo"); |
|
6 |
|
|
|
7 |
|
$_home = ""; |
|
8 |
|
|
|
9 |
|
if (rg_user_ok($repo) !== TRUE) { |
|
10 |
|
$_home .= "Invalid repo!"; |
|
11 |
|
return; |
|
12 |
|
} |
|
13 |
|
|
|
14 |
|
if (rg_repo_ok($repo) !== TRUE) { |
|
15 |
|
$_home .= "Invalid repo!"; |
|
16 |
|
return; |
|
17 |
|
} |
|
18 |
|
|
|
19 |
|
$_home .= "<h1>" . htmlspecialchars($repo) . "</h1>\n"; |
|
20 |
|
|
|
21 |
|
$rr = array("type" => "user", "user" => $user, "repo" => $repo); |
|
22 |
|
$repo_dir = rg_repo_name2base($rr) . $repo . ".git"; |
|
23 |
|
$_tree = rg_git_ls_tree($repo_dir, ""); |
|
24 |
|
$_more = array("url" => "xxxxx"); |
|
25 |
|
$_home .= rg_template($THEME . "/repo/tree", $_tree, $_more); |
|
26 |
|
|
|
27 |
|
?> |
|
28 |
|
|