1
0
Fork 0
mirror of https://github.com/Luzifer/archrepo.git synced 2024-12-20 13:11:17 +00:00
No description
Find a file
Knut Ahlers 6f0c927c8d
Add space before icon for better readability
Signed-off-by: Knut Ahlers <knut@ahlers.me>
2024-06-08 18:01:46 +02:00
repo Move repo to subdir, remove repoctl dependency 2021-10-20 21:25:37 +02:00
scripts Add space before icon for better readability 2024-06-08 18:01:46 +02:00
.gitignore Move repo to subdir, remove repoctl dependency 2021-10-20 21:25:37 +02:00
LICENSE Add documentation 2020-07-24 00:37:38 +02:00
Makefile Update build tooling 2024-06-08 00:38:28 +02:00
README.md Update build tooling 2024-06-08 00:38:28 +02:00
repo-urls Update build tooling 2024-06-08 00:38:28 +02:00

Luzifer / archrepo

This repository contains the setup and tools to maintain my "private" Archlinux repository with AUR packages and packages I rely on which does not have a place in AUR. This setup is intended for my own use and uses a clean build environment for each package.

Warning: As I'm not a Trusted User and this is not an official Archlinux repository you probably don't want to use this repository directly - at last you don't know whether those packages were tempered with. If you do please keep it civilized: if you plan to use the repository in build causing high amounts of traffic or many machines please don't or at least create a mirror.

Setup

This repository contains four essential parts:

  • The scripts folder containing bash scripts to control all actions
  • The Makefile to orchestrate everything. The main functionality is the maintenance target (or just make)
  • The package lists in repo-urls
  • The repo/luzifer.asc public key

It currently relies on my luzifer/arch-repo-builder docker image which does all of the building within a clean environment for each package.

For the initial setup you need to do some steps:

  • Adjust the Makefile as you need different download and upload targets
  • Create an empty database tar -cJf repo/luzifer.db.tar.xz -T /dev/null (adjust the filename)
  • Put the public key for your repo into repo/luzifer.asc (filename should match the database, makes it easier to find)
  • Set up your repo-urls package list: it contains one git repository URL per line (comments allowed)
  • Provide a docker daemon and all tools listed in the check_tools target of the Makefile

Afterwards you should be good to just make your first build. Depending on the number of packages you selected to be in your repo you might go and fetch dinner while it builds.

Maintenance

The repo should be updated on a regular base by just executing make on it. This will check for updates of the AUR packages specified in the aur-packages list and update them if their version is newer than the local one. Also it will check for new commits in the repos listed in repo-urls and build them if there are newer commits than those in the local cache.

Flaws / Remarks / TODOs

  • The whole build already strongly relies on Archlinux tools so will not run on any other distro
  • For packages having dynamic pkgver calculation the update check will not work properly until the PKGBUILD in the repo is updated. You can force a rebuild by removing the corresponding line from the .repo_cache