📄 group.php
字号:
* This class is responsible for providing data access mechanisms to the data source
* of XOOPS group membership class objects.
*
* @author Kazumi Ono <onokazu@xoops.org>
* @copyright copyright (c) 2000-2003 XOOPS.org
* @package kernel
*/
class XoopsMembershipHandler extends XoopsObjectHandler
{
/**
* create a new membership
*
* @param bool $isNew should the new object be set to "new"?
* @return object XoopsMembership
*/
function &create($isNew = true)
{
$mship = new XoopsMembership();
if ($isNew) {
$mship->setNew();
}
return $mship;
}
/**
* retrieve a membership
*
* @param int $id ID of the membership to get
* @return mixed reference to the object if successful, else FALSE
*/
function &get($id)
{
$id = intval($id);
$mship = false;
if ($id > 0) {
$sql = 'SELECT * FROM '.$this->db->prefix('groups_users_link').' WHERE linkid='.$id;
if (!$result = $this->db->query($sql)) {
return $mship;
}
$numrows = $this->db->getRowsNum($result);
if ($numrows == 1) {
$mship = new XoopsMembership();
$mship->assignVars($this->db->fetchArray($result));
}
}
return $mship;
}
/**
* inserts a membership in the database
*
* @param object $mship reference to the membership object
* @return bool TRUE if already in DB or successful, FALSE if failed
*/
function insert(&$mship)
{
/**
* @TODO: Change to if (!(class_exists($this->className) && $obj instanceof $this->className)) when going fully PHP5
*/
if (!is_a($mship, 'xoopsmembership')) {
return false;
}
if (!$mship->isDirty()) {
return true;
}
if (!$mship->cleanVars()) {
return false;
}
foreach ($mship->cleanVars as $k => $v) {
${$k} = $v;
}
if ($mship->isNew()) {
$linkid = $this->db->genId('groups_users_link_linkid_seq');
$sql = sprintf("INSERT INTO %s (linkid, groupid, uid) VALUES (%u, %u, %u)", $this->db->prefix('groups_users_link'), $linkid, $groupid, $uid);
} else {
$sql = sprintf("UPDATE %s SET groupid = %u, uid = %u WHERE linkid = %u", $this->db->prefix('groups_users_link'), $groupid, $uid, $linkid);
}
if (!$result = $this->db->query($sql)) {
return false;
}
if (empty($linkid)) {
$linkid = $this->db->getInsertId();
}
$mship->assignVar('linkid', $linkid);
return true;
}
/**
* delete a membership from the database
*
* @param object $mship reference to the membership object
* @return bool FALSE if failed
*/
function delete(&$mship)
{
/**
* @TODO: Change to if (!(class_exists($this->className) && $obj instanceof $this->className)) when going fully PHP5
*/
if (!is_a($mship, 'xoopsmembership')) {
return false;
}
$sql = sprintf("DELETE FROM %s WHERE linkid = %u", $this->db->prefix('groups_users_link'), $groupm->getVar('linkid'));
if (!$result = $this->db->query($sql)) {
return false;
}
return true;
}
/**
* retrieve memberships from the database
*
* @param object $criteria {@link CriteriaElement} conditions to meet
* @param bool $id_as_key should the ID be used as the array's key?
* @return array array of references
*/
function getObjects($criteria = null, $id_as_key = false)
{
$ret = array();
$limit = $start = 0;
$sql = 'SELECT * FROM '.$this->db->prefix('groups_users_link');
if (isset($criteria) && is_subclass_of($criteria, 'criteriaelement')) {
$sql .= ' '.$criteria->renderWhere();
$limit = $criteria->getLimit();
$start = $criteria->getStart();
}
$result = $this->db->query($sql, $limit, $start);
if (!$result) {
return $ret;
}
while ($myrow = $this->db->fetchArray($result)) {
$mship = new XoopsMembership();
$mship->assignVars($myrow);
if (!$id_as_key) {
$ret[] =& $mship;
} else {
$ret[$myrow['linkid']] =& $mship;
}
unset($mship);
}
return $ret;
}
/**
* count how many memberships meet the conditions
*
* @param object $criteria {@link CriteriaElement} conditions to meet
* @return int
*/
function getCount($criteria = null)
{
$sql = 'SELECT COUNT(*) FROM '.$this->db->prefix('groups_users_link');
if (isset($criteria) && is_subclass_of($criteria, 'criteriaelement')) {
$sql .= ' '.$criteria->renderWhere();
}
$result = $this->db->query($sql);
if (!$result) {
return 0;
}
list($count) = $this->db->fetchRow($result);
return $count;
}
/**
* delete all memberships meeting the conditions
*
* @param object $criteria {@link CriteriaElement} with conditions to meet
* @return bool
*/
function deleteAll($criteria = null)
{
$sql = 'DELETE FROM '.$this->db->prefix('groups_users_link');
if (isset($criteria) && is_subclass_of($criteria, 'criteriaelement')) {
$sql .= ' '.$criteria->renderWhere();
}
if (!$result = $this->db->query($sql)) {
return false;
}
return true;
}
/**
* retrieve groups for a user
*
* @param int $uid ID of the user
* @param bool $asobject should the groups be returned as {@link XoopsGroup}
* objects? FALSE returns associative array.
* @return array array of groups the user belongs to
*/
function getGroupsByUser($uid)
{
$ret = array();
$sql = 'SELECT groupid FROM '.$this->db->prefix('groups_users_link').' WHERE uid='.intval($uid);
$result = $this->db->query($sql);
if (!$result) {
return $ret;
}
while ($myrow = $this->db->fetchArray($result)) {
$ret[] = $myrow['groupid'];
}
return $ret;
}
/**
* retrieve users belonging to a group
*
* @param int $groupid ID of the group
* @param bool $asobject return users as {@link XoopsUser} objects?
* FALSE will return arrays
* @param int $limit number of entries to return
* @param int $start offset of first entry to return
* @return array array of users belonging to the group
*/
function getUsersByGroup($groupid, $limit=0, $start=0)
{
$ret = array();
$sql = 'SELECT uid FROM '.$this->db->prefix('groups_users_link').' WHERE groupid='.intval($groupid);
$result = $this->db->query($sql, $limit, $start);
if (!$result) {
return $ret;
}
while ($myrow = $this->db->fetchArray($result)) {
$ret[] = $myrow['uid'];
}
return $ret;
}
}
?>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -