1: <?php
  2:   3:   4:   5:   6:   7:   8:   9:  10:  11:  12:  13:  14: 
 15: 
 16: defined('CON_FRAMEWORK') || die('Illegal call: Missing framework initialization - request aborted.');
 17: 
 18:  19:  20:  21:  22:  23: 
 24: class cApiOnlineUserCollection extends ItemCollection {
 25: 
 26:      27:  28:  29:  30:  31: 
 32:     public function __construct($select = false) {
 33:         global $cfg;
 34:         parent::__construct($cfg['tab']['online_user'], 'user_id');
 35:         $this->_setItemClass('cApiOnlineUser');
 36:         if ($select !== false) {
 37:             $this->select($select);
 38:         }
 39:     }
 40: 
 41:      42:  43:  44:  45:  46:  47:  48: 
 49:     public function startUsersTracking($userId = NULL) {
 50:         global $auth;
 51: 
 52:         $userId = (string) $userId;
 53:         if (empty($userId)) {
 54:             $userId = $auth->auth['uid'];
 55:         }
 56: 
 57:         
 58:         $this->deleteInactiveUser();
 59: 
 60:         $bResult = $this->findUser($userId);
 61:         if ($bResult) {
 62:             
 63:             $this->updateUser($userId);
 64:         } else {
 65:             
 66:             $this->insertOnlineUser($userId);
 67:         }
 68:     }
 69: 
 70:      71:  72:  73:  74:  75: 
 76:     public function insertOnlineUser($userId) {
 77:         $oItem = $this->createNewItem((string) $userId);
 78:         if ($oItem) {
 79:             $created = date('Y-m-d H:i:s');
 80:             $oItem->set('lastaccessed', $created);
 81:             $oItem->store();
 82:         }
 83:         return ($oItem) ? true : false;
 84:     }
 85: 
 86:      87:  88:  89:  90:  91: 
 92:     public function findUser($userId) {
 93:         $oUser = new cApiOnlineUser((string) $userId);
 94:         return ($oUser->isLoaded());
 95:     }
 96: 
 97:      98:  99: 100: 101: 102: 103: 
104:     public function findAllUser() {
105:         
106:         $aAllUser = array();
107:         $aUser = array();
108:         $sClientName = '';
109: 
110:         
111:         $this->select();
112:         while (($oItem = $this->next()) !== false) {
113:             $aUser[] = $oItem->get('user_id');
114:         }
115: 
116:         $oClientColl = new cApiClientCollection();
117: 
118:         
119:         $where = "user_id IN ('" . implode("', '", $aUser) . "')";
120:         $oUserColl = new cApiUserCollection();
121:         $oUserColl->select($where);
122:         while (($oItem = $oUserColl->next()) !== false) {
123:             $sClientNames = '';
124:             $userId = $oItem->get('user_id');
125:             $aAllUser[$userId]['realname'] = $oItem->get('realname');
126:             $aAllUser[$userId]['username'] = $oItem->get('username');
127:             $aPerms = explode(',', $oItem->get('perms'));
128: 
129:             if (in_array('sysadmin', $aPerms)) {
130:                 $aAllUser[$userId]['perms'] = 'Systemadministrator';
131:             } else {
132:                 $bIsAdmin = false;
133:                 $iCounter = 0;
134:                 foreach ($aPerms as $sPerm) {
135:                     $aResults = array();
136:                     if (preg_match('/^admin\[(\d+)\]$/', $sPerm, $aResults)) {
137:                         $iClientId = $aResults[1];
138:                         $bIsAdmin = true;
139:                         $sClientName = $oClientColl->getClientname((int) $iClientId);
140:                         if ($iCounter == 0 && $sClientName != '') {
141:                             $sClientNames .= $sClientName;
142:                         } elseif ($sClientName != '') {
143:                             $sClientNames .= ', ' . $sClientName;
144:                         }
145: 
146:                         $aAllUser[$userId]['perms'] = 'Administrator (' . $sClientNames . ')';
147:                         $iCounter++;
148:                     } elseif (preg_match('/^client\[(\d+)\]$/', $sPerm, $aResults) && !$bIsAdmin) {
149:                         $iClientId = $aResults[1];
150:                         $sClientName = $oClientColl->getClientname((int) $iClientId);
151:                         if ($iCounter == 0 && $sClientName != '') {
152:                             $sClientNames .= $sClientName;
153:                         } elseif ($sClientName != '') {
154:                             $sClientNames .= ', ' . $sClientName;
155:                         }
156: 
157:                         $aAllUser[$userId]['perms'] = '(' . $sClientNames . ')';
158:                         $iCounter++;
159:                     }
160:                 }
161:             }
162:         }
163: 
164:         return $aAllUser;
165:     }
166: 
167:     168: 169: 170: 171: 172: 
173:     public function updateUser($userId) {
174:         $oUser = new cApiOnlineUser((string) $userId);
175:         if ($oUser->isLoaded()) {
176:             $now = date('Y-m-d H:i:s');
177:             $oUser->set('lastaccessed', $now);
178:             return $oUser->store();
179:         }
180:         return false;
181:     }
182: 
183:     184: 185: 186: 187: 188: 
189:     public function deleteInactiveUser() {
190:         global $cfg;
191:         include_once($cfg['path']['contenido_config'] . 'config.misc.php');
192:         $iSetTimeOut = (int) $cfg['backend']['timeout'];
193:         if ($iSetTimeOut <= 0) {
194:             $iSetTimeOut = 10;
195:         }
196: 
197:         
198:         
199:         
200:         $where = "DATE_SUB(NOW(), INTERVAL '$iSetTimeOut' Minute) >= `lastaccessed`";
201:         $result = $this->deleteByWhereClause($where);
202:         return ($result > 0) ? true : false;
203:     }
204: 
205:     206: 207: 208: 209: 
210:     public function getNumberOfUsers() {
211:         $sql = 'SELECT COUNT(*) AS cnt FROM `%s`';
212:         $result = $this->db->query($sql, $this->table);
213:         $this->_lastSQL = $sql;
214:         if ($result) {
215:             $this->db->nextRecord();
216:             return (int) $this->db->f('cnt');
217:         }
218:         return 0;
219:     }
220: 
221:     222: 223: 224: 225: 226: 
227:     public function deleteUser($userId) {
228:         return $this->delete((string) $userId);
229:     }
230: }
231: 
232: 233: 234: 235: 236: 237: 
238: class cApiOnlineUser extends Item {
239: 
240:     241: 242: 243: 244: 
245:     public function __construct($mId = false) {
246:         global $cfg;
247:         parent::__construct($cfg['tab']['online_user'], 'user_id');
248:         $this->setFilters(array(), array());
249:         if ($mId !== false) {
250:             $this->loadByPrimaryKey($mId);
251:         }
252:     }
253: }
254: