* Dropped all references to Resque * Moved all jobs under app/workers since that's the Sidekiq convention * Renamed Jobs module to Worker to match new location * Adapted all jobs to Sidekiq * Replaced all enqueue calls with perform_async * Dropped Resque hacks from specs and features, replaced with sidekig/testing in RSpec and sidekig/testing/inline in Cucumber * Updated scripts to start a Sidekiq server * Inline Sidekiq sinatra app * Let Sidekiq create the actual Redis instance * Workaround already initialized constant warnings in service models * Resolved ToDo in one job definition by creating proper exception clases for some errors in receiving posts * Added sidekiq section to configuration to make it completly configurable to the user * Add Sidekiq middleware for clean backtraces * Delay HttpMulti retry to give offline pods a chance to come back up * Do not retry on GUID already taken and alike errors * Be graceful about deleted posts in GatherOEmbedData
81 lines
2.1 KiB
Ruby
81 lines
2.1 KiB
Ruby
# Copyright (c) 2010-2011, Diaspora Inc. This file is
|
|
# licensed under the Affero General Public License version 3 or later. See
|
|
# the COPYRIGHT file.
|
|
|
|
class PublicsController < ApplicationController
|
|
include Diaspora::Parser
|
|
|
|
skip_before_filter :set_header_data
|
|
skip_before_filter :set_grammatical_gender
|
|
before_filter :check_for_xml, :only => [:receive, :receive_public]
|
|
before_filter :authenticate_user!, :only => [:index]
|
|
|
|
respond_to :html
|
|
respond_to :xml, :only => :post
|
|
|
|
caches_page :host_meta, :if => Proc.new{ Rails.env == 'production'}
|
|
|
|
layout false
|
|
|
|
def hcard
|
|
@person = Person.find_by_guid_and_closed_account(params[:guid], false)
|
|
|
|
if @person.present? && @person.local?
|
|
render 'publics/hcard'
|
|
else
|
|
render :nothing => true, :status => 404
|
|
end
|
|
end
|
|
|
|
def host_meta
|
|
render 'host_meta', :content_type => 'application/xrd+xml'
|
|
end
|
|
|
|
def webfinger
|
|
@person = Person.local_by_account_identifier(params[:q]) if params[:q]
|
|
|
|
if @person.nil? || @person.closed_account?
|
|
render :nothing => true, :status => 404
|
|
return
|
|
end
|
|
|
|
FEDERATION_LOGGER.info("webfinger profile request for :#{@person.id}")
|
|
render 'webfinger', :content_type => 'application/xrd+xml'
|
|
end
|
|
|
|
def hub
|
|
render :text => params['hub.challenge'], :status => 202, :layout => false
|
|
end
|
|
|
|
def receive_public
|
|
FEDERATION_LOGGER.info("recieved a public message")
|
|
Workers::ReceiveUnencryptedSalmon.perform_async(CGI::unescape(params[:xml]))
|
|
render :nothing => true, :status => :ok
|
|
end
|
|
|
|
def receive
|
|
person = Person.find_by_guid(params[:guid])
|
|
|
|
if person.nil? || person.owner_id.nil?
|
|
Rails.logger.error("Received post for nonexistent person #{params[:guid]}")
|
|
render :nothing => true, :status => 404
|
|
return
|
|
end
|
|
|
|
@user = person.owner
|
|
|
|
FEDERATION_LOGGER.info("recieved a private message for user:#{@user.id}")
|
|
Workers::ReceiveEncryptedSalmon.perform_async(@user.id, CGI::unescape(params[:xml]))
|
|
|
|
render :nothing => true, :status => 202
|
|
end
|
|
|
|
private
|
|
|
|
def check_for_xml
|
|
if params[:xml].nil?
|
|
render :nothing => true, :status => 422
|
|
return
|
|
end
|
|
end
|
|
end
|