Eagleget For Linux ✭

def stop(self): if self.server: self.server.shutdown() setup.py

def data(self, index, role=Qt.DisplayRole): if not index.isValid(): return None task = list(self.manager.tasks.values())[index.row()] if role == Qt.DisplayRole: if index.column() == 0: return task.filename elif index.column() == 1: return self.format_size(task.total_size) elif index.column() == 2: progress = (task.downloaded_size / task.total_size * 100) if task.total_size > 0 else 0 return f"progress:.1f%" elif index.column() == 3: return self.format_speed(task.speed) elif index.column() == 4: return task.status.value elif role == Qt.UserRole: return task return None

def resume_from_temp(self, temp_filepath: str): with open(temp_filepath, 'rb') as f: f.seek(0, 2) file_size = f.tell() # Update chunk downloaded sizes for chunk in self.chunks: if file_size > chunk.start: chunk.downloaded = min(chunk.end - chunk.start + 1, file_size - chunk.start)

class DownloadManager: def (self, db_path: str = "downloads.db"): self.db_path = db_path self.tasks: Dict[str, DownloadTask] = {} self.active_downloads: Dict[str, 'DownloadThread'] = {} self.queue = [] self.init_database() self.load_tasks() eagleget for linux

from setuptools import setup, find_packages setup( name="eagleget-linux", version="1.0.0", packages=find_packages(), install_requires=[ 'requests>=2.25.0', 'PyQt5>=5.15.0', 'pyperclip>=1.8.0', 'python-magic>=0.4.0', ], entry_points= 'console_scripts': [ 'eagleget=src.main:main', ], , author="Your Name", description="EagleGet Download Manager for Linux", classifiers=[ 'Development Status :: 4 - Beta', 'Intended Audience :: End Users/Desktop', 'License :: OSI Approved :: MIT License', 'Programming Language :: Python :: 3', ], )

#!/usr/bin/env python3 import sys import os from PyQt5.QtWidgets import QApplication from ui.main_window import MainWindow def main(): app = QApplication(sys.argv) app.setApplicationName("EagleGet for Linux") app.setOrganizationName("EagleGet")

def start_download(self): selection = self.table_view.selectionModel() if selection.hasSelection(): index = selection.selectedRows()[0] task = self.model.data(index, Qt.UserRole) if task.status in [DownloadStatus.PAUSED, DownloadStatus.PENDING]: self.manager.start_download(task.id) def stop(self): if self

def columnCount(self, parent=QModelIndex()): return len(self.headers)

def rowCount(self, parent=QModelIndex()): return len(self.manager.tasks)

def init_database(self): conn = sqlite3.connect(self.db_path) cursor = conn.cursor() cursor.execute(''' CREATE TABLE IF NOT EXISTS downloads ( id TEXT PRIMARY KEY, url TEXT, filename TEXT, save_path TEXT, total_size INTEGER, downloaded_size INTEGER, status TEXT, threads INTEGER, speed REAL, created_at TEXT, completed_at TEXT, md5 TEXT ) ''') conn.commit() conn.close() temp_filepath: str): with open(temp_filepath

def refresh(self): self.layoutChanged.emit() class MainWindow(QMainWindow): def (self): super(). init () self.manager = DownloadManager() self.init_ui() self.timer = QTimer() self.timer.timeout.connect(self.update_progress) self.timer.start(1000)

import os import json import sqlite3 import threading import hashlib from datetime import datetime from typing import List, Dict, Optional from dataclasses import dataclass, asdict from enum import Enum class DownloadStatus(Enum): PENDING = "pending" DOWNLOADING = "downloading" PAUSED = "paused" COMPLETED = "completed" FAILED = "failed" QUEUED = "queued"

def resume(self): self.paused = False

def stop(self): self.stopped = True