parent
ea84627e59
commit
1f72d3463e
3 changed files with 112 additions and 0 deletions
|
@ -179,6 +179,11 @@
|
||||||
module = "${self}/kubenix-modules/tailscale.nix";
|
module = "${self}/kubenix-modules/tailscale.nix";
|
||||||
namespace = "tailscale";
|
namespace = "tailscale";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
ntfy = {
|
||||||
|
module = "${self}/kubenix-modules/ntfy.nix";
|
||||||
|
namespace = "ntfy";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
|
|
@ -51,6 +51,7 @@
|
||||||
media = { };
|
media = { };
|
||||||
minecraft = { };
|
minecraft = { };
|
||||||
tailscale = { };
|
tailscale = { };
|
||||||
|
ntfy = { };
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes =
|
nodes =
|
||||||
|
@ -127,6 +128,7 @@
|
||||||
sonarr.storage = "150Mi";
|
sonarr.storage = "150Mi";
|
||||||
bazarr.storage = "25Mi";
|
bazarr.storage = "25Mi";
|
||||||
minecraft.storage = "1Gi";
|
minecraft.storage = "1Gi";
|
||||||
|
ntfy.storage = "300Mi";
|
||||||
};
|
};
|
||||||
|
|
||||||
tailscaleIngresses.tailscale-longhorn = {
|
tailscaleIngresses.tailscale-longhorn = {
|
||||||
|
|
105
kubenix-modules/ntfy.nix
Normal file
105
kubenix-modules/ntfy.nix
Normal file
|
@ -0,0 +1,105 @@
|
||||||
|
{ lib, ... }: {
|
||||||
|
kubernetes.resources = {
|
||||||
|
configMaps.ntfy.data.config = lib.generators.toYAML { } {
|
||||||
|
base-url = "https://ntfy.kun.is";
|
||||||
|
cache-file = "/var/cache/ntfy/cache.db";
|
||||||
|
cache-duration = "14d";
|
||||||
|
auth-file = "/var/lib/ntfy/user.db";
|
||||||
|
auth-default-access = "deny-all";
|
||||||
|
attachment-cache-dir = "/var/cache/ntfy-attachments";
|
||||||
|
enable-signup = false;
|
||||||
|
enable-login = true;
|
||||||
|
visitor-subscription-limit = 100;
|
||||||
|
};
|
||||||
|
|
||||||
|
deployments.ntfy.spec = {
|
||||||
|
selector.matchLabels.app = "ntfy";
|
||||||
|
|
||||||
|
strategy = {
|
||||||
|
type = "RollingUpdate";
|
||||||
|
|
||||||
|
rollingUpdate = {
|
||||||
|
maxSurge = 0;
|
||||||
|
maxUnavailable = 1;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
template = {
|
||||||
|
metadata.labels.app = "ntfy";
|
||||||
|
|
||||||
|
spec = {
|
||||||
|
containers.ntfy = {
|
||||||
|
image = "binwiederhier/ntfy:v2.11.0";
|
||||||
|
ports.web.containerPort = 80;
|
||||||
|
env.TZ.value = "Europe/Amsterdam";
|
||||||
|
args = [ "serve" ];
|
||||||
|
|
||||||
|
volumeMounts = [
|
||||||
|
{
|
||||||
|
name = "cache";
|
||||||
|
mountPath = "/var/cache/ntfy";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "data";
|
||||||
|
mountPath = "/var/lib/ntfy";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "attachment-cache";
|
||||||
|
mountPath = "/var/cache/ntfy-attachments";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "config";
|
||||||
|
mountPath = "/etc/ntfy/server.yml";
|
||||||
|
subPath = "config";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
volumes = {
|
||||||
|
cache.persistentVolumeClaim.claimName = "cache";
|
||||||
|
attachment-cache.persistentVolumeClaim.claimName = "attachment-cache";
|
||||||
|
data.persistentVolumeClaim.claimName = "data";
|
||||||
|
config.configMap.name = "ntfy";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
persistentVolumeClaims = {
|
||||||
|
cache.spec = {
|
||||||
|
accessModes = [ "ReadWriteOnce" ];
|
||||||
|
resources.requests.storage = "300Mi";
|
||||||
|
};
|
||||||
|
|
||||||
|
attachment-cache.spec = {
|
||||||
|
accessModes = [ "ReadWriteOnce" ];
|
||||||
|
resources.requests.storage = "500Mi";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
services.ntfy.spec = {
|
||||||
|
selector.app = "ntfy";
|
||||||
|
|
||||||
|
ports.web = {
|
||||||
|
port = 80;
|
||||||
|
targetPort = "web";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
lab = {
|
||||||
|
ingresses.ntfy = {
|
||||||
|
host = "ntfy.kun.is";
|
||||||
|
|
||||||
|
service = {
|
||||||
|
name = "ntfy";
|
||||||
|
portName = "web";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
longhorn.persistentVolumeClaim.data = {
|
||||||
|
volumeName = "ntfy";
|
||||||
|
storage = "300Mi";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue