From 0b3ba8224255247fa751a9922f83154e71a26c02 Mon Sep 17 00:00:00 2001 From: Simon Zolin Date: Wed, 26 Jun 2019 14:02:41 +0300 Subject: [PATCH] - dhcp: store lease data in database on each change rather than once on app stop --- dhcpd/dhcpd.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/dhcpd/dhcpd.go b/dhcpd/dhcpd.go index a78c83ed..9ad0b08f 100644 --- a/dhcpd/dhcpd.go +++ b/dhcpd/dhcpd.go @@ -207,8 +207,6 @@ func (s *Server) Stop() error { s.cond.Wait() } s.mutex.Unlock() - - s.dbStore() return nil } @@ -250,6 +248,7 @@ func (s *Server) reserveLease(p dhcp4.Packet) (*Lease, error) { s.leases[i].IP, hwaddr, s.leases[i].HWAddr, s.leases[i].Expiry) lease.IP = s.leases[i].IP s.leases[i] = lease + s.dbStore() s.reserveIP(lease.IP, hwaddr) return lease, nil @@ -258,6 +257,7 @@ func (s *Server) reserveLease(p dhcp4.Packet) (*Lease, error) { log.Tracef("Assigning to %s IP address %s", hwaddr, ip.String()) lease.IP = ip s.leases = append(s.leases, lease) + s.dbStore() return lease, nil } @@ -410,6 +410,7 @@ func (s *Server) blacklistLease(lease *Lease) { lease.HWAddr = hw lease.Hostname = "" lease.Expiry = time.Now().Add(s.leaseTime) + s.dbStore() s.leasesLock.Unlock() }