Fix upcoming killme() in index.php change

- Add killme() in controllers instead of relying on index.php
- Fix formatting
This commit is contained in:
Hypolite Petovan 2017-08-01 21:33:50 -04:00
parent 4601c4bd8a
commit 687eef90f7
7 changed files with 73 additions and 59 deletions

View file

@ -79,4 +79,6 @@ function directory_content(App $a)
'results' => $r, 'results' => $r,
'filter' => $forums ? 'forums' : '', 'filter' => $forums ? 'forums' : '',
)); ));
killme();
} }

View file

@ -1,10 +1,13 @@
<?php <?php
use Friendica\Directory\Rendering\View; use Friendica\Directory\Rendering\View;
if(! function_exists('help_content')) { if (!function_exists('help_content')) {
function help_content(&$a) { function help_content(&$a)
$view = new View('help'); {
$view->output(); $view = new View('help');
} $view->output();
}
killme();
}
}

View file

@ -5,13 +5,14 @@ use Friendica\Directory\Helper\Profile as ProfileHelper;
if(! function_exists('home_content')) { if(! function_exists('home_content')) {
function home_content(&$a) { function home_content(&$a) {
$profiles = q("SELECT * FROM profile WHERE comm=1 AND LENGTH(pdesc)>0 ORDER BY RAND() LIMIT 3"); $profiles = q("SELECT * FROM profile WHERE comm=1 AND LENGTH(pdesc)>0 ORDER BY RAND() LIMIT 3");
$view = new View('homepage', 'minimal'); $view = new View('homepage', 'minimal');
$view->addHelper('photoUrl', ProfileHelper::get('photoUrl')); $view->addHelper('photoUrl', ProfileHelper::get('photoUrl'));
$view->output(array( $view->output(array(
'profiles' => $profiles 'profiles' => $profiles
)); ));
killme();
}} }}

View file

@ -94,4 +94,6 @@ function search_content(App $a)
'filter' => $filter, 'filter' => $filter,
'query' => x($_GET, 'query') ? $_GET['query'] : '' 'query' => x($_GET, 'query') ? $_GET['query'] : ''
)); ));
killme();
} }

View file

