mirror of
https://github.com/torrentpier/torrentpier.git
synced 2024-12-14 16:11:16 -08:00
82e7552a9e
* Minor improvements * Updated * Update functions_delete.php * Update attach_maintenance.php * Update attach_maintenance.php * Update config.php * Updated * Update viewtopic_attach.tpl * Updated * Update CHANGELOG.md
247 lines
7.7 KiB
PHP
247 lines
7.7 KiB
PHP
<?php
|
||
/**
|
||
* TorrentPier – Bull-powered BitTorrent tracker engine
|
||
*
|
||
* @copyright Copyright (c) 2005-2024 TorrentPier (https://torrentpier.com)
|
||
* @link https://github.com/torrentpier/torrentpier for the canonical source repository
|
||
* @license https://github.com/torrentpier/torrentpier/blob/master/LICENSE MIT License
|
||
*/
|
||
|
||
/**
|
||
* All Attachment Functions processing the Deletion Process
|
||
*/
|
||
|
||
/**
|
||
* Delete Attachment(s) from post(s) (intern)
|
||
*/
|
||
function delete_attachment($post_id_array = 0, $attach_id_array = 0, $page = 0, $user_id = 0)
|
||
{
|
||
global $lang, $bb_cfg;
|
||
|
||
// Generate Array, if it's not an array
|
||
if ($post_id_array === 0 && $attach_id_array === 0 && $page === 0) {
|
||
return;
|
||
}
|
||
|
||
if ($post_id_array === 0 && $attach_id_array !== 0) {
|
||
$post_id_array = [];
|
||
|
||
if (!is_array($attach_id_array)) {
|
||
if (str_contains($attach_id_array, ', ')) {
|
||
$attach_id_array = explode(', ', $attach_id_array);
|
||
} elseif (str_contains($attach_id_array, ',')) {
|
||
$attach_id_array = explode(',', $attach_id_array);
|
||
} else {
|
||
$attach_id = (int)$attach_id_array;
|
||
$attach_id_array = [];
|
||
$attach_id_array[] = $attach_id;
|
||
}
|
||
}
|
||
|
||
// Get the post_ids to fill the array
|
||
$p_id = 'post_id';
|
||
|
||
$sql = "SELECT $p_id
|
||
FROM " . BB_ATTACHMENTS . '
|
||
WHERE attach_id IN (' . implode(', ', $attach_id_array) . ")
|
||
GROUP BY $p_id";
|
||
|
||
if (!($result = DB()->sql_query($sql))) {
|
||
bb_die('Could not select ids');
|
||
}
|
||
|
||
$num_post_list = DB()->num_rows($result);
|
||
|
||
if ($num_post_list == 0) {
|
||
DB()->sql_freeresult($result);
|
||
return;
|
||
}
|
||
|
||
while ($row = DB()->sql_fetchrow($result)) {
|
||
$post_id_array[] = (int)$row[$p_id];
|
||
}
|
||
DB()->sql_freeresult($result);
|
||
}
|
||
|
||
if (!is_array($post_id_array)) {
|
||
if (trim($post_id_array) == '') {
|
||
return;
|
||
}
|
||
|
||
if (str_contains($post_id_array, ', ')) {
|
||
$post_id_array = explode(', ', $post_id_array);
|
||
} elseif (str_contains($post_id_array, ',')) {
|
||
$post_id_array = explode(',', $post_id_array);
|
||
} else {
|
||
$post_id = (int)$post_id_array;
|
||
|
||
$post_id_array = [];
|
||
$post_id_array[] = $post_id;
|
||
}
|
||
}
|
||
|
||
if (!count($post_id_array)) {
|
||
return;
|
||
}
|
||
|
||
// First of all, determine the post id and attach_id
|
||
if ($attach_id_array === 0) {
|
||
$attach_id_array = [];
|
||
|
||
// Get the attach_ids to fill the array
|
||
$whereclause = 'WHERE post_id IN (' . implode(', ', $post_id_array) . ')';
|
||
|
||
$sql = 'SELECT attach_id
|
||
FROM ' . BB_ATTACHMENTS . " $whereclause
|
||
GROUP BY attach_id";
|
||
|
||
if (!($result = DB()->sql_query($sql))) {
|
||
bb_die('Could not select attachment id #1');
|
||
}
|
||
|
||
$num_attach_list = DB()->num_rows($result);
|
||
|
||
if ($num_attach_list == 0) {
|
||
DB()->sql_freeresult($result);
|
||
return;
|
||
}
|
||
|
||
while ($row = DB()->sql_fetchrow($result)) {
|
||
$attach_id_array[] = (int)$row['attach_id'];
|
||
}
|
||
DB()->sql_freeresult($result);
|
||
}
|
||
|
||
if (!is_array($attach_id_array)) {
|
||
if (str_contains($attach_id_array, ', ')) {
|
||
$attach_id_array = explode(', ', $attach_id_array);
|
||
} elseif (str_contains($attach_id_array, ',')) {
|
||
$attach_id_array = explode(',', $attach_id_array);
|
||
} else {
|
||
$attach_id = (int)$attach_id_array;
|
||
|
||
$attach_id_array = [];
|
||
$attach_id_array[] = $attach_id;
|
||
}
|
||
}
|
||
|
||
if (!count($attach_id_array)) {
|
||
return;
|
||
}
|
||
|
||
$sql_id = 'post_id';
|
||
|
||
if (count($post_id_array) && count($attach_id_array)) {
|
||
$sql = 'DELETE FROM ' . BB_ATTACHMENTS . '
|
||
WHERE attach_id IN (' . implode(', ', $attach_id_array) . ")
|
||
AND $sql_id IN (" . implode(', ', $post_id_array) . ')';
|
||
|
||
if (!(DB()->sql_query($sql))) {
|
||
bb_die($lang['ERROR_DELETED_ATTACHMENTS']);
|
||
}
|
||
|
||
//bt
|
||
if ($sql_id == 'post_id') {
|
||
$sql = "SELECT topic_id FROM " . BB_BT_TORRENTS . " WHERE attach_id IN(" . implode(',', $attach_id_array) . ")";
|
||
|
||
if (!$result = DB()->sql_query($sql)) {
|
||
bb_die($lang['ERROR_DELETED_ATTACHMENTS']);
|
||
}
|
||
|
||
$torrents_sql = [];
|
||
|
||
while ($row = DB()->sql_fetchrow($result)) {
|
||
$torrents_sql[] = $row['topic_id'];
|
||
}
|
||
|
||
if ($torrents_sql = implode(',', $torrents_sql)) {
|
||
// Remove peers from tracker
|
||
$sql = "DELETE FROM " . BB_BT_TRACKER . "
|
||
WHERE topic_id IN($torrents_sql)";
|
||
|
||
if (!DB()->sql_query($sql)) {
|
||
bb_die('Could not delete peers');
|
||
}
|
||
}
|
||
// Delete torrents
|
||
$sql = "DELETE FROM " . BB_BT_TORRENTS . "
|
||
WHERE attach_id IN(" . implode(',', $attach_id_array) . ")";
|
||
|
||
if (!DB()->sql_query($sql)) {
|
||
bb_die($lang['ERROR_DELETED_ATTACHMENTS']);
|
||
}
|
||
}
|
||
//bt end
|
||
|
||
foreach ($attach_id_array as $i => $iValue) {
|
||
$sql = 'SELECT attach_id
|
||
FROM ' . BB_ATTACHMENTS . '
|
||
WHERE attach_id = ' . (int)$attach_id_array[$i];
|
||
|
||
if (!($result = DB()->sql_query($sql))) {
|
||
bb_die('Could not select Attachment id #2');
|
||
}
|
||
|
||
$num_rows = DB()->num_rows($result);
|
||
DB()->sql_freeresult($result);
|
||
|
||
if ($num_rows == 0) {
|
||
$sql = 'SELECT attach_id, physical_filename, thumbnail
|
||
FROM ' . BB_ATTACHMENTS_DESC . '
|
||
WHERE attach_id = ' . (int)$attach_id_array[$i];
|
||
|
||
if (!($result = DB()->sql_query($sql))) {
|
||
bb_die('Could not query attach description table');
|
||
}
|
||
$num_rows = DB()->num_rows($result);
|
||
|
||
if ($num_rows != 0) {
|
||
$num_attach = $num_rows;
|
||
$attachments = DB()->sql_fetchrowset($result);
|
||
DB()->sql_freeresult($result);
|
||
|
||
// delete attachments
|
||
for ($j = 0; $j < $num_attach; $j++) {
|
||
unlink_attach($attachments[$j]['physical_filename']);
|
||
|
||
if ((int)$attachments[$j]['thumbnail'] == 1) {
|
||
unlink_attach($attachments[$j]['physical_filename'], MODE_THUMBNAIL);
|
||
}
|
||
|
||
$sql = 'DELETE FROM ' . BB_ATTACHMENTS_DESC . ' WHERE attach_id = ' . (int)$attachments[$j]['attach_id'];
|
||
|
||
if (!(DB()->sql_query($sql))) {
|
||
bb_die($lang['ERROR_DELETED_ATTACHMENTS']);
|
||
}
|
||
|
||
// TorrServer integration
|
||
if ($bb_cfg['torr_server']['enabled']) {
|
||
$torrServer = new \TorrentPier\TorrServerAPI();
|
||
$torrServer->removeM3U($attachments[$j]['attach_id']);
|
||
}
|
||
}
|
||
} else {
|
||
DB()->sql_freeresult($result);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
// Now Sync the Topic/PM
|
||
if (count($post_id_array)) {
|
||
$sql = 'SELECT topic_id
|
||
FROM ' . BB_POSTS . '
|
||
WHERE post_id IN (' . implode(', ', $post_id_array) . ')
|
||
GROUP BY topic_id';
|
||
|
||
if (!($result = DB()->sql_query($sql))) {
|
||
bb_die('Could not select topic id');
|
||
}
|
||
|
||
while ($row = DB()->sql_fetchrow($result)) {
|
||
attachment_sync_topic($row['topic_id']);
|
||
}
|
||
DB()->sql_freeresult($result);
|
||
}
|
||
}
|