def authorize(): google = oauth.create_client('google') token = google.authorize_access_token() response = google.get('userinfo') user_info = response.json() user = oauth.google.userinfo() session['profile'] = user_info user = User.query.filter_by(email = user_info['email']).first() if user: login_user(user) session.permanent = True return redirect(url_for('profile')) else: g_first_name = user_info['given_name'].lower() g_last_name = user_info['family_name'].lower() g_email = user_info['email'] g_verified = user_info['verified_email'] user = User( first_name = g_first_name, last_name = g_last_name, email = g_email, g_auth_verify = g_verified ) db.session.add(user) db.session.commit() session.permanent = True login_user(user) return redirect(url_for('profile')) print(user_info) return redirect(url_for('home'))
def google_auth(): google = oauth.create_client('google') redirect_uri = url_for('authorize', _external=True) return google.authorize_redirect(redirect_uri)