Class: Proxy::ContainerGateway::Api::AuthorizationHeader

Inherits:
Object
  • Object
show all
Extended by:
DependencyInjection
Defined in:
lib/smart_proxy_container_gateway/container_gateway_api.rb

Constant Summary collapse

UNAUTHORIZED_TOKEN =
'unauthorized'.freeze

Instance Method Summary collapse

Methods included from DependencyInjection

container_instance

Constructor Details

#initialize(value) ⇒ AuthorizationHeader

Returns a new instance of AuthorizationHeader.



216
217
218
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 216

def initialize(value)
  @value = value || ''
end

Instance Method Details

#basic_auth?Boolean

Returns:

  • (Boolean)


244
245
246
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 244

def basic_auth?
  @value.split(' ')[0] == 'Basic'
end

#blank?Boolean

Returns:

  • (Boolean)


248
249
250
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 248

def blank?
  Base64.decode64(@value.split(' ')[1]) == ':'
end

#present?Boolean

Returns:

  • (Boolean)


232
233
234
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 232

def present?
  !@value.nil? && @value != ""
end

#raw_headerObject



228
229
230
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 228

def raw_header
  @value
end

#token_auth?Boolean

Returns:

  • (Boolean)


240
241
242
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 240

def token_auth?
  @value.split(' ')[0] == 'Bearer'
end

#unauthorized_token?Boolean

Returns:

  • (Boolean)


236
237
238
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 236

def unauthorized_token?
  @value.split(' ')[1] == UNAUTHORIZED_TOKEN
end

#userObject



220
221
222
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 220

def user
  container_gateway_main.token_user(@value.split(' ')[1])
end

#v1_foreman_authorized_usernameObject

A special case for the V1 API. Defer authentication to Foreman and return the username. ‘nil` if not authorized.



253
254
255
256
257
258
259
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 253

def v1_foreman_authorized_username
  username = Base64.decode64(@value.split(' ')[1]).split(':')[0]
  auth_response = ForemanApi.new.fetch_token(raw_header, { 'account' => username })
  return username if auth_response.code.to_i == 200 && (JSON.parse(auth_response.body)['token'] != 'unauthenticated')

  nil
end

#valid_user_token?Boolean

Returns:

  • (Boolean)


224
225
226
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 224

def valid_user_token?
  token_auth? && container_gateway_main.valid_token?(@value.split(' ')[1])
end