/** * Receipt of a friend request message * @param object $data * @param object $msg * @return */ function friend_request_receive(&$data, &$msg) { // allow only if the server is trusted if (!$msg->validateSignature()) { return true; } $con = new HubbubConnection($msg->ownerEntity->key(), $msg->authorEntity->key()); $usr = new HubbubUser($msg->ownerEntity->key()); WriteToFile('log/activity.log', $data['msgid'] . ' friend_request received' . chr(10)); h2_audit_log('msg/friend_request/rcv', array('me' => $msg->ownerEntity->key(), 'sender' => $msg->authorEntity->key()), $data['msgid']); switch ($con->status()) { case 'req.sent': // if we already sent a request to them, complete the process $con->status('friend'); $usr->notify('friend/added', $msg->authorEntity); $msg->response['comment'] = 'status updated to {friend}'; break; case 'undefined': $con->status('req.rcv'); $usr->notify('friend/request', $msg->authorEntity); $msg->response['comment'] = 'status updated to {received}'; break; default: $msg->response['comment'] = 'status not updated'; break; } $msg->ok(); return true; }
function foreign_post_receive(&$data, &$msg) { if (!$msg->validateSignature()) { return true; } WriteToFile('log/activity.log', $data['msgid'] . ' foreign_post ' . $msg->ownerEntity->key() . ' to ' . $msg->authorEntity->key() . chr(10)); $con = new HubbubConnection($msg->ownerEntity->key(), $msg->authorEntity->key()); if ($con->status() != 'friend') { return $msg->fail('no connection'); } $usr = new HubbubUser($msg->ownerEntity->key()); if ($con->ds['c_auto_approve'] == 'Y') { // if we're gonna approve this anyway, there is no reason to store the message // let's just create a post out of this WriteToFile('log/activity.log', $data['msgid'] . ' foreign_post received, accepted' . chr(10)); $post = new HubbubMessage('post'); $npid = $post->data['msgid']; $post->data = $msg->data; $post->data['type'] = 'post'; $post->data['msgid'] = $npid; $post->author($msg->authorEntity->ds); $post->owner($msg->ownerEntity->ds); $post->data['changed'] = time(); $post->data['received'] = time(); $post->data['rel']['foreign'] = $data['msgid']; $post->save(); WriteToFile('log/activity.log', $post->data['msgid'] . ' created from foreign_post' . chr(10)); $msg->response['post'] = $post->data; $msg->doSave = false; $usr->notify('fpost/new', $msg->authorEntity, $msg); } else { // if not, let's store this message for later approval $usr->notify('fpost/approve', $msg->authorEntity, $msg); $msg->vTag = 'A'; $msg->save(); } $msg->ok(); }