(no commit message)
[atutor.git] / install / include / ustep3.php
1 <?php
2 /************************************************************************/
3 /* ATutor                                                                                                                               */
4 /************************************************************************/
5 /* Copyright (c) 2002-2008 by Greg Gay, Joel Kronenberg, Heidi Hazelton */
6 /* http://atutor.ca                                                                                                             */
7 /*                                                                                                                                              */
8 /* This program is free software. You can redistribute it and/or                */
9 /* modify it under the terms of the GNU General Public License                  */
10 /* as published by the Free Software Foundation.                                                */
11 /************************************************************************/
12 // $Id$
13
14 if (!defined('AT_INCLUDE_PATH')) { exit; }
15
16 $_POST['db_login']    = urldecode($_POST['db_login']);
17 $_POST['db_password'] = urldecode($_POST['db_password']);
18 /* Destory session */
19 session_unset();
20 $_SESSION= array();
21 if(isset($_POST['submit']) && ($_POST['action'] == 'process')) {
22         unset($errors);
23         $db = @mysql_connect($_POST['step1']['db_host'] . ':' . $_POST['step1']['db_port'], $_POST['step1']['db_login'], urldecode($_POST['step1']['db_password']));
24         @mysql_select_db($_POST['step1']['db_name'], $db);
25
26         if (version_compare($_POST['step1']['old_version'], '1.5', '<')) {
27                 $_POST['admin_username'] = trim($_POST['admin_username']);
28                 $_POST['admin_password'] = trim($_POST['admin_password']);
29                 $_POST['admin_email']    = trim($_POST['admin_email']);
30                 $_POST['site_name']      = trim($_POST['site_name']);
31                 $_POST['home_url']           = trim($_POST['home_url']);
32
33                 /* Super Administrator Account checking: */
34                 if ($_POST['admin_username'] == ''){
35                         $errors[] = 'Administrator username cannot be empty.';
36                 } else {
37                         /* check for special characters */
38                         if (!(eregi("^[a-zA-Z0-9_]([a-zA-Z0-9_])*$", $_POST['admin_username']))){
39                                 $errors[] = 'Administrator username is not valid.';
40                         }
41                 }
42                 if ($_POST['admin_password'] == '') {
43                         $errors[] = 'Administrator password cannot be empty.';
44                 }
45                 if ($_POST['admin_email'] == '') {
46                         $errors[] = 'Administrator email cannot be empty.';
47                 } else if (!eregi("^[a-z0-9\._-]+@+[a-z0-9\._-]+\.+[a-z]{2,6}$", $_POST['admin_email'])) {
48                         $errors[] = 'Administrator email is not valid.';
49                 }
50
51                 /* System Preferences checking: */
52                 if ($_POST['email'] == '') {
53                         $errors[] = 'Contact email cannot be empty.';
54                 } else if (!eregi("^[a-z0-9\._-]+@+[a-z0-9\._-]+\.+[a-z]{2,6}$", $_POST['email'])) {
55                         $errors[] = 'Contact email is not valid.';
56                 }
57
58                 if (!isset($errors)) {
59                         $sql = "INSERT INTO ".$_POST['step1']['tb_prefix']."admins VALUES ('$_POST[admin_username]', '$_POST[admin_password]', '', '$_POST[admin_email]', 'en', 1, NOW())";
60                         $result= mysql_query($sql, $db);
61
62                         unset($_POST['admin_username']);
63                         unset($_POST['admin_password']);
64                         unset($_POST['admin_email']);
65                 }
66         }
67         if (version_compare($_POST['step1']['old_version'], '1.5.2', '<')) {
68                 // update config table
69                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('contact_email', '".urldecode($_POST['step1']['contact_email'])."')";
70                 mysql_query($sql, $db);
71
72                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('email_notification', '".($_POST['step1']['email_notification'] ? 1 : 0)."')";
73                 mysql_query($sql, $db);
74
75                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('allow_instructor_requests', '".($_POST['step1']['allow_instructor_requests'] ? 1 : 0)."')";
76                 mysql_query($sql, $db);
77
78                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('auto_approve_instructors', '".($_POST['step1']['auto_approve'] ? 1 : 0)."')";
79                 mysql_query($sql, $db);
80
81                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('max_file_size', '".(int) $_POST['step1']['max_file_size']."')";
82                 mysql_query($sql, $db);
83
84                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('max_course_size', '".(int) $_POST['step1']['max_course_size']."')";
85                 mysql_query($sql, $db);
86
87                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('max_course_float', '".(int) $_POST['step1']['max_course_float']."')";
88                 mysql_query($sql, $db);
89
90                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('illegal_extentions', '".str_replace(',','|',urldecode($_POST['step1']['ill_ext']))."')";
91                 mysql_query($sql, $db);
92
93                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('site_name', '".urldecode($_POST['step1']['site_name'])."')";
94                 mysql_query($sql, $db);
95
96                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('home_url', '".urldecode($_POST['step1']['home_url'])."')";
97                 mysql_query($sql, $db);
98
99                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('default_language', 'en')";
100                 mysql_query($sql, $db);
101
102                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('cache_dir', '".urldecode($_POST['step1']['cache_dir'])."')";
103                 mysql_query($sql, $db);
104
105                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('enable_category_themes', '".($_POST['step1']['theme_categories'] ? 1 : 0)."')";
106                 mysql_query($sql, $db);
107
108                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('course_backups', '". (int) $_POST['step1']['course_backups']."')";
109                 mysql_query($sql, $db);
110
111                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('email_confirmation', '".($_POST['step1']['email_confirmation'] ? 1 : 0)."')";
112                 mysql_query($sql, $db);
113
114                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('master_list', '".($_POST['step1']['master_list'] ? 1 : 0)."')";
115                 mysql_query($sql, $db);
116
117                 $sql = "REPLACE INTO ".$_POST['step1']['tb_prefix']."config VALUES ('enable_handbook_notes', '".($_POST['step1']['enable_handbook_notes'] ? 1 : 0)."')";
118                 mysql_query($sql, $db);
119
120                 // check for bits 8192 and 4096 and remove them if they're set.
121                 $sql = "UPDATE ".$_POST['step1']['tb_prefix']."course_enrollment SET `privileges` = `privileges` - 8192 WHERE `privileges` & 8192";
122                 mysql_query($sql, $db);
123
124                 $sql = "UPDATE ".$_POST['step1']['tb_prefix']."course_enrollment SET `privileges` = `privileges` - 4096 WHERE `privileges` & 4096";
125                 mysql_query($sql, $db);
126         }
127
128         if (version_compare($_POST['step1']['old_version'], '1.5.3', '<')) {
129                 $sql = "DELETE FROM ".$_POST['step1']['tb_prefix']."groups";
130                 mysql_query($sql, $db);
131
132                 $sql = "DELETE FROM ".$_POST['step1']['tb_prefix']."groups_members";
133                 mysql_query($sql, $db);
134
135                 $sql = "DELETE FROM ".$_POST['step1']['tb_prefix']."tests_groups";
136                 mysql_query($sql, $db);
137         }
138         if (version_compare($_POST['step1']['old_version'], '1.5.3.3', '<')) {
139                 // set display_name_format to "login"
140                 $sql = "INSERT INTO ".$_POST['step1']['tb_prefix']."config VALUES ('display_name_format', '0')";
141                 mysql_query($sql, $db);
142         }
143
144         if (version_compare($_POST['step1']['old_version'], '1.5.4', '<')) {
145                 /* find all the multiple choice multiple answer questions and convert them to 
146                  * Multiple Answer which is number 7.
147                  */
148                 $sql = "UPDATE ".$_POST['step1']['tb_prefix']."tests_questions SET type=7 WHERE type=1 AND answer_0 + answer_1 + answer_2 + answer_3 + answer_4 + answer_5 + answer_6 + answer_7 + answer_8 + answer_9 > 1";
149                 mysql_query($sql, $db);
150
151                 $sql = "SELECT MAX(admin_privilege) AS max FROM ".$_POST['step1']['tb_prefix']."modules";
152                 $result = mysql_query($sql, $db);
153                 $row = mysql_fetch_assoc($result);
154                 $priv = $row['max'] * 2;
155
156                 $sql = "UPDATE ".$_POST['step1']['tb_prefix']."modules SET `admin_privilege`=$priv WHERE `dir_name`='_core/enrolment'";
157                 mysql_query($sql, $db);
158         }
159         if (version_compare($_POST['step1']['old_version'], '1.5.5', '<')) {
160                 $sql = "UPDATE ".$_POST['step1']['tb_prefix']."tests_results SET status=1, date_taken=date_taken, end_time=date_taken";
161                 mysql_query($sql, $db);
162         }
163
164         /* deal with the extra modules: */
165         /* for each module in the modules table check if that module still exists in the mod directory. */
166         /* if that module does not exist then check the old directory and prompt to have it copied */
167         /* or delete it from the modules table. or maybe disable it instead? */
168         if (version_compare($_POST['step1']['old_version'], '1.5.1', '>')) {
169                 define('TABLE_PREFIX', $_POST['step1']['tb_prefix']);
170                 require(AT_INCLUDE_PATH . 'classes/Module/Module.class.php');
171                 $moduleFactory = new ModuleFactory(FALSE);
172                 $module_list =& $moduleFactory->getModules(AT_MODULE_STATUS_DISABLED | AT_MODULE_STATUS_ENABLED);
173                 $keys = array_keys($module_list);
174                 foreach($keys as $dir_name) {
175                         $module =& $module_list[$dir_name];
176                         $module->setIsMissing($module->isExtra());
177                 }
178         }
179
180
181         if (!isset($errors)) {
182                 unset($errors);
183                 unset($_POST['submit']);
184                 unset($action);
185                 store_steps($step);
186                 $step++;
187                 return;
188         }
189 }
190
191 print_progress($step);
192
193 if (isset($errors)) {
194         print_errors($errors);
195 }
196
197
198 ?>
199
200 <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post" name="form">
201         <input type="hidden" name="action" value="process" />
202         <input type="hidden" name="step" value="<?php echo $step; ?>" />
203         <?php print_hidden($step); ?>
204
205 <?php if (version_compare($_POST['step1']['old_version'], '1.5', '<')): ?>
206         <p>Below are new configuration options that are available for this version.</p>
207
208         <br />
209                 <table width="70%" class="tableborder" cellspacing="0" cellpadding="1" align="center">
210                 <tr>
211                         <th colspan="2">Super Administrator</th>
212                 </tr>
213                 <tr>
214                         <td class="row1" colspan="2">The Super Administrator account is used for managing ATutor. Since ATutor version 1.5 the Super Administrator can also create additional Administrators each with their own privileges and roles.</td>
215                 </tr>
216                 <tr>
217                         <td class="row1"><div class="required" title="Required Field">*</div><b><label for="username">Administrator Username:</label></b><br />
218                         May contain only letters, numbers, or underscores.</td>
219                         <td class="row1"><input type="text" name="admin_username" id="username" maxlength="20" size="20" value="<?php if (!empty($_POST['admin_username'])) { echo $stripslashes(htmlspecialchars($_POST['admin_username'])); } else { echo urldecode($_POST['step1']['admin_username']); } ?>" class="formfield" /></td>
220                 </tr>
221                 <tr>
222                         <td class="row1"><div class="required" title="Required Field">*</div><b><label for="password">Administrator Password:</label></b></td>
223                         <td class="row1"><input type="text" name="admin_password" id="password" maxlength="15" size="15" value="<?php if (!empty($_POST['admin_password'])) { echo $stripslashes(htmlspecialchars($_POST['admin_password'])); } else { echo urldecode($_POST['step1']['admin_password']); } ?>" class="formfield" /></td>
224                 </tr>
225                 <tr>
226                         <td class="row1"><div class="required" title="Required Field">*</div><b><label for="email">Administrator Email:</label></b></td>
227                         <td class="row1"><input type="text" name="admin_email" id="email" size="30" value="<?php if (!empty($_POST['admin_email'])) { echo $stripslashes(htmlspecialchars($_POST['admin_email'])); } else { echo urldecode($_POST['step1']['admin_email']); } ?>" class="formfield" /></td>
228                 </tr>
229                 </table>
230
231                 <br />
232
233                 <table width="70%" class="tableborder" cellspacing="0" cellpadding="1" align="center">
234                 <tr>
235                         <th colspan="2">System Preferences</th>
236                 </tr>
237                 <tr>
238                         <td class="row1"><div class="required" title="Required Field">*</div><b><label for="cemail">Contact Email:</label></b><br />
239                         The email that will be used as the return email when needed and when instructor account requests are made.</td>
240                         <td class="row1"><input type="text" name="email" id="cemail" size="30" value="<?php if (!empty($_POST['email'])) { echo $stripslashes(htmlspecialchars($_POST['admin_email'])); } else { echo urldecode($_POST['step1']['admin_email']); } ?>" class="formfield" /></td>
241                 </tr>
242                 </table>
243 <?php endif; ?>
244 <?php if (version_compare($_POST['step1']['old_version'], '1.5.3', '<')): ?>
245         <p>Groups made prior to 1.5.3 are not backwards compatible and will be removed.</p>
246 <?php else: ?>
247         <p>There are no new configuration options for this version.</p>
248 <?php endif; ?>
249
250         <br />
251         <br />
252         <div align="center"><input type="submit" class="button" value=" Next &raquo;" name="submit" /></div>
253 </form>