. // TODO: the following is organized in a funky way. Clean it up require_once("../inc/profile.inc"); require_once("../inc/akismet.inc"); // output a select form item with the given name, // from a list of newline-delineated items from the text file. // If $selection is provided, and if it matches one of the entries in the file, // it will be selected by default. // function show_combo_box($name, $filename, $selection=null) { if (!file_exists($filename)) { echo "ERROR: $filename does not exist! Cannot create combo box.
"; exit(); } echo "\n"; fclose($file); } function show_picture_option($profile) { row1("Picture"); $warning = ""; if (profile_screening() && $profile->has_picture) { $warning = offensive_profile_warning($profile->verification); } if (($profile) && ($profile->has_picture)) { echo " "; rowify("
"); end_table(); echo ""; } else { rowify(" If you would like include a picture with your profile, click the \"Browse\" button and select a JPEG or PNG file. Please select images of 50KB or less.

"); rowify("
"); } } function show_language_selection($profile) { row1("Language"); echo "

\n"; } function show_submit() { row1("Submit profile"); echo ""; $config = get_config(); $publickey = parse_config($config, ""); if ($publickey) { table_row("To protect project's webpages from spam, we ask you to type in two words shown in the image:
\n". recaptcha_get_html($publickey)); } table_row("

"); } // Returns an array containing: // [0]: The original image refered to by $fileName if its dimensions are // less than MAX_IMG_WIDTH x MAX_IMG_HEIGHT, or a version scaled to // those dimensions if it was too large. // [1]: A scaled version of the above. function getImages($fileName) { $size = getImageSize($fileName); // Determine if the filetype uploaded is supported. // TODO: Change these to constants. switch($size[2]) { case '2': // JPEG $image = imageCreateFromJPEG($fileName); break; case '3': // PNG $image = imageCreateFromPNG($fileName); break; default: error_page("The format of your uploaded image is not supported."); } $width = $size[0]; $height = $size[1]; $smallImage = scale_image($image, $width, $height, SMALL_IMG_WIDTH, SMALL_IMG_HEIGHT); if ($width > MAX_IMG_WIDTH || $height > MAX_IMG_HEIGHT) { $image = scale_image($image, $width, $height, MAX_IMG_WIDTH, MAX_IMG_HEIGHT); } /* echo "

Image type: $size[2]"; echo "
Original width: $width"; echo "
Original height: $height"; echo "
Scalar: $scalar"; echo "
Dest width: " . ($width / $scalar); echo "
Dest height: " . ($height / $scalar); echo "
Horizontal offset: $horiz_offset"; echo "
Vertical offset: $vert_offset"; echo "

View result"; */ return array($image, $smallImage); } function show_description() { echo "

Your profile lets you share your opinions and background with the ".PROJECT." community.

