. */ namespace FireflyIII\Repositories\PeriodStatistic; use Carbon\Carbon; use FireflyIII\Models\PeriodStatistic; use FireflyIII\Models\UserGroup; use FireflyIII\Support\Repositories\UserGroup\UserGroupInterface; use FireflyIII\Support\Repositories\UserGroup\UserGroupTrait; use Illuminate\Database\Eloquent\Model; use Illuminate\Support\Collection; use Illuminate\Support\Facades\Log; use Override; class PeriodStatisticRepository implements PeriodStatisticRepositoryInterface, UserGroupInterface { use UserGroupTrait; public function findPeriodStatistics(Model $model, Carbon $start, Carbon $end, array $types): Collection { return $model->primaryPeriodStatistics() ->where('start', $start) ->where('end', $end) ->whereIn('type', $types) ->get() ; } public function findPeriodStatistic(Model $model, Carbon $start, Carbon $end, string $type): Collection { return $model->primaryPeriodStatistics() ->where('start', $start) ->where('end', $end) ->where('type', $type) ->get() ; } public function saveStatistic(Model $model, int $currencyId, Carbon $start, Carbon $end, string $type, int $count, string $amount): PeriodStatistic { $stat = new PeriodStatistic(); $stat->primaryStatable()->associate($model); $stat->transaction_currency_id = $currencyId; $stat->user_group_id = $this->getUserGroup()->id; $stat->start = $start; $stat->start_tz = $start->format('e'); $stat->end = $end; $stat->end_tz = $end->format('e'); $stat->amount = $amount; $stat->count = $count; $stat->type = $type; $stat->save(); Log::debug(sprintf( 'Saved #%d [currency #%d, Model %s #%d, %s to %s, %d, %s] as new statistic.', $stat->id, $model::class, $model->id, $stat->transaction_currency_id, $stat->start->toW3cString(), $stat->end->toW3cString(), $count, $amount )); return $stat; } public function allInRangeForModel(Model $model, Carbon $start, Carbon $end): Collection { return $model->primaryPeriodStatistics()->where('start', '>=', $start)->where('end', '<=', $end)->get(); } public function deleteStatisticsForModel(Model $model, Carbon $date): void { $model->primaryPeriodStatistics()->where('start', '<=', $date)->where('end', '>=', $date)->delete(); } #[Override] public function allInRangeForPrefix(string $prefix, Carbon $start, Carbon $end): Collection { return $this->userGroup->periodStatistics() ->where('type', 'LIKE', sprintf('%s%%', $prefix)) ->where('start', '>=', $start)->where('end', '<=', $end)->get() ; } #[Override] public function savePrefixedStatistic(string $prefix, int $currencyId, Carbon $start, Carbon $end, string $type, int $count, string $amount): PeriodStatistic { $stat = new PeriodStatistic(); $stat->transaction_currency_id = $currencyId; $stat->user_group_id = $this->getUserGroup()->id; $stat->start = $start; $stat->start_tz = $start->format('e'); $stat->end = $end; $stat->end_tz = $end->format('e'); $stat->amount = $amount; $stat->count = $count; $stat->type = sprintf('%s_%s', $prefix, $type); $stat->save(); Log::debug(sprintf( 'Saved #%d [currency #%d, type "%s", %s to %s, %d, %s] as new statistic.', $stat->id, $stat->transaction_currency_id, $stat->type, $stat->start->toW3cString(), $stat->end->toW3cString(), $count, $amount )); return $stat; } #[Override] public function deleteStatisticsForPrefix(UserGroup $userGroup, string $prefix, Carbon $date): void { $userGroup->periodStatistics()->where('start', '<=', $date)->where('end', '>=', $date)->where('type', 'LIKE', sprintf('%s%%', $prefix))->delete(); } }