Class: Proxy::ContainerGateway::Api::AuthorizationHeader
- Inherits:
-
Object
- Object
- Proxy::ContainerGateway::Api::AuthorizationHeader
- 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
- #basic_auth? ⇒ Boolean
- #blank? ⇒ Boolean
-
#initialize(value) ⇒ AuthorizationHeader
constructor
A new instance of AuthorizationHeader.
- #present? ⇒ Boolean
- #raw_header ⇒ Object
- #token_auth? ⇒ Boolean
- #unauthorized_token? ⇒ Boolean
- #user ⇒ Object
-
#v1_foreman_authorized_username ⇒ Object
A special case for the V1 API.
- #valid_user_token? ⇒ Boolean
Methods included from DependencyInjection
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
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
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
260 261 262 |
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 260 def present? !@value.nil? && @value != "" end |
#raw_header ⇒ Object
256 257 258 |
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 256 def raw_header @value end |
#token_auth? ⇒ 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
264 265 266 |
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 264 def @value.split(' ')[1] == UNAUTHORIZED_TOKEN end |
#user ⇒ Object
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_username ⇒ Object
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 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
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 |