blob: 6cd33e4fded5a260af1bb01c07eccb25dcbe86e4 (
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
# Maintainer: flan_suse <windows2linux_AT_zoho_DOT_com>
# The "stylized" name of the application is "WireGUIrd" (aka: "wireguard GUI")
# PACKAGER'S NOTE:
# This program runs with elevated permissions ("Polkit").
# The config file is located under /root/wireguird.settings
# It's preferable to use your WireGuard VPN provider's official application.
# If they do not provide one, you can use NetworkManager to create WireGuard tunnels.
# As a last resort, this application is a simple GUI that leverages "wg-quick".
# Any *.conf files found under /etc/wireguard will automatically be loaded in the list.
# You can also manually add or remove WireGuard *.conf files using the GUI interface.
# IMPORTANT NOTE ABOUT USAGE:
# If a config's filename is longer than 15 characters, you cannot activate the tunnel.
# This is due to a limitation of interface names on Linux.
pkgname=wireguird
pkgver=1.1.0
pkgrel=1
pkgdesc="GUI frontend to connect to and manage WireGuard tunnels (GTK3)"
arch=('x86_64')
url="https://github.com/UnnoTed/wireguird"
license=('MIT')
depends=('wireguard-tools' 'polkit' 'gtk3' 'libayatana-appindicator' 'openresolv')
makedepends=('go')
source=(${pkgname}-${pkgver}.tar.gz::${url}/archive/refs/tags/v${pkgver}.tar.gz)
sha256sums=(653ed74a7fbf3a53d3bad5eca7856570419e9a23cb297f68125313bf5790dc98)
prepare() {
# Change into directory
cd ${pkgname}-${pkgver}
# Prepare environment
export GOPATH=${srcdir}/go
export GOENV=${srcdir}/go/.config
export GOCACHE=${srcdir}/go/.cache
go clean -cache -modcache
# Correct the Debian executable path to work with Arch Linux and related distros
sed -i 's/^Exec.*$/Exec=wireguird/g' deb/usr/share/applications/${pkgname}.desktop
mv deb/usr/local/bin deb/usr
rmdir deb/usr/local
# Create a category for the desktop shortcut
echo "Categories=Network" >> deb/usr/share/applications/${pkgname}.desktop
# Include a comment for the desktop shortcut
echo "Comment=Manage, create, and connect to WireGuard tunnels" >> deb/usr/share/applications/${pkgname}.desktop
}
build() {
# Change into directory
cd ${pkgname}-${pkgver}
# Prepare the environment, so as to not download modules outside the working source directory
mkdir -p ${srcdir}/go ${srcdir}/go/.config ${srcdir}/go/.cache
export GOPATH=${srcdir}/go
export GOENV=${srcdir}/go/.config
export GOCACHE=${srcdir}/go/.cache
# Compile binary with gcc-go compiler
go generate
go build -modcacherw -ldflags "-s -w" -trimpath -o bin/${pkgname}
go clean -cache -modcache
}
package() {
# Change into directory
cd ${pkgname}-${pkgver}
# Prepare application directory
mkdir -p ${pkgdir}/opt/${pkgname}
# Copy compiled binary to application directory
cp bin/${pkgname} ${pkgdir}/opt/${pkgname}
# Copy icons to application directory and subdirectories
cp -a Icon ${pkgdir}/opt/${pkgname}
# Copy launcher, desktop shortcut, and polkit policy
cp -a deb/usr ${pkgdir}
# Copy changelog to application directory
cp deb/DEBIAN/changelog ${pkgdir}/opt/${pkgname}
}
|