Passed
Push — master ( 34bc8c...92daf4 )
by
unknown
02:28
created

MangoPayConstants::isDocumentTypeOk()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 4
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 1
1
<?php
2
/**
3
 * Created by Graham Owens ([email protected])
4
 * Company: PartFire Ltd (www.partfire.co.uk)
5
 * Console: Discovery
6
 *
7
 * User:    gra
8
 * Date:    31/12/16
9
 * Time:    00:53
10
 * Project: PartFire MangoPay Bundle
11
 * File:    MangoPayConstants.php
12
 *
13
 **/
14
15
namespace PartFire\MangoPayBundle;
16
17
18
class MangoPayConstants
19
{
20
    const       NATURAL_PERSON_TYPE                 = 'NATURAL';
21
    const       LEGAL_PERSON_TYPE                   = 'LEGAL';
22
23
    //  https://docs.mangopay.com/endpoints/v2.01/users#e259_create-a-legal-user
24
25
    //  May also help https://www.gov.uk/business-legal-structures/overview
26
27
    const       LEGAL_PERSON_TYPE_SOLETRADER        = 'SOLETRADER';
28
    const       LEGAL_PERSON_TYPE_ORGANISATION      = 'ORGANIZATION';
29
    const       LEGAL_PERSON_TYPE_BUSINESS          = 'BUSINESS';
30
31
    //  https://docs.mangopay.com/endpoints/v2.01/users#e253_the-user-object
32
33
    const       KYC_LEVEL_LIGHT                     = 'LIGHT';
34
    const       KYC_LEVEL_REGULAR                   = 'REGULAR';
35
36
    // https://docs.mangopay.com/endpoints/v2/users#e254_the-natural-user-object
37
38
    // KYC Doc types = https://docs.mangopay.com/endpoints/v2.01/kyc-documents#e205_create-a-kyc-document
39
    const       IDENTITY_PROOF                      = 'IDENTITY_PROOF';
40
    const       REGISTRATION_PROOF                  = 'REGISTRATION_PROOF';
41
    const       ARTICLES_OF_ASSOCIATION             = 'ARTICLES_OF_ASSOCIATION';
42
    const       SHAREHOLDER_DECLARATION             = 'SHAREHOLDER_DECLARATION';
43
    const       ADDRESS_PROOF                       = 'ADDRESS_PROOF';
44
45
    // KYC Doc Refusal reasons
46
47
    const       DOCUMENT_UNREADABLE                 = 'DOCUMENT_UNREADABLE';
48
    const       DOCUMENT_NOT_ACCEPTED               = 'DOCUMENT_NOT_ACCEPTED';
49
    const       DOCUMENT_HAS_EXPIRED                = 'DOCUMENT_HAS_EXPIRED';
50
    const       DOCUMENT_INCOMPLETE                 = 'DOCUMENT_INCOMPLETE';
51
    const       DOCUMENT_MISSING                    = 'DOCUMENT_MISSING';
52
    const       DOCUMENT_DO_NOT_MATCH_USER_DATA     = 'DOCUMENT_DO_NOT_MATCH_USER_DATA';
53
    const       DOCUMENT_DO_NOT_MATCH_ACCOUNT_DATA  = 'DOCUMENT_DO_NOT_MATCH_ACCOUNT_DATA';
54
    const       SPECIFIC_CASE                       = 'SPECIFIC_CASE';
55
    const       DOCUMENT_FALSIFIED                  = 'DOCUMENT_FALSIFIED';
56
    const       UNDERAGE_PERSON                     = 'UNDERAGE_PERSON';
57
    const       OTHER                               = 'OTHER';
58
    const       TRIGGER_PEPS                        = 'TRIGGER_PEPS';
59
    const       TRIGGER_SANCTIONS_LISTS             = 'TRIGGER_SANCTIONS_LISTS';
60
    const       TRIGGER_INTERPOL                    = 'TRIGGER_INTERPOL';
61
62
    // KYC Doc Status
63
64
    const       CREATED                             = 'CREATED';
65
    const       VALIDATION_ASKED                    = 'VALIDATION_ASKED';
66
    const       VALIDATED                           = 'VALIDATED';
67
    const       REFUSED                             = 'REFUSED';
68
69
    // Hook Status
70
    const       HOOK_NEW                            = "HOOK_NEW";
71
    const       HOOK_IN_PROGRESS                    = "HOOK_IN_PROGRESS";
72
    const       HOOK_ACTIONED                       = "HOOK_ACTIONED";
73
74
    public static function getKYCRefusalArray() : array
75
    {
76
        return [
77
            self::DOCUMENT_UNREADABLE,
78
            self::DOCUMENT_NOT_ACCEPTED,
79
            self::DOCUMENT_HAS_EXPIRED,
80
            self::DOCUMENT_INCOMPLETE,
81
            self::DOCUMENT_MISSING,
82
            self::DOCUMENT_DO_NOT_MATCH_USER_DATA,
83
            self::DOCUMENT_DO_NOT_MATCH_ACCOUNT_DATA,
84
            self::SPECIFIC_CASE,
85
            self::DOCUMENT_FALSIFIED,
86
            self::UNDERAGE_PERSON,
87
            self::OTHER,
88
            self::TRIGGER_PEPS,
89
            self::TRIGGER_SANCTIONS_LISTS,
90
            self::TRIGGER_INTERPOL
91
        ];
92
    }
93
94
    public static function getIncomeRangeFromId(int $id) : string
95
    {
96
        switch ($id) {
97
            case 1:
98
                $range = "incomes <18K€";
99
                break;
100
            case 2:
101
                $range = "incomes between 18 and 30K€";
102
                break;
103
            case 3:
104
                $range = "incomes between 30 and 50K€";
105
                break;
106
            case 4:
107
                $range = "incomes between 50 and 80K€";
108
                break;
109
            case 5:
110
                $range = "incomes between 80 and 120K€";
111
                break;
112
            case 6:
113
                $range = "incomes>120K€";
114
                break;
115
            default:
116
                $range = "Unknown range";
117
        }
118
119
        return $range;
120
    }
121
122
    public static function isPersonTypeOk($personType)
123
    {
124
        return in_array($personType, self::getPersonTypeArray());
125
    }
126
127
    public static function getPersonTypeArray()
128
    {
129
        return [
130
            self::NATURAL_PERSON_TYPE,
131
            self::LEGAL_PERSON_TYPE
132
        ];
133
    }
134
135
    public static function isDocumentTypeOk($documentType)
136
    {
137
        return in_array($documentType, self::getDocumentTypeArray());
138
    }
139
140
    public static function getDocumentTypeArray()
141
    {
142
        return [
143
            self::IDENTITY_PROOF,
144
            self::REGISTRATION_PROOF,
145
            self::ARTICLES_OF_ASSOCIATION,
146
            self::SHAREHOLDER_DECLARATION,
147
            self::ADDRESS_PROOF
148
        ];
149
    }
150
151
    //  https://docs.mangopay.com/endpoints/v2.01/hooks#e246_the-hook-object
152
    // 16th Jan 2017
153
154
    public static function isEventTypeOk($eventType)
155
    {
156
        return in_array($eventType, self::getAllEventTypes());
157
    }
158
159
    public static function getAllEventTypes()
160
    {
161
        return [
162
            'PAYIN_NORMAL_CREATED',
163
            'PAYIN_NORMAL_SUCCEEDED',
164
            'PAYIN_NORMAL_FAILED',
165
166
            'PAYOUT_NORMAL_CREATED',
167
            'PAYOUT_NORMAL_SUCCEEDED',
168
            'PAYOUT_NORMAL_FAILED',
169
170
            'TRANSFER_NORMAL_CREATED',
171
            'TRANSFER_NORMAL_SUCCEEDED',
172
            'TRANSFER_NORMAL_FAILED',
173
174
            'PAYIN_REFUND_CREATED',
175
            'PAYIN_REFUND_SUCCEEDED',
176
            'PAYIN_REFUND_FAILED',
177
178
            'PAYOUT_REFUND_CREATED',
179
            'PAYOUT_REFUND_SUCCEEDED',
180
            'PAYOUT_REFUND_FAILED',
181
182
            'TRANSFER_REFUND_CREATED',
183
            'TRANSFER_REFUND_SUCCEEDED',
184
            'TRANSFER_REFUND_FAILED',
185
186
            'PAYIN_REPUDIATION_CREATED',
187
            'PAYIN_REPUDIATION_SUCCEEDED',
188
            'PAYIN_REPUDIATION_FAILED',
189
190
            'KYC_CREATED',
191
            'KYC_SUCCEEDED',
192
            'KYC_FAILED',
193
            'KYC_VALIDATION_ASKED',
194
195
            'DISPUTE_DOCUMENT_CREATED',
196
            'DISPUTE_DOCUMENT_VALIDATION_ASKED',
197
            'DISPUTE_DOCUMENT_SUCCEEDED',
198
            'DISPUTE_DOCUMENT_FAILED',
199
200
            'DISPUTE_CREATED',
201
            'DISPUTE_SUBMITTED',
202
            'DISPUTE_ACTION_REQUIRED',
203
            'DISPUTE_FURTHER_ACTION_REQUIRED',
204
            'DISPUTE_CLOSED',
205
            'DISPUTE_SENT_TO_BANK',
206
207
            'TRANSFER_SETTLEMENT_CREATED',
208
            'TRANSFER_SETTLEMENT_SUCCEEDED',
209
            'TRANSFER_SETTLEMENT_FAILED',
210
211
            'MANDATE_CREATED',
212
            'MANDATED_FAILED',
213
            'MANDATE_ACTIVATED',
214
            'MANDATE_SUBMITTED',
215
216
            'PREAUTHORIZATION_PAYMENT_WAITING',
217
            // (not currently available) 'PREAUTHORIZATION_PAYMENT_EXPIRED',
0 ignored issues
show
Unused Code Comprehensibility introduced by
37% of this comment could be valid code. Did you maybe forget this after debugging?

Sometimes obsolete code just ends up commented out instead of removed. In this case it is better to remove the code once you have checked you do not need it.

The code might also have been commented out for debugging purposes. In this case it is vital that someone uncomments it again or your project may behave in very unexpected ways in production.

This check looks for comments that seem to be mostly valid code and reports them.

Loading history...
218
            'PREAUTHORIZATION_PAYMENT_CANCELED',
219
            'PREAUTHORIZATION_PAYMENT_VALIDATED',
220
221
        ];
222
    }
223
}