Замена vercmp и оптимизация сборки зависимостей с полной русификацией интерфейса
- Заменен vercmp с go.elara.ws/vercmp на gitea.plemya-x.ru/xpamych/vercmp v0.0.1 - Добавлена функция FilterPackagesByVersion для проверки версий установленных пакетов перед пересборкой зависимостей (учитывает version-release и epoch) - Исправлена инициализация переводов в плагинах: добавлены вызовы translations.Setup() во всех plugin subcommands (_internal-safe-script-executor, _internal-installer, _internal-repos) - Добавлен GetSubcommandHelpTemplate для корректного отображения справки команд с подкомандами на русском языке - Добавлены кастомные help команды для config, repo, helper и mirror - Добавлены русские переводы для всех пользовательских сообщений: * Сообщения о создании пакетов (Creating package file, Packaging with nfpm и др.) * Сообщения команды fix (Clearing cache, Fixing permissions и др.) * Сообщения обновления (Updating system packages, System packages updated) * Сообщения о версиях пакетов (Package is installed with older/newer version) * Заголовки справки (NAME, USAGE, COMMANDS, OPTIONS) * Справочные сообщения (Shows a list of commands or help for one command) - Оптимизирован assets/logo.png (уменьшен с 37KB до 17KB)
This commit is contained in:
@@ -583,6 +583,12 @@ func (b *Builder) BuildALRDeps(
|
||||
input.BuildOpts().Interactive,
|
||||
true,
|
||||
)
|
||||
|
||||
pkgs, err = b.installerExecutor.FilterPackagesByVersion(ctx, pkgs, input.OSRelease())
|
||||
if err != nil {
|
||||
return nil, nil, fmt.Errorf("failed to filter packages by version: %w", err)
|
||||
}
|
||||
|
||||
type item struct {
|
||||
pkg *alrsh.Package
|
||||
packages []string
|
||||
|
||||
@@ -18,8 +18,16 @@ package build
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"log/slog"
|
||||
|
||||
"github.com/leonelquinteros/gotext"
|
||||
"gitea.plemya-x.ru/xpamych/vercmp"
|
||||
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/internal/manager"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/internal/overrides"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/alrsh"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/distro"
|
||||
)
|
||||
|
||||
func NewInstaller(mgr manager.Manager) *Installer {
|
||||
@@ -58,3 +66,44 @@ func (i *Installer) RemoveAlreadyInstalled(ctx context.Context, pkgs []string) (
|
||||
|
||||
return filteredPackages, nil
|
||||
}
|
||||
|
||||
func (i *Installer) FilterPackagesByVersion(ctx context.Context, packages []alrsh.Package, osRelease *distro.OSRelease) ([]alrsh.Package, error) {
|
||||
installedPkgs, err := i.mgr.ListInstalled(nil)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("failed to list installed packages: %w", err)
|
||||
}
|
||||
|
||||
var filteredPackages []alrsh.Package
|
||||
|
||||
for _, pkg := range packages {
|
||||
alrPkgName := fmt.Sprintf("%s+%s", pkg.Name, pkg.Repository)
|
||||
installedVer, isInstalled := installedPkgs[alrPkgName]
|
||||
|
||||
if !isInstalled {
|
||||
filteredPackages = append(filteredPackages, pkg)
|
||||
continue
|
||||
}
|
||||
|
||||
repoVer := pkg.Version
|
||||
releaseStr := overrides.ReleasePlatformSpecific(pkg.Release, osRelease)
|
||||
|
||||
if pkg.Release != 0 && pkg.Epoch == 0 {
|
||||
repoVer = fmt.Sprintf("%s-%s", pkg.Version, releaseStr)
|
||||
} else if pkg.Release != 0 && pkg.Epoch != 0 {
|
||||
repoVer = fmt.Sprintf("%d:%s-%s", pkg.Epoch, pkg.Version, releaseStr)
|
||||
}
|
||||
|
||||
cmp := vercmp.Compare(repoVer, installedVer)
|
||||
|
||||
if cmp > 0 {
|
||||
slog.Info(gotext.Get("Package %s is installed with older version %s, will rebuild with version %s", alrPkgName, installedVer, repoVer))
|
||||
filteredPackages = append(filteredPackages, pkg)
|
||||
} else if cmp == 0 {
|
||||
slog.Info(gotext.Get("Package %s is already installed with version %s, skipping build", alrPkgName, installedVer))
|
||||
} else {
|
||||
slog.Info(gotext.Get("Package %s is installed with newer version %s (repo has %s), skipping build", alrPkgName, installedVer, repoVer))
|
||||
}
|
||||
}
|
||||
|
||||
return filteredPackages, nil
|
||||
}
|
||||
|
||||
@@ -21,6 +21,7 @@ import (
|
||||
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/internal/manager"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/alrsh"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/distro"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/types"
|
||||
)
|
||||
|
||||
@@ -34,6 +35,7 @@ type InstallerExecutor interface {
|
||||
Install(ctx context.Context, pkgs []string, opts *manager.Opts) error
|
||||
Remove(ctx context.Context, pkgs []string, opts *manager.Opts) error
|
||||
RemoveAlreadyInstalled(ctx context.Context, pkgs []string) ([]string, error)
|
||||
FilterPackagesByVersion(ctx context.Context, packages []alrsh.Package, osRelease *distro.OSRelease) ([]alrsh.Package, error)
|
||||
}
|
||||
|
||||
type ScriptExecutor interface {
|
||||
|
||||
@@ -24,6 +24,7 @@ import (
|
||||
"context"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/internal/manager"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/alrsh"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/distro"
|
||||
"gitea.plemya-x.ru/Plemya-x/ALR/pkg/types"
|
||||
"github.com/hashicorp/go-plugin"
|
||||
)
|
||||
@@ -205,6 +206,38 @@ func (s *InstallerExecutorRPCServer) RemoveAlreadyInstalled(args *InstallerExecu
|
||||
return nil
|
||||
}
|
||||
|
||||
type InstallerExecutorFilterPackagesByVersionArgs struct {
|
||||
Packages []alrsh.Package
|
||||
OsRelease *distro.OSRelease
|
||||
}
|
||||
|
||||
type InstallerExecutorFilterPackagesByVersionResp struct {
|
||||
Result0 []alrsh.Package
|
||||
}
|
||||
|
||||
func (s *InstallerExecutorRPC) FilterPackagesByVersion(ctx context.Context, packages []alrsh.Package, osRelease *distro.OSRelease) ([]alrsh.Package, error) {
|
||||
var resp *InstallerExecutorFilterPackagesByVersionResp
|
||||
err := s.client.Call("Plugin.FilterPackagesByVersion", &InstallerExecutorFilterPackagesByVersionArgs{
|
||||
Packages: packages,
|
||||
OsRelease: osRelease,
|
||||
}, &resp)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return resp.Result0, nil
|
||||
}
|
||||
|
||||
func (s *InstallerExecutorRPCServer) FilterPackagesByVersion(args *InstallerExecutorFilterPackagesByVersionArgs, resp *InstallerExecutorFilterPackagesByVersionResp) error {
|
||||
result0, err := s.Impl.FilterPackagesByVersion(context.Background(), args.Packages, args.OsRelease)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
*resp = InstallerExecutorFilterPackagesByVersionResp{
|
||||
Result0: result0,
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
type ScriptExecutorReadScriptArgs struct {
|
||||
ScriptPath string
|
||||
}
|
||||
|
||||
@@ -167,30 +167,30 @@ func (e *LocalScriptExecutor) ExecuteSecondPass(
|
||||
pkgName := packager.ConventionalFileName(pkgInfo) // Получаем имя файла пакета
|
||||
pkgPath := filepath.Join(dirs.BaseDir, pkgName) // Определяем путь к пакету
|
||||
|
||||
slog.Info("Creating package file", "path", pkgPath, "name", pkgName)
|
||||
slog.Info(gotext.Get("Creating package file"), "path", pkgPath, "name", pkgName)
|
||||
|
||||
pkgFile, err := os.Create(pkgPath)
|
||||
if err != nil {
|
||||
slog.Error("Failed to create package file", "path", pkgPath, "error", err)
|
||||
slog.Error(gotext.Get("Failed to create package file"), "path", pkgPath, "error", err)
|
||||
return nil, err
|
||||
}
|
||||
defer pkgFile.Close()
|
||||
|
||||
slog.Info("Packaging with nfpm", "format", pkgFormat)
|
||||
slog.Info(gotext.Get("Packaging with nfpm"), "format", pkgFormat)
|
||||
err = packager.Package(pkgInfo, pkgFile)
|
||||
if err != nil {
|
||||
slog.Error("Failed to create package", "path", pkgPath, "error", err)
|
||||
slog.Error(gotext.Get("Failed to create package"), "path", pkgPath, "error", err)
|
||||
return nil, err
|
||||
}
|
||||
|
||||
slog.Info("Package created successfully", "path", pkgPath)
|
||||
slog.Info(gotext.Get("Package created successfully"), "path", pkgPath)
|
||||
|
||||
// Проверяем, что файл действительно существует
|
||||
if _, err := os.Stat(pkgPath); err != nil {
|
||||
slog.Error("Package file not found after creation", "path", pkgPath, "error", err)
|
||||
slog.Error(gotext.Get("Package file not found after creation"), "path", pkgPath, "error", err)
|
||||
return nil, err
|
||||
}
|
||||
slog.Info("Package file verified to exist", "path", pkgPath)
|
||||
slog.Info(gotext.Get("Package file verified to exist"), "path", pkgPath)
|
||||
|
||||
builtDeps = append(builtDeps, &BuiltDep{
|
||||
Name: vars.Name,
|
||||
|
||||
@@ -42,7 +42,7 @@ type AppDeps struct {
|
||||
func (d *AppDeps) Defer() {
|
||||
if d.DB != nil {
|
||||
if err := d.DB.Close(); err != nil {
|
||||
slog.Warn("failed to close db", "err", err)
|
||||
slog.Warn(gotext.Get("failed to close db"), "err", err)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -100,3 +100,28 @@ func GetCommandHelpTemplate() string {
|
||||
gotext.Get("OPTIONS"),
|
||||
)
|
||||
}
|
||||
|
||||
func GetSubcommandHelpTemplate() string {
|
||||
return fmt.Sprintf(`%s:
|
||||
{{template "helpNameTemplate" .}}
|
||||
|
||||
%s:
|
||||
{{.HelpName}} %s [%s] {{if .ArgsUsage}}{{.ArgsUsage}}{{else}}[%s...]{{end}}
|
||||
{{if .Description}}
|
||||
|
||||
%s:
|
||||
{{template "descriptionTemplate" .}}{{end}}
|
||||
{{- if len .Authors}}
|
||||
|
||||
%s{{template "authorsTemplate" .}}{{end}}{{if .VisibleCommands}}
|
||||
|
||||
%s:{{template "visibleCommandCategoryTemplate" .}}{{end}}{{if .VisibleFlagCategories}}
|
||||
|
||||
%s:{{template "visibleFlagCategoryTemplate" .}}{{else if .VisibleFlags}}
|
||||
|
||||
%s:{{template "visibleFlagTemplate" .}}{{end}}{{if .Copyright}}
|
||||
|
||||
%s:
|
||||
{{template "copyrightTemplate" .}}{{end}}
|
||||
`, gotext.Get("NAME"), gotext.Get("USAGE"), gotext.Get("command"), gotext.Get("command options"), gotext.Get("arguments"), gotext.Get("DESCRIPTION"), gotext.Get("AUTHOR"), gotext.Get("COMMANDS"), gotext.Get("OPTIONS"), gotext.Get("OPTIONS"), gotext.Get("COPYRIGHT"))
|
||||
}
|
||||
|
||||
@@ -36,7 +36,7 @@ import (
|
||||
"github.com/go-git/go-git/v5/plumbing"
|
||||
"github.com/leonelquinteros/gotext"
|
||||
"github.com/pelletier/go-toml/v2"
|
||||
"go.elara.ws/vercmp"
|
||||
"gitea.plemya-x.ru/xpamych/vercmp"
|
||||
"mvdan.cc/sh/v3/expand"
|
||||
"mvdan.cc/sh/v3/interp"
|
||||
"mvdan.cc/sh/v3/syntax"
|
||||
@@ -420,13 +420,13 @@ func (rs *Repos) processRepoChanges(ctx context.Context, repo types.Repo, r *git
|
||||
case actionDelete:
|
||||
scriptFl, err := oldCommit.File(action.File)
|
||||
if err != nil {
|
||||
slog.Warn("Failed to get deleted file from old commit", "file", action.File, "error", err)
|
||||
slog.Warn(gotext.Get("Failed to get deleted file from old commit"), "file", action.File, "error", err)
|
||||
continue
|
||||
}
|
||||
|
||||
r, err := scriptFl.Reader()
|
||||
if err != nil {
|
||||
slog.Warn("Failed to read deleted file", "file", action.File, "error", err)
|
||||
slog.Warn(gotext.Get("Failed to read deleted file"), "file", action.File, "error", err)
|
||||
continue
|
||||
}
|
||||
|
||||
@@ -445,13 +445,13 @@ func (rs *Repos) processRepoChanges(ctx context.Context, repo types.Repo, r *git
|
||||
case actionUpdate:
|
||||
scriptFl, err := newCommit.File(action.File)
|
||||
if err != nil {
|
||||
slog.Warn("Failed to get updated file from new commit", "file", action.File, "error", err)
|
||||
slog.Warn(gotext.Get("Failed to get updated file from new commit"), "file", action.File, "error", err)
|
||||
continue
|
||||
}
|
||||
|
||||
r, err := scriptFl.Reader()
|
||||
if err != nil {
|
||||
slog.Warn("Failed to read updated file", "file", action.File, "error", err)
|
||||
slog.Warn(gotext.Get("Failed to read updated file"), "file", action.File, "error", err)
|
||||
continue
|
||||
}
|
||||
|
||||
@@ -505,7 +505,7 @@ func (rs *Repos) processRepoFull(ctx context.Context, repo types.Repo, repoDir s
|
||||
}
|
||||
|
||||
if len(matches) == 0 {
|
||||
slog.Warn("No alr.sh files found in repository", "repo", repo.Name)
|
||||
slog.Warn(gotext.Get("No alr.sh files found in repository"), "repo", repo.Name)
|
||||
return nil
|
||||
}
|
||||
|
||||
|
||||
@@ -341,7 +341,7 @@ msgstr "Выберите, какой пакет использовать для
|
||||
|
||||
#: internal/cliutils/prompt.go:156
|
||||
msgid "Choose which optional package(s) to install"
|
||||
msgstr "Выберите, какой дополнительный пакет(ы) следует установить"
|
||||
msgstr "Выберите дополнительные пакеты для установки"
|
||||
|
||||
#: internal/cliutils/template.go:74 internal/cliutils/template.go:93
|
||||
msgid "NAME"
|
||||
@@ -501,10 +501,14 @@ msgstr "Аргументы, которые будут переданы мене
|
||||
msgid "Enable interactive questions and prompts"
|
||||
msgstr "Включение интерактивных вопросов и запросов"
|
||||
|
||||
#: main.go:148
|
||||
#: main.go:147
|
||||
msgid "Show help"
|
||||
msgstr "Показать справку"
|
||||
|
||||
#: main.go:148
|
||||
msgid "Shows a list of commands or help for one command"
|
||||
msgstr "Показывает список команд или справку по одной команде"
|
||||
|
||||
#: main.go:152
|
||||
msgid "Error while running app"
|
||||
msgstr "Ошибка при запуске приложения"
|
||||
@@ -551,7 +555,7 @@ msgstr "<имя>"
|
||||
|
||||
#: repo.go:103 repo.go:465 repo.go:568
|
||||
msgid "Repo \"%s\" does not exist"
|
||||
msgstr "Репозитория \"%s\" не существует"
|
||||
msgstr "Репозиторий \"%s\" не существует"
|
||||
|
||||
#: repo.go:110
|
||||
msgid "Error removing repo directory"
|
||||
@@ -620,7 +624,7 @@ msgstr "URL \"%s\" не существует в репозитории \"%s\""
|
||||
|
||||
#: repo.go:508 repo.go:580
|
||||
msgid "Removed %d mirrors from repo \"%s\"\n"
|
||||
msgstr "Удалены зеркала %d из репозитория \"%s\"\n"
|
||||
msgstr "Удалено %d зеркал из репозитория \"%s\"\n"
|
||||
|
||||
#: repo.go:520
|
||||
msgid "Remove all mirrors from the repository"
|
||||
@@ -636,7 +640,7 @@ msgstr "URL-адрес нового репозитория"
|
||||
|
||||
#: repo.go:632
|
||||
msgid "Name of the repo to be deleted"
|
||||
msgstr "Название репозитория удалён"
|
||||
msgstr "Название репозитория для удаления"
|
||||
|
||||
#: search.go:40
|
||||
msgid "Search packages"
|
||||
@@ -656,7 +660,7 @@ msgstr "Искать по репозиторию"
|
||||
|
||||
#: search.go:66
|
||||
msgid "Search by provides"
|
||||
msgstr "Иcкать по provides"
|
||||
msgstr "Искать по provides"
|
||||
|
||||
#: search.go:130
|
||||
msgid "Error while executing search"
|
||||
@@ -672,7 +676,107 @@ msgstr "Ошибка при проверке обновлений"
|
||||
|
||||
#: upgrade.go:126
|
||||
msgid "There is nothing to do."
|
||||
msgstr "Здесь нечего делать."
|
||||
msgstr "Действия не требуются."
|
||||
|
||||
#: internal/build/installer.go:88
|
||||
msgid "Package %s is installed with older version %s, will rebuild with version %s"
|
||||
msgstr "Пакет %s установлен с устаревшей версией %s, будет пересобран с версией %s"
|
||||
|
||||
#: internal/build/installer.go:96
|
||||
msgid "Package %s is already installed with version %s, skipping build"
|
||||
msgstr "Пакет %s уже установлен с версией %s, пропуск сборки"
|
||||
|
||||
#: internal/build/installer.go:102
|
||||
msgid "Package %s is installed with newer version %s (repo has %s), skipping build"
|
||||
msgstr "Пакет %s установлен с более новой версией %s (в репозитории %s), пропуск сборки"
|
||||
|
||||
#: internal/build/script_executor.go:170
|
||||
msgid "Creating package file"
|
||||
msgstr "Создание файла пакета"
|
||||
|
||||
#: internal/build/script_executor.go:174
|
||||
msgid "Failed to create package file"
|
||||
msgstr "Не удалось создать файл пакета"
|
||||
|
||||
#: internal/build/script_executor.go:179
|
||||
msgid "Packaging with nfpm"
|
||||
msgstr "Упаковка с помощью nfpm"
|
||||
|
||||
#: internal/build/script_executor.go:182
|
||||
msgid "Failed to create package"
|
||||
msgstr "Не удалось создать пакет"
|
||||
|
||||
#: internal/build/script_executor.go:186
|
||||
msgid "Package created successfully"
|
||||
msgstr "Пакет успешно создан"
|
||||
|
||||
#: internal/build/script_executor.go:190
|
||||
msgid "Package file not found after creation"
|
||||
msgstr "Файл пакета не найден после создания"
|
||||
|
||||
#: internal/build/script_executor.go:193
|
||||
msgid "Package file verified to exist"
|
||||
msgstr "Наличие файла пакета подтверждено"
|
||||
|
||||
#: internal/repos/pull.go:423
|
||||
msgid "Failed to get deleted file from old commit"
|
||||
msgstr "Не удалось получить удалённый файл из старого коммита"
|
||||
|
||||
#: internal/repos/pull.go:429
|
||||
msgid "Failed to read deleted file"
|
||||
msgstr "Не удалось прочитать удалённый файл"
|
||||
|
||||
#: internal/repos/pull.go:448
|
||||
msgid "Failed to get updated file from new commit"
|
||||
msgstr "Не удалось получить обновлённый файл из нового коммита"
|
||||
|
||||
#: internal/repos/pull.go:454
|
||||
msgid "Failed to read updated file"
|
||||
msgstr "Не удалось прочитать обновлённый файл"
|
||||
|
||||
#: internal/repos/pull.go:508
|
||||
msgid "No alr.sh files found in repository"
|
||||
msgstr "Файлы alr.sh не найдены в репозитории"
|
||||
|
||||
#: internal/cliutils/app_builder/builder.go:45
|
||||
msgid "failed to close db"
|
||||
msgstr "не удалось закрыть БД"
|
||||
|
||||
#: internal/build/build.go:342
|
||||
msgid "Using cached package"
|
||||
msgstr "Используется кешированный пакет"
|
||||
|
||||
#: upgrade.go:89
|
||||
msgid "Updating system packages..."
|
||||
msgstr "Обновление системных пакетов..."
|
||||
|
||||
#: upgrade.go:97
|
||||
msgid "System packages updated successfully"
|
||||
msgstr "Системные пакеты успешно обновлены"
|
||||
|
||||
#: build.go:203
|
||||
msgid "Package file already moved or removed, skipping"
|
||||
msgstr "Файл пакета уже перемещён или удалён, пропускаем"
|
||||
|
||||
#: fix.go:75
|
||||
msgid "Clearing cache and temporary directories"
|
||||
msgstr "Очистка кэша и временных директорий"
|
||||
|
||||
#: fix.go:119
|
||||
msgid "Clearing temporary directory"
|
||||
msgstr "Очистка временной директории"
|
||||
|
||||
#: fix.go:126
|
||||
msgid "Unable to remove temporary directory as current user, trying with sudo"
|
||||
msgstr "Невозможно удалить временную директорию от текущего пользователя, попытка через sudo"
|
||||
|
||||
#: fix.go:156
|
||||
msgid "Fixing permissions on temporary files"
|
||||
msgstr "Исправление прав доступа к временным файлам"
|
||||
|
||||
#: fix.go:177
|
||||
msgid "Creating cache directory"
|
||||
msgstr "Создание директории кэша"
|
||||
|
||||
#, fuzzy
|
||||
#~ msgid "Failed to clear contents of cache directory"
|
||||
|
||||
Reference in New Issue
Block a user