nix-dotfiles/instances/heimdall/configuration.nix

530 lines
14 KiB
Nix

{ pkgs
, lib
, config
, ...
}:
let
hosts = import ../../hosts.nix;
in
{
# age.secrets = {
# ntfy-freya = { file = ../../secrets/ntfy-freya.age; owner = "bertof"; };
# };
boot.loader = {
systemd-boot.enable = true;
efi.canTouchEfiVariables = true;
};
console = {
font = "Lat2-Terminus16";
keyMap = "it";
};
environment = {
pathsToLink = [ "/share/zsh" ];
systemPackages = builtins.attrValues {
inherit (pkgs)
helix tmux vim
exiftool nodejs# for Nextcloud
;
};
};
hardware = {
bluetooth = {
enable = true;
# package = pkgs.bluezFull;
};
graphics.enable = true;
# amdgpu.amdvlk.enable = true;
};
i18n.defaultLocale = "it_IT.UTF-8";
networking.hostName = "heimdall";
networking.firewall = {
enable = true;
allowPing = true;
allowedTCPPorts = [
# 445 # SAMBA
# 139 # SAMBA
# 5357 # SAMBA-WSDD
# 8123 # HOME ASSISTANT
8384 # SYNCTHING
# 8385 # SYNCTHING
];
allowedUDPPorts = [
137 # SYNCTHING
138 # SYNCTHING
# 3702 # SAMBA-WSDD
];
# extraCommands =
# "iptables -t raw -A OUTPUT -p udp -m udp --dport 137 -j CT --helper netbios-ns";
};
programs = {
dconf.enable = true;
gnupg.agent = {
enable = true;
enableSSHSupport = true;
};
zsh.enable = true;
};
security.sudo.extraConfig = ''
Defaults pwfeedback
'';
users = {
groups.music-assistant = { };
users = {
zigbee2mqtt.extraGroups = [ "dialout" ];
music-assistant = {
isSystemUser = true;
group = "music-assistant";
extraGroups = [ "users" ];
};
};
};
services = {
garage.settings.data_dir = "/mnt/raid/garage/";
gitlab-runner = {
enable = true;
services = {
# runner for building docker images
docker-images = {
limit = 3;
authenticationTokenConfigFile = config.age.secrets.heimdall-gitlab-runner-docker-images.path;
dockerImage = "docker:stable";
dockerVolumes = [
"/var/run/docker.sock:/var/run/docker.sock"
];
};
# runner for everything else
default = {
limit = 3;
authenticationTokenConfigFile = config.age.secrets.heimdall-gitlab-runner-default.path;
dockerImage = "debian:stable";
};
};
};
immich.mediaLocation = "/mnt/raid/immich";
music-assistant = {
enable = true;
providers = [ "chromecast" "dlna" "filesystem_local" "hass" "hass_players" "jellyfin" "player_group" "radiobrowser" "soundcloud" "tidal" ];
};
mosquitto = {
enable = true;
listeners = [{
address = "127.0.0.1";
port = 1883;
users.zigbee2mqtt = {
acl = [
"readwrite #"
];
password = "zigbee2mqtt";
};
}];
};
zigbee2mqtt = {
enable = true;
settings = {
mqtt = {
user = "zigbee2mqtt";
password = "zigbee2mqtt";
client_id = "zigbee2mqtt";
};
frontend.enabled = true;
# permit_join = true;
serial = {
port = "/dev/serial/by-id/usb-1a86_USB_Serial-if00-port0";
adapter = "ember";
};
};
};
# grafana = {
# enable = true;
# settings.server = {
# http_addr = "0.0.0.0";
# domain = "bertof.net";
# root_url = "https://grafana.bertof.net/";
# };
# };
# avahi = {
# enable = true;
# openFirewall = true;
# nssmdns4 = true;
# publish = {
# enable = true;
# addresses = true;
# domain = true;
# userServices = true;
# workstation = true;
# };
# extraServiceFiles.ssh = "${pkgs.avahi}/etc/avahi/services/ssh.service";
# };
# blueman.enable = true;
# dbus.packages = [ pkgs.dconf ];
# gnome.gnome-keyring.enable = true;
openssh = {
enable = true;
openFirewall = true;
};
# # xserver = {
# # enable = true;
# # desktopManager.retroarch = { enable = true; package = pkgs.retroarchFull; };
# # };
#
fail2ban = {
enable = true;
bantime-increment.enable = true;
};
jellyfin = {
enable = true;
openFirewall = true;
group = "users";
};
#
home-assistant = {
enable = true;
openFirewall = true;
config = {
default_config = { };
homeassistant = {
name = "Casa";
latitude = "!secret home-latitude";
longitude = "!secret home-longitude";
country = "IT";
elevation = 24;
unit_system = "metric";
time_zone = "Europe/Rome";
external_url = "https://hass.bertof.net";
allowlist_external_dirs = [ "/tmp" ];
};
http = {
use_x_forwarded_for = true;
trusted_proxies = [
hosts.tailscale.ipv4."baldur"
"::1"
"127.0.0.1"
];
};
automation = "!include automations.yaml";
scene = "!include scenes.yaml";
alert = "!include alerts.yaml";
alarm_control_panel = {
platform = "manual";
code = "!secret alarm_code";
trigger_time = 60;
};
assist_pipeline = { };
# bluetooth = { };
camera = [
# { platform = "local_file"; file_path = "/tmp/doods_camera_camera_cancello.jpg"; name = "File DOODS2 Camera cancello"; }
# { platform = "local_file"; file_path = "/tmp/doods_camera_camera_vialetto.jpg"; name = "File DOODS2 Camera vialetto"; }
# { platform = "local_file"; file_path = "/tmp/doods_camera_camera_garage.jpg"; name = "File DOODS2 Camera garage"; }
];
cloud = { };
config = { };
# device_tracker = [{
# platform = "bluetooth_tracker";
# request_rssi = true;
# }];
image_processing = [
# {
# platform = "doods";
# url = "http://localhost:8080";
# detector = "default";
# source = [
# { entity_id = "camera.camera_camera_cancello"; name = "DOODS2 Camera cancello"; }
# { entity_id = "camera.camera_camera_vialetto"; name = "DOODS2 Camera vialetto"; }
# { entity_id = "camera.camera_camera_garage"; name = "DOODS2 Camera garage"; }
# ];
# confidence = 60;
# file_out = "/tmp/doods_{{ camera_entity.split('.')[1] }}.jpg";
# scan_interval = 5;
# labels = [ "bicycle" "car" "cat" "dog" "person" "truck" ];
# }
];
# esphome = { };
frontend = { };
google_assistant = {
project_id = "home-assistant-milano";
report_state = true;
service_account = "!include google-service-account.json";
exposed_domains = [
"alarm_control_panel"
"button"
"camera"
"climate"
"cover"
"fan"
"group"
"humidifier"
"input_boolean"
"input_button"
"input_select"
"light"
"lock"
"media_player"
"scene"
"script"
"select"
"sensor"
"switch"
"vacuum"
];
};
history = { };
logbook = { };
# logger.default = "debug";
logger.default = "info";
# "map" = { };
mobile_app = { };
notify = [
# { platform = "telegram"; name = "t_filippo"; chat_id = "!secret filippo_t_chat_id"; }
# { platform = "telegram"; name = "t_famiglia"; chat_id = "!secret famiglia_t_chat_id"; }
];
recorder.purge_keep_days = 30;
script = "!include scripts.yaml";
sensor = [
# {
# platform = "systemmonitor";
# resources = [
# { type = "disk_use_percent"; }
# { type = "disk_use"; }
# { type = "disk_free"; }
# { type = "memory_use_percent"; }
# { type = "memory_use"; }
# { type = "memory_free"; }
# { type = "swap_use_percent"; }
# { type = "swap_use"; }
# { type = "swap_free"; }
# { type = "load_1m"; }
# { type = "load_5m"; }
# { type = "load_15m"; }
# { type = "network_in"; arg = "eno1"; }
# { type = "network_out"; arg = "eno1"; }
# { type = "throughput_network_in"; arg = "eno1"; }
# { type = "throughput_network_out"; arg = "eno1"; }
# { type = "packets_in"; arg = "eno1"; }
# { type = "packets_out"; arg = "eno1"; }
# { type = "ipv4_address"; arg = "eno1"; }
# { type = "ipv6_address"; arg = "eno1"; }
# { type = "network_in"; arg = "ztmjfdwjkp"; }
# { type = "network_out"; arg = "ztmjfdwjkp"; }
# { type = "throughput_network_in"; arg = "ztmjfdwjkp"; }
# { type = "throughput_network_out"; arg = "ztmjfdwjkp"; }
# { type = "packets_in"; arg = "ztmjfdwjkp"; }
# { type = "packets_out"; arg = "ztmjfdwjkp"; }
# { type = "ipv4_address"; arg = "ztmjfdwjkp"; }
# { type = "ipv6_address"; arg = "ztmjfdwjkp"; }
# { type = "processor_use"; }
# { type = "processor_temperature"; }
# # { type = "process"; arg = "octave-cli"; }
# { type = "last_boot"; }
# ];
# }
];
shopping_list = { };
sun = { };
system_health = { };
# telegram_bot = [{
# # platform = "polling";
# platform = "webhooks";
# api_key = "!secret telegram_api_key";
# allowed_chat_ids = [
# "!secret filippo_t_chat_id"
# "!secret famiglia_t_chat_id"
# ];
# }];
tts = [
{
platform = "google_translate";
language = "it";
# tld = "it";
}
];
};
configDir = "/var/lib/hass";
configWritable = true;
extraPackages = ps: with ps; [ securetar ];
customComponents = with pkgs.home-assistant-custom-components; [ adaptive_lighting ];
extraComponents = [
"default_config"
# "accuweather"
"alert"
"analytics"
# "androidtv"
# "androidtv_remote"
"bayesian"
"binary_sensor"
"blueprint"
"bluetooth_le_tracker"
# "bluetooth_tracker"
"button"
"camera"
"cast"
"caldav"
"calendar"
"citybikes"
"co2signal"
"color_extractor"
"configurator"
# "coronavirus"
"cover"
"default_config"
"derivative"
"device_automation"
"device_sun_light_trigger"
"device_tracker"
"dlib_face_detect"
"dlib_face_identify"
"dlna_dmr"
"dlna_dms"
"esphome"
"flux"
"gdacs"
"google"
"google_translate"
"group"
"hassio"
"home_connect"
"jellyfin"
"local_file"
"media_player"
"mqtt"
"met"
"meteoalarm"
"network"
# "nextcloud"
"nmap_tracker"
"ollama"
"open_meteo"
"notify"
"ping"
"proximity"
"radarr"
"radio_browser"
"random"
"scene"
"schedule"
"script"
"sonarr"
"speedtestdotnet"
"spotify"
"tailscale"
"tcp"
# "telegram"
# "telegram_bot"
"template"
"threshold"
"transmission"
"tod" # times of the day
"trend"
"tuya"
"upnp"
"wake_on_lan"
"wled"
"workday"
"zha"
"zoneminder"
];
};
# prometheus = {
# enable = true;
# exporters = {
# node = {
# enable = true;
# enabledCollectors = [ "systemd" ];
# };
# process = {
# enable = true;
# settings.process_names = [
# # Remove nix store path from process name
# {
# name = "{{.Matches.Wrapped}} {{ .Matches.Args }}";
# cmdline = [ "^/nix/store[^ ]*/(?P<Wrapped>[^ /]*) (?P<Args>.*)" ];
# }
# ];
# };
# systemd.enable = true;
# };
# globalConfig = {
# scrape_interval = "10s";
# };
# scrapeConfigs = [
# {
# job_name = "node";
# static_configs = [
# { targets = [ "localhost:${toString config.services.prometheus.exporters.node.port}" ]; }
# ];
# }
# {
# job_name = "process";
# static_configs = [
# { targets = [ "localhost:${toString config.services.prometheus.exporters.process.port}" ]; }
# ];
# }
# {
# job_name = "systemd";
# static_configs = [
# { targets = [ "localhost:${toString config.services.prometheus.exporters.systemd.port}" ]; }
# ];
# }
# ];
# retentionTime = "15d";
# };
snapper.configs =
let
common = {
TIMELINE_CREATE = true;
TIMELINE_CLEANUP = true;
};
in
{
bertof = lib.recursiveUpdate common {
SUBVOLUME = "/mnt/raid/bertof/";
ALLOW_USERS = [ "bertof" ];
};
tiziano = lib.recursiveUpdate common {
SUBVOLUME = "/mnt/raid/tiziano/";
ALLOW_USERS = [ "tiziano" ];
};
condiviso = lib.recursiveUpdate common {
SUBVOLUME = "/mnt/raid/condiviso";
ALLOW_USERS = [
"bertof"
"tiziano"
];
};
immich = lib.recursiveUpdate common {
SUBVOLUME = "/mnt/raid/immich";
ALLOW_USERS = [ "bertof" ];
};
garage = lib.recursiveUpdate common {
SUBVOLUME = "/mnt/raid/garage";
ALLOW_USERS = [ "bertof" ];
};
};
};
time.timeZone = "Europe/Rome";
zramSwap.enable = true;
system.stateVersion = "24.05";
}