blob: c679a5df7afb9f51547ad17904450591e2ce043d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
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"
}
|