public
Description: Git mirror of the CMS Made Simple 2.0 rewrite
Homepage: http://cmsmadesimple.org
Clone URL: git://github.com/tedkulp/cmsmadesimple-2-0.git
cmsmadesimple-2-0 / lib / classes / class.cms_group.php
100644 144 lines (124 sloc) 3.946 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
<?php // -*- mode:php; tab-width:4; indent-tabs-mode:t; c-basic-offset:4; -*-
#CMS - CMS Made Simple
#(c)2004-2008 by Ted Kulp (ted@cmsmadesimple.org)
#This project's homepage is: http://cmsmadesimple.org
#
#This program is free software; you can redistribute it and/or modify
#it under the terms of the GNU General Public License as published by
#the Free Software Foundation; either version 2 of the License, or
#(at your option) any later version.
#
#This program is distributed in the hope that it will be useful,
#BUT withOUT ANY WARRANTY; without even the implied warranty of
#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
#GNU General Public License for more details.
#You should have received a copy of the GNU General Public License
#along with this program; if not, write to the Free Software
#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
#$Id$
 
/**
* Represents a user group in the database.
*
* @author Ted Kulp
* @since 2.0
* @version $Revision$
* @modifiedby $LastChangedBy$
* @lastmodified $Date$
* @license GPL
**/
class CmsGroup extends CmsObjectRelationalMapping
{
  var $params = array('id' => -1, 'name' => '', 'active' => true);
  var $field_maps = array('group_name' => 'name');
  var $table = 'groups';
  
  public function __construct()
  {
    parent::__construct();
  }
  
  public function setup()
  {
    $this->create_has_and_belongs_to_many_association('users', 'user', 'user_groups', 'user_id', 'group_id');
  }
  
  public function validate()
  {
    $this->validate_not_blank('name', lang('nofieldgiven',array(lang('username'))));
    
    // Username validation
    if ($this->name != '')
    {
      // Make sure the name is unique
      $result = $this->find_by_name($this->name);
      if ($result)
      {
        if ($result->id != $this->id)
        {
          $this->add_validation_error(lang('The group name is already in use'));
        }
      }
      
      // Make sure the name has no illegal characters
      if ( !preg_match("/^[a-zA-Z0-9\.]+$/", $this->name) )
      {
        $this->add_validation_error(lang('illegalcharacters', array(lang('groupname'))));
      }
    }
  }
 
  public function add_user($user)
  {
    if ($this->id > -1)
    {
      $date = cms_db()->DBTimeStamp(time());
      return cms_db()->Execute('INSERT INTO ' . cms_db_prefix() . "user_groups (user_id, group_id, create_date, modified_date) VALUES (?,?,{$date},{$date})", array($user->id, $this->id));
    }
    
    return false;
  }
 
  public function remove_user($user)
  {
    if ($this->id > -1)
    {
      return cms_db()->Execute('DELETE FROM '.cms_db_prefix().'user_groups WHERE user_id = ? AND group_id = ?', array($user->id, $this->id));
    }
 
    return false;
  }
  
  //Callback handlers
  public function before_save()
  {
    CmsEvents::send_event( 'Core', ($this->id == -1 ? 'AddGroupPre' : 'EditGroupPre'), array('group' => &$this));
  }
  
  public function after_save()
  {
    //Add the group to the aro table so we can do acls on it
    //Only happens on a new insert
    if ($this->create_date == $this->modified_date)
    {
      //CmsAcl::add_aro($this->id, 'Group');
    }
    CmsEvents::send_event( 'Core', ($this->create_date == $this->modified_date ? 'AddGroupPost' : 'EditGroupPost'), array('group' => &$this));
  }
  
  public function before_delete()
  {
    cms_db()->Execute('DELETE FROM '.cms_db_prefix().'user_groups WHERE group_id = ?',
             array($this->id));
    CmsEvents::send_event('Core', 'DeleteGroupPre', array('group' => &$this));
  }
  
  public function after_delete()
  {
    //CmsAcl::delete_aro($this->id, 'Group');
    CmsEvents::send_event('Core', 'DeleteGroupPost', array('group' => &$this));
  }
  
  public static function get_groups_for_dropdowm($add_everyone = false)
  {
    $result = array();
    
    if ($add_everyone)
    {
      $result[-1] = lang('Everyone');
    }
    
 
    $groups = cmsms()->group->find_all(array('order' => 'name ASC'));
    foreach ($groups as $group)
    {
      $result[$group->id] = $group->name;
    }
    
    return $result;
  }
}
 
# vim:ts=4 sw=4 noet
?>