Completed
Push — master ( 45d8dc...fe9038 )
by Frederik
02:32
created

EntryTransactionDetail::getRelatedPartyAccount()   D

Complexity

Conditions 10
Paths 14

Size

Total Lines 35
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
c 1
b 0
f 0
dl 0
loc 35
ccs 6
cts 19
cp 0.3158
rs 4.8196
cc 10
eloc 18
nc 14
nop 1
crap 42.0294

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 = null)
16
    {
17 11
        if($xmlRelatedPartyTypeAccount){
18 11
            if (false === isset($xmlRelatedPartyTypeAccount->Id)) {
19
                return;
20
            }
21
22 11
            if (isset($xmlRelatedPartyTypeAccount->Id->IBAN) && $ibanCode = (string) $xmlRelatedPartyTypeAccount->Id->IBAN) {
23 11
                return new DTO\IbanAccount(new Iban($ibanCode));
24
            }
25
26
            if (false === isset($xmlRelatedPartyTypeAccount->Id->Othr)) {
27
                return;
28
            }
29
30
            $xmlOtherIdentification = $xmlRelatedPartyTypeAccount->Id->Othr;
31
            $otherAccount = new DTO\OtherAccount((string) $xmlOtherIdentification->Id);
32
33
            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
            if (isset($xmlOtherIdentification->Issr)) {
44
                $otherAccount->setIssuer((string) $xmlOtherIdentification->Issr);
45
            }
46
47
            return $otherAccount;
48
        }
49 5
    }
50
}
51