blob: 99577efb6600387602c713360d148c80cd314733 (
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
|
# Maintainer: Mark Wagie <mark dot wagie at proton dot me>
# Contributor: John Andrews <theunderdog09 at gmail dot com>
# Contributor: Timo Kramer <fw minus aur at timokramer dot de>
pkgname=mullvad-vpn-cli
pkgver=2025.5
pkgrel=1
pkgdesc="The Mullvad VPN CLI client"
arch=('x86_64')
url="https://www.mullvad.net"
license=('GPL-3.0-or-later')
depends=(
'dbus'
'iputils'
'libnftnl'
)
makedepends=(
'cargo'
'git'
'go'
'protobuf'
)
provides=("${pkgname%-*}")
conflicts=("${pkgname%-*}")
install="${pkgname%-*}.install"
source=("git+https://github.com/mullvad/mullvadvpn-app.git#tag=$pkgver?signed"
"git+https://github.com/mullvad/mullvadvpn-app-binaries.git"
"git+https://github.com/mullvad/wireguard-go.git")
sha256sums=('3e34ea184098cac5b5ebbd116c254a69b0f943dd1f62640cfcd48e0c81869cd7'
'SKIP'
'SKIP')
validpgpkeys=('225E40C8F1C8DEB7977ABF59F293063FECE2E8ED' # Linus Färnstrand <linus@mullvad.net>
'8339C7D2942EB854E3F27CE5AEE9DECFD582E984' # David Lönnhager (code signing) <david.l@mullvad.net>
'1D0026CBD1F1858DF8DB54DFCB87E2B919A6454C' # Oskar Nyberg <oskar@mullvad.net>
'049F58CC80D9C78452151EE6EF0CCD68D0E5B9B1' # Emīls Piņķis <emils@mullvad.net>
)
prepare() {
cd mullvadvpn-app
git submodule init
git config submodule.dist-assets/binaries.url "$srcdir/mullvadvpn-app-binaries"
git config submodule.wireguard-go-rs/libwg/wireguard-go.url "$srcdir/wireguard-go"
git -c protocol.file.allow=always submodule update
# Create wireguard-go build directory
mkdir -p "build/lib/$CARCH-unknown-linux-gnu"
# Create shell-completions output directory
mkdir -p build/shell-completions
export RUSTUP_TOOLCHAIN=stable
cargo fetch --locked --target "$(rustc -vV | sed -n 's/host: //p')"
}
build() {
cd mullvadvpn-app
CFLAGS+=" -ffat-lto-objects"
export RUSTUP_TOOLCHAIN=stable
export CARGO_TARGET_DIR=target
local RUSTC_VERSION=$(rustc --version)
local PRODUCT_VERSION=$(cargo run -q --bin mullvad-version)
echo "Building Mullvad VPN ${PRODUCT_VERSION}..."
echo "Building wireguard-go..."
pushd wireguard-go-rs/libwg
export GOPATH="$srcdir/gopath"
export CGO_CPPFLAGS="${CPPFLAGS}"
export CGO_CFLAGS="${CFLAGS}"
export CGO_CXXFLAGS="${CXXFLAGS}"
export CGO_LDFLAGS="${LDFLAGS}"
export GOFLAGS="-buildmode=pie -trimpath -ldflags=-linkmode=external -mod=readonly -modcacherw"
go build -v -o "../../build/lib/$CARCH-unknown-linux-gnu"/libwg.a -buildmode c-archive
popd
# Clean module cache for makepkg -C
go clean -modcache
echo "Building Rust code in release mode using ${RUSTC_VERSION}..."
cargo_crates_to_build=(
-p mullvad-daemon --bin mullvad-daemon
-p mullvad-cli --bin mullvad
-p mullvad-setup --bin mullvad-setup
-p mullvad-problem-report --bin mullvad-problem-report
-p talpid-openvpn-plugin --lib
-p mullvad-exclude --bin mullvad-exclude
)
cargo build --frozen --release "${cargo_crates_to_build[@]}"
echo "Preparing for packaging Mullvad VPN ${PRODUCT_VERSION}..."
for sh in bash zsh fish; do
echo "Generating shell completion script for ${sh}..."
cargo run --bin mullvad --frozen --release -- shell-completions "${sh}" \
build/shell-completions/
done
echo "Updating relays.json..."
cargo run -p mullvad-api --bin relay_list --frozen --release > build/relays.json
}
package() {
cd mullvadvpn-app
# Install binaries
install -Dm755 target/release/mullvad{-problem-report,-setup} -t \
"$pkgdir/opt/Mullvad VPN/resources/"
install -Dm755 target/release/{mullvad,mullvad{-daemon,-exclude}} -t \
"$pkgdir/usr/bin/"
install -m755 target/release/libtalpid_openvpn_plugin.so -t \
"$pkgdir/opt/Mullvad VPN/resources/"
install -m755 "dist-assets/binaries/$CARCH-unknown-linux-gnu/openvpn" -t \
"$pkgdir/opt/Mullvad VPN/resources/"
# Link to the problem report binary
ln -s "/opt/Mullvad VPN/resources/mullvad-problem-report" "$pkgdir/usr/bin/"
# Install relay list
install -m644 build/relays.json -t "$pkgdir/opt/Mullvad VPN/resources/"
# Install OpenVPN certificate
install -m644 dist-assets/ca.crt -t "$pkgdir/opt/Mullvad VPN/resources/"
# Install list of maybenot machines to support DAITA
install -m644 dist-assets/maybenot_machines -t "$pkgdir/opt/Mullvad VPN/resources/"
# Install services
install -Dm644 dist-assets/linux/mullvad{-daemon,-early-boot-blocking}.service -t \
"$pkgdir/usr/lib/systemd/system/"
# Install completions
install -Dm644 build/shell-completions/mullvad.bash \
"$pkgdir/usr/share/bash-completion/completions/mullvad"
install -Dm644 build/shell-completions/_mullvad -t \
"$pkgdir/usr/share/zsh/site-functions/"
install -Dm644 build/shell-completions/mullvad.fish -t \
"$pkgdir/usr/share/fish/vendor_completions.d/"
}
|