-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathuwsgidav.py
36 lines (28 loc) · 1.2 KB
/
uwsgidav.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
from wsgidav.fs_dav_provider import FilesystemProvider
from wsgidav.wsgidav_app import WsgiDAVApp
from wsgidav.util import init_logging
import os
class Files(FilesystemProvider):
ROOT_PATH = '/data'
def __init__(self):
super().__init__(self.ROOT_PATH)
def _loc_to_file_path(self, path, environ=None):
if not environ:
raise Exception('no environ in filesystem access')
if 'SSL_CLIENT_S_DN' not in environ:
raise Exception('no SSL_CLIENT_S_DN in environ in filesystem access')
dn = dict((d.split('=') for d in environ['SSL_CLIENT_S_DN'].split(',')))
if 'CN' not in dn:
raise Exception('CN not in certificate')
new_root = os.path.join(self.ROOT_PATH, dn['CN'])
assert new_root == os.path.abspath(new_root) # no funny ".." business in CN
p = super()._loc_to_file_path(path, environ)
assert p.startswith(self.ROOT_PATH)
return os.path.join(new_root, p[len(self.ROOT_PATH)+1:])
config = {
"provider_mapping": {"/": Files()},
"simple_dc": {"user_mapping": {"*": True}}, # anonymous access
"verbose": 3,
}
init_logging(config)
app = WsgiDAVApp(config)