[aur-dev] [PATCH 1/4] Add popupdate script

Lukas Fleischer lfleischer at archlinux.org
Thu Jun 11 17:06:51 UTC 2015


This adds a simple script that can be used to recalculate the number of
votes per package. It can be used in a cronjob.

Signed-off-by: Lukas Fleischer <lfleischer at archlinux.org>
---
 scripts/popupdate.py | 27 +++++++++++++++++++++++++++
 1 file changed, 27 insertions(+)
 create mode 100755 scripts/popupdate.py

diff --git a/scripts/popupdate.py b/scripts/popupdate.py
new file mode 100755
index 0000000..489cd41
--- /dev/null
+++ b/scripts/popupdate.py
@@ -0,0 +1,27 @@
+#!/usr/bin/python3
+
+import configparser
+import mysql.connector
+import os
+
+docroot = os.path.dirname(os.path.realpath(__file__)) + "/../web/html/"
+
+config = configparser.RawConfigParser()
+config.read(os.path.dirname(os.path.realpath(__file__)) + "/../conf/config")
+
+aur_db_host = config.get('database', 'host')
+aur_db_name = config.get('database', 'name')
+aur_db_user = config.get('database', 'user')
+aur_db_pass = config.get('database', 'password')
+aur_db_socket = config.get('database', 'socket')
+
+db = mysql.connector.connect(host=aur_db_host, user=aur_db_user,
+                             passwd=aur_db_pass, db=aur_db_name,
+                             unix_socket=aur_db_socket, buffered=True)
+cur = db.cursor()
+
+cur.execute("UPDATE PackageBases SET NumVotes = (SELECT COUNT(*) FROM " +
+            "PackageVotes WHERE PackageVotes.PackageBaseID = PackageBases.ID)")
+
+db.commit()
+db.close()
-- 
2.4.2


More information about the aur-dev mailing list