"; } function show_questions($profile) { $response1 = ""; $response2 = ""; if (isset($profile->response1)) { $response1 = $profile->response1; } if (isset($profile->response2)) { $response2 = $profile->response2; } row1(show_profile_heading1()); rowify(show_profile_question1().html_info()); show_textarea("response1", $response1); row1( show_profile_heading2()); rowify( show_profile_question2().html_info()); show_textarea("response2", $response2); show_language_selection($profile); } function show_textarea($name, $text) { rowify(""); } // $profile is null if user doesn't already have a profile. // Don't assign to $profile->x if this is the case. // function process_create_profile($user, $profile) { $response1 = post_str('response1', true); $response2 = post_str('response2', true); $language = post_str('language'); $privatekey = parse_config($config, ""); if ($privatekey) { $resp = recaptcha_check_answer($privatekey, $_SERVER["REMOTE_ADDR"], $_POST["recaptcha_challenge_field"], $_POST["recaptcha_response_field"] ); if (!$resp->is_valid) { $profile->response1 = $response1; $profile->response2 = $response2; show_profile_form($profile, "Your ReCaptcha response was not correct. Please try again." ); return; } } if (!akismet_check($user, $response1)) { $profile->response1 = $response1; $profile->response2 = $response2; show_profile_form($profile, "Your first response was flagged as spam by the Akismet anti-spam system. Please modify your text and try again." ); return; } if (!akismet_check($user, $response2)) { $profile->response1 = $response1; $profile->response2 = $response2; show_profile_form($profile, "Your second response was flagged as spam by the Akismet anti-spam system. Please modify your text and try again." ); return; } if (isset($_POST['delete_pic'])) { $delete_pic = $_POST['delete_pic']; } else { $delete_pic = "off"; } if (strlen($response1)==0 && strlen($response2)==0 && $delete_pic != "on" && !is_uploaded_file($_FILES['picture']['tmp_name']) ) { error_page("Your profile submission was empty."); exit(); } if ($delete_pic == "on") { delete_user_pictures($profile->userid); $profile->has_picture = false; $profile->verification = 0; } $profile ? $hasPicture = $profile->has_picture: $hasPicture = false; if (is_uploaded_file($_FILES['picture']['tmp_name'])) { $hasPicture = true; if ($profile) $profile->verification = 0; // echo "
Name: " . $_FILES['picture']['name']; // echo "
Type: " . $_FILES['picture']['type']; // echo "
Size: " . $_FILES['picture']['size']; // echo "
Temp name: " . $_FILES['picture']['tmp_name']; $images = getImages($_FILES['picture']['tmp_name']); // Write the original image file to disk. // TODO: define a constant for image quality. ImageJPEG($images[0], IMAGE_PATH . $user->id . '.jpg'); ImageJPEG($images[1], IMAGE_PATH . $user->id . '_sm.jpg'); } $response1 = sanitize_html($response1); $response2 = sanitize_html($response2); if ($profile) { $query = " response1 = '".boinc_real_escape_string($response1)."'," ." response2 = '".boinc_real_escape_string($response2)."'," ." language = '".boinc_real_escape_string($language)."'," ." has_picture = '$hasPicture'," ." verification = '$profile->verification'" ." WHERE userid = '$user->id'"; $result = BoincProfile::update_aux($query); if (!$result) { error_page("Couldn't update profile: database error"); } } else { $query = 'SET ' ." userid = '$user->id'," ." language = '".boinc_real_escape_string($language)."'," ." response1 = '".boinc_real_escape_string($response1)."'," ." response2 = '".boinc_real_escape_string($response2)."'," ." has_picture = '$hasPicture'," ." verification=0"; $result = BoincProfile::insert($query); if (!$result) { error_page("Couldn't create profile: database error"); } $user->update("has_profile=1"); } page_head("Profile saved"); echo " Congratulations! Your profile was successfully entered into our database.

id>View your profile
"; page_tail(); } function show_profile_form($profile, $warning=null) { if ($profile) { page_head("Edit your profile"); } else { page_head("Create a profile"); } if ($warning) { echo "$warning

"; } echo "
"; start_table_noborder(); show_description(); show_questions($profile); show_picture_option($profile); show_submit(); end_table(); echo ""; page_tail(); } $user = get_logged_in_user(true); $profile = get_profile($user->id); $config = get_config(); $min_credit = parse_config($config, ""); if ($min_credit && $user->expavg_credit < $min_credit) { error_page( "To prevent spam, an average credit of $min_credit or greater is required to create or edit a profile. We apologize for this inconvenience." ); } if (post_str("submit", true)) { process_create_profile($user, $profile); exit; } show_profile_form($profile); ?>

userid . '.jpg' . "\">userid . '_sm.jpg' . "\"> $warning Your profile picture is shown at left.

To replace it, click the \"Browse\" button and select a JPEG or PNG file (50KB or less).

To remove it from your profile, check this box:

Select the language in which your profile is written:

"; if (isset($profile->language)) { show_combo_box("language", LANGUAGE_FILE, $profile->language); } else { show_combo_box("language", LANGUAGE_FILE, "English"); } echo "