summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--oauth2-proxy/PKGBUILD66
1 files changed, 66 insertions, 0 deletions
diff --git a/oauth2-proxy/PKGBUILD b/oauth2-proxy/PKGBUILD
new file mode 100644
index 000000000..c679a5df7
--- /dev/null
+++ b/oauth2-proxy/PKGBUILD
@@ -0,0 +1,66 @@
+# Maintainer: Erich Eckner <arch at eckner dot net>
+# Contributor: Martin Rys <https://rys.rs/contact> | Toss a coin on https://rys.rs/donate
+# Previous maintainers: Luiz Ribeiro <luizribeiro@gmail.com>, Tom Wambold <tom5760@gmail.com>
+
+pkgname=oauth2-proxy
+pkgver=7.7.1
+pkgrel=1
+pkgdesc="A reverse proxy that provides authentication with Google, Keycloak, GitHub or other providers."
+arch=('x86_64' 'aarch64')
+url="https://github.com/oauth2-proxy/oauth2-proxy"
+license=('MIT')
+_pinned_dependencies=(
+ 'glibc>=2.40+r16+gaa533d58ff'
+)
+depends=("${_pinned_dependencies[@]}")
+makedepends=(go)
+backup=('etc/oauth2-proxy.cfg')
+source=("${pkgname}-${pkgver}.tar.gz::https://github.com/oauth2-proxy/oauth2-proxy/archive/v${pkgver}.tar.gz")
+sha256sums=('05a849bb79a6cd160779982f5564c0551e20a08e4c4ff947882817cc638a516f')
+
+prepare() {
+ sed -i -e 's|/usr/local/bin/oauth2-proxy|/usr/bin/oauth2-proxy|' -e 's/www-data/oauth2-proxy/' -e '/^#/d' "${pkgname}-${pkgver}/contrib/${pkgname}.service.example"
+}
+
+build() {
+ mkdir -p github.com/${pkgname}
+
+ mv "${pkgname}-${pkgver}" github.com/oauth2-proxy/oauth2-proxy
+ mkdir -p deps dist
+
+ # Force fail on missing IBT / SHSTK
+ # LDFLAGS+=' -Wl,-z,cet-report=error'
+ ## github.com/oauth2-proxy/oauth2-proxy/v7
+ #/usr/lib/go/pkg/tool/linux_amd64/link: running gcc failed: exit status 1
+ #/usr/bin/ld: /tmp/go-link-1117948769/go.o: error: missing IBT and SHSTK properties
+ #/usr/bin/ld: /tmp/go-link-1117948769/000019.o: error: missing IBT and SHSTK properties
+ #collect2: error: ld returned 1 exit status
+
+ # https://wiki.archlinux.org/title/Go_package_guidelines#Flags_and_build_options
+ export CGO_CPPFLAGS="${CPPFLAGS}"
+ export CGO_CFLAGS="${CFLAGS}"
+ export CGO_CXXFLAGS="${CXXFLAGS}"
+ export CGO_LDFLAGS="${LDFLAGS}"
+ export GOFLAGS="-buildmode=pie -ldflags=-linkmode=external -mod=readonly -modcacherw -trimpath"
+ export GOPATH="$(pwd)/deps:$(realpath $(pwd)/..)"
+ cd github.com/oauth2-proxy/oauth2-proxy
+
+ # Default version variable to $pkgver instead of "undefined" as the buildtime version detection in the Makefile fails
+ sed -i "s,VERSION = \"undefined\",VERSION = \"${pkgver}\"," pkg/version/version.go
+
+ go build -o ../../../dist/oauth2-proxy
+}
+
+package() {
+ mkdir -p "${pkgdir}/usr/bin"
+ mkdir -p "${pkgdir}/etc"
+ mkdir -p "${pkgdir}/usr/lib/systemd/system"
+
+ install -Dm 644 github.com/oauth2-proxy/oauth2-proxy/LICENSE -t "${pkgdir}/usr/share/licenses/${pkgname}"
+ install dist/oauth2-proxy "${pkgdir}/usr/bin/oauth2-proxy"
+ install github.com/oauth2-proxy/oauth2-proxy/contrib/oauth2-proxy.cfg.example "${pkgdir}/etc/oauth2-proxy.cfg"
+ install -m 644 github.com/oauth2-proxy/oauth2-proxy/contrib/oauth2-proxy.service.example "${pkgdir}/usr/lib/systemd/system/oauth2-proxy.service"
+
+ echo 'u oauth2-proxy - - / /usr/bin/nologin' |
+ install -Dm644 /dev/stdin "${pkgdir}/usr/lib/sysusers.d/${pkgname}.conf"
+}