added some docs to Request [ci skip]

This commit is contained in:
danielgrippi 2011-09-15 08:38:44 -07:00
parent e4f7bc7216
commit 7216f76801

View file

@ -11,13 +11,16 @@ class Request
xml_accessor :sender_handle xml_accessor :sender_handle
xml_accessor :recipient_handle xml_accessor :recipient_handle
validates :sender, :presence => true validates :sender, :presence => true
validates :recipient, :presence => true validates :recipient, :presence => true
validate :not_already_connected validate :not_already_connected
validate :not_friending_yourself validate :not_friending_yourself
# Initalize variables
# @note we should be using ActiveModel::Serialization for this
# @return [Request]
def self.diaspora_initialize(opts = {}) def self.diaspora_initialize(opts = {})
req = self.new req = self.new
req.sender = opts[:from] req.sender = opts[:from]
@ -26,17 +29,14 @@ class Request
req req
end end
def reverse_for accepting_user # Alias of sender_handle
Request.diaspora_initialize( # @return [String]
:from => accepting_user.person,
:to => self.sender
)
end
def diaspora_handle def diaspora_handle
sender_handle sender_handle
end end
# @note Used for XML marshalling
# @return [String]
def sender_handle def sender_handle
sender.diaspora_handle sender.diaspora_handle
end end
@ -44,6 +44,8 @@ class Request
self.sender = Person.where(:diaspora_handle => sender_handle).first self.sender = Person.where(:diaspora_handle => sender_handle).first
end end
# @note Used for XML marshalling
# @return [String]
def recipient_handle def recipient_handle
recipient.diaspora_handle recipient.diaspora_handle
end end
@ -51,19 +53,28 @@ class Request
self.recipient = Person.where(:diaspora_handle => recipient_handle).first self.recipient = Person.where(:diaspora_handle => recipient_handle).first
end end
# Defines the abstract interface used in sending a corresponding [Notification] given the [Request]
# @param user [User]
# @param person [Person]
# @return [Notifications::StartedSharing]
def notification_type(user, person) def notification_type(user, person)
Notifications::StartedSharing Notifications::StartedSharing
end end
# Defines the abstract interface used in sending the [Request]
# @param user [User]
# @return [Array<Person>] The recipient of the request
def subscribers(user) def subscribers(user)
[self.recipient] [self.recipient]
end end
# Finds or initializes a corresponding [Contact], and will set Contact#sharing to true
# @note A [Contact] may already exist if the [Request]'s recipient is sharing with the sender
# @return [Request]
def receive(user, person) def receive(user, person)
Rails.logger.info("event=receive payload_type=request sender=#{self.sender} to=#{self.recipient}") Rails.logger.info("event=receive payload_type=request sender=#{self.sender} to=#{self.recipient}")
contact = user.contacts.find_or_initialize_by_person_id(self.sender.id) contact = user.contacts.find_or_initialize_by_person_id(self.sender.id)
contact.sharing = true contact.sharing = true
contact.save contact.save
@ -72,12 +83,14 @@ class Request
private private
# Checks if a [Contact] does not already exist between the requesting [User] and receiving [Person]
def not_already_connected def not_already_connected
if sender && recipient && Contact.where(:user_id => self.recipient.owner_id, :person_id => self.sender.id).exists? if sender && recipient && Contact.where(:user_id => self.recipient.owner_id, :person_id => self.sender.id).exists?
errors[:base] << 'You have already connected to this person' errors[:base] << 'You have already connected to this person'
end end
end end
# Checks to see that the requesting [User] is not sending a request to himself
def not_friending_yourself def not_friending_yourself
if self.recipient == self.sender if self.recipient == self.sender
errors[:base] << 'You can not friend yourself' errors[:base] << 'You can not friend yourself'