DomainBlockController.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. namespace App\Http\Controllers\Api\V1;
  3. use Illuminate\Http\Request;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\UserDomainBlock;
  6. use App\Util\ActivityPub\Helpers;
  7. use App\Services\UserFilterService;
  8. use Illuminate\Bus\Batch;
  9. use Illuminate\Support\Facades\Bus;
  10. use Illuminate\Support\Facades\Cache;
  11. use App\Jobs\HomeFeedPipeline\FeedRemoveDomainPipeline;
  12. use App\Jobs\ProfilePipeline\ProfilePurgeNotificationsByDomain;
  13. use App\Jobs\ProfilePipeline\ProfilePurgeFollowersByDomain;
  14. class DomainBlockController extends Controller
  15. {
  16. public function json($res, $code = 200, $headers = [])
  17. {
  18. return response()->json($res, $code, $headers, JSON_UNESCAPED_SLASHES);
  19. }
  20. public function index(Request $request)
  21. {
  22. abort_if(!$request->user() || !$request->user()->token(), 403);
  23. abort_unless($request->user()->tokenCan('read'), 403);
  24. $this->validate($request, [
  25. 'limit' => 'sometimes|integer|min:1|max:200'
  26. ]);
  27. $limit = $request->input('limit', 100);
  28. $id = $request->user()->profile_id;
  29. $filters = UserDomainBlock::whereProfileId($id)->orderByDesc('id')->cursorPaginate($limit);
  30. $links = null;
  31. $headers = [];
  32. if($filters->nextCursor()) {
  33. $links .= '<'.$filters->nextPageUrl().'&limit='.$limit.'>; rel="next"';
  34. }
  35. if($filters->previousCursor()) {
  36. if($links != null) {
  37. $links .= ', ';
  38. }
  39. $links .= '<'.$filters->previousPageUrl().'&limit='.$limit.'>; rel="prev"';
  40. }
  41. if($links) {
  42. $headers = ['Link' => $links];
  43. }
  44. return $this->json($filters->pluck('domain'), 200, $headers);
  45. }
  46. public function store(Request $request)
  47. {
  48. abort_if(!$request->user() || !$request->user()->token(), 403);
  49. abort_unless($request->user()->tokenCan('write'), 403);
  50. $this->validate($request, [
  51. 'domain' => 'required|active_url|min:1|max:120'
  52. ]);
  53. $pid = $request->user()->profile_id;
  54. $domain = trim($request->input('domain'));
  55. if(Helpers::validateUrl($domain) == false) {
  56. return abort(500, 'Invalid domain or already blocked by server admins');
  57. }
  58. $domain = strtolower(parse_url($domain, PHP_URL_HOST));
  59. abort_if(config_cache('pixelfed.domain.app') == $domain, 400, 'Cannot ban your own server');
  60. $existingCount = UserDomainBlock::whereProfileId($pid)->count();
  61. $maxLimit = config('instance.user_filters.max_domain_blocks');
  62. $errorMsg = __('profile.block.domain.max', ['max' => $maxLimit]);
  63. abort_if($existingCount >= $maxLimit, 400, $errorMsg);
  64. $block = UserDomainBlock::updateOrCreate([
  65. 'profile_id' => $pid,
  66. 'domain' => $domain
  67. ]);
  68. if($block->wasRecentlyCreated) {
  69. Bus::batch([
  70. [
  71. new FeedRemoveDomainPipeline($pid, $domain),
  72. new ProfilePurgeNotificationsByDomain($pid, $domain),
  73. new ProfilePurgeFollowersByDomain($pid, $domain)
  74. ]
  75. ])->allowFailures()->onQueue('feed')->dispatch();
  76. Cache::forget('profile:following:' . $pid);
  77. UserFilterService::domainBlocks($pid, true);
  78. }
  79. return $this->json([]);
  80. }
  81. public function delete(Request $request)
  82. {
  83. abort_if(!$request->user() || !$request->user()->token(), 403);
  84. abort_unless($request->user()->tokenCan('write'), 403);
  85. $this->validate($request, [
  86. 'domain' => 'required|min:1|max:120'
  87. ]);
  88. $pid = $request->user()->profile_id;
  89. $domain = strtolower(trim($request->input('domain')));
  90. $filters = UserDomainBlock::whereProfileId($pid)->whereDomain($domain)->delete();
  91. UserFilterService::domainBlocks($pid, true);
  92. return $this->json([]);
  93. }
  94. }