aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFlorian Dold <florian.dold@gmail.com>2016-09-07 17:10:02 +0200
committerFlorian Dold <florian.dold@gmail.com>2016-09-07 17:10:02 +0200
commit4b67f220e7d9ab4a7d7a190892f028995baa9902 (patch)
tree52aa228da5c8e32f0c19b5784aa59c08d1e9370a
parenta83e60e6057e7baf64e7596e8a9666a752b55b7f (diff)
can't import here ...
-rw-r--r--content_scripts/notify.ts112
1 files changed, 106 insertions, 6 deletions
diff --git a/content_scripts/notify.ts b/content_scripts/notify.ts
index c6351fcf7..54d7b6acb 100644
--- a/content_scripts/notify.ts
+++ b/content_scripts/notify.ts
@@ -27,14 +27,18 @@
"use strict";
-import {createReserve, confirmContract, fetchPayment} from "../lib/shopApi";
-
// Make sure we don't pollute the namespace too much.
namespace TalerNotify {
const PROTOCOL_VERSION = 1;
console.log("Taler injected", chrome.runtime.id);
+ function subst(url: string, H_contract) {
+ url = url.replace("${H_contract}", H_contract);
+ url = url.replace("${$}", "$");
+ return url;
+ }
+
const handlers = [];
function init() {
@@ -61,6 +65,8 @@ namespace TalerNotify {
init();
function registerHandlers() {
+ const $ = (x) => document.getElementById(x);
+
function addHandler(type, listener) {
document.addEventListener(type, listener);
handlers.push({type, listener});
@@ -85,7 +91,16 @@ namespace TalerNotify {
});
addHandler("taler-create-reserve", function(e: CustomEvent) {
- createReserve(e.detail.amount, e.detail.callback_url, e.detail.wt_types);
+ console.log("taler-create-reserve with " + JSON.stringify(e.detail));
+ let params = {
+ amount: JSON.stringify(e.detail.amount),
+ callback_url: URI(e.detail.callback_url)
+ .absoluteTo(document.location.href),
+ bank_url: document.location.href,
+ wt_types: JSON.stringify(e.detail.wt_types),
+ };
+ let uri = URI(chrome.extension.getURL("pages/confirm-create-reserve.html"));
+ document.location.href = uri.query(params).href();
});
addHandler("taler-confirm-reserve", function(e: CustomEvent) {
@@ -101,8 +116,53 @@ namespace TalerNotify {
});
});
+
addHandler("taler-confirm-contract", function(e: CustomEvent) {
- confirmContract(e.detail.contract_wrapper, e.detail.replace_navigation);
+ if (!e.detail.contract_wrapper) {
+ console.error("contract wrapper missing");
+ return;
+ }
+
+ const offer = e.detail.contract_wrapper;
+
+ if (!offer.contract) {
+ console.error("contract field missing");
+ return;
+ }
+
+ const msg = {
+ type: "check-repurchase",
+ detail: {
+ contract: offer.contract
+ },
+ };
+
+ chrome.runtime.sendMessage(msg, (resp) => {
+ if (resp.error) {
+ console.error("wallet backend error", resp);
+ return;
+ }
+ if (resp.isRepurchase) {
+ console.log("doing repurchase");
+ console.assert(resp.existingFulfillmentUrl);
+ console.assert(resp.existingContractHash);
+ window.location.href = subst(resp.existingFulfillmentUrl,
+ resp.existingContractHash);
+
+ } else {
+ const uri = URI(chrome.extension.getURL("pages/confirm-contract.html"));
+ const params = {
+ offer: JSON.stringify(offer),
+ merchantPageUrl: document.location.href,
+ };
+ const target = uri.query(params).href();
+ if (e.detail.replace_navigation === true) {
+ document.location.replace(target);
+ } else {
+ document.location.href = target;
+ }
+ }
+ });
});
addHandler("taler-payment-failed", (e: CustomEvent) => {
@@ -118,8 +178,48 @@ namespace TalerNotify {
});
});
- addHandler("taler-fetch-payment", (e: CustomEvent) => {
- fetchPayment(e.detail.H_contract, e.detail.offering_url);
+ // Should be: taler-request-payment, taler-result-payment
+
+ addHandler("taler-execute-contract", (e: CustomEvent) => {
+ console.log("got taler-execute-contract in content page");
+ const msg = {
+ type: "execute-payment",
+ detail: {
+ H_contract: e.detail.H_contract,
+ },
+ };
+
+ chrome.runtime.sendMessage(msg, (resp) => {
+ console.log("got resp");
+ console.dir(resp);
+ if (!resp.success) {
+ console.log("got event detial:");
+ console.dir(e.detail);
+ if (e.detail.offering_url) {
+ console.log("offering url", e.detail.offering_url);
+ window.location.href = e.detail.offering_url;
+ } else {
+ console.error("execute-payment failed");
+ }
+ return;
+ }
+ let contract = resp.contract;
+ if (!contract) {
+ throw Error("contract missing");
+ }
+
+ // We have the details for then payment, the merchant page
+ // is responsible to give it to the merchant.
+
+ let evt = new CustomEvent("taler-notify-payment", {
+ detail: {
+ H_contract: e.detail.H_contract,
+ contract: resp.contract,
+ payment: resp.payReq,
+ }
+ });
+ document.dispatchEvent(evt);
+ });
});
}
} \ No newline at end of file