mirror of
https://github.com/Jackett/Jackett
synced 2025-01-03 13:46:10 +00:00
updater: improvements in systemd jackett_launcher (#6270)
This commit is contained in:
parent
8a6d3c6c2e
commit
b72ad9a7f5
4 changed files with 48 additions and 22 deletions
21
build.cake
21
build.cake
|
@ -185,6 +185,7 @@ Task("Package-DotNetCore-LinuxAMDx64")
|
||||||
DeleteDirectory(updaterOutputPath, new DeleteDirectorySettings {Recursive = true, Force = true});
|
DeleteDirectory(updaterOutputPath, new DeleteDirectorySettings {Recursive = true, Force = true});
|
||||||
|
|
||||||
CopyFileToDirectory("./install_service_systemd.sh", buildOutputPath);
|
CopyFileToDirectory("./install_service_systemd.sh", buildOutputPath);
|
||||||
|
CopyFileToDirectory("./jackett_launcher.sh", buildOutputPath);
|
||||||
|
|
||||||
Gzip($"./BuildOutput/{netCoreFramework}/{runtimeId}", $"./{artifactsDirName}", "Jackett", "Jackett.Binaries.LinuxAMDx64.tar.gz");
|
Gzip($"./BuildOutput/{netCoreFramework}/{runtimeId}", $"./{artifactsDirName}", "Jackett", "Jackett.Binaries.LinuxAMDx64.tar.gz");
|
||||||
});
|
});
|
||||||
|
@ -204,6 +205,7 @@ Task("Package-DotNetCore-LinuxARM32")
|
||||||
DeleteDirectory(updaterOutputPath, new DeleteDirectorySettings {Recursive = true, Force = true});
|
DeleteDirectory(updaterOutputPath, new DeleteDirectorySettings {Recursive = true, Force = true});
|
||||||
|
|
||||||
CopyFileToDirectory("./install_service_systemd.sh", buildOutputPath);
|
CopyFileToDirectory("./install_service_systemd.sh", buildOutputPath);
|
||||||
|
CopyFileToDirectory("./jackett_launcher.sh", buildOutputPath);
|
||||||
|
|
||||||
Gzip($"./BuildOutput/{netCoreFramework}/{runtimeId}", $"./{artifactsDirName}", "Jackett", "Jackett.Binaries.LinuxARM32.tar.gz");
|
Gzip($"./BuildOutput/{netCoreFramework}/{runtimeId}", $"./{artifactsDirName}", "Jackett", "Jackett.Binaries.LinuxARM32.tar.gz");
|
||||||
});
|
});
|
||||||
|
@ -223,6 +225,7 @@ Task("Package-DotNetCore-LinuxARM64")
|
||||||
DeleteDirectory(updaterOutputPath, new DeleteDirectorySettings {Recursive = true, Force = true});
|
DeleteDirectory(updaterOutputPath, new DeleteDirectorySettings {Recursive = true, Force = true});
|
||||||
|
|
||||||
CopyFileToDirectory("./install_service_systemd.sh", buildOutputPath);
|
CopyFileToDirectory("./install_service_systemd.sh", buildOutputPath);
|
||||||
|
CopyFileToDirectory("./jackett_launcher.sh", buildOutputPath);
|
||||||
|
|
||||||
Gzip($"./BuildOutput/{netCoreFramework}/{runtimeId}", $"./{artifactsDirName}", "Jackett", "Jackett.Binaries.LinuxARM64.tar.gz");
|
Gzip($"./BuildOutput/{netCoreFramework}/{runtimeId}", $"./{artifactsDirName}", "Jackett", "Jackett.Binaries.LinuxARM64.tar.gz");
|
||||||
});
|
});
|
||||||
|
@ -406,16 +409,28 @@ private void Gzip(string sourceFolder, string outputDirectory, string tarCdirect
|
||||||
RunLinuxCommand("chmod", $"755 {MakeAbsolute(Directory(sourceFolder))}/Jackett/jackett");
|
RunLinuxCommand("chmod", $"755 {MakeAbsolute(Directory(sourceFolder))}/Jackett/jackett");
|
||||||
RunLinuxCommand("chmod", $"755 {MakeAbsolute(Directory(sourceFolder))}/Jackett/JackettUpdater");
|
RunLinuxCommand("chmod", $"755 {MakeAbsolute(Directory(sourceFolder))}/Jackett/JackettUpdater");
|
||||||
|
|
||||||
|
string macOsServiceScript = MakeAbsolute(Directory(sourceFolder)) + "/Jackett/install_service_macos";
|
||||||
|
if (FileExists(macOsServiceScript))
|
||||||
|
{
|
||||||
|
RunLinuxCommand("chmod", $"755 {macOsServiceScript}");
|
||||||
|
}
|
||||||
|
|
||||||
|
string systemdMonoScript = MakeAbsolute(Directory(sourceFolder)) + "/Jackett/install_service_systemd_mono.sh";
|
||||||
|
if (FileExists(systemdMonoScript))
|
||||||
|
{
|
||||||
|
RunLinuxCommand("chmod", $"755 {systemdMonoScript}");
|
||||||
|
}
|
||||||
|
|
||||||
string systemdScript = MakeAbsolute(Directory(sourceFolder)) + "/Jackett/install_service_systemd.sh";
|
string systemdScript = MakeAbsolute(Directory(sourceFolder)) + "/Jackett/install_service_systemd.sh";
|
||||||
if (FileExists(systemdScript))
|
if (FileExists(systemdScript))
|
||||||
{
|
{
|
||||||
RunLinuxCommand("chmod", $"755 {systemdScript}");
|
RunLinuxCommand("chmod", $"755 {systemdScript}");
|
||||||
}
|
}
|
||||||
|
|
||||||
string macOsServiceScript = MakeAbsolute(Directory(sourceFolder)) + "/Jackett/install_service_macos";
|
string launcherScript = MakeAbsolute(Directory(sourceFolder)) + "/Jackett/jackett_launcher.sh";
|
||||||
if (FileExists(macOsServiceScript))
|
if (FileExists(launcherScript))
|
||||||
{
|
{
|
||||||
RunLinuxCommand("chmod", $"755 {macOsServiceScript}");
|
RunLinuxCommand("chmod", $"755 {launcherScript}");
|
||||||
}
|
}
|
||||||
|
|
||||||
RunLinuxCommand("tar", $"-C {sourceFolder} -zcvf {outputDirectory}/{tarFileName}.gz {tarCdirectoryOption}");
|
RunLinuxCommand("tar", $"-C {sourceFolder} -zcvf {outputDirectory}/{tarFileName}.gz {tarCdirectoryOption}");
|
||||||
|
|
|
@ -32,23 +32,6 @@ if [[ $(systemctl status ${jackettservice} | grep "active (running)") ]]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Write the Jackett's launcher
|
|
||||||
cat >"/bin/jackett_launcher.sh" <<EOL
|
|
||||||
#!/bin/bash
|
|
||||||
|
|
||||||
${jackettdir}/jackett
|
|
||||||
|
|
||||||
while pgrep JackettUpdater > /dev/null ; do
|
|
||||||
sleep 1
|
|
||||||
done
|
|
||||||
|
|
||||||
echo "Jackett update complete"
|
|
||||||
|
|
||||||
EOL
|
|
||||||
|
|
||||||
# Give execution permissions
|
|
||||||
chmod +x "/bin/jackett_launcher.sh"
|
|
||||||
|
|
||||||
# Write the systemd service descriptor
|
# Write the systemd service descriptor
|
||||||
cat >"/etc/systemd/system/${jackettservice}" <<EOL
|
cat >"/etc/systemd/system/${jackettservice}" <<EOL
|
||||||
[Unit]
|
[Unit]
|
||||||
|
@ -63,7 +46,7 @@ Type=simple
|
||||||
User=${jackettuser}
|
User=${jackettuser}
|
||||||
Group=${jackettuser}
|
Group=${jackettuser}
|
||||||
WorkingDirectory=${jackettdir}
|
WorkingDirectory=${jackettdir}
|
||||||
ExecStart=/bin/jackett_launcher.sh
|
ExecStart=${jackettdir}/jackett_launcher.sh
|
||||||
TimeoutStopSec=20
|
TimeoutStopSec=20
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
|
|
19
jackett_launcher.sh
Executable file
19
jackett_launcher.sh
Executable file
|
@ -0,0 +1,19 @@
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Helper script to fix
|
||||||
|
# https://github.com/Jackett/Jackett/issues/5208#issuecomment-547565515
|
||||||
|
|
||||||
|
JACKETT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
|
||||||
|
|
||||||
|
# Launch Jackett
|
||||||
|
${JACKETT_DIR}/jackett
|
||||||
|
|
||||||
|
# Get user running the service
|
||||||
|
JACKETT_USER=$(whoami)
|
||||||
|
|
||||||
|
# Wait until the updater ends
|
||||||
|
while pgrep -u ${JACKETT_USER} JackettUpdater > /dev/null ; do
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "Jackett update complete"
|
|
@ -292,7 +292,8 @@ namespace Jackett.Common.Services
|
||||||
inStream.Close();
|
inStream.Close();
|
||||||
|
|
||||||
if (variant == Variants.JackettVariant.CoreMacOs || variant == Variants.JackettVariant.CoreLinuxAmdx64
|
if (variant == Variants.JackettVariant.CoreMacOs || variant == Variants.JackettVariant.CoreLinuxAmdx64
|
||||||
|| variant == Variants.JackettVariant.CoreLinuxArm32 || variant == Variants.JackettVariant.CoreLinuxArm64)
|
|| variant == Variants.JackettVariant.CoreLinuxArm32 || variant == Variants.JackettVariant.CoreLinuxArm64
|
||||||
|
|| variant == Variants.JackettVariant.Mono)
|
||||||
{
|
{
|
||||||
//Calling the file permission service to limit usage to netcoreapp. The Mono.Posix.NETStandard library causes issues outside of .NET Core
|
//Calling the file permission service to limit usage to netcoreapp. The Mono.Posix.NETStandard library causes issues outside of .NET Core
|
||||||
//https://github.com/xamarin/XamarinComponents/issues/282
|
//https://github.com/xamarin/XamarinComponents/issues/282
|
||||||
|
@ -310,10 +311,18 @@ namespace Jackett.Common.Services
|
||||||
string macosServicePath = tempDir + "/Jackett/install_service_macos";
|
string macosServicePath = tempDir + "/Jackett/install_service_macos";
|
||||||
filePermissionService.MakeFileExecutable(macosServicePath);
|
filePermissionService.MakeFileExecutable(macosServicePath);
|
||||||
}
|
}
|
||||||
|
else if (variant == Variants.JackettVariant.Mono)
|
||||||
|
{
|
||||||
|
string systemdPath = tempDir + "/Jackett/install_service_systemd_mono.sh";
|
||||||
|
filePermissionService.MakeFileExecutable(systemdPath);
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
string systemdPath = tempDir + "/Jackett/install_service_systemd.sh";
|
string systemdPath = tempDir + "/Jackett/install_service_systemd.sh";
|
||||||
filePermissionService.MakeFileExecutable(systemdPath);
|
filePermissionService.MakeFileExecutable(systemdPath);
|
||||||
|
|
||||||
|
string launcherPath = tempDir + "/Jackett/jackett_launcher.sh";
|
||||||
|
filePermissionService.MakeFileExecutable(launcherPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue