6a8a36f12d
- count() returns very different results and never a boolean (not even false on error condition). - therefore you should NOT use it in boolean expressions. This still *can* be done in PHP because of its lazyness. But it is discouraged if it comes to more clean code. Signed-off-by: Roland Häder <roland@mxchange.org>
50 lines
No EOL
1 KiB
PHP
50 lines
No EOL
1 KiB
PHP
<?php
|
|
|
|
require_once('include/group.php');
|
|
|
|
function contactgroup_content(&$a) {
|
|
|
|
|
|
if(! local_user()) {
|
|
killme();
|
|
}
|
|
|
|
if(($a->argc > 2) && intval($a->argv[1]) && intval($a->argv[2])) {
|
|
$r = q("SELECT `id` FROM `contact` WHERE `id` = %d AND `uid` = %d and `self` = 0 and `blocked` = 0 AND `pending` = 0 LIMIT 1",
|
|
intval($a->argv[2]),
|
|
intval(local_user())
|
|
);
|
|
if(dbm::is_result($r))
|
|
$change = intval($a->argv[2]);
|
|
}
|
|
|
|
if(($a->argc > 1) && (intval($a->argv[1]))) {
|
|
|
|
$r = q("SELECT * FROM `group` WHERE `id` = %d AND `uid` = %d AND `deleted` = 0 LIMIT 1",
|
|
intval($a->argv[1]),
|
|
intval(local_user())
|
|
);
|
|
if(! dbm::is_result($r)) {
|
|
killme();
|
|
}
|
|
|
|
$group = $r[0];
|
|
$members = group_get_members($group['id']);
|
|
$preselected = array();
|
|
if(count($members)) {
|
|
foreach($members as $member)
|
|
$preselected[] = $member['id'];
|
|
}
|
|
|
|
if($change) {
|
|
if(in_array($change,$preselected)) {
|
|
group_rmv_member(local_user(),$group['name'],$change);
|
|
}
|
|
else {
|
|
group_add_member(local_user(),$group['name'],$change);
|
|
}
|
|
}
|
|
}
|
|
|
|
killme();
|
|
} |