Class: OpenC3::OpenC3KeycloakAuthentication

Inherits:
OpenC3Authentication show all
Defined in:
lib/openc3/utilities/authentication.rb

Overview

OpenC3 enterprise Keycloak authentication code

Constant Summary collapse

REFRESH_OFFSET_SECONDS =

"access_token": "",
"expires_in": 600,
"refresh_expires_in": 1800,
"refresh_token": "",
"token_type": "bearer",
"id_token": "",
"not-before-policy": 0,
"session_state": "",
"scope": "openid email profile"

60

Instance Method Summary collapse

Constructor Details

#initialize(url) ⇒ OpenC3KeycloakAuthentication

Returns a new instance of OpenC3KeycloakAuthentication.

Parameters:

  • url (String)

    The url of the openc3 or keycloak in the cluster



61
62
63
64
65
66
67
68
69
# File 'lib/openc3/utilities/authentication.rb', line 61

def initialize(url)
  @url = url
  @auth_mutex = Mutex.new
  @refresh_token = nil
  @expires_at = nil
  @refresh_expires_at = nil
  @token = nil
  @log = [nil, nil]
end

Instance Method Details

#tokenObject

Load the token from the environment



72
73
74
75
76
77
78
79
80
81
82
83
84
85
# File 'lib/openc3/utilities/authentication.rb', line 72

def token()
  @auth_mutex.synchronize do
    @log = [nil, nil]
    current_time = Time.now.to_i
    if @token.nil?
      _make_token(current_time)
    elsif @refresh_expires_at < current_time
      _make_token(current_time)
    elsif @expires_at < current_time
      _refresh_token(current_time)
    end
  end
  "Bearer #{@token}"
end