getSignatureDataFormatter()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 1
eloc 1
c 1
b 0
f 1
nc 1
nop 0
dl 0
loc 3
rs 10
ccs 0
cts 2
cp 0
crap 2
1
<?php declare(strict_types = 1);
2
3
namespace SlevomatCsobGateway\Call\Extension;
4
5
use DateTimeImmutable;
6
use SlevomatCsobGateway\Call\ResponseExtensionHandler;
7
use SlevomatCsobGateway\Crypto\SignatureDataFormatter;
8
use function array_flip;
9
10
class TransactionSettlementExtension implements ResponseExtensionHandler
11
{
12
13
	public const NAME = 'trxDates';
14
15
	/**
16
	 * @param mixed[] $data
17
	 * @return TransactionSettlementResponse
18
	 */
19 1
	public function createResponse(array $data): TransactionSettlementResponse
20
	{
21 1
		return new TransactionSettlementResponse(
22 1
			new DateTimeImmutable($data['createdDate']),
23 1
			isset($data['authDate']) ? $this->parseAuthDate($data['authDate']) : null,
24 1
			isset($data['settlementDate']) ? $this->parseSettlementDate($data['settlementDate']) : null
25
		);
26
	}
27
28
	public function getSignatureDataFormatter(): SignatureDataFormatter
29
	{
30
		return new SignatureDataFormatter(array_flip(['extension', 'dttm', 'createdDate', 'authDate', 'settlementDate']));
31
	}
32
33 1
	private function parseAuthDate(string $authDate): DateTimeImmutable
34
	{
35 1
		return DateTimeImmutable::createFromFormat('ymdHis', $authDate);
0 ignored issues
show
Bug Best Practice introduced by
The expression return DateTimeImmutable...at('ymdHis', $authDate) could return the type false which is incompatible with the type-hinted return DateTimeImmutable. Consider adding an additional type-check to rule them out.
Loading history...
36
	}
37
38 1
	private function parseSettlementDate(string $settlementDate): DateTimeImmutable
39
	{
40 1
		return DateTimeImmutable::createFromFormat('Ymd', $settlementDate)->setTime(0, 0, 0);
0 ignored issues
show
Bug Best Practice introduced by
The expression return DateTimeImmutable...Date)->setTime(0, 0, 0) could return the type false which is incompatible with the type-hinted return DateTimeImmutable. Consider adding an additional type-check to rule them out.
Loading history...
41
	}
42
43
}
44