workstation virtually...done!
This commit is contained in:
parent
bdfbf790ec
commit
58878b21ed
@ -46,6 +46,11 @@ in {
|
|||||||
scripts = {
|
scripts = {
|
||||||
tasks.enable = true;
|
tasks.enable = true;
|
||||||
run.enable = true;
|
run.enable = true;
|
||||||
|
split-dir.enable = true;
|
||||||
|
pika-list.enable = true;
|
||||||
|
download.enable = true;
|
||||||
|
ffmpreg.enable = true;
|
||||||
|
ffmpeg4discord.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -93,6 +98,11 @@ in {
|
|||||||
users = {
|
users = {
|
||||||
groups.nixremote.gid = 555;
|
groups.nixremote.gid = 555;
|
||||||
users = {
|
users = {
|
||||||
|
jawz.packages = (with pkgs; [
|
||||||
|
gocryptfs # encrypted filesystem! shhh!!!
|
||||||
|
torrenttools # create torrent files from the terminal!
|
||||||
|
vcsi # video thumbnails for torrents, can I replace it with ^?
|
||||||
|
]);
|
||||||
nixremote = {
|
nixremote = {
|
||||||
isNormalUser = true;
|
isNormalUser = true;
|
||||||
createHome = true;
|
createHome = true;
|
||||||
@ -103,34 +113,6 @@ in {
|
|||||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGrC7sVvDT0is2oq/H1Do99LPaQKvyGMAsrF6/fuf1aP root@miniserver"
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGrC7sVvDT0is2oq/H1Do99LPaQKvyGMAsrF6/fuf1aP root@miniserver"
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
jawz = {
|
|
||||||
packages = (with pkgs; [
|
|
||||||
gocryptfs # encrypted filesystem! shhh!!!
|
|
||||||
|
|
||||||
torrenttools # create torrent files from the terminal!
|
|
||||||
vcsi # video thumbnails for torrents, can I replace it with ^?
|
|
||||||
|
|
||||||
(writeScriptBin "ffmpeg4discord"
|
|
||||||
(builtins.readFile ../../scripts/ffmpeg4discord.py))
|
|
||||||
(writeScriptBin "ffmpreg"
|
|
||||||
(builtins.readFile ../../scripts/ffmpreg.sh))
|
|
||||||
(writeScriptBin "split-dir"
|
|
||||||
(builtins.readFile ../../scripts/split-dir.sh))
|
|
||||||
(writeScriptBin "pika-list"
|
|
||||||
(builtins.readFile ../../scripts/pika-list.sh))
|
|
||||||
|
|
||||||
]) ++ (with pkgs.python3Packages;
|
|
||||||
[
|
|
||||||
(buildPythonApplication rec {
|
|
||||||
pname = "download";
|
|
||||||
version = "1.5";
|
|
||||||
src = ../../scripts/download/.;
|
|
||||||
doCheck = false;
|
|
||||||
buildInputs = [ setuptools ];
|
|
||||||
propagatedBuildInputs = [ pyyaml types-pyyaml ];
|
|
||||||
})
|
|
||||||
]);
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@ -1,7 +1,20 @@
|
|||||||
{ config, lib, pkgs, ... }: {
|
{ config, lib, pkgs, ... }: {
|
||||||
imports = [ ./scripts/tasks.nix ./scripts/run.nix ];
|
imports = [
|
||||||
|
./scripts/run.nix
|
||||||
|
./scripts/tasks.nix
|
||||||
|
./scripts/split-dir.nix
|
||||||
|
./scripts/pika-list.nix
|
||||||
|
./scripts/download.nix
|
||||||
|
./scripts/ffmpreg.nix
|
||||||
|
./scripts/ffmpeg4discord.nix
|
||||||
|
];
|
||||||
my.scripts = {
|
my.scripts = {
|
||||||
tasks.enable = lib.mkDefault false;
|
|
||||||
run.enable = lib.mkDefault false;
|
run.enable = lib.mkDefault false;
|
||||||
|
tasks.enable = lib.mkDefault false;
|
||||||
|
split-dir.enable = lib.mkDefault false;
|
||||||
|
pika-list.enable = lib.mkDefault false;
|
||||||
|
download.enable = lib.mkDefault false;
|
||||||
|
ffmpreg.enable = lib.mkDefault false;
|
||||||
|
ffmpeg4discord.enable = lib.mkDefault false;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,51 +1,59 @@
|
|||||||
{ config, lib, pkgs, ... }: {
|
{ config, lib, pkgs, ... }: {
|
||||||
options.my.script = {
|
options.my.scripts = lib.mkOption {
|
||||||
|
type = lib.types.attrsOf (lib.types.submodule ({
|
||||||
|
options = {
|
||||||
|
enable = lib.mkEnableOption "Whether to enable this script";
|
||||||
install = lib.mkEnableOption "Whether to install the script package";
|
install = lib.mkEnableOption "Whether to install the script package";
|
||||||
service = lib.mkEnableOption "Whether to enable the script service";
|
service = lib.mkEnableOption "Whether to enable the script service";
|
||||||
name = lib.mkOption {
|
name = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = "my-script";
|
|
||||||
description = "Name of the script.";
|
description = "Name of the script.";
|
||||||
};
|
};
|
||||||
timer = lib.mkOption {
|
timer = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = "*:0/10";
|
default = "*:0";
|
||||||
description = "Systemd timer schedule.";
|
description = "Systemd timer schedule.";
|
||||||
};
|
};
|
||||||
description = lib.mkOption {
|
description = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = "A service that runs a script.";
|
|
||||||
description = "Description of the service.";
|
description = "Description of the service.";
|
||||||
};
|
};
|
||||||
package = lib.mkOption {
|
package = lib.mkOption {
|
||||||
type = lib.types.package;
|
type = lib.types.package;
|
||||||
default = pkgs.writeScriptBin "my-script" "echo Hello World";
|
|
||||||
description = "Package containing the executable script.";
|
description = "Package containing the executable script.";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
config = {
|
}));
|
||||||
users.users.jawz = lib.mkIf config.my.script.install {
|
default = { };
|
||||||
packages = [ config.my.script.package ];
|
description = "Configuration for multiple scripts.";
|
||||||
};
|
};
|
||||||
systemd.user = with config.my.script;
|
|
||||||
lib.mkIf config.my.script.service {
|
config = lib.mkIf (lib.any (s: s.enable) (lib.attrValues config.my.scripts)) {
|
||||||
services."${name}" = {
|
users.users.jawz.packages = lib.flatten (lib.mapAttrsToList (name: script:
|
||||||
|
lib.optional (script.enable && script.install) script.package)
|
||||||
|
config.my.scripts);
|
||||||
|
|
||||||
|
systemd.user.services = lib.mapAttrs' (name: script:
|
||||||
|
lib.nameValuePair "${script.name}"
|
||||||
|
(lib.mkIf (script.enable && script.service) {
|
||||||
restartIfChanged = true;
|
restartIfChanged = true;
|
||||||
description = description;
|
description = script.description;
|
||||||
wantedBy = [ "default.target" ];
|
wantedBy = [ "default.target" ];
|
||||||
path = [ pkgs.nix package ];
|
path = [ pkgs.nix script.package ];
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
Restart = "on-failure";
|
Restart = "on-failure";
|
||||||
RestartSec = 30;
|
RestartSec = 30;
|
||||||
ExecStart = "${package}/bin/${name}";
|
ExecStart = "${script.package}/bin/${script.name}";
|
||||||
};
|
};
|
||||||
};
|
})) config.my.scripts;
|
||||||
timers."${name}" = {
|
|
||||||
|
systemd.user.timers = lib.mapAttrs' (name: script:
|
||||||
|
lib.nameValuePair "${script.name}"
|
||||||
|
(lib.mkIf (script.enable && script.service) {
|
||||||
enable = true;
|
enable = true;
|
||||||
description = description;
|
description = script.description;
|
||||||
wantedBy = [ "timers.target" ];
|
wantedBy = [ "timers.target" ];
|
||||||
timerConfig = { OnCalendar = timer; };
|
timerConfig = { OnCalendar = script.timer; };
|
||||||
};
|
})) config.my.scripts;
|
||||||
};
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
21
modules/scripts/download.nix
Normal file
21
modules/scripts/download.nix
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{ config, lib, pkgs, ... }: {
|
||||||
|
imports = [ ./base.nix ];
|
||||||
|
config = {
|
||||||
|
users.users.jawz.packages = (with pkgs; [ gallery-dl yt-dlp ]);
|
||||||
|
my.scripts.download = {
|
||||||
|
enable = true;
|
||||||
|
install = true;
|
||||||
|
service = false;
|
||||||
|
name = "download";
|
||||||
|
package = with pkgs.python3Packages;
|
||||||
|
(buildPythonApplication rec {
|
||||||
|
pname = "download";
|
||||||
|
version = "2.0";
|
||||||
|
src = ../../scripts/download/.;
|
||||||
|
doCheck = false;
|
||||||
|
buildInputs = [ setuptools ];
|
||||||
|
propagatedBuildInputs = [ pyyaml types-pyyaml ];
|
||||||
|
});
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
11
modules/scripts/ffmpeg4discord.nix
Normal file
11
modules/scripts/ffmpeg4discord.nix
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{ config, lib, pkgs, ... }: {
|
||||||
|
imports = [ ./base.nix ];
|
||||||
|
config.my.scripts.ffmpeg4discord = {
|
||||||
|
enable = true;
|
||||||
|
install = true;
|
||||||
|
service = false;
|
||||||
|
name = "ffmpeg4discord";
|
||||||
|
package = pkgs.writeScriptBin "ffmpeg4discord"
|
||||||
|
(builtins.readFile ../../scripts/ffmpeg4discord.py);
|
||||||
|
};
|
||||||
|
}
|
||||||
11
modules/scripts/ffmpreg.nix
Normal file
11
modules/scripts/ffmpreg.nix
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{ config, lib, pkgs, ... }: {
|
||||||
|
imports = [ ./base.nix ];
|
||||||
|
config.my.scripts.ffmpreg = {
|
||||||
|
enable = true;
|
||||||
|
install = true;
|
||||||
|
service = false;
|
||||||
|
name = "ffmpreg";
|
||||||
|
package = pkgs.writeScriptBin "ffmpreg"
|
||||||
|
(builtins.readFile ../../scripts/ffmpreg.sh);
|
||||||
|
};
|
||||||
|
}
|
||||||
11
modules/scripts/pika-list.nix
Normal file
11
modules/scripts/pika-list.nix
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{ config, lib, pkgs, ... }: {
|
||||||
|
imports = [ ./base.nix ];
|
||||||
|
config.my.scripts.pika-list = {
|
||||||
|
enable = true;
|
||||||
|
install = true;
|
||||||
|
service = false;
|
||||||
|
name = "pika-list";
|
||||||
|
package = pkgs.writeScriptBin "pika-list"
|
||||||
|
(builtins.readFile ../../scripts/pika-list.sh);
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -1,11 +1,11 @@
|
|||||||
{ config, lib, pkgs, ... }: {
|
{ config, lib, pkgs, ... }: {
|
||||||
imports = [ ./base.nix ];
|
imports = [ ./base.nix ];
|
||||||
options.my.scripts.run.enable = lib.mkEnableOption "enable";
|
config.my.scripts.run = {
|
||||||
config = lib.mkIf config.my.scripts.run.enable {
|
enable = true;
|
||||||
my.script = {
|
|
||||||
install = true;
|
install = true;
|
||||||
|
service = false;
|
||||||
|
name = "run";
|
||||||
package =
|
package =
|
||||||
pkgs.writeScriptBin "run" (builtins.readFile ../../scripts/run.sh);
|
pkgs.writeScriptBin "run" (builtins.readFile ../../scripts/run.sh);
|
||||||
};
|
};
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
11
modules/scripts/split-dir.nix
Normal file
11
modules/scripts/split-dir.nix
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{ config, lib, pkgs, ... }: {
|
||||||
|
imports = [ ./base.nix ];
|
||||||
|
config.my.scripts.split-dir = {
|
||||||
|
enable = true;
|
||||||
|
install = true;
|
||||||
|
service = false;
|
||||||
|
name = "split-dir";
|
||||||
|
package = pkgs.writeScriptBin "split-dir"
|
||||||
|
(builtins.readFile ../../scripts/split-dir.sh);
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -1,15 +1,13 @@
|
|||||||
{ config, lib, pkgs, ... }: {
|
{ config, lib, pkgs, ... }: {
|
||||||
imports = [ ./base.nix ];
|
imports = [ ./base.nix ];
|
||||||
options.my.scripts.tasks.enable = lib.mkEnableOption "enable";
|
config.my.scripts.tasks = {
|
||||||
config = lib.mkIf config.my.scripts.tasks.enable {
|
enable = true;
|
||||||
my.script = {
|
|
||||||
install = true;
|
install = true;
|
||||||
service = true;
|
service = true;
|
||||||
name = "tasks";
|
name = "tasks";
|
||||||
timer = "*:0/10";
|
timer = "*:0/10";
|
||||||
description = "runs a bunch of organizing tasks on selected directories";
|
description = "Runs a bunch of organizing tasks on selected directories";
|
||||||
package =
|
package =
|
||||||
pkgs.writeScriptBin "tasks" (builtins.readFile ../../scripts/tasks.sh);
|
pkgs.writeScriptBin "tasks" (builtins.readFile ../../scripts/tasks.sh);
|
||||||
};
|
};
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user