2016-09-24 03:00:46 +00:00
|
|
|
# frozen_string_literal: true
|
2012-10-26 10:04:52 +00:00
|
|
|
class MapsController < ApplicationController
|
2016-08-31 20:58:49 +00:00
|
|
|
before_action :require_user, only: [:create, :update, :access, :star, :unstar, :screenshot, :events, :destroy]
|
2016-09-21 17:22:40 +00:00
|
|
|
after_action :verify_authorized, except: [:activemaps, :featuredmaps, :mymaps, :sharedmaps, :starredmaps, :usermaps]
|
2016-08-31 20:58:49 +00:00
|
|
|
after_action :verify_policy_scoped, only: [:activemaps, :featuredmaps, :mymaps, :sharedmaps, :starredmaps, :usermaps]
|
2016-02-13 09:42:36 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
respond_to :html, :json, :csv
|
2016-02-13 09:42:36 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
autocomplete :map, :name, full: true, extra_data: [:user_id]
|
2014-07-31 01:10:10 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# GET /explore/active
|
|
|
|
def activemaps
|
|
|
|
page = params[:page].present? ? params[:page] : 1
|
|
|
|
@maps = policy_scope(Map).order('updated_at DESC')
|
|
|
|
.page(page).per(20)
|
2016-02-13 09:42:36 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
respond_to do |format|
|
|
|
|
format.html do
|
|
|
|
# root url => main/home. main/home renders maps/activemaps view.
|
|
|
|
redirect_to(root_url) && return if authenticated?
|
|
|
|
respond_with(@maps, @user)
|
2016-06-20 00:31:32 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
format.json { render json: @maps }
|
2016-04-24 15:50:35 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# GET /explore/featured
|
|
|
|
def featuredmaps
|
|
|
|
page = params[:page].present? ? params[:page] : 1
|
|
|
|
@maps = policy_scope(
|
|
|
|
Map.where('maps.featured = ? AND maps.permission != ?',
|
|
|
|
true, 'private')
|
|
|
|
).order('updated_at DESC').page(page).per(20)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { respond_with(@maps, @user) }
|
|
|
|
format.json { render json: @maps }
|
|
|
|
end
|
|
|
|
end
|
2016-04-24 15:50:35 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# GET /explore/mine
|
|
|
|
def mymaps
|
|
|
|
unless authenticated?
|
|
|
|
skip_policy_scope
|
|
|
|
return redirect_to explore_active_path
|
2014-02-10 04:36:23 +00:00
|
|
|
end
|
2014-07-31 01:10:10 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
page = params[:page].present? ? params[:page] : 1
|
|
|
|
@maps = policy_scope(
|
|
|
|
Map.where('maps.user_id = ?', current_user.id)
|
|
|
|
).order('updated_at DESC').page(page).per(20)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { respond_with(@maps, @user) }
|
|
|
|
format.json { render json: @maps }
|
2014-08-11 22:57:34 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
2014-08-11 22:57:34 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# GET /explore/shared
|
|
|
|
def sharedmaps
|
|
|
|
unless authenticated?
|
|
|
|
skip_policy_scope
|
|
|
|
return redirect_to explore_active_path
|
2016-03-26 03:31:55 +00:00
|
|
|
end
|
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
page = params[:page].present? ? params[:page] : 1
|
|
|
|
@maps = policy_scope(
|
|
|
|
Map.where('maps.id IN (?)', current_user.shared_maps.map(&:id))
|
|
|
|
).order('updated_at DESC').page(page).per(20)
|
2016-04-14 18:35:28 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
respond_to do |format|
|
|
|
|
format.html { respond_with(@maps, @user) }
|
|
|
|
format.json { render json: @maps }
|
2016-04-14 18:35:28 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
|
|
|
|
2016-08-31 20:58:49 +00:00
|
|
|
# GET /explore/starred
|
|
|
|
def starredmaps
|
|
|
|
unless authenticated?
|
|
|
|
skip_policy_scope
|
|
|
|
return redirect_to explore_active_path
|
|
|
|
end
|
|
|
|
|
|
|
|
page = params[:page].present? ? params[:page] : 1
|
|
|
|
stars = current_user.stars.map(&:map_id)
|
|
|
|
@maps = policy_scope(
|
|
|
|
Map.where('maps.id IN (?)', stars)
|
|
|
|
).order('updated_at DESC').page(page).per(20)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { respond_with(@maps, @user) }
|
|
|
|
format.json { render json: @maps }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# GET /explore/mapper/:id
|
|
|
|
def usermaps
|
|
|
|
page = params[:page].present? ? params[:page] : 1
|
|
|
|
@user = User.find(params[:id])
|
|
|
|
@maps = policy_scope(Map.where(user: @user))
|
|
|
|
.order('updated_at DESC').page(page).per(20)
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html { respond_with(@maps, @user) }
|
|
|
|
format.json { render json: @maps }
|
|
|
|
end
|
|
|
|
end
|
2016-03-26 03:31:55 +00:00
|
|
|
|
2016-08-16 12:03:06 +00:00
|
|
|
# GET maps/new
|
|
|
|
def new
|
2016-09-24 03:00:46 +00:00
|
|
|
@map = Map.new(name: 'Untitled Map', permission: 'public', arranged: true)
|
2016-08-16 12:03:06 +00:00
|
|
|
authorize @map
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html do
|
|
|
|
@map.user = current_user
|
|
|
|
@map.save
|
2016-09-24 03:00:46 +00:00
|
|
|
redirect_to(map_path(@map) + '?new')
|
2016-08-16 12:03:06 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# GET maps/:id
|
|
|
|
def show
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
2014-08-11 22:57:34 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
respond_to do |format|
|
|
|
|
format.html do
|
2014-08-04 16:20:16 +00:00
|
|
|
@allmappers = @map.contributors
|
2016-04-24 15:50:35 +00:00
|
|
|
@allcollaborators = @map.editors
|
2016-07-26 00:14:23 +00:00
|
|
|
@alltopics = @map.topics.to_a.delete_if { |t| !policy(t).show? }
|
|
|
|
@allsynapses = @map.synapses.to_a.delete_if { |s| !policy(s).show? }
|
|
|
|
@allmappings = @map.mappings.to_a.delete_if { |m| !policy(m).show? }
|
|
|
|
@allmessages = @map.messages.sort_by(&:created_at)
|
2016-08-31 20:58:49 +00:00
|
|
|
@allstars = @map.stars
|
2014-07-31 01:10:10 +00:00
|
|
|
|
2016-08-31 20:58:49 +00:00
|
|
|
respond_with(@allmappers, @allcollaborators, @allmappings, @allsynapses, @alltopics, @allmessages, @allstars, @map)
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
|
|
|
format.json { render json: @map }
|
|
|
|
format.csv { redirect_to action: :export, format: :csv }
|
|
|
|
format.xls { redirect_to action: :export, format: :xls }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# GET maps/:id/export
|
|
|
|
def export
|
|
|
|
map = Map.find(params[:id])
|
|
|
|
authorize map
|
|
|
|
exporter = MapExportService.new(current_user, map)
|
|
|
|
respond_to do |format|
|
|
|
|
format.json { render json: exporter.json }
|
|
|
|
format.csv { send_data exporter.csv }
|
|
|
|
format.xls { @spreadsheet = exporter.xls }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# POST maps/:id/events/:event
|
|
|
|
def events
|
|
|
|
map = Map.find(params[:id])
|
|
|
|
authorize map
|
|
|
|
|
|
|
|
valid_event = false
|
|
|
|
if params[:event] == 'conversation'
|
|
|
|
Events::ConversationStartedOnMap.publish!(map, current_user)
|
|
|
|
valid_event = true
|
|
|
|
elsif params[:event] == 'user_presence'
|
|
|
|
Events::UserPresentOnMap.publish!(map, current_user)
|
|
|
|
valid_event = true
|
|
|
|
end
|
2016-03-11 14:10:31 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
respond_to do |format|
|
|
|
|
format.json do
|
|
|
|
head :ok if valid_event
|
|
|
|
head :bad_request unless valid_event
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# GET maps/:id/contains
|
|
|
|
def contains
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
|
|
|
|
|
|
|
@allmappers = @map.contributors
|
|
|
|
@allcollaborators = @map.editors
|
|
|
|
@alltopics = @map.topics.to_a.delete_if { |t| !policy(t).show? }
|
|
|
|
@allsynapses = @map.synapses.to_a.delete_if { |s| !policy(s).show? }
|
|
|
|
@allmappings = @map.mappings.to_a.delete_if { |m| !policy(m).show? }
|
|
|
|
|
|
|
|
@json = {}
|
|
|
|
@json['map'] = @map
|
|
|
|
@json['topics'] = @alltopics
|
|
|
|
@json['synapses'] = @allsynapses
|
|
|
|
@json['mappings'] = @allmappings
|
|
|
|
@json['mappers'] = @allmappers
|
|
|
|
@json['collaborators'] = @allcollaborators
|
|
|
|
@json['messages'] = @map.messages.sort_by(&:created_at)
|
2016-08-31 20:58:49 +00:00
|
|
|
@json['stars'] = @map.stars
|
2016-07-26 00:14:23 +00:00
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.json { render json: @json }
|
2014-01-31 00:32:15 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# POST maps
|
|
|
|
def create
|
|
|
|
@user = current_user
|
|
|
|
@map = Map.new
|
|
|
|
@map.name = params[:name]
|
|
|
|
@map.desc = params[:desc]
|
|
|
|
@map.permission = params[:permission]
|
|
|
|
@map.user = @user
|
|
|
|
@map.arranged = false
|
|
|
|
|
|
|
|
if params[:topicsToMap]
|
|
|
|
@all = params[:topicsToMap]
|
|
|
|
@all = @all.split(',')
|
|
|
|
@all.each do |topic|
|
|
|
|
topic = topic.split('/')
|
|
|
|
mapping = Mapping.new
|
|
|
|
mapping.map = @map
|
|
|
|
mapping.user = @user
|
|
|
|
mapping.mappable = Topic.find(topic[0])
|
|
|
|
mapping.xloc = topic[1]
|
|
|
|
mapping.yloc = topic[2]
|
|
|
|
authorize mapping, :create?
|
|
|
|
mapping.save
|
|
|
|
end
|
2014-07-31 01:10:10 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
if params[:synapsesToMap]
|
|
|
|
@synAll = params[:synapsesToMap]
|
|
|
|
@synAll = @synAll.split(',')
|
|
|
|
@synAll.each do |synapse_id|
|
|
|
|
mapping = Mapping.new
|
|
|
|
mapping.map = @map
|
|
|
|
mapping.user = @user
|
|
|
|
mapping.mappable = Synapse.find(synapse_id)
|
|
|
|
authorize mapping, :create?
|
|
|
|
mapping.save
|
2014-07-31 01:10:10 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
@map.arranged = true
|
2014-07-30 03:18:43 +00:00
|
|
|
end
|
2014-07-31 01:10:10 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
authorize @map
|
2016-04-24 15:50:35 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
if @map.save
|
2016-04-24 15:50:35 +00:00
|
|
|
respond_to do |format|
|
2016-07-26 00:14:23 +00:00
|
|
|
format.json { render json: @map }
|
|
|
|
end
|
|
|
|
else
|
|
|
|
respond_to do |format|
|
|
|
|
format.json { render json: 'invalid params' }
|
2016-04-24 15:50:35 +00:00
|
|
|
end
|
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# PUT maps/:id
|
|
|
|
def update
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
if @map.update_attributes(map_params)
|
|
|
|
format.json { head :no_content }
|
|
|
|
else
|
|
|
|
format.json { render json: @map.errors, status: :unprocessable_entity }
|
2016-03-11 14:10:31 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# POST maps/:id/access
|
|
|
|
def access
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
|
|
|
userIds = params[:access] || []
|
|
|
|
added = userIds.select do |uid|
|
|
|
|
user = User.find(uid)
|
|
|
|
if user.nil? || (current_user && user == current_user)
|
|
|
|
false
|
2016-03-11 14:10:31 +00:00
|
|
|
else
|
2016-07-26 00:14:23 +00:00
|
|
|
!@map.collaborators.include?(user)
|
2016-03-11 14:10:31 +00:00
|
|
|
end
|
2014-11-10 03:10:13 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
removed = @map.collaborators.select { |user| !userIds.include?(user.id.to_s) }.map(&:id)
|
|
|
|
added.each do |uid|
|
|
|
|
UserMap.create(user_id: uid.to_i, map_id: @map.id)
|
|
|
|
user = User.find(uid.to_i)
|
|
|
|
MapMailer.invite_to_edit_email(@map, current_user, user).deliver_later
|
|
|
|
end
|
|
|
|
removed.each do |uid|
|
|
|
|
@map.user_maps.select { |um| um.user_id == uid }.each(&:destroy)
|
|
|
|
end
|
2014-11-10 03:10:13 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
respond_to do |format|
|
|
|
|
format.json do
|
|
|
|
render json: { message: 'Successfully altered edit permissions' }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-08-31 20:58:49 +00:00
|
|
|
# POST maps/:id/star
|
|
|
|
def star
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
|
|
|
star = Star.find_by_map_id_and_user_id(@map.id, current_user.id)
|
2016-09-24 03:00:46 +00:00
|
|
|
star = Star.create(map_id: @map.id, user_id: current_user.id) unless star
|
2016-08-31 20:58:49 +00:00
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.json do
|
|
|
|
render json: { message: 'Successfully starred map' }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# POST maps/:id/unstar
|
|
|
|
def unstar
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
|
|
|
star = Star.find_by_map_id_and_user_id(@map.id, current_user.id)
|
2016-09-24 03:00:46 +00:00
|
|
|
star&.delete
|
2016-08-31 20:58:49 +00:00
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.json do
|
|
|
|
render json: { message: 'Successfully unstarred map' }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# POST maps/:id/upload_screenshot
|
|
|
|
def screenshot
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
|
|
|
|
|
|
|
png = Base64.decode64(params[:encoded_image]['data:image/png;base64,'.length..-1])
|
|
|
|
StringIO.open(png) do |data|
|
|
|
|
data.class.class_eval { attr_accessor :original_filename, :content_type }
|
|
|
|
data.original_filename = 'map-' + @map.id.to_s + '-screenshot.png'
|
|
|
|
data.content_type = 'image/png'
|
|
|
|
@map.screenshot = data
|
|
|
|
end
|
2014-07-31 01:10:10 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
if @map.save
|
|
|
|
render json: { message: 'Successfully uploaded the map screenshot.' }
|
|
|
|
else
|
|
|
|
render json: { message: 'Failed to upload image.' }
|
|
|
|
end
|
|
|
|
end
|
2014-07-31 01:10:10 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# DELETE maps/:id
|
|
|
|
def destroy
|
|
|
|
@map = Map.find(params[:id])
|
|
|
|
authorize @map
|
|
|
|
|
|
|
|
@map.delete
|
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.json do
|
|
|
|
head :no_content
|
2016-03-11 14:10:31 +00:00
|
|
|
end
|
2012-10-26 10:04:52 +00:00
|
|
|
end
|
2016-07-26 00:14:23 +00:00
|
|
|
end
|
2015-09-19 08:26:34 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
private
|
2015-09-19 08:26:34 +00:00
|
|
|
|
2016-07-26 00:14:23 +00:00
|
|
|
# Never trust parameters from the scary internet, only allow the white list through.
|
|
|
|
def map_params
|
|
|
|
params.require(:map).permit(:id, :name, :arranged, :desc, :permission)
|
|
|
|
end
|
2012-10-26 10:04:52 +00:00
|
|
|
end
|