* 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
21 lines
705 B
Ruby
21 lines
705 B
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.
|
|
|
|
module Diaspora
|
|
module Parser
|
|
def self.from_xml(xml)
|
|
doc = Nokogiri::XML(xml) { |cfg| cfg.noblanks }
|
|
return unless body = doc.xpath("/XML/post").children.first
|
|
class_name = body.name.gsub('-', '/')
|
|
begin
|
|
class_name.camelize.constantize.from_xml body.to_s
|
|
rescue NameError => e
|
|
# A pods is trying to federate an object we don't recognize.
|
|
# i.e. their codebase is different from ours. Quietly discard
|
|
# so that no job failure is created
|
|
nil
|
|
end
|
|
end
|
|
end
|
|
end
|