|
1
|
|
|
<?php |
|
2
|
|
|
/** |
|
3
|
|
|
* iCal import and export via Horde iCalendar classes |
|
4
|
|
|
* |
|
5
|
|
|
* @link http://www.egroupware.org |
|
6
|
|
|
* @author Ralf Becker <RalfBecker-AT-outdoor-training.de> |
|
7
|
|
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License |
|
8
|
|
|
* @package calendar |
|
9
|
|
|
* @subpackage export |
|
10
|
|
|
* @version $Id$ |
|
11
|
|
|
*/ |
|
12
|
|
|
|
|
13
|
|
|
use EGroupware\Api; |
|
14
|
|
|
|
|
15
|
|
|
$GLOBALS['egw_info'] = array( |
|
16
|
|
|
'flags' => array( |
|
17
|
|
|
'currentapp' => 'calendar', |
|
18
|
|
|
'noheader' => True, |
|
19
|
|
|
'nofooter' => True, |
|
20
|
|
|
), |
|
21
|
|
|
); |
|
22
|
|
|
// check if we are loged in, by checking sessionid and kp3, as the sessionid get set automaticaly by php for php4-sessions |
|
23
|
|
|
if (!($loged_in = !empty($_COOKIE['sessionid']))) |
|
24
|
|
|
{ |
|
25
|
|
|
$GLOBALS['egw_info']['flags']['currentapp'] = 'login'; |
|
26
|
|
|
$GLOBALS['egw_info']['flags']['noapi'] = True; |
|
27
|
|
|
} |
|
28
|
|
|
include ('../header.inc.php'); |
|
29
|
|
|
|
|
30
|
|
|
function fail_exit($msg) |
|
31
|
|
|
{ |
|
32
|
|
|
echo "<html>\n<head>\n<title>$msg</title>\n<meta http-equiv=\"content-type\" content=\"text/html; charset=". |
|
33
|
|
|
Api\Translation::charset()."\" />\n</head>\n<body><h1>$msg</h1>\n</body>\n</html>\n"; |
|
34
|
|
|
|
|
35
|
|
|
exit(); |
|
|
|
|
|
|
36
|
|
|
} |
|
37
|
|
|
|
|
38
|
|
|
if (!$loged_in) |
|
39
|
|
|
{ |
|
40
|
|
|
include ('../api/src/loader.php'); |
|
41
|
|
|
$GLOBALS['egw_info']['flags']['currentapp'] = 'calendar'; |
|
42
|
|
|
} |
|
43
|
|
|
// fix for SOGo connector, which does not decode the = in our f/b url |
|
44
|
|
|
if (strpos($_SERVER['QUERY_STRING'],'=3D') !== false && substr($_GET['user'],0,2) == '3D') |
|
45
|
|
|
{ |
|
46
|
|
|
$_GET['user'] = substr($_GET['user'],2); |
|
47
|
|
|
if (isset($_GET['password'])) $_GET['password'] = substr($_GET['password'],2); |
|
48
|
|
|
if (isset($_GET['cred'])) $_GET['cred'] = substr($_GET['cred'],2); |
|
49
|
|
|
} |
|
50
|
|
|
if (!is_numeric($user = $_GET['user'])) |
|
51
|
|
|
{ |
|
52
|
|
|
// check if user contains the current domain --> remove it |
|
53
|
|
|
list(,$domain) = explode('@',$user); |
|
54
|
|
|
if ($domain === $GLOBALS['egw_info']['user']['domain']) |
|
55
|
|
|
list($user) = explode('@',$user); |
|
56
|
|
|
$user = $GLOBALS['egw']->accounts->name2id($user,'account_lid','u'); |
|
57
|
|
|
} |
|
58
|
|
|
if ($user === false || !($username = $GLOBALS['egw']->accounts->id2name($user))) |
|
59
|
|
|
{ |
|
60
|
|
|
fail_exit(lang("freebusy: unknown user '%1', wrong password or not available to not logged in users !!!"." $username($user)",$_GET['user'])); |
|
|
|
|
|
|
61
|
|
|
} |
|
62
|
|
|
if (!$loged_in) |
|
63
|
|
|
{ |
|
64
|
|
|
if (empty($_GET['cred'])) |
|
65
|
|
|
{ |
|
66
|
|
|
$GLOBALS['egw_info']['user']['account_id'] = $user; |
|
67
|
|
|
$GLOBALS['egw_info']['user']['account_lid'] = $username; |
|
68
|
|
|
$GLOBALS['egw']->preferences->account_id = $user; |
|
69
|
|
|
$GLOBALS['egw_info']['user']['preferences'] = $GLOBALS['egw']->preferences->read_repository(); |
|
70
|
|
|
$cal_prefs = &$GLOBALS['egw_info']['user']['preferences']['calendar']; |
|
71
|
|
|
$loged_in = !empty($cal_prefs['freebusy']) && |
|
72
|
|
|
(empty($cal_prefs['freebusy_pw']) || $cal_prefs['freebusy_pw'] == $_GET['password']); |
|
73
|
|
|
} |
|
74
|
|
|
else |
|
75
|
|
|
{ |
|
76
|
|
|
$credentials = base64_decode($_GET['cred']); |
|
77
|
|
|
list($authuser, $password) = explode(':', $credentials, 2); |
|
78
|
|
|
if (strpos($authuser, '@') === false) |
|
79
|
|
|
{ |
|
80
|
|
|
$domain = $GLOBALS['egw_info']['server']['default_domain']; |
|
81
|
|
|
$authuser .= '@' . $domain; |
|
82
|
|
|
} |
|
83
|
|
|
else |
|
84
|
|
|
{ |
|
85
|
|
|
list(, $domain) = explode('@',$authuser, 2); |
|
86
|
|
|
} |
|
87
|
|
|
if (array_key_exists($domain, $GLOBALS['egw_domain'])) |
|
88
|
|
|
{ |
|
89
|
|
|
$_POST['login'] = $authname; |
|
90
|
|
|
$_REQUEST['domain'] = $domain; |
|
91
|
|
|
$GLOBALS['egw_info']['server']['default_domain'] = $domain; |
|
92
|
|
|
$GLOBALS['egw_info']['user']['domain'] = $domain; |
|
93
|
|
|
$GLOBALS['egw_info']['flags']['currentapp'] = 'login'; |
|
94
|
|
|
$GLOBALS['egw_info']['flags']['noapi'] = false; |
|
95
|
|
|
$loged_in = $GLOBALS['egw']->session->create($authuser, $password, 'text'); |
|
96
|
|
|
session_unset(); |
|
97
|
|
|
session_destroy(); |
|
98
|
|
|
} |
|
99
|
|
|
} |
|
100
|
|
|
if (!$loged_in) |
|
101
|
|
|
{ |
|
102
|
|
|
fail_exit(lang("freebusy: unknown user '%1', or not available for unauthenticated users!", $_GET['user'])); |
|
103
|
|
|
} |
|
104
|
|
|
} |
|
105
|
|
|
if ($_GET['debug']) |
|
106
|
|
|
{ |
|
107
|
|
|
echo "<pre>"; |
|
108
|
|
|
} |
|
109
|
|
|
else |
|
110
|
|
|
{ |
|
111
|
|
|
Api\Header\Content::type('freebusy.ifb','text/calendar'); |
|
112
|
|
|
} |
|
113
|
|
|
$ical = new calendar_ical(); |
|
114
|
|
|
echo $ical->freebusy($user, $_GET['end']); |
|
115
|
|
|
|
In general, usage of exit should be done with care and only when running in a scripting context like a CLI script.