Skip to content

Commit

Permalink
Use postmessage instead of storage event for embedded case
Browse files Browse the repository at this point in the history
  • Loading branch information
Gaurav0 committed Aug 23, 2024
1 parent 24705d0 commit f0e714f
Show file tree
Hide file tree
Showing 3 changed files with 73 additions and 5 deletions.
35 changes: 35 additions & 0 deletions addon/mixins/ui-service-mixin.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ var ServicesMixin = Mixin.create({
let service = this;
let lastRemote = this.remote;
let storageToriiEventHandler;
let messageToriiEventHandler;

return new EmberPromise(function (resolve, reject) {
if (lastRemote) {
Expand All @@ -55,7 +56,40 @@ var ServicesMixin = Mixin.create({
});
}
};

// Using postMessage as an alternative to localStorage/storageEvent
// for case of web site embedded in iframe
messageToriiEventHandler = function (messageEvent) {
if (messageEvent.source === service.remote) {
if (messageEvent.data === 'getPendingRequestKey') {
// console.log('getPendingRequestKey');
service.remote.postMessage(
JSON.stringify({ pendingRequestKey: service.pendingRequestKey }),
window.location.origin
);
} else {
const msg = JSON.parse(messageEvent.data);
// console.log(msg);
const key = Object.keys(msg)[0];
var remoteIdFromEvent = PopupIdSerializer.deserialize(
decodeURIComponent(key)
);
if (remoteId === remoteIdFromEvent) {
// console.log(msg[key]);
var data = parseMessage(msg[key], keys);
localStorage.removeItem(key);
// console.log(data);
run(function () {
resolve(data);
});
}
}
}
};
window.addEventListener('message', messageToriiEventHandler);

var pendingRequestKey = PopupIdSerializer.serialize(remoteId);
service.pendingRequestKey = pendingRequestKey;
localStorage.setItem(CURRENT_REQUEST_KEY, pendingRequestKey);
localStorage.removeItem(WARNING_KEY);

Expand Down Expand Up @@ -115,6 +149,7 @@ var ServicesMixin = Mixin.create({
}).finally(function () {
// didClose will reject this same promise, but it has already resolved.
service.close();
window.removeEventListener('message', messageToriiEventHandler);
window.removeEventListener('storage', storageToriiEventHandler);
});
},
Expand Down
6 changes: 6 additions & 0 deletions addon/providers/oauth2-bearer.js
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,12 @@ var Oauth2Bearer = Provider.extend({
);
}

console.log({
authorizationToken: authData,
provider: name,
redirectUri: redirectUri,
});

return {
authorizationToken: authData,
provider: name,
Expand Down
37 changes: 32 additions & 5 deletions public/redirect.html
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,43 @@
<meta charset="UTF-8">
<title>Torii OAuth Redirect</title>
<script>
var CURRENT_REQUEST_KEY = '__torii_request';
var pendingRequestKey = window.localStorage.getItem(CURRENT_REQUEST_KEY);
const CURRENT_REQUEST_KEY = '__torii_request';
const pendingRequestKey = window.localStorage.getItem(CURRENT_REQUEST_KEY);
const origin = window.location.origin;

if (pendingRequestKey) {
window.localStorage.removeItem(CURRENT_REQUEST_KEY);
var url = window.location.toString();
const url = window.location.toString();
window.localStorage.setItem(pendingRequestKey, url);
}
const obj = {};
obj[pendingRequestKey] = url;
window.opener?.postMessage(
JSON.stringify(obj),
origin
);

window.close();
} else {
// localStorage not shared with opener due to browser restrictions
window.opener.postMessage('getPendingRequestKey', origin);
window.addEventListener('message', function(messageEvent) {
if (messageEvent.source === window.opener) {
const msg = JSON.parse(messageEvent.data);
if (msg.pendingRequestKey) {
pendingRequestKey = msg.pendingRequestKey;
url = window.location.toString();
const obj = {};
obj[pendingRequestKey] = url;
window.opener.postMessage(
JSON.stringify(obj),
origin
);

window.close();
window.close();
}
}
});
}
</script>
</head>
</html>

0 comments on commit f0e714f

Please sign in to comment.