59 lines
2.1 KiB
PHP
59 lines
2.1 KiB
PHP
<?php
|
|
/**
|
|
* Table Definition for request_queue
|
|
*/
|
|
require_once INSTALLDIR.'/classes/Memcached_DataObject.php';
|
|
|
|
class Group_join_queue extends Managed_DataObject
|
|
{
|
|
###START_AUTOCODE
|
|
/* the code below is auto generated do not remove the above tag */
|
|
|
|
public $__table = 'group_join_queue'; // table name
|
|
public $profile_id;
|
|
public $group_id;
|
|
public $created;
|
|
|
|
/* Static get */
|
|
function staticGet($k,$v=null)
|
|
{ return Memcached_DataObject::staticGet('Group_join_queue',$k,$v); }
|
|
|
|
/* Pkey get */
|
|
function pkeyGet($k)
|
|
{ return Memcached_DataObject::pkeyGet('Group_join_queue',$k); }
|
|
|
|
/* the code above is auto generated do not remove the tag below */
|
|
###END_AUTOCODE
|
|
|
|
public static function schemaDef()
|
|
{
|
|
return array(
|
|
'description' => 'Holder for group join requests awaiting moderation.',
|
|
'fields' => array(
|
|
'profile_id' => array('type' => 'int', 'not null' => true, 'description' => 'remote or local profile making the request'),
|
|
'group_id' => array('type' => 'int', 'description' => 'remote or local group to join, if any'),
|
|
'created' => array('type' => 'datetime', 'not null' => true, 'description' => 'date this record was created'),
|
|
),
|
|
'primary key' => array('profile_id', 'group_id'),
|
|
'indexes' => array(
|
|
'group_join_queue_profile_id_created_idx' => array('profile_id', 'created'),
|
|
'group_join_queue_group_id_created_idx' => array('group_id', 'created'),
|
|
),
|
|
'foreign keys' => array(
|
|
'group_join_queue_profile_id_fkey' => array('profile', array('profile_id' => 'id')),
|
|
'group_join_queue_group_id_fkey' => array('user_group', array('group_id' => 'id')),
|
|
)
|
|
);
|
|
}
|
|
|
|
public static function saveNew(Profile $profile, User_group $group)
|
|
{
|
|
$rq = new Group_join_queue();
|
|
$rq->profile_id = $profile->id;
|
|
$rq->group_id = $group->id;
|
|
$rq->created = common_sql_now();
|
|
$rq->insert();
|
|
return $rq;
|
|
}
|
|
}
|