2e0c1a4320
This reverts commit 698690effd
.
142 lines
3.5 KiB
Ruby
142 lines
3.5 KiB
Ruby
class SynapsesController < ApplicationController
|
|
include ItemsHelper
|
|
|
|
before_filter :require_user, only: [:new, :create, :edit, :update]
|
|
|
|
respond_to :html, :js, :json
|
|
|
|
# GET users/:user_id/synapses
|
|
def index
|
|
@user = User.find(params[:user_id])
|
|
|
|
@current = current_user
|
|
@synapses = Synapse.visibleToUser(@current, @user)
|
|
@synapsesjson = synapses_as_json(@current, @synapses).html_safe
|
|
|
|
respond_to do |format|
|
|
format.html
|
|
format.json { respond_with(@synapsesjson) }
|
|
end
|
|
end
|
|
|
|
# Get users/:user_id/synapses/new
|
|
def new
|
|
@synapse = Synapse.new
|
|
@user = current_user
|
|
|
|
respond_with(@synapse)
|
|
end
|
|
|
|
# GET users/:user_id/synapses/:id
|
|
def show
|
|
@user = User.find(params[:user_id])
|
|
|
|
@current = current_user
|
|
@synapse = @user.synapses.find(params[:id]).authorize_to_show(@current)
|
|
@item1 = @synapse.item1.authorize_to_show(@current)
|
|
@item2 = @synapse.item2.authorize_to_show(@current)
|
|
|
|
if @synapse && @item1 && @item2
|
|
@synapsejson = @synapse.selfplusnodes_as_json.html_safe
|
|
else
|
|
redirect_to root_url and return
|
|
end
|
|
|
|
respond_to do |format|
|
|
format.html
|
|
format.json { respond_with(@synapsejson) }
|
|
end
|
|
end
|
|
|
|
# POST users/:user_id/synapses
|
|
def create
|
|
|
|
@user = current_user
|
|
@synapse = Synapse.new()
|
|
@synapse.desc = params[:synapse][:desc]
|
|
@synapse.category = params[:synapse][:category]
|
|
@synapse.item1 = Item.find(params[:node1_id])
|
|
@synapse.item2 = Item.find(params[:node2_id])
|
|
@synapse.permission = params[:synapse][:permission]
|
|
@synapse.user = @user
|
|
@synapse.save
|
|
|
|
if params[:synapse][:map]
|
|
@mapping = Mapping.new()
|
|
@mapping.category = "Synapse"
|
|
@mapping.user = @user
|
|
@mapping.map = Map.find(params[:synapse][:map])
|
|
@mapping.synapse = @synapse
|
|
@mapping.save
|
|
|
|
if not Map.find(params[:synapse][:map]).items.include?(@synapse.item1)
|
|
@mapping1 = Mapping.new()
|
|
@mapping1.category = "Item"
|
|
@mapping1.user = @user
|
|
@mapping1.map = Map.find(params[:synapse][:map])
|
|
@mapping1.item = @synapse.item1
|
|
@mapping1.save
|
|
end
|
|
if not Map.find(params[:synapse][:map]).items.include?(@synapse.item2)
|
|
@mapping2 = Mapping.new()
|
|
@mapping2.category = "Item"
|
|
@mapping2.user = @user
|
|
@mapping2.map = Map.find(params[:synapse][:map])
|
|
@mapping2.item = @synapse.item2
|
|
@mapping2.save
|
|
end
|
|
end
|
|
|
|
respond_to do |format|
|
|
format.html { respond_with(@user, location: user_synapse_url(@user, @synapse)) }
|
|
format.js { respond_with(@synapse) }
|
|
end
|
|
|
|
end
|
|
|
|
# GET users/:user_id/synapses/:id/edit
|
|
def edit
|
|
@user = User.find(params[:user_id])
|
|
|
|
@current = current_user
|
|
@synapse = @user.synapses.find(params[:id]).authorize_to_edit(@current)
|
|
|
|
if @synapse
|
|
@items = Item.visibleToUser(@current, nil)
|
|
elsif not @synapse
|
|
redirect_to root_url and return
|
|
end
|
|
|
|
respond_with(@synapse, @items)
|
|
end
|
|
|
|
# PUT users/:user_id/synapses/:id
|
|
def update
|
|
@user = User.find(params[:user_id])
|
|
|
|
@synapse = @user.synapses.find(params[:id])
|
|
|
|
if @synapse
|
|
@synapse.desc = params[:synapse][:desc]
|
|
@synapse.category = params[:synapse][:category]
|
|
@synapse.item1 = Item.find(params[:node1_id][:node1])
|
|
@synapse.item2 = Item.find(params[:node2_id][:node2])
|
|
@synapse.permission = params[:synapse][:permission]
|
|
@synapse.save
|
|
end
|
|
|
|
respond_with(@user, location: user_synapse_url(@user, @synapse)) do |format|
|
|
end
|
|
|
|
end
|
|
|
|
# DELETE users/:user_id/synapses/:id
|
|
def destroy
|
|
@user = User.find(params[:user_id])
|
|
|
|
@synapse = @user.synapses.find(params[:id])
|
|
|
|
@synapse.delete
|
|
end
|
|
|
|
end
|