2010-12-16 07:53:38 +09:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* StatusNet - the distributed open-source microblogging tool
|
|
|
|
* Copyright (C) 2010, StatusNet, Inc.
|
|
|
|
*
|
2010-12-18 03:12:17 +09:00
|
|
|
* Importer for feeds of activities
|
2011-04-02 02:46:40 +09:00
|
|
|
*
|
2010-12-16 07:53:38 +09:00
|
|
|
* PHP version 5
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @category Account
|
|
|
|
* @package StatusNet
|
|
|
|
* @author Evan Prodromou <evan@status.net>
|
|
|
|
* @copyright 2010 StatusNet, Inc.
|
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
|
|
|
* @link http://status.net/
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (!defined('STATUSNET')) {
|
|
|
|
// This check helps protect against security problems;
|
|
|
|
// your code file can't be executed directly from the web.
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2010-12-18 03:12:17 +09:00
|
|
|
* Importer for feeds of activities
|
|
|
|
*
|
|
|
|
* Takes an XML file representing a feed of activities and imports each
|
|
|
|
* activity to the user in question.
|
2010-12-16 07:53:38 +09:00
|
|
|
*
|
|
|
|
* @category Account
|
|
|
|
* @package StatusNet
|
|
|
|
* @author Evan Prodromou <evan@status.net>
|
|
|
|
* @copyright 2010 StatusNet, Inc.
|
|
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
|
|
|
* @link http://status.net/
|
|
|
|
*/
|
2010-12-18 03:12:17 +09:00
|
|
|
class FeedImporter extends QueueHandler
|
2010-12-16 07:53:38 +09:00
|
|
|
{
|
2010-12-18 03:12:17 +09:00
|
|
|
/**
|
|
|
|
* Transport identifier
|
|
|
|
*
|
|
|
|
* @return string identifier for this queue handler
|
|
|
|
*/
|
|
|
|
public function transport()
|
2010-12-16 07:53:38 +09:00
|
|
|
{
|
2010-12-18 03:12:17 +09:00
|
|
|
return 'feedimp';
|
2010-12-16 07:53:38 +09:00
|
|
|
}
|
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
function handle($data)
|
2010-12-16 07:53:38 +09:00
|
|
|
{
|
2010-12-18 03:12:17 +09:00
|
|
|
list($user, $xml, $trusted) = $data;
|
2010-12-16 07:53:38 +09:00
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
try {
|
|
|
|
$doc = DOMDocument::loadXML($xml);
|
2010-12-16 07:53:38 +09:00
|
|
|
|
2010-12-18 08:55:00 +09:00
|
|
|
$feed = $doc->documentElement;
|
|
|
|
|
|
|
|
if ($feed->namespaceURI != Activity::ATOM ||
|
|
|
|
$feed->localName != 'feed') {
|
2011-04-02 02:46:40 +09:00
|
|
|
// TRANS: Client exception thrown when an imported feed is not an Atom feed.
|
|
|
|
throw new ClientException(_("Not an Atom feed."));
|
2010-12-17 06:17:38 +09:00
|
|
|
}
|
2010-12-16 07:53:38 +09:00
|
|
|
|
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
$author = ActivityUtils::getFeedAuthor($feed);
|
2010-12-16 07:53:38 +09:00
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
if (empty($author)) {
|
2011-04-02 02:46:40 +09:00
|
|
|
// TRANS: Client exception thrown when an imported feed does not have an author.
|
2010-12-18 03:12:17 +09:00
|
|
|
throw new ClientException(_("No author in the feed."));
|
2010-12-16 07:53:38 +09:00
|
|
|
}
|
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
if (empty($user)) {
|
|
|
|
if ($trusted) {
|
|
|
|
$user = $this->userFromAuthor($author);
|
2010-12-18 06:27:20 +09:00
|
|
|
} else {
|
2011-04-02 02:46:40 +09:00
|
|
|
// TRANS: Client exception thrown when an imported feed does not have an author that
|
|
|
|
// TRANS: can be associated with a user.
|
|
|
|
throw new ClientException(_("Cannot import without a user."));
|
2010-12-16 07:53:38 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-12-18 06:27:20 +09:00
|
|
|
$activities = $this->getActivities($feed);
|
2010-12-16 07:53:38 +09:00
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
$qm = QueueManager::get();
|
2010-12-16 07:53:38 +09:00
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
foreach ($activities as $activity) {
|
|
|
|
$qm->enqueue(array($user, $author, $activity, $trusted), 'actimp');
|
2010-12-16 07:53:38 +09:00
|
|
|
}
|
2010-12-18 03:12:17 +09:00
|
|
|
} catch (ClientException $ce) {
|
|
|
|
common_log(LOG_WARNING, $ce->getMessage());
|
|
|
|
return true;
|
|
|
|
} catch (ServerException $se) {
|
|
|
|
common_log(LOG_ERR, $ce->getMessage());
|
|
|
|
return false;
|
|
|
|
} catch (Exception $e) {
|
|
|
|
common_log(LOG_ERR, $ce->getMessage());
|
|
|
|
return false;
|
2010-12-16 07:53:38 +09:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-12-18 06:27:20 +09:00
|
|
|
function getActivities($feed)
|
|
|
|
{
|
|
|
|
$entries = $feed->getElementsByTagNameNS(Activity::ATOM, 'entry');
|
|
|
|
|
|
|
|
$activities = array();
|
|
|
|
|
|
|
|
for ($i = 0; $i < $entries->length; $i++) {
|
|
|
|
$activities[] = new Activity($entries->item($i));
|
|
|
|
}
|
|
|
|
|
|
|
|
usort($activities, array("FeedImporter", "activitySort"));
|
|
|
|
|
|
|
|
return $activities;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sort activities oldest-first
|
|
|
|
*/
|
|
|
|
static function activitySort($a, $b)
|
|
|
|
{
|
|
|
|
if ($a->time == $b->time) {
|
|
|
|
return 0;
|
|
|
|
} else if ($a->time < $b->time) {
|
|
|
|
return -1;
|
|
|
|
} else {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-12-18 03:12:17 +09:00
|
|
|
function userFromAuthor($author)
|
2010-12-16 07:53:38 +09:00
|
|
|
{
|
2013-08-18 20:04:58 +09:00
|
|
|
$user = User::getKV('uri', $author->id);
|
2010-12-16 07:53:38 +09:00
|
|
|
|
|
|
|
if (empty($user)) {
|
|
|
|
$attrs =
|
2010-12-18 03:12:17 +09:00
|
|
|
array('nickname' => Ostatus_profile::getActivityObjectNickname($author),
|
|
|
|
'uri' => $author->id);
|
2010-12-16 07:53:38 +09:00
|
|
|
|
|
|
|
$user = User::register($attrs);
|
|
|
|
}
|
|
|
|
|
|
|
|
$profile = $user->getProfile();
|
2010-12-18 03:12:17 +09:00
|
|
|
Ostatus_profile::updateProfile($profile, $author);
|
2010-12-16 07:53:38 +09:00
|
|
|
|
2011-04-02 02:46:40 +09:00
|
|
|
// @todo FIXME: Update avatar
|
2010-12-16 07:53:38 +09:00
|
|
|
return $user;
|
|
|
|
}
|
|
|
|
}
|