mirror of
https://github.com/Arrowar/StreamingCommunity.git
synced 2025-06-07 12:05:35 +00:00
Fix tor dont save file, fix update version to latest commit.
This commit is contained in:
parent
49e1dd2c3a
commit
9d74ae2a2d
@ -31,7 +31,6 @@ REQUEST_TIMEOUT = config_manager.get_float('REQUESTS', 'timeout')
|
||||
|
||||
|
||||
|
||||
|
||||
class TOR_downloader:
|
||||
def __init__(self):
|
||||
"""
|
||||
@ -89,7 +88,6 @@ class TOR_downloader:
|
||||
except Exception as e:
|
||||
logging.error(f"Failed to add magnet link: {str(e)}")
|
||||
|
||||
|
||||
def start_download(self):
|
||||
"""
|
||||
Starts downloading the latest added torrent and monitors progress.
|
||||
@ -196,6 +194,8 @@ class TOR_downloader:
|
||||
Returns:
|
||||
- bool: True if files are moved successfully, False otherwise.
|
||||
"""
|
||||
|
||||
video_extensions = {'.mp4', '.mkv', 'avi'}
|
||||
time.sleep(2)
|
||||
|
||||
# List directories in the save path
|
||||
@ -205,9 +205,18 @@ class TOR_downloader:
|
||||
if self.torrent_name.split(" ")[0] in dir_name:
|
||||
dir_path = os.path.join(self.save_path, dir_name)
|
||||
|
||||
shutil.move(dir_path, destination)
|
||||
logging.info(f"Moved directory {dir_name} to {destination}")
|
||||
break
|
||||
# Ensure destination is set; if not, use current directory
|
||||
destination = destination or os.getcwd()
|
||||
|
||||
# Move only video files
|
||||
for file_name in os.listdir(dir_path):
|
||||
file_path = os.path.join(dir_path, file_name)
|
||||
|
||||
# Check if it's a file and if it has a video extension
|
||||
if os.path.isfile(file_path) and os.path.splitext(file_name)[1] in video_extensions:
|
||||
shutil.move(file_path, os.path.join(destination, file_name))
|
||||
logging.info(f"Moved file {file_name} to {destination}")
|
||||
|
||||
time.sleep(2)
|
||||
self.qb.delete_permanently(self.qb.torrents()[-1]['hash'])
|
||||
return True
|
||||
|
@ -23,8 +23,8 @@ def move_content(source: str, destination: str) :
|
||||
Move all content from the source folder to the destination folder.
|
||||
|
||||
Parameters:
|
||||
source (str): The path to the source folder.
|
||||
destination (str): The path to the destination folder.
|
||||
- source (str): The path to the source folder.
|
||||
- destination (str): The path to the destination folder.
|
||||
"""
|
||||
|
||||
os.makedirs(destination, exist_ok=True)
|
||||
@ -48,9 +48,9 @@ def keep_specific_items(directory: str, keep_folder: str, keep_file: str):
|
||||
Delete all items in the directory except for the specified folder and file.
|
||||
|
||||
Parameters:
|
||||
directory (str): The path to the directory.
|
||||
keep_folder (str): The name of the folder to keep.
|
||||
keep_file (str): The name of the file to keep.
|
||||
- directory (str): The path to the directory.
|
||||
- keep_folder (str): The name of the folder to keep.
|
||||
- keep_file (str): The name of the file to keep.
|
||||
"""
|
||||
|
||||
try:
|
||||
@ -64,14 +64,15 @@ def keep_specific_items(directory: str, keep_folder: str, keep_file: str):
|
||||
# Check if the item is the specified folder or file
|
||||
if os.path.isdir(item_path) and item != keep_folder:
|
||||
shutil.rmtree(item_path)
|
||||
|
||||
elif os.path.isfile(item_path) and item != keep_file:
|
||||
os.remove(item_path)
|
||||
|
||||
except PermissionError as pe:
|
||||
print(f"PermissionError: {pe}. Check permissions and try running the script with admin privileges.")
|
||||
console.print(f"[red]PermissionError: {pe}. Check permissions and try again.")
|
||||
|
||||
except Exception as e:
|
||||
print(f"Error: {e}")
|
||||
console.print(f"[red]Error: {e}")
|
||||
|
||||
|
||||
def download_and_extract_latest_commit():
|
||||
@ -79,25 +80,27 @@ def download_and_extract_latest_commit():
|
||||
Download and extract the latest commit from a GitHub repository.
|
||||
"""
|
||||
|
||||
try:
|
||||
|
||||
# Get the latest commit information using GitHub API
|
||||
api_url = f'https://api.github.com/repos/{__author__}/{__title__}/commits?per_page=1'
|
||||
response = httpx.get(api_url)
|
||||
console.log("[green]Making a request to GitHub repository...")
|
||||
response = httpx.get(api_url, timeout=10)
|
||||
console.log("[green]Requesting latest commit from GitHub repository...")
|
||||
|
||||
if response.status_code == 200:
|
||||
commit_info = response.json()[0]
|
||||
commit_sha = commit_info['sha']
|
||||
zipball_url = f'https://github.com/{__author__}/{__title__}/archive/{commit_sha}.zip'
|
||||
console.log("[green]Getting zip file from repository...")
|
||||
console.log("[green]Downloading latest commit zip file...")
|
||||
|
||||
# Download the zipball
|
||||
response = httpx.get(zipball_url, follow_redirects=True, timeout=10)
|
||||
temp_path = os.path.join(os.path.dirname(os.getcwd()), 'temp_extracted')
|
||||
|
||||
# Extract the content of the zipball into a temporary folder
|
||||
temp_path = os.path.join(os.path.dirname(os.getcwd()), 'temp_extracted')
|
||||
with ZipFile(BytesIO(response.content)) as zip_ref:
|
||||
zip_ref.extractall(temp_path)
|
||||
console.log("[green]Extracting file ...")
|
||||
console.log("[green]Extracting files...")
|
||||
|
||||
# Move files from the temporary folder to the current folder
|
||||
for item in os.listdir(temp_path):
|
||||
@ -114,28 +117,31 @@ def download_and_extract_latest_commit():
|
||||
|
||||
# Remove old temp folder
|
||||
shutil.rmtree(new_folder_name)
|
||||
|
||||
console.log(f"[cyan]Latest commit downloaded and extracted successfully.")
|
||||
console.log("[cyan]Latest commit downloaded and extracted successfully.")
|
||||
else:
|
||||
console.log(f"[red]Failed to fetch commit information. Status code: {response.status_code}")
|
||||
|
||||
except httpx.RequestError as e:
|
||||
console.print(f"[red]Request failed: {e}")
|
||||
|
||||
except Exception as e:
|
||||
console.print(f"[red]An unexpected error occurred: {e}")
|
||||
|
||||
|
||||
def main_upload():
|
||||
"""
|
||||
Main function to upload the latest commit of a GitHub repository.
|
||||
"""
|
||||
|
||||
cmd_insert = Prompt.ask("[bold red]Are you sure you want to delete all files? (Only videos folder will remain)[/bold red] [yes/no]")
|
||||
cmd_insert = Prompt.ask("[bold red]Are you sure you want to delete all files? (Only 'Video' folder and 'update_version.py' will remain)", choices=['y', 'n'], default='y', show_choices=True)
|
||||
|
||||
if cmd_insert.lower() == "yes":
|
||||
console.print("[red]Deleting all files except the videos folder...")
|
||||
|
||||
# Remove all old file
|
||||
console.print("[red]Deleting all files except 'Video' folder and 'update_version.py'...")
|
||||
keep_specific_items(".", "Video", "upload.py")
|
||||
|
||||
download_and_extract_latest_commit()
|
||||
|
||||
else:
|
||||
console.print("[red]Operation cancelled.")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main_upload()
|
||||
|
Loading…
x
Reference in New Issue
Block a user