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.



324
325
326
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 324

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

Instance Method Details

#basic_auth?Boolean

Returns:

  • (Boolean)


352
353
354
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 352

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

#blank?Boolean

Returns:

  • (Boolean)


356
357
358
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 356

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

#present?Boolean

Returns:

  • (Boolean)


340
341
342
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 340

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

#raw_headerObject



336
337
338
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 336

def raw_header
  @value
end

#token_auth?Boolean

Returns:

  • (Boolean)


348
349
350
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 348

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

#unauthorized_token?Boolean

Returns:

  • (Boolean)


344
345
346
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 344

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

#userObject



328
329
330
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 328

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.



361
362
363
364
365
366
367
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 361

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)


332
333
334
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 332

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