mirror of
https://github.com/internetee/registry.git
synced 2025-07-30 06:26:15 +02:00
Added endpoints for creating and downloading api user certificates
This commit is contained in:
parent
b558c80e83
commit
47b6a1b87a
18 changed files with 377 additions and 102 deletions
|
@ -1,29 +1,52 @@
|
|||
require 'serializers/repp/certificate'
|
||||
module Repp
|
||||
module V1
|
||||
class CertificatesController < BaseController
|
||||
THROTTLED_ACTIONS = %i[create].freeze
|
||||
before_action :find_certificate, only: %i[show download]
|
||||
load_and_authorize_resource param_method: :cert_params
|
||||
|
||||
THROTTLED_ACTIONS = %i[show create download].freeze
|
||||
include Shunter::Integration::Throttle
|
||||
|
||||
api :GET, '/repp/v1/api_users/:api_user_id/certificates/:id'
|
||||
desc "Get a specific api user's specific certificate data"
|
||||
def show
|
||||
serializer = Serializers::Repp::Certificate.new(@certificate)
|
||||
render_success(data: { cert: serializer.to_json })
|
||||
end
|
||||
|
||||
api :POST, '/repp/v1/certificates'
|
||||
desc 'Submit a new api user certificate signing request'
|
||||
def create
|
||||
authorize! :create, Certificate
|
||||
@api_user = current_user.registrar.api_users.find(cert_params[:api_user_id])
|
||||
|
||||
csr = decode_cert_params(cert_params[:csr])
|
||||
|
||||
@certificate = @api_user.certificates.build(csr: csr)
|
||||
unless @certificate.save
|
||||
handle_non_epp_errors(@certificate)
|
||||
return
|
||||
end
|
||||
|
||||
notify_admins
|
||||
render_success(data: { api_user: { id: @api_user.id } })
|
||||
if @certificate.save
|
||||
notify_admins
|
||||
render_success(data: { api_user: { id: @api_user.id } })
|
||||
else
|
||||
handle_non_epp_errors(@certificate)
|
||||
end
|
||||
end
|
||||
|
||||
api :get, '/repp/v1/api_users/:api_user_id/certificates/:id/download'
|
||||
desc "Download a specific api user's specific certificate"
|
||||
param :type, String, required: true, desc: 'Type of certificate (csr or crt)'
|
||||
def download
|
||||
filename = "#{@api_user.username}_#{Time.zone.today.strftime('%y%m%d')}_portal.#{params[:type]}.pem"
|
||||
send_data @certificate[params[:type].to_s], filename: filename
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def find_certificate
|
||||
@api_user = current_user.registrar.api_users.find(params[:api_user_id])
|
||||
@certificate = @api_user.certificates.find(params[:id])
|
||||
end
|
||||
|
||||
def cert_params
|
||||
params.require(:certificate).permit(:api_user_id, csr: %i[body type])
|
||||
end
|
||||
|
@ -40,9 +63,9 @@ module Repp
|
|||
return if admin_users_emails.empty?
|
||||
|
||||
admin_users_emails.each do |email|
|
||||
CertificateMailer.new_certificate_signing_request(email: email,
|
||||
api_user: @api_user,
|
||||
csr: @certificate)
|
||||
CertificateMailer.certificate_signing_requested(email: email,
|
||||
api_user: @api_user,
|
||||
csr: @certificate)
|
||||
.deliver_now
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue