-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathBinLookupApi.php
224 lines (200 loc) · 9.82 KB
/
BinLookupApi.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
<?php
/**
* BinLookupApi
* PHP version 5
*
* @category Class
* @package CyberSource
* @author Swagger Codegen team
* @link https://github.com/swagger-api/swagger-codegen
*/
/**
* CyberSource Merged Spec
*
* All CyberSource API specs merged together. These are available at https://developer.cybersource.com/api/reference/api-reference.html
*
* OpenAPI spec version: 0.0.1
*
* Generated by: https://github.com/swagger-api/swagger-codegen.git
*
*/
/**
* NOTE: This class is auto generated by the swagger code generator program.
* https://github.com/swagger-api/swagger-codegen
* Do not edit the class manually.
*/
namespace CyberSource\Api;
use \CyberSource\ApiClient;
use \CyberSource\ApiException;
use \CyberSource\Configuration;
use \CyberSource\ObjectSerializer;
use \CyberSource\Logging\LogFactory as LogFactory;
use \CyberSource\Authentication\Util\MLEUtility;
use \Exception;
/**
* BinLookupApi Class Doc Comment
*
* @category Class
* @package CyberSource
* @author Swagger Codegen team
* @link https://github.com/swagger-api/swagger-codegen
*/
class BinLookupApi
{
private static $logger = null;
/**
* API Client
*
* @var \CyberSource\ApiClient instance of the ApiClient
*/
protected $apiClient;
/**
* Constructor
*
* @param \CyberSource\ApiClient|null $apiClient The api client to use
*/
public function __construct(\CyberSource\ApiClient $apiClient = null)
{
if ($apiClient === null) {
$apiClient = new ApiClient();
}
$this->apiClient = $apiClient;
if (self::$logger === null) {
self::$logger = (new LogFactory())->getLogger(\CyberSource\Utilities\Helpers\ClassHelper::getClassName(get_class($this)), $apiClient->merchantConfig->getLogConfiguration());
}
}
/**
* Get API client
*
* @return \CyberSource\ApiClient get the API client
*/
public function getApiClient()
{
return $this->apiClient;
}
/**
* Set the API client
*
* @param \CyberSource\ApiClient $apiClient set the API client
*
* @return BinLookupApi
*/
public function setApiClient(\CyberSource\ApiClient $apiClient)
{
$this->apiClient = $apiClient;
return $this;
}
/**
* Operation getAccountInfo
*
* BIN Lookup API
*
* DISCLAIMER : Cybersource may allow Customer to access, use, and/or test a Cybersource product or service that may still be in development or has not been market-tested ("Beta Product") solely for the purpose of evaluating the functionality or marketability of the Beta Product (a "Beta Evaluation"). Notwithstanding any language to the contrary, the following terms shall apply with respect to Customer's participation in any Beta Evaluation (and the Beta Product(s)) accessed thereunder): The Parties will enter into a separate form agreement detailing the scope of the Beta Evaluation, requirements, pricing, the length of the beta evaluation period ("Beta Product Form"). Beta Products are not, and may not become, Transaction Services and have not yet been publicly released and are offered for the sole purpose of internal testing and non-commercial evaluation. Customer's use of the Beta Product shall be solely for the purpose of conducting the Beta Evaluation. Customer accepts all risks arising out of the access and use of the Beta Products. Cybersource may, in its sole discretion, at any time, terminate or discontinue the Beta Evaluation. Customer acknowledges and agrees that any Beta Product may still be in development and that Beta Product is provided "AS IS" and may not perform at the level of a commercially available service, may not operate as expected and may be modified prior to release. CYBERSOURCE SHALL NOT BE RESPONSIBLE OR LIABLE UNDER ANY CONTRACT, TORT (INCLUDING NEGLIGENCE), OR OTHERWISE RELATING TO A BETA PRODUCT OR THE BETA EVALUATION (A) FOR LOSS OR INACCURACY OF DATA OR COST OF PROCUREMENT OF SUBSTITUTE GOODS, SERVICES OR TECHNOLOGY, (B) ANY CLAIM, LOSSES, DAMAGES, OR CAUSE OF ACTION ARISING IN CONNECTION WITH THE BETA PRODUCT; OR (C) FOR ANY INDIRECT, INCIDENTAL OR CONSEQUENTIAL DAMAGES INCLUDING, BUT NOT LIMITED TO, LOSS OF REVENUES AND LOSS OF PROFITS.
*
* @param \CyberSource\Model\CreateBinLookupRequest $createBinLookupRequest (required)
* @throws \CyberSource\ApiException on non-2xx response
* @return array of \CyberSource\Model\InlineResponse2011, HTTP status code, HTTP response headers (array of strings)
*/
public function getAccountInfo($createBinLookupRequest)
{
self::$logger->info('CALL TO METHOD getAccountInfo STARTED');
list($response, $statusCode, $httpHeader) = $this->getAccountInfoWithHttpInfo($createBinLookupRequest);
self::$logger->info('CALL TO METHOD getAccountInfo ENDED');
self::$logger->close();
return [$response, $statusCode, $httpHeader];
}
/**
* Operation getAccountInfoWithHttpInfo
*
* BIN Lookup API
*
* @param \CyberSource\Model\CreateBinLookupRequest $createBinLookupRequest (required)
* @throws \CyberSource\ApiException on non-2xx response
* @return array of \CyberSource\Model\InlineResponse2011, HTTP status code, HTTP response headers (array of strings)
*/
public function getAccountInfoWithHttpInfo($createBinLookupRequest)
{
// verify the required parameter 'createBinLookupRequest' is set
if ($createBinLookupRequest === null) {
self::$logger->error("InvalidArgumentException : Missing the required parameter $createBinLookupRequest when calling getAccountInfo");
throw new \InvalidArgumentException('Missing the required parameter $createBinLookupRequest when calling getAccountInfo');
}
// parse inputs
$resourcePath = "/bin/v1/binlookup";
$httpBody = '';
$queryParams = [];
$headerParams = [];
$formParams = [];
$_header_accept = $this->apiClient->selectHeaderAccept(['application/json;charset=utf-8']);
if (!is_null($_header_accept)) {
$headerParams['Accept'] = $_header_accept;
}
$headerParams['Content-Type'] = $this->apiClient->selectHeaderContentType(['application/json;charset=utf-8']);
// body params
$_tempBody = null;
if (isset($createBinLookupRequest)) {
$_tempBody = $createBinLookupRequest;
}
$sdkTracker = new \CyberSource\Utilities\Tracking\SdkTracker();
$modelClassLocation = explode('\\', '\CyberSource\Model\CreateBinLookupRequest');
$_tempBody = $sdkTracker->insertDeveloperIdTracker($_tempBody, end($modelClassLocation), $this->apiClient->merchantConfig->getRunEnvironment(), $this->apiClient->merchantConfig->getDefaultDeveloperId());
// for model (json/xml)
if (isset($_tempBody)) {
$httpBody = $_tempBody; // $_tempBody is the method argument, if present
} elseif (count($formParams) > 0) {
$httpBody = $formParams; // for HTTP post (form)
}
//MLE check and mle encryption for req body
$isMLESupportedByCybsForApi = false;
if (MLEUtility::checkIsMLEForAPI($this->apiClient->merchantConfig, $isMLESupportedByCybsForApi, "getAccountInfo,getAccountInfoWithHttpInfo")) {
try {
$httpBody = MLEUtility::encryptRequestPayload($this->apiClient->merchantConfig, $httpBody);
} catch (Exception $e) {
self::$logger->error("Failed to encrypt request body: $e");
throw new ApiException("Failed to encrypt request body : " . $e->getMessage());
}
}
// Logging
self::$logger->debug("Resource : POST $resourcePath");
if (isset($httpBody)) {
if ($this->apiClient->merchantConfig->getLogConfiguration()->isMaskingEnabled()) {
$printHttpBody = \CyberSource\Utilities\Helpers\DataMasker::maskData($httpBody);
} else {
$printHttpBody = $httpBody;
}
self::$logger->debug("Body Parameter :\n" . $printHttpBody);
}
self::$logger->debug("Return Type : \CyberSource\Model\InlineResponse2011");
// make the API Call
try {
list($response, $statusCode, $httpHeader) = $this->apiClient->callApi(
$resourcePath,
'POST',
$queryParams,
$httpBody,
$headerParams,
'\CyberSource\Model\InlineResponse2011',
'/bin/v1/binlookup'
);
self::$logger->debug("Response Headers :\n" . \CyberSource\Utilities\Helpers\ListHelper::toString($httpHeader));
return [$this->apiClient->getSerializer()->deserialize($response, '\CyberSource\Model\InlineResponse2011', $httpHeader), $statusCode, $httpHeader];
} catch (ApiException $e) {
switch ($e->getCode()) {
case 201:
$data = $this->apiClient->getSerializer()->deserialize($e->getResponseBody(), '\CyberSource\Model\InlineResponse2011', $e->getResponseHeaders());
$e->setResponseObject($data);
break;
case 400:
$data = $this->apiClient->getSerializer()->deserialize($e->getResponseBody(), '\CyberSource\Model\PtsV2CreateOrderPost400Response', $e->getResponseHeaders());
$e->setResponseObject($data);
break;
case 502:
$data = $this->apiClient->getSerializer()->deserialize($e->getResponseBody(), '\CyberSource\Model\PtsV2PaymentsPost502Response', $e->getResponseHeaders());
$e->setResponseObject($data);
break;
}
self::$logger->error("ApiException : $e");
throw $e;
}
}
}