class Api::V1::Accounts::MacrosController < Api::V1::Accounts::BaseController include AttachmentConcern before_action :fetch_macro, only: [:show, :update, :destroy, :execute] before_action :check_authorization, only: [:show, :update, :destroy, :execute] def index @macros = Macro.with_visibility(current_user, params) end def show head :not_found if @macro.nil? end def create blobs, actions, error = validate_and_prepare_attachments(params[:actions]) return render_could_not_create_error(error) if error @macro = Current.account.macros.new(macros_with_user.merge(created_by_id: current_user.id)) @macro.set_visibility(current_user, permitted_params) @macro.actions = actions return render_could_not_create_error(@macro.errors.messages) unless @macro.valid? @macro.save! blobs.each { |blob| @macro.files.attach(blob) } end def update blobs, actions, error = validate_and_prepare_attachments(params[:actions], @macro) return render_could_not_create_error(error) if error ActiveRecord::Base.transaction do @macro.assign_attributes(macros_with_user) @macro.set_visibility(current_user, permitted_params) @macro.actions = actions if params[:actions] @macro.save! blobs.each { |blob| @macro.files.attach(blob) } rescue StandardError => e Rails.logger.error e render_could_not_create_error(@macro.errors.messages) end end def destroy @macro.destroy! head :ok end def execute ::MacrosExecutionJob.perform_later(@macro, conversation_ids: params[:conversation_ids], user: Current.user) head :ok end private def permitted_params params.permit( :name, :visibility, actions: [:action_name, { action_params: [] }] ) end def macros_with_user permitted_params.merge(updated_by_id: current_user.id) end def fetch_macro @macro = Current.account.macros.find_by(id: params[:id]) end def check_authorization authorize(@macro) if @macro.present? end end