Completed
Pull Request — master (#21)
by Yann
02:47
created

EntryTransactionDetail::addRelatedParties()   C

Complexity

Conditions 11
Paths 23

Size

Total Lines 42
Code Lines 27

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 29
CRAP Score 11.3851

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 42
ccs 29
cts 34
cp 0.8529
rs 5.2653
cc 11
eloc 27
nc 23
nop 2
crap 11.3851

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