 wp-pay-gateways    /
                    buckaroo
                      wp-pay-gateways    /
                    buckaroo
                
                            | 1 | <?php | ||||
| 2 | |||||
| 3 | namespace Pronamic\WordPress\Pay\Gateways\Buckaroo; | ||||
| 4 | |||||
| 5 | use WP_Error; | ||||
| 6 | |||||
| 7 | /** | ||||
| 8 | * Title: Buckaroo client | ||||
| 9 | * Description: | ||||
| 10 | * Copyright: 2005-2019 Pronamic | ||||
| 11 | * Company: Pronamic | ||||
| 12 | * | ||||
| 13 | * @author Remco Tolsma | ||||
| 14 | * @version 2.0.0 | ||||
| 15 | * @since 1.0.0 | ||||
| 16 | */ | ||||
| 17 | class Client { | ||||
| 18 | /** | ||||
| 19 | * Gateway URL | ||||
| 20 | * | ||||
| 21 | * @var string | ||||
| 22 | */ | ||||
| 23 | const GATEWAY_URL = 'https://checkout.buckaroo.nl/html/'; | ||||
| 24 | |||||
| 25 | /** | ||||
| 26 | * Gateway test URL | ||||
| 27 | * | ||||
| 28 | * @var string | ||||
| 29 | */ | ||||
| 30 | const GATEWAY_TEST_URL = 'https://testcheckout.buckaroo.nl/html/'; | ||||
| 31 | |||||
| 32 | /** | ||||
| 33 | * Gateway Name-Value-Pair URL | ||||
| 34 | * | ||||
| 35 | * @var string | ||||
| 36 | */ | ||||
| 37 | const GATEWAY_NVP_URL = 'https://checkout.buckaroo.nl/nvp/'; | ||||
| 38 | |||||
| 39 | /** | ||||
| 40 | * Gateway Name-Value-Pair test URL | ||||
| 41 | * | ||||
| 42 | * @var string | ||||
| 43 | */ | ||||
| 44 | const GATEWAY_NVP_TEST_URL = 'https://testcheckout.buckaroo.nl/nvp/'; | ||||
| 45 | |||||
| 46 | /** | ||||
| 47 | * Indicator for the iDEAL payment method | ||||
| 48 | * | ||||
| 49 | * @var string | ||||
| 50 | */ | ||||
| 51 | const PAYMENT_METHOD_IDEAL = 'ideal'; | ||||
| 52 | |||||
| 53 | /** | ||||
| 54 | * The payment server URL | ||||
| 55 | * | ||||
| 56 | * @var string | ||||
| 57 | */ | ||||
| 58 | private $payment_server_url; | ||||
| 59 | |||||
| 60 | /** | ||||
| 61 | * The amount | ||||
| 62 | * | ||||
| 63 | * @var int | ||||
| 64 | */ | ||||
| 65 | private $amount; | ||||
| 66 | |||||
| 67 | /** | ||||
| 68 | * The website key | ||||
| 69 | * | ||||
| 70 | * @var string | ||||
| 71 | */ | ||||
| 72 | private $website_key; | ||||
| 73 | |||||
| 74 | /** | ||||
| 75 | * The secret key | ||||
| 76 | * | ||||
| 77 | * @var string | ||||
| 78 | */ | ||||
| 79 | private $secret_key; | ||||
| 80 | |||||
| 81 | /** | ||||
| 82 | * The payment method | ||||
| 83 | * | ||||
| 84 | * @var string | ||||
| 85 | */ | ||||
| 86 | private $payment_method; | ||||
| 87 | |||||
| 88 | /** | ||||
| 89 | * The iDEAL issuer | ||||
| 90 | * | ||||
| 91 | * @since 1.2.4 | ||||
| 92 | * @var string | ||||
| 93 | */ | ||||
| 94 | private $ideal_issuer; | ||||
| 95 | |||||
| 96 | /** | ||||
| 97 | * The country code (culture) | ||||
| 98 | * | ||||
| 99 | * @var string | ||||
| 100 | */ | ||||
| 101 | private $culture; | ||||
| 102 | |||||
| 103 | /** | ||||
| 104 | * The currency | ||||
| 105 | * | ||||
| 106 | * @var string | ||||
| 107 | */ | ||||
| 108 | private $currency; | ||||
| 109 | |||||
| 110 | /** | ||||
| 111 | * The invoice number | ||||
| 112 | * | ||||
| 113 | * @var string | ||||
| 114 | */ | ||||
| 115 | private $invoice_number; | ||||
| 116 | |||||
| 117 | /** | ||||
| 118 | * The description | ||||
| 119 | * | ||||
| 120 | * @var string | ||||
| 121 | */ | ||||
| 122 | private $description; | ||||
| 123 | |||||
| 124 | /** | ||||
| 125 | * The return url | ||||
| 126 | * | ||||
| 127 | * @var string | ||||
| 128 | */ | ||||
| 129 | private $return_url; | ||||
| 130 | |||||
| 131 | /** | ||||
| 132 | * The return reject url | ||||
| 133 | * | ||||
| 134 | * @var string | ||||
| 135 | */ | ||||
| 136 | private $return_reject_url; | ||||
| 137 | |||||
| 138 | /** | ||||
| 139 | * The return error url | ||||
| 140 | * | ||||
| 141 | * @var string | ||||
| 142 | */ | ||||
| 143 | private $return_error_url; | ||||
| 144 | |||||
| 145 | /** | ||||
| 146 | * The return cancel url | ||||
| 147 | * | ||||
| 148 | * @var string | ||||
| 149 | */ | ||||
| 150 | private $return_cancel_url; | ||||
| 151 | |||||
| 152 | /** | ||||
| 153 | * Push URL | ||||
| 154 | * | ||||
| 155 | * @var string | ||||
| 156 | */ | ||||
| 157 | private $push_url; | ||||
| 158 | |||||
| 159 | /** | ||||
| 160 | * Requested services | ||||
| 161 | * | ||||
| 162 | * @var array | ||||
| 163 | */ | ||||
| 164 | private $requested_services; | ||||
| 165 | |||||
| 166 | /** | ||||
| 167 | * Excluded services | ||||
| 168 | * | ||||
| 169 | * @var array | ||||
| 170 | */ | ||||
| 171 | private $excluded_services; | ||||
| 172 | |||||
| 173 | /** | ||||
| 174 | * Pronamic payment ID | ||||
| 175 | * | ||||
| 176 | * @var array | ||||
| 177 | */ | ||||
| 178 | private $payment_id; | ||||
| 179 | |||||
| 180 | /** | ||||
| 181 | * Error. | ||||
| 182 | * | ||||
| 183 | * @since 1.2.6 | ||||
| 184 | * @var WP_Error | ||||
| 185 | */ | ||||
| 186 | private $error; | ||||
| 187 | |||||
| 188 | /** | ||||
| 189 | * Constructs and initialize a iDEAL kassa object | ||||
| 190 | */ | ||||
| 191 | 1 | 	public function __construct() { | |||
| 192 | 1 | $this->set_payment_server_url( self::GATEWAY_URL ); | |||
| 193 | |||||
| 194 | 1 | $this->requested_services = array(); | |||
| 195 | 1 | } | |||
| 196 | |||||
| 197 | /** | ||||
| 198 | * Get error. | ||||
| 199 | * | ||||
| 200 | * @since 1.2.6 | ||||
| 201 | * @return WP_Error | ||||
| 202 | */ | ||||
| 203 | 	public function get_error() { | ||||
| 204 | return $this->error; | ||||
| 205 | } | ||||
| 206 | |||||
| 207 | /** | ||||
| 208 | * Get the payment server URL | ||||
| 209 | * | ||||
| 210 | * @return string the payment server URL | ||||
| 211 | */ | ||||
| 212 | 	public function get_payment_server_url() { | ||||
| 213 | return $this->payment_server_url; | ||||
| 214 | } | ||||
| 215 | |||||
| 216 | /** | ||||
| 217 | * Set the payment server URL | ||||
| 218 | * | ||||
| 219 | * @param string $url an URL | ||||
| 220 | */ | ||||
| 221 | 1 | 	public function set_payment_server_url( $url ) { | |||
| 222 | 1 | $this->payment_server_url = $url; | |||
| 223 | 1 | } | |||
| 224 | |||||
| 225 | 1 | 	public function get_website_key() { | |||
| 226 | 1 | return $this->website_key; | |||
| 227 | } | ||||
| 228 | |||||
| 229 | 1 | 	public function set_website_key( $website_key ) { | |||
| 230 | 1 | $this->website_key = $website_key; | |||
| 231 | 1 | } | |||
| 232 | |||||
| 233 | 1 | 	public function get_secret_key() { | |||
| 234 | 1 | return $this->secret_key; | |||
| 235 | } | ||||
| 236 | |||||
| 237 | 1 | 	public function set_secret_key( $secret_key ) { | |||
| 238 | 1 | $this->secret_key = $secret_key; | |||
| 239 | 1 | } | |||
| 240 | |||||
| 241 | 	public function get_payment_method() { | ||||
| 242 | return $this->payment_method; | ||||
| 243 | } | ||||
| 244 | |||||
| 245 | 	public function set_payment_method( $payment_method ) { | ||||
| 246 | $this->payment_method = $payment_method; | ||||
| 247 | } | ||||
| 248 | |||||
| 249 | /** | ||||
| 250 | * Get iDEAL issuer. | ||||
| 251 | * | ||||
| 252 | * @since 1.2.4 | ||||
| 253 | * @return string | ||||
| 254 | */ | ||||
| 255 | 	public function get_ideal_issuer() { | ||||
| 256 | return $this->ideal_issuer; | ||||
| 257 | } | ||||
| 258 | |||||
| 259 | /** | ||||
| 260 | * Set iDEAL issuer. | ||||
| 261 | * | ||||
| 262 | * @since 1.2.4 | ||||
| 263 | * | ||||
| 264 | * @param string $issuer | ||||
| 265 | */ | ||||
| 266 | 	public function set_ideal_issuer( $issuer ) { | ||||
| 267 | $this->ideal_issuer = $issuer; | ||||
| 268 | } | ||||
| 269 | |||||
| 270 | 	public function get_requested_services() { | ||||
| 271 | return $this->requested_services; | ||||
| 272 | } | ||||
| 273 | |||||
| 274 | 	public function add_requested_service( $service ) { | ||||
| 275 | $this->requested_services[] = $service; | ||||
| 276 | } | ||||
| 277 | |||||
| 278 | 	public function get_excluded_services() { | ||||
| 279 | return $this->excluded_services; | ||||
| 280 | } | ||||
| 281 | |||||
| 282 | 	public function set_excluded_services( $service ) { | ||||
| 283 | $this->excluded_services = $service; | ||||
| 284 | } | ||||
| 285 | |||||
| 286 | 	public function get_culture() { | ||||
| 287 | return $this->culture; | ||||
| 288 | } | ||||
| 289 | |||||
| 290 | 	public function set_culture( $culture ) { | ||||
| 291 | $this->culture = $culture; | ||||
| 292 | } | ||||
| 293 | |||||
| 294 | 	public function get_currency() { | ||||
| 295 | return $this->currency; | ||||
| 296 | } | ||||
| 297 | |||||
| 298 | 	public function set_currency( $currency ) { | ||||
| 299 | $this->currency = $currency; | ||||
| 300 | } | ||||
| 301 | |||||
| 302 | 	public function get_invoice_number() { | ||||
| 303 | return $this->invoice_number; | ||||
| 304 | } | ||||
| 305 | |||||
| 306 | 	public function set_invoice_number( $invoice_number ) { | ||||
| 307 | $this->invoice_number = $invoice_number; | ||||
| 308 | } | ||||
| 309 | |||||
| 310 | 	public function get_description() { | ||||
| 311 | return $this->description; | ||||
| 312 | } | ||||
| 313 | |||||
| 314 | 	public function set_description( $description ) { | ||||
| 315 | $this->description = $description; | ||||
| 316 | } | ||||
| 317 | |||||
| 318 | /** | ||||
| 319 | * Get amount. | ||||
| 320 | * | ||||
| 321 | * @return int | ||||
| 322 | */ | ||||
| 323 | 	public function get_amount() { | ||||
| 324 | return $this->amount; | ||||
| 325 | } | ||||
| 326 | |||||
| 327 | /** | ||||
| 328 | * Set amount. | ||||
| 329 | * | ||||
| 330 | * @param int $amount Amount. | ||||
| 331 | */ | ||||
| 332 | 	public function set_amount( $amount ) { | ||||
| 333 | $this->amount = $amount; | ||||
| 334 | } | ||||
| 335 | |||||
| 336 | /** | ||||
| 337 | * Get return URL | ||||
| 338 | * | ||||
| 339 | * @return string | ||||
| 340 | */ | ||||
| 341 | 	public function get_return_url() { | ||||
| 342 | return $this->return_url; | ||||
| 343 | } | ||||
| 344 | |||||
| 345 | /** | ||||
| 346 | * Set return URL | ||||
| 347 | * | ||||
| 348 | * @param string $url Return URL. | ||||
| 349 | */ | ||||
| 350 | 	public function set_return_url( $url ) { | ||||
| 351 | $this->return_url = $url; | ||||
| 352 | } | ||||
| 353 | |||||
| 354 | /** | ||||
| 355 | * Get return reject URL | ||||
| 356 | * | ||||
| 357 | * @return string | ||||
| 358 | */ | ||||
| 359 | 	public function get_return_reject_url() { | ||||
| 360 | return $this->return_reject_url; | ||||
| 361 | } | ||||
| 362 | |||||
| 363 | /** | ||||
| 364 | * Set return reject URL | ||||
| 365 | * | ||||
| 366 | * @param string $url Return reject URL. | ||||
| 367 | */ | ||||
| 368 | 	public function set_return_reject_url( $url ) { | ||||
| 369 | $this->return_reject_url = $url; | ||||
| 370 | } | ||||
| 371 | |||||
| 372 | /** | ||||
| 373 | * Get return error URL | ||||
| 374 | * | ||||
| 375 | * @return string | ||||
| 376 | */ | ||||
| 377 | 	public function get_return_error_url() { | ||||
| 378 | return $this->return_error_url; | ||||
| 379 | } | ||||
| 380 | |||||
| 381 | /** | ||||
| 382 | * Set return error URL | ||||
| 383 | * | ||||
| 384 | * @param string $url Return error URL. | ||||
| 385 | */ | ||||
| 386 | 	public function set_return_error_url( $url ) { | ||||
| 387 | $this->return_error_url = $url; | ||||
| 388 | } | ||||
| 389 | |||||
| 390 | /** | ||||
| 391 | * Get return cancel URL | ||||
| 392 | * | ||||
| 393 | * @return string | ||||
| 394 | */ | ||||
| 395 | 	public function get_return_cancel_url() { | ||||
| 396 | return $this->return_cancel_url; | ||||
| 397 | } | ||||
| 398 | |||||
| 399 | /** | ||||
| 400 | * Set return cancel URL | ||||
| 401 | * | ||||
| 402 | * @param string $url Return cancel URL. | ||||
| 403 | */ | ||||
| 404 | 	public function set_return_cancel_url( $url ) { | ||||
| 405 | $this->return_cancel_url = $url; | ||||
| 406 | } | ||||
| 407 | |||||
| 408 | /** | ||||
| 409 | * Get push URL | ||||
| 410 | * | ||||
| 411 | * @return string | ||||
| 412 | */ | ||||
| 413 | 	public function get_push_url() { | ||||
| 414 | return $this->push_url; | ||||
| 415 | } | ||||
| 416 | |||||
| 417 | /** | ||||
| 418 | * Set push URL | ||||
| 419 | * | ||||
| 420 | * @param string $url Push URL. | ||||
| 421 | */ | ||||
| 422 | 	public function set_push_url( $url ) { | ||||
| 423 | $this->push_url = $url; | ||||
| 424 | } | ||||
| 425 | |||||
| 426 | /** | ||||
| 427 | * Get Pronamic payment ID | ||||
| 428 | * | ||||
| 429 | * @return string | ||||
| 430 | */ | ||||
| 431 | 	public function get_payment_id() { | ||||
| 432 | return $this->payment_id; | ||||
| 0 ignored issues–
                            show             Bug
            Best Practice
    
    
    
        introduced 
                            by  
  Loading history... | |||||
| 433 | } | ||||
| 434 | |||||
| 435 | /** | ||||
| 436 | * Set Pronamic payment ID | ||||
| 437 | * | ||||
| 438 | * @param string $payment_id Payment ID. | ||||
| 439 | */ | ||||
| 440 | 	public function set_payment_id( $payment_id ) { | ||||
| 441 | $this->payment_id = $payment_id; | ||||
| 0 ignored issues–
                            show It seems like  $payment_idof typestringis incompatible with the declared typearrayof property$payment_id.Our type inference engine has found an assignment to a property that is incompatible with the declared type of that property. Either this assignment is in error or the assigned type should be added to the documentation/type hint for that property..  Loading history... | |||||
| 442 | } | ||||
| 443 | |||||
| 444 | /** | ||||
| 445 | * Get issuers | ||||
| 446 | * | ||||
| 447 | * @since 1.2.4 | ||||
| 448 | * @link http://support.buckaroo.nl/index.php/Service_iDEAL#iDEAL_banken_lijst_opvragen | ||||
| 449 | * @return array | ||||
| 450 | */ | ||||
| 451 | 1 | 	public function get_issuers() { | |||
| 452 | 1 | $issuers = array(); | |||
| 453 | |||||
| 454 | 1 | $url = add_query_arg( 'op', 'TransactionRequestSpecification', self::GATEWAY_NVP_TEST_URL ); | |||
| 455 | |||||
| 456 | $data = array( | ||||
| 457 | 1 | 'brq_websitekey' => $this->get_website_key(), | |||
| 458 | 1 | 'brq_services' => 'ideal', | |||
| 459 | 1 | 'brq_latestversiononly' => 'True', | |||
| 460 | ); | ||||
| 461 | |||||
| 462 | 1 | $signature = Security::create_signature( $data, $this->get_secret_key() ); | |||
| 463 | |||||
| 464 | 1 | $data[ Parameters::SIGNATURE ] = $signature; | |||
| 465 | |||||
| 466 | 1 | $result = wp_remote_post( | |||
| 467 | 1 | $url, | |||
| 468 | array( | ||||
| 469 | 1 | 'body' => http_build_query( $data ), | |||
| 470 | ) | ||||
| 471 | ); | ||||
| 472 | |||||
| 473 | 1 | $body = wp_remote_retrieve_body( $result ); | |||
| 0 ignored issues–
                            show It seems like  $resultcan also be of typeWP_Error; however, parameter$responseofwp_remote_retrieve_body()does only seem to acceptarray, maybe add an additional type check?
                                                                                                                                                                                           (
                                     Ignorable by Annotation
                                ) If this is a false-positive, you can also ignore this issue in your code via the  
  Loading history... | |||||
| 474 | |||||
| 475 | 1 | wp_parse_str( $body, $data ); | |||
| 476 | |||||
| 477 | 1 | $data = Util::transform_flat_response( $data ); | |||
| 478 | |||||
| 479 | 1 | $error_msg = __( 'Unable to retrieve issuers from Buckaroo.', 'pronamic_ideal' ); | |||
| 480 | |||||
| 481 | 1 | 		if ( 200 !== wp_remote_retrieve_response_code( $result ) ) { | |||
| 0 ignored issues–
                            show It seems like  $resultcan also be of typeWP_Error; however, parameter$responseofwp_remote_retrieve_response_code()does only seem to acceptarray, maybe add an additional type check?
                                                                                                                                                                                           (
                                     Ignorable by Annotation
                                ) If this is a false-positive, you can also ignore this issue in your code via the  
  Loading history... | |||||
| 482 | $this->error = new WP_Error( 'buckaroo_error', $error_msg, $data ); | ||||
| 483 | |||||
| 484 | return $issuers; | ||||
| 485 | } | ||||
| 486 | |||||
| 487 | 1 | 		if ( isset( $data['BRQ_APIRESULT'] ) && 'Fail' === $data['BRQ_APIRESULT'] ) { | |||
| 488 | 1 | 			if ( isset( $data['BRQ_APIERRORMESSAGE'] ) ) { | |||
| 489 | 1 | $error_msg = sprintf( '%s %s', $error_msg, $data['BRQ_APIERRORMESSAGE'] ); | |||
| 490 | } | ||||
| 491 | |||||
| 492 | 1 | $this->error = new WP_Error( 'buckaroo_error', $error_msg, $data ); | |||
| 493 | |||||
| 494 | 1 | return $issuers; | |||
| 495 | } | ||||
| 496 | |||||
| 497 | 		if ( ! isset( $data['BRQ_SERVICES'] ) ) { | ||||
| 498 | return $issuers; | ||||
| 499 | } | ||||
| 500 | |||||
| 501 | 		foreach ( $data['BRQ_SERVICES'] as $service ) { | ||||
| 502 | 			if ( ! isset( $service['NAME'], $service['VERSION'], $service['ACTIONDESCRIPTION'] ) ) { | ||||
| 503 | return $issuers; | ||||
| 504 | } | ||||
| 505 | |||||
| 506 | 			if ( PaymentMethods::IDEAL !== $service['NAME'] ) { | ||||
| 507 | continue; | ||||
| 508 | } | ||||
| 509 | |||||
| 510 | 			foreach ( $service['ACTIONDESCRIPTION'] as $action ) { | ||||
| 511 | 				if ( ! isset( $action['NAME'], $action['REQUESTPARAMETERS'] ) ) { | ||||
| 512 | return $issuers; | ||||
| 513 | } | ||||
| 514 | |||||
| 515 | 				if ( 'Pay' !== $action['NAME'] ) { | ||||
| 516 | continue; | ||||
| 517 | } | ||||
| 518 | |||||
| 519 | 				foreach ( $action['REQUESTPARAMETERS'] as $parameter ) { | ||||
| 520 | |||||
| 521 | 					if ( ! isset( $parameter['NAME'], $parameter['LISTITEMDESCRIPTION'] ) ) { | ||||
| 522 | return $issuers; | ||||
| 523 | } | ||||
| 524 | |||||
| 525 | 					if ( 'issuer' !== $parameter['NAME'] ) { | ||||
| 526 | continue; | ||||
| 527 | } | ||||
| 528 | |||||
| 529 | 					foreach ( $parameter['LISTITEMDESCRIPTION'] as $issuer ) { | ||||
| 530 | $issuers[ $issuer['VALUE'] ] = $issuer['DESCRIPTION']; | ||||
| 531 | } | ||||
| 532 | |||||
| 533 | break; | ||||
| 534 | } | ||||
| 535 | } | ||||
| 536 | } | ||||
| 537 | |||||
| 538 | return $issuers; | ||||
| 539 | } | ||||
| 540 | |||||
| 541 | /** | ||||
| 542 | * Get HTML fields | ||||
| 543 | * | ||||
| 544 | * @since 1.1.1 | ||||
| 545 | * @return string | ||||
| 546 | */ | ||||
| 547 | 	public function get_fields() { | ||||
| 548 | $data = array( | ||||
| 549 | Parameters::ADD_PRONAMIC_PAYMENT_ID => $this->get_payment_id(), | ||||
| 550 | Parameters::WEBSITE_KEY => $this->get_website_key(), | ||||
| 551 | Parameters::INVOICE_NUMBER => $this->get_invoice_number(), | ||||
| 552 | Parameters::AMOUNT => number_format( $this->get_amount(), 2, '.', '' ), | ||||
| 553 | Parameters::CURRENCY => $this->get_currency(), | ||||
| 554 | Parameters::CULTURE => $this->get_culture(), | ||||
| 555 | Parameters::DESCRIPTION => $this->get_description(), | ||||
| 556 | Parameters::PAYMENT_METHOD => $this->get_payment_method(), | ||||
| 557 | Parameters::RETURN_URL => $this->get_return_url(), | ||||
| 558 | Parameters::RETURN_REJECT_URL => $this->get_return_reject_url(), | ||||
| 559 | Parameters::RETURN_ERROR_URL => $this->get_return_error_url(), | ||||
| 560 | Parameters::RETURN_CANCEL_URL => $this->get_return_cancel_url(), | ||||
| 561 | Parameters::PUSH_URL => $this->get_push_url(), | ||||
| 562 | Parameters::PUSH_FAILURE_URL => $this->get_push_url(), | ||||
| 563 | Parameters::REQUESTED_SERVICES => implode( ',', $this->get_requested_services() ), | ||||
| 564 | Parameters::EXCLUDED_SERVICES => $this->get_excluded_services(), | ||||
| 565 | Parameters::IDEAL_ISSUER => $this->get_ideal_issuer(), | ||||
| 566 | ); | ||||
| 567 | |||||
| 568 | $signature = Security::create_signature( $data, $this->get_secret_key() ); | ||||
| 569 | |||||
| 570 | $data[ Parameters::SIGNATURE ] = $signature; | ||||
| 571 | |||||
| 572 | return $data; | ||||
| 0 ignored issues–
                            show | |||||
| 573 | } | ||||
| 574 | |||||
| 575 | /** | ||||
| 576 | * Verify request Buckaroo | ||||
| 577 | */ | ||||
| 578 | 	public function verify_request( $data ) { | ||||
| 579 | $result = false; | ||||
| 580 | |||||
| 581 | $signature = Security::get_signature( $data ); | ||||
| 0 ignored issues–
                            show Are you sure the assignment to  $signatureis correct asPronamic\WordPress\Pay\G...y::get_signature($data)targetingPronamic\WordPress\Pay\G...curity::get_signature()seems to always return null.This check looks for function or method calls that always return null and whose return value is assigned to a variable. class A
{
    function getObject()
    {
        return null;
    }
}
$a = new A();
$object = $a->getObject();
The method  The reason is most likely that a function or method is imcomplete or has been reduced for debug purposes.  Loading history... | |||||
| 582 | |||||
| 583 | $signature_check = Security::create_signature( $data, $this->get_secret_key() ); | ||||
| 584 | |||||
| 585 | 		if ( 0 === strcasecmp( $signature, $signature_check ) ) { | ||||
| 586 | $data = array_change_key_case( $data, CASE_LOWER ); | ||||
| 587 | |||||
| 588 | $result = filter_var_array( | ||||
| 589 | $data, | ||||
| 590 | array( | ||||
| 591 | Parameters::ADD_PRONAMIC_PAYMENT_ID => FILTER_SANITIZE_STRING, | ||||
| 592 | Parameters::PAYMENT => FILTER_SANITIZE_STRING, | ||||
| 593 | Parameters::PAYMENT_METHOD => FILTER_SANITIZE_STRING, | ||||
| 594 | Parameters::STATUS_CODE => FILTER_VALIDATE_INT, | ||||
| 595 | Parameters::STATUS_CODE_DETAIL => FILTER_SANITIZE_STRING, | ||||
| 596 | Parameters::STATUS_MESSAGE => FILTER_SANITIZE_STRING, | ||||
| 597 | Parameters::INVOICE_NUMBER => FILTER_SANITIZE_STRING, | ||||
| 598 | Parameters::AMOUNT => FILTER_VALIDATE_FLOAT, | ||||
| 599 | Parameters::CURRENCY => FILTER_SANITIZE_STRING, | ||||
| 600 | Parameters::TIMESTAMP => FILTER_SANITIZE_STRING, | ||||
| 601 | Parameters::SERVICE_IDEAL_CONSUMER_ISSUER => FILTER_SANITIZE_STRING, | ||||
| 602 | Parameters::SERVICE_IDEAL_CONSUMER_NAME => FILTER_SANITIZE_STRING, | ||||
| 603 | Parameters::SERVICE_IDEAL_CONSUMER_IBAN => FILTER_SANITIZE_STRING, | ||||
| 604 | Parameters::SERVICE_IDEAL_CONSUMER_BIC => FILTER_SANITIZE_STRING, | ||||
| 605 | Parameters::TRANSACTIONS => FILTER_SANITIZE_STRING, | ||||
| 606 | ) | ||||
| 607 | ); | ||||
| 608 | } | ||||
| 609 | |||||
| 610 | return $result; | ||||
| 611 | } | ||||
| 612 | } | ||||
| 613 | 
