class Signet::OAuth2::Client
hash with the fetched authentication token.
This reopens Client to add #apply and #apply! methods which update a
Signet::OAuth2::Client creates an OAuth2 client
def build_default_connection
def build_default_connection if !defined?(@connection_info) nil elsif @connection_info.respond_to? :call @connection_info.call else @connection_info end end
def configure_connection options
def configure_connection options @connection_info = options[:connection_builder] || options[:default_connection] self end
def fetch_access_token! options = {}
def fetch_access_token! options = {} unless options[:connection] connection = build_default_connection options = options.merge connection: connection if connection end info = retry_with_error do orig_fetch_access_token! options end notify_refresh_listeners info end
def retry_with_error max_retry_count = 5
def retry_with_error max_retry_count = 5 retry_count = 0 begin yield rescue StandardError => e raise e if e.is_a?(Signet::AuthorizationError) || e.is_a?(Signet::ParseError) if retry_count < max_retry_count retry_count += 1 sleep retry_count * 0.3 retry else msg = "Unexpected error: #{e.inspect}" raise Signet::AuthorizationError, msg end end end
def token_type
def token_type target_audience ? :id_token : :access_token end