2013-03-01 01:16:04 +00:00
|
|
|
class MappingsController < ApplicationController
|
2016-07-26 00:14:23 +00:00
|
|
|
before_action :require_user, only: [:create, :update, :destroy]
|
2016-03-11 14:10:31 +00:00
|
|
|
after_action :verify_authorized, except: :index
|
|
|
|
after_action :verify_policy_scoped, only: :index
|
2016-07-26 00:14:23 +00:00
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
respond_to :json
|
2016-07-26 00:14:23 +00:00
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
# GET /mappings/1.json
|
|
|
|
def show
|
|
|
|
@mapping = Mapping.find(params[:id])
|
2016-03-12 00:16:46 +00:00
|
|
|
authorize @mapping
|
2013-03-01 00:56:27 +00:00
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
render json: @mapping
|
2013-03-01 00:56:27 +00:00
|
|
|
end
|
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
# POST /mappings.json
|
2013-03-01 00:56:27 +00:00
|
|
|
def create
|
2015-09-19 12:01:44 +00:00
|
|
|
@mapping = Mapping.new(mapping_params)
|
2016-03-12 00:16:46 +00:00
|
|
|
authorize @mapping
|
|
|
|
@mapping.user = current_user
|
2013-03-01 01:56:57 +00:00
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
if @mapping.save
|
|
|
|
render json: @mapping, status: :created
|
2016-03-12 23:36:38 +00:00
|
|
|
Events::NewMapping.publish!(@mapping, current_user)
|
2014-07-27 19:57:35 +00:00
|
|
|
else
|
|
|
|
render json: @mapping.errors, status: :unprocessable_entity
|
2013-03-01 00:56:27 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
# PUT /mappings/1.json
|
2013-03-01 00:56:27 +00:00
|
|
|
def update
|
2014-07-27 19:57:35 +00:00
|
|
|
@mapping = Mapping.find(params[:id])
|
2016-03-12 00:16:46 +00:00
|
|
|
authorize @mapping
|
2014-07-27 19:57:35 +00:00
|
|
|
|
2015-09-19 12:01:44 +00:00
|
|
|
if @mapping.update_attributes(mapping_params)
|
2014-07-27 19:57:35 +00:00
|
|
|
head :no_content
|
|
|
|
else
|
|
|
|
render json: @mapping.errors, status: :unprocessable_entity
|
|
|
|
end
|
2013-03-01 00:56:27 +00:00
|
|
|
end
|
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
# DELETE /mappings/1.json
|
2013-03-01 00:56:27 +00:00
|
|
|
def destroy
|
2014-07-27 19:57:35 +00:00
|
|
|
@mapping = Mapping.find(params[:id])
|
2016-03-12 00:16:46 +00:00
|
|
|
authorize @mapping
|
2014-10-07 23:11:55 +00:00
|
|
|
|
2016-04-24 15:50:35 +00:00
|
|
|
mappable = @mapping.mappable
|
|
|
|
if mappable.defer_to_map
|
|
|
|
mappable.permission = mappable.defer_to_map.permission
|
|
|
|
mappable.defer_to_map_id = nil
|
|
|
|
mappable.save
|
|
|
|
end
|
|
|
|
|
2014-07-27 19:57:35 +00:00
|
|
|
@mapping.destroy
|
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
head :no_content
|
2013-03-01 00:56:27 +00:00
|
|
|
end
|
2015-09-19 08:26:34 +00:00
|
|
|
|
|
|
|
private
|
2016-07-26 00:14:23 +00:00
|
|
|
|
|
|
|
# Never trust parameters from the scary internet, only allow the white list through.
|
|
|
|
def mapping_params
|
|
|
|
params.require(:mapping).permit(:id, :xloc, :yloc, :mappable_id, :mappable_type, :map_id)
|
|
|
|
end
|
2014-10-07 23:11:55 +00:00
|
|
|
end
|