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.
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
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
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
232 233 234 |
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 232 def present? !@value.nil? && @value != "" end |
#raw_header ⇒ Object
228 229 230 |
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 228 def raw_header @value end |
#token_auth? ⇒ 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
236 237 238 |
# File 'lib/smart_proxy_container_gateway/container_gateway_api.rb', line 236 def @value.split(' ')[1] == UNAUTHORIZED_TOKEN end |
#user ⇒ Object
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_username ⇒ Object
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 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
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 |