activity()) ->allowedSorts(['timestamp']) ->allowedFilters([AllowedFilter::partial('event')]) ->with('actor') ->whereNotIn('activity_logs.event', ActivityLog::DISABLED_EVENTS) ->when(config('activity.hide_admin_activity'), function (Builder $builder) use ($server) { // We could do this with a query and a lot of joins, but that gets pretty // painful so for now we'll execute a simpler query. $subusers = $server->subusers()->pluck('user_id')->merge([$server->owner_id]); $rootAdmins = Role::getRootAdmin()->users()->pluck('id'); $builder->select('activity_logs.*') ->leftJoin('users', function (JoinClause $join) { $join->on('users.id', 'activity_logs.actor_id') ->where('activity_logs.actor_type', (new User())->getMorphClass()); }) ->where(function (Builder $builder) use ($subusers, $rootAdmins) { $builder->whereNull('users.id') ->orWhereNotIn('users.id', $rootAdmins) ->orWhereIn('users.id', $subusers); }); }) ->paginate(min($request->query('per_page', '25'), 100)) ->appends($request->query()); return $this->fractal->collection($activity) ->transformWith($this->getTransformer(ActivityLogTransformer::class)) ->toArray(); } }