// Copyright: Matthias Steffens and the file's // original author(s). // // This code is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY. Please see the GNU General Public // License for more details. // // File: ./user_options_modify.php // Repository: $HeadURL: file:///svn/p/refbase/code/branches/bleeding-edge/user_options_modify.php $ // Author(s): Matthias Steffens // // Created: 26-Oct-04, 20:57 // Modified: $Date: 2017-04-13 02:00:18 +0000 (Thu, 13 Apr 2017) $ // $Author: karnesky $ // $Revision: 1416 $ // This script validates user options selected within the form provided by 'user_options.php'. // If validation succeeds, it UPDATEs the corresponding table fields for that user and redirects to a receipt page; // if it fails, it creates error messages and these are later displayed by 'user_options.php'. // TODO: I18n // Incorporate some include files: include 'initialize/db.inc.php'; // 'db.inc.php' is included to hide username and password include 'includes/include.inc.php'; // include common functions include 'initialize/ini.inc.php'; // include common variables // -------------------------------------------------------------------- // START A SESSION: // call the 'start_session()' function (from 'include.inc.php') which will also read out available session variables: start_session(true); // -------------------------------------------------------------------- // Initialize preferred display language: // (note that 'locales.inc.php' has to be included *after* the call to the 'start_session()' function) include 'includes/locales.inc.php'; // include the locales // -------------------------------------------------------------------- // Clear any errors that might have been found previously: $errors = array(); // Write the (POST) form variables into an array: foreach($_POST as $varname => $value) $formVars[$varname] = $value; // Since checkbox form fields do only get included in the '$_POST' array if they were marked, // we have to add appropriate array elements for all checkboxes that weren't set: // (we deal with permission checkboxes separately below) if (!isset($formVars["export_cite_keys"])) $formVars["export_cite_keys"] = "no"; if (!isset($formVars["autogenerate_cite_keys"])) $formVars["autogenerate_cite_keys"] = "no"; if (!isset($formVars["prefer_autogenerated_cite_keys"])) $formVars["prefer_autogenerated_cite_keys"] = "no"; if (!isset($formVars["use_custom_cite_key_format"])) $formVars["use_custom_cite_key_format"] = "no"; // $formVars["use_custom_handling_of_nonascii_chars_in_cite_keys"] is handled (differently) below if (!isset($formVars["uniquify_duplicate_cite_keys"])) $formVars["uniquify_duplicate_cite_keys"] = "no"; if (!isset($formVars["use_custom_text_citation_format"])) $formVars["use_custom_text_citation_format"] = "no"; // -------------------------------------------------------------------- // First of all, check if this script was called by something else than 'user_options.php': if (!preg_match("#/user_options\.php#i", $referer)) // variable '$referer' is globally defined in function 'start_session()' in 'include.inc.php' { // return an appropriate error message: $HeaderString = returnMsg($loc["Warning_InvalidCallToScript"] . " '" . scriptURL() . "'!", "warning", "strong", "HeaderString"); // functions 'returnMsg()' and 'scriptURL()' are defined in 'include.inc.php' header("Location: " . $referer); // redirect to calling page exit; // >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> !EXIT! <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< } // -------------------------------------------------------------------- // (1) OPEN CONNECTION, (2) SELECT DATABASE connectToMySQLDatabase(); // function 'connectToMySQLDatabase()' is defined in 'include.inc.php' // -------------------------------------------------------------------- // VALIDATE FORM DATA: // (Note: checking for missing/incorrect input of the language field isn't really necessary if a popup is used as input field -- as it is right now) // // Validate the language // if (empty($formVars["languageName"])) // // Language cannot be a null string // $errors["languageName"] = "The language field cannot be blank:"; // Validate the number of records per page if (($_REQUEST['userID'] != 0) AND !preg_match("/^[1-9]+[0-9]*$/", $formVars["recordsPerPageNo"])) // this form element is disabled for anonymous users ('userID=0') $errors["recordsPerPageNo"] = "Please enter a number (positive integer greater than zero):"; // Note: currently, the user must select at least one item within the type/style/format lists. Alternatively, we could grey out the corresponding interface elements // if a user deselects all items. Or, hiding the corresponding interface elements *completely* would actually give the user the possibility to remove unwanted/unneeded "features"! // Validate the reference type selector if (empty($formVars["referenceTypeSelector"])) $errors["referenceTypeSelector"] = "You must choose at least one reference type:"; // Validate the citation style selector if (empty($formVars["citationStyleSelector"])) $errors["citationStyleSelector"] = "You must choose at least one citation style:"; // Validate the cite format selector if (empty($formVars["citationFormatSelector"])) $errors["citationFormatSelector"] = "You must choose at least one citation format:"; // Validate the export format selector if (empty($formVars["exportFormatSelector"])) $errors["exportFormatSelector"] = "You must choose at least one export format:"; // Validate the main fields selector if (($_REQUEST['userID'] != 0) AND empty($formVars["mainFieldsSelector"])) // this form element is disabled for anonymous users ('userID=0') $errors["mainFieldsSelector"] = "You must specify at least one field as \"main field\":"; // -------------------------------------------------------------------- // Now the script has finished the validation, check if there were any errors: if (count($errors) > 0) { // Write back session variables: saveSessionVariable("errors", $errors); // function 'saveSessionVariable()' is defined in 'include.inc.php' saveSessionVariable("formVars", $formVars); // There are errors. Relocate back to the client form: header("Location: user_options.php?userID=" . $_REQUEST['userID']); // 'userID' got included as hidden form tag by 'user_options.php' exit; // >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> !EXIT! <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< } // -------------------------------------------------------------------- // If we made it here, then the data is considered valid! // CONSTRUCT SQL QUERY: // If a user is logged in and has submitted 'user_options.php' with a 'userID' parameter: // (while the admin has no restrictions, a normal user can only submit 'user_options.php' with his own 'userID' as parameter!) if (isset($_SESSION['loginEmail']) && ($_REQUEST['userID'] != "")) // -> perform an update: { if ($loginEmail != $adminLoginEmail) // if not admin logged in ('$adminLoginEmail' is specified in 'ini.inc.php') $userID = getUserID($loginEmail); // Get the 'user_id' using 'loginEmail' (function 'getUserID()' is defined in 'include.inc.php') else // if the admin is logged in he should be able to make any changes to account data/options of _other_ users... $userID = $_REQUEST['userID']; // ...in this case we accept 'userID' from the GET/POST request (it got included as hidden form tag by 'user_options.php') // UPDATE - construct queries to update the relevant table fields for this user // a) update the language field of the 'users' table: if ($userID != 0) // the 'languageName' form element is disabled for anonymous users ('userID=0'), and there isn't an entry with 'user_id=0' in table 'users' $queryArray[] = "UPDATE $tableUsers SET " . "language = " . quote_smart($formVars["languageName"]) . " " . "WHERE user_id = " . quote_smart($userID); if ($loginEmail == $adminLoginEmail) // if the admin is logged in { // b) update all entries for this user within the 'user_types' table: // - first, get a list of IDs for all types within the 'user_types' table that are available and were enabled by the admin for the current user: $enabledUserTypesArray = getEnabledUserFormatsStylesTypes($userID, "type", "", true); // function 'getEnabledUserFormatsStylesTypes()' is defined in 'include.inc.php' $enabledUserTypesInSelectedTypesArray = array_intersect($enabledUserTypesArray, $formVars["referenceTypeSelector"]); $enabledUserTypesNOTInSelectedTypesArray = array_diff($enabledUserTypesArray, $formVars["referenceTypeSelector"]); $selectedTypesNOTInEnabledUserTypesArray = array_diff($formVars["referenceTypeSelector"], $enabledUserTypesArray); if (!empty($enabledUserTypesNOTInSelectedTypesArray)) { // - remove types which do exist within the 'user_types' table but were deselected by the admin: $enabledUserTypesNOTInSelectedTypesString = implode("|", $enabledUserTypesNOTInSelectedTypesArray); // join array of type IDs using a pipe as separator $queryArray[] = "DELETE FROM $tableUserTypes " . "WHERE user_id = " . quote_smart($userID) . " AND type_id RLIKE " . quote_smart("^(" . $enabledUserTypesNOTInSelectedTypesString . ")$"); } if (!empty($selectedTypesNOTInEnabledUserTypesArray)) { // - insert types that were selected by the admin but which do not yet exist within the 'user_types' table: $selectedTypesNOTInEnabledUserTypesString = implode("|", $selectedTypesNOTInEnabledUserTypesArray); // join array of type IDs using a pipe as separator $insertTypesQuery = "INSERT INTO $tableUserTypes VALUES "; foreach ($selectedTypesNOTInEnabledUserTypesArray as $newUserTypeID) $insertTypesQueryValues[] = "(NULL, " . quote_smart($newUserTypeID) . ", " . quote_smart($userID) . ", 'true')"; $queryArray[] = $insertTypesQuery . implode(", ", $insertTypesQueryValues) . ";"; } // --------------------- // c) update all entries for this user within the 'user_styles' table: // - first, get a list of IDs for all styles within the 'user_styles' table that are available and were enabled by the admin for the current user: $enabledUserStylesArray = getEnabledUserFormatsStylesTypes($userID, "style", "", true); // function 'getEnabledUserFormatsStylesTypes()' is defined in 'include.inc.php' $enabledUserStylesInSelectedStylesArray = array_intersect($enabledUserStylesArray, $formVars["citationStyleSelector"]); $enabledUserStylesNOTInSelectedStylesArray = array_diff($enabledUserStylesArray, $formVars["citationStyleSelector"]); $selectedStylesNOTInEnabledUserStylesArray = array_diff($formVars["citationStyleSelector"], $enabledUserStylesArray); if (!empty($enabledUserStylesNOTInSelectedStylesArray)) { // - remove styles which do exist within the 'user_styles' table but were deselected by the admin: $enabledUserStylesNOTInSelectedStylesString = implode("|", $enabledUserStylesNOTInSelectedStylesArray); // join array of style IDs using a pipe as separator $queryArray[] = "DELETE FROM $tableUserStyles " . "WHERE user_id = " . quote_smart($userID) . " AND style_id RLIKE " . quote_smart("^(" . $enabledUserStylesNOTInSelectedStylesString . ")$"); } if (!empty($selectedStylesNOTInEnabledUserStylesArray)) { // - insert styles that were selected by the admin but which do not yet exist within the 'user_styles' table: $selectedStylesNOTInEnabledUserStylesString = implode("|", $selectedStylesNOTInEnabledUserStylesArray); // join array of style IDs using a pipe as separator $insertStylesQuery = "INSERT INTO $tableUserStyles VALUES "; foreach ($selectedStylesNOTInEnabledUserStylesArray as $newUserStyleID) $insertStylesQueryValues[] = "(NULL, " . quote_smart($newUserStyleID) . ", " . quote_smart($userID) . ", 'true')"; $queryArray[] = $insertStylesQuery . implode(", ", $insertStylesQueryValues) . ";"; } // --------------------- // d) update all cite entries for this user within the 'user_formats' table: // - first, get a list of IDs for all cite formats within the 'user_formats' table that are available and were enabled by the admin for the current user: $enabledUserFormatsArray = getEnabledUserFormatsStylesTypes($userID, "format", "cite", true); // function 'getEnabledUserFormatsStylesTypes()' is defined in 'include.inc.php' $enabledUserFormatsInSelectedFormatsArray = array_intersect($enabledUserFormatsArray, $formVars["citationFormatSelector"]); $enabledUserFormatsNOTInSelectedFormatsArray = array_diff($enabledUserFormatsArray, $formVars["citationFormatSelector"]); $selectedFormatsNOTInEnabledUserFormatsArray = array_diff($formVars["citationFormatSelector"], $enabledUserFormatsArray); if (!empty($enabledUserFormatsNOTInSelectedFormatsArray)) { // - remove cite formats which do exist within the 'user_formats' table but were deselected by the admin: $enabledUserFormatsNOTInSelectedFormatsString = implode("|", $enabledUserFormatsNOTInSelectedFormatsArray); // join array of format IDs using a pipe as separator $queryArray[] = "DELETE FROM $tableUserFormats " . "WHERE user_id = " . quote_smart($userID) . " AND format_id RLIKE " . quote_smart("^(" . $enabledUserFormatsNOTInSelectedFormatsString . ")$"); } if (!empty($selectedFormatsNOTInEnabledUserFormatsArray)) { // - insert cite formats that were selected by the admin but which do not yet exist within the 'user_formats' table: $selectedFormatsNOTInEnabledUserFormatsString = implode("|", $selectedFormatsNOTInEnabledUserFormatsArray); // join array of format IDs using a pipe as separator $insertFormatsQuery = "INSERT INTO $tableUserFormats VALUES "; foreach ($selectedFormatsNOTInEnabledUserFormatsArray as $newUserFormatID) $insertFormatsQueryValues[] = "(NULL, " . quote_smart($newUserFormatID) . ", " . quote_smart($userID) . ", 'true')"; $queryArray[] = $insertFormatsQuery . implode(", ", $insertFormatsQueryValues) . ";"; } // --------------------- // e) update all export entries for this user within the 'user_formats' table: // - first, get a list of IDs for all export formats within the 'user_formats' table that are available and were enabled by the admin for the current user: $enabledUserFormatsArray = getEnabledUserFormatsStylesTypes($userID, "format", "export", true); // function 'getEnabledUserFormatsStylesTypes()' is defined in 'include.inc.php' $enabledUserFormatsInSelectedFormatsArray = array_intersect($enabledUserFormatsArray, $formVars["exportFormatSelector"]); $enabledUserFormatsNOTInSelectedFormatsArray = array_diff($enabledUserFormatsArray, $formVars["exportFormatSelector"]); $selectedFormatsNOTInEnabledUserFormatsArray = array_diff($formVars["exportFormatSelector"], $enabledUserFormatsArray); if (!empty($enabledUserFormatsNOTInSelectedFormatsArray)) { // - remove export formats which do exist within the 'user_formats' table but were deselected by the admin: $enabledUserFormatsNOTInSelectedFormatsString = implode("|", $enabledUserFormatsNOTInSelectedFormatsArray); // join array of format IDs using a pipe as separator $queryArray[] = "DELETE FROM $tableUserFormats " . "WHERE user_id = " . quote_smart($userID) . " AND format_id RLIKE " . quote_smart("^(" . $enabledUserFormatsNOTInSelectedFormatsString . ")$"); } if (!empty($selectedFormatsNOTInEnabledUserFormatsArray)) { // - insert export formats that were selected by the admin but which do not yet exist within the 'user_formats' table: $selectedFormatsNOTInEnabledUserFormatsString = implode("|", $selectedFormatsNOTInEnabledUserFormatsArray); // join array of format IDs using a pipe as separator $insertFormatsQuery = "INSERT INTO $tableUserFormats VALUES "; foreach ($selectedFormatsNOTInEnabledUserFormatsArray as $newUserFormatID) $insertFormatsQueryValues[] = "(NULL, " . quote_smart($newUserFormatID) . ", " . quote_smart($userID) . ", 'true')"; $queryArray[] = $insertFormatsQuery . implode(", ", $insertFormatsQueryValues) . ";"; } // --------------------- // f) update all permission settings for this user within the 'user_permissions' table: // get all user permissions for the current user (as they were before submit of 'user_options.php'): $userPermissionsArray = getPermissions($userID, "user", false); // function 'getPermissions()' is defined in 'include.inc.php' // copy all array elements that deal with permission settings from the '$formVars' array to '$updatedUserPermissionsArray': // (note that, except hidden permission settings, only those permission settings were included in the '$formVars' array whose checkboxes were marked!) $updatedUserPermissionsArray = array(); foreach($formVars as $itemKey => $itemValue) if (preg_match("/^allow/i", $itemKey)) $updatedUserPermissionsArray[$itemKey] = $itemValue; // allow the particular feature ('$itemValue' will be 'yes' anyhow) // then, all permission settings that aren't contained within '$updatedUserPermissionsArray' must have been unchecked: // (note: this logic only works if all permission settings queried by function 'getPermissions()' are also made available by 'user_options.php' -- either as checkbox or as hidden form tag!) foreach($userPermissionsArray as $permissionKey => $permissionValue) if (!isset($updatedUserPermissionsArray[$permissionKey])) $updatedUserPermissionsArray[$permissionKey] = 'no'; // disallow the particular feature // update all user permissions for the current user: $updateSucceeded = updateUserPermissions(array($userID), $updatedUserPermissionsArray); // function 'updateUserPermissions()' is defined in 'include.inc.php' } // --------------------------------------------------------------- else // if a normal user is logged in { // b) update all entries for this user within the 'user_types' table: $typeIDString = implode("|", $formVars["referenceTypeSelector"]); // join array of type IDs using a pipe as separator $queryArray[] = "UPDATE $tableUserTypes SET " . "show_type = \"true\" " . "WHERE user_id = " . quote_smart($userID) . " AND type_id RLIKE " . quote_smart("^(" . $typeIDString . ")$"); $queryArray[] = "UPDATE $tableUserTypes SET " . "show_type = \"false\" " . "WHERE user_id = " . quote_smart($userID) . " AND type_id NOT RLIKE " . quote_smart("^(" . $typeIDString . ")$"); // c) update all entries for this user within the 'user_styles' table: $styleIDString = implode("|", $formVars["citationStyleSelector"]); // join array of style IDs using a pipe as separator $queryArray[] = "UPDATE $tableUserStyles SET " . "show_style = \"true\" " . "WHERE user_id = " . quote_smart($userID) . " AND style_id RLIKE " . quote_smart("^(" . $styleIDString . ")$"); $queryArray[] = "UPDATE $tableUserStyles SET " . "show_style = \"false\" " . "WHERE user_id = " . quote_smart($userID) . " AND style_id NOT RLIKE " . quote_smart("^(" . $styleIDString . ")$"); // d) update all cite entries for this user within the 'user_formats' table: $citeFormatIDString = implode("|", $formVars["citationFormatSelector"]); // join array of format IDs using a pipe as separator $queryArray[] = "UPDATE $tableUserFormats SET " . "show_format = \"true\" " . "WHERE user_id = " . quote_smart($userID) . " AND format_id RLIKE " . quote_smart("^(" . $citeFormatIDString . ")$"); $queryArray[] = "UPDATE $tableUserFormats SET " . "show_format = \"false\" " . "WHERE user_id = " . quote_smart($userID) . " AND format_id NOT RLIKE " . quote_smart("^(" . $citeFormatIDString . ")$"); // e) update all export entries for this user within the 'user_formats' table: $exportFormatIDString = implode("|", $formVars["exportFormatSelector"]); // join array of format IDs using a pipe as separator $queryArray[] = "UPDATE $tableUserFormats SET " . "show_format = \"true\" " . "WHERE user_id = " . quote_smart($userID) . " AND format_id RLIKE " . quote_smart("^(" . $exportFormatIDString . ")$"); $queryArray[] = "UPDATE $tableUserFormats SET " . "show_format = \"false\" " . "WHERE user_id = " . quote_smart($userID) . " AND format_id NOT RLIKE " . quote_smart("^(" . $exportFormatIDString . ")$") . " AND format_id NOT RLIKE " . quote_smart("^(" . $citeFormatIDString . ")$"); // we need to include '$citeFormatIDString' here, otherwise the user's selected cite formats would get deleted again } // --------------------------------------------------------------- // f) update the user's options in the 'user_options' table: if (!isset($formVars["use_custom_handling_of_nonascii_chars_in_cite_keys"])) $nonASCIICharsInCiteKeys = "NULL"; // use the site default given in '$handleNonASCIICharsInCiteKeysDefault' in 'ini.inc.php' else $nonASCIICharsInCiteKeys = quote_smart($formVars["nonascii_chars_in_cite_keys"]); // use the setting chosen by the user if ($userID != 0) { $recordsPerPage = $formVars["recordsPerPageNo"]; $showAutoCompletions = $formVars["showAutoCompletionsRadio"]; $mainFieldsString = implode(", ", $formVars["mainFieldsSelector"]); // join array of the user's preferred main fields using a comma (and whitespace) as separator } else // the 'recordsPerPageNo', 'showAutoCompletionsRadio' and 'mainFieldsSelector' form elements are disabled for anonymous users ('userID=0'), so we load the defaults: { $recordsPerPage = getDefaultNumberOfRecords(0); // function 'getDefaultNumberOfRecords()' is defined in 'include.inc.php' $showAutoCompletions = getPrefAutoCompletions(0); // function 'getPrefAutoCompletions()' is defined in 'include.inc.php' $mainFieldsString = implode(", ", getMainFields(0)); // function 'getMainFields()' is defined in 'include.inc.php' } // we account for the possibility that no entry in table 'user_options' exists for the current user // (in which case an entry will be added): // check if there's already an entry for the current user within the 'user_options' table: // CONSTRUCT SQL QUERY: $query = "SELECT option_id FROM $tableUserOptions WHERE user_id = " . quote_smart($userID); // RUN the query on the database through the connection: $result = queryMySQLDatabase($query); // function 'queryMySQLDatabase()' is defined in 'include.inc.php' if (mysqli_num_rows($result) == 1) // if there's already an existing user_data entry, we perform an UPDATE action: $queryArray[] = "UPDATE $tableUserOptions SET " . "export_cite_keys = " . quote_smart($formVars["export_cite_keys"]) . ", autogenerate_cite_keys = " . quote_smart($formVars["autogenerate_cite_keys"]) . ", prefer_autogenerated_cite_keys = " . quote_smart($formVars["prefer_autogenerated_cite_keys"]) . ", use_custom_cite_key_format = " . quote_smart($formVars["use_custom_cite_key_format"]) . ", cite_key_format = " . quote_smart($formVars["cite_key_format"]) . ", uniquify_duplicate_cite_keys = " . quote_smart($formVars["uniquify_duplicate_cite_keys"]) . ", nonascii_chars_in_cite_keys = " . $nonASCIICharsInCiteKeys // already quote_smart . ", use_custom_text_citation_format = " . quote_smart($formVars["use_custom_text_citation_format"]) . ", text_citation_format = " . quote_smart($formVars["text_citation_format"]) . ", records_per_page = " . quote_smart($recordsPerPage) . ", show_auto_completions = " . quote_smart($showAutoCompletions) . ", main_fields = " . quote_smart($mainFieldsString) . " WHERE user_id = " . quote_smart($userID); else // otherwise we perform an INSERT action: $queryArray[] = "INSERT INTO $tableUserOptions SET " . "export_cite_keys = " . quote_smart($formVars["export_cite_keys"]) . ", autogenerate_cite_keys = " . quote_smart($formVars["autogenerate_cite_keys"]) . ", prefer_autogenerated_cite_keys = " . quote_smart($formVars["prefer_autogenerated_cite_keys"]) . ", use_custom_cite_key_format = " . quote_smart($formVars["use_custom_cite_key_format"]) . ", cite_key_format = " . quote_smart($formVars["cite_key_format"]) . ", uniquify_duplicate_cite_keys = " . quote_smart($formVars["uniquify_duplicate_cite_keys"]) . ", nonascii_chars_in_cite_keys = " . $nonASCIICharsInCiteKeys // already quote_smart . ", use_custom_text_citation_format = " . quote_smart($formVars["use_custom_text_citation_format"]) . ", text_citation_format = " . quote_smart($formVars["text_citation_format"]) . ", records_per_page = " . quote_smart($recordsPerPage) . ", show_auto_completions = " . quote_smart($showAutoCompletions) . ", main_fields = " . quote_smart($mainFieldsString) . ", user_id = " . quote_smart($userID) . ", option_id = NULL"; // inserting 'NULL' into an auto_increment PRIMARY KEY attribute allocates the next available key value } // -------------------------------------------------------------------- // (3) RUN the queries on the database through the connection: foreach($queryArray as $query) $result = queryMySQLDatabase($query); // function 'queryMySQLDatabase()' is defined in 'include.inc.php' // ---------------------------------------------- // we'll only update the appropriate session variables if either a normal user is logged in -OR- the admin is logged in AND the updated user data are his own: if (($loginEmail != $adminLoginEmail) | (($loginEmail == $adminLoginEmail) && ($userID == getUserID($loginEmail)))) { // Write back session variables: saveSessionVariable("userLanguage", $formVars["languageName"]); // function 'saveSessionVariable()' is defined in 'include.inc.php' // Note: the user's types/styles/formats will be written to their corresponding session variables in function 'getVisibleUserFormatsStylesTypes()' // which will be called by the following receipt page ('user_receipt.php') anyhow, so we won't call the function here... // The same is true for the user's preferred number of records per page, the user's pref setting to show auto-completions and for the // list of "main fields" which will be saved to session variables from within 'user_receipt.php' thru functions 'getMainFields()', // 'getDefaultNumberOfRecords()' and 'getPrefAutoCompletions()', respectively. } // Clear the 'errors' and 'formVars' session variables so a future
is blank: deleteSessionVariable("errors"); // function 'deleteSessionVariable()' is defined in 'include.inc.php' deleteSessionVariable("formVars"); // ---------------------------------------------- // (4) Now show the user RECEIPT: header("Location: user_receipt.php?userID=$userID"); // (5) CLOSE the database connection: disconnectFromMySQLDatabase(); // function 'disconnectFromMySQLDatabase()' is defined in 'include.inc.php' // -------------------------------------------------------------------- ?>