Exemple #1
0
    def login(self):

        consumer = Consumer(session, SOOpenIDStore())
        # catch Google Apps domain that is referring, if any 
        domain = None
        if 'domain' in request.POST:
            domain = request.POST['domain']
        elif 'domain' in request.GET:
            domain = request.GET['domain']

        try:
            # two different endpoints depending on whether the using is using Google Account or Google Apps Account
            if domain:
                auth_request = consumer.begin('https://www.google.com/accounts/o8/site-xrds?hd=%s' % domain)
            else:
                auth_request = consumer.begin('https://www.google.com/accounts/o8/id')
        except DiscoveryFailure as e:
            flash ("Google Accounts Error : Google's OpenID endpoint is not available.")
            return redirect("/user/show_login")

        # add requests for additional account information required, in my case: email
        auth_request.addExtensionArg('http://openid.net/srv/ax/1.0', 'mode', 'fetch_request')
        auth_request.addExtensionArg('http://openid.net/srv/ax/1.0', 'required', 'email')
        auth_request.addExtensionArg('http://openid.net/srv/ax/1.0', 'type.email', 'http://schema.openid.net/contact/email')

        return redirect(auth_request.redirectURL(url('/', qualified=True), url(controller='user', action='google_login_response', qualified=True)))
Exemple #2
0
    def setup(self):
        user = self.user
        if not user:
            return redirect("show_login")
        display_name = request.params["display_name"]
        if not display_name:
            flash("Please enter a display name")
            return redirect(url(controller="user", action="show_setup"))

        user.display_name = display_name

        create_channel(user.password)

        return redirect(url(controller="lobby", action="lobby"))
Exemple #3
0
    def google_login_response(self):
        oidconsumer = Consumer(session, SOOpenIDStore())

        # parse GET parameters submit them with the full url to consumer.complete
        _params = dict((k, unicode(v).encode('utf-8')) for k, v in request.GET.items())
        info = oidconsumer.complete(_params, request.scheme + '://' + request.host + request.path)
        display_identifier = info.getDisplayIdentifier()

        if info.status == FAILURE and display_identifier:
            flash("Verification of %(user)s failed: %(error_message)s" % {'user' : display_identifier, 'error_message' : info.message})

        elif info.status == SUCCESS:
            email = info.message.args[('http://openid.net/srv/ax/1.0', 'value.email')]
            try:
                user = User.selectBy(email=email.lower())[0]
            except IndexError:
                # create a new account if one does not exist with the authorized email yet and log that user in
                user = User.create(email=email.lower())
                user.login()
                session['user_id'] = user.id
                session.save()
                return redirect(url(action="show_setup", controller="user"))
            else:
                user.login()
                session['user_id'] = user.id
                session.save()
                return redirect(url(action="show_setup", controller="user"))

        elif info.status == CANCEL:
            flash('Google account verification cancelled.')
            return redirect(url(action="show_login", controller="user"))

        elif info.status == SETUP_NEEDED:
            if info.setup_url:
                flash('<a href="%(url)s">Setup needed</a>' % { 'url' : info.setup_url })
            else:
                # This means auth didn't succeed, but you're welcome to try
                # non-immediate mode.
                flash('Setup needed')
                return redirect(url(action="show_login", controller="user"))
        else:
            # Either we don't understand the code or there is no
            # openid_url included with the error. Give a generic
            # failure message. The library should supply debug
            # information in a log.
            flash('Google account verification failed for an unknown reason.')
            return redirect(url(action="show_login", controller="user"))