Fix incorrect package list in admin actions

This commit is contained in:
rubenwardy 2024-01-27 22:41:31 +00:00
parent cbe232ca0c
commit 4c5b506053

@ -121,10 +121,9 @@ def _package_list(packages: List[str]):
# Who needs translations? # Who needs translations?
if len(packages) >= 3: if len(packages) >= 3:
packages[len(packages) - 1] = "and " + packages[len(packages) - 1] packages[len(packages) - 1] = "and " + packages[len(packages) - 1]
packages_list = ", ".join(packages) return ", ".join(packages)
else: else:
packages_list = " and ".join(packages) return " and ".join(packages)
return packages_list
@action("Send WIP package notification") @action("Send WIP package notification")
@ -133,12 +132,12 @@ def remind_wip():
Package.state == PackageState.WIP, Package.state == PackageState.CHANGES_NEEDED))) Package.state == PackageState.WIP, Package.state == PackageState.CHANGES_NEEDED)))
system_user = get_system_user() system_user = get_system_user()
for user in users: for user in users:
packages = db.session.query(Package.title).filter( packages = Package.query.filter(
Package.author_id == user.id, Package.author_id == user.id,
or_(Package.state == PackageState.WIP, Package.state == PackageState.CHANGES_NEEDED)) \ or_(Package.state == PackageState.WIP, Package.state == PackageState.CHANGES_NEEDED)) \
.all() .all()
packages = [pkg[0] for pkg in packages] packages = [pkg.title for pkg in packages]
packages_list = _package_list(packages) packages_list = _package_list(packages)
havent = "haven't" if len(packages) > 1 else "hasn't" havent = "haven't" if len(packages) > 1 else "hasn't"
@ -154,12 +153,12 @@ def remind_outdated():
Package.update_config.has(PackageUpdateConfig.outdated_at.isnot(None)))) Package.update_config.has(PackageUpdateConfig.outdated_at.isnot(None))))
system_user = get_system_user() system_user = get_system_user()
for user in users: for user in users:
packages = db.session.query(Package.title).filter( packages = Package.query.filter(
Package.maintainers.contains(user), Package.maintainers.contains(user),
Package.update_config.has(PackageUpdateConfig.outdated_at.isnot(None))) \ Package.update_config.has(PackageUpdateConfig.outdated_at.isnot(None))) \
.all() .all()
packages = [pkg[0] for pkg in packages] packages = [pkg.title for pkg in packages]
packages_list = _package_list(packages) packages_list = _package_list(packages)
add_notification(user, system_user, NotificationType.PACKAGE_APPROVAL, add_notification(user, system_user, NotificationType.PACKAGE_APPROVAL,
@ -231,15 +230,15 @@ def remind_video_url():
and_(Package.video_url == None, Package.type == PackageType.GAME, Package.state == PackageState.APPROVED))) and_(Package.video_url == None, Package.type == PackageType.GAME, Package.state == PackageState.APPROVED)))
system_user = get_system_user() system_user = get_system_user()
for user in users: for user in users:
packages = db.session.query(Package.title).filter( packages = Package.query.filter(
or_(Package.author == user, Package.maintainers.contains(user)), or_(Package.author == user, Package.maintainers.contains(user)),
Package.video_url == None, Package.video_url == None,
Package.type == PackageType.GAME, Package.type == PackageType.GAME,
Package.state == PackageState.APPROVED) \ Package.state == PackageState.APPROVED) \
.all() .all()
packages = [pkg[0] for pkg in packages] package_names = [pkg.title for pkg in packages]
packages_list = _package_list(packages) packages_list = _package_list(package_names)
add_notification(user, system_user, NotificationType.PACKAGE_APPROVAL, add_notification(user, system_user, NotificationType.PACKAGE_APPROVAL,
f"You should add a video to {packages_list}", f"You should add a video to {packages_list}",
@ -259,7 +258,7 @@ def remind_missing_game_support():
system_user = get_system_user() system_user = get_system_user()
for user in users: for user in users:
packages = db.session.query(Package.title).filter( packages = Package.query.filter(
Package.maintainers.contains(user), Package.maintainers.contains(user),
Package.state != PackageState.DELETED, Package.state != PackageState.DELETED,
Package.type.in_([PackageType.MOD, PackageType.TXP]), Package.type.in_([PackageType.MOD, PackageType.TXP]),
@ -267,7 +266,7 @@ def remind_missing_game_support():
Package.supports_all_games == False) \ Package.supports_all_games == False) \
.all() .all()
packages = [pkg[0] for pkg in packages] packages = [pkg.title for pkg in packages]
packages_list = _package_list(packages) packages_list = _package_list(packages)
add_notification(user, system_user, NotificationType.PACKAGE_APPROVAL, add_notification(user, system_user, NotificationType.PACKAGE_APPROVAL,