Compare commits

...

25 Commits

Author SHA1 Message Date
fbt
0af6624ba1 up
Signed-off-by: fbt <fbt@fleshless.org>
2023-10-26 00:49:32 +00:00
fbt
df93a9bd80 fix latest changes
Signed-off-by: fbt <fbt@fleshless.org>
2023-10-25 11:59:33 +00:00
fbt
b42e62d9d6 Fleshless mirrorlist
Signed-off-by: fbt <fbt@fleshless.org>
2022-12-16 13:09:53 +00:00
fbt
99bba5c866 do this with a trap
Signed-off-by: fbt <fbt@fleshless.org>
2021-10-28 16:48:47 +03:00
fbt
c9740dac87 install deps
Signed-off-by: fbt <fbt@fleshless.org>
2021-10-06 12:26:25 +03:00
fbt
0a31377fcd work with no keep-id
Signed-off-by: fbt <fbt@fleshless.org>
2021-10-06 10:57:26 +03:00
fbt
8adeef05bc cleanup with a trap
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 11:29:30 +03:00
fbt
0181a1099f that was debug
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 09:35:54 +03:00
fbt
179080a377 Arch
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 09:28:11 +03:00
fbt
86539bce14 this is actually redundant
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 09:23:19 +03:00
fbt
a90a326af1 trailing trash
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 09:19:33 +03:00
fbt
e449b6a3e4 try creating the dest dir
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 09:02:39 +03:00
fbt
f0b451030f Let's say it's a comment
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 08:59:39 +03:00
fbt
b7379871e9 maybe?
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 08:59:12 +03:00
fbt
81664a9400 pkgbuilder
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 08:56:26 +03:00
fbt
162ef2ffe1 pkgbuilder
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 08:56:10 +03:00
fbt
1fa31d3e0f pkgbuilder
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 08:55:16 +03:00
fbt
407501dc8a make ci respect PODMAN_IMAGE too
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 08:41:03 +03:00
fbt
dcac04661b move the repo scripts out
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 08:03:54 +03:00
fbt
4a548d05e1 oops
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 07:44:19 +03:00
fbt
22f33ba2c6 !
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 07:43:09 +03:00
fbt
e8f71b2eb1 why utf-8?
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 07:41:29 +03:00
fbt
d1b08a83be trash
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 07:41:02 +03:00
fbt
0fc6927784 locales
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 07:40:01 +03:00
fbt
b5843c81ec no need for sudoers
Signed-off-by: fbt <fbt@fleshless.org>
2021-03-06 07:39:11 +03:00
14 changed files with 124 additions and 177 deletions

View File

@@ -2,11 +2,64 @@ Spark autobuilder
=================
To use the build scripts, grab the latest Spark rootfs in one of the following ways:
* `curl -sL https://spark.fleshless.org/rootfs/latest.tar.xz | podman import - localhost/spark`
* `git clone https://code.fleshless.org/Spark/spark-rootfs.git; cd spark-rootfs; podman build --rm -t localhost/spark .`
```
curl -sL https://spark.fleshless.org/rootfs/latest.tar.xz | podman import - localhost/spark
# or
git clone https://code.fleshless.org/Spark/spark-rootfs.git; cd spark-rootfs; podman build --rm -t localhost/spark .
```
Then build a builder image from `./autobuilder`: `cd ./autobuilder; podman build --rm -t localhost/spark:autobuilder .`
Then build a builder image from `./autobuilder`:
```
cd ./autobuilder; podman build --rm -t localhost/spark:autobuilder .
```
Examples:
* `git clone https://code.fleshless.org/PKGBUILDs/ssm-git /tmp/ssm-git; cd /tmp/ssm-git; makepkg-podman -sL`
* `podman-ci /tmp/artifacts; makepkg-ci https://code.fleshless.org/PKGBUILDs/ssm-git`
Example for Arch images:
```
cd autobuilder
podman build --build-arg BASEIMAGE=docker.io/archlinux:base-devel --rm -t localhost/arch:autobuilder .
PODMAN_IMAGE=localhost/arch:autobuilder makepkg-ci /tmp/pkg https://code.fleshless.org/PKGBUILDs/ssm-git
```
makepkg-podman
--------------
Builds Arch packages using `podman`. Takes the image name in the `PODMAN_IMAGE` env var.
Usage:
```
[PODMAN_IMAGE=<image>] makepkg-podman [makepkg_args]
```
Example:
```
git clone https://code.fleshless.org/PKGBUILDs/ssm-git /tmp/ssm-git
cd /tmp/ssm-git
makepkg-podman -sL
```
makepkg-ci
----------
Builds Arch packages from a git repo using `makepkg-podman` and puts the packages into `dest`.
Usage:
```
[PODMAN_IMAGE=<image>] makepkg-ci <dest> <url>
```
Example:
```
makepkg-ci /tmp/artifacts https://code.fleshless.org/PKGBUILDs/ssm-git
```
pkgbuilder
----------
Tracks given git repos for changes and builds packages on updates.
`pkgbuilder.conf` goes into `$XDG_CONFIG_HOME/pkgbuilder/config`
Usage:
```
pkgbuilder
```

View File

@@ -1,10 +1,11 @@
FROM localhost/spark
RUN pacman -Suy --noconfirm base-devel
COPY locale.gen /etc/locale.gen
RUN locale-gen
ARG BASEIMAGE=localhost/spark
FROM $BASEIMAGE
COPY ./mirrorlist /etc/pacman.d/mirrorlist
COPY gnupg /.gnupg
COPY ./build /build
RUN pacman -Sy --noconfirm archlinux-keyring
RUN pacman -Suy --noconfirm base-devel nodejs git
RUN chmod 700 /.gnupg

View File

@@ -1,20 +1,35 @@
#!/usr/bin/env bash
# The builder user is already created in the rootfs
shopt -s nullglob
export PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin
export LC_ALL=en_US.UTF-8
cleanup() {
chown -R root:root /buildroot
}
# Upgrade
pacman -Suy --noconfirm
# gnupg dir permissions
chown -R "$BUILDUSER:$BUILDUSER" /.gnupg
# Create a builder user
useradd -U builder
builder_uid=$(id -u builder)
builder_gid=$(id -g builder)
# dir permissions
chown -R "$builder_uid:$builder_gid" /.gnupg /buildroot
# Return the permissions on exit
trap cleanup INT TERM EXIT
# Add sudo permissions for pacman to install dependencies
printf '%s ALL=(ALL) NOPASSWD: /usr/bin/pacman\n' "$BUILDUSER" > /etc/sudoers.d/builduser
printf '%s ALL=(ALL) NOPASSWD: /usr/bin/pacman\n' 'builder' > /etc/sudoers.d/builduser
# Workdir
cd /buildroot
# Install all additional packages
deps=( ./deps/* )
[[ $deps ]] && pacman -U "${deps[@]}"
# Build the damn thing
sudo -u "$BUILDUSER" GNUPGHOME="/.gnupg" makepkg "$@"
sudo -u builder GNUPGHOME="/.gnupg" makepkg "$@"
chown -R root:root /buildroot/

3
autobuilder/build-container Executable file
View File

@@ -0,0 +1,3 @@
#!/usr/bin/env bash
podman build . -t 'spark:autobuilder'

View File

@@ -1 +0,0 @@
builder ALL=(ALL) NOPASSWD: /usr/bin/pacman

0
autobuilder/gnupg/.empty Normal file
View File

View File

@@ -1 +0,0 @@
en_US.UTF-8 UTF-8

7
autobuilder/mirrorlist Normal file
View File

@@ -0,0 +1,7 @@
# Fleshless
Server = https://mirror.fleshless.org/arch/$repo/os/$arch
# Backup
Server = https://mirror.pkgbuild.com/$repo/os/$arch
Server = https://mirror.pseudoform.org/$repo/os/$arch
Server = https://ftp.halifax.rwth-aachen.de/archlinux/$repo/os/$arch

View File

@@ -1,18 +1,23 @@
#!/usr/bin/env bash
shopt -s nullglob
cleanup() { rm -rf "$tmpdir"; }
trap 'cleanup' EXIT
did="pkg-build-$$.$SRANDOM"
mkdir "/tmp/$did"
tmpdir="/tmp/$did"
mkdir "$tmpdir"
pkg_dest=$1
pkg_url=$2
#podman run --userns=keep-id -u root --rm -v "/tmp/$did:/buildroot" "spark:autobuilder" /build
git clone "$pkg_url" "/tmp/$did"
cd "/tmp/$did"
PODMAN_IMAGE='localhost/spark:autobuilder' makepkg-podman --noconfirm -sL
mkdir -p "$pkg_dest" || exit 1
artifacts=( "/tmp/$did/"*.pkg.* )
git clone "$pkg_url" "$tmpdir"
cd "$tmpdir"
makepkg-podman --noconfirm -sL
artifacts=( "$tmpdir/"*.pkg.* )
for i in "${artifacts[@]}"; do
i_name="${i##*/}"
@@ -25,6 +30,3 @@ for i in "${artifacts[@]}"; do
cp -vn "$i" "$pkg_dest"
fi
done
# cleanup
rm -rf "/tmp/$did"

