services/soulbeet: init and add to alyssum
Some checks are pending
CI / Build linux-lava for x86_64-linux (push) Waiting to run
Some checks are pending
CI / Build linux-lava for x86_64-linux (push) Waiting to run
This commit is contained in:
parent
402c847f3c
commit
c36a3f09de
4 changed files with 43 additions and 0 deletions
|
|
@ -6,6 +6,7 @@
|
||||||
let
|
let
|
||||||
name = "fluorite";
|
name = "fluorite";
|
||||||
fqdn = "fluorite.lava.moe";
|
fqdn = "fluorite.lava.moe";
|
||||||
|
altfqdn = hostname: "fluorite.${hostname}.lava.moe";
|
||||||
subnetId = "6";
|
subnetId = "6";
|
||||||
|
|
||||||
subnet = x: "fd0d:1::${subnetId}:${toString x}";
|
subnet = x: "fd0d:1::${subnetId}:${toString x}";
|
||||||
|
|
@ -42,6 +43,13 @@
|
||||||
listenAddresses = [ "10.0.0.1" "[fd0d::1]" "100.67.1.1" ];
|
listenAddresses = [ "10.0.0.1" "[fd0d::1]" "100.67.1.1" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
services.nginx.virtualHosts."${altfqdn config.networking.hostname}" = {
|
||||||
|
useACMEHost = "lava.moe";
|
||||||
|
forceSSL = true;
|
||||||
|
locations."/".proxyPass = "http://[${client}]:5030";
|
||||||
|
listenAddresses = [ "10.0.0.1" "[fd0d::1]" "100.67.1.1" ];
|
||||||
|
};
|
||||||
|
|
||||||
systemd.tmpfiles.rules = [
|
systemd.tmpfiles.rules = [
|
||||||
"d /persist/containers/${name} 755 root users"
|
"d /persist/containers/${name} 755 root users"
|
||||||
"d /persist/media/music 075 nobody users"
|
"d /persist/media/music 075 nobody users"
|
||||||
|
|
|
||||||
|
|
@ -24,8 +24,10 @@
|
||||||
tailscale
|
tailscale
|
||||||
|
|
||||||
modules.services.nginx
|
modules.services.nginx
|
||||||
|
modules.services.soulbeet
|
||||||
modules.services.syncthing
|
modules.services.syncthing
|
||||||
|
|
||||||
|
inputs.c-fluorite.nixosModule
|
||||||
inputs.c-garnet.nixosModule
|
inputs.c-garnet.nixosModule
|
||||||
|
|
||||||
./filesystem.nix
|
./filesystem.nix
|
||||||
|
|
|
||||||
|
|
@ -22,6 +22,7 @@ in {
|
||||||
./services/nginx.nix
|
./services/nginx.nix
|
||||||
./services/postgres.nix
|
./services/postgres.nix
|
||||||
./services/sonarr.nix
|
./services/sonarr.nix
|
||||||
|
./services/soulbeet.nix
|
||||||
./services/synapse.nix
|
./services/synapse.nix
|
||||||
./services/syncthing.nix
|
./services/syncthing.nix
|
||||||
./services/tmptsync.nix
|
./services/tmptsync.nix
|
||||||
|
|
|
||||||
32
modules/services/soulbeet.nix
Normal file
32
modules/services/soulbeet.nix
Normal file
|
|
@ -0,0 +1,32 @@
|
||||||
|
{ ... }:
|
||||||
|
let
|
||||||
|
dir_data = "/persist/services/soulbeet/data";
|
||||||
|
dir_downloads = "/persist/containers/fluorite/slskd/downloads";
|
||||||
|
dir_music = "/persist/media/music";
|
||||||
|
in {
|
||||||
|
systemd.tmpfiles.rules = [
|
||||||
|
"d ${dir_data} 700 root root"
|
||||||
|
"d ${dir_downloads} 755 root users"
|
||||||
|
"d ${dir_music} 075 nobody users"
|
||||||
|
];
|
||||||
|
virtualisation.oci-containers.backend = "docker";
|
||||||
|
virtualisation.oci-containers.containers = {
|
||||||
|
container-name = {
|
||||||
|
image = "docker.io/docccccc/soulbeet:latest";
|
||||||
|
autoStart = true;
|
||||||
|
ports = [ "9765:9765" ];
|
||||||
|
environment = {
|
||||||
|
DATABASE_URL = "sqlite:/data/soulbeet.db";
|
||||||
|
DOWNLOAD_PATH = "/downloads";
|
||||||
|
SECRET_KEY = "change-me-in-production";
|
||||||
|
NAVIDROME_URL = "http://navidrome:4533";
|
||||||
|
BEETS_CONFIG = "/config/config.yaml";
|
||||||
|
};
|
||||||
|
volumes = [
|
||||||
|
"${dir_data}:/data"
|
||||||
|
"${dir_downloads}:/downloads"
|
||||||
|
"${dir_music}:/music"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue