44 lines
966 B
Ruby
44 lines
966 B
Ruby
class APIController < ApplicationController
|
|
before_action :authenticate_user
|
|
before_action :default_format_json
|
|
|
|
resource_description do
|
|
description <<-EOS
|
|
L'authentification de l'API se fait via un header HTTP :
|
|
|
|
```
|
|
Authorization: Bearer <Token administrateur>
|
|
```
|
|
EOS
|
|
end
|
|
|
|
def authenticate_user
|
|
if !valid_token?
|
|
request_http_token_authentication
|
|
end
|
|
end
|
|
|
|
protected
|
|
|
|
def valid_token?
|
|
current_administrateur.present?
|
|
end
|
|
|
|
def current_administrateur
|
|
@administrateur ||= (authenticate_with_bearer_token || authenticate_with_param_token)
|
|
end
|
|
|
|
def authenticate_with_bearer_token
|
|
authenticate_with_http_token do |token, options|
|
|
Administrateur.find_by(api_token: token)
|
|
end
|
|
end
|
|
|
|
def authenticate_with_param_token
|
|
Administrateur.find_by(api_token: params[:token])
|
|
end
|
|
|
|
def default_format_json
|
|
request.format = "json" if !request.params[:format]
|
|
end
|
|
end
|