implemented a radical overhaul of permissions, so that it actually hides content that it's supposed to

This commit is contained in:
Connor Turland 2012-10-27 04:30:56 -04:00
parent 402786a7c6
commit 6b8a99eb01
12 changed files with 312 additions and 97 deletions

View file

@ -1,5 +1,5 @@
class ItemsController < ApplicationController class ItemsController < ApplicationController
before_filter :require_user, only: [:new, :create, :edit, :update] before_filter :require_user, only: [:new, :create, :edit, :update]
respond_to :html, :js, :json respond_to :html, :js, :json
@ -8,7 +8,8 @@ class ItemsController < ApplicationController
def index def index
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@items = @user.items @current = current_user
@items = Item.visibleToUser(@current, @user)
respond_with(@user,@items) respond_with(@user,@items)
end end
@ -25,9 +26,14 @@ class ItemsController < ApplicationController
def show def show
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@item = @user.items.find(params[:id]) @current = current_user
@item = @user.items.find(params[:id]).authorize_to_show(@current)
@relatives = @item.network_as_json.html_safe if @item
@relatives = @item.network_as_json(@current).html_safe
else
redirect_to root_url and return
end
respond_to do |format| respond_to do |format|
format.html { respond_with(@item, @user) } format.html { respond_with(@item, @user) }
@ -69,7 +75,12 @@ class ItemsController < ApplicationController
def edit def edit
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@item = @user.items.find(params[:id]) @current = current_user
@item = @user.items.find(params[:id]).authorize_to_edit(@current)
if not @item
redirect_to root_url and return
end
respond_with(@item) respond_with(@item)
end end

View file

@ -4,13 +4,10 @@ class MainController < ApplicationController
respond_to :html, :js, :json respond_to :html, :js, :json
def home def home
@current_user = current_user @current = current_user
@item = Item.all.first @item = Item.visibleToUser(@current, nil).first
@alljson = all_as_json(@current).html_safe
if @item
@alljson = @item.all_as_json.html_safe
end
respond_to do |format| respond_to do |format|
format.html { respond_with(@item) } format.html { respond_with(@item) }
@ -18,10 +15,9 @@ class MainController < ApplicationController
end end
end end
def allmaps def allmaps
@current_user = current_user @current = current_user
@maps = Map.visibleToUser(@current, nil)
@maps = Map.all
respond_to do |format| respond_to do |format|
format.html { respond_with(@maps) } format.html { respond_with(@maps) }

View file

@ -1,5 +1,5 @@
class MapsController < ApplicationController class MapsController < ApplicationController
before_filter :require_user, only: [:new, :create, :edit, :update] before_filter :require_user, only: [:new, :create, :edit, :update]
respond_to :html, :js, :json respond_to :html, :js, :json
@ -7,7 +7,9 @@ class MapsController < ApplicationController
# GET /users/:user_id/maps # GET /users/:user_id/maps
def index def index
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@maps = @user.maps
@current = current_user
@maps = Map.visibleToUser(@current, @user)
respond_with(@maps,@user) respond_with(@maps,@user)
end end
@ -24,9 +26,14 @@ class MapsController < ApplicationController
def show def show
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@map = @user.maps.find(params[:id]) @current = current_user
@map = @user.maps.find(params[:id]).authorize_to_show(@current)
@mapjson = @map.self_as_json.html_safe if not @map
redirect_to root_url and return
end
@mapjson = @map.self_as_json(@current).html_safe
respond_to do |format| respond_to do |format|
format.html { respond_with(@map, @user) } format.html { respond_with(@map, @user) }
@ -53,7 +60,12 @@ class MapsController < ApplicationController
def edit def edit
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@map = @user.maps.find(params[:id]) @current = current_user
@map = @user.maps.find(params[:id]).authorize_to_edit(@current)
if not @map
redirect_to root_url and return
end
respond_with(@user, @map) respond_with(@user, @map)
end end

View file

