mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-31 10:47:00 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			144 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| declare(strict_types=1);
 | |
| /*
 | |
|  * PeriodStatisticRepository.php
 | |
|  * Copyright (c) 2025 james@firefly-iii.org
 | |
|  *
 | |
|  * This file is part of Firefly III (https://github.com/firefly-iii).
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Affero General Public License as
 | |
|  * published by the Free Software Foundation, either version 3 of the
 | |
|  * License, or (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Affero General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Affero General Public License
 | |
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| 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();
 | |
|     }
 | |
| }
 |