2010-07-05 03:33:02 -07:00
< ? php
function group_add ( $uid , $name ) {
2010-07-12 23:08:07 -07:00
2010-07-05 03:33:02 -07:00
$ret = false ;
if ( x ( $uid ) && x ( $name )) {
$r = group_byname ( $uid , $name ); // check for dups
if ( $r !== false )
return true ;
2010-07-11 06:06:30 -07:00
$r = q ( " INSERT INTO `group` ( `uid`, `name` )
2010-07-05 03:33:02 -07:00
VALUES ( % d , '%s' ) " ,
intval ( $uid ),
dbesc ( $name )
);
$ret = $r ;
}
return $ret ;
}
function group_rmv ( $uid , $name ) {
$ret = false ;
if ( x ( $uid ) && x ( $name )) {
$r = q ( " SELECT * FROM `group` WHERE `uid` = %d AND `name` = '%s' LIMIT 1 " ,
intval ( $uid ),
dbesc ( $name )
2010-07-11 02:52:47 -07:00
);
2010-07-05 03:33:02 -07:00
if ( count ( $r ))
$group_id = $r [ 0 ][ 'id' ];
if ( ! $group_id )
return false ;
// remove all members
$r = q ( " DELETE FROM `group_member` WHERE `uid` = %d AND `gid` = %d " ,
intval ( $uid ),
intval ( $group_id )
);
// remove group
2010-08-11 04:14:47 -07:00
$r = q ( " UPDATE `group` SET `deleted` = 1 WHERE `uid` = %d AND `name` = '%s' LIMIT 1 " ,
2010-07-05 03:33:02 -07:00
intval ( $uid ),
dbesc ( $name )
);
$ret = $r ;
}
return $ret ;
}
function group_byname ( $uid , $name ) {
if (( ! $uid ) || ( ! strlen ( $name )))
return false ;
$r = q ( " SELECT * FROM `group` WHERE `uid` = %d AND `name` = '%s' LIMIT 1 " ,
intval ( $uid ),
dbesc ( $name )
);
if ( count ( $r ))
return $r [ 0 ][ 'id' ];
return false ;
}
function group_rmv_member ( $uid , $name , $member ) {
$gid = group_byname ( $uid , $name );
if ( ! $gid )
return false ;
if ( ! ( $uid && $gid && $member ))
return false ;
$r = q ( " DELETE FROM `group_member` WHERE `uid` = %d AND `gid` = %d AND `contact-id` = %d LIMIT 1 " ,
intval ( $uid ),
intval ( $gid ),
intval ( $member )
);
return $r ;
}
function group_add_member ( $uid , $name , $member ) {
$gid = group_byname ( $uid , $name );
if (( ! $gid ) || ( ! $uid ) || ( ! $member ))
return false ;
$r = q ( " SELECT * FROM `group_member` WHERE `uid` = %d AND `id` = %d AND `contact-id` = %d LIMIT 1 " ,
intval ( $uid ),
intval ( $gid ),
intval ( $member )
);
if ( count ( $r ))
return true ; // You might question this, but
// we indicate success because the group was in fact created
// -- It was just created at another time
if ( ! count ( $r ))
$r = q ( " INSERT INTO `group_member` (`uid`, `gid`, `contact-id`)
VALUES ( % d , % d , % d ) " ,
intval ( $uid ),
intval ( $gid ),
intval ( $member )
);
return $r ;
2010-07-11 02:52:47 -07:00
}
2010-07-12 23:08:07 -07:00
function group_get_members ( $gid ) {
$ret = array ();
if ( intval ( $gid )) {
$r = q ( " SELECT `group_member`.`contact-id`, `contact`.* FROM `group_member`
LEFT JOIN `contact` ON `contact` . `id` = `group_member` . `contact-id`
2011-04-12 01:31:55 -07:00
WHERE `gid` = % d AND `group_member` . `uid` = % d ORDER BY `contact` . `name` ASC " ,
2010-07-12 23:08:07 -07:00
intval ( $gid ),
2011-04-03 20:41:40 -07:00
intval ( local_user ())
2010-07-12 23:08:07 -07:00
);
if ( count ( $r ))
$ret = $r ;
}
return $ret ;
}
2011-04-03 20:41:40 -07:00
function group_public_members ( $gid ) {
$ret = 0 ;
if ( intval ( $gid )) {
$r = q ( " SELECT `contact`.`id` AS `contact-id` FROM `group_member`
LEFT JOIN `contact` ON `contact` . `id` = `group_member` . `contact-id`
2011-04-17 23:27:11 -07:00
WHERE `gid` = % d AND `group_member` . `uid` = % d
2011-04-26 05:45:53 -07:00
AND `contact` . `network` != 'dfrn' AND `contact` . `network` != 'mail' AND `contact` . `network` != 'face' " ,
2011-04-03 20:41:40 -07:00
intval ( $gid ),
intval ( local_user ())
);
if ( count ( $r ))
$ret = count ( $r );
}
return $ret ;
}
2010-07-11 02:52:47 -07:00
2011-07-01 06:14:15 -07:00
function group_side ( $every = " contacts " , $each = " group " , $edit = false , $group_id = 0 ) {
2010-07-11 02:52:47 -07:00
2010-10-31 16:38:22 -07:00
$o = '' ;
2010-07-11 02:52:47 -07:00
if ( ! local_user ())
2010-10-31 16:38:22 -07:00
return '' ;
2010-07-27 19:27:14 -07:00
2010-10-31 16:38:22 -07:00
$createtext = t ( 'Create a new group' );
$linktext = t ( 'Everybody' );
2011-07-01 06:23:09 -07:00
$selected = (( $group_id == 0 ) ? ' class="group-selected" ' : '' );
2010-07-11 02:52:47 -07:00
$o .= <<< EOT
< div id = " group-sidebar " >
< h3 > Groups </ h3 >
< div id = " sidebar-group-list " >
2010-07-11 06:06:30 -07:00
< ul id = " sidebar-group-ul " >
2011-07-01 06:14:15 -07:00
< li class = " sidebar-group-li " >< a href = " $every " $selected > $linktext </ a ></ li >
2010-07-11 06:06:30 -07:00
2010-07-11 02:52:47 -07:00
EOT ;
2011-05-29 21:45:00 -07:00
$r = q ( " SELECT * FROM `group` WHERE `deleted` = 0 AND `uid` = %d ORDER BY `name` ASC " ,
2010-07-11 02:52:47 -07:00
intval ( $_SESSION [ 'uid' ])
);
if ( count ( $r )) {
2011-07-01 06:26:46 -07:00
foreach ( $r as $rr ) {
2011-07-01 06:23:09 -07:00
$selected = (( $group_id == $rr [ 'id' ]) ? ' class="group-selected" ' : '' );
2011-07-01 06:14:15 -07:00
$o .= ' <li class="sidebar-group-li">' . (( $edit ) ? " <a href= \" group/ { $rr [ 'id' ] } \" title= \" " . t ( 'Edit' ) . " \" ><img src= \" images/spencil.gif \" alt= \" " . t ( 'Edit' ) . " \" ></a> " : " " ) . " <a href= \" $each / { $rr [ 'id' ] } \" $selected > { $rr [ 'name' ] } </a></li> \r \n " ;
2011-07-01 06:26:46 -07:00
}
2010-07-11 02:52:47 -07:00
}
2011-07-02 02:47:01 -07:00
$o .= " </ul> \r \n </div> " ;
$o .= <<< EOT
< div id = " sidebar-new-group " >
< a href = " group/new " > $createtext </ a >
</ div >
</ div >
EOT ;
2010-07-11 02:52:47 -07:00
return $o ;
2010-07-14 23:04:10 -07:00
}
function expand_groups ( $a ) {
if ( ! ( is_array ( $a ) && count ( $a )))
return array ();
$groups = implode ( ',' , $a );
$groups = dbesc ( $groups );
$r = q ( " SELECT `contact-id` FROM `group_member` WHERE `gid` IN ( $groups ) " );
$ret = array ();
if ( count ( $r ))
foreach ( $r as $rr )
$ret [] = $rr [ 'contact-id' ];
return $ret ;
}
2011-05-31 19:24:26 -07:00
function member_of ( $c ) {
$r = q ( " SELECT `group`.`name`, `group`.`id` FROM `group` LEFT JOIN `group_member` ON `group_member`.`gid` = `group`.`id` WHERE `group_member`.`contact-id` = %d AND `group`.`deleted` = 0 ORDER BY `group`.`name` ASC " ,
intval ( $c )
);
return $r ;
}