'desc']; protected string|array $orderGuarantee = ['id' => 'desc']; protected array $withJoinTable = ['user', 'channel']; protected function initController(WebmanRequest $request): ?Response { $this->model = new \app\common\model\DepositOrder(); return null; } protected function _index(): Response { if ($this->request && $this->request->get('select')) { return $this->select($this->request); } list($where, $alias, $limit, $order) = $this->queryBuilder(); $table = strtolower($this->model->getTable()); $mainShort = $alias[$table] ?? ''; if ($mainShort !== '' && $this->auth && !$this->auth->isSuperAdmin()) { $channelIds = $this->getScopedChannelIdsForFilter(); $where[] = [$mainShort . '.channel_id', 'in', $channelIds !== [] ? $channelIds : [0]]; } $res = $this->model ->withJoin($this->withJoinTable, $this->withJoinType) ->with($this->withJoinTable) ->visible([ 'user' => ['username', 'phone'], 'channel' => ['name'], ]) ->alias($alias) ->where($where) ->order($order) ->paginate($limit); return $this->success('', [ 'list' => $res->items(), 'total' => $res->total(), 'remark' => get_route_remark(), ]); } /** * @return int[] */ private function getScopedChannelIdsForFilter(): array { if (!$this->auth) { return [0]; } if ($this->auth->isSuperAdmin()) { return []; } $admin = Db::name('admin')->field(['id', 'channel_id'])->where('id', $this->auth->id)->find(); $ids = []; if ($admin && !empty($admin['channel_id'])) { $ids[] = $admin['channel_id']; } return array_values(array_unique($ids)); } }