diff options
author | friendica <info@friendica.com> | 2014-11-10 15:21:04 -0800 |
---|---|---|
committer | friendica <info@friendica.com> | 2014-11-10 15:21:04 -0800 |
commit | 62094652333514e92f9f00699e14b9f49680bb64 (patch) | |
tree | f61a8410d6c469c5ae5b7b3aa69cfb8dd5a956a7 /mod/zfinger.php | |
parent | 0b4575a40b5412f0497c50560b0510a304599086 (diff) | |
download | volse-hubzilla-62094652333514e92f9f00699e14b9f49680bb64.tar.gz volse-hubzilla-62094652333514e92f9f00699e14b9f49680bb64.tar.bz2 volse-hubzilla-62094652333514e92f9f00699e14b9f49680bb64.zip |
add public forum identification to libzot. No attempt is made to identify other types of forums or weird custom channel permissions. If the channel is auto-accept and taggable, it's a public forum.
Diffstat (limited to 'mod/zfinger.php')
-rw-r--r-- | mod/zfinger.php | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/mod/zfinger.php b/mod/zfinger.php index 666f141ec..c2aebc675 100644 --- a/mod/zfinger.php +++ b/mod/zfinger.php @@ -108,6 +108,21 @@ function zfinger_init(&$a) { if($deleted || $censored) $searchable = false; + $public_forum = false; + + $role = get_pconfig($e['channel_id'],'system','permissions_role'); + if($role === 'forum') { + $public_forum = true; + } + else { + // check if it has characteristics of a public forum based on custom permissions. + $t = q("select abook_my_perms from abook where abook_channel = %d and (abook_flags & %d) limit 1", + intval($e['channel_id']), + intval(ABOOK_FLAG_SELF) + ); + if($t && ($t[0]['abook_my_perms'] & PERMS_W_TAGWALL)) + $public_forum = true; + } // This is for birthdays and keywords, but must check access permissions @@ -174,6 +189,7 @@ function zfinger_init(&$a) { $ret['target_sig'] = $zsig; $ret['searchable'] = $searchable; $ret['adult_content'] = $adult_channel; + $ret['public_forum'] = $public_forum; if($deleted) $ret['deleted'] = $deleted; |