@ -4,17 +4,17 @@ use Friendica\Directory\Rendering\View;
require_once 'include/site-health.php'; require_once 'include/site-health.php';
function servers_content(&$a) { function servers_content(&$a)
{
$sites = array(); $sites = array();
//Find the user count per site. //Find the user count per site.
$r = q("SELECT `homepage` FROM `profile`"); $r = q("SELECT `homepage` FROM `profile`");
if(count($r)) { if (count($r)) {
foreach($r as $rr) { foreach ($r as $rr) {
$site = parse_site_from_url($rr['homepage']); $site = parse_site_from_url($rr['homepage']);
if($site) { if ($site) {
if(!isset($sites[$site])) if (!isset($sites[$site]))
$sites[$site] = 0; $sites[$site] = 0;
$sites[$site] ++; $sites[$site] ++;
} }
@ -26,8 +26,8 @@ function servers_content(&$a) {
$site_healths = array(); $site_healths = array();
$r = q("SELECT * FROM `site-health` WHERE `reg_policy`='REGISTER_OPEN' AND `ssl_state` = 1"); $r = q("SELECT * FROM `site-health` WHERE `reg_policy`='REGISTER_OPEN' AND `ssl_state` = 1");
if(count($r)) { if (count($r)) {
foreach($r as $rr) { foreach ($r as $rr) {
if (isset($sites[$rr['base_url']])) { if (isset($sites[$rr['base_url']])) {
$sites_with_health[$rr['base_url']] = (($sites[$rr['base_url']] / 100) + 10) * intval($rr['health_score']); $sites_with_health[$rr['base_url']] = (($sites[$rr['base_url']] / 100) + 10) * intval($rr['health_score']);
$site_healths[$rr['base_url']] = $rr; $site_healths[$rr['base_url']] = $rr;
@ -38,17 +38,20 @@ function servers_content(&$a) {
arsort($sites_with_health); arsort($sites_with_health);
$total = 0; $total = 0;
$public_sites = array(); $public_sites = array();
foreach($sites_with_health as $k => $v)
{
foreach ($sites_with_health as $k => $v) {
//Stop at unhealthy sites. //Stop at unhealthy sites.
$site = $site_healths[$k]; $site = $site_healths[$k];
if($site['health_score'] <= 20) break; if ($site['health_score'] <= 20) {
break;
}
//Skip small sites. //Skip small sites.
$users = $sites[$k]; $users = $sites[$k];
if($users < 5) continue; if ($users < 5) {
continue;
}
//Add health score name and user count. //Add health score name and user count.
$site['health_score_name'] = health_score_to_name($site['health_score']); $site['health_score_name'] = health_score_to_name($site['health_score']);
@ -57,33 +60,33 @@ function servers_content(&$a) {
//Figure out what this server supports. //Figure out what this server supports.
$plugins = explode("\r\n", $site['plugins']); $plugins = explode("\r\n", $site['plugins']);
$site['plugins'] = $plugins; $site['plugins'] = $plugins;
$hasPlugin = function(array $input)use($plugins){ $hasPlugin = function (array $input) use ($plugins) {
return !!count(array_intersect($input, $plugins)); return !!count(array_intersect($input, $plugins));
}; };
$site['supports'] = array( $site['supports'] = array(
'HTTPS' => $site['ssl_state'] == 1, 'HTTPS' => $site['ssl_state'] == 1,
'Twitter' => $hasPlugin(array('buffer', 'twitter')), 'Twitter' => $hasPlugin(array('buffer', 'twitter')),
'Facebook' => $hasPlugin(array('buffer')), 'Facebook' => $hasPlugin(array('buffer')),
'Google+' => $hasPlugin(array('buffer', 'gpluspost')), 'Google+' => $hasPlugin(array('buffer', 'gpluspost')),
'RSS/Atom' => true, //Built-in. 'RSS/Atom' => true, //Built-in.
'Diaspora*' => $hasPlugin(array('diaspora')), 'Diaspora*' => $hasPlugin(array('diaspora')),
'pump.io' => $hasPlugin(array('pumpio')), 'pump.io' => $hasPlugin(array('pumpio')),
'StatusNet' => $hasPlugin(array('statusnet')), 'StatusNet' => $hasPlugin(array('statusnet')),
'Tumblr' => $hasPlugin(array('tumblr')), 'Tumblr' => $hasPlugin(array('tumblr')),
'Blogger' => $hasPlugin(array('blogger')), 'Blogger' => $hasPlugin(array('blogger')),
'Dreamwidth' => $hasPlugin(array('dwpost')), 'Dreamwidth' => $hasPlugin(array('dwpost')),
'Wordpress' => $hasPlugin(array('wppost')), 'Wordpress' => $hasPlugin(array('wppost')),
'LiveJournal' => $hasPlugin(array('ljpost')), 'LiveJournal' => $hasPlugin(array('ljpost')),
'Insanejournal' => $hasPlugin(array('ijpost')), 'Insanejournal' => $hasPlugin(array('ijpost')),
'Libertree' => $hasPlugin(array('libertree')) 'Libertree' => $hasPlugin(array('libertree'))
); );
//Subset of the full support list, to show popular items. //Subset of the full support list, to show popular items.
$site['popular_supports'] = array( $site['popular_supports'] = array(
'HTTPS' => $site['supports']['HTTPS'], 'HTTPS' => $site['supports']['HTTPS'],
'Twitter' => $site['supports']['Twitter'], 'Twitter' => $site['supports']['Twitter'],
'Google+' => $site['supports']['Google+'], 'Google+' => $site['supports']['Google+'],
'Wordpress' => $site['supports']['Wordpress'] 'Wordpress' => $site['supports']['Wordpress']
); );
@ -92,9 +95,9 @@ function servers_content(&$a) {
//Get the difference. //Get the difference.
$site['supports_more'] = 0; $site['supports_more'] = 0;
foreach ($site['supports'] as $key => $value){ foreach ($site['supports'] as $key => $value) {
if($value && !array_key_exists($key, $site['popular_supports'])){ if ($value && !array_key_exists($key, $site['popular_supports'])) {
$site['supports_more']++; $site['supports_more'] ++;
} }
} }
@ -103,25 +106,24 @@ function servers_content(&$a) {
//Count the result. //Count the result.
$total ++; $total ++;
} }
//In case we asked for a surprise, pick a random one from the top 10! :D //In case we asked for a surprise, pick a random one from the top 10! :D
if($a->argc > 1 && $a->argv[1] == 'surprise'){ if ($a->argc > 1 && $a->argv[1] == 'surprise') {
$max = min(count($public_sites), 10); $max = min(count($public_sites), 10);
$i = mt_rand(0, $max-1); $i = mt_rand(0, $max - 1);
$surpriseSite = $public_sites[$i]; $surpriseSite = $public_sites[$i];
header('Location:'.$surpriseSite['base_url'].'/register'); header('Location:' . $surpriseSite['base_url'] . '/register');
exit; exit;
} }
//Show results. //Show results.
$view = new View('servers'); $view = new View('servers');
$view->output(array( $view->output(array(
'total' => number_format($total), 'total' => number_format($total),
'sites' => $public_sites 'sites' => $public_sites
)); ));
killme();
} }

View file

@ -1,10 +1,14 @@
<?php <?php
use Friendica\Directory\Rendering\View; use Friendica\Directory\Rendering\View;
if(! function_exists('stats_content')) { if (!function_exists('stats_content')) {
function stats_content(&$a) { function stats_content(&$a)
$view = new View('stats'); {
$view->output(); $view = new View('stats');
} $view->output();
killme();
}
} }

View file

@ -10,11 +10,11 @@
Keep in mind that different servers may support different features like communicating with additional networks besides Friendica. Keep in mind that different servers may support different features like communicating with additional networks besides Friendica.
It's best to pick the one that best suits your needs. It's best to pick the one that best suits your needs.
</p> </p>
<div class="feeling-lucky"> <div class="feeling-lucky">
<a class="btn surprise" href="/servers/surprise">Surprise me &raquo;</a> <a class="btn surprise" href="/servers/surprise">Surprise me &raquo;</a>
</div> </div>
<h3>Recommending <?php echo $total; ?> public servers</h3> <h3>Recommending <?php echo $total; ?> public servers</h3>
<?php <?php
foreach ($sites as $site) foreach ($sites as $site)