 7e2b0068e6
			
		
	
	7e2b0068e6
	
	
	
		
			
			There is nothing in this commit except for the changes made by nix-shell -p nixfmt-rfc-style --run "nixfmt ." If this has mucked up your open branches then sorry about that. You can probably nixfmt them to match before merging
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| {
 | |
|   liminix,
 | |
|   writeAshScript,
 | |
|   serviceFns,
 | |
|   lib,
 | |
| }:
 | |
| { interface }:
 | |
| let
 | |
|   inherit (liminix.services) longrun;
 | |
|   name = "${interface.name}.dhcpc";
 | |
|   script = writeAshScript "dhcp-notify" { } ''
 | |
|     . ${serviceFns}
 | |
|     exec 2>&1
 | |
|     action=$1
 | |
| 
 | |
|     set_address() {
 | |
|         ip address replace $ip/$mask dev $interface
 | |
|         (in_outputs ${name}
 | |
|          for i in lease mask ip router siaddr dns serverid subnet opt53 interface ; do
 | |
|             (printenv $i || true) > $i
 | |
|          done)
 | |
|     }
 | |
|     case $action in
 | |
|       deconfig)
 | |
|         ip address flush $interface
 | |
|         ip link set up dev $interface
 | |
|         ;;
 | |
|       bound)
 | |
|         # this doesn't actually replace, it adds a new address.
 | |
|         set_address
 | |
|         echo  >/proc/self/fd/10
 | |
|         ;;
 | |
|       renew)
 | |
|         set_address
 | |
|         ;;
 | |
|       nak)
 | |
|         echo "received NAK on $interface"
 | |
|         ;;
 | |
|     esac
 | |
|   '';
 | |
| in
 | |
| longrun {
 | |
|   inherit name;
 | |
|   run = "exec /bin/udhcpc -f -i $(output ${interface} ifname) -x hostname:$(cat /proc/sys/kernel/hostname) -s ${script}";
 | |
|   notification-fd = 10;
 | |
|   dependencies = [ interface ];
 | |
| }
 |