Completed
Push — master ( b5ae25...349033 )
by Frederik
02:37
created

EntryTransactionDetail::addReferences()   D

Complexity

Conditions 18
Paths 6

Size

Total Lines 32
Code Lines 23

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 25
CRAP Score 18

Importance

Changes 2
Bugs 0 Features 1
Metric Value
c 2
b 0
f 1
dl 0
loc 32
ccs 25
cts 25
cp 1
rs 4.947
cc 18
eloc 23
nc 6
nop 2
crap 18

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