Merge pull request #35343 from gnidorah/softether
softether module: fix dataDir option
This commit is contained in:
commit
df4963daca
|
@ -5,6 +5,8 @@ with lib;
|
||||||
let
|
let
|
||||||
cfg = config.services.softether;
|
cfg = config.services.softether;
|
||||||
|
|
||||||
|
package = cfg.package.override { dataDir = cfg.dataDir; };
|
||||||
|
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -49,7 +51,7 @@ in
|
||||||
|
|
||||||
dataDir = mkOption {
|
dataDir = mkOption {
|
||||||
type = types.string;
|
type = types.string;
|
||||||
default = "${cfg.package.dataDir}";
|
default = "/var/lib/softether";
|
||||||
description = ''
|
description = ''
|
||||||
Data directory for SoftEther VPN.
|
Data directory for SoftEther VPN.
|
||||||
'';
|
'';
|
||||||
|
@ -64,11 +66,8 @@ in
|
||||||
config = mkIf cfg.enable (
|
config = mkIf cfg.enable (
|
||||||
|
|
||||||
mkMerge [{
|
mkMerge [{
|
||||||
environment.systemPackages = [
|
environment.systemPackages = [ package ];
|
||||||
(pkgs.lib.overrideDerivation cfg.package (attrs: {
|
|
||||||
dataDir = cfg.dataDir;
|
|
||||||
}))
|
|
||||||
];
|
|
||||||
systemd.services."softether-init" = {
|
systemd.services."softether-init" = {
|
||||||
description = "SoftEther VPN services initial task";
|
description = "SoftEther VPN services initial task";
|
||||||
wantedBy = [ "network.target" ];
|
wantedBy = [ "network.target" ];
|
||||||
|
@ -80,11 +79,11 @@ in
|
||||||
for d in vpnserver vpnbridge vpnclient vpncmd; do
|
for d in vpnserver vpnbridge vpnclient vpncmd; do
|
||||||
if ! test -e ${cfg.dataDir}/$d; then
|
if ! test -e ${cfg.dataDir}/$d; then
|
||||||
${pkgs.coreutils}/bin/mkdir -m0700 -p ${cfg.dataDir}/$d
|
${pkgs.coreutils}/bin/mkdir -m0700 -p ${cfg.dataDir}/$d
|
||||||
install -m0600 ${cfg.package}${cfg.dataDir}/$d/hamcore.se2 ${cfg.dataDir}/$d/hamcore.se2
|
install -m0600 ${package}${cfg.dataDir}/$d/hamcore.se2 ${cfg.dataDir}/$d/hamcore.se2
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
rm -rf ${cfg.dataDir}/vpncmd/vpncmd
|
rm -rf ${cfg.dataDir}/vpncmd/vpncmd
|
||||||
ln -s ${cfg.package}${cfg.dataDir}/vpncmd/vpncmd ${cfg.dataDir}/vpncmd/vpncmd
|
ln -s ${package}${cfg.dataDir}/vpncmd/vpncmd ${cfg.dataDir}/vpncmd/vpncmd
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -97,12 +96,12 @@ in
|
||||||
wantedBy = [ "network.target" ];
|
wantedBy = [ "network.target" ];
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Type = "forking";
|
Type = "forking";
|
||||||
ExecStart = "${cfg.package}/bin/vpnserver start";
|
ExecStart = "${package}/bin/vpnserver start";
|
||||||
ExecStop = "${cfg.package}/bin/vpnserver stop";
|
ExecStop = "${package}/bin/vpnserver stop";
|
||||||
};
|
};
|
||||||
preStart = ''
|
preStart = ''
|
||||||
rm -rf ${cfg.dataDir}/vpnserver/vpnserver
|
rm -rf ${cfg.dataDir}/vpnserver/vpnserver
|
||||||
ln -s ${cfg.package}${cfg.dataDir}/vpnserver/vpnserver ${cfg.dataDir}/vpnserver/vpnserver
|
ln -s ${package}${cfg.dataDir}/vpnserver/vpnserver ${cfg.dataDir}/vpnserver/vpnserver
|
||||||
'';
|
'';
|
||||||
postStop = ''
|
postStop = ''
|
||||||
rm -rf ${cfg.dataDir}/vpnserver/vpnserver
|
rm -rf ${cfg.dataDir}/vpnserver/vpnserver
|
||||||
|
@ -118,12 +117,12 @@ in
|
||||||
wantedBy = [ "network.target" ];
|
wantedBy = [ "network.target" ];
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Type = "forking";
|
Type = "forking";
|
||||||
ExecStart = "${cfg.package}/bin/vpnbridge start";
|
ExecStart = "${package}/bin/vpnbridge start";
|
||||||
ExecStop = "${cfg.package}/bin/vpnbridge stop";
|
ExecStop = "${package}/bin/vpnbridge stop";
|
||||||
};
|
};
|
||||||
preStart = ''
|
preStart = ''
|
||||||
rm -rf ${cfg.dataDir}/vpnbridge/vpnbridge
|
rm -rf ${cfg.dataDir}/vpnbridge/vpnbridge
|
||||||
ln -s ${cfg.package}${cfg.dataDir}/vpnbridge/vpnbridge ${cfg.dataDir}/vpnbridge/vpnbridge
|
ln -s ${package}${cfg.dataDir}/vpnbridge/vpnbridge ${cfg.dataDir}/vpnbridge/vpnbridge
|
||||||
'';
|
'';
|
||||||
postStop = ''
|
postStop = ''
|
||||||
rm -rf ${cfg.dataDir}/vpnbridge/vpnbridge
|
rm -rf ${cfg.dataDir}/vpnbridge/vpnbridge
|
||||||
|
@ -139,12 +138,12 @@ in
|
||||||
wantedBy = [ "network.target" ];
|
wantedBy = [ "network.target" ];
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Type = "forking";
|
Type = "forking";
|
||||||
ExecStart = "${cfg.package}/bin/vpnclient start";
|
ExecStart = "${package}/bin/vpnclient start";
|
||||||
ExecStop = "${cfg.package}/bin/vpnclient stop";
|
ExecStop = "${package}/bin/vpnclient stop";
|
||||||
};
|
};
|
||||||
preStart = ''
|
preStart = ''
|
||||||
rm -rf ${cfg.dataDir}/vpnclient/vpnclient
|
rm -rf ${cfg.dataDir}/vpnclient/vpnclient
|
||||||
ln -s ${cfg.package}${cfg.dataDir}/vpnclient/vpnclient ${cfg.dataDir}/vpnclient/vpnclient
|
ln -s ${package}${cfg.dataDir}/vpnclient/vpnclient ${cfg.dataDir}/vpnclient/vpnclient
|
||||||
'';
|
'';
|
||||||
postStart = ''
|
postStart = ''
|
||||||
sleep 1
|
sleep 1
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
{ stdenv, fetchurl
|
{ stdenv, fetchurl
|
||||||
, openssl, readline, ncurses, zlib }:
|
, openssl, readline, ncurses, zlib
|
||||||
|
, dataDir ? "/var/lib/softether" }:
|
||||||
|
|
||||||
let
|
let
|
||||||
os = if stdenv.isLinux then "1"
|
os = if stdenv.isLinux then "1"
|
||||||
|
@ -17,7 +18,6 @@ stdenv.mkDerivation rec {
|
||||||
version = "4.18";
|
version = "4.18";
|
||||||
build = "9570";
|
build = "9570";
|
||||||
compiledDate = "2015.07.26";
|
compiledDate = "2015.07.26";
|
||||||
dataDir = "/var/lib/softether";
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "http://www.softether-download.com/files/softether/v${version}-${build}-rtm-${compiledDate}-tree/Source_Code/softether-src-v${version}-${build}-rtm.tar.gz";
|
url = "http://www.softether-download.com/files/softether/v${version}-${build}-rtm-${compiledDate}-tree/Source_Code/softether-src-v${version}-${build}-rtm.tar.gz";
|
||||||
|
@ -48,6 +48,6 @@ stdenv.mkDerivation rec {
|
||||||
homepage = https://www.softether.org/;
|
homepage = https://www.softether.org/;
|
||||||
license = licenses.gpl2;
|
license = licenses.gpl2;
|
||||||
maintainers = [ maintainers.rick68 ];
|
maintainers = [ maintainers.rick68 ];
|
||||||
platforms = platforms.linux;
|
platforms = filter (p: p != "aarch64-linux") platforms.linux;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
{ stdenv, fetchurl
|
{ stdenv, fetchurl
|
||||||
, openssl, readline, ncurses, zlib }:
|
, openssl, readline, ncurses, zlib
|
||||||
|
, dataDir ? "/var/lib/softether" }:
|
||||||
|
|
||||||
let
|
let
|
||||||
os = if stdenv.isLinux then "1"
|
os = if stdenv.isLinux then "1"
|
||||||
|
@ -17,7 +18,6 @@ stdenv.mkDerivation rec {
|
||||||
version = "4.20";
|
version = "4.20";
|
||||||
build = "9608";
|
build = "9608";
|
||||||
compiledDate = "2016.04.17";
|
compiledDate = "2016.04.17";
|
||||||
dataDir = "/var/lib/softether";
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "http://www.softether-download.com/files/softether/v${version}-${build}-rtm-${compiledDate}-tree/Source_Code/softether-src-v${version}-${build}-rtm.tar.gz";
|
url = "http://www.softether-download.com/files/softether/v${version}-${build}-rtm-${compiledDate}-tree/Source_Code/softether-src-v${version}-${build}-rtm.tar.gz";
|
||||||
|
@ -48,6 +48,6 @@ stdenv.mkDerivation rec {
|
||||||
homepage = https://www.softether.org/;
|
homepage = https://www.softether.org/;
|
||||||
license = licenses.gpl2;
|
license = licenses.gpl2;
|
||||||
maintainers = [ maintainers.rick68 ];
|
maintainers = [ maintainers.rick68 ];
|
||||||
platforms = platforms.linux;
|
platforms = filter (p: p != "aarch64-linux") platforms.linux;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
{ stdenv, fetchurl
|
{ stdenv, fetchurl
|
||||||
, openssl, readline, ncurses, zlib }:
|
, openssl, readline, ncurses, zlib
|
||||||
|
, dataDir ? "/var/lib/softether" }:
|
||||||
|
|
||||||
let
|
let
|
||||||
os = if stdenv.isLinux then "1"
|
os = if stdenv.isLinux then "1"
|
||||||
|
@ -17,7 +18,6 @@ stdenv.mkDerivation rec {
|
||||||
version = "4.25";
|
version = "4.25";
|
||||||
build = "9656";
|
build = "9656";
|
||||||
compiledDate = "2018.01.15";
|
compiledDate = "2018.01.15";
|
||||||
dataDir = "/var/lib/softether";
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "http://www.softether-download.com/files/softether/v${version}-${build}-rtm-${compiledDate}-tree/Source_Code/softether-src-v${version}-${build}-rtm.tar.gz";
|
url = "http://www.softether-download.com/files/softether/v${version}-${build}-rtm-${compiledDate}-tree/Source_Code/softether-src-v${version}-${build}-rtm.tar.gz";
|
||||||
|
@ -48,6 +48,6 @@ stdenv.mkDerivation rec {
|
||||||
homepage = https://www.softether.org/;
|
homepage = https://www.softether.org/;
|
||||||
license = licenses.gpl2;
|
license = licenses.gpl2;
|
||||||
maintainers = [ maintainers.rick68 ];
|
maintainers = [ maintainers.rick68 ];
|
||||||
platforms = platforms.linux;
|
platforms = filter (p: p != "aarch64-linux") platforms.linux;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue