mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 21:16:47 +00:00 
			
		
		
		
	🤖 Auto commit for release 'develop' on 2025-09-01
This commit is contained in:
		| @@ -108,7 +108,7 @@ abstract class Controller extends BaseController | ||||
|     { | ||||
|         $bag      = new ParameterBag(); | ||||
|         $page     = (int)request()->get('page'); | ||||
|         $page = min(max(1, $page), 2 ** 16); | ||||
|         $page     = min(max(1, $page), 2 ** 16); | ||||
|         $bag->set('page', $page); | ||||
| 
 | ||||
|         // some date fields:
 | ||||
| @@ -132,7 +132,7 @@ abstract class Controller extends BaseController | ||||
|                     Log::warning(sprintf('Ignored invalid date "%s" in API controller parameter check: %s', substr((string)$date, 0, 20), $e->getMessage())); | ||||
|                 } | ||||
|             } | ||||
|             if($obj instanceof Carbon){ | ||||
|             if ($obj instanceof Carbon) { | ||||
|                 $bag->set($field, $obj); | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -73,38 +73,38 @@ class ShowController extends Controller | ||||
|      */ | ||||
|     public function index(ShowRequest $request): JsonResponse | ||||
|     { | ||||
|         $manager = $this->getManager(); | ||||
|         $params  = $request->getParameters(); | ||||
|         $manager     = $this->getManager(); | ||||
|         $params      = $request->getParameters(); | ||||
|         $this->parameters->set('type', $params['type']); | ||||
| 
 | ||||
|         // types to get, page size:
 | ||||
|         $types    = $this->mapAccountTypes($params['type']); | ||||
|         $types       = $this->mapAccountTypes($params['type']); | ||||
| 
 | ||||
|         // get list of accounts. Count it and split it.
 | ||||
|         $this->repository->resetAccountOrder(); | ||||
|         $collection = $this->repository->getAccountsByType($types, $params['sort']); | ||||
|         $count      = $collection->count(); | ||||
|         $collection  = $this->repository->getAccountsByType($types, $params['sort']); | ||||
|         $count       = $collection->count(); | ||||
| 
 | ||||
|         // continue sort:
 | ||||
|         $accounts = $collection->slice(($this->parameters->get('page') - 1) * $params['limit'], $params['limit']); | ||||
|         $accounts    = $collection->slice(($this->parameters->get('page') - 1) * $params['limit'], $params['limit']); | ||||
| 
 | ||||
|         // enrich
 | ||||
|         /** @var User $admin */ | ||||
|         $admin      = auth()->user(); | ||||
|         $enrichment = new AccountEnrichment(); | ||||
|         $admin       = auth()->user(); | ||||
|         $enrichment  = new AccountEnrichment(); | ||||
|         $enrichment->setDate($this->parameters->get('date')); | ||||
|         $enrichment->setUser($admin); | ||||
|         $accounts = $enrichment->enrich($accounts); | ||||
|         $accounts    = $enrichment->enrich($accounts); | ||||
| 
 | ||||
|         // make paginator:
 | ||||
|         $paginator = new LengthAwarePaginator($accounts, $count, $params['limit'], $this->parameters->get('page')); | ||||
|         $paginator->setPath(route('api.v1.accounts.index') . $this->buildParams()); | ||||
|         $paginator   = new LengthAwarePaginator($accounts, $count, $params['limit'], $this->parameters->get('page')); | ||||
|         $paginator->setPath(route('api.v1.accounts.index').$this->buildParams()); | ||||
| 
 | ||||
|         /** @var AccountTransformer $transformer */ | ||||
|         $transformer = app(AccountTransformer::class); | ||||
|         $transformer->setParameters($this->parameters); | ||||
| 
 | ||||
|         $resource = new FractalCollection($accounts, $transformer, self::RESOURCE_KEY); | ||||
|         $resource    = new FractalCollection($accounts, $transformer, self::RESOURCE_KEY); | ||||
|         $resource->setPaginator(new IlluminatePaginatorAdapter($paginator)); | ||||
| 
 | ||||
|         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE); | ||||
| @@ -121,21 +121,21 @@ class ShowController extends Controller | ||||
|         // get list of accounts. Count it and split it.
 | ||||
|         $this->repository->resetAccountOrder(); | ||||
|         $account->refresh(); | ||||
|         $manager = $this->getManager(); | ||||
|         $manager     = $this->getManager(); | ||||
| 
 | ||||
|         // enrich
 | ||||
|         /** @var User $admin */ | ||||
|         $admin      = auth()->user(); | ||||
|         $enrichment = new AccountEnrichment(); | ||||
|         $admin       = auth()->user(); | ||||
|         $enrichment  = new AccountEnrichment(); | ||||
|         $enrichment->setDate($this->parameters->get('date')); | ||||
|         $enrichment->setUser($admin); | ||||
|         $account = $enrichment->enrichSingle($account); | ||||
|         $account     = $enrichment->enrichSingle($account); | ||||
| 
 | ||||
| 
 | ||||
|         /** @var AccountTransformer $transformer */ | ||||
|         $transformer = app(AccountTransformer::class); | ||||
|         $transformer->setParameters($this->parameters); | ||||
|         $resource = new Item($account, $transformer, self::RESOURCE_KEY); | ||||
|         $resource    = new Item($account, $transformer, self::RESOURCE_KEY); | ||||
| 
 | ||||
|         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE); | ||||
|     } | ||||
|   | ||||
| @@ -70,10 +70,10 @@ class ShowController extends Controller | ||||
|      */ | ||||
|     public function index(): JsonResponse | ||||
|     { | ||||
|         $manager = $this->getManager(); | ||||
|         $manager     = $this->getManager(); | ||||
| 
 | ||||
|         // types to get, page size:
 | ||||
|         $pageSize = $this->parameters->get('limit'); | ||||
|         $pageSize    = $this->parameters->get('limit'); | ||||
| 
 | ||||
|         // get list of budgets. Count it and split it.
 | ||||
|         $collection  = $this->repository->get(); | ||||
| @@ -82,20 +82,20 @@ class ShowController extends Controller | ||||
| 
 | ||||
|         // enrich
 | ||||
|         /** @var User $admin */ | ||||
|         $admin      = auth()->user(); | ||||
|         $enrichment = new RecurringEnrichment(); | ||||
|         $admin       = auth()->user(); | ||||
|         $enrichment  = new RecurringEnrichment(); | ||||
|         $enrichment->setUser($admin); | ||||
|         $recurrences = $enrichment->enrich($recurrences); | ||||
| 
 | ||||
|         // make paginator:
 | ||||
|         $paginator = new LengthAwarePaginator($recurrences, $count, $pageSize, $this->parameters->get('page')); | ||||
|         $paginator->setPath(route('api.v1.recurrences.index') . $this->buildParams()); | ||||
|         $paginator   = new LengthAwarePaginator($recurrences, $count, $pageSize, $this->parameters->get('page')); | ||||
|         $paginator->setPath(route('api.v1.recurrences.index').$this->buildParams()); | ||||
| 
 | ||||
|         /** @var RecurrenceTransformer $transformer */ | ||||
|         $transformer = app(RecurrenceTransformer::class); | ||||
|         $transformer->setParameters($this->parameters); | ||||
| 
 | ||||
|         $resource = new FractalCollection($recurrences, $transformer, 'recurrences'); | ||||
|         $resource    = new FractalCollection($recurrences, $transformer, 'recurrences'); | ||||
|         $resource->setPaginator(new IlluminatePaginatorAdapter($paginator)); | ||||
| 
 | ||||
|         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE); | ||||
| @@ -109,23 +109,21 @@ class ShowController extends Controller | ||||
|      */ | ||||
|     public function show(Recurrence $recurrence): JsonResponse | ||||
|     { | ||||
|         $manager = $this->getManager(); | ||||
|         $manager     = $this->getManager(); | ||||
| 
 | ||||
|         // enrich
 | ||||
|         /** @var User $admin */ | ||||
|         $admin      = auth()->user(); | ||||
|         $enrichment = new RecurringEnrichment(); | ||||
|         $admin       = auth()->user(); | ||||
|         $enrichment  = new RecurringEnrichment(); | ||||
|         $enrichment->setUser($admin); | ||||
|         $recurrence = $enrichment->enrichSingle($recurrence); | ||||
|         $recurrence  = $enrichment->enrichSingle($recurrence); | ||||
| 
 | ||||
|         /** @var RecurrenceTransformer $transformer */ | ||||
|         $transformer = app(RecurrenceTransformer::class); | ||||
|         $transformer->setParameters($this->parameters); | ||||
| 
 | ||||
|         $resource = new Item($recurrence, $transformer, 'recurrences'); | ||||
|         $resource    = new Item($recurrence, $transformer, 'recurrences'); | ||||
| 
 | ||||
|         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,6 @@ | ||||
| <?php | ||||
| 
 | ||||
| declare(strict_types=1); | ||||
| /* | ||||
|  * TriggerController.php | ||||
|  * Copyright (c) 2025 james@firefly-iii.org | ||||
| @@ -58,27 +60,25 @@ class TriggerController extends Controller | ||||
|         ); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      */ | ||||
|     public function trigger(SingleDateRequest $request, Recurrence $recurrence): JsonResponse | ||||
|     { | ||||
|         // find recurrence occurrence for this date and trigger it.
 | ||||
|         // grab the date from the last time the recurrence fired:
 | ||||
|         $backupDate = $recurrence->latest_date; | ||||
|         $date       = $request->getDate(); | ||||
|         $backupDate                 = $recurrence->latest_date; | ||||
|         $date                       = $request->getDate(); | ||||
| 
 | ||||
|         // fire the recurring cron job on the given date, then post-date the created transaction.
 | ||||
|         Log::info(sprintf('Trigger: will now fire recurring cron job task for date "%s".', $date->format('Y-m-d H:i:s'))); | ||||
| 
 | ||||
|         /** @var CreateRecurringTransactions $job */ | ||||
|         $job = app(CreateRecurringTransactions::class); | ||||
|         $job                        = app(CreateRecurringTransactions::class); | ||||
|         $job->setRecurrences(new Collection()->push($recurrence)); | ||||
|         $job->setDate($date); | ||||
|         $job->setForce(false); | ||||
|         $job->handle(); | ||||
|         Log::debug('Done with recurrence.'); | ||||
| 
 | ||||
|         $groups = $job->getGroups(); | ||||
|         $groups                     = $job->getGroups(); | ||||
|         $this->repository->markGroupsAsNow($groups); | ||||
|         $recurrence->latest_date    = $backupDate; | ||||
|         $recurrence->latest_date_tz = $backupDate?->format('e'); | ||||
| @@ -88,38 +88,39 @@ class TriggerController extends Controller | ||||
|         // enrich groups and return them:
 | ||||
| 
 | ||||
|         if (0 === $groups->count()) { | ||||
|             $paginator = new LengthAwarePaginator(new Collection(), 0, 1,); | ||||
|             $paginator = new LengthAwarePaginator(new Collection(), 0, 1); | ||||
|         } | ||||
|         if ($groups->count() > 0) { | ||||
|             /** @var User $admin */ | ||||
|             $admin = auth()->user(); | ||||
|             $admin     = auth()->user(); | ||||
| 
 | ||||
|             // use new group collector:
 | ||||
|             /** @var GroupCollectorInterface $collector */ | ||||
|             $collector = app(GroupCollectorInterface::class); | ||||
|             $collector | ||||
|                 ->setUser($admin) | ||||
|                 ->setIds($groups->pluck('id')->toArray()) | ||||
|                 ->withAPIInformation(); | ||||
|                 ->withAPIInformation() | ||||
|             ; | ||||
|             $paginator = $collector->getPaginatedGroups(); | ||||
|         } | ||||
| 
 | ||||
|         $manager = $this->getManager(); | ||||
|         $paginator->setPath(route('api.v1.recurrences.trigger', [$recurrence->id]) . $this->buildParams()); | ||||
|         $manager                    = $this->getManager(); | ||||
|         $paginator->setPath(route('api.v1.recurrences.trigger', [$recurrence->id]).$this->buildParams()); | ||||
| 
 | ||||
|         // enrich
 | ||||
|         $admin = auth()->user(); | ||||
|         $enrichment = new TransactionGroupEnrichment(); | ||||
|         $admin                      = auth()->user(); | ||||
|         $enrichment                 = new TransactionGroupEnrichment(); | ||||
|         $enrichment->setUser($admin); | ||||
|         $transactions = $enrichment->enrich($paginator->getCollection()); | ||||
|         $transactions               = $enrichment->enrich($paginator->getCollection()); | ||||
| 
 | ||||
|         /** @var TransactionGroupTransformer $transformer */ | ||||
|         $transformer = app(TransactionGroupTransformer::class); | ||||
|         $transformer                = app(TransactionGroupTransformer::class); | ||||
|         $transformer->setParameters($this->parameters); | ||||
| 
 | ||||
|         $resource = new FractalCollection($transactions, $transformer, 'transactions'); | ||||
|         $resource                   = new FractalCollection($transactions, $transformer, 'transactions'); | ||||
|         $resource->setPaginator(new IlluminatePaginatorAdapter($paginator)); | ||||
| 
 | ||||
|         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,6 @@ | ||||
| <?php | ||||
| 
 | ||||
| declare(strict_types=1); | ||||
| /* | ||||
|  * ShowRequest.php | ||||
|  * Copyright (c) 2025 james@firefly-iii.org | ||||
| @@ -21,7 +23,6 @@ | ||||
| 
 | ||||
| namespace FireflyIII\Api\V1\Requests\Models\Account; | ||||
| 
 | ||||
| 
 | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Models\Preference; | ||||
| use FireflyIII\Support\Facades\Preferences; | ||||
| @@ -33,8 +34,8 @@ use Illuminate\Foundation\Http\FormRequest; | ||||
| 
 | ||||
| class ShowRequest extends FormRequest | ||||
| { | ||||
|     use ConvertsDataTypes; | ||||
|     use AccountFilter; | ||||
|     use ConvertsDataTypes; | ||||
| 
 | ||||
|     public function getParameters(): array | ||||
|     { | ||||
| @@ -42,14 +43,14 @@ class ShowRequest extends FormRequest | ||||
|         if (0 === $limit) { | ||||
|             // get default for user:
 | ||||
|             /** @var User $user */ | ||||
|             $user = auth()->user(); | ||||
|             $user  = auth()->user(); | ||||
| 
 | ||||
|             /** @var Preference $pageSize */ | ||||
|             $limit = (int)Preferences::getForUser($user, 'listPageSize', 50)->data; | ||||
|         } | ||||
| 
 | ||||
|         $page = $this->convertInteger('page'); | ||||
|         $page = min(max(1, $page), 2 ** 16); | ||||
|         $page  = $this->convertInteger('page'); | ||||
|         $page  = min(max(1, $page), 2 ** 16); | ||||
| 
 | ||||
|         return [ | ||||
|             'type'  => $this->convertString('type', 'all'), | ||||
| @@ -61,7 +62,8 @@ class ShowRequest extends FormRequest | ||||
| 
 | ||||
|     public function rules(): array | ||||
|     { | ||||
|         $keys = join(',', array_keys($this->types)); | ||||
|         $keys = implode(',', array_keys($this->types)); | ||||
| 
 | ||||
|         return [ | ||||
|             'date'  => 'date', | ||||
|             'start' => 'date|present_with:end|before_or_equal:end|before:2038-01-17|after:1970-01-02', | ||||
| @@ -90,7 +92,7 @@ class ShowRequest extends FormRequest | ||||
|                         $validator->errors()->add('date', (string)trans('validation.between_date')); | ||||
|                     } | ||||
|                 } | ||||
|             }); | ||||
|             } | ||||
|         ); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|   | ||||
| @@ -851,7 +851,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|      */ | ||||
|     public function getPaginatedGroups(): LengthAwarePaginator | ||||
|     { | ||||
|         $set = $this->getGroups(); | ||||
|         $set   = $this->getGroups(); | ||||
|         if (0 === $this->limit) { | ||||
|             $this->setLimit(50); | ||||
|         } | ||||
| @@ -861,7 +861,8 @@ class GroupCollector implements GroupCollectorInterface | ||||
| 
 | ||||
|             return new LengthAwarePaginator($set, $this->total, $total, 1); | ||||
|         } | ||||
|         $limit= $this->limit ?? 1; | ||||
|         $limit = $this->limit ?? 1; | ||||
| 
 | ||||
