diff options
author | friendica <info@friendica.com> | 2013-01-29 02:04:07 -0800 |
---|---|---|
committer | friendica <info@friendica.com> | 2013-01-29 02:05:21 -0800 |
commit | b2d03eb55c9e1047f39a2f7fb3a57f3631e12924 (patch) | |
tree | 2b2be7505a9e1c8129b1202e07e7859c7bb44971 /include/follow.php | |
parent | 3cf3f7437ea4c25c7a7fdcf04bfcf72be2d32698 (diff) | |
download | volse-hubzilla-b2d03eb55c9e1047f39a2f7fb3a57f3631e12924.tar.gz volse-hubzilla-b2d03eb55c9e1047f39a2f7fb3a57f3631e12924.tar.bz2 volse-hubzilla-b2d03eb55c9e1047f39a2f7fb3a57f3631e12924.zip |
convert mod/follow to associative json and add more logging for when things go wrong
Diffstat (limited to 'include/follow.php')
-rw-r--r-- | include/follow.php | 34 |
1 files changed, 23 insertions, 11 deletions
diff --git a/include/follow.php b/include/follow.php index 7fc4c2dc6..cf77c40ea 100644 --- a/include/follow.php +++ b/include/follow.php @@ -37,14 +37,26 @@ function new_contact($uid,$url,$channel,$interactive = false) { $ret = zot_finger($url,$channel); if($ret['success']) { - $j = json_decode($ret['body']); - + $j = json_decode($ret['body'],true); + } + else { + $result['message'] = t('Channel discovery failed. Website may be down or misconfigured.'); + logger('mod_follow: ' . $result['message']); + return $result; } logger('follow: ' . $url . ' ' . print_r($j,true)); - if(! ($j->success && $j->guid)) { - $result['message'] = t('Unable to communicate with requested channel.'); + if(! $j) { + $result['message'] = t('Response from remote channel was not understood.'); + logger('mod_follow: ' . $result['message']); + return $result; + } + + + if(! ($j['success'] && $j['guid'])) { + $result['message'] = t('Response from remote channel was incomplete.'); + logger('mod_follow: ' . $result['message']); return $result; } @@ -66,7 +78,7 @@ function new_contact($uid,$url,$channel,$interactive = false) { // do we have an xchan and hubloc? // If not, create them. - $x = import_xchan_from_json($j); + $x = import_xchan($j); if(! $x['success']) return $x; @@ -78,18 +90,18 @@ function new_contact($uid,$url,$channel,$interactive = false) { $global_perms = get_perms(); - if($j->permissions->data) { + if( array_key_exists('permissions',$j) && array_key_exists('data',$j['permissions'])) { $permissions = aes_unencapsulate(array( - 'data' => $j->permissions->data, - 'key' => $j->permissions->key, - 'iv' => $j->permissions->iv), + 'data' => $j['permissions']['data'], + 'key' => $j['permissions']['key'], + 'iv' => $j['permissions']['iv']), $channel['channel_prvkey']); if($permissions) - $permissions = json_decode($permissions); + $permissions = json_decode($permissions,true); logger('decrypted permissions: ' . print_r($permissions,true), LOGGER_DATA); } else - $permissions = $j->permissions; + $permissions = $j['permissions']; foreach($permissions as $k => $v) { if($v) { |