aboutsummaryrefslogtreecommitdiffstats
path: root/mod/sitelist.php
blob: 4e52f04632b9f96d3996680eaaca2040dec1f073 (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
<?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 $start, $limit ";

	$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 1 $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();
			

}