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 apply(a_hash, opts = {})

Returns a clone of a_hash updated with the authentication token
def apply(a_hash, opts = {})
  a_copy = a_hash.clone
  apply!(a_copy, opts)
  a_copy
end

def apply!(a_hash, opts = {})

Updates a_hash updated with the authentication token
def apply!(a_hash, opts = {})
  # fetch the access token there is currently not one, or if the client
  # has expired
  fetch_access_token!(opts) if access_token.nil? || expires_within?(60)
  a_hash[AUTH_METADATA_KEY] = "Bearer #{access_token}"
end

def fetch_access_token!(options = {})

def fetch_access_token!(options = {})
  info = orig_fetch_access_token!(options)
  notify_refresh_listeners
  info
end

def notify_refresh_listeners

def notify_refresh_listeners
  listeners = @refresh_listeners || []
  listeners.each do |block|
    block.call(self)
  end
end

def on_refresh(&block)

def on_refresh(&block)
  @refresh_listeners ||= []
  @refresh_listeners << block
end

def retry_with_error(max_retry_count = 5)

def retry_with_error(max_retry_count = 5)
  retry_count = 0
  begin
    yield
  rescue => e
    if e.is_a?(Signet::AuthorizationError) || e.is_a?(Signet::ParseError)
      raise e
    end
    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 updater_proc

a closure
Returns a reference to the #apply method, suitable for passing as
def updater_proc
  lambda(&method(:apply))
end