Compare commits

...

2 Commits

Author SHA1 Message Date
85cda3e705 wip 2024-01-17 15:36:11 +03:00
dc54853fc7 refactor 2024-01-17 13:47:54 +03:00
11 changed files with 155 additions and 59 deletions

View File

@ -1,12 +1,11 @@
FROM registry.altlinux.org/alt/python:p10 FROM registry.altlinux.org/alt/python:p10
RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \
eepm \
wget \ wget \
apt-repo-tools \ apt-repo-tools \
alien \ alien \
pip pip && \
# && rm -rf /var/lib/apt/lists/* wget -O- https://eepm.ru/epm.sh | bash /dev/stdin ei
COPY requirements.txt . COPY requirements.txt .
RUN pip --no-cache-dir install -r requirements.txt RUN pip --no-cache-dir install -r requirements.txt

View File

@ -13,6 +13,8 @@ def _get_file(directory):
class BaseProvider: class BaseProvider:
disabled = False
def __init__(self, config): def __init__(self, config):
self.config = config self.config = config
@ -23,11 +25,7 @@ class BaseProvider:
return self._name return self._name
def get_version(self): def get_version(self):
url = utils.run([ url = utils.eget([
'epm',
'--silent',
'tool',
'eget',
'--get-real-url', '--get-real-url',
self.get_download_url(), self.get_download_url(),
]) ])
@ -42,24 +40,27 @@ class BaseProvider:
def get_download_url(self): def get_download_url(self):
return self.DOWNLOAD_URL return self.DOWNLOAD_URL
def get_download_name(self):
return ""
def download(self): def download(self):
download_directory = tempfile.mkdtemp() download_directory = tempfile.mkdtemp()
repacked_directory = tempfile.mkdtemp() repacked_directory = tempfile.mkdtemp()
utils.run([ args = []
'epm',
'--silent', download_name = self.get_download_name()
'tool',
'eget', if download_name:
'-q', args += ["-O", download_name]
self.get_download_url(),
], cwd=download_directory) args += [self.get_download_url()]
utils.eget(args, cwd=download_directory)
file = _get_file(download_directory) file = _get_file(download_directory)
utils.run([ utils.epm([
'epm',
'--silent',
'-y', '-y',
'repack', 'repack',
file, file,
@ -69,9 +70,7 @@ class BaseProvider:
file = _get_file(repacked_directory) file = _get_file(repacked_directory)
utils.run([ utils.epm([
'epm',
'--silent',
'repo', 'repo',
'pkgadd', 'pkgadd',
self.config.get('repo_path'), self.config.get('repo_path'),

View File

@ -0,0 +1,35 @@
import re
from autorepacked import utils
from autorepacked.common_providers.base_provider import BaseProvider
class GithubReleasesProvider(BaseProvider):
_repo = ''
def _last_release_url(self):
return utils.eget([
'--get-real-url',
f'https://github.com/{self._repo}/releases/latest'
])
def _last_tag_name(self):
return self.get_version()
def _get_release_filename(self):
return ''
def get_version(self):
url = self._last_release_url()
pattern = r'\d+\.\d+\.\d+'
match = re.search(pattern, url)
if match:
return match.group()
else:
return "not found"
def get_download_url(self):
return (f"https://github.com/"
f"{self._repo}/releases/download/"
f"{self._last_tag_name()}/{self._get_release_filename()}")

View File

@ -0,0 +1,35 @@
import json
import urllib
from autorepacked.common_providers.base_provider import BaseProvider
from urllib.request import Request, urlopen
class SnapProvider(BaseProvider):
_package_name = "package"
_channel = "stable"
_arch = "amd64"
def _get_snap_info(self):
request = Request(
f"http://api.snapcraft.io/v2/snaps/info/{self._package_name}",
headers={"Content-Type": "application/json", "Snap-Device-Series": "16"},
)
response = urlopen(request).read()
return json.loads(response)
def get_download_name(self):
return f"{self._package_name}-{self.get_version()}.snap"
def get_version(self):
snap_info = self._get_snap_info()
for channel_map in snap_info["channel-map"]:
if (channel_map["channel"]["name"] == self._channel
and channel_map["channel"]["architecture"] == self._arch):
return channel_map['version']
def get_download_url(self):
snap_info = self._get_snap_info()
for channel_map in snap_info["channel-map"]:
if (channel_map["channel"]["name"] == self._channel
and channel_map["channel"]["architecture"] == self._arch):
return channel_map['download']['url']

View File

@ -9,19 +9,24 @@ import uvicorn
from fastapi_utils.tasks import repeat_every from fastapi_utils.tasks import repeat_every
from autorepacked import utils from autorepacked import utils
from autorepacked.base_provider import BaseProvider from autorepacked.common_providers.base_provider import BaseProvider
from autorepacked.config import Config from autorepacked.config import Config
def create_repo(config: Config): def create_repo(config: Config):
utils.run([ utils.epm([
'epm',
'repo', 'repo',
'create', 'create',
config.get('repo_path') config.get('repo_path')
]) ])
def update_epm():
utils.epm([
'ei'
])
@asynccontextmanager @asynccontextmanager
async def lifespan(app: FastAPI): async def lifespan(app: FastAPI):
await update_repeat() await update_repeat()
@ -51,6 +56,8 @@ def update():
update_task_started = False update_task_started = False
return return
update_epm()
providers_path = os.path.join(os.getcwd(), 'autorepacked/providers') providers_path = os.path.join(os.getcwd(), 'autorepacked/providers')
modules = os.listdir(providers_path) modules = os.listdir(providers_path)
@ -60,6 +67,7 @@ def update():
module = importlib.import_module(f'providers.{module_name}') module = importlib.import_module(f'providers.{module_name}')
if hasattr(module, 'get_provider'): if hasattr(module, 'get_provider'):
provider = module.get_provider(config) # type: BaseProvider provider = module.get_provider(config) # type: BaseProvider
if not provider.disabled:
name = provider.get_name() name = provider.get_name()
print(f"request version of {name}") print(f"request version of {name}")
version = provider.get_version() version = provider.get_version()
@ -74,9 +82,8 @@ def update():
current_date = datetime.datetime.utcnow() current_date = datetime.datetime.utcnow()
if need_update_index: if need_update_index:
utils.run( utils.epm(
args=[ args=[
'epm',
'repo', 'repo',
'index', 'index',
config.get('repo_path'), config.get('repo_path'),

View File

@ -1,4 +1,4 @@
from autorepacked.base_provider import BaseProvider from autorepacked.common_providers.base_provider import BaseProvider
class CodeProvider(BaseProvider): class CodeProvider(BaseProvider):

View File

@ -1,4 +1,4 @@
from autorepacked.base_provider import BaseProvider from autorepacked.common_providers.base_provider import BaseProvider
class DiscordProvider(BaseProvider): class DiscordProvider(BaseProvider):

View File

@ -1,30 +1,13 @@
import subprocess from autorepacked.common_providers.github_releases_provider import GithubReleasesProvider
from autorepacked.base_provider import BaseProvider
class RustdeskProvider(BaseProvider): class RustdeskProvider(GithubReleasesProvider):
_name = 'rustdesk' _name = 'rustdesk'
_release_url = 'https://github.com/rustdesk/rustdesk/releases'
_release_file = '[0-9]/rustdesk-[0-9].[0-9].[0-9].deb'
def get_download_url(self): _repo = 'rustdesk/rustdesk'
url = subprocess.run(
args=[
'epm',
'--silent',
'tool',
'eget',
'--list',
'--latest',
'--get-real-url',
self._release_url,
self._release_file,
],
stdout=subprocess.PIPE
).stdout.decode('utf-8')
return url def _get_release_filename(self):
return f'rustdesk-{self.get_version()}-x86_64.deb'
def get_provider(config): def get_provider(config):

View File

@ -0,0 +1,12 @@
from autorepacked.common_providers.snap_provider import SnapProvider
class SingularityApp(SnapProvider):
disabled = True
_name = 'singularityapp'
_package_name = 'singularityapp'
def get_provider(config):
return SingularityApp(config)

View File

@ -0,0 +1,17 @@
from autorepacked.common_providers.github_releases_provider import GithubReleasesProvider
class TrezorSuiteProvider(GithubReleasesProvider):
_name = 'Trezor-Suite'
_repo = 'trezor/trezor-suite'
def _last_tag_name(self):
return f'v{self.get_version()}'
def _get_release_filename(self):
return f'Trezor-Suite-{self.get_version()}-linux-x86_64.AppImage'
def get_provider(config):
return TrezorSuiteProvider(config)

View File

@ -7,3 +7,12 @@ def run(args, cwd=None):
cwd=cwd, cwd=cwd,
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
).stdout.decode('utf-8') ).stdout.decode('utf-8')
def epm(args, cwd=None):
return run(["epm"] + args, cwd=cwd)
def eget(args, cwd=None):
return epm(["tool", "eget"] + args, cwd=cwd)