package webapp; use Dancer2; use Op; use Op1; use URI; use Net::OAuth2::Client; use HTML::Entities; our $VERSION = '0.1'; sub client { Net::OAuth2::Profile::WebServer->new( client_id => 'xxxxxxxxxxxxxxxxxx', client_secret => 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', authorize_url => 'https://dev.oktapreview.com/oauth2/v1/authorize', access_token_url => 'https://dev.oktapreview.com/oauth2/v1/token', response_type => 'code', redirect_uri => uri_for ("/"), grant_type => 'authorization_code', scope => 'openid', state => '1234', ); } get '/:site_id' => sub { my $id = route_parameters->get('site_id'); print "$id" . "\n"; redirect client(params->{$id})->authorize; my $code = params->{code}; print "$code" . "\n"; }; get '/got/:site_id' => sub { defined params->{code} or return html_page("Error: Missing access code"); my $id = route_parameters->get('site_id'); my $site_id = params->{$id}; my $site_id = params->{$id}; my $access_token = client($site_id)->get_access_token(params->{code}); return html_page("Error: " . $access_token->to_string) if $access_token->{error}; my $content = "
'.encode_entities($access_token->to_string)."
\n"; $content .= "'.encode_entities($response->decoded_content).'
'; } else { $content .= 'Error: '. $response->status_line."
\n"; } $content =~ s[\n][