Failed Conditions
Push — master ( c19c1b...d89672 )
by Adrien
05:11
created

EntryTransactionDetail::getRelatedPartyAccount()   B

Complexity

Conditions 10
Paths 14

Size

Total Lines 36
Code Lines 18

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 6
CRAP Score 42.0294

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 10
eloc 18
c 1
b 0
f 0
nc 14
nop 1
dl 0
loc 36
ccs 6
cts 19
cp 0.3158
crap 42.0294
rs 7.6666

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
namespace Genkgo\Camt\Camt053\Decoder;
4
5
use Genkgo\Camt\Decoder\EntryTransactionDetail as BaseDecoder;
6
use Genkgo\Camt\DTO;
7
use Genkgo\Camt\Iban;
8
use SimpleXMLElement;
9
10
class EntryTransactionDetail extends BaseDecoder
11
{
12
    /**
13
     * {@inheritdoc}
14
     */
15 12
    public function getRelatedPartyAccount(?SimpleXMLElement $xmlRelatedPartyTypeAccount): ?DTO\Account
16
    {
17 12
        if (!$xmlRelatedPartyTypeAccount) {
18 5
            return null;
19
        }
20
21 12
        if (false === isset($xmlRelatedPartyTypeAccount->Id)) {
22
            return null;
23
        }
24
25 12
        if (isset($xmlRelatedPartyTypeAccount->Id->IBAN) && $ibanCode = (string) $xmlRelatedPartyTypeAccount->Id->IBAN) {
26 12
            return new DTO\IbanAccount(new Iban($ibanCode));
27
        }
28
29
        if (false === isset($xmlRelatedPartyTypeAccount->Id->Othr)) {
30
            return null;
31
        }
32
33
        $xmlOtherIdentification = $xmlRelatedPartyTypeAccount->Id->Othr;
34
        $otherAccount = new DTO\OtherAccount((string) $xmlOtherIdentification->Id);
35
36
        if (isset($xmlOtherIdentification->SchmeNm)) {
37
            if (isset($xmlOtherIdentification->SchmeNm->Cd)) {
38
                $otherAccount->setSchemeName((string) $xmlOtherIdentification->SchmeNm->Cd);
39
            }
40
41
            if (isset($xmlOtherIdentification->SchmeNm->Prtry)) {
42
                $otherAccount->setSchemeName((string) $xmlOtherIdentification->SchmeNm->Prtry);
43
            }
44
        }
45
46
        if (isset($xmlOtherIdentification->Issr)) {
47
            $otherAccount->setIssuer((string) $xmlOtherIdentification->Issr);
48
        }
49
50
        return $otherAccount;
51
    }
52
}
53