Completed
Push — master ( eece82...d22127 )
by Carlos
05:06 queued 02:13
created

MerchantPay   A

Complexity

Total Complexity 8

Size/Duplication

Total Lines 81
Duplicated Lines 100 %

Coupling/Cohesion

Components 1
Dependencies 1

Test Coverage

Coverage 0%

Importance

Changes 4
Bugs 0 Features 3
Metric Value
wmc 8
lcom 1
cbo 1
dl 81
loc 81
ccs 0
cts 20
cp 0
rs 10
c 4
b 0
f 3

6 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 4 4 1
A setMerchant() 4 4 1
A getMerchant() 4 4 1
A setAPI() 4 4 1
A getAPI() 4 4 2
A __call() 6 6 2

How to fix   Duplicated Code   

Duplicated Code

Duplicate code is one of the most pungent code smells. A rule that is often used is to re-structure code once it is duplicated in three or more places.

Common duplication problems, and corresponding solutions are:

1
<?php
2
3
/*
4
 * This file is part of the overtrue/wechat.
5
 *
6
 * (c) overtrue <[email protected]>
7
 *
8
 * This source file is subject to the MIT license that is bundled
9
 * with this source code in the file LICENSE.
10
 */
11
12
/**
13
 * MerchantPay.php.
14
 *
15
 * @author    AC <[email protected]>
16
 * @copyright 2015 overtrue <[email protected]>
17
 *
18
 * @link      https://github.com/overtrue
19
 * @link      http://overtrue.me
20
 */
21
namespace EasyWeChat\Payment\MerchantPay;
22
23
use EasyWeChat\Payment\Merchant;
24
25
/**
26
 * Class MerchantPay.
27
 */
28 View Code Duplication
class MerchantPay
29
{
30
    /**
31
     * @var API
32
     */
33
    protected $api;
34
35
    /**
36
     * Merchant instance.
37
     *
38
     * @var \EasyWeChat\Payment\Merchant
39
     */
40
    protected $merchant;
41
42
    /**
43
     * Constructor.
44
     *
45
     * @param Merchant $merchant
46
     */
47
    public function __construct(Merchant $merchant)
48
    {
49
        $this->merchant = $merchant;
50
    }
51
52
    /**
53
     * Merchant setter.
54
     *
55
     * @param Merchant $merchant
56
     */
57
    public function setMerchant(Merchant $merchant)
58
    {
59
        $this->merchant = $merchant;
60
    }
61
62
    /**
63
     * Merchant getter.
64
     *
65
     * @return Merchant
66
     */
67
    public function getMerchant()
68
    {
69
        return $this->merchant;
70
    }
71
72
    /**
73
     * API setter.
74
     *
75
     * @param API $api
76
     */
77
    public function setAPI(API $api)
78
    {
79
        $this->api = $api;
80
    }
81
82
    /**
83
     * Return API instance.
84
     *
85
     * @return API
86
     */
87
    public function getAPI()
88
    {
89
        return $this->api ?: $this->api = new API($this->getMerchant());
90
    }
91
92
    /**
93
     * Magic call.
94
     *
95
     * @param string $method
96
     * @param array  $args
97
     *
98
     * @return mixed
99
     *
100
     * @codeCoverageIgnore
101
     */
102
    public function __call($method, $args)
103
    {
104
        if (is_callable([$this->getAPI(), $method])) {
105
            return call_user_func_array([$this->api, $method], $args);
106
        }
107
    }
108
}
109