2012-10-24 06:47:08 +00:00
|
|
|
class Map < ActiveRecord::Base
|
2012-10-26 10:04:52 +00:00
|
|
|
|
2014-08-12 22:14:04 +00:00
|
|
|
belongs_to :user
|
2012-10-26 10:04:52 +00:00
|
|
|
|
2015-09-19 08:48:24 +00:00
|
|
|
has_many :topicmappings, -> { Mapping.topicmapping }, class_name: :Mapping
|
|
|
|
has_many :synapsemappings, -> { Mapping.synapsemapping }, class_name: :Mapping
|
|
|
|
has_many :topics, through: :topicmappings
|
|
|
|
has_many :synapses, through: :synapsemappings
|
2012-10-26 10:04:52 +00:00
|
|
|
|
2015-10-01 02:30:53 +00:00
|
|
|
has_many :webhooks, as: :hookable
|
|
|
|
has_many :events, -> { includes :user }, as: :eventable, dependent: :destroy
|
|
|
|
|
2014-08-15 22:04:22 +00:00
|
|
|
# This method associates the attribute ":image" with a file attachment
|
|
|
|
has_attached_file :screenshot, :styles => {
|
2014-11-10 03:10:13 +00:00
|
|
|
:thumb => ['188x126#', :png]
|
|
|
|
#:full => ['940x630#', :png]
|
2014-10-08 04:07:54 +00:00
|
|
|
},
|
|
|
|
:default_url => "/assets/missing-map.png"
|
2014-08-15 22:04:22 +00:00
|
|
|
|
|
|
|
# Validate the attached image is image/jpg, image/png, etc
|
|
|
|
validates_attachment_content_type :screenshot, :content_type => /\Aimage\/.*\Z/
|
|
|
|
|
2014-08-12 22:14:04 +00:00
|
|
|
def mappings
|
|
|
|
topicmappings + synapsemappings
|
|
|
|
end
|
2013-01-18 22:08:06 +00:00
|
|
|
|
2014-08-12 22:14:04 +00:00
|
|
|
def mk_permission
|
|
|
|
if self.permission == "commons"
|
|
|
|
"co"
|
|
|
|
elsif self.permission == "public"
|
|
|
|
"pu"
|
|
|
|
elsif self.permission == "private"
|
|
|
|
"pr"
|
|
|
|
end
|
2013-01-18 22:08:06 +00:00
|
|
|
end
|
2014-01-29 03:46:58 +00:00
|
|
|
|
|
|
|
#return an array of the contributors to the map
|
|
|
|
def contributors
|
|
|
|
contributors = []
|
|
|
|
|
|
|
|
self.mappings.each do |m|
|
|
|
|
contributors.push(m.user) if !contributors.include?(m.user)
|
|
|
|
end
|
|
|
|
|
|
|
|
return contributors
|
|
|
|
end
|
2014-08-12 15:09:53 +00:00
|
|
|
|
|
|
|
def topic_count
|
|
|
|
self.topics.length
|
|
|
|
end
|
|
|
|
|
|
|
|
def synapse_count
|
|
|
|
self.synapses.length
|
|
|
|
end
|
|
|
|
|
|
|
|
def user_name
|
|
|
|
self.user.name
|
|
|
|
end
|
|
|
|
|
2014-08-12 16:01:01 +00:00
|
|
|
def user_image
|
|
|
|
self.user.image.url
|
|
|
|
end
|
|
|
|
|
2014-08-15 22:04:22 +00:00
|
|
|
def contributor_count
|
|
|
|
self.contributors.length
|
|
|
|
end
|
|
|
|
|
2014-10-08 04:07:54 +00:00
|
|
|
def screenshot_url
|
|
|
|
self.screenshot.url(:thumb)
|
|
|
|
end
|
|
|
|
|
2014-08-27 02:51:50 +00:00
|
|
|
def created_at_str
|
|
|
|
self.created_at.strftime("%m/%d/%Y")
|
|
|
|
end
|
|
|
|
|
|
|
|
def updated_at_str
|
|
|
|
self.updated_at.strftime("%m/%d/%Y")
|
|
|
|
end
|
|
|
|
|
2014-08-12 15:09:53 +00:00
|
|
|
def as_json(options={})
|
2015-01-31 17:39:48 +00:00
|
|
|
json = super(:methods =>[:user_name, :user_image, :topic_count, :synapse_count, :contributor_count, :screenshot_url], :except => [:screenshot_content_type, :screenshot_file_size, :screenshot_file_name, :screenshot_updated_at])
|
|
|
|
json[:created_at_clean] = self.created_at_str
|
|
|
|
json[:updated_at_clean] = self.updated_at_str
|
2014-08-27 02:51:50 +00:00
|
|
|
json
|
2014-08-12 15:09:53 +00:00
|
|
|
end
|
2014-10-07 23:11:55 +00:00
|
|
|
|
2012-10-27 08:30:56 +00:00
|
|
|
##### PERMISSIONS ######
|
|
|
|
|
2014-10-27 17:26:24 +00:00
|
|
|
def authorize_to_delete(user)
|
|
|
|
if (self.user != user)
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
return self
|
|
|
|
end
|
|
|
|
|
2012-10-27 08:30:56 +00:00
|
|
|
# returns false if user not allowed to 'show' Topic, Synapse, or Map
|
2014-10-13 23:27:30 +00:00
|
|
|
def authorize_to_show(user)
|
|
|
|
if (self.permission == "private" && self.user != user)
|
2014-08-12 22:14:04 +00:00
|
|
|
return false
|
|
|
|
end
|
|
|
|
return self
|
2012-10-27 08:30:56 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# returns false if user not allowed to 'edit' Topic, Synapse, or Map
|
|
|
|
def authorize_to_edit(user)
|
2014-10-13 23:27:30 +00:00
|
|
|
if !user
|
|
|
|
return false
|
|
|
|
elsif (self.permission == "private" && self.user != user)
|
2014-08-12 22:14:04 +00:00
|
|
|
return false
|
|
|
|
elsif (self.permission == "public" && self.user != user)
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
return self
|
2012-10-27 08:30:56 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# returns Boolean if user allowed to view Topic, Synapse, or Map
|
|
|
|
def authorize_to_view(user)
|
2014-08-12 22:14:04 +00:00
|
|
|
if (self.permission == "private" && self.user != user)
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
return true
|
2012-10-27 08:30:56 +00:00
|
|
|
end
|
2012-10-26 10:04:52 +00:00
|
|
|
|
2014-10-08 04:07:54 +00:00
|
|
|
def decode_base64(imgBase64)
|
|
|
|
decoded_data = Base64.decode64(imgBase64)
|
|
|
|
|
|
|
|
data = StringIO.new(decoded_data)
|
|
|
|
data.class_eval do
|
|
|
|
attr_accessor :content_type, :original_filename
|
|
|
|
end
|
|
|
|
|
|
|
|
data.content_type = "image/png"
|
2014-10-13 23:27:30 +00:00
|
|
|
data.original_filename = File.basename('map-' + self.id.to_s + '-screenshot.png')
|
2014-10-08 04:07:54 +00:00
|
|
|
|
|
|
|
self.screenshot = data
|
|
|
|
self.save
|
|
|
|
end
|
|
|
|
|
2012-10-24 06:47:08 +00:00
|
|
|
end
|