mirror of
https://github.com/internetee/registry.git
synced 2025-06-11 07:04:47 +02:00
41 lines
1 KiB
Ruby
41 lines
1 KiB
Ruby
require 'rails5_api_controller_backport'
|
|
require 'auth_token/auth_token_decryptor'
|
|
|
|
module Api
|
|
module V1
|
|
module Registrant
|
|
class DomainsController < ActionController::API
|
|
before_filter :authenticate
|
|
|
|
def index
|
|
registrant = ::Registrant.find_by(ident: current_user.registrant_ident)
|
|
unless registrant
|
|
render json: Domain.all
|
|
else
|
|
domains = Domain.where(registrant_id: registrant.id)
|
|
render json: domains
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def bearer_token
|
|
pattern = /^Bearer /
|
|
header = request.headers['Authorization']
|
|
header.gsub(pattern, '') if header && header.match(pattern)
|
|
end
|
|
|
|
def authenticate
|
|
decryptor = AuthTokenDecryptor.create_with_defaults(bearer_token)
|
|
decryptor.decrypt_token
|
|
|
|
if decryptor.valid?
|
|
sign_in decryptor.user
|
|
else
|
|
render json: { error: "Not authorized" }, status: 403
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|