class OmniAuth::Strategies::WechatQiye

Public Instance Methods

raw_info() click to toggle source
# File lib/omniauth/strategies/wechat_qiye.rb, line 48
def raw_info
  # step 2: get userid via code and access_token
  @code ||= access_token[:code]

  # step 3: get user info via userid
  @uid ||= begin
    access_token.options[:mode] = :query
    response = access_token.get('/cgi-bin/user/getuserinfo', :params => {'code' => @code}, parse: :json)
    response.parsed['UserId']
  end

  @raw_info ||= begin
    access_token.options[:mode] = :query
    response = access_token.get("/cgi-bin/user/get", :params => {"userid" => @uid}, parse: :json)
    response.parsed
  end
end
request_phase() click to toggle source
# File lib/omniauth/strategies/wechat_qiye.rb, line 42
def request_phase
  params = client.auth_code.authorize_params.merge(redirect_uri: callback_url).merge(authorize_params)
  params["appid"] = params.delete("client_id")
  redirect client.authorize_url(params)
end

Protected Instance Methods

build_access_token() click to toggle source
# File lib/omniauth/strategies/wechat_qiye.rb, line 67
def build_access_token
  # step 0: wechat respond code
  code = request.params['code']

  # step 1: get access token
  params = {
      'corpid' => client.id,
      'corpsecret' => client.secret,
  }.merge(token_params.to_hash(symbolize_keys: true))
  client.get_token(params, deep_symbolize(options.auth_token_params.merge({code: code})))
end