class Profiles::GpgKeysController < Profiles::ApplicationController before_action :set_gpg_key, only: [:destroy, :revoke] def index @gpg_keys = current_user.gpg_keys @gpg_key = GpgKey.new end def create @gpg_key = GpgKeys::CreateService.new(current_user, gpg_key_params).execute if @gpg_key.persisted? redirect_to profile_gpg_keys_path else @gpg_keys = current_user.gpg_keys.select(&:persisted?) render :index end end def destroy @gpg_key.destroy respond_to do |format| format.html { redirect_to profile_gpg_keys_url, status: 302 } format.js { head :ok } end end def revoke @gpg_key.revoke respond_to do |format| format.html { redirect_to profile_gpg_keys_url, status: 302 } format.js { head :ok } end end private def gpg_key_params params.require(:gpg_key).permit(:key) end def set_gpg_key @gpg_key = current_user.gpg_keys.find(params[:id]) end end