mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2024-11-18 23:21:30 +08:00
52 lines
1.3 KiB
Ruby
52 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Api
|
|
class ApiController < ActionController::API
|
|
include TokenAuthentication
|
|
|
|
attr_reader :current_user
|
|
|
|
before_action :authenticate_request!, except: %i(status health)
|
|
|
|
rescue_from StandardError do |e|
|
|
logger.error e.message
|
|
logger.error e.backtrace.join("\n")
|
|
render json: {}, status: :bad_request
|
|
end
|
|
|
|
rescue_from JWT::DecodeError,
|
|
JWT::InvalidPayload,
|
|
JWT::VerificationError do |e|
|
|
logger.error e.message
|
|
render json: { message: I18n.t('api.core.invalid_token') },
|
|
status: :unauthorized
|
|
end
|
|
|
|
rescue_from JWT::ExpiredSignature do |e|
|
|
logger.error e.message
|
|
render json: { message: I18n.t('api.core.expired_token') },
|
|
status: :unauthorized
|
|
end
|
|
|
|
def initialize
|
|
super
|
|
@iss = nil
|
|
end
|
|
|
|
def health
|
|
User.new && Team.new && Project.new
|
|
User.first if params[:db]
|
|
render plain: 'RUNNING'
|
|
end
|
|
|
|
def status
|
|
response = {}
|
|
response[:message] = I18n.t('api.core.status_ok')
|
|
response[:versions] = []
|
|
Extends::API_VERSIONS.each do |ver|
|
|
response[:versions] << { version: ver, baseUrl: "/api/#{ver}/" }
|
|
end
|
|
render json: response, status: :ok
|
|
end
|
|
end
|
|
end
|