dir/mod/group.php

152 lines
3.7 KiB
PHP
Raw Normal View History

2010-07-11 15:06:30 +02:00
<?php
2010-07-13 13:05:23 +02:00
function validate_members(&$item) {
$item = intval($item);
}
2010-07-11 15:06:30 +02:00
function group_init(&$a) {
2010-09-09 05:14:17 +02:00
if(local_user()) {
require_once('include/group.php');
$a->page['aside'] = group_side();
}
2010-07-11 15:06:30 +02:00
}
function group_post(&$a) {
if(! local_user()) {
2010-08-11 10:48:43 +02:00
notice( t('Permission denied.') . EOL);
2010-07-11 15:06:30 +02:00
return;
}
2010-09-27 02:24:20 +02:00
if(($a->argc == 2) && ($a->argv[1] === 'new')) {
2010-07-11 15:06:30 +02:00
$name = notags(trim($_POST['groupname']));
2010-10-18 23:34:59 +02:00
$r = group_add(local_user(),$name);
2010-07-11 15:06:30 +02:00
if($r) {
2010-08-11 10:48:43 +02:00
notice( t('Group created.') . EOL );
2010-10-18 23:34:59 +02:00
$r = group_byname(local_user(),$name);
2010-07-11 15:06:30 +02:00
if($r)
goaway($a->get_baseurl() . '/group/' . $r);
}
else
2010-08-11 10:48:43 +02:00
notice( t('Could not create group.') . EOL );
2010-07-13 13:18:57 +02:00
goaway($a->get_baseurl() . '/group');
2010-07-11 15:06:30 +02:00
return; // NOTREACHED
}
2010-07-13 13:05:23 +02:00
if(($a->argc == 2) && (intval($a->argv[1]))) {
$r = q("SELECT * FROM `group` WHERE `id` = %d AND `uid` = %d LIMIT 1",
intval($a->argv[1]),
2010-10-18 23:34:59 +02:00
intval(local_user())
2010-07-13 13:05:23 +02:00
);
if(! count($r)) {
2010-08-11 10:48:43 +02:00
notice( t('Group not found.') . EOL );
2010-07-13 13:05:23 +02:00
goaway($a->get_baseurl() . '/contacts');
2010-09-09 05:14:17 +02:00
return; // NOTREACHED
2010-07-13 13:05:23 +02:00
}
$group = $r[0];
$groupname = notags(trim($_POST['groupname']));
if((strlen($groupname)) && ($groupname != $group['name'])) {
$r = q("UPDATE `group` SET `name` = '%s' WHERE `uid` = %d AND `id` = %d LIMIT 1",
dbesc($groupname),
2010-10-18 23:34:59 +02:00
intval(local_user()),
2010-07-13 13:05:23 +02:00
intval($group['id'])
);
2010-07-13 13:18:57 +02:00
if($r)
2010-08-11 10:48:43 +02:00
notice( t('Group name changed.') . EOL );
2010-07-13 13:05:23 +02:00
}
$members = $_POST['group_members_select'];
array_walk($members,'validate_members');
$r = q("DELETE FROM `group_member` WHERE `gid` = %d AND `uid` = %d",
intval($a->argv[1]),
2010-10-18 23:34:59 +02:00
intval(local_user())
2010-07-13 13:05:23 +02:00
);
2010-07-13 13:18:57 +02:00
$result = true;
2010-07-13 13:05:23 +02:00
if(count($members)) {
foreach($members as $member) {
$r = q("INSERT INTO `group_member` ( `uid`, `gid`, `contact-id`)
VALUES ( %d, %d, %d )",
2010-10-18 23:34:59 +02:00
intval(local_user()),
2010-07-13 13:05:23 +02:00
intval($group['id']),
intval($member)
);
2010-07-13 13:18:57 +02:00
if(! $r)
$result = false;
2010-07-13 13:05:23 +02:00
}
}
2010-07-13 13:18:57 +02:00
if($result)
2010-08-11 10:48:43 +02:00
notice( t('Membership list updated.') . EOL);
2010-09-09 05:14:17 +02:00
$a->page['aside'] = group_side();
2010-07-13 13:05:23 +02:00
}
2010-09-09 05:14:17 +02:00
return;
2010-07-11 15:06:30 +02:00
}
function group_content(&$a) {
if(! local_user()) {
2010-08-11 10:48:43 +02:00
notice( t('Permission denied') . EOL);
2010-07-11 15:06:30 +02:00
return;
}
2010-09-27 02:24:20 +02:00
if(($a->argc == 2) && ($a->argv[1] === 'new')) {
$tpl = load_view_file('view/group_new.tpl');
2010-09-09 05:14:17 +02:00
$o .= replace_macros($tpl,array());
return $o;
2010-07-13 08:08:07 +02:00
}
2010-08-11 13:14:47 +02:00
2010-09-27 02:24:20 +02:00
if(($a->argc == 3) && ($a->argv[1] === 'drop')) {
2010-08-11 13:14:47 +02:00
if(intval($a->argv[2])) {
2010-08-11 10:48:43 +02:00
$r = q("SELECT `name` FROM `group` WHERE `id` = %d AND `uid` = %d LIMIT 1",
2010-08-11 13:14:47 +02:00
intval($a->argv[2]),
2010-10-18 23:34:59 +02:00
intval(local_user())
2010-08-11 10:48:43 +02:00
);
if(count($r))
2010-10-18 23:34:59 +02:00
$result = group_rmv(local_user(),$r[0]['name']);
2010-08-11 10:48:43 +02:00
if($result)
notice( t('Group removed.') . EOL);
else
notice( t('Unable to remove group.') . EOL);
}
goaway($a->get_baseurl() . '/group');
return; // NOTREACHED
}
2010-07-13 11:26:28 +02:00
2010-07-13 08:08:07 +02:00
if(($a->argc == 2) && (intval($a->argv[1]))) {
require_once('view/acl_selectors.php');
$r = q("SELECT * FROM `group` WHERE `id` = %d AND `uid` = %d LIMIT 1",
intval($a->argv[1]),
2010-10-18 23:34:59 +02:00
intval(local_user())
2010-07-13 08:08:07 +02:00
);
if(! count($r)) {
2010-09-09 05:14:17 +02:00
notice( t('Group not found.') . EOL );
2010-07-13 08:08:07 +02:00
goaway($a->get_baseurl() . '/contacts');
}
2010-07-13 11:26:28 +02:00
$group = $r[0];
$ret = group_get_members($group['id']);
2010-07-13 08:08:07 +02:00
$preselected = array();
if(count($ret)) {
foreach($ret as $p)
$preselected[] = $p['id'];
}
2010-07-13 11:26:28 +02:00
$drop_tpl = load_view_file('view/group_drop.tpl');
2010-08-11 10:48:43 +02:00
$drop_txt = replace_macros($drop_tpl, array(
'$id' => $group['id'],
'$delete' => t('Delete')
));
2010-10-18 09:43:49 +02:00
$celeb = ((($a->user['page-flags'] == PAGE_SOAPBOX) || ($a->user['page-flags'] == PAGE_COMMUNITY)) ? true : false);
$tpl = load_view_file('view/group_edit.tpl');
2010-07-13 11:26:28 +02:00
$o .= replace_macros($tpl, array(
'$gid' => $group['id'],
'$name' => $group['name'],
2010-08-11 10:48:43 +02:00
'$drop' => $drop_txt,
2010-10-18 09:43:49 +02:00
'$selector' => contact_select('group_members_select','group_members_select',$preselected,25,false,$celeb)
2010-07-13 11:26:28 +02:00
));
2010-07-13 08:08:07 +02:00
}
2010-07-11 15:06:30 +02:00
return $o;
}