1
0
Fork 0
mirror of https://git.sr.ht/~roxwize/.dotfiles synced 2025-03-13 07:53:25 +00:00
This commit is contained in:
Rae 5e 2025-03-03 23:55:20 -05:00
parent bbcc5dbb76
commit 721a38ce25
Signed by: rae
GPG key ID: 5B1A0FAB9BAB81EE
6 changed files with 110 additions and 7 deletions

View file

@ -4,5 +4,8 @@ root = true
end_of_line = lf
insert_final_newline = true
charset = utf-8
indent_style = space
indent_style = tab
indent_size = 4
[*.{yml, yaml}]
indent_style = space # stupid cocksucking motherfucking piece of shit

12
nixos/docker/default.nix Normal file
View file

@ -0,0 +1,12 @@
{ lib, config, ... }: with lib; let
c = options.containers;
in {
options.containers = {
homepage = {
#TODO: https://github.com/NixOS/nixpkgs/blob/nixos-24.11/nixos/modules/services/misc/homepage-dashboard.nix#L221
enable = mkEnableOption "homepage";
};
};
config = mkIf c.homepage import ./homepage;
}

View file

@ -0,0 +1,68 @@
# 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 = [
"/home/rae/.dotfiles/configs/homepage:/app/config:rw"
"/var/run/docker.sock:/var/run/docker.sock:rw"
];
ports = [
"3000:3000/tcp"
];
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" ];
};
}

View file

@ -0,0 +1,10 @@
name: homepage
services:
homepage:
image: ghcr.io/gethomepage/homepage:latest
container_name: homepage
ports:
- 3000:3000
volumes:
- /home/rae/.dotfiles/configs/homepage:/app/config # Make sure your local config directory exists
- /var/run/docker.sock:/var/run/docker.sock # (optional) For docker integrations

View file

@ -4,23 +4,32 @@
inputs.raspberry-pi-nix.nixosModules.sd-image
./hardware-configuration.nix
../base.nix
../../docker
];
users.users.root.openssh.authorizedKeys.keys = [
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIPyZFWvrboUTM/dKzz5kQHEKjNqI410VJUGiVckhjOve rae@ioides"
];
services.openssh = {
ports = [ 22 ];
banner = "I won't hold it against you";
settings = {
PasswordAuthentication = true;
programs.git.enable = true;
virtualisation.docker.enable = true;
containers = {
homepage.enable = true;
};
services = {
openssh = {
ports = [ 22 ];
banner = "I won't hold it against you";
settings = {
PasswordAuthentication = true;
};
};
};
networking = {
hostName = "near";
firewall.allowedTCPPorts = [ 22 ];
firewall.allowedTCPPorts = [ 22 8082 ];
};
time.timeZone = "America/New_York";

View file

@ -75,6 +75,7 @@
android-tools # Android SDK platform tools
bat # Cat(1) clone with syntax highlighting and Git integration
btop # Monitor of resources
compose2nix # Generate a NixOS config from a Docker Compose project
dconf-editor # GSettings editor for GNOME
kdePackages.dolphin # File manager by KDE
ffmpeg # Complete, cross-platform solution to record, convert and stream audio and video