mirror of
https://github.com/minetest/contentdb.git
synced 2025-01-05 12:47:29 +01:00
Add bulk dependency importer from Github
This commit is contained in:
parent
fb5cba4cc8
commit
746cf7f4b5
@ -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")
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user