2018-05-26 22:49:39 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
2018-09-22 05:23:16 +00:00
|
|
|
use App\{
|
2019-02-10 20:25:37 +00:00
|
|
|
DiscoverCategory,
|
2018-09-22 05:23:16 +00:00
|
|
|
Follower,
|
|
|
|
Hashtag,
|
|
|
|
Profile,
|
|
|
|
Status,
|
2019-02-10 20:25:37 +00:00
|
|
|
StatusHashtag,
|
2018-09-22 05:23:16 +00:00
|
|
|
UserFilter
|
|
|
|
};
|
|
|
|
use Auth, DB, Cache;
|
2018-08-28 03:07:36 +00:00
|
|
|
use Illuminate\Http\Request;
|
2018-05-26 22:49:39 +00:00
|
|
|
|
|
|
|
class DiscoverController extends Controller
|
|
|
|
{
|
2018-05-30 03:04:26 +00:00
|
|
|
public function __construct()
|
|
|
|
{
|
2018-08-28 03:07:36 +00:00
|
|
|
$this->middleware('auth');
|
2018-05-30 03:04:26 +00:00
|
|
|
}
|
|
|
|
|
2018-09-22 05:31:21 +00:00
|
|
|
public function home(Request $request)
|
2018-05-26 22:49:39 +00:00
|
|
|
{
|
2018-11-09 04:14:35 +00:00
|
|
|
return view('discover.home');
|
2018-05-26 22:49:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function showTags(Request $request, $hashtag)
|
|
|
|
{
|
2018-08-28 03:07:36 +00:00
|
|
|
$this->validate($request, [
|
2019-03-02 08:38:44 +00:00
|
|
|
'page' => 'nullable|integer|min:1|max:20',
|
2019-02-10 20:25:37 +00:00
|
|
|
]);
|
2018-08-10 02:58:52 +00:00
|
|
|
|
2019-03-02 19:11:24 +00:00
|
|
|
$tag = Hashtag::whereSlug($hashtag)
|
2018-08-10 02:58:52 +00:00
|
|
|
->firstOrFail();
|
|
|
|
|
2019-03-02 08:38:44 +00:00
|
|
|
$page = $request->input('page') ?? 1;
|
|
|
|
$key = 'discover:tag-'.$tag->id.':page-'.$page;
|
2019-03-02 19:29:29 +00:00
|
|
|
$keyMinutes = $page == 1 ? 15 : 5;
|
2019-03-02 08:38:44 +00:00
|
|
|
|
|
|
|
$posts = Cache::remember($key, now()->addMinutes($keyMinutes), function() use ($tag, $request) {
|
|
|
|
return $tag->posts()
|
2018-12-21 19:53:10 +00:00
|
|
|
->whereNull('url')
|
|
|
|
->whereNull('uri')
|
2018-11-19 04:26:52 +00:00
|
|
|
->whereHas('media')
|
2018-10-20 18:29:37 +00:00
|
|
|
->withCount(['likes', 'comments'])
|
2018-08-10 02:58:52 +00:00
|
|
|
->whereIsNsfw(false)
|
|
|
|
->whereVisibility('public')
|
2018-08-28 03:07:36 +00:00
|
|
|
->orderBy('id', 'desc')
|
2019-03-02 08:38:44 +00:00
|
|
|
->simplePaginate(24);
|
|
|
|
});
|
2018-08-10 02:58:52 +00:00
|
|
|
|
2018-11-19 04:26:52 +00:00
|
|
|
if($posts->count() == 0) {
|
|
|
|
abort(404);
|
|
|
|
}
|
|
|
|
|
2018-08-28 03:07:36 +00:00
|
|
|
return view('discover.tags.show', compact('tag', 'posts'));
|
2018-05-26 22:49:39 +00:00
|
|
|
}
|
2019-02-10 20:25:37 +00:00
|
|
|
|
|
|
|
public function showCategory(Request $request, $slug)
|
|
|
|
{
|
|
|
|
$tag = DiscoverCategory::whereActive(true)
|
|
|
|
->whereSlug($slug)
|
|
|
|
->firstOrFail();
|
|
|
|
|
2019-03-02 07:18:57 +00:00
|
|
|
$posts = Cache::remember('discover:category-'.$tag->id.':posts', now()->addMinutes(15), function() use ($tag) {
|
|
|
|
$tagids = $tag->hashtags->pluck('id')->toArray();
|
|
|
|
$sids = StatusHashtag::whereIn('hashtag_id', $tagids)->orderByDesc('status_id')->take(500)->pluck('status_id')->toArray();
|
|
|
|
$posts = Status::whereScope('public')->whereIn('id', $sids)->whereNull('uri')->whereType('photo')->whereNull('in_reply_to_id')->whereNull('reblog_of_id')->orderByDesc('created_at')->take(39)->get();
|
|
|
|
return $posts;
|
|
|
|
});
|
|
|
|
$tag->posts_count = Cache::remember('discover:category-'.$tag->id.':posts_count', now()->addMinutes(30), function() use ($tag) {
|
|
|
|
return $tag->posts()->whereScope('public')->count();
|
|
|
|
});
|
2019-02-10 20:25:37 +00:00
|
|
|
return view('discover.tags.category', compact('tag', 'posts'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function showPersonal(Request $request)
|
|
|
|
{
|
|
|
|
$profile = Auth::user()->profile;
|
2019-03-02 07:18:57 +00:00
|
|
|
|
|
|
|
$tags = Cache::remember('profile-'.$profile->id.':hashtags', now()->addMinutes(15), function() use ($profile){
|
|
|
|
return $profile->hashtags()->groupBy('hashtag_id')->inRandomOrder()->take(8)->get();
|
|
|
|
});
|
|
|
|
$following = Cache::remember('profile:following:'.$profile->id, now()->addMinutes(60), function() use ($profile) {
|
|
|
|
$res = Follower::whereProfileId($profile->id)->pluck('following_id');
|
|
|
|
return $res->push($profile->id)->toArray();
|
|
|
|
});
|
|
|
|
$posts = Cache::remember('profile-'.$profile->id.':hashtag-posts', now()->addMinutes(5), function() use ($profile, $following) {
|
|
|
|
$posts = Status::whereScope('public')->withCount(['likes','comments'])->whereNotIn('profile_id', $following)->whereHas('media')->whereType('photo')->orderByDesc('created_at')->take(39)->get();
|
|
|
|
$posts->post_count = Status::whereScope('public')->whereNotIn('profile_id', $following)->whereHas('media')->whereType('photo')->count();
|
|
|
|
return $posts;
|
|
|
|
});
|
2019-02-10 20:25:37 +00:00
|
|
|
return view('discover.personal', compact('posts', 'tags'));
|
|
|
|
}
|
2018-05-26 22:49:39 +00:00
|
|
|
}
|