Add delete unused uploads admin function

This commit is contained in:
rubenwardy 2020-05-30 16:48:37 +01:00
parent ed78a2e06f
commit c1b4256d44
3 changed files with 32 additions and 2 deletions

@ -26,7 +26,7 @@ from app.tasks.forumtasks import importTopicList, checkAllForumAccounts
from flask_wtf import FlaskForm from flask_wtf import FlaskForm
from wtforms import * from wtforms import *
from app.utils import loginUser, rank_required, triggerNotif from app.utils import loginUser, rank_required, triggerNotif
import datetime import datetime, os
@bp.route("/admin/", methods=["GET", "POST"]) @bp.route("/admin/", methods=["GET", "POST"])
@rank_required(UserRank.ADMIN) @rank_required(UserRank.ADMIN)
@ -114,6 +114,35 @@ def admin_page():
triggerNotif(package.author, current_user, msg, rel.getEditURL()) triggerNotif(package.author, current_user, msg, rel.getEditURL())
db.session.commit() db.session.commit()
elif action == "cleanuploads":
upload_dir = app.config['UPLOAD_DIR']
(_, _, filenames) = next(os.walk(upload_dir))
existing_uploads = set(filenames)
if len(existing_uploads) != 0:
def getURLsFromDB(column):
results = db.session.query(column).filter(column != None, column != "").all()
return set([os.path.basename(x[0]) for x in results])
release_urls = getURLsFromDB(PackageRelease.url)
screenshot_urls = getURLsFromDB(PackageScreenshot.url)
db_urls = release_urls.union(screenshot_urls)
unreachable = existing_uploads.difference(db_urls)
import sys
print("On Disk: ", existing_uploads, file=sys.stderr)
print("In DB: ", db_urls, file=sys.stderr)
print("Unreachable: ", unreachable, file=sys.stderr)
for filename in unreachable:
os.remove(os.path.join(upload_dir, filename))
flash("Deleted " + str(len(unreachable)) + " unreachable uploads", "success")
else:
flash("No downloads to create", "danger")
else: else:
flash("Unknown action: " + action, "danger") flash("Unknown action: " + action, "danger")

@ -25,6 +25,7 @@
<option value="recalcscores">Recalculate package scores</option> <option value="recalcscores">Recalculate package scores</option>
<option value="checkusers">Check forum users</option> <option value="checkusers">Check forum users</option>
<option value="importscreenshots">Import screenshots from VCS</option> <option value="importscreenshots">Import screenshots from VCS</option>
<option value="cleanuploads">Delete unreachable uploads</option>
<!-- <option value="importdepends">Import dependencies from downloads</option> --> <!-- <option value="importdepends">Import dependencies from downloads</option> -->
<!-- <option value="modprovides">Set provides to mod name</option> --> <!-- <option value="modprovides">Set provides to mod name</option> -->
<!-- <option value="vcsrelease">Create VCS releases</option> --> <!-- <option value="vcsrelease">Create VCS releases</option> -->

@ -73,7 +73,7 @@ def doFileUpload(file, fileType, fileTypeDesc):
ext = getExtension(file.filename) ext = getExtension(file.filename)
if ext is None or not ext in allowedExtensions: if ext is None or not ext in allowedExtensions:
flash("Please upload load " + fileTypeDesc, "danger") flash("Please upload " + fileTypeDesc, "danger")
return None, None return None, None
if isImage and not isAllowedImage(file.stream.read()): if isImage and not isAllowedImage(file.stream.read()):