Compare commits
14 Commits
d695ad5ed3
...
2026.1-dev
| Author | SHA1 | Date | |
|---|---|---|---|
| 0a93fe0370 | |||
| b13eac38f9 | |||
|
|
c92f4fbf84 | ||
| 7650a60fa6 | |||
|
|
7aa41d7b67 | ||
|
|
6deccfa667 | ||
|
|
047680a1f3 | ||
|
|
31c74fd178 | ||
|
|
cf6a072724 | ||
|
|
89c6da8e8b | ||
|
|
f2928898bf | ||
|
|
2f47541f62 | ||
|
|
a57cea5bcb | ||
|
|
d4e1042d3c |
8
.gitmodules
vendored
Normal file
8
.gitmodules
vendored
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
[submodule "mullvad-vpn-daemon/mullvadvpn-app"]
|
||||||
|
path = mullvad-vpn-daemon/mullvadvpn-app
|
||||||
|
url = git@github.com:mullvad/mullvadvpn-app-priv.git
|
||||||
|
branch = poc-slint
|
||||||
|
[submodule "mullvad-vpn-slint/mullvadvpn-app"]
|
||||||
|
path = mullvad-vpn-slint/mullvadvpn-app
|
||||||
|
url = git@github.com:mullvad/mullvadvpn-app-priv.git
|
||||||
|
branch = poc-slint
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
1. Install `abuild`
|
1. Install `abuild`
|
||||||
2. Create keys: `abuild-keygen`
|
2. Create keys: `abuild-keygen`
|
||||||
The keys will end up in ~/.abuild/, and will be mounted into the build container by podma, and will be mounted into the build container.
|
The keys will end up in ~/.abuild/, and will be mounted into the build container.
|
||||||
3. Remember to keep keys around.
|
3. Remember to keep keys around.
|
||||||
|
|
||||||
## Building
|
## Building
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ cd "$(dirname "$0")"
|
|||||||
|
|
||||||
package="$1"
|
package="$1"
|
||||||
builder_image="mullvad-slint-musl-builder"
|
builder_image="mullvad-slint-musl-builder"
|
||||||
|
cargo_home="${CARGO_HOME:-$HOME/.cargo}"
|
||||||
. "$HOME/.abuild/abuild.conf"
|
. "$HOME/.abuild/abuild.conf"
|
||||||
|
|
||||||
docker build . -f Dockerfile -t "$builder_image"
|
docker build . -f Dockerfile -t "$builder_image"
|
||||||
@@ -14,8 +15,10 @@ docker run --rm \
|
|||||||
-v "$PACKAGER_PRIVKEY":/key.rsa:ro \
|
-v "$PACKAGER_PRIVKEY":/key.rsa:ro \
|
||||||
-v "$PACKAGER_PRIVKEY.pub":/key.rsa.pub:ro \
|
-v "$PACKAGER_PRIVKEY.pub":/key.rsa.pub:ro \
|
||||||
-v "$PACKAGER_PRIVKEY.pub":/etc/apk/keys/key.rsa.pub:ro \
|
-v "$PACKAGER_PRIVKEY.pub":/etc/apk/keys/key.rsa.pub:ro \
|
||||||
-v ./target:/cargo-target \
|
|
||||||
-v ./packages:/root/packages \
|
-v ./packages:/root/packages \
|
||||||
|
-v "$cargo_home":/cargo-home \
|
||||||
|
-e "CARGO_HOME=/cargo-home" \
|
||||||
|
-v ./target:/cargo-target \
|
||||||
-e "CARGO_TARGET_DIR=/cargo-target" \
|
-e "CARGO_TARGET_DIR=/cargo-target" \
|
||||||
-it \
|
-it \
|
||||||
"$builder_image" \
|
"$builder_image" \
|
||||||
|
|||||||
39
mullvad-vpn-daemon/mullvad-vpn-daemon.post-deinstall
Normal file
39
mullvad-vpn-daemon/mullvad-vpn-daemon.post-deinstall
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
function remove_logs_and_cache {
|
||||||
|
rm -r --interactive=never /var/log/mullvad-vpn/ || \
|
||||||
|
echo "Failed to remove mullvad-vpn logs"
|
||||||
|
rm -r --interactive=never /var/cache/mullvad-vpn/ || \
|
||||||
|
echo "Failed to remove mullvad-vpn cache"
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_config {
|
||||||
|
rm -r --interactive=never /etc/mullvad-vpn || \
|
||||||
|
echo "Failed to remove mullvad-vpn config"
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_symlinks {
|
||||||
|
rm /usr/bin/mullvad-problem-report || \
|
||||||
|
echo "Failed to remove mullvad-problem-report"
|
||||||
|
}
|
||||||
|
|
||||||
|
# checking what kind of an action is taking place
|
||||||
|
case $@ in
|
||||||
|
# apt purge passes "purge"
|
||||||
|
"purge")
|
||||||
|
remove_logs_and_cache
|
||||||
|
remove_config
|
||||||
|
remove_symlinks
|
||||||
|
;;
|
||||||
|
# apt remove passes "remove"
|
||||||
|
"remove")
|
||||||
|
remove_symlinks
|
||||||
|
;;
|
||||||
|
# dnf remove passes a 0
|
||||||
|
"0")
|
||||||
|
remove_logs_and_cache
|
||||||
|
remove_config
|
||||||
|
remove_symlinks
|
||||||
|
;;
|
||||||
|
esac
|
||||||
8
mullvad-vpn-daemon/mullvad-vpn-daemon.post-install
Normal file
8
mullvad-vpn-daemon/mullvad-vpn-daemon.post-install
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
ln -sf /opt/Mullvad\ VPN/resources/mullvad-problem-report /usr/bin/mullvad-problem-report
|
||||||
|
|
||||||
|
systemctl enable "/usr/lib/systemd/system/mullvad-daemon.service"
|
||||||
|
systemctl start mullvad-daemon.service || echo "Failed to start mullvad-daemon.service"
|
||||||
|
systemctl enable "/usr/lib/systemd/system/mullvad-early-boot-blocking.service"
|
||||||
23
mullvad-vpn-daemon/mullvad-vpn-daemon.pre-deinstall
Normal file
23
mullvad-vpn-daemon/mullvad-vpn-daemon.pre-deinstall
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
echo "Running prerm."
|
||||||
|
is_number_re='^[0-9]+$'
|
||||||
|
# Check if we're running during an upgrade step on Fedora
|
||||||
|
# https://fedoraproject.org/wiki/Packaging:Scriptlets#Syntax
|
||||||
|
if [[ "$1" =~ $is_number_re ]] && [ "$1" -gt 0 ]; then
|
||||||
|
exit 0;
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$1" == "upgrade" ]]; then
|
||||||
|
exit 0;
|
||||||
|
fi
|
||||||
|
|
||||||
|
# the user might've disabled or stopped the service themselves already
|
||||||
|
systemctl stop mullvad-daemon.service || true
|
||||||
|
systemctl disable mullvad-daemon.service || true
|
||||||
|
systemctl stop mullvad-early-boot-blocking.service || true
|
||||||
|
systemctl disable mullvad-early-boot-blocking.service || true
|
||||||
|
|
||||||
|
/opt/Mullvad\ VPN/resources/mullvad-setup reset-firewall || echo "Failed to reset firewall"
|
||||||
|
/opt/Mullvad\ VPN/resources/mullvad-setup remove-device || echo "Failed to remove device from account"
|
||||||
16
mullvad-vpn-daemon/mullvad-vpn-daemon.pre-install
Normal file
16
mullvad-vpn-daemon/mullvad-vpn-daemon.pre-install
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
if which systemctl &> /dev/null && systemctl is-system-running | grep -vq offline &> /dev/null; then
|
||||||
|
if systemctl status mullvad-daemon &> /dev/null; then
|
||||||
|
/opt/Mullvad\ VPN/resources/mullvad-setup prepare-restart || true
|
||||||
|
systemctl stop mullvad-daemon.service
|
||||||
|
systemctl disable mullvad-daemon.service
|
||||||
|
systemctl disable mullvad-early-boot-blocking.service || true
|
||||||
|
cp /var/log/mullvad-vpn/daemon.log /var/log/mullvad-vpn/old-install-daemon.log \
|
||||||
|
|| echo "Failed to copy old daemon log"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -f /var/cache/mullvad-vpn/relays.json
|
||||||
|
rm -f /var/cache/mullvad-vpn/api-ip-address.txt
|
||||||
1
mullvad-vpn-daemon/mullvadvpn-app
Submodule
1
mullvad-vpn-daemon/mullvadvpn-app
Submodule
Submodule mullvad-vpn-daemon/mullvadvpn-app added at 27f4b02410
@@ -48,10 +48,40 @@ build() {
|
|||||||
package() {
|
package() {
|
||||||
local target="$(rustup +stable show active-toolchain | sed 's/^[^-]*-//' | grep -o "^[^ ]*")"
|
local target="$(rustup +stable show active-toolchain | sed 's/^[^-]*-//' | grep -o "^[^ ]*")"
|
||||||
|
|
||||||
# TODO: .desktop
|
# Executable
|
||||||
# TODO: icon
|
|
||||||
|
|
||||||
install -m755 -D "$_cargo_target_dir/$target/release/mullvad-slint" \
|
install -m755 -D "$_cargo_target_dir/$target/release/mullvad-slint" \
|
||||||
"$pkgdir"/usr/bin/mullvad-slint
|
"$pkgdir"/usr/bin/mullvad-slint
|
||||||
|
|
||||||
|
# .desktop file
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/mullvad-vpn-slint.desktop" \
|
||||||
|
"$pkgdir"/usr/share/applications/mullvad-vpn-slint.desktop
|
||||||
|
|
||||||
|
# Icons
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_1_16x16x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/16x16/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_2_20x20x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/20x20/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_3_24x24x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/24x24/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_5_30x30x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/30x30/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_6_32x32x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/32x32/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_7_36x36x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/36x36/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_8_40x40x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/40x40/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_9_48x48x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/48x48/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_12_64x64x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/64x64/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_13_72x72x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/72x72/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_15_96x96x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/96x96/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_4_256x256x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/256x256/apps/mullvad.png
|
||||||
|
install -m644 -D "$startdir/mullvadvpn-app/dist-assets/linux/slint/icon_10_512x512x32.png" \
|
||||||
|
"$pkgdir"/usr/share/icons/hicolor/512x512/apps/mullvad.png
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
1
mullvad-vpn-slint/mullvadvpn-app
Submodule
1
mullvad-vpn-slint/mullvadvpn-app
Submodule
Submodule mullvad-vpn-slint/mullvadvpn-app added at 27f4b02410
@@ -5,6 +5,7 @@ cd "$(dirname "$0")"
|
|||||||
|
|
||||||
package="$1"
|
package="$1"
|
||||||
builder_image="mullvad-slint-musl-builder"
|
builder_image="mullvad-slint-musl-builder"
|
||||||
|
cargo_home="${CARGO_HOME:-$HOME/.cargo}"
|
||||||
. "$HOME/.abuild/abuild.conf"
|
. "$HOME/.abuild/abuild.conf"
|
||||||
|
|
||||||
podman build . -f Dockerfile -t "$builder_image"
|
podman build . -f Dockerfile -t "$builder_image"
|
||||||
@@ -14,8 +15,10 @@ podman run --rm \
|
|||||||
-v "$PACKAGER_PRIVKEY":/key.rsa:ro \
|
-v "$PACKAGER_PRIVKEY":/key.rsa:ro \
|
||||||
-v "$PACKAGER_PRIVKEY.pub":/key.rsa.pub:ro \
|
-v "$PACKAGER_PRIVKEY.pub":/key.rsa.pub:ro \
|
||||||
-v "$PACKAGER_PRIVKEY.pub":/etc/apk/keys/key.rsa.pub:ro \
|
-v "$PACKAGER_PRIVKEY.pub":/etc/apk/keys/key.rsa.pub:ro \
|
||||||
-v ./target:/cargo-target \
|
|
||||||
-v ./packages:/root/packages \
|
-v ./packages:/root/packages \
|
||||||
|
-v "$cargo_home":/cargo-home \
|
||||||
|
-e "CARGO_HOME=/cargo-home" \
|
||||||
|
-v ./target:/cargo-target \
|
||||||
-e "CARGO_TARGET_DIR=/cargo-target" \
|
-e "CARGO_TARGET_DIR=/cargo-target" \
|
||||||
-it \
|
-it \
|
||||||
"$builder_image" \
|
"$builder_image" \
|
||||||
|
|||||||
Reference in New Issue
Block a user