77 lines
2.9 KiB
PHP
77 lines
2.9 KiB
PHP
<?php
|
|
/**
|
|
* Table Definition for local_group
|
|
*/
|
|
|
|
class Local_group extends Managed_DataObject
|
|
{
|
|
###START_AUTOCODE
|
|
/* the code below is auto generated do not remove the above tag */
|
|
|
|
public $__table = 'local_group'; // table name
|
|
public $group_id; // int(4) primary_key not_null
|
|
public $nickname; // varchar(64) unique_key
|
|
public $created; // datetime() not_null default_0000-00-00%2000%3A00%3A00
|
|
public $modified; // datetime() not_null default_CURRENT_TIMESTAMP
|
|
|
|
/* the code above is auto generated do not remove the tag below */
|
|
###END_AUTOCODE
|
|
|
|
public static function schemaDef()
|
|
{
|
|
return array(
|
|
'description' => 'Record for a user group on the local site, with some additional info not in user_group',
|
|
'fields' => array(
|
|
'group_id' => array('type' => 'int', 'not null' => true, 'description' => 'group represented'),
|
|
'nickname' => array('type' => 'varchar', 'length' => 64, 'description' => 'group represented'),
|
|
'created' => array('type' => 'datetime', 'not null' => true, 'default' => '0000-00-00 00:00:00', 'description' => 'date this record was created'),
|
|
'modified' => array('type' => 'datetime', 'not null' => true, 'default' => 'CURRENT_TIMESTAMP', 'description' => 'date this record was modified'),
|
|
),
|
|
'primary key' => array('group_id'),
|
|
'foreign keys' => array(
|
|
'local_group_group_id_fkey' => array('user_group', array('group_id' => 'id')),
|
|
),
|
|
'unique keys' => array(
|
|
'local_group_nickname_key' => array('nickname'),
|
|
),
|
|
);
|
|
}
|
|
|
|
public function getProfile()
|
|
{
|
|
return $this->getGroup()->getProfile();
|
|
}
|
|
|
|
public function getGroup()
|
|
{
|
|
$group = new User_group();
|
|
$group->id = $this->group_id;
|
|
$group->find(true);
|
|
if (!$group instanceof User_group) {
|
|
common_log(LOG_ERR, 'User_group does not exist for Local_group: '.$this->group_id);
|
|
throw new NoSuchGroupException(array('id' => $this->group_id));
|
|
}
|
|
return $group;
|
|
}
|
|
|
|
function setNickname($nickname)
|
|
{
|
|
$this->decache();
|
|
$qry = 'UPDATE local_group set nickname = "'.$this->escape($nickname).'" where group_id = ' . $this->group_id;
|
|
|
|
$result = $this->query($qry);
|
|
|
|
if ($result) {
|
|
$this->nickname = $nickname;
|
|
$this->fixupTimestamps();
|
|
$this->encache();
|
|
} else {
|
|
common_log_db_error($local, 'UPDATE', __FILE__);
|
|
// TRANS: Server exception thrown when updating a local group fails.
|
|
throw new ServerException(_('Could not update local group.'));
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
}
|