|         return new LengthAwarePaginator($set, $this->total, $limit, $this->page); | ||||
|     } | ||||
| 
 | ||||
|   | ||||
| @@ -59,7 +59,7 @@ class RecurringEnrichment implements EnrichmentInterface | ||||
|     private Collection          $collection; | ||||
|     private array               $ids                   = []; | ||||
|     private array               $transactionTypeIds    = []; | ||||
|     //private array               $transactionTypes      = [];
 | ||||
|     // private array               $transactionTypes      = [];
 | ||||
|     private array               $notes                 = []; | ||||
|     private array               $repetitions           = []; | ||||
|     private array               $transactions          = []; | ||||
| @@ -128,14 +128,14 @@ class RecurringEnrichment implements EnrichmentInterface | ||||
|             $this->ids[]                   = $id; | ||||
|             $this->transactionTypeIds[$id] = $typeId; | ||||
|         } | ||||
|         $this->ids        = array_unique($this->ids); | ||||
|         $this->ids = array_unique($this->ids); | ||||
| 
 | ||||
|         // collect transaction types.
 | ||||
| //        $transactionTypes = TransactionType::whereIn('id', array_unique($this->transactionTypeIds))->get();
 | ||||
| //        foreach ($transactionTypes as $transactionType) {
 | ||||
