Add bulk dependency importer from Github

This commit is contained in:
rubenwardy 2018-05-27 22:34:24 +01:00
parent fb5cba4cc8
commit 746cf7f4b5
No known key found for this signature in database
GPG Key ID: A1E29D52FF81513C
3 changed files with 97 additions and 3 deletions

@ -215,7 +215,6 @@ def getMeta(urlstr, author):
if info is not None: if info is not None:
result["forumId"] = info.get("topicId") result["forumId"] = info.get("topicId")
print(result)
return result return result
@ -291,3 +290,94 @@ def importRepoScreenshot(id):
print("screenshot.png does not exist") print("screenshot.png does not exist")
return None return None
def getDepends(package):
url = urlparse(package.repo)
urlmaker = None
if url.netloc == "github.com":
urlmaker = GithubURLMaker(url)
else:
raise TaskError("Unsupported repo")
result = {}
if urlmaker.isValid():
#
# Try getting depends on mod.conf
#
try:
contents = urllib.request.urlopen(urlmaker.getModConfURL()).read().decode("utf-8")
conf = parseConf(contents)
for key in ["depends", "optional_depends"]:
try:
result[key] = conf[key]
except KeyError:
pass
except HTTPError:
print("mod.conf does not exist")
if "depends" in result or "optional_depends" in result:
return result
#
# Try depends.txt
#
import re
pattern = re.compile("^([a-z0-9_]+)\??$")
try:
contents = urllib.request.urlopen(urlmaker.getDependsURL()).read().decode("utf-8")
soft = []
hard = []
for line in contents.split("\n"):
line = line.strip()
if pattern.match(line):
if line[len(line) - 1] == "?":
soft.append( line[:-1])
else:
hard.append(line)
result["depends"] = ",".join(hard)
result["optional_depends"] = ",".join(soft)
except HTTPError:
print("depends.txt does not exist")
return result
else:
print(TaskError("non-github depends detector not implemented yet!"))
return {}
def importDependencies(package, mpackage_cache):
if Dependency.query.filter_by(depender=package).count() != 0:
return
result = getDepends(package)
if "depends" in result:
deps = Dependency.SpecToList(package, result["depends"], mpackage_cache)
print("{} hard: {}".format(len(deps), result["depends"]))
for dep in deps:
dep.optional = False
db.session.add(dep)
if "optional_depends" in result:
deps = Dependency.SpecToList(package, result["optional_depends"], mpackage_cache)
print("{} soft: {}".format(len(deps), result["optional_depends"]))
for dep in deps:
dep.optional = True
db.session.add(dep)
@celery.task()
def importAllDependencies():
Dependency.query.delete()
mpackage_cache = {}
packages = Package.query.filter_by(type=PackageType.MOD).all()
for i, p in enumerate(packages):
print("============= {} ({}/{}) =============".format(p.name, i, len(packages)))
importDependencies(p, mpackage_cache)
db.session.commit()

@ -17,8 +17,9 @@
<form method="post" action="" class="box-body"> <form method="post" action="" class="box-body">
<input type="hidden" name="csrf_token" value="{{ csrf_token() }}" /> <input type="hidden" name="csrf_token" value="{{ csrf_token() }}" />
<select name="action"> <select name="action">
<option value="importusers" selected>Create users from mod list</option> <option value="importusers">Create users from mod list</option>
<option value="importscreenshots">Import screenshots from VCS</option> <option value="importscreenshots">Import screenshots from VCS</option>
<option value="importdepends" selected>Import dependencies from downloads</option>
</select> </select>
<input type="submit" value="Perform" /> <input type="submit" value="Perform" />
</form> </form>

@ -20,7 +20,7 @@ from flask_user import *
from flask.ext import menu from flask.ext import menu
from app import app from app import app
from app.models import * from app.models import *
from app.tasks.importtasks import importRepoScreenshot from app.tasks.importtasks import importRepoScreenshot, importAllDependencies
from app.tasks.forumtasks import importUsersFromModList from app.tasks.forumtasks import importUsersFromModList
from flask_wtf import FlaskForm from flask_wtf import FlaskForm
from wtforms import * from wtforms import *
@ -52,6 +52,9 @@ def admin_page():
package.soft_deleted = False package.soft_deleted = False
db.session.commit() db.session.commit()
return redirect(url_for("admin_page")) return redirect(url_for("admin_page"))
elif action == "importdepends":
task = importAllDependencies.delay()
return redirect(url_for("check_task", id=task.id, r=url_for("admin_page")))
else: else:
flash("Unknown action: " + action, "error") flash("Unknown action: " + action, "error")