48373628a1
Macros policy update. ref: #5730
89 lines
2.3 KiB
Ruby
89 lines
2.3 KiB
Ruby
class Api::V1::Accounts::MacrosController < Api::V1::Accounts::BaseController
|
|
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 create
|
|
@macro = Current.account.macros.new(macros_with_user.merge(created_by_id: current_user.id))
|
|
@macro.set_visibility(current_user, permitted_params)
|
|
@macro.actions = params[:actions]
|
|
|
|
render json: { error: @macro.errors.messages }, status: :unprocessable_entity and return unless @macro.valid?
|
|
|
|
@macro.save!
|
|
process_attachments
|
|
@macro
|
|
end
|
|
|
|
def show
|
|
head :not_found if @macro.nil?
|
|
end
|
|
|
|
def destroy
|
|
@macro.destroy!
|
|
head :ok
|
|
end
|
|
|
|
def attach_file
|
|
file_blob = ActiveStorage::Blob.create_and_upload!(
|
|
key: nil,
|
|
io: params[:attachment].tempfile,
|
|
filename: params[:attachment].original_filename,
|
|
content_type: params[:attachment].content_type
|
|
)
|
|
render json: { blob_key: file_blob.key, blob_id: file_blob.id }
|
|
end
|
|
|
|
def update
|
|
ActiveRecord::Base.transaction do
|
|
@macro.update!(macros_with_user)
|
|
@macro.set_visibility(current_user, permitted_params)
|
|
process_attachments
|
|
@macro.save!
|
|
rescue StandardError => e
|
|
Rails.logger.error e
|
|
render json: { error: @macro.errors.messages }.to_json, status: :unprocessable_entity
|
|
end
|
|
end
|
|
|
|
def execute
|
|
::MacrosExecutionJob.perform_later(@macro, conversation_ids: params[:conversation_ids], user: Current.user)
|
|
|
|
head :ok
|
|
end
|
|
|
|
private
|
|
|
|
def process_attachments
|
|
actions = @macro.actions.filter_map { |k, _v| k if k['action_name'] == 'send_attachment' }
|
|
return if actions.blank?
|
|
|
|
actions.each do |action|
|
|
blob_id = action['action_params']
|
|
blob = ActiveStorage::Blob.find_by(id: blob_id)
|
|
@macro.files.attach(blob)
|
|
end
|
|
end
|
|
|
|
def permitted_params
|
|
params.permit(
|
|
:name, :account_id, :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
|