mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2025-01-25 19:58:37 +01:00
3fd820e5fa
Signed-off-by: Dimitris Zlatanidis <d.zlatanidis@gmail.com>
116 lines
No EOL
4.3 KiB
Python
116 lines
No EOL
4.3 KiB
Python
#!/usr/bin/python3
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# downloader.py file is part of slpkg.
|
|
|
|
# Copyright 2014-2020 Dimitris Zlatanidis <d.zlatanidis@gmail.com>
|
|
# All rights reserved.
|
|
|
|
# Slpkg is a user-friendly package manager for Slackware installations
|
|
|
|
# https://gitlab.com/dslackw/slpkg
|
|
|
|
# Slpkg is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
import os
|
|
import tarfile
|
|
import subprocess
|
|
|
|
from slpkg.utils import Utils
|
|
from slpkg.messages import Msg
|
|
from slpkg.slack.slack_version import slack_ver
|
|
from slpkg.__metadata__ import MetaData as _meta_
|
|
|
|
|
|
class Download:
|
|
"""Downloader manager. Slpkg use wget by default but support
|
|
curl, aria2 and httpie
|
|
"""
|
|
def __init__(self, path, url, repo):
|
|
self.path = path
|
|
self.url = url
|
|
self.repo = repo
|
|
self.file_name = ""
|
|
self.meta = _meta_
|
|
self.green = _meta_.color["GREEN"]
|
|
self.red = _meta_.color["RED"]
|
|
self.endc = _meta_.color["ENDC"]
|
|
self.msg = Msg()
|
|
self.dir_prefix = ""
|
|
self.downder = self.meta.downder
|
|
self.downder_options = self.meta.downder_options
|
|
|
|
def start(self):
|
|
"""Download files using wget or other downloader.
|
|
Optional curl, aria2c and httpie
|
|
"""
|
|
dwn_count = 1
|
|
self._directory_prefix()
|
|
for dwn in self.url:
|
|
self.file_name = Utils().fix_file_name(dwn.split("/")[-1])
|
|
|
|
if dwn.startswith("file:///"):
|
|
source_dir = dwn[7:-7].replace(slack_ver(), "")
|
|
self._make_tarfile(self.file_name, source_dir)
|
|
|
|
self._check_certificate()
|
|
print(f"\n[{dwn_count}/{len(self.url)}][ {self.green}Download{self.endc} ] --> {self.file_name}\n")
|
|
if self.downder in ["wget"]:
|
|
subprocess.call(f"{self.downder} {self.downder_options} {self.dir_prefix}{self.path} {dwn}", shell=True)
|
|
if self.downder in ["aria2c"]:
|
|
subprocess.call(f"{self.downder} {self.downder_options} {self.dir_prefix}{self.path[:-1]} {dwn}", shell=True)
|
|
elif self.downder in ["curl", "http"]:
|
|
subprocess.call(f"{self.downder} {self.downder_options} {self.path}{self.file_name} {dwn}", shell=True)
|
|
self._check_if_downloaded()
|
|
dwn_count += 1
|
|
|
|
def _make_tarfile(self, output_filename, source_dir):
|
|
"""Create .tar.gz file
|
|
"""
|
|
with tarfile.open(output_filename, "w:gz") as tar:
|
|
tar.add(source_dir, arcname=os.path.basename(source_dir))
|
|
|
|
def _directory_prefix(self):
|
|
"""Downloader options for specific directory
|
|
"""
|
|
if self.downder == "wget":
|
|
self.dir_prefix = "--directory-prefix="
|
|
elif self.downder == "aria2c":
|
|
self.dir_prefix = "--dir="
|
|
|
|
def _check_if_downloaded(self):
|
|
"""Check if file downloaded
|
|
"""
|
|
if not os.path.isfile(self.path + self.file_name):
|
|
print()
|
|
self.msg.template(78)
|
|
print(f"| Download '{self.file_name}' file [ {self.red}FAILED{self.endc} ]")
|
|
self.msg.template(78)
|
|
print()
|
|
if not self.msg.answer() in ["y", "Y"]:
|
|
raise SystemExit()
|
|
|
|
def _check_certificate(self):
|
|
"""Check for certificates options for wget
|
|
"""
|
|
if (self.file_name.startswith("jdk-") and self.repo == "sbo" and
|
|
self.downder == "wget"):
|
|
certificate = (' --no-check-certificate --header="Cookie: '
|
|
'oraclelicense=accept-securebackup-cookie"')
|
|
self.msg.template(78)
|
|
print(f"| '{certificate[:23].strip()}' need to go ahead downloading")
|
|
self.msg.template(78)
|
|
print()
|
|
self.downder_options += certificate
|
|
if not self.msg.answer() in ["y", "Y"]:
|
|
raise SystemExit() |