DomainBlockController.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  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. class DomainBlockController extends Controller
  8. {
  9. public function json($res, $code = 200, $headers = [])
  10. {
  11. return response()->json($res, $code, $headers, JSON_UNESCAPED_SLASHES);
  12. }
  13. public function index(Request $request)
  14. {
  15. abort_unless($request->user(), 403);
  16. $this->validate($request, [
  17. 'limit' => 'sometimes|integer|min:1|max:200'
  18. ]);
  19. $limit = $request->input('limit', 100);
  20. $id = $request->user()->profile_id;
  21. $filters = UserDomainBlock::whereProfileId($id)->orderByDesc('id')->cursorPaginate($limit);
  22. $links = null;
  23. $headers = [];
  24. if($filters->nextCursor()) {
  25. $links .= '<'.$filters->nextPageUrl().'&limit='.$limit.'>; rel="next"';
  26. }
  27. if($filters->previousCursor()) {
  28. if($links != null) {
  29. $links .= ', ';
  30. }
  31. $links .= '<'.$filters->previousPageUrl().'&limit='.$limit.'>; rel="prev"';
  32. }
  33. if($links) {
  34. $headers = ['Link' => $links];
  35. }
  36. return $this->json($filters->pluck('domain'), 200, $headers);
  37. }
  38. public function store(Request $request)
  39. {
  40. abort_unless($request->user(), 403);
  41. $this->validate($request, [
  42. 'domain' => 'required|active_url|min:1|max:120'
  43. ]);
  44. $pid = $request->user()->profile_id;
  45. $domain = trim($request->input('domain'));
  46. if(Helpers::validateUrl($domain) == false) {
  47. return abort(500, 'Invalid domain or already blocked by server admins');
  48. }
  49. $domain = parse_url($domain, PHP_URL_HOST);
  50. abort_if(config_cache('pixelfed.domain.app') == $domain, 400, 'Cannot ban your own server');
  51. $existingCount = UserDomainBlock::whereProfileId($pid)->count();
  52. $maxLimit = config('instance.user_filters.max_domain_blocks');
  53. $errorMsg = __('profile.block.domain.max', ['max' => $maxLimit]);
  54. abort_if($existingCount >= $maxLimit, 400, $errorMsg);
  55. $block = UserDomainBlock::updateOrInsert([
  56. 'profile_id' => $pid,
  57. 'domain' => $domain
  58. ]);
  59. return $this->json([]);
  60. }
  61. public function delete(Request $request)
  62. {
  63. abort_unless($request->user(), 403);
  64. $this->validate($request, [
  65. 'domain' => 'required|min:1|max:120'
  66. ]);
  67. $pid = $request->user()->profile_id;
  68. $domain = trim($request->input('domain'));
  69. $filters = UserDomainBlock::whereProfileId($pid)->whereDomain($domain)->delete();
  70. return $this->json([]);
  71. }
  72. }