-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathCharge.php
262 lines (259 loc) · 14.3 KB
/
Charge.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
<?php
namespace Dfe\Qiwi;
use Df\Payment\Source\Identification;
use Zend_Date as ZD;
/**
* 2017-09-03
* @method Method m()
* @method Settings s()
*/
final class Charge extends \Df\Payment\Charge {
/**
* 2017-09-04 Our local (without the module prefix) internal payment ID.
* @override
* @see \Df\Payment\Operation::id()
* @used-by self::pRedirect()
* @used-by \Dfe\Qiwi\Init\Action::preorder()
* @used-by \Dfe\Qiwi\Init\Action::transId()
*/
function id():string {return dfc($this, function() {return Identification::get($this->o());});}
/**
* 2017-09-04
* 1) The GitHub-based documentation:
* https://github.com/QIWI-API/pull-payments-docs/blob/40d48cf0/_pull-payments-api_en.html.md#request--put
* https://github.com/QIWI-API/pull-payments-docs/blob/40d48cf0/_pull-payments-api_ru.html.md#Запрос--put
* 2) The PDF documentation:
* «4.2. Creating an Invoice», page 7.
* «4.2. Выставление счета пользователю», страница 7.
* `[QIWI Wallet] The REST API specification (v.2.12)`, https://mage2.pro/t/3745
* 3) An online documentation: https://developer.qiwi.com/ru/pull-payments/index.html#invoice_rest
* @used-by \Dfe\Qiwi\Init\Action::preorder()
* @return array(string, array(string => mixed))
*/
function pBill():array {return [
/**
* 2017-09-04
* 1) The GitHub-based documentation:
* «The invoice amount. The rounding up method depends on the invoice currency.»
* «Сумма, на которую выставляется счет. Способ округления зависит от валюты.»
* 2) The PDF documentation:
* «A positive number rounded up to 2 or 3 decimal places after the comma.»
* «Положительное число, округленное до 2 или 3 знаков после десятичной точки.»
* Required, number(6.3). Regex: ^\d+(.\d{0,3})?$
* [QIWI Wallet] What are the rounding rules for each supported currency? https://mage2.pro/t/4454
* @see \Dfe\Qiwi\Method::amountFormat()
*/
'amount' => $this->amountF()
# 2017-09-04
# 1) The GitHub-based documentation:
# «Invoice currency identifier (Alpha-3 ISO 4217 code).
# Depends on currencies allowed for the merchant.
# The following values are supported: RUB, EUR, USD, KZT.»
# «Идентификатор валюты (Alpha-3 ISO 4217 код).
# Может использоваться любая валюта, предусмотренная договором с КИВИ.»
# As you can see, the English and Russian versions of the same documentation
# contain a contradictory information about currencies.
# [QIWI Wallet] Which currencies are supported by the REST API? https://mage2.pro/t/4445
# 2) The PDF documentation: «Three-letter abbreviation» / «Трёхбуквенная аббревиатура».
# Required, string(3). Regex: ^[a-zA-Z]{3}$
,'ccy' => $this->currencyC()
# 2017-09-04
# 1) The GitHub-based documentation: «Comment to the invoice» / «Комментарий к счету».
# 2) The PDF documentation: «Any text up to 255 symbols» / «Любой текст».
# Required, string(255). Regex: ^\.{0,255}$
,'comment' => $this->description()
,'lifetime' => $this->lifetime()
# 2017-09-04
# 1) The GitHub-based documentation:
# «If the value is "mobile" the user’s MNO balance will be used as a funding source.
# If the value is "qw", any other funding source is used available in Visa QIWI Wallet interface.
# If parameter isn’t present, value "qw" is assumed.»
# «"mobile" - оплата счета будет производиться с баланса мобильного телефона пользователя,
# "qw" – любым способом через интерфейс Visa QIWI Wallet.
# По умолчанию "qw".»
# 2) The PDF documentation: «"mobile", "qw"».
# Optional, string. Regex: ^((mobile)|(qw)){1}$
,'pay_source' => 'qw'
# 2017-09-04
# 1) The GitHub-based documentation: «Merchant’s name» / «Название провайдера».
# 2) The PDF documentation: «Any text, not more than 100 symbols» / «Произвольная строка до 100 символов»
# Optional, string(100). Regex: ^\.{1,100}$
,'prv_name' => df_chop($this->store()->getFrontendName(), 100)
# 2017-09-04
# 1) The GitHub-based documentation:
# «The Visa QIWI Wallet user’s ID, to whom the invoice is issued.
# It is the user’s phone number with "tel:" prefix.»
# «Идентификатор номера QIWI Wallet, на который выставляется счет (в международном формате),
# с префиксом "tel:".»
# 2) The PDF documentation:
# «String of the form "tel:phone_number",
# where "phone_number" – wireless phone number in international format.»
# «Строка вида "tel:phone_number", где phone_number – номер мобильного телефона в международном формате.»
# Required, string(20). Regex: ^tel:\+\d{1,15}$
,'user' => "tel:{$this->m()->phone()}"
];}
/**
* 2017-09-04
* «4.3. Redirection for Invoice Payment», page 9.
* «4.3. Переадресация для оплаты счета», страница 9.
* «Merchant may offer a Visa QIWI Wallet user to pay the invoice immediately
* by redirecting to the Visa QIWI Wallet checkout page.»
* «Провайдер может предложить пользователю немедленно оплатить счет
* с помощью переадресации на страницу оплаты».
* «[QIWI Wallet] The REST API specification (v.2.12)»: https://mage2.pro/t/3745
* https://github.com/QIWI-API/pull-payments-docs/blob/40d48cf0/_checkout_en.html.md#checkout-checkout_en
* https://github.com/QIWI-API/pull-payments-docs/blob/40d48cf0/_checkout_ru.html.md#Форма-оплаты-checkout_ru
* https://developer.qiwi.com/ru/pull-payments/index.html#checkout_ru
* @used-by \Dfe\Qiwi\Init\Action::redirectParams()
* @return array(string, array(string => mixed))
*/
function pRedirect() {$s = $this->s(); return [
/**
* 2017-09-04
* «The URL to which the payer will be redirected
* when creation of Visa QIWI Wallet transaction is unsuccessful.
* URL must be within merchant's site.»
* «URL для переадресации в случае неуспеха при создании транзакции в Visa QIWI Wallet.
* Ссылка должна вести на сайт провайдера.
* Если пользователь выбрал на платежной форме способ оплаты,
* отличный от оплаты с баланса Visa QIWI Wallet,
* то переадресация на сайт провайдера не выполняется.»
* Optional, string.
* 2017-09-12
* *) In English:
* «If creation of transaction is unsuccessful,
* Visa QIWI Wallet redirects user to http://mystore.com/fail?a=1&b=2&order=123123123.»
* «4.3. Redirection for Invoice Payment», page 11.
* *) In Russian:
* «В случае неуспеха при создании транзакции
* сайт Visa QIWI Wallet выполняет возврат клиента на страницу со следующим URL:
* http://mystore.com/fail?a=1&b=2&order=1234567»
* «4.3. Переадресация для оплаты счета», страница 11.
* `[QIWI Wallet] The REST API specification (v.2.12)`, https://mage2.pro/t/3745
*/
'failUrl' => $this->customerReturnRemoteWithFailure()
# 2017-09-04
# «This parameter (if true) means that invoice page would be opened in "iframe".
# The checkout page appears more compact
# and can be embedded conveniently within the merchant’s site.
# Default value is false.»
# «Признак отображения страницы в iframe
# (более компактный вид, удобный для встраивания ее в сайт провайдера).
# По умолчанию false»
# Optional, true/false.
,'iframe' => false
# 2017-09-04
# «Accepts mobile, qw, card, wm, ssk.
# Default payment method to show first for the client.
# Allowed values:
# card – a credit/debit card;
# mobile – client’s cell phone account;
# qw – Visa QIWI Wallet account;
# ssk – payment by cash in a QIWI Terminal;
# wm – linked WebMoney wallet.
# When specified method is inaccessible for the Customer,
# the page contains notice about it and the client can choose another method.»
# «Способ оплаты по умолчанию,
# который необходимо отобразить пользователю при открытии платежной формы.
# Возможные значения:
# card – оплата банковской картой;
# mobile – оплата с баланса мобильного телефона;
# qw – оплата с баланса Visa QIWI Wallet;
# ssk – оплата наличными в терминале QIWI;
# wm – оплата с привязанного кошелька WebMoney.
# Если способ оплаты не доступен, пользователю отображается предупреждение,
# при этом на странице можно выбрать другие способы оплаты.»
# Optional, string.
,'pay_source' => ''
# 2017-09-04
# «Merchant’s ID in Visa QIWI Wallet system,
# corresponds to {prv_id} parameter used to create the bill.»
# «Идентификатор провайдера.
# Соответствует параметру {prv_id} из запроса на выставление счета.»
# Required, string.
,'shop' => $s->merchantID()
/**
* 2017-09-04
* «The URL to which the payer will be redirected
* in case of successful creation of Visa QIWI Wallet transaction.
* URL must be within merchant's site»
* «URL для переадресации в случае успешного создания транзакции в Visa QIWI Wallet.
* Ссылка должна вести на сайт провайдера.
* Если пользователь выбрал на платежной форме способ оплаты,
* отличный от оплаты с баланса Visa QIWI Wallet,
* то переадресация на сайт провайдера не выполняется.»
* Optional, string.
* 2017-09-12
* *) In English:
* «If transaction is successfully created,
* Visa QIWI Wallet redirects user to http://mystore.com/success?a=1&b=2&order=123123123.»
* «4.3. Redirection for Invoice Payment», page 11.
* *) In Russian:
* «После и успешного создания транзакции
* сайт Visa QIWI Wallet выполняет возврат клиента на сайт провайдера:
* http://mystore.com/success?a=1&b=2&order=1234567»
* «4.3. Переадресация для оплаты счета», страница 11.
* `[QIWI Wallet] The REST API specification (v.2.12)`, https://mage2.pro/t/3745
*/
,'successUrl' => $this->customerReturnRemote()
# 2017-09-04
# «"iframe" or empty.
# This parameter means that hyperlink specified in successUrl / failUrl parameter
# opens in "iframe" page.»
# «Флаг, показывающий, что ссылки в параметрах successUrl / failUrl открываются в iframe.
# Если отсутствует, то считается выключенным.»
# Optional, string.
,'target' => ''
# 2017-09-04
# «Invoice ID generated by the merchant,
# corresponds to `bill_id` parameter used to create the bill.»
# «Идентификатор счета в информационной системе провайдера.
# Соответствует параметру `bill_id` из запроса на выставление счета.».
# Required, string.
,'transaction' => $this->id()
];}
/**
* 2017-09-05
* 1) The GitHub-based documentation:
* «Date and time up to which the invoice is available for payment.
* If the invoice is not paid by this date it will become void and will be assigned a final status.
* Important! Invoice will be automatically expired when 45 days is passed after the invoicing date.»
* «Дата, до которой счет будет доступен для оплаты.
* Если счет не будет оплачен до этой даты, ему присваивается финальный статус
* и последующая оплата станет невозможна.
* Внимание! По истечении 28 суток от даты выставления
* счет автоматически будет переведен в финальный статус.»
* As you can see, the English and Russian versions of the same documentation
* contain a contradictory information.
* [QIWI Wallet] What is the maximum unpaid invoice lifetime? https://mage2.pro/t/4453
* 2) The PDF documentation:
* «Date/time, up to the seconds, in ISO 8601 format (YYYY-MM-DD'T' hh:mm:ss).
* Important! Time is specified in Moscow time zone.»
* «Дата/время с точностью до секунд в формате ISO 8601 (ГГГГ-ММ-ДД'T'чч:мм:сс).
* Внимание! Указывается московское время.»
* Required, dateTime. Regex: ^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}: \d{2}$
* @return string
*/
private function lifetime() {
$d = ZD::now(); /** @var ZD $d */
/**
* 2017-09-05
* Эта операция конвертирует время из пояса @see date_default_timezone_get() в пояс аргумента.
* Пример:
* $dateS = «2016/07/28 11:35:03»,
* date_default_timezone_get() = «Asia/Taipei»
* пояс аргумента = «Europe/Moscow»
* $result->toString() = 'Jul 28, 2016 6:35:03 AM'
*/
$d->setTimezone('Europe/Moscow');
$d->addDay($this->s()->waitPeriod());
/**
* 2017-09-05
* I do not use @see ZD::ISO_8601 here,
* because in thic case the result will be formatted with the timezone at the end,
* e.g.: «2017-10-20T19:18:31+03:00»,
* but QIWI Wallet requires a value without a timezone suffix.
*/
return $d->toString('y-MM-ddTHH:mm:ss');
}
}