- user web: code cleanup in prefs.inc

svn path=/trunk/boinc/; revision=21766
This commit is contained in:
David Anderson 2010-06-17 19:11:00 +00:00
parent fcd3eb4fda
commit 30d7ced4ca
2 changed files with 55 additions and 26 deletions

View File

@ -4357,3 +4357,9 @@ David 17 Jun 2010
api/ api/
boinc_api.cpp boinc_api.cpp
David 17 Jun 2010
- user web: code cleanup in prefs.inc
html/inc/
prefs.inc

View File

@ -343,6 +343,26 @@ if (isset($project_has_beta) && $project_has_beta) {
false false
); );
} }
if (defined("EMAIL_FROM")) {
$x = "<br><span class=note>".tra("Emails will be sent from %1; make sure your spam filter accepts this address.", EMAIL_FROM)."</span>";
} else {
$x = "";
}
$privacy_pref_descs = array (
new PREF_BOOL(
tra("Is it OK for %1 and your team (if any) to email you?", PROJECT).$x,
"send_email",
true,
false
),
new PREF_BOOL(
tra("Should %1 show your computers on its web site?", PROJECT),
"show_hosts",
true,
false
),
);
define("DISK_LIMIT_DESC", tra("Disk and memory usage")); define("DISK_LIMIT_DESC", tra("Disk and memory usage"));
define("CPU_LIMIT_DESC", tra("Processor usage")); define("CPU_LIMIT_DESC", tra("Processor usage"));
@ -741,17 +761,17 @@ function prefs_show_project($prefs, $columns=false) {
} }
} }
function prefs_show_privacy($user) { function prefs_show_privacy($user, $columns) {
$x = ""; global $privacy_pref_descs;
if (defined('EMAIL_FROM')) { if ($columns) {
$x = "<br><span class=note>". foreach ($privacy_pref_descs as $p) {
tra("Emails will be sent from %1; make sure your spam filter accepts this address.", EMAIL_FROM). $p->show_cols($user);
"</span>"; }
} else {
foreach ($privacy_pref_descs as $p) {
$p->show($user);
}
} }
row2(tra("Is it OK for %1 and your team (if any) to email you?", PROJECT)." $x",
$user->send_email?tra("yes"):tra("no")
);
row2(tra("Should %1 show your computers on its web site?", PROJECT), $user->show_hosts?tra("yes"):tra("no"));
} }
function prefs_show_project_specific($prefs, $columns=false) { function prefs_show_project_specific($prefs, $columns=false) {
@ -804,7 +824,7 @@ function print_prefs_display_project($user, $columns=false) {
row1(tra("Combined preferences").$switch_link, 2, "heading"); row1(tra("Combined preferences").$switch_link, 2, "heading");
echo "<tr><td colspan=2>"; echo "<tr><td colspan=2>";
start_table(); start_table();
prefs_show_privacy($user); prefs_show_privacy($user, true);
venue_show($user); venue_show($user);
row_top(tra("Project specific settings")); row_top(tra("Project specific settings"));
prefs_show_project($project_prefs, true); prefs_show_project($project_prefs, true);
@ -819,7 +839,7 @@ function print_prefs_display_project($user, $columns=false) {
echo "<tr><td colspan=2>"; echo "<tr><td colspan=2>";
start_table(); start_table();
prefs_show_project($project_prefs, false); prefs_show_project($project_prefs, false);
prefs_show_privacy($user); prefs_show_privacy($user, false);
venue_show($user); venue_show($user);
prefs_show_project_specific($project_prefs, false); prefs_show_project_specific($project_prefs, false);
$tokens = url_tokens($user->authenticator); $tokens = url_tokens($user->authenticator);
@ -947,17 +967,14 @@ function prefs_form_global($user, $prefs, $error=false) {
} }
function prefs_form_privacy($user) { function prefs_form_privacy($user) {
$y = prefs_form_radio_buttons("send_email", $user->send_email); global $privacy_pref_descs;
row2(tra("Is it OK for %1 and your team (if any) to email you?", PROJECT), $y); foreach ($privacy_pref_descs as $p) {
$p->show_form_row($user, false);
$y = prefs_form_radio_buttons("show_hosts", $user->show_hosts); }
row2(tra("Should %1 show your computers on its web site?", PROJECT), $y);
} }
function prefs_form_project($prefs, $error=false) { function prefs_form_project($prefs, $error=false) {
global $project_pref_descs; global $project_pref_descs;
global $app_types;
foreach ($project_pref_descs as $p) { foreach ($project_pref_descs as $p) {
$p->show_form_row($prefs, $error); $p->show_form_row($prefs, $error);
} }
@ -973,6 +990,7 @@ function prefs_form_project_specific($prefs_xml, $error=false) {
// //
// @param string $name name of the radio buttons // @param string $name name of the radio buttons
// @param bool $yesno toggles the preset of the buttons; true=yes, false=no // @param bool $yesno toggles the preset of the buttons; true=yes, false=no
//
function prefs_form_radio_buttons($name, $yesno) { function prefs_form_radio_buttons($name, $yesno) {
$rb = tra("yes")." <input type=radio name=$name value=yes " $rb = tra("yes")." <input type=radio name=$name value=yes "
.($yesno?"checked":"") .($yesno?"checked":"")
@ -1046,12 +1064,16 @@ function prefs_resource_parse_form(&$prefs) {
} }
function prefs_privacy_parse_form(&$user) { function prefs_privacy_parse_form(&$user) {
$user->send_email = ($_GET['send_email'] == "yes")?1:0; global $privacy_pref_descs;
$user->show_hosts = ($_GET['show_hosts'] == "yes")?1:0; $error = false;
foreach ($privacy_pref_descs as $p) {
$p->parse_form($user, $error);
}
return $error;
} }
// This function parses the project specific prefs form. // Parse the project specific prefs form.
// For details look into project/project_specific_prefs.inc // For details see project/project_specific_prefs.inc
// //
function prefs_project_parse_form(&$prefs) { function prefs_project_parse_form(&$prefs) {
$error = false; $error = false;
@ -1069,8 +1091,6 @@ function global_prefs_make_xml($prefs, $primary=true) {
global $disk_prefs; global $disk_prefs;
global $net_prefs; global $net_prefs;
// N.B.: each XML entry must end with \n due to the sloppy parsing by the
// BOINC client!!
$xml = ""; $xml = "";
if ($primary) { if ($primary) {
$xml = "<global_preferences>\n"; $xml = "<global_preferences>\n";
@ -1153,7 +1173,10 @@ function global_prefs_update(&$user, $prefs) {
function project_prefs_update(&$user, $prefs) { function project_prefs_update(&$user, $prefs) {
$prefs_xml = mysql_real_escape_string(project_prefs_make_xml($prefs)); $prefs_xml = mysql_real_escape_string(project_prefs_make_xml($prefs));
$retval = mysql_query("update user set project_prefs='$prefs_xml', send_email=$user->send_email, show_hosts=$user->show_hosts where id=$user->id"); $send_email = $user->send_email?1:0;
$show_hosts = $user->show_hosts?1:0;
$query = "update user set project_prefs='$prefs_xml', send_email=$send_email, show_hosts=$show_hosts where id=$user->id";
$retval = mysql_query($query);
$user->project_prefs = $prefs_xml; $user->project_prefs = $prefs_xml;
return $retval; return $retval;
} }