mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2025-01-27 19:58:21 +01:00
Updated configs
Signed-off-by: Dimitris Zlatanidis <d.zlatanidis@gmail.com>
This commit is contained in:
parent
74be03c890
commit
77ad114452
7 changed files with 35 additions and 47 deletions
|
@ -12,10 +12,10 @@ class Blacklist:
|
||||||
''' Reads and returns the blacklist. '''
|
''' Reads and returns the blacklist. '''
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.etc_path: str = Configs.etc_path
|
self.configs: str = Configs
|
||||||
|
|
||||||
def get(self):
|
def get(self):
|
||||||
file = f'{self.etc_path}/blacklist.toml'
|
file = f'{self.configs.etc_path}/blacklist.toml'
|
||||||
if os.path.isfile(file):
|
if os.path.isfile(file):
|
||||||
with open(file, 'rb') as black:
|
with open(file, 'rb') as black:
|
||||||
return tomli.load(black)['blacklist']['packages']
|
return tomli.load(black)['blacklist']['packages']
|
||||||
|
|
|
@ -12,18 +12,16 @@ class CheckUpdates:
|
||||||
''' Check for changes in the ChangeLog file. '''
|
''' Check for changes in the ChangeLog file. '''
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.sbo_repo_url: str = Configs.sbo_repo_url
|
self.configs: str = Configs
|
||||||
self.sbo_repo_path: str = Configs.sbo_repo_path
|
|
||||||
self.chglog_txt: str = Configs.chglog_txt
|
|
||||||
|
|
||||||
def updates(self):
|
def updates(self):
|
||||||
|
|
||||||
local_date = 0
|
local_date = 0
|
||||||
local_chg_txt = f'{self.sbo_repo_path}/{self.chglog_txt}'
|
local_chg_txt = (f'{self.configs.sbo_repo_path}/'
|
||||||
|
f'{self.configs.chglog_txt}')
|
||||||
|
|
||||||
http = urllib3.PoolManager()
|
http = urllib3.PoolManager()
|
||||||
repo = http.request(
|
repo = http.request(
|
||||||
'GET', f'{self.sbo_repo_url}/{self.chglog_txt}')
|
'GET', f'{self.configs.sbo_repo_url}/{self.configs.chglog_txt}')
|
||||||
|
|
||||||
if os.path.isfile(local_chg_txt):
|
if os.path.isfile(local_chg_txt):
|
||||||
local_date = int(os.stat(local_chg_txt).st_size)
|
local_date = int(os.stat(local_chg_txt).st_size)
|
||||||
|
|
|
@ -12,11 +12,7 @@ class Check:
|
||||||
''' Some checks before proceed. '''
|
''' Some checks before proceed. '''
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.log_packages: str = Configs.log_packages
|
self.configs: str = Configs
|
||||||
self.sbo_repo_tag: str = Configs.sbo_repo_tag
|
|
||||||
self.db_path: str = Configs.db_path
|
|
||||||
self.database_name: str = Configs.database
|
|
||||||
self.etc_path: str = Configs.etc_path
|
|
||||||
|
|
||||||
def exists(self, slackbuilds: list):
|
def exists(self, slackbuilds: list):
|
||||||
''' Checking if the slackbuild exists in the repository. '''
|
''' Checking if the slackbuild exists in the repository. '''
|
||||||
|
@ -43,9 +39,9 @@ class Check:
|
||||||
found, not_found = [], []
|
found, not_found = [], []
|
||||||
|
|
||||||
for sbo in slackbuilds:
|
for sbo in slackbuilds:
|
||||||
for package in os.listdir(self.log_packages):
|
for package in os.listdir(self.configs.log_packages):
|
||||||
if (package.startswith(f'{sbo}-') and
|
if (package.startswith(f'{sbo}-') and
|
||||||
package.endswith(self.sbo_repo_tag)):
|
package.endswith(self.configs.sbo_repo_tag)):
|
||||||
found.append(sbo)
|
found.append(sbo)
|
||||||
|
|
||||||
for sbo in slackbuilds:
|
for sbo in slackbuilds:
|
||||||
|
@ -70,12 +66,12 @@ class Check:
|
||||||
if packages:
|
if packages:
|
||||||
raise SystemExit(
|
raise SystemExit(
|
||||||
f'\nThe packages \'{", ".join(packages)}\' is blacklisted.\n'
|
f'\nThe packages \'{", ".join(packages)}\' is blacklisted.\n'
|
||||||
f'Please edit the blacklist.toml file in {self.etc_path} '
|
f'Please edit the blacklist.toml file in '
|
||||||
'folder.\n')
|
f'{self.configs.etc_path} folder.\n')
|
||||||
|
|
||||||
def database(self):
|
def database(self):
|
||||||
''' Checking for empty table '''
|
''' Checking for empty table '''
|
||||||
db = f'{self.db_path}/{self.database_name}'
|
db = f'{self.configs.db_path}/{self.configs.database}'
|
||||||
if not SBoQueries('').names() or not os.path.isfile(db):
|
if not SBoQueries('').names() or not os.path.isfile(db):
|
||||||
raise SystemExit('\nYou need to update the package lists first.\n'
|
raise SystemExit('\nYou need to update the package lists first.\n'
|
||||||
'Please run slpkg update.\n')
|
'Please run slpkg update.\n')
|
||||||
|
|
|
@ -11,9 +11,7 @@ class CreateData:
|
||||||
''' Reads the SLACKBUILDS.TXT file and inserts them into the database. '''
|
''' Reads the SLACKBUILDS.TXT file and inserts them into the database. '''
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.db_path: str = Configs.db_path
|
self.configs: str = Configs
|
||||||
self.sbo_txt: str = Configs.sbo_txt
|
|
||||||
self.sbo_repo_path: str = Configs.sbo_repo_path
|
|
||||||
self.session: str = Session
|
self.session: str = Session
|
||||||
|
|
||||||
def insert_sbo_table(self):
|
def insert_sbo_table(self):
|
||||||
|
@ -30,7 +28,8 @@ class CreateData:
|
||||||
'SLACKBUILD SHORT DESCRIPTION:'
|
'SLACKBUILD SHORT DESCRIPTION:'
|
||||||
]
|
]
|
||||||
|
|
||||||
sbo_file = self.read_file(f'{self.sbo_repo_path}/SLACKBUILDS.TXT')
|
sbo_file = self.read_file(
|
||||||
|
f'{self.configs.sbo_repo_path}/SLACKBUILDS.TXT')
|
||||||
|
|
||||||
cache = [] # init cache
|
cache = [] # init cache
|
||||||
|
|
||||||
|
|
|
@ -12,12 +12,10 @@ from slpkg.models.models import session as Session
|
||||||
class Download:
|
class Download:
|
||||||
''' Download the slackbuilds with the sources only. '''
|
''' Download the slackbuilds with the sources only. '''
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self, flags):
|
||||||
self.flags: list
|
self.flags: list = flags
|
||||||
|
self.configs: str = Configs
|
||||||
self.session: str = Session
|
self.session: str = Session
|
||||||
self.download_only = Configs.download_only
|
|
||||||
self.sbo_repo_url: str = Configs.sbo_repo_url
|
|
||||||
self.sbo_tar_suffix: str = Configs.sbo_tar_suffix
|
|
||||||
|
|
||||||
def packages(self, slackbuilds: list):
|
def packages(self, slackbuilds: list):
|
||||||
|
|
||||||
|
@ -27,12 +25,12 @@ class Download:
|
||||||
wget = Wget()
|
wget = Wget()
|
||||||
|
|
||||||
for sbo in slackbuilds:
|
for sbo in slackbuilds:
|
||||||
file = f'{sbo}{self.sbo_tar_suffix}'
|
file = f'{sbo}{self.configs.sbo_tar_suffix}'
|
||||||
location = SBoQueries(sbo).location()
|
location = SBoQueries(sbo).location()
|
||||||
url = f'{self.sbo_repo_url}/{location}/{file}'
|
url = f'{self.configs.sbo_repo_url}/{location}/{file}'
|
||||||
|
|
||||||
wget.download(self.download_only, url)
|
wget.download(self.configs.download_only, url)
|
||||||
|
|
||||||
sources = SBoQueries(sbo).sources()
|
sources = SBoQueries(sbo).sources()
|
||||||
for source in sources.split():
|
for source in sources.split():
|
||||||
wget.download(self.download_only, source)
|
wget.download(self.configs.download_only, source)
|
||||||
|
|
|
@ -15,9 +15,8 @@ class ViewPackage:
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.session: str = Session
|
self.session: str = Session
|
||||||
self.colors: dict = Configs.colour
|
self.configs: str = Configs
|
||||||
self.sbo_repo_url: str = Configs.sbo_repo_url
|
self.colors: dict = self.configs.colour
|
||||||
self.sbo_tar_suffix: str = Configs.sbo_tar_suffix
|
|
||||||
|
|
||||||
def package(self, packages):
|
def package(self, packages):
|
||||||
http = urllib3.PoolManager()
|
http = urllib3.PoolManager()
|
||||||
|
@ -44,10 +43,10 @@ class ViewPackage:
|
||||||
).filter(SBoTable.name == package).first()
|
).filter(SBoTable.name == package).first()
|
||||||
|
|
||||||
readme = http.request(
|
readme = http.request(
|
||||||
'GET', f'{self.sbo_repo_url}/{info[9]}/{info[0]}/README')
|
'GET', f'{self.configs.sbo_repo_url}/{info[9]}/{info[0]}/README')
|
||||||
|
|
||||||
info_file = http.request(
|
info_file = http.request(
|
||||||
'GET', f'{self.sbo_repo_url}/{info[9]}/{info[0]}/{info[0]}.info')
|
'GET', f'{self.configs.sbo_repo_url}/{info[9]}/{info[0]}/{info[0]}.info')
|
||||||
|
|
||||||
maintainer, email, homepage = '', '', ''
|
maintainer, email, homepage = '', '', ''
|
||||||
for line in info_file.data.decode().splitlines():
|
for line in info_file.data.decode().splitlines():
|
||||||
|
@ -64,16 +63,16 @@ class ViewPackage:
|
||||||
f'Version: {GREEN}{info[1]}{ENDC}\n'
|
f'Version: {GREEN}{info[1]}{ENDC}\n'
|
||||||
f'Requires: {GREEN}{deps}{ENDC}\n'
|
f'Requires: {GREEN}{deps}{ENDC}\n'
|
||||||
f'Homepage: {BLUE}{homepage}{ENDC}\n'
|
f'Homepage: {BLUE}{homepage}{ENDC}\n'
|
||||||
f'Download SlackBuild: {BLUE}{self.sbo_repo_url}/{info[9]}/{info[0]}{self.sbo_tar_suffix}{ENDC}\n'
|
f'Download SlackBuild: {BLUE}{self.configs.sbo_repo_url}/{info[9]}/{info[0]}{self.configs.sbo_tar_suffix}{ENDC}\n'
|
||||||
f'Download sources: {BLUE}{info[3]}{ENDC}\n'
|
f'Download sources: {BLUE}{info[3]}{ENDC}\n'
|
||||||
f'Download_x86_64 sources: {BLUE}{info[4]}{ENDC}\n'
|
f'Download_x86_64 sources: {BLUE}{info[4]}{ENDC}\n'
|
||||||
f'Md5sum: {YELLOW}{info[5]}{ENDC}\n'
|
f'Md5sum: {YELLOW}{info[5]}{ENDC}\n'
|
||||||
f'Md5sum_x86_64: {YELLOW}{info[6]}{ENDC}\n'
|
f'Md5sum_x86_64: {YELLOW}{info[6]}{ENDC}\n'
|
||||||
f'Files: {GREEN}{info[7]}{ENDC}\n'
|
f'Files: {GREEN}{info[7]}{ENDC}\n'
|
||||||
f'Description: {GREEN}{info[8]}{ENDC}\n'
|
f'Description: {GREEN}{info[8]}{ENDC}\n'
|
||||||
f'Slackware: {CYAN}{self.sbo_repo_url.split("/")[-1]}{ENDC}\n'
|
f'Slackware: {CYAN}{self.configs.sbo_repo_url.split("/")[-1]}{ENDC}\n'
|
||||||
f'Category: {RED}{info[9]}{ENDC}\n'
|
f'Category: {RED}{info[9]}{ENDC}\n'
|
||||||
f'SBo url: {BLUE}{self.sbo_repo_url}/{info[9]}/{info[0]}{ENDC}\n'
|
f'SBo url: {BLUE}{self.configs.sbo_repo_url}/{info[9]}/{info[0]}{ENDC}\n'
|
||||||
f'Maintainer: {YELLOW}{maintainer}{ENDC}\n'
|
f'Maintainer: {YELLOW}{maintainer}{ENDC}\n'
|
||||||
f'Email: {YELLOW}{email}{ENDC}\n'
|
f'Email: {YELLOW}{email}{ENDC}\n'
|
||||||
f'\nREADME: {CYAN}{readme.data.decode()}{ENDC}')
|
f'\nREADME: {CYAN}{readme.data.decode()}{ENDC}')
|
||||||
|
|
|
@ -16,10 +16,8 @@ class ViewMessage:
|
||||||
|
|
||||||
def __init__(self, flags):
|
def __init__(self, flags):
|
||||||
self.flags: list = flags
|
self.flags: list = flags
|
||||||
self.colors: dict = Configs.colour
|
self.configs: str = Configs
|
||||||
self.log_packages: str = Configs.log_packages
|
self.colors: dict = self.configs.colour
|
||||||
self.sbo_repo_tag: str = Configs.sbo_repo_tag
|
|
||||||
self.arch: str = Configs.os_arch
|
|
||||||
self.session: str = Session
|
self.session: str = Session
|
||||||
self.utils: str = Utilities()
|
self.utils: str = Utilities()
|
||||||
self.black: list = Blacklist()
|
self.black: list = Blacklist()
|
||||||
|
@ -119,7 +117,7 @@ class ViewMessage:
|
||||||
install, set_color = 'upgrade', color['YELLOW']
|
install, set_color = 'upgrade', color['YELLOW']
|
||||||
|
|
||||||
if installed and 'noarch' in installed:
|
if installed and 'noarch' in installed:
|
||||||
self.arch = 'noarch'
|
self.configs.os_arch = 'noarch'
|
||||||
|
|
||||||
if installed:
|
if installed:
|
||||||
|
|
||||||
|
@ -128,7 +126,7 @@ class ViewMessage:
|
||||||
|
|
||||||
print(f'[{set_color} {install} {color["ENDC"]}] -> '
|
print(f'[{set_color} {install} {color["ENDC"]}] -> '
|
||||||
f'{sbo}-{version} {set_color}'
|
f'{sbo}-{version} {set_color}'
|
||||||
f'({installed.split(self.arch)[0][:-1].split("-")[-1]})'
|
f'({installed.split(self.configs.os_arch)[0][:-1].split("-")[-1]})'
|
||||||
f'{color["ENDC"]}')
|
f'{color["ENDC"]}')
|
||||||
else:
|
else:
|
||||||
print(f'[{color["CYAN"]} install {color["ENDC"]}] -> '
|
print(f'[{color["CYAN"]} install {color["ENDC"]}] -> '
|
||||||
|
@ -136,13 +134,13 @@ class ViewMessage:
|
||||||
|
|
||||||
def _view_installed_packages(self, name: str):
|
def _view_installed_packages(self, name: str):
|
||||||
''' View and creates list with packages for remove. '''
|
''' View and creates list with packages for remove. '''
|
||||||
installed = os.listdir(self.log_packages)
|
installed = os.listdir(self.configs.log_packages)
|
||||||
color = self.colors()
|
color = self.colors()
|
||||||
|
|
||||||
for package in installed:
|
for package in installed:
|
||||||
black = package.split('-')[0]
|
black = package.split('-')[0]
|
||||||
if (package.startswith(f'{name}-') and
|
if (package.startswith(f'{name}-') and
|
||||||
self.sbo_repo_tag in package and
|
self.configs.sbo_repo_tag in package and
|
||||||
black not in self.black.get()):
|
black not in self.black.get()):
|
||||||
self.installed_packages.append(package)
|
self.installed_packages.append(package)
|
||||||
print(f'[{color["RED"]} delete {color["ENDC"]}] -> {package}')
|
print(f'[{color["RED"]} delete {color["ENDC"]}] -> {package}')
|
||||||
|
|
Loading…
Add table
Reference in a new issue