2018-05-28 09:53:54 +02:00
|
|
|
// Binary dhcp6 obtains a DHCPv6 lease, persists it to
|
2018-05-27 17:30:42 +02:00
|
|
|
// /perm/dhcp6/wire/lease.json and notifies netconfigd.
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"flag"
|
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
2018-06-02 21:00:56 +02:00
|
|
|
"os/signal"
|
2018-05-27 17:30:42 +02:00
|
|
|
"path/filepath"
|
|
|
|
"router7/internal/dhcp6"
|
|
|
|
"router7/internal/notify"
|
2018-06-02 21:00:56 +02:00
|
|
|
"router7/internal/teelogger"
|
2018-05-27 17:30:42 +02:00
|
|
|
"syscall"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2018-06-02 21:00:56 +02:00
|
|
|
var log = teelogger.NewConsole()
|
|
|
|
|
2018-05-27 17:30:42 +02:00
|
|
|
func logic() error {
|
|
|
|
const configPath = "/perm/dhcp6/wire/lease.json"
|
|
|
|
if err := os.MkdirAll(filepath.Dir(configPath), 0755); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2018-06-02 21:00:56 +02:00
|
|
|
duid, err := ioutil.ReadFile("/perm/dhcp6/duid")
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("could not read /perm/dhcp6/duid (%v), proceeding with DUID-LLT")
|
|
|
|
}
|
|
|
|
|
2018-05-27 17:30:42 +02:00
|
|
|
c, err := dhcp6.NewClient(dhcp6.ClientConfig{
|
|
|
|
InterfaceName: "uplink0",
|
2018-06-02 21:00:56 +02:00
|
|
|
DUID: duid,
|
2018-05-27 17:30:42 +02:00
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2018-06-02 21:00:56 +02:00
|
|
|
usr2 := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(usr2, syscall.SIGUSR2)
|
2018-05-27 17:30:42 +02:00
|
|
|
for c.ObtainOrRenew() {
|
|
|
|
if err := c.Err(); err != nil {
|
|
|
|
log.Printf("Temporary error: %v", err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
log.Printf("lease: %+v", c.Config())
|
|
|
|
b, err := json.Marshal(c.Config())
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := ioutil.WriteFile(configPath, b, 0644); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2018-06-22 17:59:23 +02:00
|
|
|
if err := notify.Process("/user/netconfigd", syscall.SIGUSR1); err != nil {
|
2018-05-27 17:30:42 +02:00
|
|
|
log.Printf("notifying netconfig: %v", err)
|
|
|
|
}
|
2018-06-15 09:28:41 +02:00
|
|
|
if err := notify.Process("/user/radvd", syscall.SIGUSR1); err != nil {
|
|
|
|
log.Printf("notifying radvd: %v", err)
|
|
|
|
}
|
2018-06-02 21:00:56 +02:00
|
|
|
select {
|
|
|
|
case <-time.After(time.Until(c.Config().RenewAfter)):
|
|
|
|
// fallthrough and renew the DHCP lease
|
|
|
|
case <-usr2:
|
|
|
|
log.Printf("SIGUSR2 received, sending DHCPRELEASE")
|
|
|
|
if _, _, err := c.Release(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
os.Exit(125) // quit supervision by gokrazy
|
|
|
|
}
|
2018-05-27 17:30:42 +02:00
|
|
|
}
|
|
|
|
return c.Err() // permanent error
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
if err := logic(); err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|