Skip to content

Commit

Permalink
security: post OAuth token to webapps using file protocol
Browse files Browse the repository at this point in the history
When client is loaded from file oauth can't be used
because location.hostname is null.

So we fallback by using postMessage API,
instead of parsing the token page.

Test could have been done on location.hostname,
but for security concerns only file:// protocol is whitelisted

Change-Id: I42af71ae822491150c019cff9688356b1a0e2532
Bug: #1149
Signed-off-by: Philippe Coval <p.coval@samsung.com>
  • Loading branch information
rzr committed Jul 9, 2018
1 parent 8489dcf commit c7d0f4f
Showing 1 changed file with 7 additions and 0 deletions.
7 changes: 7 additions & 0 deletions src/views/local-token-service.mustache
Original file line number Diff line number Diff line change
Expand Up @@ -134,6 +134,13 @@ for (let origin of document.querySelectorAll('.origin')) {
if (!window.location.origin.endsWith('.mozilla-iot.org')) {
document.body.classList.add('insecure');
}
/* postToken to client apps if any */
if (window.location.protocol === "file:") {
window.addEventListener("message", function(ev) {
if (ev.data.message === "token") {
ev.source.postMessage({ message: { token: "{{token}}" }}, "*");
}
});
hljs.initHighlightingOnLoad();
</script>
Expand Down

0 comments on commit c7d0f4f

Please sign in to comment.