Issues (171)

server.php (1 issue)

Labels
Severity
1
<?php
2
/*
3
 * SPDX-License-Identifier: AGPL-3.0-only
4
 * SPDX-FileCopyrightText: Copyright 2016 - 2018 Kopano b.v.
5
 * SPDX-FileCopyrightText: Copyright 2020-2024 grommunio GmbH
6
 *
7
 * This is the entry point through which all requests are processed.
8
 */
9
10
namespace grommunio\DAV;
11
12
use Sabre\CalDAV\CalendarRoot;
13
use Sabre\CalDAV\ICSExportPlugin;
14
use Sabre\CardDAV\AddressBookRoot;
15
use Sabre\CardDAV\Plugin;
16
use Sabre\DAV\Server;
17
use Sabre\DAV\Version;
18
use Sabre\DAVACL\PrincipalCollection;
19
20
// require composer auto-loader
21
require __DIR__ . '/vendor/autoload.php';
22
23
// Configure & create main logger
24
GLogger::configure(__DIR__ . '/glogger.ini');
25
$logger = new GLogger('main');
26
27
// don't log any Sabre asset requests (images etc)
28
if (isset($_REQUEST['sabreAction']) && $_REQUEST['sabreAction'] == 'asset') {
29
	$logger->resetConfiguration();
30
}
31
32
// log the start data
33
$logger->debug('------------------ Start');
34
$logger->debug('%s %s', $_SERVER['REQUEST_METHOD'], $_SERVER['REQUEST_URI']);
35
$logger->debug('grommunio-dav version %s', GDAV_VERSION);
36
$logger->debug('SabreDAV version %s', Version::VERSION);
37
38
$gdavBackend = new GrommunioDavBackend(new GLogger('dav'));
39
if (defined("SABRE_AUTH_BACKEND") && strcmp(SABRE_AUTH_BACKEND, "apache") == 0) {
0 ignored issues
show
The constant grommunio\DAV\SABRE_AUTH_BACKEND was not found. Maybe you did not declare it correctly or list all dependencies?
Loading history...
40
	$authBackend = new AuthApache;
41
} else {
42
	$authBackend = new AuthBasicBackend($gdavBackend);
43
}
44
$authBackend->setRealm(SABRE_AUTH_REALM);
45
$principalBackend = new PrincipalsBackend($gdavBackend);
46
$gCarddavBackend = new GrommunioCardDavBackend($gdavBackend, new GLogger('card'));
47
$gCaldavBackend = new GrommunioCalDavBackend($gdavBackend, new GLogger('cal'));
48
49
// Setting up the directory tree
50
$nodes = [
51
	new PrincipalCollection($principalBackend),
52
	new AddressBookRoot($principalBackend, $gCarddavBackend),
53
	new CalendarRoot($principalBackend, $gCaldavBackend),
54
];
55
56
// initialize the server
57
$server = new Server($nodes);
58
$server->setBaseUri(DAV_ROOT_URI);
59
$server->setLogger($logger->getGPSR3Logger());
60
61
$authPlugin = new \Sabre\DAV\Auth\Plugin($authBackend);
62
$server->addPlugin($authPlugin);
63
64
// add our version to the headers
65
$server->httpResponse->addHeader('X-GDAV-Version', GDAV_VERSION);
66
67
// log the incoming request (only if authenticated)
68
$logger->LogIncoming($server->httpRequest);
69
70
$aclPlugin = new DAVACL();
71
$aclPlugin->allowUnauthenticatedAccess = false;
72
$server->addPlugin($aclPlugin);
73
74
$schedulePlugin = new GrommunioSchedulePlugin($gdavBackend, new GLogger('schedule'));
75
$server->addPlugin($schedulePlugin);
76
77
$imipPlugin = new GrommunioIMipPlugin($gdavBackend, new GLogger('imip'));
78
$server->addPlugin($imipPlugin);
79
80
$server->addPlugin(new ICSExportPlugin());
81
$server->addPlugin(new Plugin());
82
83
// TODO: do we need $caldavPlugin for anything?
84
$caldavPlugin = new \Sabre\CalDAV\Plugin();
85
$server->addPlugin($caldavPlugin);
86
87
if (strlen(SYNC_DB) > 0) {
88
	$server->addPlugin(new \Sabre\DAV\Sync\Plugin());
89
}
90
91
if (DEVELOPER_MODE) {
92
	$server->addPlugin(new \Sabre\DAV\Browser\Plugin(false));
93
}
94
95
$server->start();
96
97
// Log outgoing data
98
$logger->LogOutgoing($server->httpResponse);
99
100
$logger->debug(
101
	"httpcode='%s' memory='%s/%s' time='%ss'",
102
	http_response_code(),
103
	$logger->FormatBytes(memory_get_peak_usage(false)),
104
	$logger->FormatBytes(memory_get_peak_usage(true)),
105
	number_format(microtime(true) - $_SERVER["REQUEST_TIME_FLOAT"], 2)
106
);
107
$logger->debug('------------------ End');
108