Passed
Push — master ( d7f25f...f789dc )
by Roman
02:17 queued 10s
created

PayoutRequest::setReferenceTransaction()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 2
c 1
b 0
f 0
dl 0
loc 5
rs 10
cc 1
nc 1
nop 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Skrill\Request;
6
7
use Money\Money;
8
use Skrill\ValueObject\Email;
9
use Skrill\ValueObject\Description;
10
use Skrill\ValueObject\TransactionID;
11
use Skrill\Request\Traits\GetPayloadTrait;
12
use Skrill\Request\Traits\AmountFormatterTrait;
13
14
/**
15
 * Class PayoutRequest.
16
 */
17
final class PayoutRequest
18
{
19
    use GetPayloadTrait;
20
    use AmountFormatterTrait;
21
22
    /**
23
     * @param Email       $recipientEmail
24
     * @param Money       $amount
25
     * @param Description $description
26
     */
27
    public function __construct(Money $amount, Description $description)
28
    {
29
        $this->payload = [
30
            'currency' => strval($amount->getCurrency()),
31
            'amount' => $this->formatToFloat($amount),
32
            'subject' => $description->getSubject(),
33
            'note' => $description->getText(),
34
        ];
35
    }
36
37
    /**
38
     * Your reference ID (must be unique if submitted).
39
     *
40
     * @param TransactionID $transactionId
41
     *
42
     * @return $this
43
     */
44
    public function setReferenceTransaction(TransactionID $transactionId): self
45
    {
46
        $this->payload['frn_trn_id'] = strval($transactionId);
47
48
        return $this;
49
    }
50
51
    /**
52
     * Set transaction_id of the original payment for quick checkout payouts
53
     *
54
     * @param TransactionID $transactionId instance
55
     * @return $this
56
     */
57
    public function setOriginalTransactionId(TransactionID $transactionId): self
58
    {
59
        $this->payload['transaction_id'] = strval($transactionId);
60
61
        return $this;
62
    }
63
64
    /**
65
     * Setting The Skrill transaction ID of the original payment.
66
     *
67
     * Used for preparing Neteller payouts with initial neteller's successful deposit
68
     * transaction ID.
69
     *
70
     * @param TransactionID $transactionId instance
71
     * @return $this
72
     */
73
    public function setSkrillOriginalTransactionId(TransactionID $transactionId): self
74
    {
75
        $this->payload['mb_transaction_id'] = strval($transactionId);
76
77
        return $this;
78
    }
79
}
80