View File

@@ -4,7 +4,6 @@ image=${PODMAN_IMAGE:-localhost/spark:autobuilder}
podman_cmd=(
podman run --rm -it -u root
--userns=keep-id
-v "$PWD:/buildroot"
--workdir /buildroot
--name "autobuilder.$$"

16
pkgbuilder.config Normal file
View File

@@ -0,0 +1,16 @@
# Example config for pkgbuilder
spark_repos="$HOME/public"
pkg_dests=(
[spark]="$spark_repos/spark/import"
[spark-extra]="$spark_repos/spark-extra/import"
[spark-testing]="$spark_repos/spark-testing/import"
[spark-updates]="$spark_repos/spark-updates/spark/import"
)
repos=(
spark "https://code.fleshless.org/pkgbuilds/sinit-spark"
spark-extra "https://code.fleshless.org/pkgbuilds/anope-services"
spark-testing "https://code.fleshless.org/pkgbuilds/ssm-git"
)

View File

@@ -1,83 +0,0 @@
#!/usr/bin/bash
shopt -s nullglob
parse_pkg_filename() {
declare filename=$1
declare -a filename_array
IFS='-' read -r -a filename_array <<< "$filename"
for (( i=${#filename_array[@]}; i>=0; i-- )); do
printf '%s ' "${filename_array[$i]}"
done
}
is_latest() {
declare filename=$1 p
for p in "${latest[@]}"; do
if [[ "$filename" == "$p" ]]; then
return 0
fi
done
return 1
}
_pacsort() {
declare i
for i in *.pkg.tar.xz *.pkg.tar.zst; do
printf '%s\n' "$i"
done | pacsort -f
}
while (( $# )); do
case "$1" in
-r) flag_rm=1;;
-d) flag_debug=1;;
esac
shift
done
if ! (( flag_rm )); then
if ! [[ -d old ]]; then
mkdir -p old || {
return 1
}
fi
fi
read -d '' -r -a package_files < <( _pacsort )
for f in "${package_files[@]}"; do
unset revision version end package_name
read -r end revision version _ < <(parse_pkg_filename "$f")
package_name=${f%%-$version-$revision*}
declare -g -A latest["$package_name"]="$package_name-$version-$revision-$end"
done
for f in ${package_files[@]}; do
if is_latest "$f"; then
(( flag_debug )) && printf '%s is the latest version available\n' "$f"
else
printf 'Removing: %s\n' "$f"
if (( flag_rm )); then
rm -f "$f" "${f}.sig"
else
mv "$f" old/
if [[ -f "${f}.sig" ]]; then
mv "${f}.sig" old/
fi
fi
fi
done
if [[ -d old ]]; then
cd old
exec bash "$0" -r
fi

View File

@@ -1,49 +0,0 @@
#!/usr/bin/env bash
shopt -s nullglob
lockfile='.mainenance.lock'
usage() { echo "$0 <repo_name>"; }
spark_repo=$1
[[ "$spark_repo" ]] || {
usage
exit 1
}
cleanup() { rm -f "$lockfile"; }
lock() {
[[ -f "$lockfile" ]] && {
printf 'Lockfile found: %s\n' "$lockfile" >&2
return 1
}
echo $$ > "$lockfile"
lock_pid=$(<"$lockfile")
[[ $$ == "$lock_pid" ]] || return 1
}
cd "$HOME/public/$spark_repo" || exit $?
lock || exit 1
trap cleanup EXIT
for f in import/*; do
f_name="${f##*/}"
if [[ -f "$f_name" ]]; then
printf 'Package already exists: %s, not overwriting\n' "$f_name" >&2
rm -vf "$f"
else
mv -vf "$f" ./
new_pkgs+=( "$f_name" )
fi
done
repo-sign
repo-clean
for p in "${new_pkgs[@]}"; do
repo-add -n "$spark_repo.db.tar.gz" "$p"
done

View File

@@ -1,15 +0,0 @@
#!/usr/bin/bash
shopt -s nullglob
for i in *.pkg.*; do
if ! [[ "$i" == "${i%.*}.sig" ]]; then
if ! [[ -f "${i}.sig" ]]; then
unsigned_pkgs+=( "$i" )
fi
fi
done
for i in "${unsigned_pkgs[@]}"; do
echo $i
gpg --pinentry-mode loopback --passphrase-fd 0 --batch --no-tty --detach-sign --no-armor "$i" < ~/.gnupg/passphrase
done