2021-02-10 16:20:01 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @copyright 2021 Podlibre
|
|
|
|
* @license https://www.gnu.org/licenses/agpl-3.0.en.html AGPL3
|
|
|
|
* @link https://castopod.org/
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
use CodeIgniter\Database\BaseResult;
|
|
|
|
use App\Entities\EpisodePerson;
|
2021-02-10 16:20:01 +00:00
|
|
|
use CodeIgniter\Model;
|
|
|
|
|
|
|
|
class EpisodePersonModel extends Model
|
|
|
|
{
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $table = 'episodes_persons';
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $primaryKey = 'id';
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var string[]
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $allowedFields = [
|
|
|
|
'id',
|
|
|
|
'podcast_id',
|
|
|
|
'episode_id',
|
|
|
|
'person_id',
|
|
|
|
'person_group',
|
|
|
|
'person_role',
|
|
|
|
];
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $returnType = EpisodePerson::class;
|
|
|
|
/**
|
|
|
|
* @var bool
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $useSoftDeletes = false;
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var bool
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $useTimestamps = false;
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var array<string, string>
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $validationRules = [
|
|
|
|
'episode_id' => 'required',
|
|
|
|
'person_id' => 'required',
|
|
|
|
];
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var string[]
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $afterInsert = ['clearCache'];
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @var string[]
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
protected $beforeDelete = ['clearCache'];
|
|
|
|
|
2021-04-22 17:20:28 +00:00
|
|
|
public function getEpisodePersons($podcastId, $episodeId)
|
2021-02-10 16:20:01 +00:00
|
|
|
{
|
2021-04-22 17:20:28 +00:00
|
|
|
$cacheName = "podcast#{$podcastId}_episode#{$episodeId}_persons";
|
2021-04-20 13:43:38 +00:00
|
|
|
if (!($found = cache($cacheName))) {
|
2021-02-10 16:20:01 +00:00
|
|
|
$found = $this->select('episodes_persons.*')
|
|
|
|
->where('episode_id', $episodeId)
|
2021-04-20 13:43:38 +00:00
|
|
|
->join('persons', 'person_id=persons.id')
|
2021-02-10 16:20:01 +00:00
|
|
|
->orderby('full_name')
|
|
|
|
->findAll();
|
|
|
|
|
2021-04-20 13:43:38 +00:00
|
|
|
cache()->save($cacheName, $found, DECADE);
|
2021-02-10 16:20:01 +00:00
|
|
|
}
|
|
|
|
return $found;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add persons to episode
|
|
|
|
*
|
|
|
|
* @param int podcastId
|
|
|
|
*
|
2021-05-06 14:00:48 +00:00
|
|
|
* @return bool|int Number of rows inserted or FALSE on failure
|
2021-02-10 16:20:01 +00:00
|
|
|
*/
|
|
|
|
public function addEpisodePersons(
|
|
|
|
$podcastId,
|
2021-05-06 14:00:48 +00:00
|
|
|
int $episodeId,
|
|
|
|
array $persons,
|
|
|
|
array $groups_roles
|
2021-02-10 16:20:01 +00:00
|
|
|
) {
|
|
|
|
if (!empty($persons)) {
|
|
|
|
$this->clearCache([
|
2021-04-20 13:43:38 +00:00
|
|
|
'episode_id' => $episodeId,
|
2021-02-10 16:20:01 +00:00
|
|
|
]);
|
2021-04-20 13:43:38 +00:00
|
|
|
|
2021-02-10 16:20:01 +00:00
|
|
|
$data = [];
|
|
|
|
foreach ($persons as $person) {
|
2021-05-06 14:00:48 +00:00
|
|
|
if ($groups_roles !== []) {
|
2021-02-10 16:20:01 +00:00
|
|
|
foreach ($groups_roles as $group_role) {
|
|
|
|
$group_role = explode(',', $group_role);
|
|
|
|
$data[] = [
|
|
|
|
'podcast_id' => $podcastId,
|
|
|
|
'episode_id' => $episodeId,
|
|
|
|
'person_id' => $person,
|
|
|
|
'person_group' => $group_role[0],
|
|
|
|
'person_role' => $group_role[1],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$data[] = [
|
|
|
|
'podcast_id' => $podcastId,
|
|
|
|
'episode_id' => $episodeId,
|
|
|
|
'person_id' => $person,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->insertBatch($data);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @return bool|BaseResult
|
|
|
|
*/
|
2021-02-10 16:20:01 +00:00
|
|
|
public function removeEpisodePersons(
|
|
|
|
$podcastId,
|
|
|
|
$episodeId,
|
|
|
|
$episodePersonId
|
|
|
|
) {
|
|
|
|
return $this->delete([
|
|
|
|
'podcast_id' => $podcastId,
|
|
|
|
'episode_id' => $episodeId,
|
|
|
|
'id' => $episodePersonId,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
2021-05-06 14:00:48 +00:00
|
|
|
/**
|
|
|
|
* @return array<string, array<string|int, mixed>>
|
|
|
|
*/
|
|
|
|
protected function clearCache(array $data): array
|
2021-02-10 16:20:01 +00:00
|
|
|
{
|
2021-04-20 13:43:38 +00:00
|
|
|
if (isset($data['episode_id'])) {
|
|
|
|
$episodeId = $data['episode_id'];
|
2021-02-10 16:20:01 +00:00
|
|
|
} else {
|
2021-04-20 13:43:38 +00:00
|
|
|
$person = (new EpisodePersonModel())->find(
|
|
|
|
is_array($data['id']) ? $data['id']['id'] : $data['id'],
|
2021-02-10 16:20:01 +00:00
|
|
|
);
|
2021-04-20 13:43:38 +00:00
|
|
|
$episodeId = $person->episode_id;
|
2021-02-10 16:20:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
(new EpisodeModel())->clearCache(['id' => $episodeId]);
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
}
|