Compare commits
25 Commits
3eb3afaa3a
...
master
Author | SHA1 | Date | |
---|---|---|---|
0af6624ba1 | |||
df93a9bd80 | |||
b42e62d9d6 | |||
99bba5c866 | |||
c9740dac87 | |||
0a31377fcd | |||
8adeef05bc | |||
0181a1099f | |||
179080a377 | |||
86539bce14 | |||
a90a326af1 | |||
e449b6a3e4 | |||
f0b451030f | |||
b7379871e9 | |||
81664a9400 | |||
162ef2ffe1 | |||
1fa31d3e0f | |||
407501dc8a | |||
dcac04661b | |||
4a548d05e1 | |||
22f33ba2c6 | |||
e8f71b2eb1 | |||
d1b08a83be | |||
0fc6927784 | |||
b5843c81ec |
65
README.md
65
README.md
@@ -2,11 +2,64 @@ Spark autobuilder
|
|||||||
=================
|
=================
|
||||||
|
|
||||||
To use the build scripts, grab the latest Spark rootfs in one of the following ways:
|
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:
|
Example for Arch images:
|
||||||
* `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`
|
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
|
||||||
|
```
|
||||||
|
@@ -1,10 +1,11 @@
|
|||||||
FROM localhost/spark
|
ARG BASEIMAGE=localhost/spark
|
||||||
RUN pacman -Suy --noconfirm base-devel
|
FROM $BASEIMAGE
|
||||||
|
|
||||||
COPY locale.gen /etc/locale.gen
|
|
||||||
RUN locale-gen
|
|
||||||
|
|
||||||
|
COPY ./mirrorlist /etc/pacman.d/mirrorlist
|
||||||
COPY gnupg /.gnupg
|
COPY gnupg /.gnupg
|
||||||
COPY ./build /build
|
COPY ./build /build
|
||||||
|
|
||||||
|
RUN pacman -Sy --noconfirm archlinux-keyring
|
||||||
|
RUN pacman -Suy --noconfirm base-devel nodejs git
|
||||||
|
|
||||||
RUN chmod 700 /.gnupg
|
RUN chmod 700 /.gnupg
|
||||||
|
@@ -1,20 +1,35 @@
|
|||||||
#!/usr/bin/env bash
|
#!/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
|
cleanup() {
|
||||||
export LC_ALL=en_US.UTF-8
|
chown -R root:root /buildroot
|
||||||
|
}
|
||||||
|
|
||||||
# Upgrade
|
# Upgrade
|
||||||
pacman -Suy --noconfirm
|
pacman -Suy --noconfirm
|
||||||
|
|
||||||
# gnupg dir permissions
|
# Create a builder user
|
||||||
chown -R "$BUILDUSER:$BUILDUSER" /.gnupg
|
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
|
# 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
|
# Workdir
|
||||||
cd /buildroot
|
cd /buildroot
|
||||||
|
|
||||||
|
# Install all additional packages
|
||||||
|
deps=( ./deps/* )
|
||||||
|
[[ $deps ]] && pacman -U "${deps[@]}"
|
||||||
|
|
||||||
# Build the damn thing
|
# 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
3
autobuilder/build-container
Executable file
@@ -0,0 +1,3 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
podman build . -t 'spark:autobuilder'
|
@@ -1 +0,0 @@
|
|||||||
builder ALL=(ALL) NOPASSWD: /usr/bin/pacman
|
|
0
autobuilder/gnupg/.empty
Normal file
0
autobuilder/gnupg/.empty
Normal file
@@ -1 +0,0 @@
|
|||||||
en_US.UTF-8 UTF-8
|
|
7
autobuilder/mirrorlist
Normal file
7
autobuilder/mirrorlist
Normal 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
|
20
makepkg-ci
20
makepkg-ci
@@ -1,18 +1,23 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
shopt -s nullglob
|
shopt -s nullglob
|
||||||
|
|
||||||
|
cleanup() { rm -rf "$tmpdir"; }
|
||||||
|
trap 'cleanup' EXIT
|
||||||
|
|
||||||
did="pkg-build-$$.$SRANDOM"
|
did="pkg-build-$$.$SRANDOM"
|
||||||
mkdir "/tmp/$did"
|
tmpdir="/tmp/$did"
|
||||||
|
mkdir "$tmpdir"
|
||||||
|
|
||||||
pkg_dest=$1
|
pkg_dest=$1
|
||||||
pkg_url=$2
|
pkg_url=$2
|
||||||
|
|
||||||
#podman run --userns=keep-id -u root --rm -v "/tmp/$did:/buildroot" "spark:autobuilder" /build
|
mkdir -p "$pkg_dest" || exit 1
|
||||||
git clone "$pkg_url" "/tmp/$did"
|
|
||||||
cd "/tmp/$did"
|
|
||||||
PODMAN_IMAGE='localhost/spark:autobuilder' makepkg-podman --noconfirm -sL
|
|
||||||
|
|
||||||
artifacts=( "/tmp/$did/"*.pkg.* )
|
git clone "$pkg_url" "$tmpdir"
|
||||||
|
cd "$tmpdir"
|
||||||
|
makepkg-podman --noconfirm -sL
|
||||||
|
|
||||||
|
artifacts=( "$tmpdir/"*.pkg.* )
|
||||||
for i in "${artifacts[@]}"; do
|
for i in "${artifacts[@]}"; do
|
||||||
i_name="${i##*/}"
|
i_name="${i##*/}"
|
||||||
|
|
||||||
@@ -25,6 +30,3 @@ for i in "${artifacts[@]}"; do
|
|||||||
cp -vn "$i" "$pkg_dest"
|
cp -vn "$i" "$pkg_dest"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
# cleanup
|
|
||||||
rm -rf "/tmp/$did"
|
|
||||||
|
@@ -4,7 +4,6 @@ image=${PODMAN_IMAGE:-localhost/spark:autobuilder}
|
|||||||
|
|
||||||
podman_cmd=(
|
podman_cmd=(
|
||||||
podman run --rm -it -u root
|
podman run --rm -it -u root
|
||||||
--userns=keep-id
|
|
||||||
-v "$PWD:/buildroot"
|
-v "$PWD:/buildroot"
|
||||||
--workdir /buildroot
|
--workdir /buildroot
|
||||||
--name "autobuilder.$$"
|
--name "autobuilder.$$"
|
||||||
|
16
pkgbuilder.config
Normal file
16
pkgbuilder.config
Normal 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"
|
||||||
|
)
|
83
repo-clean
83
repo-clean
@@ -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
|
|
@@ -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
|
|
15
repo-sign
15
repo-sign
@@ -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
|
|
Reference in New Issue
Block a user