nixpkgs-update: add queue

This commit is contained in:
zowoq 2024-10-26 18:24:59 +10:00
parent b87603f6cf
commit 77ed21e32b
3 changed files with 103 additions and 0 deletions

View file

@ -3,4 +3,5 @@
- Logs: [https://nixpkgs-update-logs.nix-community.org](https://nixpkgs-update-logs.nix-community.org)
- Nixpkgs Pull Requests: [https://github.com/NixOS/nixpkgs/pulls?q=is%3Apr+author%3Ar-ryantm](https://github.com/NixOS/nixpkgs/pulls?q=is%3Apr+author%3Ar-ryantm)
- Matrix: [https://matrix.to/#/#nixpkgs-update:nixos.org](https://matrix.to/#/#nixpkgs-update:nixos.org)
- Queue: [https://nixpkgs-update-logs.nix-community.org/~supervisor/queue.html](https://nixpkgs-update-logs.nix-community.org/~supervisor/queue.html)
- Source: [https://github.com/nix-community/nixpkgs-update](https://github.com/nix-community/nixpkgs-update)

View file

@ -191,6 +191,30 @@ in
'';
};
systemd.services.nixpkgs-update-queue = {
after = [ config.systemd.services.nixpkgs-update-supervisor.name ];
wantedBy = [ config.systemd.targets.multi-user.name ];
serviceConfig = {
Type = "simple";
User = "r-ryantm";
Group = "r-ryantm";
Restart = "on-failure";
RestartSec = "5s";
LogsDirectory = "nixpkgs-update/";
LogsDirectoryMode = "755";
RuntimeDirectory = "nixpkgs-update-queue";
RuntimeDirectoryMode = "755";
};
path = [ pkgs.python3 ];
script = ''
cd "$LOGS_DIRECTORY/~supervisor"
python3 ${./update_queue.py}
'';
};
systemd.services.nixpkgs-update-delete-old-logs = {
startAt = "daily";
# delete logs older than 18 months, delete worker logs older than 3 months, delete empty directories

View file

@ -0,0 +1,78 @@
import sqlite3
import time
from datetime import datetime, timezone
def get_db_connection(db_path):
conn = sqlite3.connect(db_path)
conn.row_factory = sqlite3.Row
return conn
def fetch_queue_data(conn):
query = """
SELECT
ROW_NUMBER() OVER (ORDER BY last_started ASC) AS number,
attr_path,
payload
FROM
'queue'
ORDER BY
last_started ASC
"""
return conn.execute(query).fetchall()
def generate_html_table(rows):
table_rows = "".join(
f"""
<tr>
<td>{row['number']}</td>
<td>{row['attr_path']}</td>
<td>{row['payload']}</td>
</tr>
"""
for row in rows
)
return table_rows
def export_html(db_path):
with get_db_connection(db_path) as conn:
results = fetch_queue_data(conn)
generated = datetime.now(timezone.utc).strftime("%Y-%m-%d %H:%M:%S UTC")
html = f"""
<html>
<head>
<title>nixpkgs-update queue</title>
</head>
<body>
<h1>nixpkgs-update queue</h1>
<h3>this page is updated every 15 minutes, last updated: {generated}</h3>
<table>
<thead>
<tr>
<th>number</th>
<th>attribute path</th>
<th>payload</th>
</tr>
</thead>
<tbody>
{generate_html_table(results)}
</tbody>
</table>
</body>
</html>
"""
with open("queue.html", "w") as f:
f.write(html)
if __name__ == "__main__":
DB_PATH = "state.db"
while True:
export_html(DB_PATH)
time.sleep(15 * 60)