35 lines
845 B
Ruby
35 lines
845 B
Ruby
class AccessRequest < ApplicationRecord
|
|
belongs_to :user
|
|
belongs_to :map
|
|
|
|
def approve
|
|
self.approved = true
|
|
self.answered = true
|
|
self.save
|
|
|
|
Mailboxer::Notification.where(notified_object: self).find_each do |notification|
|
|
Mailboxer::Receipt.where(notification: notification).update_all(is_read: true)
|
|
end
|
|
|
|
user_map = UserMap.create(user: user, map: map)
|
|
NotificationService.access_approved(self)
|
|
end
|
|
|
|
def deny
|
|
self.approved = false
|
|
self.answered = true
|
|
self.save
|
|
|
|
Mailboxer::Notification.where(notified_object: self).find_each do |notification|
|
|
Mailboxer::Receipt.where(notification: notification).update_all(is_read: true)
|
|
end
|
|
end
|
|
|
|
def requested_text
|
|
self.map.name + ' - request to edit'
|
|
end
|
|
|
|
def approved_text
|
|
self.map.name + ' - access approved'
|
|
end
|
|
end
|