Newer
Older
# licensed under the Affero General Public License version 3 or later. See
Daniel Vincent Grippi
a validé
danielvincent
a validé
class PeopleController < ApplicationController
before_filter :authenticate_user!
respond_to :html
respond_to :json, :only => [:index, :show]
danielvincent
a validé
def index
@aspect = :search
@people = Person.search(params[:q]).paginate :page => params[:page], :per_page => 25, :order => 'created_at DESC'
# dont do it@people.first.diaspora_handle == params[:q]
#only do it if it is an email address
if params[:q].try(:match, Devise.email_regexp)
webfinger(params[:q])
respond_with @people
danielvincent
a validé
end
danielvincent
a validé
def show
@person = Person.find(params[:id].to_id)
maxwell
a validé
@post_type = :all
@profile = @person.profile
@contact = current_user.contact_for(@person)
@is_contact = @person != current_user.person && @contact
if @contact
@aspects_with_person = @contact.aspects
else
@pending_request = current_user.request_for(@person)
@posts = current_user.visible_posts(:person_id => @person.id).paginate :page => params[:page], :order => 'created_at DESC'
maxwell
a validé
respond_with @person, :locals => {:post_type => :all}
flash[:error] = I18n.t 'people.show.does_not_exist'
redirect_to people_path
Raphael
a validé
end
danielvincent
a validé
end
danielvincent
a validé
def destroy
current_user.disconnect(current_user.visible_person_by_id(params[:id]))
danielvincent
a validé
end
danielvincent
a validé
def edit
@aspect = :person_edit
@person = current_user.person
@profile = @person.profile
end
def update
danielvincent
a validé
# convert date selector into proper timestamp
if birthday = params[:date]
unless [:month, :day, :year].any?{|x| birthday[x].blank?}
params[:person][:profile][:birthday] ||= Date.parse("#{birthday[:year]}-#{birthday[:month]}-#{birthday[:day]}")
end
danielvincent
a validé
end
danielvincent
a validé
# upload and set new profile photo
params[:person][:profile] ||= {}
if params[:person][:profile][:image].present?
danielvincent
a validé
raw_image = params[:person][:profile].delete(:image)
params[:profile_image_hash] = { :user_file => raw_image, :to => "all" }
photo = current_user.post(:photo, params[:profile_image_hash])
params[:person][:profile][:image_url] = photo.url(:thumb_medium)
end
danielvincent
a validé
if current_user.update_profile params[:person][:profile]
danielvincent
a validé
else
danielvincent
a validé
end
redirect_to getting_started_path(:step => params[:getting_started].to_i+1)
else
redirect_to edit_person_path
end
danielvincent
a validé
end
def retrieve_remote
if params[:diaspora_handle]
webfinger(params[:diaspora_handle], :single_aspect_form => true)
render :nothing => true
else
render :nothing => true, :status => 422
end
end
private
def webfinger(account, opts = {})
finger = EMWebfinger.new(account)
finger.on_person do |response|
if response.class == Person
response.socket_to_uid(current_user.id, opts)
else
require File.join(Rails.root,'lib/diaspora/websocket')
Diaspora::WebSocket.queue_to_user(current_user.id, {:class => 'people', :status => 'fail', :query => account, :response => response}.to_json)
end
end
end