DG IZ; fixed person requesting (friend requests).

This commit is contained in:
danielvincent 2010-07-07 17:47:09 -07:00
parent 3d105e7c1e
commit a33acd134e
11 changed files with 81 additions and 58 deletions

View file

@ -1,30 +1,26 @@
class PersonRequest
include MongoMapper::Document
include Diaspora::Webhooks
include ROXML
key :url, String
xml_name :person_request
attr_accessor :sender
xml_accessor :_id
xml_accessor :person, :as => Person
key :url, String
key :person, Person
validates_presence_of :url
before_save :check_for_person_requests
def to_person_xml
person = Person.new
person.email = sender.email
person.url = sender.url
person.profile = sender.profile.clone
person.to_xml
end
def self.for(url)
person_request = PersonRequest.new(:url => url)
person_request.sender = User.first
person_request.save
request = PersonRequest.new(:url => url)
request.person = User.first
request.save
person_request.push_person_request_to_url(person_request.url)
request.push_to([request])
end
def check_for_person_requests

View file

@ -0,0 +1,9 @@
= form_for @person_request do |f|
= f.error_messages
%p
= f.label :url
= f.text_field :url
%p
= f.submit

View file

@ -0,0 +1,9 @@
= form_for @person_request, :remote => true do |f|
= f.error_messages
%p
= f.label :url
= f.text_field :url
%p
= f.submit

View file

@ -0,0 +1,2 @@
%li.message{:id => person_request.id}
= person_request.inspect

View file

@ -0,0 +1,8 @@
- title "Edit Person Request"
= render 'form'
%p
= link_to "Show", person_request_path(@person_request)
|
= link_to "View All", person_request_path

View file

@ -0,0 +1,7 @@
%h1 person requests
= render "person_requests/new_person_request", :person_request => @person_request
%ul#stream
- for person_request in @person_requests
= render "person_request", :person_request => person_request
#pagination
= will_paginate @person_requests

View file

@ -0,0 +1,5 @@
- title "New Person Request"
= render 'form'
%p= link_to "Back to List", person_requests_path

View file

@ -0,0 +1,11 @@
- title "Person Request"
%p
= person_request.inspect
%p
= link_to "Edit", edit_person_request_path(@person_request)
|
= link_to "Destroy", @person_request, :confirm => 'Are you sure?', :method => :delete
|
= link_to "View All", person_requests_path

View file

@ -33,11 +33,12 @@ module Diaspora
objects.each do |p|
if p.is_a? Retraction
p.perform
elsif p.is_a? Person
elsif p.is_a? PersonRequest
if PersonRequest.where(:url => p.url).first
p.active = true
end
p.save
p.person.save
#This line checks if the sender was in the database, among other things?
elsif p.respond_to?(:person) && !(p.person.nil?) && !(p.person.is_a? User) #WTF
p.save
@ -68,19 +69,6 @@ module Diaspora
end
end
def push_person_request_to_url(url)
if url
url = url + "receive/"
xml = "<XML>
<posts><post>
#{self.to_person_xml.to_s}
</post></posts>
</XML>"
@@queue.add_post_request( [url], xml )
@@queue.process
end
end
def prep_webhook
"<post>#{self.to_xml.to_s}</post>"
end

View file

@ -111,13 +111,10 @@ describe "parser in application helper" do
end
it "should create a new person upon getting a person request" do
person_request = PersonRequest.new(:url => "http://www.googles.com/")
person_request.sender = @person
xml = "<XML>
<posts><post>
#{person_request.to_person_xml.to_s}
</post></posts>
</XML>"
request = PersonRequest.new(:url => "http://www.googles.com/")
request.person = @person
xml = Post.build_xml_for [request]
@person.destroy
@user.destroy
@ -127,22 +124,13 @@ describe "parser in application helper" do
end
it "should activate the Person if I initiated a request to that url" do
person_request = PersonRequest.create(:url => @person.url, :sender => @user)
person_request_remote = PersonRequest.new(:url => "http://www.yahoo.com/")
person_request_remote.sender = @person.clone
xml = "<XML>
<posts><post>
#{person_request_remote.to_person_xml.to_s}
</post></posts>
</XML>"
request = PersonRequest.create(:url => @person.url, :person => @user)
request_remote = PersonRequest.new(:url => "http://www.yahoo.com/")
request_remote.person = @person.clone
@person.destroy
@user.destroy
Person.count.should be 0
store_objects_from_xml(xml)
Person.count.should be 1
Person.first.active.should be true
xml = Post.build_xml_for [request_remote]
Person.where(:url => @person.url).first.active.should be true
end
end

View file

@ -10,14 +10,14 @@ describe PersonRequest do
end
it 'should generate xml for the User as a Person' do
person_request = PersonRequest.new(:url => "http://www.google.com")
user = Factory.create(:user)
person_request.sender = user
person_xml = person_request.to_person_xml.to_s
person_xml.include?(user.email).should be true
person_xml.include?(user.url).should be true
person_xml.include?(user.profile.first_name).should be true
person_xml.include?(user.profile.last_name).should be true
request = PersonRequest.new(:url => "http://www.google.com/", :person => user)
xml = request.to_xml.to_s
xml.include?(user.email).should be true
xml.include?(user.url).should be true
xml.include?(user.profile.first_name).should be true
xml.include?(user.profile.last_name).should be true
end
it 'should be sent to the url upon for action' do