source: subversion/trunk/roundcubemail/program/steps/settings/func.inc @ 922

Last change on this file since 922 was 922, checked in by thomasb, 5 years ago

Fix overriding of session vars when register_globals is on (#1484670)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 10.9 KB
Line 
1<?php
2
3/*
4 +-----------------------------------------------------------------------+
5 | program/steps/settings/func.inc                                       |
6 |                                                                       |
7 | This file is part of the RoundCube Webmail client                     |
8 | Copyright (C) 2005-2007, RoundCube Dev. - Switzerland                 |
9 | Licensed under the GNU GPL                                            |
10 |                                                                       |
11 | PURPOSE:                                                              |
12 |   Provide functionality for user's settings & preferences             |
13 |                                                                       |
14 +-----------------------------------------------------------------------+
15 | Author: Thomas Bruederli <roundcube@gmail.com>                        |
16 +-----------------------------------------------------------------------+
17
18 $Id$
19
20*/
21
22
23// get user record
24$sql_result = $DB->query("SELECT username, mail_host FROM ".get_table_name('users')."
25                          WHERE  user_id=?",
26                          $_SESSION['user_id']);
27                                 
28if ($USER_DATA = $DB->fetch_assoc($sql_result))
29{
30  $OUTPUT->set_pagetitle(rcube_label('settingsfor') . " ". $USER_DATA['username'] . (!strpos($USER_DATA['username'], '@') ? '@'.$USER_DATA['mail_host'] : ''));
31}
32
33
34
35function rcmail_user_prefs_form($attrib)
36  {
37  global $DB, $CONFIG, $sess_user_lang;
38
39  $no_override = is_array($CONFIG['dont_override']) ? array_flip($CONFIG['dont_override']) : array();
40
41  // add some labels to client
42  rcube_add_label('nopagesizewarning');
43 
44  list($form_start, $form_end) = get_form_tags($attrib, 'save-prefs');
45  unset($attrib['form']);
46
47  // allow the following attributes to be added to the <table> tag
48  $attrib_str = create_attrib_string($attrib, array('style', 'class', 'id', 'cellpadding', 'cellspacing', 'border', 'summary'));
49
50  // return the complete edit form as table
51  $out = "$form_start<table" . $attrib_str . ">\n\n";
52
53  // show language selection
54  if (!isset($no_override['language']))
55    {
56    $a_lang = rcube_list_languages();
57    asort($a_lang);
58 
59    $field_id = 'rcmfd_lang';
60    $select_lang = new select(array('name' => '_language', 'id' => $field_id));
61    $select_lang->add(array_values($a_lang), array_keys($a_lang));
62 
63    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
64                    $field_id,
65                    Q(rcube_label('language')),
66                    $select_lang->show($sess_user_lang));
67    }
68
69
70  // show page size selection
71  if (!isset($no_override['timezone']))
72    {
73    $field_id = 'rcmfd_timezone';
74    $select_timezone = new select(array('name' => '_timezone', 'id' => $field_id));
75    $select_timezone->add('(GMT -11:00) Midway Island, Samoa', '-11');
76    $select_timezone->add('(GMT -10:00) Hawaii', '-10');
77    $select_timezone->add('(GMT -9:00) Alaska', '-9');
78    $select_timezone->add('(GMT -8:00) Pacific Time (US/Canada)', '-8');
79    $select_timezone->add('(GMT -7:00) Mountain Time (US/Canada)', '-7');
80    $select_timezone->add('(GMT -6:00) Central Time (US/Canada), Mexico City', '-6');
81    $select_timezone->add('(GMT -5:00) Eastern Time (US/Canada), Bogota, Lima', '-5');
82    $select_timezone->add('(GMT -4:00) Atlantic Time (Canada), Caracas, La Paz', '-4');
83    $select_timezone->add('(GMT -3:00) Brazil, Buenos Aires, Georgetown', '-3');
84    $select_timezone->add('(GMT -3:30) Nfld Time (Canada), Nfld, S. Labador', '-3.5');
85    $select_timezone->add('(GMT -2:00) Mid-Atlantic', '-2');
86    $select_timezone->add('(GMT -1:00) Azores, Cape Verde Islands', '-1');
87    $select_timezone->add('(GMT) Western Europe, London, Lisbon, Casablanca', '0');
88    $select_timezone->add('(GMT +1:00) Central European Time', '1');
89    $select_timezone->add('(GMT +2:00) EET: Kaliningrad, South Africa', '2');
90    $select_timezone->add('(GMT +3:00) Baghdad, Kuwait, Riyadh, Moscow, Nairobi', '3');
91    $select_timezone->add('(GMT +3:30) Tehran', '3.5');
92    $select_timezone->add('(GMT +4:00) Abu Dhabi, Muscat, Baku, Tbilisi', '4');
93    $select_timezone->add('(GMT +4:30) Kabul', '4.5');
94    $select_timezone->add('(GMT +5:00) Ekaterinburg, Islamabad, Karachi', '5');
95    $select_timezone->add('(GMT +5:30) Chennai, Kolkata, Mumbai, New Delhi', '5.5');
96    $select_timezone->add('(GMT +5:45) Kathmandu', '5.75');
97    $select_timezone->add('(GMT +6:00) Almaty, Dhaka, Colombo', '6');
98    $select_timezone->add('(GMT +7:00) Bangkok, Hanoi, Jakarta', '7');
99    $select_timezone->add('(GMT +8:00) Beijing, Perth, Singapore, Taipei', '8');
100    $select_timezone->add('(GMT +9:00) Tokyo, Seoul, Yakutsk', '9');
101    $select_timezone->add('(GMT +9:30) Adelaide, Darwin', '9.5');
102    $select_timezone->add('(GMT +10:00) EAST/AEST: Sydney, Guam, Vladivostok', '10');
103    $select_timezone->add('(GMT +11:00) Magadan, Solomon Islands', '11');
104    $select_timezone->add('(GMT +12:00) Auckland, Wellington, Kamchatka', '12');
105    $select_timezone->add('(GMT +13:00) Tonga, Pheonix Islands', '13');
106    $select_timezone->add('(GMT +14:00) Kiribati', '14');
107 
108 
109    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
110                    $field_id,
111                    Q(rcube_label('timezone')),
112                    $select_timezone->show($CONFIG['timezone']));
113    }
114
115  // daylight savings
116  if (!isset($no_override['dst_active']))
117    {
118    $field_id = 'rcmfd_dst';
119    $input_dst = new checkbox(array('name' => '_dst_active', 'id' => $field_id, 'value' => 1));
120    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
121                    $field_id,
122                    Q(rcube_label('dstactive')),
123                    $input_dst->show($CONFIG['dst_active']));
124    }
125
126  // show page size selection
127  if (!isset($no_override['pagesize']))
128    {
129    $field_id = 'rcmfd_pgsize';
130    $input_pagesize = new textfield(array('name' => '_pagesize', 'id' => $field_id, 'size' => 5));
131
132    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
133                    $field_id,
134                    Q(rcube_label('pagesize')),
135                    $input_pagesize->show($CONFIG['pagesize']));
136    }
137
138  // MM: Show checkbox for toggling 'pretty dates'
139  if (!isset($no_override['prettydate']))
140    {
141    $field_id = 'rcmfd_prettydate';
142    $input_prettydate = new checkbox(array('name' => '_pretty_date', 'id' => $field_id, 'value' => 1));
143
144    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
145                    $field_id,
146                    Q(rcube_label('prettydate')),
147                    $input_prettydate->show($CONFIG['prettydate']?1:0));
148    }
149
150  // show checkbox for HTML/plaintext messages
151  if (!isset($no_override['prefer_html']))
152    {
153    $field_id = 'rcmfd_htmlmsg';
154    $input_pagesize = new checkbox(array('name' => '_prefer_html', 'id' => $field_id, 'value' => 1));
155
156    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
157                    $field_id,
158                    Q(rcube_label('preferhtml')),
159                    $input_pagesize->show($CONFIG['prefer_html']?1:0));
160    }
161
162  // Show checkbox for HTML Editor
163  if (!isset($no_override['htmleditor']))
164    {
165    $field_id = 'rcmfd_htmleditor';
166    $input_htmleditor = new checkbox(array('name' => '_htmleditor', 'id' => $field_id, 'value' => 1));
167    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
168                    $field_id,
169                    Q(rcube_label('htmleditor')),
170                    $input_htmleditor->show($CONFIG['htmleditor']?1:0));
171    }
172
173  // show config parameter for preview pane
174  if (!isset($no_override['preview_pane']))
175    {
176    $field_id = 'rcmfd_preview';
177    $input_preview = new checkbox(array('name' => '_preview_pane', 'id' => $field_id, 'value' => 1));
178    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
179                    $field_id,
180                    Q(rcube_label('previewpane')),
181                    $input_preview->show($CONFIG['preview_pane']?1:0));
182    }
183                 
184  if (!empty($CONFIG['drafts_mbox']) && !isset($no_override['draft_autosave']))
185    {
186    $field_id = 'rcmfd_autosave';
187    $select_autosave = new select(array('name' => '_draft_autosave', 'id' => $field_id));
188    $select_autosave->add(rcube_label('never'), 0);
189    foreach (array(3, 5, 10) as $i => $min)
190      $select_autosave->add(rcube_label(array('name' => 'everynminutes', 'vars' => array('n' => $min))), $min*60);
191
192    $out .= sprintf("<tr><td class=\"title\"><label for=\"%s\">%s</label></td><td>%s</td></tr>\n",
193                    $field_id,
194                    Q(rcube_label('autosavedraft')),
195                    $select_autosave->show($CONFIG['draft_autosave']));
196    }
197
198  $out .= "\n</table>$form_end";
199
200  return $out; 
201  }
202
203
204
205function rcmail_identities_list($attrib)
206  {
207  global $DB, $CONFIG, $OUTPUT;
208
209
210  // get contacts from DB
211  $sql_result = $DB->query("SELECT * FROM ".get_table_name('identities')."
212                            WHERE  del<>1
213                            AND    user_id=?
214                            ORDER BY standard DESC, name ASC",
215                            $_SESSION['user_id']);
216
217
218  // add id to message list table if not specified
219  if (!strlen($attrib['id']))
220    $attrib['id'] = 'rcmIdentitiesList';
221
222  // define list of cols to be displayed
223  $a_show_cols = array('name', 'email', 'organization', 'reply-to');
224
225  // create XHTML table 
226  $out = rcube_table_output($attrib, $sql_result, $a_show_cols, 'identity_id');
227 
228  // set client env
229  $OUTPUT->add_gui_object('identitieslist', $attrib['id']);
230
231  return $out;
232  }
233
234
235
236// similar function as in /steps/addressbook/edit.inc
237function get_form_tags($attrib, $action, $add_hidden=array())
238  {
239  global $OUTPUT, $EDIT_FORM, $SESS_HIDDEN_FIELD; 
240
241  $form_start = '';
242  if (!strlen($EDIT_FORM))
243    {
244    $hiddenfields = new hiddenfield(array('name' => '_task', 'value' => $GLOBALS['_task']));
245    $hiddenfields->add(array('name' => '_action', 'value' => $action));
246   
247    if ($add_hidden)
248      $hiddenfields->add($add_hidden);
249   
250    if ($_GET['_framed'] || $_POST['_framed'])
251      $hiddenfields->add(array('name' => '_framed', 'value' => 1));
252   
253    $form_start = !strlen($attrib['form']) ? '<form name="form" action="./" method="post">' : '';
254    $form_start .= "\n$SESS_HIDDEN_FIELD\n";
255    $form_start .= $hiddenfields->show();
256    }
257   
258  $form_end = (!strlen($EDIT_FORM) && !strlen($attrib['form'])) ? '</form>' : '';
259  $form_name = strlen($attrib['form']) ? $attrib['form'] : 'form';
260
261  if (!strlen($EDIT_FORM))
262    $OUTPUT->add_gui_object('editform', $form_name);
263 
264  $EDIT_FORM = $form_name;
265
266  return array($form_start, $form_end); 
267  }
268
269
270// register UI objects
271$OUTPUT->add_handlers(array(
272  'userprefs' => 'rcmail_user_prefs_form',
273  'itentitieslist' => 'rcmail_identities_list'
274));
275
276
277?>
Note: See TracBrowser for help on using the repository browser.