From aa6892da82c709670a447434496f16392617aa69 Mon Sep 17 00:00:00 2001 From: rubenwardy Date: Tue, 14 Jul 2020 00:28:56 +0100 Subject: [PATCH] Add admin function to import foreign release URLs --- app/blueprints/admin/admin.py | 17 ++++++++++++++++- app/tasks/importtasks.py | 26 +++++++++++++++++++++++++- app/templates/admin/list.html | 1 + 3 files changed, 42 insertions(+), 2 deletions(-) diff --git a/app/blueprints/admin/admin.py b/app/blueprints/admin/admin.py index 01bd196..382dda8 100644 --- a/app/blueprints/admin/admin.py +++ b/app/blueprints/admin/admin.py @@ -21,7 +21,7 @@ import flask_menu as menu from . import bp from app.models import * from celery import uuid, group -from app.tasks.importtasks import importRepoScreenshot, makeVCSRelease, checkZipRelease, updateMetaFromRelease +from app.tasks.importtasks import importRepoScreenshot, makeVCSRelease, checkZipRelease, updateMetaFromRelease, importForeignDownloads from app.tasks.forumtasks import importTopicList, checkAllForumAccounts from flask_wtf import FlaskForm from wtforms import * @@ -71,6 +71,21 @@ def admin_page(): return redirect(url_for("todo.view")) + elif action == "importforeign": + releases = PackageRelease.query.filter(PackageRelease.url.like("http%")).all() + + tasks = [] + for release in releases: + tasks.append(importForeignDownloads.s(release.id)) + + result = group(tasks).apply_async() + + while not result.ready(): + import time + time.sleep(0.1) + + return redirect(url_for("todo.view")) + elif action == "importmodlist": task = importTopicList.delay() return redirect(url_for("tasks.check", id=task.id, r=url_for("todo.topics"))) diff --git a/app/tasks/importtasks.py b/app/tasks/importtasks.py index 0e5536c..e0b2308 100644 --- a/app/tasks/importtasks.py +++ b/app/tasks/importtasks.py @@ -27,7 +27,7 @@ from zipfile import ZipFile from app import app from app.models import * from app.tasks import celery, TaskError -from app.utils import randomString +from app.utils import randomString, getExtension from .minetestcheck import build_tree, MinetestCheckError, ContentType from .minetestcheck.config import parse_conf @@ -341,3 +341,27 @@ def importRepoScreenshot(id): print("screenshot.png does not exist") return None + + +@celery.task(bind=True) +def importForeignDownloads(self, id): + release = PackageRelease.query.get(id) + if release is None: + raise TaskError("No such release!") + elif release.package is None: + raise TaskError("No package attached to release") + elif not release.url.startswith("http"): + return + + try: + ext = getExtension(release.url) + filename = randomString(10) + "." + ext + filepath = os.path.join(app.config["UPLOAD_DIR"], filename) + urllib.request.urlretrieve(release.url, filepath) + + release.url = "/uploads/" + filename + db.session.commit() + except urllib.error.URLError: + release.task_id = self.request.id + release.approved = False + db.session.commit() diff --git a/app/templates/admin/list.html b/app/templates/admin/list.html index faa6652..75fb61e 100644 --- a/app/templates/admin/list.html +++ b/app/templates/admin/list.html @@ -28,6 +28,7 @@ +