testing
This commit is contained in:
parent
01e68bc10f
commit
b61ce7e7c1
101
main.py
101
main.py
@ -8,15 +8,17 @@ archival locations.
|
||||
|
||||
"""
|
||||
|
||||
import argparse
|
||||
import os
|
||||
import sqlite3
|
||||
import sys
|
||||
import uuid
|
||||
import argparse
|
||||
import sqlite3
|
||||
|
||||
import qbittorrent
|
||||
|
||||
# SCHEMA format is YYYYMMDDX
|
||||
SCHEMA = 202410040
|
||||
SCHEMA = 202410042
|
||||
|
||||
|
||||
def init_db(conn):
|
||||
"""
|
||||
@ -27,34 +29,73 @@ def init_db(conn):
|
||||
c.executescript(
|
||||
f"""
|
||||
PRAGMA user_version = {SCHEMA};
|
||||
|
||||
CREATE TABLE IF NOT EXISTS clients (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
uuid TEXT NOT NULL UNIQUE,
|
||||
endpoint TEXT NOT NULL,
|
||||
last_seen DATETIME NOT NULL
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS torrents (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
info_hash_v1 TEXT NOT NULL UNIQUE,
|
||||
info_hash_v2 TEXT UNIQUE,
|
||||
name TEXT NOT NULL,
|
||||
file_count INTEGER NOT NULL,
|
||||
completed_on DATETIME NOT NULL
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS torrent_clients (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
torrent_id INTEGER NOT NULL,
|
||||
client_id INTEGER NOT NULL,
|
||||
name TEXT NOT NULL,
|
||||
content_path TEXT NOT NULL,
|
||||
completed_on DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
tracker_ids TEXT
|
||||
last_seen DATETIME NOT NULL,
|
||||
FOREIGN KEY (torrent_id) REFERENCES torrents(id),
|
||||
FOREIGN KEY (client_id) REFERENCES clients(id),
|
||||
UNIQUE (torrent_id, client_id)
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS trackers (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
url TEXT NOT NULL UNIQUE
|
||||
url TEXT NOT NULL UNIQUE,
|
||||
last_seen DATETIME NOT NULL
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS torrent_trackers (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
client_id INTEGER NOT NULL,
|
||||
torrent_id INTEGER NOT NULL,
|
||||
tracker_id INTEGER NOT NULL,
|
||||
last_seen DATETIME NOT NULL,
|
||||
FOREIGN KEY (client_id) REFERENCES clients(id),
|
||||
FOREIGN KEY (torrent_id) REFERENCES torrents(id),
|
||||
FOREIGN KEY (tracker_id) REFERENCES trackers(id),
|
||||
UNIQUE (client_id, torrent_id, tracker_id)
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS files (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
torrent_id INTEGER NOT NULL,
|
||||
file_index INTEGER NOT NULL,
|
||||
file_path TEXT NOT NULL,
|
||||
size INTEGER NOT NULL,
|
||||
is_downloaded BOOLEAN NOT NULL DEFAULT 0,
|
||||
last_checked DATETIME,
|
||||
FOREIGN KEY (torrent_id) REFERENCES torrents(id),
|
||||
UNIQUE (torrent_id, file_index)
|
||||
oshash TEXT NOT NULL UNIQUE,
|
||||
hash TEXT UNIQUE
|
||||
);
|
||||
|
||||
CREATE TABLE IF NOT EXISTS torrent_files (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
file_id INTEGER NOT NULL,
|
||||
torrent_id INTEGER NOT NULL,
|
||||
client_id INTEGER NOT NULL,
|
||||
file_index INTEGER NOT NULL,
|
||||
file_path TEXT NOT NULL,
|
||||
is_downloaded BOOLEAN NOT NULL,
|
||||
last_checked DATETIME NOT NULL,
|
||||
FOREIGN KEY (file_id) REFERENCES files(id),
|
||||
FOREIGN KEY (torrent_id) REFERENCES torrents(id),
|
||||
FOREIGN KEY (client_id) REFERENCES clients(id),
|
||||
UNIQUE (file_id, torrent_id, client_id, file_index)
|
||||
);
|
||||
"""
|
||||
)
|
||||
c.close()
|
||||
@ -71,6 +112,20 @@ def list_tables(conn):
|
||||
return [table[0] for table in table_list]
|
||||
|
||||
|
||||
def add_client(conn, endpoint, last_seen):
|
||||
"""
|
||||
Add a new client endpoint to database
|
||||
"""
|
||||
c = conn.cursor()
|
||||
c.execute(
|
||||
f"""
|
||||
INSERT INTO clients (uuid, endpoint, last_seen)
|
||||
VALUES ("{uuid}", "{endpoint}", "{last_seen}");
|
||||
"""
|
||||
)
|
||||
c.close()
|
||||
|
||||
|
||||
parser = argparse.ArgumentParser(description="Manage BitTorrent datasets", prog="tarch")
|
||||
subparsers = parser.add_subparsers(
|
||||
dest="command", required=True, help="Available commands"
|
||||
@ -78,6 +133,7 @@ subparsers = parser.add_subparsers(
|
||||
|
||||
scan_parser = subparsers.add_parser("scan", help="Scan command")
|
||||
scan_parser.add_argument("--debug", action="store_true", help="Enable debug mode")
|
||||
scan_parser.add_argument("--confirm-add", help="Confirm adding a new client")
|
||||
scan_parser.add_argument("-d", "--directory", help="Directory to scan")
|
||||
scan_parser.add_argument("-t", "--type", help="Scan type")
|
||||
scan_parser.add_argument("-e", "--endpoint", help="Endpoint URL")
|
||||
@ -96,7 +152,7 @@ if args.command == "scan":
|
||||
sqlitedb = sqlite3.connect(STORAGE)
|
||||
tables = list_tables(sqlitedb)
|
||||
except sqlite3.DatabaseError as e:
|
||||
print(f"[ERROR]: Database \"{STORAGE}\" Error: {str(e)}")
|
||||
print(f'[ERROR]: Database "{STORAGE}" Error: {str(e)}')
|
||||
sys.exit(1)
|
||||
if len(tables) == 0:
|
||||
print(f"[INFO]: Initializing database at {STORAGE}")
|
||||
@ -111,17 +167,26 @@ if args.command == "scan":
|
||||
if not args.directory is None:
|
||||
print("[INFO]: --directory is not implemented\n")
|
||||
sys.exit(0)
|
||||
if not args.endpoint is None:
|
||||
elif not args.endpoint is None:
|
||||
qb = qbittorrent.Client(args.endpoint)
|
||||
print(repr(qb))
|
||||
print(f"[INFO]: qbittorrent version is {qb.app.version}")
|
||||
torrents = qb.torrents()
|
||||
print(f"[INFO]: There are {len(torrents)} torrents\n")
|
||||
for torrent in torrents[:10]:
|
||||
files = qb.get_torrent_files(torrent["hash"])
|
||||
if args.debug:
|
||||
print(f"[DEBUG]: {repr(torrent)}")
|
||||
trackers = qb.get_torrent_trackers(torrent["hash"])
|
||||
print(f"[name]: {torrent['name']}")
|
||||
print(f"[infohash_v1]: {torrent['infohash_v1']}")
|
||||
print(f"[content_path]: {torrent['content_path']}")
|
||||
print(f"[magent_uri]: {torrent['magnet_uri'][0:80]}")
|
||||
print(f"[completed_on]: {torrent['completed']}")
|
||||
print(f"[trackers]: {len(trackers)}\n")
|
||||
print(f"[file_count]: {len(files)}\n")
|
||||
if args.debug:
|
||||
print(f"[DEBUG]: {repr(torrent)}")
|
||||
for elem in trackers:
|
||||
print(f"[tracker]: {repr(elem)}")
|
||||
else:
|
||||
print("[ERROR]: Must specify directory OR client endpoint")
|
||||
sys.exit(1)
|
||||
|
@ -1 +1,2 @@
|
||||
python-qbittorrent==0.4.3
|
||||
oshash==0.1.1
|
Loading…
x
Reference in New Issue
Block a user