Start some register_globals = off fixes:
[squirrelmail.git] / src / right_main.php
1 <?php
2
3 /**
4 * right_main.php
5 *
6 * Copyright (c) 1999-2002 The SquirrelMail Project Team
7 * Licensed under the GNU GPL. For full terms see the file COPYING.
8 *
9 * This is where the mailboxes are listed. This controls most of what
10 * goes on in SquirrelMail.
11 *
12 * $Id$
13 */
14
15 /* Path for SquirrelMail required files. */
16 define('SM_PATH','../');
17
18 /* SquirrelMail required files. */
19 require_once(SM_PATH . 'include/validate.php');
20 require_once(SM_PATH . 'functions/imap.php');
21 require_once(SM_PATH . 'functions/date.php');
22 require_once(SM_PATH . 'functions/array.php');
23 require_once(SM_PATH . 'functions/mime.php');
24 require_once(SM_PATH . 'functions/mailbox_display.php');
25 require_once(SM_PATH . 'functions/display_messages.php');
26 require_once(SM_PATH . 'functions/html.php');
27
28 /***********************************************************
29 * incoming variables from URL: *
30 * $sort Direction to sort by date *
31 * values: 0 - descending order *
32 * values: 1 - ascending order *
33 * $startMessage Message to start at *
34 * $mailbox Full Mailbox name *
35 * *
36 * incoming from cookie: *
37 * $key pass *
38 * incoming from session: *
39 * $username duh *
40 * *
41 ***********************************************************/
42
43
44 /* lets get the global vars we may need */
45 $username = $_SESSION['username'];
46 $key = $_COOKIE['key'];
47 $onetimepad = $_SESSION['onetimepad'];
48 $base_uri = $_SESSION['base_uri'];
49 $delimiter = $_SESSION['delimiter'];
50
51 if (isset($_GET['startMessage'])) {
52 $startMessage = $_GET['startMessage'];
53 }
54 if (isset($_GET['mailbox'])) {
55 $mailbox = $_GET['mailbox'];
56 }
57 if (isset($_GET['PG_SHOWNUM'])) {
58 $PG_SHOWNUM = $_GET['PG_SHOWNUM'];
59 }
60 elseif (isset($_SESSION['PG_SHOWNUM'])) {
61 $PG_SHOWNUM = $_SESSION['PG_SHOWNUM'];
62 }
63 if (isset($_GET['PG_SHOWALL'])) {
64 $PG_SHOWALL = $_GET['PG_SHOWALL'];
65 }
66 if (isset($_GET['newsort'])) {
67 $newsort = $_GET['newsort'];
68 }
69 if (isset($_GET['checkall'])) {
70 $checkall = $_GET['checkall'];
71 }
72 if (isset($_GET['set_thread'])) {
73 $set_thread = $_GET['set_thread'];
74 }
75 if (isset($_SESSION['lastTargetMailbox'])) {
76 $lastTargetMailbox =$_SESSION['lastTargetMailbox'];
77 }
78
79 /* end of get globals */
80
81
82 /* Open a connection on the imap port (143) */
83
84 $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 0);
85
86 if (isset($PG_SHOWALL)) {
87 if ($PG_SHOWALL) {
88 $PG_SHOWNUM=999999;
89 $show_num=$PG_SHOWNUM;
90 sqsession_register($PG_SHOWNUM, 'PG_SHOWNUM');
91 }
92 else {
93 sqsession_unregister('PG_SHOWNUM');
94 unset($PG_SHOWNUM);
95 }
96 }
97 else if( isset( $PG_SHOWNUM ) ) {
98 $show_num = $PG_SHOWNUM;
99 }
100
101 if (isset($newsort) && $newsort != $sort) {
102 setPref($data_dir, $username, 'sort', $newsort);
103 }
104
105
106
107 /* If the page has been loaded without a specific mailbox, */
108 /* send them to the inbox */
109 if (!isset($mailbox)) {
110 $mailbox = 'INBOX';
111 $startMessage = 1;
112 }
113
114
115 if (!isset($startMessage) || ($startMessage == '')) {
116 $startMessage = 1;
117 }
118
119 /* compensate for the UW vulnerability. */
120 if ($imap_server_type == 'uw' && (strstr($mailbox, '../') ||
121 substr($mailbox, 0, 1) == '/')) {
122 $mailbox = 'INBOX';
123 }
124
125 /* decide if we are thread sorting or not */
126 if ($allow_thread_sort == TRUE) {
127 if (isset($set_thread)) {
128 if ($set_thread == 1) {
129 setPref($data_dir, $username, "thread_$mailbox", 1);
130 $thread_sort_messages = '1';
131 }
132 elseif ($set_thread == 2) {
133 setPref($data_dir, $username, "thread_$mailbox", 0);
134 $thread_sort_messages = '0';
135 }
136 }
137 else {
138 $thread_sort_messages = getPref($data_dir, $username, "thread_$mailbox");
139 }
140 }
141 else {
142 $thread_sort_messages = 0;
143 }
144
145 do_hook ('generic_header');
146
147 sqimap_mailbox_select($imapConnection, $mailbox);
148
149 if (isset($composenew) && $composenew) {
150 $comp_uri = '../src/compose.php?mailbox='. urlencode($mailbox).
151 "&amp;session=$composesession";
152 displayPageHeader($color, $mailbox, "comp_in_new('$comp_uri');", false);
153 } else {
154 displayPageHeader($color, $mailbox);
155 }
156 do_hook('right_main_after_header');
157 if (isset($note)) {
158 echo html_tag( 'div', '<b>' . $note .'</b>', 'center' ) . "<br>\n";
159 }
160
161 if (isset($_SESSION['just_logged_in'])) {
162 $just_logged_in = $_SESSION['just_logged_in'];
163 if ($just_logged_in == true) {
164 $just_logged_in = false;
165
166 if (strlen(trim($motd)) > 0) {
167 echo html_tag( 'table',
168 html_tag( 'tr',
169 html_tag( 'td',
170 html_tag( 'table',
171 html_tag( 'tr',
172 html_tag( 'td', $motd, 'center' )
173 ) ,
174 '', $color[4], 'width="100%" cellpadding="5" cellspacing="1" border="0"' )
175 )
176 ) ,
177 'center', $color[9], 'width="70%" cellpadding="0" cellspacing="3" border="0"' );
178 }
179 }
180 }
181
182 if (isset($newsort)) {
183 $sort = $newsort;
184 sqsession_register($sort, 'sort');
185 }
186
187 /*********************************************************************
188 * Check to see if we can use cache or not. Currently the only time *
189 * when you will not use it is when a link on the left hand frame is *
190 * used. Also check to make sure we actually have the array in the *
191 * registered session data. :) *
192 *********************************************************************/
193 if (! isset($use_mailbox_cache)) {
194 $use_mailbox_cache = 0;
195 }
196
197 if ($use_mailbox_cache && session_is_registered('msgs')) {
198 showMessagesForMailbox($imapConnection, $mailbox, $numMessages, $startMessage, $sort, $color, $show_num, $use_mailbox_cache);
199 } else {
200 if (session_is_registered('msgs')) {
201 unset($msgs);
202 }
203
204 if (session_is_registered('msort')) {
205 unset($msort);
206 }
207
208 if (session_is_registered('numMessages')) {
209 unset($numMessages);
210 }
211
212 $numMessages = sqimap_get_num_messages ($imapConnection, $mailbox);
213
214 showMessagesForMailbox($imapConnection, $mailbox, $numMessages,
215 $startMessage, $sort, $color, $show_num,
216 $use_mailbox_cache);
217
218 if (session_is_registered('msgs') && isset($msgs)) {
219 sqsession_register($msgs, 'msgs');
220 $_SESSION['msgs'] = $msgs;
221 }
222
223 if (session_is_registered('msort') && isset($msort)) {
224 sqsession_register($msort, 'msort');
225 $_SESSION['msort'] = $msort;
226 }
227
228 sqsession_register($numMessages, 'numMessages');
229 $_SESSION['numMessages'] = $numMessages;
230 }
231 do_hook('right_main_bottom');
232 sqimap_logout ($imapConnection);
233
234 echo '</body></html>';
235
236 ?>