8 use Friendica\Core\Config;
9 use Friendica\Database\DBM;
10 use Friendica\Protocol\Diaspora;
12 require_once('include/salmon.php');
13 require_once('include/crypto.php');
15 function receive_post(App $a) {
16 $enabled = intval(Config::get('system', 'diaspora_enabled'));
18 logger('mod-diaspora: disabled');
19 http_status_exit(500);
22 if (($a->argc == 2) && ($a->argv[1] === 'public')) {
28 if ($a->argc != 3 || $a->argv[1] !== 'users') {
29 http_status_exit(500);
33 $importer = dba::select('user', array(), array('guid' => $guid, 'account_expired' => false, 'account_removed' => false), array('limit' => 1));
34 if (!DBM::is_result($importer)) {
35 http_status_exit(500);
39 // It is an application/x-www-form-urlencoded
41 logger('mod-diaspora: receiving post', LOGGER_DEBUG);
43 $xml = urldecode($_POST['xml']);
46 $postdata = file_get_contents("php://input");
47 if ($postdata == '') {
48 http_status_exit(500);
51 logger('mod-diaspora: message is in the new format', LOGGER_DEBUG);
52 $msg = Diaspora::decode_raw($importer, $postdata);
54 logger('mod-diaspora: decode message in the old format', LOGGER_DEBUG);
55 $msg = Diaspora::decode($importer, $xml);
57 if ($public && !$msg) {
58 logger('mod-diaspora: decode message in the new format', LOGGER_DEBUG);
59 $msg = Diaspora::decode_raw($importer, $xml);
63 logger('mod-diaspora: decoded', LOGGER_DEBUG);
65 logger('mod-diaspora: decoded msg: ' . print_r($msg, true), LOGGER_DATA);
67 if (!is_array($msg)) {
68 http_status_exit(500);
71 logger('mod-diaspora: dispatching', LOGGER_DEBUG);
75 Diaspora::dispatch_public($msg);
77 $ret = Diaspora::dispatch($importer, $msg);
80 http_status_exit(($ret) ? 200 : 500);