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.



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

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

Instance Method Details

#basic_auth?Boolean

Returns:

  • (Boolean)


272
273
274
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 272

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

#blank?Boolean

Returns:

  • (Boolean)


276
277
278
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 276

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

#present?Boolean

Returns:

  • (Boolean)


260
261
262
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 260

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

#raw_headerObject



256
257
258
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 256

def raw_header
  @value
end

#token_auth?Boolean

Returns:

  • (Boolean)


268
269
270
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 268

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

#unauthorized_token?Boolean

Returns:

  • (Boolean)


264
265
266
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 264

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

#userObject



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

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.



281
282
283
284
285
286
287
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 281

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)


252
253
254
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 252

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