3 * brisk - dbase_file.phh
5 * Copyright (C) 2006-2011 Matteo Nastasi
6 * mailto: nastasi@alternativeoutput.it
7 * matteo.nastasi@milug.org
8 * web: http://www.alternativeoutput.it
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful, but
16 * WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABLILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 * General Public License for more details. You should have received a
19 * copy of the GNU General Public License along with this program; if
20 * not, write to the Free Software Foundation, Inc, 59 Temple Place -
21 * Suite 330, Boston, MA 02111-1307, USA.
25 require_once("${G_base}Obj/dbase_base.phh");
27 define(BRISK_AUTH_CONF, "brisk_auth.conf.pho");
36 GLOBAL $DOCUMENT_ROOT;
37 log_main("LoginDB create:start");
39 if (file_exists("$DOCUMENT_ROOT/Etc/".BRISK_AUTH_CONF)) {
40 require("$DOCUMENT_ROOT/Etc/".BRISK_AUTH_CONF);
43 $this->item = array( new LoginDBItem(1, "uno", md5("one"), "pippo@pluto.com", USER_FLAG_TY_SUPER),
44 new LoginDBItem(2, "due", md5("two"), "pippo@pluto.com", USER_FLAG_TY_NORM),
45 new LoginDBItem(3, "a_b", md5("abb"), "pippo@pluto.com", USER_FLAG_TY_NORM),
46 new LoginDBItem(4, "tre", md5("three"), "pippo@pluto.com", USER_FLAG_TY_NORM) );
48 $this->item_n = count($this->item);
49 log_main("LoginDB create:end");
54 return ($this->item_n);
57 function login_exists($login)
59 log_main("login_exists: ".$login);
61 /* check the existence of the nick in the LoginDB */
62 for ($i = 0 ; $i < $this->item_n ; $i++) {
63 if (strcasecmp($this->item[$i]->login, $login) == 0) {
64 log_main("login[".$i."]: ".$this->item[$i]->login);
71 function getlogin_byidx($idx)
73 if ($idx >= $this->item_n)
75 return ($this->item[$idx]->login);
78 function &getitem_bylogin($login, &$id)
82 log_main("login_exists: ".$login);
84 /* check the existence of the nick in the LoginDB */
85 for ($i = 0 ; $i < $this->item_n ; $i++) {
86 if (strcasecmp($this->item[$i]->login, $login) == 0) {
87 log_main("login[".$i."]: ".$this->item[$i]->login);
88 $ret = &$this->item[$i];
97 function getmail($login)
101 /* check the existence of the nick in the LoginDB */
102 for ($i = 0 ; $i < $this->item_n ; $i++) {
103 if (strcasecmp($this->item[$i]->login, $login) == 0) {
104 log_main("login[".$i."]: ".$this->item[$i]->login);
105 return ($this->item[$i]->email);
111 function gettype($login)
115 /* check the existence of the nick in the LoginDB */
116 for ($i = 0 ; $i < $this->item_n ; $i++) {
117 if (strcasecmp($this->item[$i]->login, $login) == 0) {
118 log_main("login[".$i."]: ".$this->item[$i]->login);
119 return ($this->item[$i]->type);
125 function &login_verify($login, $pass)
131 log_main("login_verify: ".$login);
133 /* check the existence of the nick in the LoginDB */
134 for ($i = 0 ; $i < $this->item_n ; $i++) {
135 log_main("login_verify: LOOP");
136 if (strcasecmp($this->item[$i]->login, $login) == 0) {
137 log_main("login[".$i."]: ".$this->item[$i]->login);
139 /* if it exists check for a valid challenge */
140 if (($a_sem = Challenges::lock_data()) != FALSE) {
142 if (($chals = &Challenges::load_data()) != FALSE) {
143 for ($e = 0 ; $e < $chals->item_n ; $e++) {
145 log_main("challenge[".$i."]: ".$chals->item[$e]->login);
146 if (strcmp($login, $chals->item[$e]->login) == 0) {
147 log_main("login_verify [".$pass."] with [".md5($chals->item[$e]->token.$this->item[$i]->pass)."]");
149 if (strcmp($pass , md5($chals->item[$e]->token.$this->item[$i]->pass)) == 0) {
150 log_main("login_verify SUCCESS for ".$login);
153 $ret = &$this->item[$i];
157 } // end for ($e = 0 ...
160 if ($chals->ismod()) {
161 Challenges::save_data(&$chals);
164 Challenges::unlock_data($a_sem);
167 } // if (strcasecmp($this->item[$i]->login, ...
173 } // End class LoginDB