mirror of
https://git.sr.ht/~roxwize/.dotfiles
synced 2025-03-13 07:53:25 +00:00
~
This commit is contained in:
parent
bbcc5dbb76
commit
721a38ce25
6 changed files with 110 additions and 7 deletions
|
@ -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
12
nixos/docker/default.nix
Normal 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;
|
||||
}
|
68
nixos/docker/homepage/default.nix
Normal file
68
nixos/docker/homepage/default.nix
Normal 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" ];
|
||||
};
|
||||
}
|
10
nixos/docker/homepage/docker-compose.yml
Normal file
10
nixos/docker/homepage/docker-compose.yml
Normal 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
|
|
@ -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";
|
||||
|
|
|
@ -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
|
||||
|
|
Loading…
Add table
Reference in a new issue