如何在joomla 2.5中创建joomla用户组

时间:2012-06-19 10:18:31

标签: php joomla nested-sets joomla2.5

我正在使用joomla 2.5中的组件,我需要通过代码动态创建用户组。

正如我在2.5中所知,joomla使用嵌套集来维护层次结构,因此当我们插入任何新条目时它可能会影响整个表。

joomla是否提供可以直接用于创建用户组的任何功能? 我们可以在其中指定父组,并在其下创建新组。

2 个答案:

答案 0 :(得分:3)

我自己解决了

在我的情况下,我需要在特定组下面插入子组(在下面的代码中称为$ parent_id)

// get max right from all the child under parent id
    $child_query = "SELECT max(`rgt`) FROM `#__usergroups` WHERE `id` = ".$parent_id;
$db->setQuery($child_query);
$max_rgt = $db->loadResult();


// calculate left and rgt for new entry
$new_lft = $max_rgt;
$new_rgt = $max_rgt + 1;

// update lft and rgt of all entries having lft , rgt greater than max_rgt
$upd1 = "UPDATE `#__usergroups` SET `lft` = `lft` + 2 WHERE `lft` > ".$max_rgt;
$upd2 = "UPDATE `#__usergroups` SET `rgt` = `rgt` + 2 WHERE `rgt` >= ".$max_rgt;


// insert new  child
$insert = "INSERT INTO `#__usergroups`(`parent_id`,`lft`,`rgt`,`title`) VALUES(".$matrix_parent.",".$new_lft.",".$new_rgt.",'".$title."')";

答案 1 :(得分:3)

即使问题是一种旧的并且已被接受,我也会使用此代码在自定义组件中添加/更新/删除组

为了获得com_users所需的模型,需要:

JModelLegacy::addIncludePath( JPATH_ADMINISTRATOR . 
                '/components/com_users/models/', 'UsersModel' );

$groupModel = JModelLegacy::getInstance( 'Group', 'UsersModel' );

在下面显示的代码生效之前。

添加* /更新

$groupData = array(
    'title' => <new/old name of group here>,
    'parent_id' => <new/old id of parent group here>,
    'id' => <group id here> );

$groupModel->save( $groupData );

* 如果新创建的组比id应该是0。保存后,可以使用数据库查询访问新id,因为知道组的名称/标题

删除:

$groupModel->delete( $groupIds );

上面的整个代码包含在我的某个组件模型的save(), delete()方法中。 由于Joomla在单独的Map表中存储用户和组之间的连接,因此删除组时不会损坏用户数据。请注意,delete()方法将一组id作为参数。