aboutsummaryrefslogtreecommitdiffstats
path: root/mod/receive.php
blob: 46b1f2745684e6cb513a192d2a480cd1ab351fde (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<?php

/**
 * Diaspora endpoint
 */


require_once('include/salmon.php');
require_once('include/crypto.php');
require_once('include/diaspora.php');


	
function receive_post(&$a) {

	if($a->argc != 3 || $a->argv[1] !== 'users')
		http_status_exit(500);

	$guid = $a->argv[2];

	$r = q("SELECT * FROM `user` WHERE `guid` = '%s' LIMIT 1",
		dbesc($guid)
	);
	if(! count($r))
		http_status_exit(500);

	$importer = $r[0];

	// I really don't know why we need urldecode - PHP should be doing this for us.
	// It is an application/x-www-form-urlencoded

	$xml = urldecode($_POST['xml']);

	logger('mod-diaspora: new salmon ' . $xml, LOGGER_DATA);

	if(! $xml)
		http_status_exit(500);

	$msg = diaspora_decode($importer,$xml);

	logger('mod-diaspora: decoded msg: ' . $msg, LOGGER_DATA);

	if(! $msg)
		http_status_exit(500);


	$parsed_xml = parse_xml_string($msg,false);

	$xmlbase = $parsed_xml->post;

	// If we reached this point, the message is good. 
	// Now let's figure out if the author is allowed to send us stuff.

	$r = q("SELECT * FROM `contact` WHERE `network` = 'dspr' AND ( `url` = '%s' OR `alias` = '%s') 
		AND `uid` = %d LIMIT 1",
		dbesc($author_link),
		dbesc($author_link),
		intval($importer['uid'])
	);
	if(! count($r)) {
		logger('mod-diaspora: Author unknown to us.');
	}	

	// is this a follower? Or have we ignored the person?
	// If so we can not accept this post.
	// However we will accept a sharing e.g. friend request
	// or a retraction of same.


	$allow_blocked = (($xmlbase->request || ($xmlbase->retraction && $xmlbase->retraction->type == 'Person')) ? true : false);

	if((count($r)) 
		&& (($r[0]['rel'] == CONTACT_IS_FOLLOWER) || ($r[0]['blocked']) || ($r[0]['readonly'])) 
		&& (! $allow_blocked)) {
			logger('mod-diaspora: Ignoring this author.');
			http_status_exit(202);
			// NOTREACHED
	}

	require_once('include/items.php');

	$contact = ((count($r)) ? $r[0] : null);

	if($xmlbase->request) {
		diaspora_request($importer,$contact,$xmlbase->request);
	}
	elseif($xmlbase->status_message) {
		diaspora_post($importer,$contact,$xmlbase->status_message);
	}
	elseif($xmlbase->comment) {
		diaspora_comment($importer,$contact,$xmlbase->comment);
	}
	elseif($xmlbase->like) {
		diaspora_like($importer,$contact,$xmlbase->like);
	}
	elseif($xmlbase->retraction) {
		diaspora_retraction($importer,$contact,$xmlbase->retraction);
	}
	else {
		logger('mod-diaspora: unknown message type: ' . print_r($xmlbase,true));
	}

	http_status_exit(200);
	// NOTREACHED
}