国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
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.

145 lines
6.1KB

  1. <?php
  2. /**
  3. * 文档操作
  4. *
  5. * @version $id:inc_batchup.php 10:32 2010年7月21日 tianya $
  6. * @package DedeBIZ.Administrator
  7. * @copyright Copyright (c) 2022 DedeBIZ.COM
  8. * @license GNU GPL v2 (https://www.dedebiz.com/license)
  9. * @link https://www.dedebiz.com
  10. */
  11. /**
  12. * 删除文档信息
  13. *
  14. * @access public
  15. * @param string $aid 文档id
  16. * @param string $type 类型
  17. * @param string $onlyfile 删除数据库记录
  18. * @return string
  19. */
  20. function DelArc($aid, $type = 'ON', $onlyfile = FALSE, $recycle = 0)
  21. {
  22. global $dsql, $cfg_cookie_encode, $cfg_multi_site, $cfg_medias_dir, $cuserLogin, $cfg_upload_switch, $cfg_delete, $cfg_basedir, $admin_catalogs, $cfg_admin_channel;
  23. if ($cfg_delete == 'N') $type = 'OK';
  24. if (empty($aid)) return;
  25. $aid = preg_replace("#[^0-9]#i", '', $aid);
  26. $arctitle = $arcurl = '';
  27. if ($recycle == 1) $whererecycle = "AND arcrank = '-2'";
  28. else $whererecycle = "";
  29. //查询表信息
  30. $query = "SELECT ch.maintable,ch.addtable,ch.nid,ch.issystem FROM `#@__arctiny` arc LEFT JOIN `#@__arctype` tp ON tp.id=arc.typeid LEFT JOIN `#@__channeltype` ch ON ch.id=arc.channel WHERE arc.id='$aid' ";
  31. $row = $dsql->GetOne($query);
  32. $nid = $row['nid'];
  33. $maintable = (trim($row['maintable']) == '' ? '#@__archives' : trim($row['maintable']));
  34. $addtable = trim($row['addtable']);
  35. $issystem = $row['issystem'];
  36. //查询文档信息
  37. if ($issystem == -1) {
  38. $arcQuery = "SELECT arc.*,tp.* FROM `$addtable` arc LEFT JOIN `#@__arctype` tp ON arc.typeid=tp.id WHERE arc.aid='$aid' ";
  39. } else {
  40. $arcQuery = "SELECT arc.*,tp.*,arc.id AS aid FROM `$maintable` arc LEFT JOIN `#@__arctype` tp ON arc.typeid=tp.id WHERE arc.id='$aid' ";
  41. }
  42. $arcRow = $dsql->GetOne($arcQuery);
  43. //检测权限
  44. if (!TestPurview('a_Del,sys_ArcBatch')) {
  45. if (TestPurview('a_AccDel')) {
  46. if (!in_array($arcRow['typeid'], $admin_catalogs) && (count($admin_catalogs) != 0 || $cfg_admin_channel != 'all')) {
  47. return FALSE;
  48. }
  49. } else if (TestPurview('a_MyDel')) {
  50. if ($arcRow['mid'] != $cuserLogin->getUserID()) {
  51. return FALSE;
  52. }
  53. } else {
  54. return FALSE;
  55. }
  56. }
  57. //$issystem==-1是自定义模型,不使用回收站
  58. if ($issystem == -1) $type = 'OK';
  59. if (!is_array($arcRow)) return FALSE;
  60. /** 删除到回收站 **/
  61. if ($cfg_delete == 'Y' && $type == 'ON') {
  62. $dsql->ExecuteNoneQuery("UPDATE `$maintable` SET arcrank='-2' WHERE id='$aid' ");
  63. $dsql->ExecuteNoneQuery("UPDATE `#@__arctiny` SET `arcrank` = '-2' WHERE id = '$aid';");
  64. } else {
  65. //删除数据库记录
  66. if (!$onlyfile) {
  67. $query = "DELETE FROM `#@__arctiny` WHERE id='$aid' $whererecycle";
  68. if ($dsql->ExecuteNoneQuery($query)) {
  69. $dsql->ExecuteNoneQuery("DELETE FROM `#@__feedback` WHERE aid='$aid' ");
  70. $dsql->ExecuteNoneQuery("DELETE FROM `#@__member_stow` WHERE aid='$aid' ");
  71. $dsql->ExecuteNoneQuery("DELETE FROM `#@__taglist` WHERE aid='$aid' ");
  72. $dsql->ExecuteNoneQuery("DELETE FROM `#@__erradd` WHERE aid='$aid' ");
  73. if ($addtable != '') {
  74. $dsql->ExecuteNoneQuery("DELETE FROM `$addtable` WHERE aid='$aid'");
  75. }
  76. if ($issystem != -1) {
  77. $dsql->ExecuteNoneQuery("DELETE FROM `#@__archives` WHERE id='$aid' $whererecycle");
  78. }
  79. //删除相关附件
  80. if ($cfg_upload_switch == 'Y') {
  81. $dsql->Execute("me", "SELECT * FROM `#@__uploads` WHERE arcid = '$aid'");
  82. while ($row = $dsql->GetArray('me')) {
  83. $addfile = $row['url'];
  84. $aid = $row['aid'];
  85. $dsql->ExecuteNoneQuery("DELETE FROM `#@__uploads` WHERE aid = '$aid' ");
  86. $upfile = $cfg_basedir.$addfile;
  87. if (@file_exists($upfile)) @unlink($upfile);
  88. }
  89. }
  90. }
  91. }
  92. //删除文本数据
  93. $filenameh = DEDEDATA."/textdata/".(ceil($aid / 5000))."/{$aid}-".substr(md5($cfg_cookie_encode), 0, 16).".txt";
  94. if (@is_file($filenameh)) @unlink($filenameh);
  95. }
  96. if ($dsql->IsTable('#@__search_sync')) {
  97. $intime = time();
  98. $insql = "INSERT INTO `#@__search_sync` (`aid`, `add_at`) VALUES ({$aid}, $intime)";
  99. $dsql->ExecuteNoneQuery($insql);
  100. }
  101. if (empty($arcRow['money'])) $arcRow['money'] = 0;
  102. if (empty($arcRow['ismake'])) $arcRow['ismake'] = 1;
  103. if (empty($arcRow['arcrank'])) $arcRow['arcrank'] = 0;
  104. if (empty($arcRow['filename'])) $arcRow['filename'] = '';
  105. //删除HTML
  106. if ($arcRow['ismake'] == -1 || $arcRow['arcrank'] != 0 || $arcRow['typeid'] == 0 || $arcRow['money'] > 0) {
  107. return TRUE;
  108. }
  109. //强制转换非多站点模式,以便统一方式获得实际网页文件
  110. $GLOBALS['cfg_multi_site'] = 'N';
  111. $arcurl = GetFileUrl(
  112. $arcRow['aid'],
  113. $arcRow['typeid'],
  114. $arcRow['senddate'],
  115. $arcRow['title'],
  116. $arcRow['ismake'],
  117. $arcRow['arcrank'],
  118. $arcRow['namerule'],
  119. $arcRow['typedir'],
  120. $arcRow['money'],
  121. $arcRow['filename']
  122. );
  123. if (!preg_match("#\?#", $arcurl)) {
  124. $htmlfile = GetTruePath().str_replace($GLOBALS['cfg_basehost'], '', $arcurl);
  125. if (file_exists($htmlfile) && !is_dir($htmlfile)) {
  126. @unlink($htmlfile);
  127. $arcurls = explode(".", $htmlfile);
  128. $sname = $arcurls[count($arcurls) - 1];
  129. $fname = preg_replace("#(\.$sname)$#", "", $htmlfile);
  130. for ($i = 2; $i <= 100; $i++) {
  131. $htmlfile = $fname."_{$i}.".$sname;
  132. if (@file_exists($htmlfile)) @unlink($htmlfile);
  133. else break;
  134. }
  135. }
  136. }
  137. return true;
  138. }
  139. //获取真实路径
  140. function GetTruePath($siterefer = '', $sitepath = '')
  141. {
  142. $truepath = $GLOBALS['cfg_basedir'];
  143. return $truepath;
  144. }
  145. ?>