You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

234 lines
11 KiB

  1. <?php
  2. // Project: Web Reference Database (refbase) <http://www.refbase.net>
  3. // Copyright: Matthias Steffens <mailto:refbase@extracts.de> and the file's
  4. // original author(s).
  5. //
  6. // This code is distributed in the hope that it will be useful,
  7. // but WITHOUT ANY WARRANTY. Please see the GNU General Public
  8. // License for more details.
  9. //
  10. // File: ./duplicate_manager.php
  11. // Repository: $HeadURL: file:///svn/p/refbase/code/branches/bleeding-edge/duplicate_manager.php $
  12. // Author(s): Matthias Steffens <mailto:refbase@extracts.de>
  13. //
  14. // Created: 27-Jan-07, 21:18
  15. // Modified: $Date: 2015-02-16 20:53:19 +0000 (Mon, 16 Feb 2015) $
  16. // $Author: karnesky $
  17. // $Revision: 1405 $
  18. // This script enables you to manually manage duplicate records by entering their database serial numbers
  19. // into the provided form. The form lets you flag (i.e. identify) an "original" record and its related
  20. // duplicate entries. The script will then update the 'orig_record' field in table 'refs' accordingly.
  21. // TODO: I18n
  22. // Incorporate some include files:
  23. include 'initialize/db.inc.php'; // 'db.inc.php' is included to hide username and password
  24. include 'includes/header.inc.php'; // include header
  25. include 'includes/footer.inc.php'; // include footer
  26. include 'includes/include.inc.php'; // include common functions
  27. include 'initialize/ini.inc.php'; // include common variables
  28. // --------------------------------------------------------------------
  29. // START A SESSION:
  30. // call the 'start_session()' function (from 'include.inc.php') which will also read out available session variables:
  31. start_session(true);
  32. // --------------------------------------------------------------------
  33. // Initialize preferred display language:
  34. // (note that 'locales.inc.php' has to be included *after* the call to the 'start_session()' function)
  35. include 'includes/locales.inc.php'; // include the locales
  36. // --------------------------------------------------------------------
  37. // Extract session variables (only necessary if register globals is OFF!):
  38. if (isset($_SESSION['errors']))
  39. $errors = $_SESSION['errors'];
  40. else
  41. $errors = array(); // initialize variable (in order to prevent 'Undefined index/variable...' messages)
  42. if (isset($_SESSION['formVars']))
  43. $formVars = $_SESSION['formVars'];
  44. else
  45. $formVars = array(); // initialize variable (in order to prevent 'Undefined index/variable...' messages)
  46. // The current values of the session variables 'errors' and 'formVars' get stored in '$errors' or '$formVars', respectively. (either automatically if
  47. // register globals is ON, or explicitly if register globals is OFF [by uncommenting the code above]).
  48. // We need to clear these session variables here, since they would otherwise be still there on a subsequent call of 'duplicate_manager.php'!
  49. // Note: though we clear the session variables, the current error message (or form variables) is still available to this script via '$errors' (or '$formVars', respectively).
  50. deleteSessionVariable("errors"); // function 'deleteSessionVariable()' is defined in 'include.inc.php'
  51. deleteSessionVariable("formVars");
  52. // --------------------------------------------------------------------
  53. // TODO: enable checking for 'allow_flag_duplicates' permission
  54. // CAUTION: Since there's not a 'allow_flag_duplicates' permission setting (yet), we currently just check whether a user is logged in!
  55. if (!isset($_SESSION['loginEmail'])) // if a user isn't logged in...
  56. // In order to flag any records as duplicates, a user must be logged in AND must be allowed to flag duplicates in the database:
  57. // if (!(isset($_SESSION['loginEmail']) AND (isset($_SESSION['user_permissions']) AND preg_match("/allow_flag_duplicates/", $_SESSION['user_permissions'])))) // if a user isn't logged in OR if the 'user_permissions' session variable does NOT contain 'allow_flag_duplicates'...
  58. {
  59. // return an appropriate error message:
  60. $HeaderString = returnMsg($loc["NoPermission"] . $loc["NoPermission_ForFlagDups"] . "!", "warning", "strong", "HeaderString"); // function 'returnMsg()' is defined in 'include.inc.php'
  61. // save the URL of the currently displayed page:
  62. $referer = $_SERVER['HTTP_REFERER'];
  63. // Write back session variables:
  64. saveSessionVariable("referer", $referer); // function 'saveSessionVariable()' is defined in 'include.inc.php'
  65. header("Location: index.php");
  66. exit; // >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> !EXIT! <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
  67. }
  68. // --------------------------------------------------------------------
  69. // Extract the view type requested by the user (either 'Mobile', 'Print', 'Web' or ''):
  70. // ('' will produce the default 'Web' output style)
  71. if (isset($_REQUEST['viewType']))
  72. $viewType = $_REQUEST['viewType'];
  73. else
  74. $viewType = "";
  75. // Setup some required variables:
  76. // If there's no stored message available:
  77. if (!isset($_SESSION['HeaderString']))
  78. {
  79. if (empty($errors)) // provide one of the default messages:
  80. {
  81. $errors = array(); // re-assign an empty array (in order to prevent 'Undefined variable "errors"...' messages when calling the 'fieldError' function later on)
  82. $HeaderString = "Flag records as original or duplicate entries:"; // Provide the default message
  83. }
  84. else // -> there were errors validating the data entered by the user
  85. $HeaderString = "There were validation errors regarding the data you entered:";
  86. }
  87. else
  88. {
  89. $HeaderString = $_SESSION['HeaderString']; // extract 'HeaderString' session variable (only necessary if register globals is OFF!)
  90. // Note: though we clear the session variable, the current message is still available to this script via '$HeaderString':
  91. deleteSessionVariable("HeaderString"); // function 'deleteSessionVariable()' is defined in 'include.inc.php'
  92. }
  93. // --------------------------------------------------------------------
  94. // Assign correct values to the form variables:
  95. if (!empty($errors)) // if there were some errors on submit
  96. {
  97. // load the form data that were entered by the user:
  98. $origRecord = $formVars['origRecord'];
  99. $dupRecords = $formVars['dupRecords'];
  100. }
  101. else
  102. {
  103. $origRecord = "";
  104. $dupRecords = "";
  105. }
  106. // --------------------------------------------------------------------
  107. // Show the login status:
  108. showLogin(); // (function 'showLogin()' is defined in 'include.inc.php')
  109. // (2a) Display header:
  110. // call the 'displayHTMLhead()' and 'showPageHeader()' functions (which are defined in 'header.inc.php'):
  111. displayHTMLhead(encodeHTML($officialDatabaseName) . " -- " . "Manage Duplicates", "index,follow", "Manage duplicate records in the " . encodeHTML($officialDatabaseName), "", false, "", $viewType, array());
  112. showPageHeader($HeaderString);
  113. // (2b) Start <form> and <table> holding the form elements:
  114. // note: we provide a default value for the 'submit' form tag so that hitting <enter> within a text entry field will act as if the user clicked the 'Flag Duplicates' button
  115. ?>
  116. <form action="duplicate_modify.php" method="POST">
  117. <input type="hidden" name="formType" value="flagDuplicates">
  118. <input type="hidden" name="viewType" value="<?php echo encodeHTML($viewType); ?>">
  119. <input type="hidden" name="submit" value="Flag Duplicates">
  120. <table align="center" border="0" cellpadding="0" cellspacing="10" width="95%" summary="This table holds a form that allows you to manage duplicate database entries">
  121. <tr>
  122. <td width="120">
  123. <div class="sect"><?php echo $loc["Original"]; ?>:</div>
  124. </td>
  125. <td><?php echo fieldError("origRecord", $errors); ?>
  126. <input type="text" name="origRecord" value="<?php echo encodeHTML($origRecord); ?>" size="10" title="enter the serial number of the original (master) record">
  127. </td>
  128. </tr>
  129. <tr>
  130. <td width="120">
  131. <div class="sect"><?php echo $loc["Duplicates"]; ?>:</div>
  132. </td>
  133. <td><?php echo fieldError("dupRecords", $errors); ?>
  134. <input type="text" name="dupRecords" value="<?php echo encodeHTML($dupRecords); ?>" size="50" title="enter the serial number(s) of all records that are duplicate entries of the above specified record; separate multiple serials with any non-digit characters">
  135. </td>
  136. </tr>
  137. <tr>
  138. <td>&nbsp;</td>
  139. <td>
  140. <input type="submit" name="submit" value="Flag Duplicates" title="mark the given records as original/duplicate entries">
  141. </td>
  142. </tr>
  143. </table>
  144. <table class="showhide" align="center" border="0" cellpadding="0" cellspacing="10" width="95%">
  145. <tr>
  146. <td class="small" width="120" valign="top">
  147. <a href="javascript:toggleVisibility('helptxt','helpToggleimg','helpToggletxt','<?php echo rawurlencode($loc["HelpAndExamples"]); ?>')"<?php echo addAccessKey("attribute", "search_help"); ?> title="<?php echo $loc["LinkTitle_ToggleVisibility"] . addAccessKey("title", "search_help"); ?>">
  148. <img id="helpToggleimg" class="toggleimg" src="img/closed.gif" alt="<?php echo $loc["LinkTitle_ToggleVisibility"]; ?>" width="9" height="9" hspace="0" border="0">
  149. <span id="helpToggletxt" class="toggletxt"><?php echo $loc["HelpAndExamples"]; ?></span>
  150. </a>
  151. </td>
  152. </tr>
  153. </table>
  154. <table id="helptxt" align="center" border="0" cellpadding="0" cellspacing="10" width="95%" summary="This table holds some help text for the form on this page" style="display: none;">
  155. <tr>
  156. <td width="120" valign="top">
  157. <div class="sect"><?php echo $loc["Help"]; ?>:</div>
  158. </td>
  159. <td class="helpbody" valign="top">
  160. <div class="even">
  161. This form allows you to manually flag records as original or duplicate entries. If the database contains multiple entries of the same bibliographic resource, enter the serial number of the "original" record (i.e. the master record) in the upper text entry field. Then enter the serial number(s) of its duplicate record entries (delimited by any non-digit characters) in the lower text entry field and press the <em>Flag Duplicates</em> button.
  162. </div>
  163. <div class="odd">
  164. If records have been flagged as original or duplicate entries, a small icon is displayed next to these records in list view to inform the user about it: <img src="img/ok.gif" alt="(original)" title="original record" width="14" height="16" hspace="0" border="0"> indicates original entries, while <img src="img/caution.gif" alt="(duplicate)" title="duplicate record" width="5" height="16" hspace="0" border="0"> denotes duplicate entries.
  165. </div>
  166. </td>
  167. </tr>
  168. <tr>
  169. <td width="120" valign="top">
  170. <div class="sect"><?php echo $loc["Examples"]; ?>:</div>
  171. </td>
  172. <td class="examples" valign="top">
  173. <div class="even">
  174. To flag record number 123 as an original record, and mark records 456, 7890 and 13579 as duplicate entries (which get linked to their original record), use:
  175. <pre><b>Original:</b> 123</pre>
  176. <pre><b>Duplicates:</b> 456 7890 13579</pre>
  177. </div>
  178. </td>
  179. </tr>
  180. </table>
  181. </form><?php
  182. // --------------------------------------------------------------------
  183. // SHOW ERROR IN RED:
  184. function fieldError($fieldName, $errors)
  185. {
  186. if (isset($errors[$fieldName]))
  187. return "<b><span class=\"warning2\">" . $errors[$fieldName] . "</span></b><br>";
  188. }
  189. // --------------------------------------------------------------------
  190. // DISPLAY THE HTML FOOTER:
  191. // call the 'showPageFooter()' and 'displayHTMLfoot()' functions (which are defined in 'footer.inc.php')
  192. showPageFooter($HeaderString);
  193. displayHTMLfoot();
  194. // --------------------------------------------------------------------
  195. ?>