@ -9,7 +9,9 @@ class SynapsesController < ApplicationController
def index def index
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@synapsesjson = usersynapses_as_json(@user).html_safe @current = current_user
@synapses = Synapse.visibleToUser(@current, @user)
@synapsesjson = synapses_as_json(@current, @synapses).html_safe
respond_to do |format| respond_to do |format|
format.html format.html
@ -29,10 +31,15 @@ class SynapsesController < ApplicationController
def show def show
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@synapse = @user.synapses.find(params[: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 if @synapse && @item1 && @item2
@synapsejson = @synapse.selfplusnodes_as_json.html_safe @synapsejson = @synapse.selfplusnodes_as_json.html_safe
else
redirect_to root_url and return
end end
respond_to do |format| respond_to do |format|
@ -91,12 +98,13 @@ class SynapsesController < ApplicationController
def edit def edit
@user = User.find(params[:user_id]) @user = User.find(params[:user_id])
@synapse = @user.synapses.find(params[:id]) @current = current_user
@synapse = @user.synapses.find(params[:id]).authorize_to_edit(@current)
@items = nil
if @synapse if @synapse
@items = Item.all @items = Item.visibleToUser(@current)
elsif not @synapse
redirect_to root_url and return
end end
respond_with(@synapse, @items) respond_with(@synapse, @items)

View file

@ -1,2 +1,2 @@
module ApplicationHelper module ApplicationHelper
end end

View file

@ -1,5 +1,5 @@
module ItemsHelper module ItemsHelper
#find all nodes in any given nodes network #find all nodes in any given nodes network
def network(node, array) def network(node, array)
# recurse starting with a node to find all connected nodes and return an array of items that constitutes the starting nodes network # recurse starting with a node to find all connected nodes and return an array of items that constitutes the starting nodes network
@ -29,18 +29,17 @@ module ItemsHelper
end end
#return a json object containing all of a users added synapses #return a json object containing all of a users added synapses
def usersynapses_as_json(user) def synapses_as_json(current, synapses)
Jbuilder.encode do |json| Jbuilder.encode do |json|
@synapses = user.synapses
@items = Array.new @items = Array.new
@synapses.each do |synapse| synapses.each do |synapse|
@items.push(synapse.item1) if not @items.include?(synapse.item1) @items.push(synapse.item1) if (not @items.include?(synapse.item1)) && synapse.item1.authorize_to_view(current)
@items.push(synapse.item2) if not @items.include?(synapse.item2) @items.push(synapse.item2) if (not @items.include?(synapse.item2)) && synapse.item2.authorize_to_view(current)
end end
json.array!(@items) do |item| json.array!(@items) do |item|
json.adjacencies item.synapses2.delete_if{|synapse| not synapse.user == user} do |json, synapse| json.adjacencies item.synapses2.delete_if{|synapse| not @items.include?(Item.find_by_id(synapse.node1_id))} do |json, synapse|
json.nodeTo synapse.node1_id json.nodeTo synapse.node1_id
json.nodeFrom synapse.node2_id json.nodeFrom synapse.node2_id
@ -62,6 +61,39 @@ module ItemsHelper
end end
end end
end end
def all_as_json(current)
Jbuilder.encode do |json|
@items = Item.visibleToUser(current, nil)
@synapses = Synapse.visibleToUser(current, nil)
json.array!(@items) do |item|
json.adjacencies item.synapses2.delete_if{|synapse| (not @items.include?(Item.find_by_id(synapse.node1_id))) || (not @synapses.include?(synapse))} do |json, synapse|
json.nodeTo synapse.node1_id
json.nodeFrom synapse.node2_id
@synapsedata = Hash.new
@synapsedata['$desc'] = synapse.desc
@synapsedata['$category'] = synapse.category
@synapsedata['$userid'] = synapse.user.id
@synapsedata['$username'] = synapse.user.name
json.data @synapsedata
end
@itemdata = Hash.new
@itemdata['$desc'] = item.desc
@itemdata['$link'] = item.link
@itemdata['$itemcatname'] = item.item_category.name
@itemdata['$userid'] = item.user.id
@itemdata['$username'] = item.user.name
json.data @itemdata
json.id item.id
json.name item.name
end
end
end
end end

View file

@ -21,6 +21,18 @@ has_many :maps, :through => :mappings
belongs_to :item_category belongs_to :item_category
# has no viewable synapses helper function
def has_viewable_synapses(current)
result = false
self.synapses.each do |synapse|
if synapse.authorize_to_view(current)
result = true
end
end
return result
end
###### JSON ######
def self_as_json def self_as_json
Jbuilder.encode do |json| Jbuilder.encode do |json|
@ -37,66 +49,101 @@ belongs_to :item_category
end end
#build a json object of everything connected to a specified node #build a json object of everything connected to a specified node
def network_as_json def network_as_json(current)
Jbuilder.encode do |json| Jbuilder.encode do |json|
@items = network(self,nil) @items = network(self,nil)
json.array!(@items) do |item| if @items.count > 1
json.adjacencies item.synapses2.delete_if{|synapse| not @items.include?(Item.find_by_id(synapse.node1_id))} do |json, synapse| json.array!(@items.delete_if{|item| (not item.authorize_to_view(current)) || (not item.has_viewable_synapses(current))}) do |item|
json.nodeTo synapse.node1_id
json.nodeFrom synapse.node2_id json.adjacencies item.synapses2.delete_if{|synapse| (not @items.include?(synapse.item1)) || (not synapse.authorize_to_view(current)) || (not synapse.item1.authorize_to_view(current)) } do |json, synapse|
json.nodeTo synapse.node1_id
@synapsedata = Hash.new json.nodeFrom synapse.node2_id
@synapsedata['$desc'] = synapse.desc
@synapsedata['$category'] = synapse.category @synapsedata = Hash.new
@synapsedata['$userid'] = synapse.user.id @synapsedata['$desc'] = synapse.desc
@synapsedata['$username'] = synapse.user.name @synapsedata['$category'] = synapse.category
json.data @synapsedata @synapsedata['$userid'] = synapse.user.id
@synapsedata['$username'] = synapse.user.name
json.data @synapsedata
end
@itemdata = Hash.new
@itemdata['$desc'] = item.desc
@itemdata['$link'] = item.link
@itemdata['$itemcatname'] = item.item_category.name
@itemdata['$userid'] = item.user.id
@itemdata['$username'] = item.user.name
json.data @itemdata
json.id item.id
json.name item.name
end end
elsif @items.count == 1
@itemdata = Hash.new json.array!(@items) do |item|
@itemdata['$desc'] = item.desc @itemdata = Hash.new
@itemdata['$link'] = item.link @itemdata['$desc'] = item.desc
@itemdata['$itemcatname'] = item.item_category.name @itemdata['$link'] = item.link
@itemdata['$userid'] = item.user.id @itemdata['$itemcatname'] = item.item_category.name
@itemdata['$username'] = item.user.name @itemdata['$userid'] = item.user.id
json.data @itemdata @itemdata['$username'] = item.user.name
json.id item.id json.data @itemdata
json.name item.name json.id item.id
end json.name item.name
end
end
end end
end end
def all_as_json ##### PERMISSIONS ######
Jbuilder.encode do |json|
scope :visibleToUser, lambda { |current, user|
@items = Item.all if user != nil
if user != current
json.array!(@items) do |item| Item.find_all_by_user_id_and_permission(user.id, "commons") | Item.find_all_by_user_id_and_permission(user.id, "public")
json.adjacencies item.synapses2.delete_if{|synapse| not @items.include?(Item.find_by_id(synapse.node1_id))} do |json, synapse| elsif user == current
json.nodeTo synapse.node1_id Item.find_all_by_user_id_and_permission(user.id, "commons") | Item.find_all_by_user_id_and_permission(user.id, "public") | current.items.where(:permission => "private")
json.nodeFrom synapse.node2_id end
elsif (current != nil && user == nil)
@synapsedata = Hash.new Item.find_all_by_permission("commons") | Item.find_all_by_permission("public") | current.items.where(:permission => "private")
@synapsedata['$desc'] = synapse.desc elsif (current == nil)
@synapsedata['$category'] = synapse.category Item.find_all_by_permission("commons") | Item.find_all_by_permission("public")
@synapsedata['$userid'] = synapse.user.id end
@synapsedata['$username'] = synapse.user.name }
json.data @synapsedata
end # returns false if user not allowed to 'show' Topic, Synapse, or Map
def authorize_to_show(user)
@itemdata = Hash.new if (self.permission == "private" && self.user != user)
@itemdata['$desc'] = item.desc return false
@itemdata['$link'] = item.link end
@itemdata['$itemcatname'] = item.item_category.name return self
@itemdata['$userid'] = item.user.id end
@itemdata['$username'] = item.user.name
# returns false if user not allowed to 'edit' Topic, Synapse, or Map
json.data @itemdata def authorize_to_edit(user)
json.id item.id if (self.permission == "private" && self.user != user)
json.name item.name return false
end elsif (self.permission == "public" && self.user != user)
end return false
end
return self
end
# returns Boolean if user allowed to view Topic, Synapse, or Map
def authorize_to_view(user)
if (self.permission == "private" && self.user != user)
return false
end
return true
end
# returns Boolean based on whether user has permissions to edit or not
def authorize_linkto_edit(user)
if (self.user == user)
return true
elsif (self.permission == "commons")
return true
end
return false
end end
end end

View file

@ -10,16 +10,19 @@ has_many :synapses, :through => :synapsemappings
def mappings def mappings
itemmappings + synapsemappings itemmappings + synapsemappings
end end
###### JSON ######
#build a json object of a map #build a json object of a map
def self_as_json def self_as_json(current)
Jbuilder.encode do |json| Jbuilder.encode do |json|
@items = self.items @items = self.items
@synapses = self.synapses @synapses = self.synapses
json.array!(@items) do |item| json.array!(@items.delete_if{|item| not item.authorize_to_view(current)}) do |item|
json.adjacencies item.synapses2.delete_if{|synapse| not @synapses.include?(synapse)} do |json, synapse|
json.adjacencies item.synapses2.delete_if{|synapse| (not @items.include?(synapse.item1)) || (not @synapses.include?(synapse)) || (not synapse.authorize_to_view(current)) || (not synapse.item1.authorize_to_view(current)) } do |json, synapse|
json.nodeTo synapse.node1_id json.nodeTo synapse.node1_id
json.nodeFrom synapse.node2_id json.nodeFrom synapse.node2_id
@ -43,5 +46,57 @@ end
end end
end end
end end
##### PERMISSIONS ######
scope :visibleToUser, lambda { |current, user|
if user != nil
if user != current
Map.find_all_by_user_id_and_permission(user.id, "commons") | Map.find_all_by_user_id_and_permission(user.id, "public")
elsif user == current
Map.find_all_by_user_id_and_permission(user.id, "commons") | Map.find_all_by_user_id_and_permission(user.id, "public") | current.maps.where(:permission => "private")
end
elsif (current != nil && user == nil)
Map.find_all_by_permission("commons") | Map.find_all_by_permission("public") | current.maps.where(:permission => "private")
elsif (current == nil)
Map.find_all_by_permission("commons") | Map.find_all_by_permission("public")
end
}
# returns false if user not allowed to 'show' Topic, Synapse, or Map
def authorize_to_show(user)
if (self.permission == "private" && self.user != user)
return false
end
return self
end
# returns false if user not allowed to 'edit' Topic, Synapse, or Map
def authorize_to_edit(user)
if (self.permission == "private" && self.user != user)
return false
elsif (self.permission == "public" && self.user != user)
return false
end
return self
end
# returns Boolean if user allowed to view Topic, Synapse, or Map
def authorize_to_view(user)
if (self.permission == "private" && self.user != user)
return false
end
return true
end
# returns Boolean based on whether user has permissions to edit or not
def authorize_linkto_edit(user)
if (self.user == user)
return true
elsif (self.permission == "commons")
return true
end
return false
end
end end

View file

@ -8,6 +8,8 @@ belongs_to :item2, :class_name => "Item", :foreign_key => "node2_id"
has_many :mappings has_many :mappings
has_many :maps, :through => :mappings has_many :maps, :through => :mappings
##### JSON ######
def self_as_json def self_as_json
Jbuilder.encode do |json| Jbuilder.encode do |json|
@synapsedata = Hash.new @synapsedata = Hash.new
@ -50,5 +52,57 @@ has_many :maps, :through => :mappings
end end
end end
end end
##### PERMISSIONS ######
scope :visibleToUser, lambda { |current, user|
if user != nil
if user != current
Synapse.find_all_by_user_id_and_permission(user.id, "commons") | Synapse.find_all_by_user_id_and_permission(user.id, "public")
elsif user == current
Synapse.find_all_by_user_id_and_permission(user.id, "commons") | Synapse.find_all_by_user_id_and_permission(user.id, "public") | current.synapses.where(:permission => "private")
end
elsif (current != nil && user == nil)
Synapse.find_all_by_permission("commons") | Synapse.find_all_by_permission("public") | current.synapses.where(:permission => "private")
elsif (current == nil)
Synapse.find_all_by_permission("commons") | Synapse.find_all_by_permission("public")
end
}
# returns false if user not allowed to 'show' Topic, Synapse, or Map
def authorize_to_show(user)
if (self.permission == "private" && self.user != user)
return false
end
return self
end
# returns false if user not allowed to 'edit' Topic, Synapse, or Map
def authorize_to_edit(user)
if (self.permission == "private" && self.user != user)
return false
elsif (self.permission == "public" && self.user != user)
return false
end
return self
end
# returns Boolean if user allowed to view Topic, Synapse, or Map
def authorize_to_view(user)
if (self.permission == "private" && self.user != user)
return false
end
return true
end
# returns Boolean based on whether user has permissions to edit or not
def authorize_linkto_edit(user)
if (self.user == user)
return true
elsif (self.permission == "commons")
return true
end
return false
end
end end

View file

@ -9,6 +9,6 @@
<label for="item_link">Link</label> <label for="item_link">Link</label>
<%= form.text_field :link, class: "link" %> <%= form.text_field :link, class: "link" %>
<label for="item_permission">Permission</label> <label for="item_permission">Permission</label>
<%= form.select(:permission, options_for_select(['commons', 'public', 'private'])) %> <%= form.select :permission, options_for_select(['commons', 'public', 'private'], @item.permission) %>
<%= form.submit "Update", class: "update" %> <%= form.submit "Update", class: "update" %>
<% end %> <% end %>

View file

@ -5,6 +5,6 @@
<label for="map_desc">Description</label> <label for="map_desc">Description</label>
<%= form.text_area :desc, class: "description", :rows => 5 %> <%= form.text_area :desc, class: "description", :rows => 5 %>
<label for="map_perm">Permission</label> <label for="map_perm">Permission</label>
<%= form.select(:permission, options_for_select(['commons', 'public', 'private']), { :selected => @map.permission }) %> <%= form.select :permission, options_for_select(['commons', 'public', 'private'], @map.permission) %>
<%= form.submit "Update", class: "update" %> <%= form.submit "Update", class: "update" %>
<% end %> <% end %>

View file

@ -11,6 +11,6 @@
<%= select "node2_id", "node2", @collection.order("name ASC").map {|p| [ p.name, p.id ] }, { :selected => @synapse.node2_id } %> <%= select "node2_id", "node2", @collection.order("name ASC").map {|p| [ p.name, p.id ] }, { :selected => @synapse.node2_id } %>
<% end %> <% end %>
<label for="synapse_permission">Permission</label> <label for="synapse_permission">Permission</label>
<%= form.select(:permission, options_for_select(['commons', 'public', 'private'])) %> <%= form.select :permission, options_for_select(['commons', 'public', 'private'], @synapse.permission) %>
<%= form.submit "Update", class: "update" %> <%= form.submit "Update", class: "update" %>
<% end %> <% end %>