Skip to content
Snippets Groups Projects
AnalyticsWebsiteByRefererModel.php 3.2 KiB
Newer Older
 * Class AnalyticsWebsiteByRefererModel Model for analytics_website_by_referer table in database
 *
 * @copyright  2020 Podlibre
 * @license    https://www.gnu.org/licenses/agpl-3.0.en.html AGPL3
 * @link       https://castopod.org/
 */
use Analytics\Entities\AnalyticsWebsiteByReferer;
use CodeIgniter\Model;

class AnalyticsWebsiteByRefererModel extends Model
{
    protected $table = 'analytics_website_by_referer';

    /**
     * @var string
     */
    protected $returnType = AnalyticsWebsiteByReferer::class;
    protected $useSoftDeletes = false;

    protected $useTimestamps = false;

    /**
     * Gets referer data for a podcast
     *
     */
    public function getData(int $podcastId): array
    {
        if (! ($found = cache("{$podcastId}_analytics_website_by_referer"))) {
            $oneWeekAgo = date('Y-m-d', strtotime('-1 week'));
            $found = $this->select('referer_url as labels')
                ->selectSum('hits', 'values')
                    'podcast_id' => $podcastId,
                    'date >' => $oneWeekAgo,
                ->groupBy('labels')
                ->orderBy('values', 'DESC')
            cache()
                ->save("{$podcastId}_analytics_website_by_referer", $found, 600,);
        }
        return $found;
    }

    /**
     * Gets domain data for a podcast
     *
    public function getDataByDomainWeekly(int $podcastId): array
            ! ($found = cache("{$podcastId}_analytics_website_by_domain_weekly"))
            $oneWeekAgo = date('Y-m-d', strtotime('-1 week'));
            $found = $this->select("SUBSTRING_INDEX(domain, '.', -2) as labels")
                    'podcast_id' => $podcastId,
                    'date >' => $oneWeekAgo,
                ->groupBy('labels')
                ->orderBy('values', 'DESC')
            cache()
                ->save("{$podcastId}_analytics_website_by_domain_weekly", $found, 600,);
     */
    public function getDataByDomainYearly(int $podcastId): array
    {
        if (
            ! ($found = cache("{$podcastId}_analytics_website_by_domain_yearly"))
            $oneYearAgo = date('Y-m-d', strtotime('-1 year'));
            $found = $this->select("SUBSTRING_INDEX(domain, '.', -2) as labels")
                    'podcast_id' => $podcastId,
                    'date >' => $oneYearAgo,
                ->groupBy('labels')
                ->orderBy('values', 'DESC')
            cache()
                ->save("{$podcastId}_analytics_website_by_domain_yearly", $found, 600,);