mirror of
https://git.sr.ht/~roxwize/.dotfiles
synced 2025-05-02 03:39:32 +00:00
~
This commit is contained in:
parent
15ba5fb4e8
commit
41fe95e9b1
7 changed files with 5 additions and 147 deletions
|
@ -1,5 +0,0 @@
|
|||
{ lib, config, ... }: {
|
||||
imports = [
|
||||
./homepage
|
||||
];
|
||||
}
|
|
@ -1,67 +0,0 @@
|
|||
# Auto-generated using compose2nix v0.3.1.
|
||||
{ pkgs, lib, ... }:
|
||||
|
||||
{
|
||||
# Runtime
|
||||
virtualisation.docker = {
|
||||
enable = true;
|
||||
autoPrune.enable = true;
|
||||
};
|
||||
virtualisation.oci-containers.backend = "docker";
|
||||
|
||||
# Containers
|
||||
virtualisation.oci-containers.containers."homepage" = {
|
||||
image = "ghcr.io/gethomepage/homepage:latest";
|
||||
volumes = [
|
||||
"/etc/homepage-dashboard:/app/config:rw"
|
||||
"/var/run/docker.sock:/var/run/docker.sock:rw"
|
||||
];
|
||||
log-driver = "journald";
|
||||
extraOptions = [
|
||||
"--network-alias=homepage"
|
||||
"--network=homepage_default"
|
||||
];
|
||||
};
|
||||
systemd.services."docker-homepage" = {
|
||||
serviceConfig = {
|
||||
Restart = lib.mkOverride 90 "no";
|
||||
};
|
||||
after = [
|
||||
"docker-network-homepage_default.service"
|
||||
];
|
||||
requires = [
|
||||
"docker-network-homepage_default.service"
|
||||
];
|
||||
partOf = [
|
||||
"docker-compose-homepage-root.target"
|
||||
];
|
||||
wantedBy = [
|
||||
"docker-compose-homepage-root.target"
|
||||
];
|
||||
};
|
||||
|
||||
# Networks
|
||||
systemd.services."docker-network-homepage_default" = {
|
||||
path = [ pkgs.docker ];
|
||||
serviceConfig = {
|
||||
Type = "oneshot";
|
||||
RemainAfterExit = true;
|
||||
ExecStop = "docker network rm -f homepage_default";
|
||||
};
|
||||
script = ''
|
||||
docker network inspect homepage_default || docker network create homepage_default
|
||||
'';
|
||||
partOf = [ "docker-compose-homepage-root.target" ];
|
||||
wantedBy = [ "docker-compose-homepage-root.target" ];
|
||||
};
|
||||
|
||||
# Root service
|
||||
# When started, this will automatically create all resources and start
|
||||
# the containers. When stopped, this will teardown all resources.
|
||||
systemd.targets."docker-compose-homepage-root" = {
|
||||
unitConfig = {
|
||||
Description = "Root target generated by compose2nix.";
|
||||
};
|
||||
wantedBy = [ "multi-user.target" ];
|
||||
};
|
||||
}
|
|
@ -1,49 +0,0 @@
|
|||
{ pkgs, lib, config, ... }: let
|
||||
cfg = config.r5e.containers.homepage;
|
||||
settingsFormat = pkgs.formats.yaml {};
|
||||
in with lib; {
|
||||
options.r5e.containers.homepage = {
|
||||
enable = mkEnableOption "homepage";
|
||||
listenPort = mkOption {
|
||||
type = types.int;
|
||||
default = 3000;
|
||||
};
|
||||
openFirewall = mkOption {
|
||||
type = types.bool;
|
||||
default = false;
|
||||
};
|
||||
settings = mkOption {
|
||||
inherit (settingsFormat) type;
|
||||
description = "See https://gethomepage.dev/configs/settings/";
|
||||
default = {};
|
||||
};
|
||||
widgets = mkOption {
|
||||
inherit (settingsFormat) type;
|
||||
description = "See https://gethomepage.dev/widgets/";
|
||||
default = [];
|
||||
};
|
||||
imagesDir = mkOption {
|
||||
type = types.path;
|
||||
default = "";
|
||||
};
|
||||
};
|
||||
|
||||
config = mkMerge [
|
||||
(import ./compose.nix { inherit pkgs lib; })
|
||||
{
|
||||
environment.etc = mkIf cfg.enable {
|
||||
"homepage-dashboard/settings.yaml".source = settingsFormat.generate "settings.yaml" cfg.settings;
|
||||
"homepage-dashboard/widgets.yaml".source = settingsFormat.generate "widgets.yaml" cfg.widgets;
|
||||
};
|
||||
|
||||
networking.firewall = mkIf cfg.openFirewall {
|
||||
allowedTCPPorts = [ cfg.listenPort ];
|
||||
};
|
||||
|
||||
virtualisation.oci-containers.containers.homepage = {
|
||||
ports = [ (builtins.toString cfg.listenPort + ":3000/tcp") ];
|
||||
volumes = mkIf (cfg.imagesDir != null) [ (builtins.toString cfg.imagesDir + ":/app/public/images:rw") ];
|
||||
};
|
||||
}
|
||||
];
|
||||
}
|
|
@ -1,10 +0,0 @@
|
|||
name: homepage
|
||||
services:
|
||||
homepage:
|
||||
image: ghcr.io/gethomepage/homepage:latest
|
||||
container_name: homepage
|
||||
ports:
|
||||
- 3000:3000
|
||||
volumes:
|
||||
- /etc/homepage-dashboard:/app/config # Make sure your local config directory exists
|
||||
- /var/run/docker.sock:/var/run/docker.sock # (optional) For docker integrations
|
|
@ -4,7 +4,6 @@
|
|||
inputs.raspberry-pi-nix.nixosModules.sd-image
|
||||
./hardware-configuration.nix
|
||||
../base.nix
|
||||
../../docker
|
||||
];
|
||||
|
||||
users.users.root.openssh.authorizedKeys.keys = [
|
||||
|
@ -13,16 +12,14 @@
|
|||
|
||||
programs.git.enable = true;
|
||||
virtualisation.docker.enable = true;
|
||||
r5e.containers = {
|
||||
# TODO: this doesnt work (some random ENOENT shit) and it seems slightly overkill
|
||||
# maybe make your own dashboard page yourself or something
|
||||
homepage = {
|
||||
enable = false;
|
||||
|
||||
services = {
|
||||
homepage-dashboard = {
|
||||
enable = true;
|
||||
listenPort = 80;
|
||||
openFirewall = true;
|
||||
settings = {
|
||||
title = "near";
|
||||
background = "/images/2kki_rainy_apartments.png";
|
||||
theme = "dark";
|
||||
color = "violet";
|
||||
headerStyle = "clean";
|
||||
|
@ -52,11 +49,7 @@
|
|||
};
|
||||
}
|
||||
];
|
||||
imagesDir = /home/rae/.dotfiles/assets/wallpapers;
|
||||
};
|
||||
};
|
||||
|
||||
services = {
|
||||
openssh = {
|
||||
ports = [ 22 ];
|
||||
banner = "I won't hold it against you";
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue