diff options
author | friendica <info@friendica.com> | 2012-12-18 19:10:56 -0800 |
---|---|---|
committer | friendica <info@friendica.com> | 2012-12-18 19:10:56 -0800 |
commit | 44e70bdca367344c441b1e26e790ac0465953734 (patch) | |
tree | 8dcee9d777dd4ed6fd11264d6dcb48ad53d78ae0 /include | |
parent | e9c87a69ce1a78e0790241467961bfab465b3358 (diff) | |
download | volse-hubzilla-44e70bdca367344c441b1e26e790ac0465953734.tar.gz volse-hubzilla-44e70bdca367344c441b1e26e790ac0465953734.tar.bz2 volse-hubzilla-44e70bdca367344c441b1e26e790ac0465953734.zip |
send stuff to zothub as a fallback directory master for now
Diffstat (limited to 'include')
-rw-r--r-- | include/directory.php | 45 |
1 files changed, 37 insertions, 8 deletions
diff --git a/include/directory.php b/include/directory.php index f35cb4cb4..5b5698768 100644 --- a/include/directory.php +++ b/include/directory.php @@ -1,27 +1,56 @@ <?php require_once('boot.php'); +require_once('include/zot.php'); require_once('include/cli_startup.php'); +function find_upstream_directory($dirmode) { + return; +} + function directory_run($argv, $argc){ cli_startup(); - if(argc() != 2) + if($argc != 2) return; - $dir = get_config('system','directory_submit_url'); + $dirmode = get_config('system','directory_mode'); + if($dirmode === false) + $dirmode = DIRECTORY_MODE_NORMAL; - if(! strlen($dir)) + if(($dirmode == DIRECTORY_MODE_PRIMARY) || ($dirmode == DIRECTORY_MODE_STANDALONE)) { + // syncdirs(); return; + } - $arr = array('url' => argv(1)); + $x = q("select * from channel where channel_id = %d limit 1", + intval($argv[1]) + ); + if(! $x) + return; - call_hooks('globaldir_update', $arr); + $channel = $x[0]; - if(strlen($arr['url'])) - fetch_url($dir . '?url=' . bin2hex($arr['url'])); + // is channel profile visible to the public? + // FIXME - remove dir entry if permission is revoked + + if(! perm_is_allowed($channel['channel_id'],null,'view_profile')) + return; + + $directory = find_upstream_directory($dirmode); + + if($directory) { + $url = $directory['url']; + } + else { + $url = DIRECTORY_FALLBACK_MASTER . '/post'; + } + + $packet = zot_build_packet($channel,'refresh'); + $z = zot_zot($url,$packet); + + // re-queue if unsuccessful - return; } if (array_search(__file__,get_included_files())===0){ |