<?php / Project: Web Reference Database (refbase) <http://www.refbase.net> / Copyright: Matthias Steffens <mailto:refbase@extracts.de> 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: ./update.php / Repository: $HeadURL: file:///svn/p/refbase/code/branches/bleeding-edge/update.php $ / Author(s): Matthias Steffens <mailto:refbase@extracts.de> / / Created: 01-Mar-05, 20:47 / Modified: $Date: 2015-02-16 20:53:19 +0000 (Mon, 16 Feb 2015) $ / $Author: karnesky $ / $Revision: 1405 $
/ This file will update any refbase MySQL database installation from v0.8.0 or greater to v0.9.6. / (Note that this script currently doesn't offer any conversion from 'latin1' to 'utf8') // CAUTION: YOU MUST REMOVE THIS SCRIPT FROM YOUR WEB DIRECTORY AFTER THE UPDATE!!
/ Incorporate some include files: include 'initialize/db.inc.php'; / 'db.inc.php' is included to hide username and password include 'includes/header.inc.php'; / include header include 'includes/footer.inc.php'; / include footer include 'includes/include.inc.php'; / include common functions include 'includes/install.inc.php'; / include install/update 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(false);
// ——————————————————————–
/ 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
// ——————————————————————–
/ This specifies the name of the database that handles the MySQL user access privileges. / Unless you've fiddled with it, you shouldn't change the default value ('mysql'): $adminDatabaseName = 'mysql';
// Extract any parameters passed to the script: if (isset($_REQUEST['adminUserName'])) $adminUserName = $_REQUEST['adminUserName']; else $adminUserName = "";
if (isset($_REQUEST['adminPassword'])) $adminPassword = $_REQUEST['adminPassword']; else $adminPassword = "";
// ——————————————————————–
// Check the correct parameters have been passed: if (empty($adminUserName) AND empty($adminPassword)) { / if 'update.php' was called without any valid parameters: / Display an update form:
if (isset($_SESSION['errors'])) { $errors = $_SESSION['errors'];
/ Note: though we clear the session variable, the current error message is still available to this script via '$errors': deleteSessionVariable("errors"); / function 'deleteSessionVariable()' is defined in 'include.inc.php' } else $errors = array(); // initialize the '$errors' variable in order to prevent 'Undefined variable…' messages
if (isset($_SESSION['formVars'])) { $formVars = $_SESSION['formVars'];
// Note: though we clear the session variable, the current form variables are still available to this script via '$formVars': deleteSessionVariable("formVars"); } else { // Reset the '$formVars' variable (since we're providing the default values): $formVars = array();
// provide the default values: $formVars["adminUserName"] = "root"; $formVars["adminPassword"] = ""; }
// If there's no stored message available: if (!isset($_SESSION['HeaderString'])) { if (empty($errors)) // provide the default message: $HeaderString = "To update refbase v0.8.0 or greater please fill out the form below and click the Update button:"; else // -> there were errors when validating the fields $HeaderString = "There were validation errors regarding the details you entered. Please check the comments above the respective fields:"; } else { $HeaderString = $_SESSION['HeaderString']; // extract 'HeaderString' session variable (only necessary if register globals is OFF!)
// Note: though we clear the session variable, the current message is still available to this script via '$HeaderString': deleteSessionVariable("HeaderString"); }
/ Extract the view type requested by the user (either 'Mobile', 'Print', 'Web' or ''): / ('' will produce the default 'Web' output style) if (isset($_REQUEST['viewType'])) $viewType = $_REQUEST['viewType']; else $viewType = "";
/ Show the login status: showLogin(); / (function 'showLogin()' is defined in 'include.inc.php')
/ DISPLAY header: / call the 'displayHTMLhead()' and 'showPageHeader()' functions (which are defined in 'header.inc.php'): displayHTMLhead(encodeHTML($officialDatabaseName) . " -- Update", "index,follow", "Update form for the " . encodeHTML($officialDatabaseName), "", false, "", $viewType, array()); showPageHeader($HeaderString);
// Start <form> and <table> holding the form elements: ?>
<form action="update.php" method="POST"> <input type="hidden" name="formType" value="update"> <input type="hidden" name="submit" value="Update"><?php // provide a default value for the 'submit' form tag. Otherwise, some browsers may not recognize the correct output format when a user hits <enter> within a form field (instead of clicking the "Update" button) ?>
<table align="center" border="0" cellpadding="0" cellspacing="12" width="95%" summary="This table holds the update form"> <tr> <td colspan="3"><h3>refbase Update</h3></td> </tr> <tr> <td width="190" valign="top"><b>Important Notes:</b></td> <td valign="top" colspan="2"> It's important that you make a <span class="warning">backup</span> copy of your original files <em>db.inc.php</em> and <em>ini.inc.php</em> (which are located within the <em>initialize</em> subdirectory of your refbase base directory). We also strongly recommend to <a href="http://backup.refbase.net/" target="top" title="Instructions how to backup your refbase MySQL database">backup</a> your existing refbase MySQL database before proceeding. <br> <br> Before executing this script, you <span class="warning">must edit</span> the updated include file <span class="warning"><em>initialize/db.inc.php</em></span> in a text editor and re-enter the values from your old <em>db.inc.php</em> file for the variables <em>$databaseName</em>, <em>$username</em> and <em>$password</em>. Then, proceed with this form: </td> </tr> <tr> <td valign="top"><b>MySQL Admin User:</b></td> <td valign="top"><?php echo fieldError("adminUserName", $errors); ?>
<input type="text" name="adminUserName" value="<?php echo encodeHTML($formVars["adminUserName"]); ?>" size="30"> </td> <td valign="top">Give the name of an administrative user that has full access to your MySQL database. Often, this is the <em>root</em> user.</td> </tr> <tr> <td valign="top"><b>MySQL Admin Password:</b></td> <td valign="top"><?php // the form won't remember the password, so we'll ask the user to re-type it... if (!empty($errors) AND !isset($errors["adminPassword"])) // ...if there were some validation errors but not with the password field echo "\n\t\t\t<b>Please type your password again:</b>\n\t\t\t<br>"; else echo fieldError("adminPassword", $errors); ?>
<input type="password" name="adminPassword" size="30"> </td> <td valign="top">Please enter the password for the administrative user you've specified above.</td> </tr> <tr> <td valign="top"> </td> <td valign="top" align="right"> <input type="submit" name="submit" value="Update"> </td> <td valign="top"> </td> </tr> </table> </form><?php
// ——————————————————————–
/ DISPLAY THE HTML FOOTER: / call the 'showPageFooter()' and 'displayHTMLfoot()' functions (which are defined in 'footer.inc.php') showPageFooter($HeaderString);
displayHTMLfoot();
// ——————————————————————–
} else // some parameters have been passed, so let's validate the fields: {
// ——————————————————————–
// 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;
// Validate the 'adminUserName' field: if (empty($formVars["adminUserName"])) // The 'adminUserName' field cannot be a null string $errors["adminUserName"] = "This field cannot be blank:";
// Validate the 'adminPassword' field: if (empty($formVars["adminPassword"])) // The 'adminPassword' field cannot be a null string $errors["adminPassword"] = "This field cannot be blank:";
// ——————————————————————–
// 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 update form: header("Location: update.php");
exit; // >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> !EXIT! <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< }
// ——————————————————————–
// If we made it here, then the data is considered valid!
/ (0) CLOSE EXISTING CONNECTION / we have to close the existing connection since we need to establish a new connection with admin permissions disconnectFromMySQLDatabase(); // function 'disconnectFromMySQLDatabase()' is defined in 'include.inc.php'
/ (1) OPEN ADMIN CONNECTION, (2) SELECT DATABASE connectToMySQLDatabaseAsAdmin($adminUserName, $adminPassword); / function 'connectToMySQLDatabaseAsAdmin()' is defined in 'install.inc.php'
// ——————————————————————–
// (2) RUN the SQL queries on the database through the admin connection:
/ NOTE: many simple, brain-dead UPDATE queries follow below / (we should probably have a SQL function and/or make this an array and process that)
$resultArray = array();
/ Alter table specification for table 'deleted' / TODO: create a new function 'changeColumn()' that only modifies the column spec if the new column spec is different from the old one $query = "ALTER table " . $tableDeleted . " MODIFY edition varchar(50) default NULL"; $result = queryMySQLDatabase($query); $resultArray["Table 'deleted': altered table specification. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0); // get the number of rows that were modified (or return 0 if an error occurred)
$query = "ALTER table " . $tableDeleted . " MODIFY thesis enum('Bachelor''s thesis','Honours thesis','Master''s thesis','Ph.D. thesis','Diploma thesis','Doctoral thesis','Habilitation thesis') default NULL"; $result = queryMySQLDatabase($query); $resultArray["Table 'deleted': altered table specification. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Alter table specification for table 'refs' $query = "ALTER table " . $tableRefs . " MODIFY edition varchar(50) default NULL"; $result = queryMySQLDatabase($query); $resultArray["Table 'refs': altered table specification. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "ALTER table " . $tableRefs . " MODIFY thesis enum('Bachelor''s thesis','Honours thesis','Master''s thesis','Ph.D. thesis','Diploma thesis','Doctoral thesis','Habilitation thesis') default NULL"; $result = queryMySQLDatabase($query); $resultArray["Table 'refs': altered table specification. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Add field 'version' to table 'deleted' $properties = "MEDIUMINT(8) UNSIGNED DEFAULT 1 AFTER modified_by"; $resultArray["Table 'deleted': added field 'version'"] = addColumnIfNotExists("version", $tableDeleted, $properties); // function 'addColumnIfNotExists()' is defined in 'install.inc.php'
// Add field 'version' to table 'refs' $properties = "MEDIUMINT(8) UNSIGNED DEFAULT 1 AFTER modified_by"; $resultArray["Table 'refs': added field 'version'"] = addColumnIfNotExists("version", $tableRefs, $properties);
/ Update table 'refs' $query = "UPDATE " . $tableRefs . " SET thesis = NULL WHERE thesis = ''"; / this fix is required to ensure correct sorting when outputting citations with '$citeOrder="type"' or '$citeOrder="type-year"' $result = queryMySQLDatabase($query); $resultArray["Table 'refs': updated 'thesis' field (replaced empty string with NULL). Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableRefs . " SET type = 'Conference Article' WHERE type RLIKE '^(Unsupported: )?Conference Proceeding$'"; // this may not be perfect since some items of type "Conference Proceeding" may be actually a "Conference Volume" $result = queryMySQLDatabase($query); $resultArray["Table 'refs': updated 'type' field ('Conference Proceeding' => 'Conference Article'). Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableRefs . " SET type = 'Miscellaneous' WHERE type RLIKE '^(Unsupported: )?Generic$'"; $result = queryMySQLDatabase($query); $resultArray["Table 'refs': updated 'type' field ('Generic' => 'Miscellaneous'). Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableRefs . " SET type = 'Newspaper Article' WHERE type RLIKE '^(Unsupported: )?Newspaper$'"; // this may not be perfect since some items of type "Newspaper" may be actually a "Newspaper Volume" $result = queryMySQLDatabase($query); $resultArray["Table 'refs': updated 'type' field ('Newspaper' => 'Newspaper Article'). Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableRefs . " SET type = 'Software' WHERE type RLIKE '^(Unsupported: )?Computer Program$'"; $result = queryMySQLDatabase($query); $resultArray["Table 'refs': updated 'type' field ('Computer Program' => 'Software'). Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableRefs . " SET type = REPLACE(type,'Unsupported: ','') WHERE type RLIKE '^Unsupported: (Abstract|Conference (Article|Volume)|Magazine Article|Manual|Miscellaneous|Newspaper Article|Patent|Report|Software)$'"; $result = queryMySQLDatabase($query); $resultArray["Table 'refs': updated 'type' field (removed 'Unsupported' label for all newly supported types). Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Add new utilities to table 'depends' $values = "(NULL, 'pdftotext', 'true', NULL)"; $resultArray["Table 'depends': inserted entry for 'pdftotext' utility"] = insertIfNotExists(array("depends_external" => "pdftotext"), $tableDepends, $values);
// Create new MySQL table 'user_options' $properties = "(option_id MEDIUMINT(8) UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, " . "user_id MEDIUMINT(8) UNSIGNED NOT NULL DEFAULT '0', " . "export_cite_keys ENUM('yes','no') NOT NULL DEFAULT 'yes', " . "autogenerate_cite_keys ENUM('yes','no') NOT NULL DEFAULT 'yes', " . "prefer_autogenerated_cite_keys ENUM('no','yes') NOT NULL DEFAULT 'no', " . "use_custom_cite_key_format ENUM('no','yes') NOT NULL DEFAULT 'no', " . "cite_key_format VARCHAR(255) DEFAULT NULL, " . "uniquify_duplicate_cite_keys ENUM('yes','no') NOT NULL DEFAULT 'yes', " . "nonascii_chars_in_cite_keys ENUM('transliterate','strip','keep') DEFAULT NULL, " . "use_custom_text_citation_format ENUM('no','yes') NOT NULL DEFAULT 'no', " . "text_citation_format VARCHAR(255) DEFAULT NULL, " . "records_per_page SMALLINT(5) UNSIGNED DEFAULT NULL, " . "show_auto_completions ENUM('yes','no') NOT NULL DEFAULT 'yes', " . "main_fields TEXT, " . "INDEX (user_id))";
$resultArray["Created table 'user_options'"] = addTableIfNotExists($tableUserOptions, $properties); // function 'addTableIfNotExists()' is defined in 'install.inc.php'
// Insert default user options for anyone who's not logged in $values = "(NULL, 0, 'yes', 'yes', 'no', 'no', '<:authors:><:year:>', 'yes', NULL, 'no', '<:authors[2| & | et al.]:>< :year:>< {:recordIdentifier:}>', NULL, 'author, title, publication, keywords, abstract')"; $resultArray["Table 'user_options': inserted default options for anyone who's not logged in"] = insertIfNotExists(array("user_id" => 0), $tableUserOptions, $values); // function 'insertIfNotExists()' is defined in 'install.inc.php'
/ Insert default user options for all users / First, check how many users are contained in table 'users': $query = "SELECT user_id, first_name, last_name FROM " . $tableUsers; $result = queryMySQLDatabase($query); // function 'queryMySQLDatabase()' is defined in 'include.inc.php' $rowsFound = @ mysql_num_rows($result); if ($rowsFound > 0) // If there were rows (= user IDs) found ... { while ($row = @ mysql_fetch_array($result)) { $values = "(NULL, " . $row['user_id'] . ", 'yes', 'yes', 'no', 'yes', '<:authors[2|+|++]:><:year:>', 'yes', 'transliterate', 'no', '<:authors[2| & | et al.]:>< :year:>< {:recordIdentifier:}>', NULL, 'author, title, publication, keywords, abstract')"; $resultArray["Table 'user_options': inserted default options for user " . $row['user_id'] . " (" . $row['first_name'] . " " . $row['last_name'] . ")"] = insertIfNotExists(array("user_id" => $row['user_id']), $tableUserOptions, $values); } }
// Add field 'records_per_page' to table 'user_options' $properties = "SMALLINT(5) UNSIGNED DEFAULT NULL AFTER text_citation_format"; $resultArray["Table 'user_options': added field 'records_per_page'"] = addColumnIfNotExists("records_per_page", $tableUserOptions, $properties);
// Add field 'show_auto_completions' to table 'user_options' $properties = "ENUM('yes','no') NOT NULL DEFAULT 'yes' AFTER records_per_page"; $resultArray["Table 'user_options': added field 'show_auto_completions'"] = addColumnIfNotExists("show_auto_completions", $tableUserOptions, $properties);
// Add field 'main_fields' to table 'user_options' $properties = "TEXT AFTER show_auto_completions"; $resultArray["Table 'user_options': added field 'main_fields'"] = addColumnIfNotExists("main_fields", $tableUserOptions, $properties);
// Add field 'allow_browse_view' to table 'user_permissions' $properties = "ENUM('yes','no') NOT NULL DEFAULT 'yes' AFTER allow_print_view"; $resultArray["Table 'user_permissions': added field 'allow_browse_view'"] = addColumnIfNotExists("allow_browse_view", $tableUserPermissions, $properties);
// Add field 'allow_list_view' to table 'user_permissions' $properties = "ENUM('yes','no') NOT NULL DEFAULT 'yes' AFTER allow_upload"; $resultArray["Table 'user_permissions': added field 'allow_list_view'"] = addColumnIfNotExists("allow_list_view", $tableUserPermissions, $properties);
// Disable the Browse view feature (which isn't done yet) for all users $query= "UPDATE " . $tableUserPermissions . " SET allow_browse_view = 'no'"; $result = queryMySQLDatabase($query); $resultArray["Table 'user_permissions': disabled the Browse view feature (which isn't done yet). Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Enable the Export feature for anyone who's not logged in ('$userID = 0'): $query= "UPDATE " . $tableUserPermissions . " SET allow_export = 'yes', allow_batch_export = 'yes' WHERE user_id = 0"; $result = queryMySQLDatabase($query); $resultArray["Table 'user_permissions': enabled the export feature for anyone who's not logged in. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Update table 'styles' $query = "UPDATE " . $tableStyles . " SET style_spec = REPLACE(style_spec,'cite_','styles/cite_') WHERE style_spec RLIKE '^cite_'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'style_spec' field. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$values = "(NULL, 'Ann Glaciol', 'true', 'styles/cite_AnnGlaciol_JGlaciol.php', 'B010', '1')"; $resultArray["Table 'styles': inserted style 'Ann Glaciol'"] = insertIfNotExists(array("style_name" => "Ann Glaciol"), $tableStyles, $values);
$values = "(NULL, 'J Glaciol', 'true', 'styles/cite_AnnGlaciol_JGlaciol.php', 'B030', '1')"; $resultArray["Table 'styles': inserted style 'J Glaciol'"] = insertIfNotExists(array("style_name" => "J Glaciol"), $tableStyles, $values);
$values = "(NULL, 'APA', 'true', 'styles/cite_APA.php', 'A010', '1')"; $resultArray["Table 'styles': inserted style 'APA'"] = insertIfNotExists(array("style_name" => "APA"), $tableStyles, $values);
$values = "(NULL, 'AMA', 'true', 'styles/cite_AMA.php', 'A020', '1')"; $resultArray["Table 'styles': inserted style 'AMA'"] = insertIfNotExists(array("style_name" => "AMA"), $tableStyles, $values);
$values = "(NULL, 'MLA', 'true', 'styles/cite_MLA.php', 'A030', '1')"; $resultArray["Table 'styles': inserted style 'MLA'"] = insertIfNotExists(array("style_name" => "MLA"), $tableStyles, $values);
$values = "(NULL, 'Chicago', 'true', 'styles/cite_Chicago.php', 'A070', '1')"; $resultArray["Table 'styles': inserted style 'Chicago'"] = insertIfNotExists(array("style_name" => "Chicago"), $tableStyles, $values);
$values = "(NULL, 'Harvard 1', 'true', 'styles/cite_Harvard_1.php', 'A090', '1')"; $resultArray["Table 'styles': inserted style 'Harvard 1'"] = insertIfNotExists(array("style_name" => "Harvard 1"), $tableStyles, $values);
$values = "(NULL, 'Harvard 2', 'true', 'styles/cite_Harvard_2.php', 'A093', '1')"; $resultArray["Table 'styles': inserted style 'Harvard 2'"] = insertIfNotExists(array("style_name" => "Harvard 2"), $tableStyles, $values);
$values = "(NULL, 'Harvard 3', 'true', 'styles/cite_Harvard_3.php', 'A096', '1')"; $resultArray["Table 'styles': inserted style 'Harvard 3'"] = insertIfNotExists(array("style_name" => "Harvard 3"), $tableStyles, $values);
$values = "(NULL, 'Vancouver', 'true', 'styles/cite_Vancouver.php', 'A110', '1')"; $resultArray["Table 'styles': inserted style 'Vancouver'"] = insertIfNotExists(array("style_name" => "Vancouver"), $tableStyles, $values);
$query = "UPDATE " . $tableStyles . " SET order_by = 'B010' WHERE style_name = 'Ann Glaciol'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'Ann Glaciol' style. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableStyles . " SET order_by = 'B020' WHERE style_name = 'Deep Sea Res'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'Deep Sea Res' style. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableStyles . " SET order_by = 'B030' WHERE style_name = 'J Glaciol'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'J Glaciol' style. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableStyles . " SET order_by = 'B040' WHERE style_name = 'Mar Biol'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'Mar Biol' style. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableStyles . " SET order_by = 'B050' WHERE style_name = 'MEPS'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'MEPS' style. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableStyles . " SET order_by = 'B060' WHERE style_name = 'Polar Biol'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'Polar Biol' style. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableStyles . " SET order_by = 'C010' WHERE style_name = 'Text Citation'"; $result = queryMySQLDatabase($query); $resultArray["Table 'styles': updated 'Text Citation' style. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Update table 'types' $query = "UPDATE " . $tableTypes . " SET order_by = '01' WHERE type_name = 'Journal Article'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Journal Article' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '02' WHERE type_name = 'Abstract'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Abstract' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '03' WHERE type_name = 'Book Chapter'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Book Chapter' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '04' WHERE type_name = 'Book Whole'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Book Whole' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '05' WHERE type_name = 'Conference Article'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Conference Article' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '06' WHERE type_name = 'Conference Volume'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Conference Volume' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '07' WHERE type_name = 'Journal'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Journal' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '08' WHERE type_name = 'Magazine Article'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Magazine Article' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '09' WHERE type_name = 'Manual'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Manual' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '10' WHERE type_name = 'Manuscript'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Manuscript' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '11' WHERE type_name = 'Map'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Map' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '12' WHERE type_name = 'Miscellaneous'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Miscellaneous' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '13' WHERE type_name = 'Newspaper Article'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Newspaper Article' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '14' WHERE type_name = 'Patent'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Patent' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '15' WHERE type_name = 'Report'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Report' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableTypes . " SET order_by = '16' WHERE type_name = 'Software'"; $result = queryMySQLDatabase($query); $resultArray["Table 'types': updated 'Software' type. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$values = "(NULL, 'Abstract', 'true', 2, '02')"; $resultArray["Table 'types': inserted type 'Abstract'"] = insertIfNotExists(array("type_name" => "Abstract"), $tableTypes, $values);
$values = "(NULL, 'Conference Article', 'true', 2, '05')"; $resultArray["Table 'types': inserted type 'Conference Article'"] = insertIfNotExists(array("type_name" => "Conference Article"), $tableTypes, $values);
$values = "(NULL, 'Conference Volume', 'true', 3, '06')"; $resultArray["Table 'types': inserted type 'Conference Volume'"] = insertIfNotExists(array("type_name" => "Conference Volume"), $tableTypes, $values);
$values = "(NULL, 'Magazine Article', 'true', 1, '08')"; $resultArray["Table 'types': inserted type 'Magazine Article'"] = insertIfNotExists(array("type_name" => "Magazine Article"), $tableTypes, $values);
$values = "(NULL, 'Manual', 'true', 3, '09')"; $resultArray["Table 'types': inserted type 'Manual'"] = insertIfNotExists(array("type_name" => "Manual"), $tableTypes, $values);
$values = "(NULL, 'Miscellaneous', 'true', 3, '12')"; $resultArray["Table 'types': inserted type 'Miscellaneous'"] = insertIfNotExists(array("type_name" => "Miscellaneous"), $tableTypes, $values);
$values = "(NULL, 'Newspaper Article', 'true', 1, '13')"; $resultArray["Table 'types': inserted type 'Newspaper Article'"] = insertIfNotExists(array("type_name" => "Newspaper Article"), $tableTypes, $values);
$values = "(NULL, 'Patent', 'true', 3, '14')"; $resultArray["Table 'types': inserted type 'Patent'"] = insertIfNotExists(array("type_name" => "Patent"), $tableTypes, $values);
$values = "(NULL, 'Report', 'true', 3, '15')"; $resultArray["Table 'types': inserted type 'Report'"] = insertIfNotExists(array("type_name" => "Report"), $tableTypes, $values);
$values = "(NULL, 'Software', 'true', 3, '16')"; $resultArray["Table 'types': inserted type 'Software'"] = insertIfNotExists(array("type_name" => "Software"), $tableTypes, $values);
// Add new language options to table 'languages' $values = "(NULL, 'fr', 'true', '3')"; $resultArray["Table 'languages': inserted French language option"] = insertIfNotExists(array("language_name" => "fr"), $tableLanguages, $values);
$values = "(NULL, 'es', 'false', '4')"; $resultArray["Table 'languages': inserted Spanish language option"] = insertIfNotExists(array("language_name" => "es"), $tableLanguages, $values);
$values = "(NULL, 'cn', 'true', '5')"; $resultArray["Table 'languages': inserted Chinese language option"] = insertIfNotExists(array("language_name" => "cn"), $tableLanguages, $values);
$values = "(NULL, 'ru', 'true', '6')"; $resultArray["Table 'languages': inserted Russian language option"] = insertIfNotExists(array("language_name" => "ru"), $tableLanguages, $values);
$values = "(NULL, 'ja', 'true', '7')"; $resultArray["Table 'languages': inserted Japanese language option"] = insertIfNotExists(array("language_name" => "ja"), $tableLanguages, $values);
// Enable disabled localizations $query = "UPDATE " . $tableLanguages . " SET language_enabled = 'true' WHERE language_name = 'de'"; $result = queryMySQLDatabase($query); $resultArray["Table 'languages': enabled German language option. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Alter table specification for table 'formats' $query = "ALTER table " . $tableFormats . " MODIFY format_type enum('export','import','cite') NOT NULL default 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': altered table specification. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Update existing formats in table 'formats' $query = "UPDATE " . $tableFormats . " SET format_name = 'BibTeX' WHERE format_name = 'Bibtex'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': renamed format name 'Bibtex' to 'BibTeX'. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Update existing import formats in table 'formats' $query = "UPDATE " . $tableFormats . " SET format_spec = 'bibutils/import_bib2refbase.php', order_by = 'A010' WHERE format_name = 'BibTeX' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'BibTeX' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A020' WHERE format_name = 'Copac' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Copac' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A030' WHERE format_name = 'CSA' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'CSA' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET format_spec = 'bibutils/import_end2refbase.php', order_by = 'A040' WHERE format_name = 'Endnote' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Endnote' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A045' WHERE format_name = 'Endnote XML' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Endnote XML' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET format_name = 'ISI', format_spec = 'import_isi2refbase.php', order_by = 'A050', depends_id = 1 WHERE (format_name = 'RIS (ISI)' OR format_name = 'ISI') AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'ISI' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A060' WHERE format_name = 'Pubmed Medline' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Pubmed Medline' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET format_spec = 'bibutils/import_med2refbase.php', order_by = 'A065' WHERE format_name = 'Pubmed XML' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Pubmed XML' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A070' WHERE format_name = 'RefWorks' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'RefWorks' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET format_spec = 'import_ris2refbase.php', order_by = 'A080', depends_id = 1 WHERE format_name = 'RIS' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'RIS' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A090' WHERE format_name = 'SciFinder' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'SciFinder' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A100' WHERE format_name = 'Text (Tab-Delimited)' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Text (Tab-Delimited)' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A150' WHERE format_name = 'CrossRef XML' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'CrossRef XML' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET format_spec = 'bibutils/import_modsxml2refbase.php', order_by = 'A160', depends_id = 2 WHERE format_name = 'MODS XML' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'MODS XML' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'A170' WHERE format_name = 'OAI_DC XML' AND format_type = 'import'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'OAI_DC XML' import format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Add new import formats in table 'formats' $values = "(NULL, 'Copac', 'import', 'true', 'bibutils/import_copac2refbase.php', 'A020', 2)"; $resultArray["Table 'formats': inserted 'Copac' import format"] = insertIfNotExists(array("format_name" => "Copac", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'CSA', 'import', 'true', 'import_csa2refbase.php', 'A030', 1)"; $resultArray["Table 'formats': inserted 'CSA' import format"] = insertIfNotExists(array("format_name" => "CSA", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'Endnote XML', 'import', 'true', 'bibutils/import_endx2refbase.php', 'A045', 2)"; $resultArray["Table 'formats': inserted 'Endnote XML' import format"] = insertIfNotExists(array("format_name" => "Endnote XML", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'Pubmed Medline', 'import', 'true', 'import_medline2refbase.php', 'A060', 1)"; $resultArray["Table 'formats': inserted 'Pubmed Medline' import format"] = insertIfNotExists(array("format_name" => "Pubmed Medline", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'RefWorks', 'import', 'true', 'import_refworks2refbase.php', 'A070', 1)"; $resultArray["Table 'formats': inserted 'RefWorks' import format"] = insertIfNotExists(array("format_name" => "RefWorks", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'SciFinder', 'import', 'true', 'import_scifinder2refbase.php', 'A090', 1)"; $resultArray["Table 'formats': inserted 'SciFinder' import format"] = insertIfNotExists(array("format_name" => "SciFinder", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'Text (Tab-Delimited)', 'import', 'true', 'import_tabdelim2refbase.php', 'A100', 1)"; $resultArray["Table 'formats': inserted 'Text (Tab-Delimited)' import format"] = insertIfNotExists(array("format_name" => "Text (Tab-Delimited)", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'arXiv XML', 'import', 'true', 'import_arxiv2refbase.php', 'A130', 1)"; $resultArray["Table 'formats': inserted 'arXiv XML' import format"] = insertIfNotExists(array("format_name" => "arXiv XML", "format_type" => "import"), $tableFormats, $values);
$values = "(NULL, 'CrossRef XML', 'import', 'true', 'import_crossref2refbase.php', 'A150', 1)"; $resultArray["Table 'formats': inserted 'CrossRef XML' import format"] = insertIfNotExists(array("format_name" => "CrossRef XML", "format_type" => "import"), $tableFormats, $values);
// Update existing export formats in table 'formats' $query = "UPDATE " . $tableFormats . " SET order_by = 'B010' WHERE format_name = 'BibTeX' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'BibTeX' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B040' WHERE format_name = 'Endnote' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Endnote' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B050' WHERE format_name = 'ISI' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'ISI' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B080' WHERE format_name = 'RIS' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'RIS' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B105' WHERE format_name = 'Text (CSV)' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Text (CSV)' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET format_name = 'Atom XML', format_enabled = 'true', format_spec ='export_atomxml.php', order_by = 'B140' WHERE format_name = 'OpenSearch RSS' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'OpenSearch RSS' export format, and renamed it to 'Atom XML'. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B160' WHERE format_name = 'MODS XML' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'MODS XML' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B170' WHERE format_name = 'OAI_DC XML' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'OAI_DC XML' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B180' WHERE format_name = 'ODF XML' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'ODF XML' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET format_name = 'SRW_MODS XML', order_by = 'B195' WHERE format_name = 'SRW XML' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'SRW XML' export format, and renamed it to 'SRW_MODS XML'. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'B200' WHERE format_name = 'Word XML' AND format_type = 'export'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Word XML' export format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Add new export formats in table 'formats' $values = "(NULL, 'ADS', 'export', 'true', 'bibutils/export_xml2ads.php', 'B005', 2)"; $resultArray["Table 'formats': inserted 'ADS' export format"] = insertIfNotExists(array("format_name" => "ADS", "format_type" => "export"), $tableFormats, $values);
$values = "(NULL, 'ISI', 'export', 'true', 'bibutils/export_xml2isi.php', 'B050', 2)"; $resultArray["Table 'formats': inserted 'ISI' export format"] = insertIfNotExists(array("format_name" => "ISI", "format_type" => "export"), $tableFormats, $values);
$values = "(NULL, 'Atom XML', 'export', 'true', 'export_atomxml.php', 'B140', 1)"; $resultArray["Table 'formats': inserted 'Atom XML' export format"] = insertIfNotExists(array("format_name" => "Atom XML", "format_type" => "export"), $tableFormats, $values);
$values = "(NULL, 'OAI_DC XML', 'export', 'true', 'export_oaidcxml.php', 'B170', 1)"; $resultArray["Table 'formats': inserted 'OAI_DC XML' export format"] = insertIfNotExists(array("format_name" => "OAI_DC XML", "format_type" => "export"), $tableFormats, $values);
$values = "(NULL, 'ODF XML', 'export', 'true', 'export_odfxml.php', 'B180', 1)"; $resultArray["Table 'formats': inserted 'ODF XML' export format"] = insertIfNotExists(array("format_name" => "ODF XML", "format_type" => "export"), $tableFormats, $values);
$values = "(NULL, 'SRW_DC XML', 'export', 'true', 'export_srwxml.php', 'B190', 1)"; $resultArray["Table 'formats': inserted 'SRW_DC XML' export format"] = insertIfNotExists(array("format_name" => "SRW_DC XML", "format_type" => "export"), $tableFormats, $values);
$values = "(NULL, 'SRW_MODS XML', 'export', 'true', 'export_srwxml.php', 'B195', 1)"; $resultArray["Table 'formats': inserted 'SRW_MODS XML' export format"] = insertIfNotExists(array("format_name" => "SRW_MODS XML", "format_type" => "export"), $tableFormats, $values);
$values = "(NULL, 'Word XML', 'export', 'true', 'bibutils/export_xml2word.php', 'B200', 2)"; $resultArray["Table 'formats': inserted 'Word XML' export format"] = insertIfNotExists(array("format_name" => "Word XML", "format_type" => "export"), $tableFormats, $values);
// Update existing citation formats in table 'formats' $query = "UPDATE " . $tableFormats . " SET order_by = 'C010' WHERE format_name = 'html' AND format_type = 'cite'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'html' citation format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'C020' WHERE format_name = 'RTF' AND format_type = 'cite'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'RTF' citation format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'C030' WHERE format_name = 'PDF' AND format_type = 'cite'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'PDF' citation format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'C040' WHERE format_name = 'LaTeX' AND format_type = 'cite'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'LaTeX' citation format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'C045' WHERE format_name = 'LaTeX .bbl' AND format_type = 'cite'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'LaTeX .bbl' citation format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'C050' WHERE format_name = 'Markdown' AND format_type = 'cite'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'Markdown' citation format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
$query = "UPDATE " . $tableFormats . " SET order_by = 'C060' WHERE format_name = 'ASCII' AND format_type = 'cite'"; $result = queryMySQLDatabase($query); $resultArray["Table 'formats': updated 'ASCII' citation format. Affected rows"] = ($result ? mysql_affected_rows($connection) : 0);
// Add new citation formats in table 'formats' $values = "(NULL, 'html', 'cite', 'true', 'formats/cite_html.php', 'C010', 1)"; $resultArray["Table 'formats': inserted 'html' citation format"] = insertIfNotExists(array("format_name" => "html", "format_type" => "cite"), $tableFormats, $values);
$values = "(NULL, 'RTF', 'cite', 'true', 'formats/cite_rtf.php', 'C020', 1)"; $resultArray["Table 'formats': inserted 'RTF' citation format"] = insertIfNotExists(array("format_name" => "RTF", "format_type" => "cite"), $tableFormats, $values);
$values = "(NULL, 'PDF', 'cite', 'true', 'formats/cite_pdf.php', 'C030', 1)"; $resultArray["Table 'formats': inserted 'PDF' citation format"] = insertIfNotExists(array("format_name" => "PDF", "format_type" => "cite"), $tableFormats, $values);
$values = "(NULL, 'LaTeX', 'cite', 'true', 'formats/cite_latex.php', 'C040', 1)"; $resultArray["Table 'formats': inserted 'LaTeX' citation format"] = insertIfNotExists(array("format_name" => "LaTeX", "format_type" => "cite"), $tableFormats, $values);
$values = "(NULL, 'LaTeX .bbl', 'cite', 'true', 'formats/cite_latex_bbl.php', 'C045', 1)"; $resultArray["Table 'formats': inserted 'LaTeX .bbl' citation format"] = insertIfNotExists(array("format_name" => "LaTeX .bbl", "format_type" => "cite"), $tableFormats, $values);
$values = "(NULL, 'Markdown', 'cite', 'true', 'formats/cite_markdown.php', 'C050', 1)"; $resultArray["Table 'formats': inserted 'Markdown' citation format"] = insertIfNotExists(array("format_name" => "Markdown", "format_type" => "cite"), $tableFormats, $values);
$values = "(NULL, 'ASCII', 'cite', 'true', 'formats/cite_ascii.php', 'C060', 1)"; $resultArray["Table 'formats': inserted 'ASCII' citation format"] = insertIfNotExists(array("format_name" => "ASCII", "format_type" => "cite"), $tableFormats, $values);
/ Enable some of the existing export formats (which were previously disabled by default) for anyone who's not logged in ('$userID = 0'): / Fetch IDs for all formats that shall be enabled: $formatIDArray = array(); $query = "SELECT format_id, format_name FROM " . $tableFormats . " WHERE (format_name RLIKE '^(BibTeX|Endnote|RIS)$' AND format_type = 'export')"; $result = queryMySQLDatabase($query); $rowsFound = @ mysql_num_rows($result); if ($rowsFound > 0) { while ($row = @ mysql_fetch_array($result)) $formatIDArray[$row['format_id']] = $row['format_name']; }
foreach ($formatIDArray as $formatID => $formatName) { $values = "(NULL, " . $formatID . ", 0, 'true')"; $resultArray["Table 'user_formats': enabled format '" . $formatName . "' for anyone who's not logged in"] = insertIfNotExists(array("format_id" => $formatID), $tableUserFormats, $values, "0"); }
/ Enable some of the newly created export/citation formats, citation styles & resource types for all users: / Fetch IDs for all formats that shall be enabled: $formatIDArray = array(); $query = "SELECT format_id, format_name FROM " . $tableFormats . " WHERE (format_name RLIKE '^(ISI|ODF XML|Word XML)$' AND format_type = 'export') OR (format_name RLIKE '^(html|RTF|PDF|LaTeX)$' AND format_type = 'cite')"; $result = queryMySQLDatabase($query); $rowsFound = @ mysql_num_rows($result); if ($rowsFound > 0) { while ($row = @ mysql_fetch_array($result)) $formatIDArray[$row['format_id']] = $row['format_name']; }
// Fetch IDs for all styles that shall be enabled: $styleIDArray = array(); $query = "SELECT style_id, style_name FROM " . $tableStyles . " WHERE style_name RLIKE '^(AMA|APA|Chicago|Harvard( [0-9]+)?|J Glaciol|MLA|Vancouver)$'"; $result = queryMySQLDatabase($query); $rowsFound = @ mysql_num_rows($result); if ($rowsFound > 0) { while ($row = @ mysql_fetch_array($result)) $styleIDArray[$row['style_id']] = $row['style_name']; }
// Fetch IDs for all types that shall be enabled: $typeIDArray = array(); $query = "SELECT type_id, type_name FROM " . $tableTypes . " WHERE type_name RLIKE '^(Abstract|Conference Article|Conference Volume|Magazine Article|Manual|Miscellaneous|Newspaper Article|Patent|Report|Software)$'"; $result = queryMySQLDatabase($query); $rowsFound = @ mysql_num_rows($result); if ($rowsFound > 0) { while ($row = @ mysql_fetch_array($result)) $typeIDArray[$row['type_id']] = $row['type_name']; }
// Enable formats, styles & types for anyone who's not logged in ('$userID = 0'): foreach ($formatIDArray as $formatID => $formatName) { $values = "(NULL, " . $formatID . ", 0, 'true')"; $resultArray["Table 'user_formats': enabled format '" . $formatName . "' for anyone who's not logged in"] = insertIfNotExists(array("format_id" => $formatID), $tableUserFormats, $values, "0"); }
foreach ($styleIDArray as $styleID => $styleName) { $values = "(NULL, " . $styleID . ", 0, 'true')"; $resultArray["Table 'user_styles': enabled style '" . $styleName . "' for anyone who's not logged in"] = insertIfNotExists(array("style_id" => $styleID), $tableUserStyles, $values, "0"); }
foreach ($typeIDArray as $typeID => $typeName) { $values = "(NULL, " . $typeID . ", 0, 'true')"; $resultArray["Table 'user_types': enabled type '" . $typeName . "' for anyone who's not logged in"] = insertIfNotExists(array("type_id" => $typeID), $tableUserTypes, $values, "0"); }
/ Enable formats, styles & types for all users: / First, check how many users are contained in table 'users': $query = "SELECT user_id, first_name, last_name FROM " . $tableUsers; $result = queryMySQLDatabase($query); $rowsFound = @ mysql_num_rows($result); if ($rowsFound > 0) // If there were rows (= user IDs) found ... { while ($row = @ mysql_fetch_array($result)) { foreach ($formatIDArray as $formatID => $formatName) { $values = "(NULL, " . $formatID . ", " . $row['user_id'] . ", 'true')"; $resultArray["Table 'user_formats': enabled format '" . $formatName . "' for user " . $row['user_id'] . " (" . $row['first_name'] . " " . $row['last_name'] . ")"] = insertIfNotExists(array("format_id" => $formatID), $tableUserFormats, $values, $row['user_id']); }
foreach ($styleIDArray as $styleID => $styleName) { $values = "(NULL, " . $styleID . ", " . $row['user_id'] . ", 'true')"; $resultArray["Table 'user_styles': enabled style '" . $styleName . "' for user " . $row['user_id'] . " (" . $row['first_name'] . " " . $row['last_name'] . ")"] = insertIfNotExists(array("style_id" => $styleID), $tableUserStyles, $values, $row['user_id']); }
foreach ($typeIDArray as $typeID => $typeName) { $values = "(NULL, " . $typeID . ", " . $row['user_id'] . ", 'true')"; $resultArray["Table 'user_types': enabled type '" . $typeName . "' for user " . $row['user_id'] . " (" . $row['first_name'] . " " . $row['last_name'] . ")"] = insertIfNotExists(array("type_id" => $typeID), $tableUserTypes, $values, $row['user_id']); } } }
// (3) ERRORS
/ Check whether any tables/rows were affected by the performed SQL queries: unset($resultArray["Table 'deleted': altered table specification. Affected rows"]); / currently, we simply remove again the results of the 'ALTER TABLE' queries since they will always affect every row in that table unset($resultArray["Table 'refs': altered table specification. Affected rows"]); unset($resultArray["Table 'formats': altered table specification. Affected rows"]);
foreach($resultArray as $varname > $value)
if (($value =
"0") OR ($value == "false"))
unset($resultArray[$varname]); // remove any action that didn't affect any table or rows
if (empty($resultArray)) { $HeaderString = "Nothing was changed! Your refbase installation is up-to-date.";
// Write back session variables: saveSessionVariable("HeaderString", $HeaderString); }
// (4) CLOSE ADMIN CONNECTION disconnectFromMySQLDatabase();
// ——————————————————————–
// Provide a feedback page:
/ If there's no stored message available: if (!isset($_SESSION['HeaderString'])) / provide a default message: { $HeaderString = "Update of the Web Reference Database was successful!"; } else { $HeaderString = $_SESSION['HeaderString']; // extract 'HeaderString' session variable (only necessary if register globals is OFF!)
// Note: though we clear the session variable, the current message is still available to this script via '$HeaderString': deleteSessionVariable("HeaderString"); }
/ Extract the view type requested by the user (either 'Mobile', 'Print', 'Web' or ''): / ('' will produce the default 'Web' output style) if (isset($_REQUEST['viewType'])) $viewType = $_REQUEST['viewType']; else $viewType = "";
/ Show the login status: showLogin(); / (function 'showLogin()' is defined in 'include.inc.php')
/ DISPLAY header: / call the 'displayHTMLhead()' and 'showPageHeader()' functions (which are defined in 'header.inc.php'): displayHTMLhead(encodeHTML($officialDatabaseName) . " -- Update Feedback", "index,follow", "Update feedback for the " . encodeHTML($officialDatabaseName), "", false, "", $viewType, array()); showPageHeader($HeaderString);
// Start a <table>: ?>
<table align="center" border="0" cellpadding="0" cellspacing="10" width="95%" summary="This table holds the update feedback info"><?php
if (!empty($resultArray)) // if something was changed, add a welcome title: { ?>
<tr> <td colspan="2"><h3>Welcome to refbase v0.9.6!</h3></td> </tr><?php
}
// following note will be always displayed no matter if something was changed or not: ?>
<tr> <td valign="top"><b>Important Note:</b></td> <td> The files <em>update.php</em> and <em>update.sql</em> (as well as <em>install.php</em> and <em>install.sql</em>) are only provided for update/installation purposes and are not needed anymore. Due to security considerations you should <span class="warning">remove these files</span> from your web directory NOW!! </td> </tr><?php
if (!empty($resultArray)) // if something was changed, add some configuration info: { ?>
<tr> <td valign="top"><b>Configure refbase:</b></td> <td> In order to re-establish your existing settings, please open file <em>initialize/ini.inc.php</em> in a text editor and restore all values from your old <em>ini.inc.php</em> file. The new include file contains new settings which you should check out and adopt to your needs if needed. Please see the comments within the file for further information. </td> </tr> <tr> <td valign="top"><b>Log:</b></td> <td> Following update actions were performed successfully: </td> </tr> <tr> <td valign="top"> </td> <td> <pre><?php
foreach($resultArray as $varname => $value) { if ($value == "true") echo $varname . ".\n"; else echo $varname . ": " . $value . "\n"; } ?> </pre> </td> </tr><?php
} ?>
</table><?php
// ——————————————————————–
/ DISPLAY THE HTML FOOTER: / call the 'showPageFooter()' and 'displayHTMLfoot()' functions (which are defined in 'footer.inc.php') showPageFooter($HeaderString);
displayHTMLfoot();
// ——————————————————————–
} ?>