/**
  * Checks whether the given class is supported for denormalization by this normalizer.
  *
  * @param mixed $data Data to denormalize from.
  * @param string $type The class to which the data should be denormalized.
  * @param string $format The format being deserialized from.
  *
  * @return bool
  */
 public function supportsDenormalization($data, $type, $format = null)
 {
     if ($format == "xml" && $type == AutoSettle::GetClassName()) {
         return true;
     }
     return false;
 }
 /**
  * Tests conversion of {@link PaymentRequest} to and from XML using setters.
  */
 public function testPaymentRequestXmlSetters()
 {
     $card = new Card();
     $card->setExpiryDate(SampleXmlValidationUtils::CARD_EXPIRY_DATE);
     $card->setNumber(SampleXmlValidationUtils::CARD_NUMBER);
     $card->setType(SampleXmlValidationUtils::$CARD_TYPE->getType());
     $card->setCardHolderName(SampleXmlValidationUtils::CARD_HOLDER_NAME);
     $card->setIssueNumber(SampleXmlValidationUtils::CARD_ISSUE_NUMBER);
     $cvn = new Cvn();
     $cvn->setNumber(SampleXmlValidationUtils::CARD_CVN_NUMBER);
     $cvn->setPresenceIndicator(SampleXmlValidationUtils::$CARD_CVN_PRESENCE->getIndicator());
     $card->setCvn($cvn);
     $request = new PaymentRequest();
     $request->setAccount(SampleXmlValidationUtils::ACCOUNT);
     $request->setMerchantId(SampleXmlValidationUtils::MERCHANT_ID);
     $request->setType(PaymentType::AUTH);
     $amount = new Amount();
     $amount->setAmount(SampleXmlValidationUtils::AMOUNT);
     $amount->setCurrency(SampleXmlValidationUtils::CURRENCY);
     $request->setAmount($amount);
     $autoSettle = new AutoSettle();
     $autoSettle->setFlag(SampleXmlValidationUtils::$AUTO_SETTLE_FLAG->getFlag());
     $request->setAutoSettle($autoSettle);
     $request->setCard($card);
     $request->setTimeStamp(SampleXmlValidationUtils::TIMESTAMP);
     $request->setChannel(SampleXmlValidationUtils::CHANNEL);
     $request->setOrderId(SampleXmlValidationUtils::ORDER_ID);
     $request->setHash(SampleXmlValidationUtils::REQUEST_HASH);
     $comments = new CommentCollection();
     $comment = new Comment();
     $comment->setId(1);
     $comment->setComment(SampleXmlValidationUtils::COMMENT1);
     $comments->add($comment);
     $comment = new Comment();
     $comment->setId(2);
     $comment->setComment(SampleXmlValidationUtils::COMMENT2);
     $comments->add($comment);
     $request->setComments($comments);
     $request->setPaymentsReference(SampleXmlValidationUtils::PASREF);
     $request->setAuthCode(SampleXmlValidationUtils::AUTH_CODE);
     $request->setRefundHash(SampleXmlValidationUtils::REFUND_HASH);
     $request->setFraudFilter(SampleXmlValidationUtils::FRAUD_FILTER);
     $recurring = new Recurring();
     $recurring->setFlag(SampleXmlValidationUtils::$RECURRING_FLAG->getRecurringFlag());
     $recurring->setSequence(SampleXmlValidationUtils::$RECURRING_SEQUENCE->getSequence());
     $recurring->setType(SampleXmlValidationUtils::$RECURRING_TYPE->getType());
     $request->setRecurring($recurring);
     $tssInfo = new TssInfo();
     $tssInfo->setCustomerNumber(SampleXmlValidationUtils::CUSTOMER_NUMBER);
     $tssInfo->setProductId(SampleXmlValidationUtils::PRODUCT_ID);
     $tssInfo->setVariableReference(SampleXmlValidationUtils::VARIABLE_REFERENCE);
     $tssInfo->setCustomerIpAddress(SampleXmlValidationUtils::CUSTOMER_IP);
     $addresses = array();
     $address = new Address();
     $address->setType(SampleXmlValidationUtils::$ADDRESS_TYPE_BUSINESS->getAddressType());
     $address->setCode(SampleXmlValidationUtils::ADDRESS_CODE_BUSINESS);
     $address->setCountry(SampleXmlValidationUtils::ADDRESS_COUNTRY_BUSINESS);
     $addresses[] = $address;
     $address = new Address();
     $address->setType(SampleXmlValidationUtils::$ADDRESS_TYPE_SHIPPING->getAddressType());
     $address->setCode(SampleXmlValidationUtils::ADDRESS_CODE_SHIPPING);
     $address->setCountry(SampleXmlValidationUtils::ADDRESS_COUNTRY_SHIPPING);
     $addresses[] = $address;
     $tssInfo->setAddresses($addresses);
     $request->setTssInfo($tssInfo);
     $mpi = new Mpi();
     $mpi->setCavv(SampleXmlValidationUtils::THREE_D_SECURE_CAVV);
     $mpi->setXid(SampleXmlValidationUtils::THREE_D_SECURE_XID);
     $mpi->setEci(SampleXmlValidationUtils::THREE_D_SECURE_ECI);
     $request->setMpi($mpi);
     //convert to XML
     $xml = $request->toXml();
     //Convert from XML back to PaymentRequest
     /* @var PaymentRequest $fromXmlRequest */
     $fromXmlRequest = new PaymentRequest();
     $fromXmlRequest = $fromXmlRequest->fromXml($xml);
     SampleXmlValidationUtils::checkUnmarshalledPaymentRequest($fromXmlRequest, $this);
 }
 private function denormaliseAutoSettle(\ArrayAccess $array)
 {
     $autoSettleData = $array['autosettle'];
     if (is_null($autoSettleData)) {
         return null;
     }
     $data = new SafeArrayAccess($autoSettleData);
     $autoSettle = new AutoSettle();
     $autoSettle->addFlag($data['@flag']);
     return $autoSettle;
 }
 private function denormaliseAutoSettle(\ArrayAccess $array)
 {
     return $this->serializer->denormalize($array['autosettle'], AutoSettle::GetClassName(), $this->format, $this->context);
 }
 /**
  * Tests conversion of {@link ThreeDSecureRequest} card enrolled to and from XML using setters.
  */
 public function testThreeDSecureCardEnrolledRequestXmlWithSetters()
 {
     $request = new ThreeDSecureRequest();
     $request->setAccount(SampleXmlValidationUtils::CARD_VERIFY_ACCOUNT);
     $request->setMerchantId(SampleXmlValidationUtils::CARD_VERIFY_MERCHANT_ID);
     $paymentData = new PaymentData();
     $paymentData->addCvnNumber(SampleXmlValidationUtils::CARD_PAYMENT_DATA_CVN);
     $request->setPaymentData($paymentData);
     $amount = new Amount();
     $amount->setAmount(SampleXmlValidationUtils::CARD_VERIFY_AMOUNT);
     $amount->setCurrency(SampleXmlValidationUtils::CARD_VERIFY_CURRENCY);
     $request->setAmount($amount);
     $request->setTimeStamp(SampleXmlValidationUtils::CARD_VERIFY_TIMESTAMP);
     $request->setOrderId(SampleXmlValidationUtils::CARD_VERIFY_ORDER_ID);
     $request->setPaymentMethod(SampleXmlValidationUtils::CARD_VERIFY_REF);
     $request->setPayerRef(SampleXmlValidationUtils::CARD_VERIFY_PAYER_REF);
     $request->setHash(SampleXmlValidationUtils::CARD_VERIFY_REQUEST_HASH);
     $request->setType(ThreeDSecureType::VERIFY_STORED_CARD_ENROLLED);
     $autoSettle = new AutoSettle();
     $autoSettle->setFlag(SampleXmlValidationUtils::$CARD_VERIFY_AUTO_SETTLE_FLAG->getFlag());
     $request->setAutoSettle($autoSettle);
     // convert to XML
     $xml = $request->toXml();
     // Convert from XML back to PaymentRequest
     /* @var ThreeDSecureRequest $fromXmlRequest */
     $fromXmlRequest = new ThreeDSecureRequest();
     $fromXmlRequest = $fromXmlRequest->fromXml($xml);
     SampleXmlValidationUtils::checkUnmarshalledVerifyCardEnrolledPaymentRequest($fromXmlRequest, $this);
 }