31

I redirect user to the OAuth 2.0 authorization endpoint in popup window. What is best way to close this popup and refresh main window after OAuth 2.0 authorization server redirects user back with an authorization code?

Thanks in advance for any help.

om-nom-nom
  • 62,329
  • 13
  • 183
  • 228
Lukasz Moren
  • 1,625
  • 2
  • 15
  • 16

3 Answers3

37

I think popup you can close by

parent.close();

And to refresh main window I used this trick:

$(function() {
    var win;
    var checkConnect;
    var $connect = $("#some_button");
    var oAuthURL = "http://example.com/account/_oauth?redirect_url=" + redirect_url;
    $connect.click(function() {
        win = window.open(oAuthURL, 'SomeAuthentication', 'width=972,height=660,modal=yes,alwaysRaised=yes');
    });

    checkConnect = setInterval(function() {
        if (!win || !win.closed) return;
        clearInterval(checkConnect);
        window.location.reload();
    }, 100);
});

Opener ( main window ) just checks every time if the popup still live and if win.closed returns true - the main window reloads

Hope it will help somebody

Baby Groot
  • 4,637
  • 39
  • 52
  • 71
Mak
  • 19,913
  • 5
  • 26
  • 32
2

So IDK if this will help anyone, but instead of refreshing the page, you probably want to be checking your server to see if the user connected or not via a re-occurring timeout, and then use .close() after they did. An added benefit here is that you'll now have the data to continue on with the registration process.

Agamemnus
  • 1,395
  • 4
  • 17
  • 41
0

First, on the main window you need to open an new popup window, this will open a centered window:

$('.openwindow').click(function(){
    var uri = 'https://my-oauth-server-url'
    var left = (screen.width/2 - 400)
    var top = (screen.height/2 - 350)
    window.open(uri, 'oauth window','resizable=yes, width=800, height=700, top='+top+', left='+left)
});

Once you have the popup window opened you will need to reload the main window (opener window) with new content and close the popup window.

window.opener.location.replace('/oauthok');
window.close();
lvicedo
  • 31
  • 3