/** * Parse the specified XML element into an iDEAL transaction object * * @param SimpleXMLElement $xml */ public static function parse(SimpleXMLElement $xml) { $transaction = new Pronamic_WP_Pay_Gateways_IDealAdvanced_Transaction(); if ($xml->transactionID) { $transaction->setId(Pronamic_WP_Pay_XML_Security::filter($xml->transactionID)); } if ($xml->purchaseID) { $transaction->setPurchaseId(Pronamic_WP_Pay_XML_Security::filter($xml->purchaseID)); } if ($xml->status) { $transaction->setStatus(Pronamic_WP_Pay_XML_Security::filter($xml->status)); } if ($xml->consumerName) { $transaction->setConsumerName(Pronamic_WP_Pay_XML_Security::filter($xml->consumerName)); } if ($xml->consumerAccountNumber) { $transaction->setConsumerAccountNumber(Pronamic_WP_Pay_XML_Security::filter($xml->consumerAccountNumber)); } if ($xml->consumerCity) { $transaction->setConsumerCity(Pronamic_WP_Pay_XML_Security::filter($xml->consumerCity)); } return $transaction; }
/** * Start transaction with the specified date * * @see Pronamic_WP_Pay_Gateway::start() */ public function start(Pronamic_Pay_PaymentDataInterface $data, Pronamic_Pay_Payment $payment, $payment_method = null) { // Purchase ID $purchase_id = Pronamic_WP_Pay_Gateways_IDeal_Util::get_purchase_id($this->config->purchase_id, $data, $payment); $payment->set_meta('purchase_id', $purchase_id); // Transaction request message $transaction = new Pronamic_WP_Pay_Gateways_IDealAdvanced_Transaction(); $transaction->setPurchaseId($purchase_id); $transaction->setAmount($data->get_amount()); $transaction->setCurrency($data->get_currency()); $transaction->setExpirationPeriod('PT3M30S'); $transaction->setLanguage($data->get_language()); $transaction->setDescription($data->get_description()); $transaction->setEntranceCode($data->get_entrance_code()); $return_url = add_query_arg('payment', $payment->get_id(), home_url('/')); $result = $this->client->create_transaction($transaction, $return_url, $data->get_issuer_id()); $error = $this->client->get_error(); if (null !== $error) { $this->error = $error; } else { $payment->set_action_url($result->issuer->authenticationUrl); $payment->set_transaction_id($result->transaction->getId()); } }