@@ -30,47 +30,47 @@ |
||
30 | 30 | |
31 | 31 | class AnonymousOptionsPlugin extends ServerPlugin { |
32 | 32 | |
33 | - /** |
|
34 | - * @var \Sabre\DAV\Server |
|
35 | - */ |
|
36 | - private $server; |
|
33 | + /** |
|
34 | + * @var \Sabre\DAV\Server |
|
35 | + */ |
|
36 | + private $server; |
|
37 | 37 | |
38 | - /** |
|
39 | - * @param \Sabre\DAV\Server $server |
|
40 | - * @return void |
|
41 | - */ |
|
42 | - public function initialize(\Sabre\DAV\Server $server) { |
|
43 | - $this->server = $server; |
|
44 | - // before auth |
|
45 | - $this->server->on('beforeMethod', [$this, 'handleAnonymousOptions'], 9); |
|
46 | - } |
|
38 | + /** |
|
39 | + * @param \Sabre\DAV\Server $server |
|
40 | + * @return void |
|
41 | + */ |
|
42 | + public function initialize(\Sabre\DAV\Server $server) { |
|
43 | + $this->server = $server; |
|
44 | + // before auth |
|
45 | + $this->server->on('beforeMethod', [$this, 'handleAnonymousOptions'], 9); |
|
46 | + } |
|
47 | 47 | |
48 | - /** |
|
49 | - * @return bool |
|
50 | - */ |
|
51 | - public function isRequestInRoot($path) { |
|
52 | - return $path === '' || (is_string($path) && strpos($path, '/') === FALSE); |
|
53 | - } |
|
48 | + /** |
|
49 | + * @return bool |
|
50 | + */ |
|
51 | + public function isRequestInRoot($path) { |
|
52 | + return $path === '' || (is_string($path) && strpos($path, '/') === FALSE); |
|
53 | + } |
|
54 | 54 | |
55 | - /** |
|
56 | - * @throws \Sabre\DAV\Exception\Forbidden |
|
57 | - * @return bool |
|
58 | - */ |
|
59 | - public function handleAnonymousOptions(RequestInterface $request, ResponseInterface $response) { |
|
60 | - $isOffice = preg_match('/Microsoft Office/i', $request->getHeader('User-Agent')); |
|
61 | - $isAnonymousOption = ($request->getMethod() === 'OPTIONS' && ($request->getHeader('Authorization') === null || trim($request->getHeader('Authorization')) === 'Bearer') && $this->isRequestInRoot($request->getPath())); |
|
62 | - $isOfficeHead = $request->getMethod() === 'HEAD' && $isOffice && $request->getHeader('Authorization') === 'Bearer'; |
|
63 | - if ($isAnonymousOption || $isOfficeHead) { |
|
64 | - /** @var CorePlugin $corePlugin */ |
|
65 | - $corePlugin = $this->server->getPlugin('core'); |
|
66 | - // setup a fake tree for anonymous access |
|
67 | - $this->server->tree = new Tree(new Directory('')); |
|
68 | - $corePlugin->httpOptions($request, $response); |
|
69 | - $this->server->emit('afterMethod', [$request, $response]); |
|
70 | - $this->server->emit('afterMethod:OPTIONS', [$request, $response]); |
|
55 | + /** |
|
56 | + * @throws \Sabre\DAV\Exception\Forbidden |
|
57 | + * @return bool |
|
58 | + */ |
|
59 | + public function handleAnonymousOptions(RequestInterface $request, ResponseInterface $response) { |
|
60 | + $isOffice = preg_match('/Microsoft Office/i', $request->getHeader('User-Agent')); |
|
61 | + $isAnonymousOption = ($request->getMethod() === 'OPTIONS' && ($request->getHeader('Authorization') === null || trim($request->getHeader('Authorization')) === 'Bearer') && $this->isRequestInRoot($request->getPath())); |
|
62 | + $isOfficeHead = $request->getMethod() === 'HEAD' && $isOffice && $request->getHeader('Authorization') === 'Bearer'; |
|
63 | + if ($isAnonymousOption || $isOfficeHead) { |
|
64 | + /** @var CorePlugin $corePlugin */ |
|
65 | + $corePlugin = $this->server->getPlugin('core'); |
|
66 | + // setup a fake tree for anonymous access |
|
67 | + $this->server->tree = new Tree(new Directory('')); |
|
68 | + $corePlugin->httpOptions($request, $response); |
|
69 | + $this->server->emit('afterMethod', [$request, $response]); |
|
70 | + $this->server->emit('afterMethod:OPTIONS', [$request, $response]); |
|
71 | 71 | |
72 | - $this->server->sapi->sendResponse($response); |
|
73 | - return false; |
|
74 | - } |
|
75 | - } |
|
72 | + $this->server->sapi->sendResponse($response); |
|
73 | + return false; |
|
74 | + } |
|
75 | + } |
|
76 | 76 | } |