wallet-core/src/headless/merchant.ts

139 lines
3.6 KiB
TypeScript
Raw Normal View History

2019-08-18 20:22:43 +02:00
/*
This file is part of GNU Taler
(C) 2019 GNUnet e.V.
GNU Taler is free software; you can redistribute it and/or modify it under the
terms of the GNU General Public License as published by the Free Software
Foundation; either version 3, or (at your option) any later version.
GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with
GNU Taler; see the file COPYING. If not, see <http://www.gnu.org/licenses/>
*/
/**
* Helpers for talking to the GNU Taler merchant backend.
* Used mostly for integration tests.
*/
2019-11-30 00:36:20 +01:00
/**
* Imports.
*/
2019-08-18 20:22:43 +02:00
import axios from "axios";
import { CheckPaymentResponse } from "../talerTypes";
import URI = require("urijs");
/**
* Connection to the *internal* merchant backend.
*/
export class MerchantBackendConnection {
2019-11-30 00:36:20 +01:00
async refund(
orderId: string,
reason: string,
refundAmount: string,
): Promise<void> {
const reqUrl = new URI("refund").absoluteTo(this.merchantBaseUrl).href();
const refundReq = {
order_id: orderId,
reason,
refund: refundAmount,
};
const resp = await axios({
method: "post",
url: reqUrl,
data: refundReq,
responseType: "json",
headers: {
Authorization: `ApiKey ${this.apiKey}`,
},
});
if (resp.status != 200) {
throw Error("failed to do refund");
}
console.log("response", resp.data);
const refundUri = resp.data.taler_refund_uri;
if (!refundUri) {
throw Error("no refund URI in response");
}
return refundUri;
}
constructor(public merchantBaseUrl: string, public apiKey: string) {}
async authorizeTip(amount: string, justification: string) {
const reqUrl = new URI("tip-authorize").absoluteTo(this.merchantBaseUrl).href();
const tipReq = {
amount,
justification,
};
const resp = await axios({
method: "post",
url: reqUrl,
data: tipReq,
responseType: "json",
headers: {
Authorization: `ApiKey ${this.apiKey}`,
},
});
const tipUri = resp.data.taler_tip_uri;
if (!tipUri) {
throw Error("response does not contain tip URI");
}
return tipUri;
}
2019-08-18 20:22:43 +02:00
async createOrder(
amount: string,
summary: string,
fulfillmentUrl: string,
): Promise<{ orderId: string }> {
const reqUrl = new URI("order").absoluteTo(this.merchantBaseUrl).href();
const orderReq = {
order: {
amount,
summary,
fulfillment_url: fulfillmentUrl,
},
};
const resp = await axios({
method: "post",
url: reqUrl,
data: orderReq,
responseType: "json",
headers: {
Authorization: `ApiKey ${this.apiKey}`,
},
});
if (resp.status != 200) {
throw Error("failed to create bank reserve");
}
const orderId = resp.data.order_id;
if (!orderId) {
throw Error("no order id in response");
}
return { orderId };
}
async checkPayment(orderId: string): Promise<CheckPaymentResponse> {
const reqUrl = new URI("check-payment")
.absoluteTo(this.merchantBaseUrl)
.href();
const resp = await axios({
method: "get",
url: reqUrl,
2019-10-01 20:45:36 +02:00
params: { order_id: orderId },
2019-08-18 20:22:43 +02:00
responseType: "json",
headers: {
Authorization: `ApiKey ${this.apiKey}`,
},
});
if (resp.status != 200) {
throw Error("failed to check payment");
}
return CheckPaymentResponse.checked(resp.data);
}
}