diff options
author | Florian Dold <florian.dold@gmail.com> | 2015-12-20 20:05:06 +0100 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2015-12-20 20:05:06 +0100 |
commit | 4bba46b53eb93de669b91c3078cd04ac13a0647c (patch) | |
tree | bc2f11f1dca621f3e4cf210e580c0705e4771c06 /extension/content_scripts | |
parent | d583dfb07364b955801dc4f8b3a46237c1fa6b7c (diff) | |
download | wallet-core-4bba46b53eb93de669b91c3078cd04ac13a0647c.tar.xz |
payment
Diffstat (limited to 'extension/content_scripts')
-rw-r--r-- | extension/content_scripts/notify.js | 43 | ||||
-rw-r--r-- | extension/content_scripts/notify.ts | 45 |
2 files changed, 72 insertions, 16 deletions
diff --git a/extension/content_scripts/notify.js b/extension/content_scripts/notify.js index 4a014e853..899355f8e 100644 --- a/extension/content_scripts/notify.js +++ b/extension/content_scripts/notify.js @@ -1,22 +1,22 @@ // Script that is injected into pages in order to allow merchants pages to // query the availability of Taler. -'use strict'; -document.addEventListener('taler-checkout-probe', function (e) { - let evt = new Event('taler-wallet-present'); +"use strict"; +document.addEventListener("taler-checkout-probe", function (e) { + let evt = new Event("taler-wallet-present"); document.dispatchEvent(evt); console.log("merchant handshake done"); }); -document.addEventListener('taler-wire-probe', function (e) { - let evt = new Event('taler-wallet-present'); +document.addEventListener("taler-wire-probe", function (e) { + let evt = new Event("taler-wallet-present"); document.dispatchEvent(evt); console.log("bank handshake done"); }); -document.addEventListener('taler-checkout-probe', function (e) { - let evt = new Event('taler-wallet-present'); +document.addEventListener("taler-checkout-probe", function (e) { + let evt = new Event("taler-wallet-present"); document.dispatchEvent(evt); console.log("merchant handshake done"); }); -document.addEventListener('taler-create-reserve', function (e) { +document.addEventListener("taler-create-reserve", function (e) { let $ = (x) => document.getElementById(x); console.log("taler-create-reserve with " + JSON.stringify(e.detail)); let form_uri = $(e.detail.form_id).action; @@ -46,3 +46,30 @@ document.addEventListener('taler-contract', function (e) { }; document.location.href = uri.query(params).href(); }); +document.addEventListener('taler-execute-payment', function (e) { + console.log("got taler-execute-payment in content page"); + let msg = { + type: "execute-payment", + detail: { + H_contract: e.detail.H_contract + }, + }; + chrome.runtime.sendMessage(msg, (resp) => { + //console.log("got response from bg page", JSON.stringify(resp)); + if (!resp.success) { + console.log("failure!"); + return; + } + let r = new XMLHttpRequest(); + r.open('post', resp.payUrl); + r.send(JSON.stringify(resp.payReq)); + r.onload = (e) => { + if (r.status != 200) { + console.log("non-200 error"); + console.log(r.responseText); + } + let evt = new Event("taler-payment-result", resp); + document.dispatchEvent(evt); + }; + }); +}); diff --git a/extension/content_scripts/notify.ts b/extension/content_scripts/notify.ts index 7a50582e8..03135dd06 100644 --- a/extension/content_scripts/notify.ts +++ b/extension/content_scripts/notify.ts @@ -1,27 +1,27 @@ // Script that is injected into pages in order to allow merchants pages to // query the availability of Taler. -'use strict'; +"use strict"; -document.addEventListener('taler-checkout-probe', function(e) { - let evt = new Event('taler-wallet-present'); +document.addEventListener("taler-checkout-probe", function(e) { + let evt = new Event("taler-wallet-present"); document.dispatchEvent(evt); console.log("merchant handshake done"); }); -document.addEventListener('taler-wire-probe', function(e) { - let evt = new Event('taler-wallet-present'); +document.addEventListener("taler-wire-probe", function(e) { + let evt = new Event("taler-wallet-present"); document.dispatchEvent(evt); console.log("bank handshake done"); }); -document.addEventListener('taler-checkout-probe', function(e) { - let evt = new Event('taler-wallet-present'); +document.addEventListener("taler-checkout-probe", function(e) { + let evt = new Event("taler-wallet-present"); document.dispatchEvent(evt); console.log("merchant handshake done"); }); -document.addEventListener('taler-create-reserve', function(e: CustomEvent) { +document.addEventListener("taler-create-reserve", function(e: CustomEvent) { let $ = (x) => document.getElementById(x); console.log("taler-create-reserve with " + JSON.stringify(e.detail)); let form_uri = (<HTMLFormElement>$(e.detail.form_id)).action; @@ -52,3 +52,32 @@ document.addEventListener('taler-contract', function(e: CustomEvent) { }; document.location.href = uri.query(params).href(); }); + + +document.addEventListener('taler-execute-payment', function(e: CustomEvent) { + console.log("got taler-execute-payment in content page"); + let msg = { + type: "execute-payment", + detail: { + H_contract: e.detail.H_contract + }, + }; + chrome.runtime.sendMessage(msg, (resp) => { + //console.log("got response from bg page", JSON.stringify(resp)); + if (!resp.success) { + console.log("failure!"); + return; + } + let r = new XMLHttpRequest(); + r.open('post', resp.payUrl); + r.send(JSON.stringify(resp.payReq)); + r.onload = (e) => { + if (r.status != 200) { + console.log("non-200 error"); + console.log(r.responseText); + } + let evt = new Event("taler-payment-result", resp); + document.dispatchEvent(evt); + }; + }); +});
\ No newline at end of file |