Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php namespace App\Repositories; use App\Models\Album; use App\Models\Artist; use App\M..

Decoded Output download

<?php

namespace App\Repositories;

use App\Models\Album;
use App\Models\Artist;
use App\Models\User;
use App\Repositories\Traits\Searchable;
use Illuminate\Contracts\Pagination\Paginator;
use Illuminate\Database\Query\JoinClause;
use Illuminate\Support\Collection;

class AlbumRepository extends Repository
{
    use Searchable;

    /** @return Collection|array<array-key, Album> */
    public function getRecentlyAdded(int $count = 6): Collection
    {
        return Album::query()
            ->isStandard()
            ->latest('created_at')
            ->limit($count)
            ->get();
    }

    /** @return Collection|array<array-key, Album> */
    public function getMostPlayed(int $count = 6, ?User $user = null): Collection
    {
        $user ??= $this->auth->user();

        return Album::query()
            ->leftJoin('songs', 'albums.id', 'songs.album_id')
            ->leftJoin('interactions', static function (JoinClause $join) use ($user): void {
                $join->on('songs.id', 'interactions.song_id')->where('interactions.user_id', $user->id);
            })
            ->isStandard()
            ->orderByDesc('play_count')
            ->limit($count)
            ->get('albums.*');
    }

    /** @return Collection|array<array-key, Album> */
    public function getByArtist(Artist $artist): Collection
    {
        return Album::query()
            ->where('artist_id', $artist->id)
            ->orWhereIn('id', $artist->songs()->pluck('album_id'))
            ->orderBy('name')
            ->get();
    }

    public function paginate(): Paginator
    {
        return Album::query()
            ->isStandard()
            ->orderBy('name')
            ->simplePaginate(21);
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

namespace App\Repositories;

use App\Models\Album;
use App\Models\Artist;
use App\Models\User;
use App\Repositories\Traits\Searchable;
use Illuminate\Contracts\Pagination\Paginator;
use Illuminate\Database\Query\JoinClause;
use Illuminate\Support\Collection;

class AlbumRepository extends Repository
{
    use Searchable;

    /** @return Collection|array<array-key, Album> */
    public function getRecentlyAdded(int $count = 6): Collection
    {
        return Album::query()
            ->isStandard()
            ->latest('created_at')
            ->limit($count)
            ->get();
    }

    /** @return Collection|array<array-key, Album> */
    public function getMostPlayed(int $count = 6, ?User $user = null): Collection
    {
        $user ??= $this->auth->user();

        return Album::query()
            ->leftJoin('songs', 'albums.id', 'songs.album_id')
            ->leftJoin('interactions', static function (JoinClause $join) use ($user): void {
                $join->on('songs.id', 'interactions.song_id')->where('interactions.user_id', $user->id);
            })
            ->isStandard()
            ->orderByDesc('play_count')
            ->limit($count)
            ->get('albums.*');
    }

    /** @return Collection|array<array-key, Album> */
    public function getByArtist(Artist $artist): Collection
    {
        return Album::query()
            ->where('artist_id', $artist->id)
            ->orWhereIn('id', $artist->songs()->pluck('album_id'))
            ->orderBy('name')
            ->get();
    }

    public function paginate(): Paginator
    {
        return Album::query()
            ->isStandard()
            ->orderBy('name')
            ->simplePaginate(21);
    }
}

Function Calls

None

Variables

None

Stats

MD5 e7778489805630f2d83d3be1e8fb3e56
Eval Count 0
Decode Time 126 ms