| //            $id                          = (int)$transactionType->id;
 | ||||
| //            $this->transactionTypes[$id] = TransactionTypeEnum::from($transactionType->type);
 | ||||
| //        }
 | ||||
|         //        $transactionTypes = TransactionType::whereIn('id', array_unique($this->transactionTypeIds))->get();
 | ||||
|         //        foreach ($transactionTypes as $transactionType) {
 | ||||
|         //            $id                          = (int)$transactionType->id;
 | ||||
|         //            $this->transactionTypes[$id] = TransactionTypeEnum::from($transactionType->type);
 | ||||
|         //        }
 | ||||
|     } | ||||
| 
 | ||||
|     private function collectRepetitions(): void | ||||
| @@ -414,8 +414,9 @@ class RecurringEnrichment implements EnrichmentInterface | ||||
|             // this should refer to another array, were rtIds can be used to find the recurrence.
 | ||||
|             $recurrenceId  = $this->recurrenceIds[$transactionId] ?? 0; | ||||
|             $name          = (string)$entry->name ?? ''; | ||||
|             if(0 === $recurrenceId) { | ||||
|             if (0 === $recurrenceId) { | ||||
|                 Log::error(sprintf('Could not find recurrence ID for recurrence transaction ID %d', $transactionId)); | ||||
| 
 | ||||
|                 continue; | ||||
|             } | ||||
| 
 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user