2004-02-02 23:34:39 +00:00
|
|
|
<?php
|
2008-08-05 22:43:14 +00:00
|
|
|
// This file is part of BOINC.
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2008 University of California
|
|
|
|
//
|
|
|
|
// BOINC is free software; you can redistribute it and/or modify it
|
|
|
|
// under the terms of the GNU Lesser General Public License
|
|
|
|
// as published by the Free Software Foundation,
|
|
|
|
// either version 3 of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// BOINC is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
// See the GNU Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
2004-02-02 23:34:39 +00:00
|
|
|
|
|
|
|
require_once("../inc/db_ops.inc");
|
|
|
|
require_once("../inc/util.inc");
|
|
|
|
require_once("../project/project.inc");
|
|
|
|
|
2008-02-01 23:11:09 +00:00
|
|
|
// TODO: get rid of the following. use style sheets
|
2005-02-08 03:33:35 +00:00
|
|
|
define("TD", "<td bgcolor=\"#708090\">");
|
|
|
|
define("TD2", "<td colspan=\"2\" bgcolor=\"#708090\">");
|
|
|
|
define("TD3", "<td colspan=\"3\" bgcolor=\"#708090\">");
|
|
|
|
define("TABLE", "<table cellpadding=\"8\" border=\"1\" width=\"100%\">");
|
|
|
|
define("TABLE2", "<table width=\"580\">");
|
2004-02-02 23:34:39 +00:00
|
|
|
|
|
|
|
function admin_page_head($title) {
|
2008-02-01 23:11:09 +00:00
|
|
|
$stylesheet = URL_BASE.STYLESHEET;
|
|
|
|
|
|
|
|
echo "<html><head><title>$title</title>
|
2009-04-17 00:01:33 +00:00
|
|
|
<link rel=stylesheet type=\"text/css\" href=\"".URL_BASE."main.css\" media=\"all\" />
|
2008-02-01 23:11:09 +00:00
|
|
|
<link rel=\"stylesheet\" type=\"text/css\" href=\"$stylesheet\">
|
|
|
|
</head>
|
|
|
|
<body bgcolor=\"#ffffff\">
|
|
|
|
<h2>".PROJECT.": $title</h2>
|
|
|
|
";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function admin_page_tail() {
|
2008-02-01 23:11:09 +00:00
|
|
|
echo "<br><hr noshade size=1><center>
|
2009-09-15 04:48:08 +00:00
|
|
|
<a href=\"index.php\"> Back to Main admin page </a> |
|
|
|
|
";
|
|
|
|
$user = get_logged_in_user_ops();
|
|
|
|
if ($user) {
|
|
|
|
echo "logged in as $user->name. <a href=logout.php>Log out</a>";
|
|
|
|
} else {
|
|
|
|
echo "<a href=login_form.php>Log in</a>";
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "
|
|
|
|
</center>
|
2008-02-01 23:11:09 +00:00
|
|
|
</body></html>
|
|
|
|
";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
|
2008-02-01 23:11:09 +00:00
|
|
|
// TODO: get rid of all the following
|
|
|
|
|
2004-02-02 23:34:39 +00:00
|
|
|
function print_checkbox($text,$name,$checked) {
|
2005-02-08 03:33:35 +00:00
|
|
|
echo "<input type=\"checkbox\" name=\"$name\""
|
|
|
|
. (strlen($checked) ? " checked=\"checked\"" : "") . ">"
|
2004-02-02 23:34:39 +00:00
|
|
|
. "$text\n"
|
|
|
|
. "<p>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
function print_radio_button($text,$name,$value,$checked) {
|
2005-02-08 03:33:35 +00:00
|
|
|
echo "<input type=\"radio\" name=\"$name\" value=\"$value\""
|
|
|
|
. (strlen($checked) ? " checked=\"checked\"" : "") . ">"
|
2004-02-02 23:34:39 +00:00
|
|
|
. "$text\n"
|
|
|
|
. "<br>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
function print_text_field($text,$name,$value) {
|
2005-02-08 03:33:35 +00:00
|
|
|
echo "$text <input type=\"text\" size=\"10\" name=\"$name\" value=\"$value\">\n"
|
2004-02-02 23:34:39 +00:00
|
|
|
. "<p>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
function row($x, $y) {
|
2005-02-08 03:33:35 +00:00
|
|
|
echo "<tr><td valign=\"top\" align=\"right\">$x</td>\n<td>$y</td>\n</tr>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function c_row2($color, $x, $y) {
|
2005-02-08 03:33:35 +00:00
|
|
|
echo "<tr bgcolor=\"$color\"><td align=\"right\">$x</td><td>$y</td></tr>\n";
|
2004-02-02 23:34:39 +00:00
|
|
|
}
|
|
|
|
|
2008-01-07 23:33:48 +00:00
|
|
|
function show_profile_link_ops($user) {
|
|
|
|
if ($user->has_profile) {
|
|
|
|
row2("Profile",
|
|
|
|
"<a href=\"".URL_BASE."view_profile.php?userid=$user->id\">View</a>"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-09-15 18:14:37 +00:00
|
|
|
// initialize database connection with username & password from
|
|
|
|
// command line instead of config.xml
|
|
|
|
//
|
|
|
|
function db_init_cli() {
|
|
|
|
$config = get_config();
|
|
|
|
$db_name = parse_config($config, "<db_name>");
|
|
|
|
$host = parse_config($config, "<db_host>");
|
|
|
|
if ($host == null) {
|
|
|
|
$host = "localhost";
|
|
|
|
}
|
|
|
|
$in = fopen("php://stdin","r");
|
|
|
|
print "Database username for $db_name@$host: ";
|
|
|
|
$user = rtrim(fgets($in, 80));
|
|
|
|
print "Database password for $db_name@host: ";
|
|
|
|
$pass = rtrim(fgets($in, 80));
|
|
|
|
|
|
|
|
$retval = mysql_pconnect($host, $user, $pass);
|
|
|
|
if (!$retval) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
if (!mysql_select_db($db_name)) {
|
|
|
|
return 2;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2009-09-15 04:48:08 +00:00
|
|
|
function print_login_form_ops($next_url='') {
|
|
|
|
if ($next_url == '') $next_url = $_SERVER['REQUEST_URI'];
|
2009-09-15 18:14:37 +00:00
|
|
|
start_table();
|
2009-09-15 04:48:08 +00:00
|
|
|
echo "
|
|
|
|
<form method=post action=login_action.php>
|
|
|
|
<input type=hidden name=next_url value=$next_url>
|
|
|
|
";
|
2009-09-15 18:14:37 +00:00
|
|
|
row2("Email", "<input name=email_addr size=40>");
|
|
|
|
row2("Password", "<input type=password name=passwd size=40>");
|
|
|
|
row2("", "<input type=submit value=OK>");
|
|
|
|
end_table();
|
2009-09-15 04:48:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function get_logged_in_user_ops() {
|
|
|
|
global $g_logged_in_user;
|
|
|
|
if ($g_logged_in_user) return $g_logged_in_user;
|
|
|
|
$authenticator = null;
|
|
|
|
if (isset($_COOKIE['auth'])) $authenticator = $_COOKIE['auth'];
|
|
|
|
|
|
|
|
$authenticator = BoincDb::escape_string($authenticator);
|
|
|
|
if ($authenticator) {
|
|
|
|
$g_logged_in_user = BoincUser::lookup("authenticator='$authenticator'");
|
|
|
|
}
|
|
|
|
return $g_logged_in_user;
|
|
|
|
}
|
|
|
|
|
2009-09-15 18:14:37 +00:00
|
|
|
////////// functions for access control of admin web pages /////////////
|
|
|
|
|
|
|
|
// deny access
|
|
|
|
|
|
|
|
function auth_ops_deny() {
|
|
|
|
error_page("To allow access to admin pages,
|
|
|
|
you must define a function auth_ops() in html/project/project.inc
|
|
|
|
that specifies your access control policy.
|
|
|
|
<a href=http://boinc.berkeley.edu/trac/wiki/HtmlOps>See how here</a>
|
|
|
|
.
|
|
|
|
");
|
|
|
|
}
|
|
|
|
|
|
|
|
// allow access only if logged in as user in a given set
|
|
|
|
//
|
|
|
|
function auth_ops_userid($admin_user_ids) {
|
|
|
|
$user = get_logged_in_user_ops();
|
|
|
|
if (!$user) {
|
|
|
|
admin_page_head("Log in");
|
|
|
|
echo "You must log in to performance admin functions.<p>\n";
|
|
|
|
print_login_form_ops();
|
|
|
|
admin_page_tail();
|
|
|
|
exit;
|
|
|
|
} else if (!in_array($user->id, $admin_user_ids)) {
|
|
|
|
admin_page_head("Log in");
|
|
|
|
echo "
|
|
|
|
You must be logged in as an admin to perform admin functions.
|
|
|
|
<p>
|
|
|
|
<a href=logout.php>Log out</a>
|
2009-09-15 04:48:08 +00:00
|
|
|
";
|
2009-09-15 18:14:37 +00:00
|
|
|
admin_page_tail();
|
2009-09-15 04:48:08 +00:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-09-15 18:14:37 +00:00
|
|
|
// allow access only to users with ADMIN/DEV flags in forum prefs.
|
|
|
|
// If you use this, make sure you know who has these privileges
|
|
|
|
//
|
|
|
|
function auth_ops_privilege() {
|
|
|
|
$user = get_logged_in_user_ops();
|
|
|
|
if (!$user) {
|
|
|
|
admin_page_head("Log in");
|
|
|
|
echo "You must log in to performance admin functions.<p>\n";
|
|
|
|
print_login_form_ops();
|
|
|
|
admin_page_tail();
|
2009-09-15 04:48:08 +00:00
|
|
|
exit;
|
|
|
|
}
|
2009-09-15 18:14:37 +00:00
|
|
|
BoincForumPrefs::lookup($user);
|
|
|
|
if ($user->prefs->privilege(S_ADMIN) || $user->prefs->privilege(S_DEV)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
error_page("Access denied");
|
|
|
|
}
|
|
|
|
|
|
|
|
// if project hasn't specified a policy in project.inc, the default is no access
|
|
|
|
//
|
|
|
|
if (!function_exists('auth_ops')) {
|
|
|
|
function auth_ops() {
|
|
|
|
auth_ops_deny();
|
|
|
|
}
|
2009-09-15 04:48:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function error_page_ops($msg) {
|
|
|
|
admin_page_head("Unable to handle request");
|
|
|
|
echo $msg;
|
|
|
|
admin_page_tail();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2009-10-02 18:32:40 +00:00
|
|
|
if (isset($cli_only)) {
|
|
|
|
if (array_key_exists("SERVER_PORT", $_SERVER)) {
|
|
|
|
die("This script is intended to be run from the command line,
|
|
|
|
not from the web server."
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!isset($skip_auth_ops) && array_key_exists("SERVER_PORT", $_SERVER)) {
|
2009-09-15 18:14:37 +00:00
|
|
|
auth_ops();
|
|
|
|
}
|
|
|
|
|
2008-02-01 23:11:09 +00:00
|
|
|
$cvs_version_tracker[]="\$Id$"; //Generated automatically - do not edit
|
2004-02-02 23:34:39 +00:00
|
|
|
?>
|