kdhcp/server/server.go

90 lines
1.6 KiB
Go
Raw Normal View History

2023-05-02 16:27:27 +00:00
package server
import (
"errors"
"net"
"git.wntrmute.dev/kyle/kdhcp/config"
2023-05-02 23:33:14 +00:00
"git.wntrmute.dev/kyle/kdhcp/dhcp"
2023-05-02 16:27:27 +00:00
"git.wntrmute.dev/kyle/kdhcp/log"
)
const (
MaxPacketSize = 512
)
type Server struct {
Conn net.PacketConn
Config *config.Config
}
func (s *Server) Close() error {
return s.Conn.Close()
}
func (s *Server) Bind() (err error) {
2023-05-02 23:33:14 +00:00
// In order to read DHCP packets, we'll need to listen on all addresses.
ip := net.IP([]byte{0, 0, 0, 0})
s.Conn, err = BindInterface(ip, s.Config.Port, s.Config.Interface)
2023-05-02 16:27:27 +00:00
return err
}
func (s *Server) ReadFrom() ([]byte, net.Addr, error) {
b := make([]byte, MaxPacketSize)
n, addr, err := s.Conn.ReadFrom(b)
if err != nil {
return nil, nil, err
}
b = b[:n]
return b, addr, nil
}
2023-05-02 23:33:14 +00:00
func (s *Server) ReadDHCPRequest() (*dhcp.BootRequest, error) {
pkt, addr, err := s.ReadFrom()
if err != nil {
return nil, err
}
log.Debugf("server: read %db packet from %s", len(pkt), addr)
return dhcp.ReadRequest(pkt)
}
2023-05-02 16:27:27 +00:00
func (s *Server) WriteTo(b []byte, addr net.Addr) error {
return errors.New("server: not implemented")
}
func (s *Server) AcceptPacket() error {
2023-05-02 23:33:14 +00:00
request, err := s.ReadDHCPRequest()
2023-05-02 16:27:27 +00:00
if err != nil {
return err
}
2023-05-02 23:33:14 +00:00
log.Debugf("BOOTP request received from %x", request.HardwareAddress)
2023-05-02 16:27:27 +00:00
return nil
}
func (s *Server) Listen() {
for {
if err := s.AcceptPacket(); err != nil {
log.Errf("server: error reading packet: %s", err)
continue
}
}
}
func New(cfg *config.Config) (*Server, error) {
srv := &Server{
Config: cfg,
}
err := srv.Bind()
if err != nil {
return nil, err
}
log.Infof("server: bound to %s:%s", cfg.Interface, srv.Conn.LocalAddr())
return srv, nil
}