123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- package ipsec
- import (
- "errors"
- "fmt"
- "net"
- "syscall"
- "github.com/flannel-io/flannel/subnet"
- "github.com/vishvananda/netlink"
- log "k8s.io/klog"
- )
- func AddXFRMPolicy(myLease, remoteLease *subnet.Lease, dir netlink.Dir, reqID int) error {
- src := myLease.Subnet.ToIPNet()
- dst := remoteLease.Subnet.ToIPNet()
- policy := &netlink.XfrmPolicy{
- Src: src,
- Dst: dst,
- Dir: dir,
- }
- tunnelLeft := myLease.Attrs.PublicIP.ToIP()
- tunnelRight := remoteLease.Attrs.PublicIP.ToIP()
- tmpl := netlink.XfrmPolicyTmpl{
- Src: tunnelLeft,
- Dst: tunnelRight,
- Proto: netlink.XFRM_PROTO_ESP,
- Mode: netlink.XFRM_MODE_TUNNEL,
- Reqid: reqID,
- }
- policy.Tmpls = append(policy.Tmpls, tmpl)
- if existingPolicy, err := netlink.XfrmPolicyGet(policy); err != nil {
- if errors.Is(err, syscall.ENOENT) {
- log.Infof("Adding ipsec policy: %+v", tmpl)
- if err := netlink.XfrmPolicyAdd(policy); err != nil {
- return fmt.Errorf("error adding policy: %+v err: %v", policy, err)
- }
- } else {
- return fmt.Errorf("error getting policy: %+v err: %v", policy, err)
- }
- } else {
- log.Infof("Updating ipsec policy %+v with %+v", existingPolicy, policy)
- if err := netlink.XfrmPolicyUpdate(policy); err != nil {
- return fmt.Errorf("error updating policy: %+v err: %v", policy, err)
- }
- }
- return nil
- }
- func DeleteXFRMPolicy(localSubnet, remoteSubnet *net.IPNet, localPublicIP, remotePublicIP net.IP, dir netlink.Dir, reqID int) error {
- src := localSubnet
- dst := remoteSubnet
- policy := netlink.XfrmPolicy{
- Src: src,
- Dst: dst,
- Dir: dir,
- }
- tunnelLeft := localPublicIP
- tunnelRight := remotePublicIP
- tmpl := netlink.XfrmPolicyTmpl{
- Src: tunnelLeft,
- Dst: tunnelRight,
- Proto: netlink.XFRM_PROTO_ESP,
- Mode: netlink.XFRM_MODE_TUNNEL,
- Reqid: reqID,
- }
- log.Infof("Deleting ipsec policy: %+v", tmpl)
- policy.Tmpls = append(policy.Tmpls, tmpl)
- if err := netlink.XfrmPolicyDel(&policy); err != nil {
- return fmt.Errorf("error deleting policy: %+v err: %v", policy, err)
- }
- return nil
- }
|