1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/hubzilla_ynh.git synced 2024-09-03 19:26:21 +02:00
hubzilla_ynh/sources/mod/sitelist.php
2015-08-23 16:38:18 -04:00

58 lines
No EOL
1.4 KiB
PHP

<?php /** @file */
function sitelist_init(&$a) {
$start = (($_REQUEST['start']) ? intval($_REQUEST['start']) : 0);
$limit = ((intval($_REQUEST['limit'])) ? intval($_REQUEST['limit']) : 30);
$order = (($_REQUEST['order']) ? $_REQUEST['order'] : 'random');
$open = (($_REQUEST['open']) ? intval($_REQUEST['open']) : false);
$sql_order = " order by site_url ";
$rand = db_getfunc('rand');
if($order == 'random')
$sql_order = " order by $rand ";
$sql_limit = " LIMIT $limit OFFSET $start ";
$sql_extra = "";
if($open)
$sql_extra = " and site_register = " . intval(REGISTER_OPEN) . " ";
$realm = get_directory_realm();
if($realm == DIRECTORY_REALM) {
$sql_extra .= " and ( site_realm = '" . dbesc($realm) . "' or site_realm = '') ";
}
else
$sql_extra .= " and site_realm = '" . dbesc($realm) . "' ";
$result = array('success' => false);
$r = q("select count(site_url) as total from site where true $sql_extra ");
if($r)
$result['total'] = intval($r[0]['total']);
$result['start'] = $start;
$result['limit'] = $limit;
$r = q("select * from site where true $sql_extra $sql_order $sql_limit");
$result['results'] = 0;
$result['entries'] = array();
if($r) {
$result['success'] = true;
$result['results'] = count($r);
foreach($r as $rr) {
$result['entries'][] = array('url' => $rr['site_url']);
}
}
echo json_encode($result);
killme();
}