/** * Denormalizes data back into an object of the given class. * * @param mixed $data data to restore * @param string $class the expected class to instantiate * @param string $format format the given data was extracted from * @param array $context options available to the denormalizer * * @return object */ public function denormalize($data, $class, $format = null, array $context = array()) { if (is_null($data)) { return null; } $data = new SafeArrayAccess($data); $cvn = new CvnNumber(); $cvn->addNumber($data['number']); return $cvn; }
/** * Tests conversion of {@link PaymentRequest} to and from XML using setters for Paymentdata. */ public function testPaymentRequestXmlPaymentDataFluentSetters1() { $autoSettle = new AutoSettle(); $autoSettle->setFlag(SampleXmlValidationUtils::$RECEIPT_IN_AUTO_SETTLE_FLAG->getFlag()); $cvnNumber = new CvnNumber(); $cvnNumber->addNumber(SampleXmlValidationUtils::RECEIPT_IN_CVN); $paymentData = new PaymentData(); $paymentData->addCvnNumber($cvnNumber); $request = new PaymentRequest(); $request->addAccount(SampleXmlValidationUtils::RECEIPT_IN_ACCOUNT)->addMerchantId(SampleXmlValidationUtils::RECEIPT_IN_MERCHANT_ID)->addType(PaymentType::RECEIPT_IN)->addAmount(SampleXmlValidationUtils::RECEIPT_IN_AMOUNT)->addCurrency(SampleXmlValidationUtils::RECEIPT_IN_CURRENCY)->addPayerReference(SampleXmlValidationUtils::RECEIPT_IN_PAYER)->addPaymentMethod(SampleXmlValidationUtils::RECEIPT_IN_PAYMENT_METHOD)->addAutoSettle($autoSettle)->addTimeStamp(SampleXmlValidationUtils::RECEIPT_IN_TIMESTAMP)->addOrderId(SampleXmlValidationUtils::RECEIPT_IN_ORDER_ID)->addHash(SampleXmlValidationUtils::RECEIPT_IN_REQUEST_HASH)->addPaymentData($paymentData); // convert to XML $xml = $request->toXml(); // Convert from XML back to PaymentRequest /* @var PaymentRequest $fromXmlRequest */ $fromXmlRequest = new PaymentRequest(); $fromXmlRequest = $fromXmlRequest->fromXml($xml); SampleXmlValidationUtils::checkUnmarshalledReceiptInPaymentRequest($fromXmlRequest, $this); }