140 lines
3.4 KiB
Ruby
140 lines
3.4 KiB
Ruby
class SynapsesController < ApplicationController
|
|
include TopicsHelper
|
|
|
|
before_filter :require_user, only: [:new, :create, :edit, :update]
|
|
|
|
respond_to :html, :js, :json
|
|
|
|
autocomplete :synapse, :desc, :full => true
|
|
|
|
# GET synapses
|
|
# or GET users/:user_id/synapses
|
|
def index
|
|
@current = current_user
|
|
|
|
if params[:user_id]
|
|
@user = User.find(params[:user_id])
|
|
@synapses = Synapse.visibleToUser(@current, @user)
|
|
elsif
|
|
@synapses = Synapse.visibleToUser(@current, nil)
|
|
end
|
|
|
|
@synapsesjson = synapses_as_json(@current, @synapses).html_safe
|
|
|
|
respond_to do |format|
|
|
format.html
|
|
format.json { respond_with(@synapsesjson) }
|
|
end
|
|
end
|
|
|
|
# Get synapses/new
|
|
def new
|
|
@synapse = Synapse.new
|
|
@user = current_user
|
|
|
|
respond_with(@synapse)
|
|
end
|
|
|
|
# GET synapses/:id
|
|
def show
|
|
@current = current_user
|
|
@synapse = Synapse.find(params[:id]).authorize_to_show(@current)
|
|
@topic1 = @synapse.topic1.authorize_to_show(@current)
|
|
@topic2 = @synapse.topic2.authorize_to_show(@current)
|
|
|
|
if @synapse && @topic1 && @topic2
|
|
@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 synapses
|
|
def create
|
|
|
|
@user = current_user
|
|
@synapse = Synapse.new()
|
|
@synapse.desc = params[:synapse][:desc]
|
|
@synapse.topic1 = Topic.find(params[:synapse][:topic1id])
|
|
@synapse.topic2 = Topic.find(params[:synapse][:topic2id])
|
|
@synapse.permission = "commons"
|
|
@synapse.category = "from-to"
|
|
@synapse.weight = 5
|
|
@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
|
|
end
|
|
|
|
respond_to do |format|
|
|
format.html { respond_with(@user, location: synapse_url(@synapse)) }
|
|
format.js { respond_with(@synapse) }
|
|
end
|
|
|
|
end
|
|
|
|
# GET synapses/:id/edit
|
|
def edit
|
|
@current = current_user
|
|
@synapse = Synapse.find(params[:id]).authorize_to_edit(@current)
|
|
|
|
if @synapse
|
|
@topics = Topic.visibleToUser(@current, nil)
|
|
elsif not @synapse
|
|
redirect_to root_url and return
|
|
end
|
|
|
|
respond_with(@synapse, @topics)
|
|
end
|
|
|
|
# PUT synapses/:id
|
|
def update
|
|
@current = current_user
|
|
@synapse = Synapse.find(params[:id]).authorize_to_edit(@current)
|
|
|
|
if @synapse
|
|
@synapse.desc = params[:synapse][:desc]
|
|
@synapse.category = params[:synapse][:category]
|
|
@synapse.topic1 = Topic.find(params[:node1_id][:node1])
|
|
@synapse.topic2 = Topic.find(params[:node2_id][:node2])
|
|
@synapse.permission = params[:synapse][:permission]
|
|
@synapse.save
|
|
end
|
|
|
|
respond_with(@user, location: synapse_url(@synapse)) do |format|
|
|
end
|
|
end
|
|
|
|
# POST mappings/:map_id/:synapse_id/removefrommap
|
|
def removefrommap
|
|
@mapping = Mapping.find_by_synapse_id_and_map_id(params[:synapse_id],params[:map_id])
|
|
@mapping.delete
|
|
|
|
respond_to do |format|
|
|
format.js
|
|
end
|
|
end
|
|
|
|
# DELETE synapses/:id
|
|
def destroy
|
|
@current = current_user
|
|
@synapse = Synapse.find(params[:id]).authorize_to_edit(@current)
|
|
|
|
@synapse.mappings.each do |m|
|
|
m.delete
|
|
end
|
|
|
|
@synapse.delete if @synapse
|
|
end
|
|
end
|