forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.5 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;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Send notifications via email etc to group administrators about
 | |
|      * this exciting new pending moderation queue item!
 | |
|      */
 | |
|     public function notify()
 | |
|     {
 | |
|         $joiner = Profile::staticGet('id', $this->profile_id);
 | |
|         $group = User_group::staticGet('id', $this->group_id);
 | |
|         mail_notify_group_join_pending($group, $joiner);
 | |
|     }
 | |
| }
 |