дату updated_at в формате d.m.Y H:i:s, если она меньше текущей и, если она совпадает с текущей, то в формате diffForHumans.
Этот кейс работает, однако поставили задачу запускать крон и пробегаться по полю updated_at, и получать разницу с текущей датой в 7 дней. Вот тут и возникает проблема. Поскольку updated_at с текущей датой возвращает мне формат diffForHumans и приложение падает.
Пробовал возвращать просто дату, но тогда в цикле foreach, где я формирую данные на выход возникает ошибка парсинга даты в формат diffForHumans, но зато отрабатывает крон. Подскажите как быть?
Вот что указываю в getUpdatedAtAttribute
public function getUpdatedAtAttribute($date)
{
if (! isset($date)) {
return null;
}
$tmp_date = Carbon::createFromFormat('Y-m-d H:i:s', $date)->format('Y-m-d');
if ($tmp_date === Carbon::now()->format('Y-m-d')) {
return $date;
} else {
return Carbon::createFromFormat('Y-m-d H:i:s', $date)->format('d.m.Y - H:i:s');
}
}
Метод API
foreach ($players as $player) {
preg_match('/[0-9]{2}[.][0-9]{2}.[0-9]{4} - [0-9]{2}[:][0-9]{2}[:][0-9]{2}/', $player->updated_at, $matches);
if (isset ($matches[0])) {
continue;
} else {
/**$player->updated_at = Carbon::createFromFormat('Y-m-d H:i:s', $player->updated_at)->diffForHumans();**/
$player->updated_at = Carbon::parse($player->updated_at)->diffForHumans();
}
}
Я бы не делал модификатор для updated_at, а всегда возвращал бы его значением из БД (ну пусть пропущенным через Carbon). А там где надо diffForHuman - там бы и делал
https://habr.com/ru/post/309942/
Обсуждают сегодня