diff options
author | friendica <info@friendica.com> | 2014-11-23 18:22:19 -0800 |
---|---|---|
committer | friendica <info@friendica.com> | 2014-11-23 18:22:19 -0800 |
commit | 5bb794cc2852f3a53526b15dcd610a002ce86563 (patch) | |
tree | 9988b1d33132d566c529f00663c3abdc9be8f740 /mod/dirsearch.php | |
parent | 746e4860faae897ef1a5a2bc6c4378454dac33ab (diff) | |
download | volse-hubzilla-5bb794cc2852f3a53526b15dcd610a002ce86563.tar.gz volse-hubzilla-5bb794cc2852f3a53526b15dcd610a002ce86563.tar.bz2 volse-hubzilla-5bb794cc2852f3a53526b15dcd610a002ce86563.zip |
allow directory searches to be filtered by (public forums) and/or (! public forums)
Diffstat (limited to 'mod/dirsearch.php')
-rw-r--r-- | mod/dirsearch.php | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/mod/dirsearch.php b/mod/dirsearch.php index 56e2378a8..1ecf33393 100644 --- a/mod/dirsearch.php +++ b/mod/dirsearch.php @@ -64,6 +64,9 @@ function dirsearch_content(&$a) { $agege = ((x($_REQUEST,'agege')) ? intval($_REQUEST['agege']) : 0 ); $agele = ((x($_REQUEST,'agele')) ? intval($_REQUEST['agele']) : 0 ); $kw = ((x($_REQUEST,'kw')) ? intval($_REQUEST['kw']) : 0 ); + $forums = ((array_key_exists('pubforums',$_REQUEST)) ? intval($_REQUEST['pubforums']) : null); + + // by default use a safe search $safe = ((x($_REQUEST,'safe'))); // ? intval($_REQUEST['safe']) : 1 ); @@ -108,6 +111,10 @@ function dirsearch_content(&$a) { if($keywords) $sql_extra .= dir_query_build($joiner,'xprof_keywords',$keywords); + if(! is_null($forums)) + $sql_extra .= dir_flag_build($joiner,'xprof_flags',XCHAN_FLAGS_PUBFORUM, $forums); + + // we only support an age range currently. You must set both agege // (greater than or equal) and agele (less than or equal) @@ -179,7 +186,6 @@ function dirsearch_content(&$a) { else $order = " order by xchan_name_date desc "; - if($sync) { $spkt = array('transactions' => array()); $r = q("select * from updates where ud_date >= '%s' and ud_guid != '' order by ud_date desc", @@ -273,6 +279,11 @@ function dir_query_build($joiner,$field,$s) { return $ret; } +function dir_flag_build($joiner,$field,$bit,$s) { + return dbesc($joiner) . " ( " . dbesc('xchan_flags') . " & " . intval($bit) . " ) " . ((intval($s)) ? '>' : '=' ) . " 0 "; +} + + function dir_parse_query($s) { $ret = array(); |