BioTorrents.de’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.

notify_handle.php 3.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <?php
  2. #declare(strict_types=1);
  3. if (!check_perms('site_torrents_notify')) {
  4. error(403);
  5. }
  6. authorize();
  7. $FormID = '';
  8. $ArtistList = '';
  9. $TagList = '';
  10. $NotTagList = '';
  11. $CategoryList = '';
  12. $MediaList = '';
  13. $Users = '';
  14. $HasFilter = false;
  15. if ($_POST['formid'] && is_number($_POST['formid'])) {
  16. $FormID = $_POST['formid'];
  17. }
  18. if ($_POST['artists'.$FormID]) {
  19. $Artists = explode(',', $_POST['artists'.$FormID]);
  20. $ParsedArtists = [];
  21. foreach ($Artists as $Artist) {
  22. if (trim($Artist) !== '') {
  23. $ParsedArtists[] = db_string(trim($Artist));
  24. }
  25. }
  26. if (count($ParsedArtists) > 0) {
  27. $ArtistList = '|'.implode('|', $ParsedArtists).'|';
  28. $HasFilter = true;
  29. }
  30. }
  31. if ($_POST['excludeva'.$FormID]) {
  32. $ExcludeVA = '1';
  33. $HasFilter = true;
  34. } else {
  35. $ExcludeVA = '0';
  36. }
  37. if ($_POST['newgroupsonly'.$FormID]) {
  38. $NewGroupsOnly = '1';
  39. $HasFilter = true;
  40. } else {
  41. $NewGroupsOnly = '0';
  42. }
  43. if ($_POST['tags'.$FormID]) {
  44. $TagList = '|';
  45. $Tags = explode(',', $_POST['tags'.$FormID]);
  46. foreach ($Tags as $Tag) {
  47. $TagList.=db_string(trim($Tag)).'|';
  48. }
  49. $HasFilter = true;
  50. }
  51. if ($_POST['nottags'.$FormID]) {
  52. $NotTagList = '|';
  53. $Tags = explode(',', $_POST['nottags'.$FormID]);
  54. foreach ($Tags as $Tag) {
  55. $NotTagList.=db_string(trim($Tag)).'|';
  56. }
  57. $HasFilter = true;
  58. }
  59. if ($_POST['categories'.$FormID]) {
  60. $CategoryList = '|';
  61. foreach ($_POST['categories'.$FormID] as $Category) {
  62. $CategoryList.=db_string(trim($Category)).'|';
  63. }
  64. $HasFilter = true;
  65. }
  66. if ($_POST['media'.$FormID]) {
  67. $MediaList = '|';
  68. foreach ($_POST['media'.$FormID] as $Medium) {
  69. $MediaList.=db_string(trim($Medium)).'|';
  70. }
  71. $HasFilter = true;
  72. }
  73. if ($_POST['users'.$FormID]) {
  74. $Usernames = explode(',', $_POST['users'.$FormID]);
  75. $EscapedUsernames = [];
  76. foreach ($Usernames as $Username) {
  77. $EscapedUsernames[] = db_string(trim($Username));
  78. }
  79. $DB->query("
  80. SELECT ID, Paranoia
  81. FROM users_main
  82. WHERE Username IN ('" . implode("', '", $EscapedUsernames) . "')
  83. AND ID != $LoggedUser[ID]");
  84. while (list($UserID, $Paranoia) = $DB->next_record()) {
  85. $Paranoia = unserialize($Paranoia);
  86. if (!in_array('notifications', $Paranoia)) {
  87. $Users .= '|' . $UserID . '|';
  88. $HasFilter = true;
  89. }
  90. }
  91. }
  92. if (!$HasFilter) {
  93. $Err = 'You must add at least one criterion to filter by';
  94. } elseif (!$_POST['label'.$FormID] && !$_POST['id'.$FormID]) {
  95. $Err = 'You must add a label for the filter set';
  96. }
  97. if ($Err) {
  98. error($Err);
  99. header('Location: user.php?action=notify');
  100. error();
  101. }
  102. $ArtistList = str_replace('||', '|', $ArtistList);
  103. $TagList = str_replace('||', '|', $TagList);
  104. $NotTagList = str_replace('||', '|', $NotTagList);
  105. $Users = str_replace('||', '|', $Users);
  106. if ($_POST['id'.$FormID] && is_number($_POST['id'.$FormID])) {
  107. $DB->query("
  108. UPDATE users_notify_filters
  109. SET
  110. Artists='$ArtistList',
  111. ExcludeVA='$ExcludeVA',
  112. NewGroupsOnly='$NewGroupsOnly',
  113. Tags='$TagList',
  114. NotTags='$NotTagList',
  115. Categories='$CategoryList',
  116. Media='$MediaList',
  117. Users ='$Users'
  118. WHERE ID='".$_POST['id'.$FormID]."'
  119. AND UserID='$LoggedUser[ID]'");
  120. } else {
  121. $DB->query("
  122. INSERT INTO users_notify_filters
  123. (UserID, Label, Artists, ExcludeVA, NewGroupsOnly, Tags, NotTags, Categories, Media, Users)
  124. VALUES
  125. ('$LoggedUser[ID]','".db_string($_POST['label'.$FormID])."','$ArtistList','$ExcludeVA','$NewGroupsOnly','$TagList','$NotTagList','$CategoryList','$MediaList','$Users')");
  126. }
  127. $Cache->delete_value('notify_filters_'.$LoggedUser['ID']);
  128. if (($Notify = $Cache->get_value('notify_artists_'.$LoggedUser['ID'])) !== false && $Notify['ID'] === $_POST['id'.$FormID]) {
  129. $Cache->delete_value('notify_artists_'.$LoggedUser['ID']);
  130. }
  131. header('Location: user.php?action=notify');