Sha256: ec563058378904b458bfde26133b37230593cf084e50771ff330fa7eef431127
Contents?: true
Size: 1.77 KB
Versions: 1
Compression:
Stored size: 1.77 KB
Contents
# frozen_string_literal: true require "rodauth/oauth" module Rodauth Feature.define(:oauth_implicit_grant, :OauthImplicitGrant) do depends :oauth_authorize_base def oauth_grant_types_supported super | %w[implicit] end def oauth_response_types_supported super | %w[token] end def oauth_response_modes_supported super | %w[fragment] end private def do_authorize(response_params = {}, response_mode = param_or_nil("response_mode")) response_type = param("response_type") return super unless response_type == "token" && supported_response_type?(response_type) response_mode ||= "fragment" redirect_response_error("invalid_request") unless supported_response_mode?(response_mode) response_params.replace(_do_authorize_token) response_params["state"] = param("state") if param_or_nil("state") [response_params, response_mode] end def _do_authorize_token grant_params = { oauth_grants_type_column => "implicit", oauth_grants_oauth_application_id_column => oauth_application[oauth_applications_id_column], oauth_grants_scopes_column => scopes, oauth_grants_account_id_column => account_id } oauth_grant = generate_token(grant_params, false) json_access_token_payload(oauth_grant) end def authorize_response(params, mode) return super unless mode == "fragment" redirect_url = URI.parse(redirect_uri) params = params.map { |k, v| "#{k}=#{v}" } params << redirect_url.query if redirect_url.query redirect_url.fragment = params.join("&") redirect(redirect_url.to_s) end def check_valid_response_type? return true if param_or_nil("response_type") == "token" super end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rodauth-oauth-1.0.0.pre.beta1 | lib/rodauth/features/oauth_implicit_grant.rb |