b0f97d9a87
* Wrap methods of ProcessFeedService::ProcessEntry in classes
This is a change same with 002ed7dc62
, except
that it has the following changes:
* Revert irrelevant change in find_or_create_conversation
* Fix error handling for RemoteActivity
* Introduce Ostatus name space
50 lines
1,022 B
Ruby
50 lines
1,022 B
Ruby
# frozen_string_literal: true
|
|
|
|
class Ostatus::Activity::Base
|
|
def initialize(xml, account = nil)
|
|
@xml = xml
|
|
@account = account
|
|
end
|
|
|
|
def status?
|
|
[:activity, :note, :comment].include?(type)
|
|
end
|
|
|
|
def verb
|
|
raw = @xml.at_xpath('./activity:verb', activity: TagManager::AS_XMLNS).content
|
|
TagManager::VERBS.key(raw)
|
|
rescue
|
|
:post
|
|
end
|
|
|
|
def type
|
|
raw = @xml.at_xpath('./activity:object-type', activity: TagManager::AS_XMLNS).content
|
|
TagManager::TYPES.key(raw)
|
|
rescue
|
|
:activity
|
|
end
|
|
|
|
def id
|
|
@xml.at_xpath('./xmlns:id', xmlns: TagManager::XMLNS).content
|
|
end
|
|
|
|
def url
|
|
link = @xml.at_xpath('./xmlns:link[@rel="alternate"]', xmlns: TagManager::XMLNS)
|
|
link.nil? ? nil : link['href']
|
|
end
|
|
|
|
private
|
|
|
|
def find_status(uri)
|
|
if TagManager.instance.local_id?(uri)
|
|
local_id = TagManager.instance.unique_tag_to_local_id(uri, 'Status')
|
|
return Status.find_by(id: local_id)
|
|
end
|
|
|
|
Status.find_by(uri: uri)
|
|
end
|
|
|
|
def redis
|
|
Redis.current
|
|
end
|
|
end
|