Oppaitime's version of Gazelle
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.

screenshotedit.php 2.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <?
  2. authorize();
  3. if (!$_POST['groupid'] || !is_number($_POST['groupid'])) {
  4. error(404);
  5. }
  6. $GroupID = $_POST['groupid'];
  7. if (!check_perms('torrents_edit') && !check_perms('screenshots_add') && !check_perms('screenshots_delete')) {
  8. $DB->query("
  9. SELECT UserID
  10. FROM torrents
  11. WHERE GroupID = $GroupID");
  12. if (!in_array($LoggedUser['ID'], $DB->collect('UserID'))) {
  13. error(403);
  14. }
  15. }
  16. $Screenshots = isset($_POST['screenshots']) ? $_POST['screenshots'] : array();
  17. if (count($Screenshots) > 10) {
  18. error(0);
  19. }
  20. $ScreenshotsEscaped = array();
  21. foreach ($Screenshots as $i => $Screenshot) {
  22. if (!preg_match('/^'.IMAGE_REGEX.'$/i', trim($Screenshot)))
  23. error(0);
  24. $Screenshots[$i] = db_string(trim($Screenshot));
  25. }
  26. $DB->query("
  27. SELECT UserID, Image
  28. FROM torrents_screenshots
  29. WHERE GroupID = $GroupID");
  30. // $Old is an array of the form URL => UserID where UserID is the ID of the User who originally uploaded that image.
  31. $Old = array();
  32. if ($DB->has_results()) {
  33. while($S = $DB->next_record(MYSQLI_ASSOC)) {
  34. $Old[$S['Image']] = $S['UserID'];
  35. }
  36. }
  37. if (!empty($Old)) {
  38. $New = array_diff($Screenshots, array_keys($Old));
  39. $Deleted = array_diff(array_keys($Old), $Screenshots);
  40. } else {
  41. $New = $Screenshots;
  42. }
  43. // Deletion
  44. if (!empty($Deleted)) {
  45. $sql = "DELETE FROM torrents_screenshots WHERE Image IN ('";
  46. if (check_perms('screenshots_delete') || check_perms('torrents_edit')) {
  47. $DeleteList = $Deleted;
  48. } else {
  49. $DeleteList = array();
  50. foreach ($Deleted as $S) {
  51. // If the user who submitted this request uploaded the image, add the image to the list.
  52. if ($Old[$S] == $LoggedUser['ID']) {
  53. $DeleteList[] = $S;
  54. } else {
  55. error(403);
  56. }
  57. }
  58. }
  59. if (!empty($DeleteList)) {
  60. $sql .= implode("', '", $DeleteList) . "')";
  61. $DB->query($sql);
  62. }
  63. }
  64. // New screenshots
  65. foreach ($New as $Screenshot) {
  66. $DB->query("
  67. INSERT INTO torrents_screenshots
  68. (GroupID, UserID, Time, Image)
  69. VALUES
  70. ($GroupID, $LoggedUser[ID], '".sqltime()."', '$Screenshot')");
  71. }
  72. if (!empty($New)) {
  73. Torrents::write_group_log($GroupID, 0, $LoggedUser['ID'], "Added screenshot(s) ".implode(' , ', $New), 0);
  74. Misc::write_log("Screenshots ( ".implode(' , ', $New)." ) added to Torrent Group ".$GroupID." by ".$LoggedUser['Username']);
  75. }
  76. if (!empty($DeleteList)) {
  77. Torrents::write_group_log($GroupID, 0, $LoggedUser['ID'], "Deleted screenshot(s) ".implode(' , ', $DeleteList), 0);
  78. Misc::write_log("Screenshots ( ".implode(' , ', $DeleteList)." ) deleted from Torrent Group ".$GroupID." by ".$LoggedUser['Username']);
  79. }
  80. $Cache->delete_value("torrents_details_".$GroupID);
  81. header("Location: torrents.php?id=$GroupID");
  82. ?>