trabajo-afectivo/app/controllers/settings_controller.rb

99 lines
2.2 KiB
Ruby
Raw Normal View History

2014-02-03 19:24:49 +00:00
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
2012-04-10 14:06:46 +00:00
class SettingsController < ApplicationController
before_action :authentication_check
2012-04-10 14:06:46 +00:00
# GET /settings
def index
deny_if_not_role(Z_ROLENAME_ADMIN)
model_index_render(Setting, params)
2012-04-10 14:06:46 +00:00
end
# GET /settings/1
def show
deny_if_not_role(Z_ROLENAME_ADMIN)
model_show_render(Setting, params)
2012-04-10 14:06:46 +00:00
end
# POST /settings
def create
deny_if_not_role(Z_ROLENAME_ADMIN)
model_create_render(Setting, params)
2012-04-10 14:06:46 +00:00
end
# PUT /settings/1
def update
deny_if_not_role(Z_ROLENAME_ADMIN)
check_access
model_update_render(Setting, params)
2012-04-10 14:06:46 +00:00
end
2015-07-12 01:32:40 +00:00
# PUT /settings/image/:id
def update_image
deny_if_not_role(Z_ROLENAME_ADMIN)
2015-07-12 01:32:40 +00:00
if !params[:logo]
render json: {
result: 'invalid',
message: 'Need logo param',
}
return
end
# validate image
if params[:logo] !~ /^data:image/i
render json: {
result: 'invalid',
message: 'Invalid payload, need data:image in logo param',
}
return
end
# process image
file = StaticAssets.data_url_attributes(params[:logo])
if !file[:content] || !file[:mime_type]
render json: {
result: 'invalid',
message: 'Unable to process image upload.',
}
return
end
# store image 1:1
StaticAssets.store_raw(file[:content], file[:mime_type])
# store resized image 1:1
setting = Setting.find_by(name: 'product_logo')
if params[:logo_resize] && params[:logo_resize] =~ /^data:image/i
# data:image/png;base64
file = StaticAssets.data_url_attributes(params[:logo_resize])
2015-07-12 01:32:40 +00:00
# store image 1:1
setting.state = StaticAssets.store(file[:content], file[:mime_type])
2015-07-12 01:32:40 +00:00
setting.save
end
render json: {
result: 'ok',
settings: [setting],
}
end
2012-04-10 14:06:46 +00:00
# DELETE /settings/1
def destroy
deny_if_not_role(Z_ROLENAME_ADMIN)
check_access
model_destory_render(Setting, params)
2012-04-10 14:06:46 +00:00
end
private
def check_access
return true if !Setting.get('system_online_service')
setting = Setting.find(params[:id])
return true if setting.preferences && !setting.preferences[:online_service_disable]
raise Exceptions::NotAuthorized
end
2012-04-10 14:06:46 +00:00
end