# This is an example configuration for a "typical" small office/home # router and wifi access point. # You need to copy it to another filename and change the configuration # wherever the text "EDIT" appears - please consult the tutorial # documentation for details. { config, pkgs, lib, modulesPath, ... } : let liminix = ./liminix; inherit (pkgs.liminix.services) bundle oneshot longrun; inherit (pkgs) serviceFns; # EDIT: you can pick your preferred RFC1918 address space # for NATted connections, if you don't like this one. svc = config.system.service; in rec { boot = { tftp = { freeSpaceBytes = 3 * 1024 * 1024; serverip = "10.0.0.1"; ipaddr = "10.0.0.8"; }; }; hardware.ubi = { # PLEASE remove this when using the real RAM. These are just tweaks to make tftpboot working minIOSize = lib.mkForce "1"; eraseBlockSize = lib.mkForce "130944"; }; imports = [ (liminix + "/modules/network") (liminix + "/modules/ssh") (liminix + "/modules/outputs/ubimage.nix") #(liminix + "/modules/outputs/ext4fs.nix") ]; rootfsType = "ubifs"; hostname = "hackens-router"; # EDIT services.int = svc.network.address.build { interface = config.hardware.networkInterfaces.wan; family = "inet"; address = "10.0.0.8"; prefixLength = 24; }; services.sshd = svc.ssh.build { }; users.root = { # EDIT: choose a root password and then use # "mkpasswd -m sha512crypt" to determine the hash. # It should start wirh $6$. passwd = "$6$9XlVymX951ai.c2C$SYtEF2Ykcud8VRuLRxfQRfuc9h7oJpVo.xDEv6fTWjBngMj3bPN9GbFMv3r.T.K2wIj1rTo9j1m58G.GTPKWo/"; }; }