Merge commit 'origin/platal-0.10.0'
[platal.git] / classes / platalglobals.php.in
1 <?php
2 /***************************************************************************
3 * Copyright (C) 2003-2009 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
5 * *
6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the Free Software *
18 * Foundation, Inc., *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
21
22 class PlatalGlobals extends PlGlobals
23 {
24 /** The x.org version */
25 public $version = '@VERSION@';
26
27 /** db params */
28 public $dbdb = 'x4dat';
29 public $dbhost = 'localhost';
30 public $dbuser = 'x4dat';
31 public $dbpwd = 'x4dat';
32 public $dbcharset = 'utf8';
33
34 /** default skin */
35 public $skin;
36 public $register_skin;
37
38 public function __construct()
39 {
40 parent::__construct(array('platal.ini', 'platal.conf'));
41 if (isset($GLOBALS['IS_XNET_SITE'])) {
42 $this->core->sitename = 'Polytechnique.net';
43 }
44 }
45
46 public function init()
47 {
48 $this->bootstrap(array('NbIns'), array($this, 'updateNbIns'));
49 $this->bootstrap(array('NbValid'), array($this, 'updateNbValid'));
50 }
51
52 public function asso($key=null)
53 {
54 static $aid = null;
55
56 if (is_null($aid)) {
57 $gp = Get::v('n');
58 if ($p = strpos($gp, '/')) {
59 $gp = substr($gp, 0, $p);
60 }
61
62 if ($gp) {
63 $res = XDB::query('SELECT a.*, d.nom AS domnom,
64 FIND_IN_SET(\'wiki_desc\', a.flags) AS wiki_desc,
65 FIND_IN_SET(\'notif_unsub\', a.flags) AS notif_unsub
66 FROM groupex.asso AS a
67 LEFT JOIN groupex.dom AS d ON d.id = a.dom
68 WHERE diminutif = {?}', $gp);
69 if (!($aid = $res->fetchOneAssoc())) {
70 $aid = array();
71 }
72 } else {
73 $aid = array();
74 }
75 }
76 if (empty($key)) {
77 return $aid;
78 } elseif ( isset($aid[$key]) ) {
79 return $aid[$key];
80 } else {
81 return null;
82 }
83 }
84
85
86 public function updateNbIns()
87 {
88 $res = XDB::query("SELECT COUNT(*)
89 FROM auth_user_md5
90 WHERE perms IN ('admin','user') AND deces=0");
91 $cnt = $res->fetchOneCell();
92 $this->changeDynamicConfig(array('NbIns' => $cnt));
93 }
94
95 public function updateNbValid()
96 {
97 $res = XDB::query("SELECT COUNT(*)
98 FROM requests");
99 $this->changeDynamicConfig(array('NbValid' => $res->fetchOneCell()));
100 }
101 }
102
103
104 /******************************************************************************
105 * Dynamic configuration update/edition stuff
106 *****************************************************************************/
107
108 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
109 ?>