Appstream import fixes

This commit is contained in:
Rampoina 2022-02-17 17:54:23 +01:00
parent 71ca47846d
commit 6f926a321c
1 changed files with 56 additions and 19 deletions

View File

@ -1,4 +1,5 @@
import gi
import PIL
import requests
import os
import sys
@ -54,6 +55,19 @@ session=db.session
licenses = { x.name : x for x in License.query.all() }
tags = { x.name : x for x in Tag.query.all() }
admin_user = User.query.filter_by(username="appstream").first()
for ss in PackageScreenshot.query.all():
if ss.package.cover_image == ss:
ss.package.cover_image = None
session.commit()
session.delete(ss)
session.commit()
for game in Package.query.all():
session.delete(game)
session.commit()
if not admin_user:
admin_user = User("appstream")
admin_user.is_active = True
@ -71,10 +85,16 @@ for app in apps:
print("APPLICATION: ",app.get_name())
game1 = Package()
game1.state = PackageState.APPROVED
game1.name = app.get_id().replace('.','_')
game1.name = app.get_id().replace('.','_').replace('-','_')
game1.title = app.get_name()
game1.type = PackageType.GAME
game1.license = licenses["MIT"]
license = "Uknown" if app.get_project_license() is None else app.get_project_license().split("AND")[0].split("and")[0]
if license not in licenses:
row = License(license)
licenses[row.name] = row
session.add(row)
session.commit()
game1.license = licenses[license]
#game1.license = licenses[app.get_project_license()]
game1.media_license = licenses["MIT"]
game1.author = admin_user
@ -92,25 +112,42 @@ for app in apps:
game1.desc = app.get_description()
session.add(game1)
for i,screenshot in enumerate(screenshots):
ss = PackageScreenshot()
ss.package = game1
ss.title = "Untitled"
for screenshot in screenshots:
counter = 1
url = screenshot.get_url()
r = requests.get(url)
filename = randomString(10) + "." + "png"
filepath = os.path.join("/var/cdb/uploads", filename)
with open(filepath,"wb") as f:
f.write(r.content)
try:
r = requests.get(url,timeout=10)
r.raise_for_status()
filename = randomString(10) + "." + "png"
filepath = os.path.join("/var/cdb/uploads", filename)
print("Screenshot url: ", url)
with open(filepath,"wb") as f:
f.write(r.content)
ss.url = "uploads/" + filename
ss.approved = True
ss.order = i
ss.width, ss.height = get_image_size(filepath)
session.add(ss)
session.commit()
game1.cover_image = ss
session.commit()
width, height = get_image_size(filepath)
if (width is not None) and (height is not None):
ss = PackageScreenshot()
ss.package = game1
ss.title = "Untitled"
ss.url = "/uploads/" + filename
ss.width = width
ss.height = height
ss.approved = True
ss.order = counter
session.add(ss)
session.commit()
game1.cover_image = ss
session.commit()
counter += 1
except requests.exceptions.HTTPError as err:
print("HTTP error downloading the screenshot ", err)
except requests.exceptions.ConnectionError as err:
print("HTTP error downloading the screenshot ", err)
except requests.exceptions.ReadTimeout as err:
print("Screenshot timeout ", err)
except PIL.UnidentifiedImageError as err:
print("Corrupt image ", err)
session.commit()