12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- package ipsec
- import (
- "fmt"
- "net"
- log "github.com/golang/glog"
- "github.com/vishvananda/netlink"
- "github.com/coreos/flannel/subnet"
- )
- 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,
- }
- log.Infof("Adding ipsec policy: %+v", tmpl)
- policy.Tmpls = append(policy.Tmpls, tmpl)
- if err := netlink.XfrmPolicyAdd(&policy); err != nil {
- return fmt.Errorf("error adding 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
- }
|