Blame view
app/Queries/Ban/BanQueryHandler.php
3.54 KB
e77200db5 Initial commit |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 |
<?php namespace FootyRoom\Queries\Ban; use DateTime; use FootyRoom\Support\AutoMapper; use Illuminate\Database\Connection; class BanQueryHandler { /** * @var \Illuminate\Database\Connection */ protected $mysql; /** * Constructor. * * @param \Illuminate\Database\Connection $mysql */ public function __construct(Connection $mysql) { $this->mysql = $mysql; } /** * Query handler. * * @param \FootyRoom\Queries\Ban\ActiveBanQuery $query * * @return \FootyRoom\Queries\Ban\Ban */ public function findActiveBan(ActiveBanQuery $query) { $ban = $this->mysql ->table('bans') ->select([ 'id', 'entity_type as entityType', 'entity_id as entityId', 'type', 'duration', 'created_at as createdAt', 'username as createdBy', ]) ->join('fr_users', 'bans.created_by', '=', 'user_id') ->where('entity_type', '=', $query->getEntityType()) ->where('entity_id', '=', $query->getEntityId()) ->where('type', '=', $query->getType()) ->whereRaw('DATE_ADD(created_at, INTERVAL `duration` SECOND) > NOW()') ->orderBy('id', 'desc') ->first(); if (!$ban) { return null; } $ban->createdAt = new DateTime($ban->createdAt); return AutoMapper::map($ban, Ban::class); } /** * Get list of users who have ban records. * * @return \FootyRoom\Queries\Ban\BanSummary[] */ public function findBanSummaries(int $offset = 20, string $sortBy = 'banCount', string $username = null): array { $query = $this->mysql ->table('bans') ->select( 'bans.entity_id as userId', 'fr_users.username', $this->mysql->raw('count(*) as banCount'), $this->mysql->raw('MAX(created_at) as latestBan') ) ->groupBy('userId') ->where('entity_type', '=', 'user_id') ->where('type', '=', 'comment') ->orderBy($sortBy, 'DESC') ->offset($offset) ->limit(20) ->join('fr_users', 'bans.entity_id', '=', 'fr_users.user_id'); if ($username) { $query->where('fr_users.username', '=', $username); } $bans = $query->get(); $bansSummaries = []; foreach ($bans as $ban) { $ban->latestBan = new DateTime($ban->latestBan); $bansSummaries[] = AutoMapper::map($ban, BanSummary::class); } return $bansSummaries; } /** * Find comment bans by user id. * * @return \FootyRoom\Queries\Ban\Ban[] */ public function findCommentBansByUserId(int $userId): array { $bans = $this->mysql ->table('bans') ->select([ 'entity_id as entityId', 'created_at as createdAt', 'fr_users.username as createdBy', 'duration', ]) ->where('entity_type', '=', 'user_id') ->where('entity_id', '=', $userId) ->where('type', '=', 'comment') ->orderBy('created_at', 'DESC') ->join('fr_users', 'bans.created_by', '=', 'fr_users.user_id') ->get(); $banModels = []; foreach ($bans as $ban) { $ban->createdAt = new DateTime($ban->createdAt); $banModels[] = AutoMapper::map($ban, Ban::class); } return $banModels; } } |