forked from tcannonfodder/oauth2-client-tester
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.rb
43 lines (31 loc) · 1.41 KB
/
app.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
require 'rubygems'; require 'bundler'; Bundler.require
require 'debug'
require 'faraday'
require_relative 'config'
get '/' do
erb :index
end
get '/step1' do
@client = OAuth2::Client.new(ENV.fetch("CLIENT_ID"), ENV.fetch("CLIENT_SECRET"), site: ENV.fetch("PROVIDER_SITE"), authorize_url: ENV.fetch("AUTHORIZE_URL"), token_url: ENV.fetch("TOKEN_URL"), auth_scheme: :request_body)
redirect @client.auth_code.authorize_url(
redirect_uri: ENV.fetch("REDIRECT_URI"),
state: "test1234"
)
end
get '/step2' do
@code = params[:code]
@state = params[:state]
# Used when you need to look at the details of the response for debugging
# conn = Faraday.new(:url => PROVIDER_SITE) do |faraday|
# faraday.request :url_encoded # form-encode POST params
# faraday.response :logger # log requests to STDOUT
# faraday.adapter Faraday.default_adapter # make requests with Net::HTTP
# end
# response = conn.post TOKEN_URL, { :code => @code, :client_id => CLIENT_ID, :client_secret => CLIENT_SECRET}
# debugger
# Rack::Utils.parse_query(response.body)
@client = OAuth2::Client.new(ENV.fetch("CLIENT_ID"), ENV.fetch("CLIENT_SECRET"), site: ENV.fetch("PROVIDER_SITE"), authorize_url: ENV.fetch("AUTHORIZE_URL"), token_url: ENV.fetch("TOKEN_URL"), auth_scheme: :request_body)
@token = @client.auth_code.get_token(@code, redirect_uri: ENV.fetch("REDIRECT_URI"))
logger.info @token.to_hash
erb :step2
end