Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
10 / 10
100.00% covered (success)
100.00%
2 / 2
CRAP
100.00% covered (success)
100.00%
1 / 1
GetAccountBalanceHistoryAction
100.00% covered (success)
100.00%
10 / 10
100.00% covered (success)
100.00%
2 / 2
3
100.00% covered (success)
100.00%
1 / 1
 __construct
100.00% covered (success)
100.00%
2 / 2
100.00% covered (success)
100.00%
1 / 1
1
 __invoke
100.00% covered (success)
100.00%
8 / 8
100.00% covered (success)
100.00%
1 / 1
2
1<?php
2
3declare(strict_types=1);
4
5namespace App\Action\Account;
6
7use App\Domain\Account\Service\AccountService;
8use App\Renderer\JsonRenderer;
9use InvalidArgumentException;
10use Psr\Http\Message\ResponseInterface;
11use Psr\Http\Message\ServerRequestInterface;
12
13/**
14 * Returns balance history for charting.
15 *
16 * GET /api/accounts/{id}/balance-history
17 */
18final class GetAccountBalanceHistoryAction
19{
20    private AccountService $service;
21
22    private JsonRenderer $renderer;
23
24    public function __construct(
25        AccountService $service,
26        JsonRenderer $renderer,
27    ) {
28        $this->service = $service;
29        $this->renderer = $renderer;
30    }
31
32    /**
33     * @param array<string, string> $args
34     * @param ServerRequestInterface $request
35     * @param ResponseInterface $response
36     */
37    public function __invoke(
38        ServerRequestInterface $request,
39        ResponseInterface $response,
40        array $args,
41    ): ResponseInterface {
42        $accountId = (int)$args['id'];
43
44        if ($accountId <= 0) {
45            throw new InvalidArgumentException('Invalid account ID');
46        }
47
48        $history = $this->service->getBalanceHistory($accountId);
49
50        return $this->renderer->json($response, [
51            'success' => true,
52            'data' => $history,
53        ]);
54    }
55}