move jellyfin-rpc module to nixos service

This commit is contained in:
♥ Minnie ♥ 2023-12-19 09:14:55 +08:00
parent eed97c13a2
commit 53d96b58a4
3 changed files with 55 additions and 22 deletions

View file

@ -4,5 +4,4 @@
{
# List your module files here
# my-module = import ./my-module.nix;
jellyfin-rpc = import ./jellyfin-rpc.nix;
}

View file

@ -5,4 +5,5 @@
# List your module files here
# my-module = import ./my-module.nix;
qbittorrent = import ./qbittorrent.nix;
jellyfin-rpc = import ./jellyfin-rpc.nix;
}

View file

@ -1,10 +1,32 @@
{ lib, pkgs, config, ... }:
with lib;
with lib;
let
cfg = config.services.jellyfin-rpc;
in {
UID = 999;
GID = 999;
in
{
options.services.jellyfin-rpc = {
enable = mkEnableOption "jellyfin-rpc service";
user = mkOption {
type = types.str;
default = "jellyfin-rpc";
description = lib.mdDoc ''
User account under which jellyfin-rpc runs.
'';
};
group = mkOption {
type = types.str;
default = "jellyfin-rpc";
description = lib.mdDoc ''
Group under which jellyfin-rpc runs.
'';
};
jellyfin.url = mkOption {
type = types.str;
default = "https://example.com";
@ -12,6 +34,7 @@ in {
Url to jellyfin server.
'';
};
jellyfin.apiKey = mkOption {
type = types.str;
default = "sadasodsapasdskd";
@ -19,6 +42,7 @@ in {
Jellyfin API key, you can get one at http(s)://your_jellyfin_url/web/#!/apikeys.html
'';
};
jellyfin.username = mkOption {
type = types.str;
default = "my_user";
@ -26,6 +50,7 @@ in {
Username used to log in to jellyfin.
'';
};
discordApplicationID = mkOption {
type = types.str;
default = "1053747938519679018";
@ -33,6 +58,7 @@ in {
Discord application ID, you can make one here https://discord.com/developers/applications
'';
};
imgurClientID = mkOption {
type = types.str;
default = "asdjdjdg394209fdjs093";
@ -40,6 +66,7 @@ in {
Imgur Client ID, goto https://api.imgur.com/oauth2/addclient
'';
};
package = mkOption {
type = types.package;
default = pkgs.jellyfin-rpc;
@ -52,8 +79,21 @@ in {
};
config = mkIf cfg.enable {
home.packages = [ cfg.package ];
xdg.configFile."jellyfin-rpc/main.json".text = ''
systemd.services.jellyfin-rpc = {
description = "jellyfin-rpc service";
wantedBy = [ "multi-user.target" ];
serviceConfig = {
Type = "simple";
User = cfg.user;
Group = cfg.group;
ExecStart = "${cfg.package}/bin/jellyfin-rpc --config /etc/jellyfin-rpc/main.json";
};
};
environment.etc."jellyfin-rpc/main.json".text = ''
{
"jellyfin": {
"url": "${cfg.jellyfin.url}",
@ -75,24 +115,17 @@ in {
}
}
'';
systemd.user.services.jellyfin-rpc = {
Unit = {
Description = "Jellyfin-RPC";
};
Install = { WantedBy = [ "multi-user.target" ]; };
Service = {
ExecStart = concatStringsSep " " ([
"${getExe cfg.package}"
"--config ${config.xdg.configFile."jellyfin-rpc/main.json".source}"
]);
Restart = "always";
RestartSec = 3;
users.users = mkIf (cfg.user == "jellyfin-rpc") {
jellyfin-rpc = {
group = cfg.group;
uid = UID;
};
};
users.groups = mkIf (cfg.group == "jellyfin-rpc") {
jellyfin-rpc = { gid = GID; };
};
};
meta.maintainers = with lib.maintainers; [ sajenim ];
}
}