Arch User Repository (Русский)
Пользовательский репозиторий Arch (Arch User Repository, AUR) — поддерживаемое сообществом хранилище программ для пользователей Arch. Содержит описания пакетов (файлы PKGBUILD), которые позволяют скомпилировать пакет из исходников утилитой makepkg и затем установить его с помощью pacman. AUR был создан с целью организации совместного доступа к новым пакетам, которые были созданы сообществом, а также чтобы ускорить добавление популярных пакетов в репозиторий extra. В статье описано, как получить доступ к AUR и как с ним работать.
Многие пакеты, в настоящее время находящиеся в официальных репозиториях, когда-то начинали свой путь в AUR. В AUR пользователи могут добавлять собственные сборки пакетов (PKGBUILD
и другие необходимые файлы). Сообщество может голосовать за понравившиеся пакеты. Если пакет стал популярным, распространяется под подходящей лицензией и собирается без излишних сложностей, то он может быть перенесён в репозиторий extra (доступный напрямую с помощью pacman или системы сборки Arch).
PKGBUILD
и не проходят тщательную проверку. Используйте их на свой страх и риск.Приступая к работе
Искать и скачивать файлы PKGBUILD можно через веб-интерфейс AUR. Эти файлы позволяют собрать устанавливаемый пакет утилитой makepkg и установить его в систему с помощью pacman.
- Установите мета-пакет base-devel.
- Просмотрите раздел #Часто задаваемые вопросы.
- Перед сборкой пакетов из AUR имеет смысл внести изменения в файл
/etc/makepkg.conf
, чтобы оптимизировать процесс сборки под вашу систему. На системах с многоядерным процессором можно добиться значительного ускорения сборки с помощью переменнойMAKEFLAGS
, использованием нескольких ядер при сжатии или выбором нестандартного алгоритма сжатия. Аппаратно-зависимые оптимизации компилятора можно включить переменнойCFLAGS
. Подробнее см. makepkg#Советы и рекомендации.
Если вы настроили аутентификацию в AUR через SSH, то можно использовать его для доступа к AUR: команда ssh aur@aur.archlinux.org help
выведет список доступных команд.
Установка и обновление пакетов
Установка пакетов из AUR относительно проста:
- Скачайте файлы сборки, включая PKGBUILD и, возможно, другие необходимые файлы вроде юнитов systemd и патчей (но, чаще всего, не сам исходный код).
- Убедитесь, что
PKGBUILD
и прочие файлы не являются вредоносными или ненадёжными. - Выполните
makepkg
в каталоге с сохранёнными файлами. Эта команда загрузит исходный код, скомпилирует его и создаст пакет. - Выполните
pacman -U файл_пакета
, чтобы установить пакет в систему.
Подготовка
Прежде всего убедитесь, что в системе установлены необходимые инструменты: установите мета-пакет base-devel. В него входят make и некоторые другие инструменты, необходимые для компиляции из исходников.
Затем выберите подходящий каталог сборки. Каталог сборки — это просто место, в котором пакет будет «собран» из исходников. Им может быть любой каталог в системе. В примерах ниже в качестве каталога сборки используется ~/builds
.
Получение файлов
Найдите пакет в AUR. Это можно сделать поиском на главной странице AUR (текстовое поле вверху). После перехода по одной из ссылок из списка результатов откроется страница информации о выбранном пакете. Прочтите описание, убедитесь, что это то, что вы искали; обратите внимание на дату последнего обновления пакета и прочтите комментарии.
Существует несколько способов получить необходимые файлы пакета:
- Склонировать git-репозиторий, указанный в графе «URL для git clone» в разделе «Информация о пакете». Это предпочтительный метод, поскольку он позволяет получать обновления файлов пакета с помощью
git pull
:
$ git clone https://aur.archlinux.org/имя_пакета.git
- Загрузить снимок (snapshot) с помощью ссылки «Загрузить снимок» под заголовком «Действия над пакетом» справа или командой:
$ curl -L -O https://aur.archlinux.org/cgit/aur.git/snapshot/имя_пакета.tar.gz
- Примечание: Снимок представляет собой сжатый архив, который необходимо распаковать (лучше всего — в каталог, отдельный от каталога для сборки пакетов из AUR):
tar -xvf имя_пакета.tar.gz
- Использовать зеркало archlinux/aur на GitHub, в котором каждый пакет находится в отдельной ветке. Рекомендуется клонировать только одну выбранную вами ветку (весь репозиторий слишком большой и клонироваться целиком будет очень медленно). Это можно сделать двумя способами:
- использовать
git clone --single-branch
:$ git clone --branch имя_пакета --single-branch https://github.com/archlinux/aur.git
- выполнить частичное клонирование репозитория (
git clone --depth=1
) и выборочно добавить ветки:
- использовать
$ git clone --depth=1 https://github.com/archlinux/aur.git; cd aur
$ git remote set-branches --add origin имя_пакета
$ git fetch
$ git checkout имя_пакета
Получение открытого ключа PGP (при необходимости)
Проверьте массив source в файле PKGBUILD на предмет наличия в нём файла подписи (суффикс .sig или .asc), и, если таковой присутствует, получите любой открытый ключ из массива validpgpkeys. Подробнее см. makepkg#Проверка цифровых подписей.
Сборка пакета
Перейдите в каталог, содержащий PKGBUILD пакета:
$ cd имя_пакета
PKGBUILD
, файлы .install
и любые другие файлы в git-репозитории пакета на наличие вредоносных и опасных команд. Если возникли сомнения, отмените сборку и обратитесь за советом на форум или в почтовую рассылку. Ранее в пакетах уже находили вредоносный код. [1]Просмотрите содержимое всех предоставленных файлов. Например, для просмотра PKGBUILD
с помощью less выполните:
$ less PKGBUILD
- Для просмотра изменений с момента последнего коммита выполните
git show
. - Для просмотра изменений с момента последнего коммита с помощью vimdiff выполните
git difftool @~..@ --tool=vimdiff
. Преимущество vimdiff в том, что можно увидеть полное содержимое каждого файла с отметками в местах изменений.
Соберите пакет. После ручной проверки содержимого файлов запустите makepkg от имени обычного пользователя. Некоторые полезные флаги:
-s
/--syncdeps
— при помощи pacman перед сборкой проверить зависимости и установить недостающие. Если пакет завит от пакетов из AUR, их необходимо установить вручную до сборки.-i
/--install
— установить пакет после успешной сборки. Позволяет пропустить шаг по ручной установке.-r
/--rmdeps
— удалить зависимости, необходимые только для сборки, так как они больше не требуются. Учтите, что они могут потребоваться при переустановке или обновлении пакета.-c
/--clean
— удалить временные файлы после сборки, так как они больше не требуются. Эти файлы обычно необходимы только для отладки процесса сборки.
git clean -dfx
, чтобы удалить все файлы, которые git не отслеживает — это удалит все предыдущие файлы сборки.Установка пакета
После сборки можно установить пакет с помощью pacman:
# pacman -U имя_пакета-версия-архитектура.pkg.tar.zst
- Если вы изменяли
PKGEXT
вmakepkg.conf
, то имя пакета может отличаться. - Пример выше даёт лишь краткое описание процесса сборки пакета. Настоятельно рекомендуется прочесть статьи makepkg и Система сборки Arch, в которых представлена более подробная информация.
Переход на новую версию пакета
Когда в AUR появляется новая версия пакета, для его установки в каталоге с PKGBUILD пакета сначала обновите файлы командой
$ git pull
после чего повторите процесс сборки и установки, описанный выше.
Обновление пакетов
AUR не имеет официальной поддержки, поэтому pacman не обновляет пакеты из AUR автоматически — это ваша задача. После установки обновлений из официальных репозиториев вам также нужно обновить (пересобрать и переустановить) все AUR-пакеты, зависящие от библиотек из обновившихся пакетов, — даже если в AUR не появлялось новых версий.
Статус учётной записи
Приостановленная
Учётные записи могут быть приостановлены (suspended) сопровождающими пакетов или разработчиками. У приостановленных учётных записей теряется возможность:
- входить на https://aur.archlinux.org;
- получать уведомления;
- взаимодействовать с интерфейсом git.
Неактивная
Вы можете отметить свою учётную запись как неактивную (inactive). Сопровождающие пакетов и разработчики также могут отмечать неактивными другие учётные записи. Это используется для двух вещей:
- для отображения даты, когда кто-то был отмечен неактивным, на странице его учётной записи;
- для подсчёта активных сопровождающих пакетов на основе их неактивности.
Обратная связь
Комментарии к пакету
Веб-интерфейс AUR имеет возможность комментирования, благодаря которой пользователи могут сообщить мэйнтейнеру PKGBUILD
о предложениях и улучшениях.
PKGBUILD
в свои комментарии, так как они очень быстро устаревают и в итоге просто занимают место. Вместо этого отправляйте такие файлы на email ответственного сопроводителя или используйте pastebin.Python-Markdown предоставляет базовый Markdown-синтаксис для форматирования комментариев.
- Эта реализация иногда имеет некоторые отличия от официальных правил синтаксиса.
- Хеши коммитов Git-репозиториев пакетов и ссылки на Flyspray карты преобразуются в ссылки автоматически.
- Длинные комментарии сворачиваются и могут быть показаны по требованию.
Голосование
Одним из самых простых действий для всех пользователей Arch Linux является обзор AUR и голосование за понравившиеся пакеты. Каждый пакет может быть принят кем-нибудь из сопровождающих пакетов в репозиторий extra. Количество голосов — один из важных критериев, поэтому в интересах пользователей активное голосование за пакеты.
Зарегистрируйтесь на сайте AUR, чтобы появилась возможность «Проголосовать за пакет» при просмотре пакета. После регистрации также можно проголосовать за пакет из командной строки при помощи aur-auto-vote-gitAUR.
Кроме того, если настроена аутентификация в AUR через SSH, можно проголосовать из командной строки с использованием ssh-ключа. Это означает, что не придётся сохранять или вводить пароль от AUR.
$ ssh aur@aur.archlinux.org vote имя_пакета
Устаревшие пакеты
Используйте Пометить пакет как устаревший для установки соответствующего флага. Укажите причину, по которой вы сочли пакет устаревшим, лучше всего — указав ссылку на объявление о релизе или его tarball.
Также можно попробовать связаться с сопроводителем по email. Если ответа не последует в течение двух недель, можно отправить запрос Сделать сиротой для данного пакета. Смотрите AUR submission guidelines (Русский)#Запросы для дополнительной информации.
pkgver
. Не пытайтесь их пометить, поскольку сопроводитель просто снимет отметку и проигнорирует запрос. Сопроводители пакетов AUR не должны коммитить «пустые» обновления значения pkgver
.Отладка процесса сборки пакета
- Убедитесь, что ваше сборочное окружение обновлено, прежде чем собирать что-либо.
- Убедитесь, что мета-пакет base-devel установлен.
- Используйте опцию
-s
с командойmakepkg
, чтобы проверить и установить все необходимые зависимости перед сборкой. - Попробуйте стандартную конфигурацию makepkg.
- Смотрите Makepkg (Русский)#Решение проблем по часто возникающим проблемам.
Если у вас проблемы со сборкой пакета, первым делом почитайте PKGBUILD и комментарии на странице AUR.
Вполне может оказаться, что PKGBUILD
сломан для всех. Если вы не можете разобраться сами, сообщите сопроводителю пакета (например, текст ошибки в комментарии на странице AUR). Также можно поискать помощь на форуме в разделе AUR Issues, Discussion & PKGBUILD Requests.
Причина может оказаться очень нетривиальной. Нестандартные CFLAGS
, LDFLAGS
и MAKEFLAGS
могут вызывать проблемы. Чтобы избежать проблем, которые могут быть вызваны специфичным окружением, собирайте пакеты в clean chroot. Если сборка не получается даже в clean chroot, тогда проблема скорее всего в самом PKGBUILD
.
Смотрите Создание пакетов#Проверка целостности пакета об использовании namcap
. Если вы хотите получить ревью PKGBUILD
, отправьте его в aur-general mailing list или на форум в раздел Creating & Modifying Packages. Также можно попросить помощь в IRC-канале #archlinux-aur на Libera Chat.
Отправка пакетов
При помощи AUR пользователи могут распространять свои файлы PKGBUILD. Инструкции и правила публикации описаны в статье AUR submission guidelines (Русский).
Перевод веб-интерфейса
Информацию о создании и поддержке перевода веб-интерфейса AUR смотрите в файле i18n.txt в дереве исходных текстов AUR.
История
В начале времён был лишь FTP-сервер ftp://ftp.archlinux.org/incoming
, на который люди загружали свои файлы PKGBUILD, другие необходимые файлы и сами собранные пакеты. Пакет и связанные с ним файлы хранились на сервере, ожидая проверки доверенными пользователями (Trusted Users, ныне это сопровождающие пакетов — Package Maintainers) и добавления в официальный репозиторий.
Позднее некоторым участникам сообщества было разрешено содержать собственные репозитории с общим доступом. Так появились репозитории доверенных пользователей (Trusted User Repositories). AUR был создан как развитие этой идеи, чтобы сделать систему более гибкой и удобной. Сопровождающие AUR часто упоминались как доверенные пользователи (Trusted Users, TU), пока роль не была переименована в сопровождающих пакетов (Package Maintainers).
Между 2015-06-08 и 2015-08-08 состоялся переход AUR с версии 3.5.1 на 4.0.0, что было связано с началом использования Git-репозиториев для публикации файлов PKGBUILD
. Существовавшие на тот момент пакеты были частично перенесены в новую инфраструктуру их сопроводителями.
Git-репозитории с пакетами AUR3
Архив AUR на GitHub содержит все пакеты AUR3 на момент миграции. Также существует репозиторий aur3-mirror с аналогичным содержанием.
Часто задаваемые вопросы
Какие типы пакетов разрешены в AUR?
Пакеты AUR — это просто «скрипты сборки» исполняемых файлов для последующей упаковки полученных бинарных файлов в пакет и установки при помощи pacman. Обычно разрешено всё, что удовлетворяет принципам полезности, инструкциям и лицензионным требованиям программного обеспечения. Но в некоторых случаях прямо указано, что запрещено создавать ссылки на скачивание, например, когда контент запрещён к распространению, вы можете использовать лишь само имя файла в качестве исходника. Это означает, что пользователь должен самостоятельно озаботиться в получении таких файлов. Если вы сомневаетесь в правовых аспектах, лучше сначала спросить.
Как я могу голосовать за пакеты в AUR?
Смотрите #Голосование.
Кто такие сопровождающие пакетов?
Этот термин может обозначать как официальную роль Arch Linux, дающую доступ к публикации пакетов в официальных репозиториях (Package Maintainer), так и просто людей, поддерживающих файлы PKGBUILD
в AUR. Смотрите Arch terminology#Package maintainer.
В чём разница между AUR и репозиторием extra?
Arch User Repository — это место, где хранятся все файлы PKGBUILD, присланные пользователями. Сами пакеты должны быть собраны вручную при помощи makepkg. Когда файлы PKGBUILD
набирают достаточный интерес со стороны сообщества и поддержку от сопровождающего пакетов, они перемещаются в репозиторий extra (поддерживаемый сопровождающими пакетов), содержащий собранные пакеты, которые уже можно напрямую установить при помощи pacman.
Пакет из AUR устарел, что я могу сделать?
Смотрите #Устаревшие пакеты.
В то же время вы можете попробовать обновить пакет самостоятельно, отредактировав PKGBUILD локально. Иногда обновления не требуют изменений в процессе сборки или создания пакета, в этом случае достаточно просто обновить pkgver
или массив source
.
Пакет foo из AUR не собирается, когда я запускаю makepkg; что мне делать?
Возможно, вы упускаете что-то тривиальное; смотрите #Отладка процесса сборки пакета.
ОШИБКА: Одна или больше PGP-подписей не могут быть проверены! Что мне делать?
Скорее всего, у вас нет необходимого открытого ключа (ключей) в вашей личной связке ключей для проверки скачанных файлов. Смотрите makepkg (Русский)#Проверка цифровых подписей.
Как создать PKGBUILD?
Смотрите статьи AUR submission guidelines (Русский)#Правила отправки пакетов и Создание пакетов.
У меня есть PKGBUILD, который я хочу опубликовать; кто-нибудь может проверить его на наличие ошибок?
Существует несколько каналов, по которым можно отправить свой пакет на проверку; смотрите #Отладка процесса сборки пакета.
Что необходимо для перемещения PKGBUILD в репозиторий extra?
Обычно необходимо как минимум 10 голосов для того, чтобы пакет мог быть перемещён в extra. Однако, если сопровождающий пакетов захочет поддерживать пакет, он скорее всего сделает это сразу.
Получение пакетом минимально необходимого количества голосов — не единственное требование: у кого-либо из сопровождающих пакетов должно появиться желание поддерживать этот пакет. Сопровождающие пакетов не обязаны перемещать пакет в репозиторий extra, даже если он имеет тысячи голосов.
В большинстве случаев очень популярные пакеты остаются в AUR по одной или нескольким из следующих причин:
- в репозиториях Arch Linux уже содержится другая версия пакета;
- прямое распространение запрещено лицензией;
- пакет предназначен для AUR (например, это инструмент для работы с AUR).
Смотрите также правила добавления пакетов в репозиторий extra.
Как ускорить повторную сборку?
Смотрите makepkg (Русский)#Сокращение времени сборки.
В чём разница между пакетами foo и foo-git?
Многие пакеты AUR выпускаются в виде «стабильных» версий и «нестабильных», находящихся в процессе разработки. Пакеты разработки обычно имеют суффикс, обозначающий их систему контроля версий, и не предназначены для обычного использования, но могут содержать новые возможности или исправления ошибок. Поскольку эти пакеты скачивают только последние доступные исходные тексты при выполнении makepkg
, их pkgver()
в AUR не отражает изменения из апстрима. По той же причине эти пакеты не могут выполнять проверку подлинности для любого источника VCS.
Почему пакет пропал из AUR?
Возможно, пакет был принят сопровождающим пакетов и теперь находится в репозитории extra.
Пакет мог быть удалён, если он не удовлетворял правилам отправки пакетов. Для уточнения причины удаления смотрите архив aur-requests.
Как узнать, пропал ли из AUR какой-либо из установленных мной пакетов?
Самый простой способ — проверить HTTP-статус страницы пакета AUR:
$ comm -23 <(pacman -Qqm | sort) <(curl https://aur.archlinux.org/packages.gz | gzip -cd | sort)
Как получить список всех пакетов AUR?
- https://aur.archlinux.org/packages.gz
- Используйте
aurpkglist
из python3-aurAUR