diff options
author | cbdev <cb@cbcdn.com> | 2021-07-20 23:19:55 +0200 |
---|---|---|
committer | cbdev <cb@cbcdn.com> | 2021-07-20 23:19:55 +0200 |
commit | dad7fcafa4d4b2ab3fd59edb01c57a12155f0375 (patch) | |
tree | 66c60e78f6430048c47f540c2464b24606a050b0 /backend | |
parent | fbcd1f22d63f6bac83fc3a87481e76808552972d (diff) | |
download | cargohold-dad7fcafa4d4b2ab3fd59edb01c57a12155f0375.tar.gz cargohold-dad7fcafa4d4b2ab3fd59edb01c57a12155f0375.tar.bz2 cargohold-dad7fcafa4d4b2ab3fd59edb01c57a12155f0375.zip |
Add size calculation
Diffstat (limited to 'backend')
-rw-r--r-- | backend/main.py | 31 |
1 files changed, 21 insertions, 10 deletions
diff --git a/backend/main.py b/backend/main.py index 716ca13..592b7a3 100644 --- a/backend/main.py +++ b/backend/main.py @@ -11,14 +11,13 @@ def playout(filename, content = "text/html"): def home(): return ["", [('Content-Type','text/html'), ("Location", config.homepage)], "302 Home"] -def target_filename_internal(session, file): - target = "" - if not file: - file = "" +def target_filename_internal(session, filename): + target = session["path"] + "/" + if filename: + target += filename if config.user_subdirs: - target = session["user"] + "/" - return target + session["path"] + "/" + file - + target = session["user"] + "/" + target + return target def target_filename(session, file): return config.fileroot + target_filename_internal(session, file) @@ -37,11 +36,23 @@ def resolve_alias(alias): return session def listing(session): - target = target_filename(session, None) - files = os.listdir(target) - return [json.dumps(files), [('Content-Type','application/json')], "200 OK"] + listing = {"total": 0, "files": []} + if 'r' not in session["access"]: + return ["", [('Content-Type','text/html')], "403 No"] + + directory = target_filename(session, None) + files = os.listdir(directory) + + for filename in files: + size = os.path.getsize(directory + filename) + listing["files"].append({"name": filename, "size": size}) + listing["total"] += size + + return [json.dumps(listing), [('Content-Type','application/json')], "200 OK"] def upload(session, post): + if 'c' not in session["access"]: + return ["", [('Content-Type','text/html')], "403 No"] if post["file"].filename: target = target_filename(session, os.path.basename(post["file"].filename)) try: |