mirror of
https://github.com/HDInnovations/UNIT3D-Community-Edition.git
synced 2026-01-24 12:59:44 -06:00
449 lines
23 KiB
PHP
449 lines
23 KiB
PHP
<?php
|
|
/**
|
|
* NOTICE OF LICENSE.
|
|
*
|
|
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
|
|
* The details is bundled with this project in the file LICENSE.txt.
|
|
*
|
|
* @project UNIT3D Community Edition
|
|
*
|
|
* @author HDVinnie <hdinnovations@protonmail.com>
|
|
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
|
|
*/
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Models\Article;
|
|
use App\Models\Bookmark;
|
|
use App\Models\FeaturedTorrent;
|
|
use App\Models\FreeleechToken;
|
|
use App\Models\Group;
|
|
use App\Models\Movie;
|
|
use App\Models\Poll;
|
|
use App\Models\Post;
|
|
use App\Models\Topic;
|
|
use App\Models\Torrent;
|
|
use App\Models\Tv;
|
|
use App\Models\User;
|
|
use Illuminate\Database\Eloquent\Builder;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Exception;
|
|
|
|
/**
|
|
* @see \Tests\Todo\Feature\Http\Controllers\Staff\HomeControllerTest
|
|
*/
|
|
class HomeController extends Controller
|
|
{
|
|
/**
|
|
* Display Home Page.
|
|
*
|
|
* @throws Exception
|
|
*/
|
|
public function index(Request $request): \Illuminate\Contracts\View\Factory|\Illuminate\View\View
|
|
{
|
|
// For Cache
|
|
$expiresAt = now()->addMinutes(1);
|
|
|
|
// Authorized User
|
|
$user = $request->user();
|
|
|
|
// Latest Articles/News Block
|
|
$articles = cache()->remember('latest_article', $expiresAt, fn () => Article::latest()->take(1)->get());
|
|
|
|
foreach ($articles as $article) {
|
|
$article->newNews = ($user->last_login->subDays(3)->getTimestamp() < $article->created_at->getTimestamp()) ? 1 : 0;
|
|
}
|
|
|
|
return view('home.index', [
|
|
'user' => $user,
|
|
'personal_freeleech' => cache()->get('personal_freeleech:'.$user->id),
|
|
'users' => cache()->remember(
|
|
'online_users',
|
|
$expiresAt,
|
|
fn () => User::with('group', 'privacy')
|
|
->withCount([
|
|
'warnings' => function (Builder $query): void {
|
|
$query->whereNotNull('torrent')->where('active', '1');
|
|
},
|
|
])
|
|
->where('last_action', '>', now()->subMinutes(5))
|
|
->get()
|
|
),
|
|
'groups' => cache()->remember(
|
|
'user-groups',
|
|
$expiresAt,
|
|
fn () => Group::select([
|
|
'name',
|
|
'color',
|
|
'effect',
|
|
'icon'
|
|
])
|
|
->oldest('position')
|
|
->get()
|
|
),
|
|
'articles' => $articles,
|
|
'newest' => cache()->remember(
|
|
'newest_torrents',
|
|
$expiresAt,
|
|
function () use ($user) {
|
|
$newest = Torrent::with(['user', 'category', 'type', 'resolution'])
|
|
->withExists([
|
|
'bookmarks' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'freeleechTokens' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'history as seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 1),
|
|
'history as leeching' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 0),
|
|
'history as not_completed' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNull('completed_at'),
|
|
'history as not_seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNotNull('completed_at'),
|
|
])
|
|
->selectRaw("
|
|
CASE
|
|
WHEN category_id IN (SELECT `id` from `categories` where `movie_meta` = 1) THEN 'movie'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `tv_meta` = 1) THEN 'tv'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `game_meta` = 1) THEN 'game'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `music_meta` = 1) THEN 'music'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `no_meta` = 1) THEN 'no'
|
|
END as meta
|
|
")
|
|
->withCount(['thanks', 'comments'])
|
|
->latest()
|
|
->take(5)
|
|
->get();
|
|
|
|
$movieIds = $newest->where('meta', '=', 'movie')->pluck('tmdb');
|
|
$tvIds = $newest->where('meta', '=', 'tv')->pluck('tmdb');
|
|
$gameIds = $newest->where('meta', '=', 'game')->pluck('igdb');
|
|
|
|
$movies = Movie::with('genres')->whereIntegerInRaw('id', $movieIds)->get()->keyBy('id');
|
|
$tv = Tv::with('genres')->whereIntegerInRaw('id', $tvIds)->get()->keyBy('id');
|
|
$games = [];
|
|
|
|
foreach ($gameIds as $gameId) {
|
|
$games[$gameId] = \MarcReichel\IGDBLaravel\Models\Game::with(['cover' => ['url', 'image_id']])->find($gameId);
|
|
}
|
|
|
|
$newest = $newest->map(function ($torrent) use ($movies, $tv, $games) {
|
|
$torrent->meta = match ($torrent->meta) {
|
|
'movie' => $movies[$torrent->tmdb] ?? null,
|
|
'tv' => $tv[$torrent->tmdb] ?? null,
|
|
'game' => $games[$torrent->igdb] ?? null,
|
|
default => null,
|
|
};
|
|
|
|
return $torrent;
|
|
});
|
|
|
|
return $newest;
|
|
}
|
|
),
|
|
'seeded' => cache()->remember(
|
|
'seeded_torrents',
|
|
$expiresAt,
|
|
function () use ($user) {
|
|
$seeded = Torrent::with(['user', 'category', 'type', 'resolution'])
|
|
->withExists([
|
|
'bookmarks' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'freeleechTokens' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'history as seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 1),
|
|
'history as leeching' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 0),
|
|
'history as not_completed' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNull('completed_at'),
|
|
'history as not_seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNotNull('completed_at'),
|
|
])
|
|
->selectRaw("
|
|
CASE
|
|
WHEN category_id IN (SELECT `id` from `categories` where `movie_meta` = 1) THEN 'movie'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `tv_meta` = 1) THEN 'tv'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `game_meta` = 1) THEN 'game'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `music_meta` = 1) THEN 'music'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `no_meta` = 1) THEN 'no'
|
|
END as meta
|
|
")
|
|
->withCount(['thanks', 'comments'])
|
|
->latest('seeders')
|
|
->take(5)
|
|
->get();
|
|
|
|
$movieIds = $seeded->where('meta', '=', 'movie')->pluck('tmdb');
|
|
$tvIds = $seeded->where('meta', '=', 'tv')->pluck('tmdb');
|
|
$gameIds = $seeded->where('meta', '=', 'game')->pluck('igdb');
|
|
|
|
$movies = Movie::with('genres')->whereIntegerInRaw('id', $movieIds)->get()->keyBy('id');
|
|
$tv = Tv::with('genres')->whereIntegerInRaw('id', $tvIds)->get()->keyBy('id');
|
|
$games = [];
|
|
|
|
foreach ($gameIds as $gameId) {
|
|
$games[$gameId] = \MarcReichel\IGDBLaravel\Models\Game::with(['cover' => ['url', 'image_id']])->find($gameId);
|
|
}
|
|
|
|
$seeded = $seeded->map(function ($torrent) use ($movies, $tv, $games) {
|
|
$torrent->meta = match ($torrent->meta) {
|
|
'movie' => $movies[$torrent->tmdb] ?? null,
|
|
'tv' => $tv[$torrent->tmdb] ?? null,
|
|
'game' => $games[$torrent->igdb] ?? null,
|
|
default => null,
|
|
};
|
|
|
|
return $torrent;
|
|
});
|
|
|
|
return $seeded;
|
|
}
|
|
),
|
|
'dying' => cache()->remember(
|
|
'dying_torrents',
|
|
$expiresAt,
|
|
function () use ($user) {
|
|
$dying = Torrent::with(['user', 'category', 'type', 'resolution'])
|
|
->withExists([
|
|
'bookmarks' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'freeleechTokens' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'history as seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 1),
|
|
'history as leeching' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 0),
|
|
'history as not_completed' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNull('completed_at'),
|
|
'history as not_seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNotNull('completed_at'),
|
|
])
|
|
->selectRaw("
|
|
CASE
|
|
WHEN category_id IN (SELECT `id` from `categories` where `movie_meta` = 1) THEN 'movie'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `tv_meta` = 1) THEN 'tv'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `game_meta` = 1) THEN 'game'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `music_meta` = 1) THEN 'music'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `no_meta` = 1) THEN 'no'
|
|
END as meta
|
|
")
|
|
->withCount(['thanks', 'comments'])
|
|
->where('seeders', '=', 1)
|
|
->where('times_completed', '>=', 1)
|
|
->latest('leechers')
|
|
->take(5)
|
|
->get();
|
|
|
|
$movieIds = $dying->where('meta', '=', 'movie')->pluck('tmdb');
|
|
$tvIds = $dying->where('meta', '=', 'tv')->pluck('tmdb');
|
|
$gameIds = $dying->where('meta', '=', 'game')->pluck('igdb');
|
|
|
|
$movies = Movie::with('genres')->whereIntegerInRaw('id', $movieIds)->get()->keyBy('id');
|
|
$tv = Tv::with('genres')->whereIntegerInRaw('id', $tvIds)->get()->keyBy('id');
|
|
$games = [];
|
|
|
|
foreach ($gameIds as $gameId) {
|
|
$games[$gameId] = \MarcReichel\IGDBLaravel\Models\Game::with(['cover' => ['url', 'image_id']])->find($gameId);
|
|
}
|
|
|
|
$dying = $dying->map(function ($torrent) use ($movies, $tv, $games) {
|
|
$torrent->meta = match ($torrent->meta) {
|
|
'movie' => $movies[$torrent->tmdb] ?? null,
|
|
'tv' => $tv[$torrent->tmdb] ?? null,
|
|
'game' => $games[$torrent->igdb] ?? null,
|
|
default => null,
|
|
};
|
|
|
|
return $torrent;
|
|
});
|
|
|
|
return $dying;
|
|
}
|
|
),
|
|
'leeched' => cache()->remember(
|
|
'leeched_torrents',
|
|
$expiresAt,
|
|
function () use ($user) {
|
|
$leeched = Torrent::with(['user', 'category', 'type', 'resolution'])
|
|
->withExists([
|
|
'bookmarks' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'freeleechTokens' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'history as seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 1),
|
|
'history as leeching' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 0),
|
|
'history as not_completed' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNull('completed_at'),
|
|
'history as not_seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNotNull('completed_at'),
|
|
])
|
|
->selectRaw("
|
|
CASE
|
|
WHEN category_id IN (SELECT `id` from `categories` where `movie_meta` = 1) THEN 'movie'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `tv_meta` = 1) THEN 'tv'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `game_meta` = 1) THEN 'game'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `music_meta` = 1) THEN 'music'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `no_meta` = 1) THEN 'no'
|
|
END as meta
|
|
")
|
|
->withCount(['thanks', 'comments'])
|
|
->latest('leechers')
|
|
->take(5)
|
|
->get();
|
|
|
|
$movieIds = $leeched->where('meta', '=', 'movie')->pluck('tmdb');
|
|
$tvIds = $leeched->where('meta', '=', 'tv')->pluck('tmdb');
|
|
$gameIds = $leeched->where('meta', '=', 'game')->pluck('igdb');
|
|
|
|
$movies = Movie::with('genres')->whereIntegerInRaw('id', $movieIds)->get()->keyBy('id');
|
|
$tv = Tv::with('genres')->whereIntegerInRaw('id', $tvIds)->get()->keyBy('id');
|
|
$games = [];
|
|
|
|
foreach ($gameIds as $gameId) {
|
|
$games[$gameId] = \MarcReichel\IGDBLaravel\Models\Game::with(['cover' => ['url', 'image_id']])->find($gameId);
|
|
}
|
|
|
|
$leeched = $leeched->map(function ($torrent) use ($movies, $tv, $games) {
|
|
$torrent->meta = match ($torrent->meta) {
|
|
'movie' => $movies[$torrent->tmdb] ?? null,
|
|
'tv' => $tv[$torrent->tmdb] ?? null,
|
|
'game' => $games[$torrent->igdb] ?? null,
|
|
default => null,
|
|
};
|
|
|
|
return $torrent;
|
|
});
|
|
|
|
return $leeched;
|
|
}
|
|
),
|
|
'dead' => cache()->remember(
|
|
'dead_torrents',
|
|
$expiresAt,
|
|
function () use ($user) {
|
|
$dead = Torrent::with(['user', 'category', 'type', 'resolution'])
|
|
->withExists([
|
|
'bookmarks' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'freeleechTokens' => fn ($query) => $query->where('user_id', '=', $user->id),
|
|
'history as seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 1),
|
|
'history as leeching' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 1)
|
|
->where('seeder', '=', 0),
|
|
'history as not_completed' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNull('completed_at'),
|
|
'history as not_seeding' => fn ($query) => $query->where('user_id', '=', $user->id)
|
|
->where('active', '=', 0)
|
|
->where('seeder', '=', 1)
|
|
->whereNotNull('completed_at'),
|
|
])
|
|
->selectRaw("
|
|
CASE
|
|
WHEN category_id IN (SELECT `id` from `categories` where `movie_meta` = 1) THEN 'movie'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `tv_meta` = 1) THEN 'tv'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `game_meta` = 1) THEN 'game'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `music_meta` = 1) THEN 'music'
|
|
WHEN category_id IN (SELECT `id` from `categories` where `no_meta` = 1) THEN 'no'
|
|
END as meta
|
|
")
|
|
->withCount(['thanks', 'comments'])
|
|
->where('seeders', '=', 0)
|
|
->latest('leechers')
|
|
->take(5)
|
|
->get();
|
|
|
|
$movieIds = $dead->where('meta', '=', 'movie')->pluck('tmdb');
|
|
$tvIds = $dead->where('meta', '=', 'tv')->pluck('tmdb');
|
|
$gameIds = $dead->where('meta', '=', 'game')->pluck('igdb');
|
|
|
|
$movies = Movie::with('genres')->whereIntegerInRaw('id', $movieIds)->get()->keyBy('id');
|
|
$tv = Tv::with('genres')->whereIntegerInRaw('id', $tvIds)->get()->keyBy('id');
|
|
$games = [];
|
|
|
|
foreach ($gameIds as $gameId) {
|
|
$games[$gameId] = \MarcReichel\IGDBLaravel\Models\Game::with(['cover' => ['url', 'image_id']])->find($gameId);
|
|
}
|
|
|
|
$dead = $dead->map(function ($torrent) use ($movies, $tv, $games) {
|
|
$torrent->meta = match ($torrent->meta) {
|
|
'movie' => $movies[$torrent->tmdb] ?? null,
|
|
'tv' => $tv[$torrent->tmdb] ?? null,
|
|
'game' => $games[$torrent->igdb] ?? null,
|
|
default => null,
|
|
};
|
|
|
|
return $torrent;
|
|
});
|
|
|
|
return $dead;
|
|
}
|
|
),
|
|
'topics' => cache()->remember(
|
|
'latest_topics',
|
|
$expiresAt,
|
|
fn () => Topic::with('forum')->latest()->take(5)->get()
|
|
),
|
|
'posts' => cache()->remember(
|
|
'latest_posts',
|
|
$expiresAt,
|
|
fn () => Post::with('topic', 'user')
|
|
->withCount('likes', 'dislikes', 'authorPosts', 'authorTopics')
|
|
->latest()
|
|
->take(5)
|
|
->get()
|
|
),
|
|
'featured' => cache()->remember(
|
|
'latest_featured',
|
|
$expiresAt,
|
|
fn () => FeaturedTorrent::with([
|
|
'torrent',
|
|
'torrent.resolution',
|
|
'torrent.type',
|
|
'torrent.category',
|
|
'user',
|
|
'user.group'
|
|
])->get()
|
|
),
|
|
'poll' => cache()->remember('latest_poll', $expiresAt, fn () => Poll::latest()->first()),
|
|
'uploaders' => cache()->remember('top_uploaders', $expiresAt, fn () => Torrent::with(['user', 'user.group'])
|
|
->select(DB::raw('user_id, count(*) as value'))
|
|
->groupBy('user_id')
|
|
->latest('value')
|
|
->take(10)
|
|
->get()),
|
|
'past_uploaders' => cache()->remember('month_uploaders', $expiresAt, fn () => Torrent::with(['user', 'user.group'])
|
|
->where('created_at', '>', now()->subDays(30)->toDateTimeString())
|
|
->select(DB::raw('user_id, count(*) as value'))
|
|
->groupBy('user_id')
|
|
->latest('value')
|
|
->take(10)
|
|
->get()),
|
|
'freeleech_tokens' => FreeleechToken::where('user_id', $user->id)->get(),
|
|
'bookmarks' => Bookmark::where('user_id', $user->id)->get(),
|
|
]);
|
|
}
|
|
}
|