RefundRequestBuilder   A
last analyzed

Complexity

Total Complexity 8

Size/Duplication

Total Lines 123
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 8
eloc 26
dl 0
loc 123
rs 10
c 0
b 0
f 0

8 Methods

Rating   Name   Duplication   Size   Complexity  
A buildBaseRefundRequestForOrder() 0 6 1
A addOrderItemToRefundRequest() 0 9 1
A addOrderExpenseToRefundRequest() 0 8 1
A buildExpenseItemTransfer() 0 10 1
A addOrderItemToRefundDetails() 0 5 1
A intToDecimalString() 0 3 1
A __construct() 0 6 1
A decimalToInt() 0 3 1
1
<?php
2
3
/**
4
 * MIT License
5
 * For full license information, please view the LICENSE file that was distributed with this source code.
6
 */
7
8
namespace SprykerEco\Zed\AfterPay\Business\Payment\Transaction\Refund;
9
10
use Generated\Shared\Transfer\AfterPayRefundRequestTransfer;
0 ignored issues
show
Bug introduced by
The type Generated\Shared\Transfe...ayRefundRequestTransfer was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
11
use Generated\Shared\Transfer\AfterPayRequestOrderItemTransfer;
0 ignored issues
show
Bug introduced by
The type Generated\Shared\Transfe...equestOrderItemTransfer was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
12
use Generated\Shared\Transfer\ItemTransfer;
0 ignored issues
show
Bug introduced by
The type Generated\Shared\Transfer\ItemTransfer was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
13
use Generated\Shared\Transfer\OrderTransfer;
0 ignored issues
show
Bug introduced by
The type Generated\Shared\Transfer\OrderTransfer was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
14
use SprykerEco\Shared\AfterPay\AfterPayConfig;
15
use SprykerEco\Zed\AfterPay\Business\Payment\Mapper\OrderToRequestTransferInterface;
16
use SprykerEco\Zed\AfterPay\Dependency\Facade\AfterPayToMoneyFacadeInterface;
17
18
class RefundRequestBuilder implements RefundRequestBuilderInterface
19
{
20
    /**
21
     * @var int
22
     */
23
    protected const ZERO_AMOUNT = 0;
24
25
    /**
26
     * @var \SprykerEco\Zed\AfterPay\Business\Payment\Mapper\OrderToRequestTransferInterface
27
     */
28
    protected $orderToRequestMapper;
29
30
    /**
31
     * @var \SprykerEco\Zed\AfterPay\Dependency\Facade\AfterPayToMoneyFacadeInterface
32
     */
33
    protected $money;
34
35
    /**
36
     * @param \SprykerEco\Zed\AfterPay\Business\Payment\Mapper\OrderToRequestTransferInterface $orderToRequestMapper
37
     * @param \SprykerEco\Zed\AfterPay\Dependency\Facade\AfterPayToMoneyFacadeInterface $money
38
     */
39
    public function __construct(
40
        OrderToRequestTransferInterface $orderToRequestMapper,
41
        AfterPayToMoneyFacadeInterface $money
42
    ) {
43
        $this->orderToRequestMapper = $orderToRequestMapper;
44
        $this->money = $money;
45
    }
46
47
    /**
48
     * @param \Generated\Shared\Transfer\OrderTransfer $orderTransfer
49
     *
50
     * @return \Generated\Shared\Transfer\AfterPayRefundRequestTransfer
51
     */
52
    public function buildBaseRefundRequestForOrder(OrderTransfer $orderTransfer): AfterPayRefundRequestTransfer
53
    {
54
        $refundRequestTransfer = $this->orderToRequestMapper
55
            ->orderToBaseRefundRequest($orderTransfer);
56
57
        return $refundRequestTransfer;
58
    }
59
60
    /**
61
     * @param \Generated\Shared\Transfer\ItemTransfer $orderItemTransfer
62
     * @param \Generated\Shared\Transfer\AfterPayRefundRequestTransfer $refundRequestTransfer
63
     *
64
     * @return \SprykerEco\Zed\AfterPay\Business\Payment\Transaction\Refund\RefundRequestBuilderInterface
65
     */
66
    public function addOrderItemToRefundRequest(
67
        ItemTransfer $orderItemTransfer,
68
        AfterPayRefundRequestTransfer $refundRequestTransfer
69
    ): RefundRequestBuilderInterface {
70
        $orderItemRequestTransfer = $this->orderToRequestMapper->orderItemToAfterPayItemRequest($orderItemTransfer);
71
72
        $this->addOrderItemToRefundDetails($orderItemRequestTransfer, $refundRequestTransfer);
73
74
        return $this;
75
    }
76
77
    /**
78
     * @param int $expenseAmount
79
     * @param \Generated\Shared\Transfer\AfterPayRefundRequestTransfer $refundRequestTransfer
80
     *
81
     * @return \SprykerEco\Zed\AfterPay\Business\Payment\Transaction\Refund\RefundRequestBuilderInterface
82
     */
83
    public function addOrderExpenseToRefundRequest(
84
        int $expenseAmount,
85
        AfterPayRefundRequestTransfer $refundRequestTransfer
86
    ): RefundRequestBuilderInterface {
87
        $expenseItemRequestTransfer = $this->buildExpenseItemTransfer($expenseAmount);
88
        $this->addOrderItemToRefundRequest($expenseItemRequestTransfer, $refundRequestTransfer);
89
90
        return $this;
91
    }
92
93
    /**
94
     * @param \Generated\Shared\Transfer\AfterPayRequestOrderItemTransfer $orderItemRequestTransfer
95
     * @param \Generated\Shared\Transfer\AfterPayRefundRequestTransfer $refundRequestTransfer
96
     *
97
     * @return void
98
     */
99
    protected function addOrderItemToRefundDetails(
100
        AfterPayRequestOrderItemTransfer $orderItemRequestTransfer,
101
        AfterPayRefundRequestTransfer $refundRequestTransfer
102
    ): void {
103
        $refundRequestTransfer->addOrderItem($orderItemRequestTransfer);
104
    }
105
106
    /**
107
     * @param int $expenseAmount
108
     *
109
     * @return \Generated\Shared\Transfer\ItemTransfer
110
     */
111
    protected function buildExpenseItemTransfer(int $expenseAmount): ItemTransfer
112
    {
113
        return (new ItemTransfer())
114
            ->setSku(AfterPayConfig::REFUND_EXPENSE_SKU)
115
            ->setName(AfterPayConfig::REFUND_EXPENSE_DECRIPTION)
116
            ->setUnitGrossPrice($expenseAmount)
117
            ->setUnitPriceToPayAggregation($expenseAmount)
118
            ->setUnitTaxAmountFullAggregation(static::ZERO_AMOUNT)
119
            ->setTaxRate(static::ZERO_AMOUNT)
120
            ->setQuantity(1);
121
    }
122
123
    /**
124
     * @param float $decimalValue
125
     *
126
     * @return int
127
     */
128
    protected function decimalToInt(float $decimalValue): int
129
    {
130
        return $this->money->convertDecimalToInteger($decimalValue);
131
    }
132
133
    /**
134
     * @param int $intValue
135
     *
136
     * @return string
137
     */
138
    protected function intToDecimalString(int $intValue): string
139
    {
140
        return (string)$this->money->convertIntegerToDecimal($intValue);
141
    }
142
}
143