'Y', 'NY' => 'A', 'YN' => 'Z', 'NN' => 'N' ]; /** * Gets payment AVS verification code. * * @param OrderPaymentInterface $orderPayment * @return string * @throws \InvalidArgumentException If specified order payment has different payment method code. */ public function getCode(OrderPaymentInterface $orderPayment) { if ($orderPayment->getMethod() !== Config::METHOD_PAYFLOWPRO) { throw new \InvalidArgumentException( 'The "' . $orderPayment->getMethod() . '" does not supported by Payflow AVS mapper.' ); } $additionalInfo = $orderPayment->getAdditionalInformation(); if (empty($additionalInfo[Info::PAYPAL_AVSADDR]) || empty($additionalInfo[Info::PAYPAL_AVSZIP]) ) { return self::$unavailableCode; } $streetCode = $additionalInfo[Info::PAYPAL_AVSADDR]; $zipCode = $additionalInfo[Info::PAYPAL_AVSZIP]; $key = $zipCode . $streetCode; return isset(self::$avsMap[$key]) ? self::$avsMap[$key] : self::$unavailableCode; } }