loopback plugin support to pass previous result transpartently
Signed-off-by: Bruce Ma <brucema19901024@gmail.com>
This commit is contained in:
parent
659a09f34e
commit
3d56f7504d
@ -15,12 +15,15 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
|
|
||||||
"github.com/vishvananda/netlink"
|
"github.com/vishvananda/netlink"
|
||||||
|
|
||||||
"github.com/containernetworking/cni/pkg/skel"
|
"github.com/containernetworking/cni/pkg/skel"
|
||||||
|
"github.com/containernetworking/cni/pkg/types"
|
||||||
"github.com/containernetworking/cni/pkg/types/current"
|
"github.com/containernetworking/cni/pkg/types/current"
|
||||||
"github.com/containernetworking/cni/pkg/version"
|
"github.com/containernetworking/cni/pkg/version"
|
||||||
|
|
||||||
@ -28,9 +31,32 @@ import (
|
|||||||
bv "github.com/containernetworking/plugins/pkg/utils/buildversion"
|
bv "github.com/containernetworking/plugins/pkg/utils/buildversion"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func parseNetConf(bytes []byte) (*types.NetConf, error) {
|
||||||
|
conf := &types.NetConf{}
|
||||||
|
if err := json.Unmarshal(bytes, conf); err != nil {
|
||||||
|
return nil, fmt.Errorf("failed to parse network config: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if conf.RawPrevResult != nil {
|
||||||
|
if err := version.ParsePrevResult(conf); err != nil {
|
||||||
|
return nil, fmt.Errorf("failed to parse prevResult: %v", err)
|
||||||
|
}
|
||||||
|
if _, err := current.NewResultFromResult(conf.PrevResult); err != nil {
|
||||||
|
return nil, fmt.Errorf("failed to convert result to current version: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return conf, nil
|
||||||
|
}
|
||||||
|
|
||||||
func cmdAdd(args *skel.CmdArgs) error {
|
func cmdAdd(args *skel.CmdArgs) error {
|
||||||
|
conf, err := parseNetConf(args.StdinData)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
args.IfName = "lo" // ignore config, this only works for loopback
|
args.IfName = "lo" // ignore config, this only works for loopback
|
||||||
err := ns.WithNetNSPath(args.Netns, func(_ ns.NetNS) error {
|
err = ns.WithNetNSPath(args.Netns, func(_ ns.NetNS) error {
|
||||||
link, err := netlink.LinkByName(args.IfName)
|
link, err := netlink.LinkByName(args.IfName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err // not tested
|
return err // not tested
|
||||||
@ -47,8 +73,16 @@ func cmdAdd(args *skel.CmdArgs) error {
|
|||||||
return err // not tested
|
return err // not tested
|
||||||
}
|
}
|
||||||
|
|
||||||
result := current.Result{}
|
var result types.Result
|
||||||
return result.Print()
|
if conf.PrevResult != nil {
|
||||||
|
// If loopback has previous result which passes from previous CNI plugin,
|
||||||
|
// loopback should pass it transparently
|
||||||
|
result = conf.PrevResult
|
||||||
|
} else {
|
||||||
|
result = ¤t.Result{}
|
||||||
|
}
|
||||||
|
|
||||||
|
return types.PrintResult(result, conf.CNIVersion)
|
||||||
}
|
}
|
||||||
|
|
||||||
func cmdDel(args *skel.CmdArgs) error {
|
func cmdDel(args *skel.CmdArgs) error {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user