forked from GNUsocial/gnu-social
more work on salmon
This commit is contained in:
parent
eea52c708b
commit
80ef3946d0
@ -62,20 +62,146 @@ class SalmonAction extends Action
|
|||||||
// XXX: check the signature
|
// XXX: check the signature
|
||||||
|
|
||||||
$this->act = new Activity($dom->documentElement);
|
$this->act = new Activity($dom->documentElement);
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function handle($args)
|
function handle($args)
|
||||||
{
|
{
|
||||||
common_log(LOG_DEBUG, 'Salmon: incoming post for user: '. $user_id);
|
common_log(LOG_INFO, 'Salmon: incoming post for user '. $this->user->id);
|
||||||
|
|
||||||
// TODO : Insert new $xml -> notice code
|
// TODO : Insert new $xml -> notice code
|
||||||
|
|
||||||
switch ($this->act->verb)
|
if (Event::handle('StartHandleSalmon', array($this->user, $this->activity))) {
|
||||||
{
|
switch ($this->act->verb)
|
||||||
case Activity::POST:
|
{
|
||||||
case Activity::SHARE:
|
case ActivityVerb::POST:
|
||||||
case Activity::FAVORITE:
|
$this->handlePost();
|
||||||
case Activity::FOLLOW:
|
break;
|
||||||
|
case ActivityVerb::SHARE:
|
||||||
|
$this->handleShare();
|
||||||
|
break;
|
||||||
|
case ActivityVerb::FAVORITE:
|
||||||
|
$this->handleFavorite();
|
||||||
|
break;
|
||||||
|
case ActivityVerb::FOLLOW:
|
||||||
|
case ActivityVerb::FRIEND:
|
||||||
|
$this->handleFollow();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
Event::handle('EndHandleSalmon', array($this->user, $this->activity));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function handlePost()
|
||||||
|
{
|
||||||
|
switch ($this->act->object->type) {
|
||||||
|
case ActivityObject::ARTICLE:
|
||||||
|
case ActivityObject::BLOGENTRY:
|
||||||
|
case ActivityObject::NOTE:
|
||||||
|
case ActivityObject::STATUS:
|
||||||
|
case ActivityObject::COMMENT:
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new Exception("Can't handle that kind of post.");
|
||||||
|
}
|
||||||
|
|
||||||
|
$profile = $this->ensureProfile();
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleFollow()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleFavorite()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleShare()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
function ensureProfile()
|
||||||
|
{
|
||||||
|
$actor = $this->act->actor;
|
||||||
|
|
||||||
|
if (empty($actor->id)) {
|
||||||
|
throw new Exception("Received a salmon slap from unidentified actor.");
|
||||||
|
}
|
||||||
|
|
||||||
|
$ostatusProfile = Ostatus_profile::staticGet('homeuri', $actor->id);
|
||||||
|
|
||||||
|
if (empty($ostatusProfile)) {
|
||||||
|
return $this->createProfile();
|
||||||
|
} else {
|
||||||
|
// XXX: can we receive a salmon slap from a group...?
|
||||||
|
assert(!empty($ostatusProfile->profile_id));
|
||||||
|
return Profile::staticGet($ostatusProfile->profile_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function createProfile()
|
||||||
|
{
|
||||||
|
$actor = $this->act->actor;
|
||||||
|
|
||||||
|
$profile = new Profile();
|
||||||
|
|
||||||
|
$profile->nickname = $this->nicknameFromURI($actor->id);
|
||||||
|
|
||||||
|
if (empty($profile->nickname)) {
|
||||||
|
$profile->nickname = common_nicknamize($actor->title);
|
||||||
|
}
|
||||||
|
|
||||||
|
$profile->fullname = $actor->title;
|
||||||
|
$profile->bio = $actor->summary; // XXX: is that right?
|
||||||
|
$profile->profileurl = $actor->link; // XXX: is that right?
|
||||||
|
$profile->created = common_sql_now();
|
||||||
|
|
||||||
|
$id = $profile->insert();
|
||||||
|
|
||||||
|
if (empty($id)) {
|
||||||
|
common_log_db_error($profile, 'INSERT', __FILE__);
|
||||||
|
throw new Exception("Couldn't save new profile for $actor->id\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
// XXX: add avatars
|
||||||
|
|
||||||
|
$op = new Ostatus_profile();
|
||||||
|
|
||||||
|
$op->profile_id = $id;
|
||||||
|
$op->homeuri = $actor->id;
|
||||||
|
$op->created = $profile->created;
|
||||||
|
|
||||||
|
// XXX: determine feed URI from source or Webfinger or whatever
|
||||||
|
|
||||||
|
$id = $op->insert();
|
||||||
|
|
||||||
|
if (empty($id)) {
|
||||||
|
common_log_db_error($op, 'INSERT', __FILE__);
|
||||||
|
throw new Exception("Couldn't save new ostatus profile for $actor->id\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
return $profile;
|
||||||
|
}
|
||||||
|
|
||||||
|
function nicknameFromURI($uri)
|
||||||
|
{
|
||||||
|
preg_match('/(\w+):/', $uri, $matches);
|
||||||
|
|
||||||
|
$protocol = $matches[1];
|
||||||
|
|
||||||
|
switch ($protocol) {
|
||||||
|
case 'acct':
|
||||||
|
case 'mailto':
|
||||||
|
if (preg_match("/^$protocol:(.*)?@.*\$/", $uri, $matches)) {
|
||||||
|
return common_canonical_nickname($matches[1]);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
case 'http':
|
||||||
|
return common_url_to_nickname($uri);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user