c67e4479 |
1 | <?php |
2 | |
3 | /** |
4 | * mailto.php -- mailto: url handler |
5 | * |
c67e4479 |
6 | * This checks to see if we're logged in. If we are we open up a new |
7 | * compose window for this email, otherwise we go to login.php |
8 | * (the above functionality has been disabled, by default you are required to |
9 | * login first) |
10 | * |
11 | * Use the following url to use mailto: |
d69119eb |
12 | * http://<your server>/<squirrelmail base dir>/src/mailto.php?emailaddress=%1 |
c67e4479 |
13 | * see ../contrib/squirrelmail.mailto.reg for a Windows Registry file |
47ccfad4 |
14 | * @copyright © 1999-2006 The SquirrelMail Project Team |
4b4abf93 |
15 | * @license http://opensource.org/licenses/gpl-license.php GNU Public License |
30967a1e |
16 | * @version $Id$ |
8f6f9ba5 |
17 | * @package squirrelmail |
c67e4479 |
18 | */ |
19 | |
202bcbcc |
20 | // reduce the included files in int.php |
21 | $bLogin = true; |
22 | |
30967a1e |
23 | /** |
202bcbcc |
24 | * Include the SquirrelMail initialization file. |
30967a1e |
25 | */ |
202bcbcc |
26 | require('../include/init.php'); |
c67e4479 |
27 | |
d69119eb |
28 | /* Force users to login each time? */ |
29 | $force_login = true; |
30 | /* Open only the compose window, meaningless if $force_login is true */ |
31 | $compose_only = false; |
32 | |
c67e4479 |
33 | header('Pragma: no-cache'); |
c67e4479 |
34 | |
d69119eb |
35 | $trtable = array('cc' => 'send_to_cc', |
c67e4479 |
36 | 'bcc' => 'send_to_bcc', |
37 | 'body' => 'body', |
38 | 'subject' => 'subject'); |
39 | $url = ''; |
d69119eb |
40 | |
7e2ff844 |
41 | $data = array(); |
42 | |
d69119eb |
43 | if(sqgetGlobalVar('emailaddress', $emailaddress)) { |
44 | $emailaddress = trim($emailaddress); |
45 | if(stristr($emailaddress, 'mailto:')) { |
46 | $emailaddress = substr($emailaddress, 7); |
47 | } |
48 | if(strpos($emailaddress, '?') !== false) { |
49 | list($emailaddress, $a) = explode('?', $emailaddress, 2); |
50 | if(strlen(trim($a)) > 0) { |
51 | $a = explode('=', $a, 2); |
7e2ff844 |
52 | $data[strtolower($a[0])] = $a[1]; |
d69119eb |
53 | } |
54 | } |
7e2ff844 |
55 | $data['to'] = $emailaddress; |
d69119eb |
56 | |
57 | /* CC, BCC, etc could be any case, so we'll fix them here */ |
58 | foreach($_GET as $k=>$g) { |
c67e4479 |
59 | $k = strtolower($k); |
d69119eb |
60 | if(isset($trtable[$k])) { |
61 | $k = $trtable[$k]; |
7e2ff844 |
62 | $data[$k] = $g; |
d69119eb |
63 | } |
c67e4479 |
64 | } |
65 | } |
7e2ff844 |
66 | sqsession_is_active(); |
d69119eb |
67 | |
68 | if($force_login == false && sqsession_is_registered('user_is_logged_in')) { |
69 | if($compose_only == true) { |
7e2ff844 |
70 | $redirect = 'compose.php?mailtodata=' . urlencode(serialize($data)); |
d69119eb |
71 | } else { |
7e2ff844 |
72 | $redirect = 'webmail.php?mailtodata=' . urlencode(serialize($data)); |
d69119eb |
73 | } |
c67e4479 |
74 | } else { |
7e2ff844 |
75 | $redirect = 'login.php?mailtodata=' . urlencode(serialize($data)); |
c67e4479 |
76 | } |
d69119eb |
77 | |
c67e4479 |
78 | session_write_close(); |
3ae35858 |
79 | header('Location: ' . get_location() . '/' . $redirect); |
a2b193bc |
80 | |
7e2ff844 |
81 | ?> |