/** * {@inheritDoc} * * @param Capture $request */ public function execute($request) { RequestNotSupportedException::assertSupports($this, $request); $model = ArrayObject::ensureArrayObject($request->getModel()); $httpRequest = new GetHttpRequest(); $this->gateway->execute($httpRequest); if (isset($httpRequest->request[Api::FIELD_V2_HASH])) { $model->replace($httpRequest->request); //validate hash if (false === $this->api->verifyHash($httpRequest->request[Api::FIELD_V2_HASH], $httpRequest->request)) { throw new HttpRedirect((string) $request->getToken()->getAfterUrl()); } } else { //payment canceled if (isset($httpRequest->request[Api::FIELD_PAYMENT_BATCH_NUM]) && (int) $httpRequest->request[Api::FIELD_PAYMENT_BATCH_NUM] === 0) { $model->replace($httpRequest->request); throw new HttpRedirect((string) $request->getToken()->getAfterUrl()); } if (false === isset($model[Api::FIELD_PAYMENT_URL]) && $request->getToken()) { $model[Api::FIELD_PAYMENT_URL] = $request->getToken()->getTargetUrl(); } if (false === isset($model[Api::FIELD_NOPAYMENT_URL]) && $request->getToken()) { $model[Api::FIELD_NOPAYMENT_URL] = $request->getToken()->getTargetUrl(); } throw new HttpPostRedirect($this->api->getApiEndpoint(), $this->api->preparePayment($model->toUnsafeArray())); } }
/** * @test */ public function shouldNotChangeAmountIfNotSandbox() { $api = new Api(['alternate_passphrase' => 'passphares', 'payee_account' => 'account', 'display_name' => 'payment', 'sandbox' => false], $this->createHttpClientMock()); $post = $api->preparePayment([Api::FIELD_PAYMENT_AMOUNT => 100]); $this->assertArrayHasKey(Api::FIELD_PAYMENT_AMOUNT, $post); $this->assertEquals(100, $post[Api::FIELD_PAYMENT_AMOUNT]); }