Newer
Older
<?php
/**
* Class AnalyticsWebsiteByEntryPageModel
* Model for analytics_website_by_entry_page table in database
* @copyright 2020 Podlibre
* @license https://www.gnu.org/licenses/agpl-3.0.en.html AGPL3
* @link https://castopod.org/
*/
namespace App\Models;
use CodeIgniter\Model;
class AnalyticsWebsiteByEntryPageModel extends Model
{
protected $table = 'analytics_website_by_entry_page';
protected $allowedFields = [];
protected $returnType = \App\Entities\AnalyticsWebsiteByEntryPage::class;
protected $useSoftDeletes = false;
protected $useTimestamps = false;
/**
* Gets entry pages data for a podcast
*
* @param int $podcastId
*
* @return array
*/
public function getData(int $podcastId): array
{
if (!($found = cache("{$podcastId}_analytics_website_by_entry_page"))) {

Benjamin Bellamy
committed
$oneWeekAgo = date('Y-m-d', strtotime('-1 week'));

Benjamin Bellamy
committed
$found = $this->select(
'IF(entry_page_url=\'/\',\'/\',SUBSTRING_INDEX(entry_page_url,\'/\',-1)) as labels',

Benjamin Bellamy
committed
)
->selectSum('hits', 'values')
'podcast_id' => $podcastId,
'date >' => $oneWeekAgo,
->groupBy('labels')
->orderBy('values', 'DESC')

Benjamin Bellamy
committed
->findAll();
cache()->save(
"{$podcastId}_analytics_website_by_entry_page",
$found,
600,