blob: 8c502076213052a9b880823598d6985e6f095447 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package bacgopes
import "github.com/rs/zerolog"
type IPRouter struct {
nodes []*IPRouterNode
log zerolog.Logger
}
func NewIPRouter(localLog zerolog.Logger) *IPRouter {
return &IPRouter{
log: localLog,
}
}
func (n *IPRouter) AddNetwork(addr *Address, lan *IPNetwork) {
n.log.Debug().Stringer("addr", addr).Stringer("lan", lan).Msg("adding network")
node, err := NewIPRouterNode(n.log, n, addr, lan)
if err != nil {
n.log.Error().Err(err).Msg("error creating IPRouterNode")
return
}
n.log.Debug().Stringer("node", node).Msg("node")
n.nodes = append(n.nodes, node)
}
func (n *IPRouter) ProcessPDU(node *IPRouterNode, pdu PDU) {
n.log.Debug().Stringer("node", node).Stringer("pdu", pdu).Msg("processing PDU")
// unpack the address part of the destination
addrstr := *pdu.GetPDUDestination().AddrIP //TODO: check if this is the right way here.
ipaddr := addrstr
n.log.Debug().Uint32("ipaddr", ipaddr).Msg("ipaddr")
// loop through the other nodes
for _, inode := range n.nodes {
if inode != node {
if ipaddr&*inode.addrMask == *inode.addrSubnet {
n.log.Debug().Stringer("inode", inode).Msg("inode")
if err := inode.ProcessPDU(pdu); err != nil {
n.log.Debug().Err(err).Msg("error processing inode")
}
}
}
}
}