Sha256: 752d41156acaedeefba0dd0d827f55deef4fc532bb70307f81b24230b6ec0cb5
Contents?: true
Size: 1.88 KB
Versions: 1
Compression:
Stored size: 1.88 KB
Contents
require 'omniauth-oauth2' module OmniAuth module Strategies class GitHub < OmniAuth::Strategies::OAuth2 option :client_options, { :site => 'https://api.github.com', :authorize_url => 'https://github.com/login/oauth/authorize', :token_url => 'https://github.com/login/oauth/access_token' } def request_phase super end def authorize_params super.tap do |params| %w[scope client_options].each do |v| if request.params[v] params[v.to_sym] = request.params[v] end end end end uid { raw_info['id'].to_s } info do { 'nickname' => raw_info['login'], 'email' => email, 'name' => raw_info['name'], 'image' => raw_info['avatar_url'], 'urls' => { 'GitHub' => "https://github.com/#{raw_info['login']}", 'Blog' => raw_info['blog'], }, } end extra do {:raw_info => raw_info} end def raw_info access_token.options[:mode] = :query @raw_info ||= access_token.get('user').parsed end def email (email_access_allowed?) ? primary_email : raw_info['email'] end def primary_email primary = emails.find{|i| i['primary'] } primary && primary['email'] || emails.first && emails.first['email'] end # The new /user/emails API - http://developer.github.com/v3/users/emails/#future-response def emails return [] unless email_access_allowed? access_token.options[:mode] = :query @emails ||= access_token.get('user/emails', :headers => { 'Accept' => 'application/vnd.github.v3' }).parsed end def email_access_allowed? options['scope'] =~ /user/ end end end end OmniAuth.config.add_camelization 'github', 'GitHub'
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
omniauth-github-1.1.2 | lib/omniauth/strategies/github.rb |