mirror of
https://github.com/pixelfed/pixelfed.git
synced 2024-11-25 15:55:22 +00:00
Merge pull request #2849 from pixelfed/staging
Update PublicApiController, fix public timeline filtering
This commit is contained in:
commit
52b1a1ca39
2 changed files with 56 additions and 18 deletions
|
@ -296,26 +296,61 @@ class PublicApiController extends Controller
|
||||||
->whereIn('filter_type', ['mute', 'block'])
|
->whereIn('filter_type', ['mute', 'block'])
|
||||||
->pluck('filterable_id')->toArray();
|
->pluck('filterable_id')->toArray();
|
||||||
|
|
||||||
if(PublicTimelineService::count() == 0) {
|
if($min || $max) {
|
||||||
PublicTimelineService::warmCache(true, 400);
|
$dir = $min ? '>' : '<';
|
||||||
|
$id = $min ?? $max;
|
||||||
|
$timeline = Status::select(
|
||||||
|
'id',
|
||||||
|
'profile_id',
|
||||||
|
'type',
|
||||||
|
'scope',
|
||||||
|
'local'
|
||||||
|
)->where('id', $dir, $id)
|
||||||
|
->whereIn('type', ['text', 'photo', 'photo:album', 'video', 'video:album', 'photo:video:album'])
|
||||||
|
->whereNotIn('profile_id', $filtered)
|
||||||
|
->whereLocal(true)
|
||||||
|
->whereScope('public')
|
||||||
|
->orderBy('id', 'desc')
|
||||||
|
->limit($limit)
|
||||||
|
->get()
|
||||||
|
->map(function($s) use ($user) {
|
||||||
|
$status = StatusService::get($s->id);
|
||||||
|
$status['favourited'] = (bool) LikeService::liked($user->profile_id, $s->id);
|
||||||
|
return $status;
|
||||||
|
});
|
||||||
|
$res = $timeline->toArray();
|
||||||
|
} else {
|
||||||
|
$timeline = Status::select(
|
||||||
|
'id',
|
||||||
|
'uri',
|
||||||
|
'caption',
|
||||||
|
'rendered',
|
||||||
|
'profile_id',
|
||||||
|
'type',
|
||||||
|
'in_reply_to_id',
|
||||||
|
'reblog_of_id',
|
||||||
|
'is_nsfw',
|
||||||
|
'scope',
|
||||||
|
'local',
|
||||||
|
'reply_count',
|
||||||
|
'comments_disabled',
|
||||||
|
'created_at',
|
||||||
|
'place_id',
|
||||||
|
'likes_count',
|
||||||
|
'reblogs_count',
|
||||||
|
'updated_at'
|
||||||
|
)->whereIn('type', ['text', 'photo', 'photo:album', 'video', 'video:album', 'photo:video:album'])
|
||||||
|
->whereNotIn('profile_id', $filtered)
|
||||||
|
->with('profile', 'hashtags', 'mentions')
|
||||||
|
->whereLocal(true)
|
||||||
|
->whereScope('public')
|
||||||
|
->orderBy('id', 'desc')
|
||||||
|
->simplePaginate($limit);
|
||||||
|
|
||||||
|
$fractal = new Fractal\Resource\Collection($timeline, new StatusTransformer());
|
||||||
|
$res = $this->fractal->createData($fractal)->toArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($max) {
|
|
||||||
$feed = PublicTimelineService::getRankedMaxId($max, $limit);
|
|
||||||
} else if ($min) {
|
|
||||||
$feed = PublicTimelineService::getRankedMinId($min, $limit);
|
|
||||||
} else {
|
|
||||||
$feed = PublicTimelineService::get(0, $limit);
|
|
||||||
}
|
|
||||||
|
|
||||||
$res = collect($feed)
|
|
||||||
->map(function($k) use($user) {
|
|
||||||
$status = StatusService::get($k);
|
|
||||||
$status['favourited'] = (bool) LikeService::liked($user->profile_id, $k);
|
|
||||||
return $status;
|
|
||||||
})
|
|
||||||
->toArray();
|
|
||||||
|
|
||||||
return response()->json($res);
|
return response()->json($res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,8 @@ class PublicTimelineService {
|
||||||
|
|
||||||
public static function add($val)
|
public static function add($val)
|
||||||
{
|
{
|
||||||
|
return;
|
||||||
|
|
||||||
if(config('database.redis.client') === 'phpredis' && self::count() > 400) {
|
if(config('database.redis.client') === 'phpredis' && self::count() > 400) {
|
||||||
Redis::zpopmin(self::CACHE_KEY);
|
Redis::zpopmin(self::CACHE_KEY);
|
||||||
}
|
}
|
||||||
|
@ -73,6 +75,7 @@ class PublicTimelineService {
|
||||||
public static function warmCache($force = false, $limit = 100)
|
public static function warmCache($force = false, $limit = 100)
|
||||||
{
|
{
|
||||||
if(self::count() == 0 || $force == true) {
|
if(self::count() == 0 || $force == true) {
|
||||||
|
Redis::del(self::CACHE_KEY);
|
||||||
$ids = Status::whereNull('uri')
|
$ids = Status::whereNull('uri')
|
||||||
->whereNull('in_reply_to_id')
|
->whereNull('in_reply_to_id')
|
||||||
->whereNull('reblog_of_id')
|
->whereNull('reblog_of_id')
|
||||||
|
|
Loading…
Reference in a new issue