Skip to content

Commit

Permalink
migrate arista provider
Browse files Browse the repository at this point in the history
Signed-off-by: Ivan Milchev <[email protected]>
  • Loading branch information
imilchev committed Feb 8, 2024
1 parent ad83e1d commit d5a37cc
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 128 deletions.
4 changes: 4 additions & 0 deletions providers-sdk/v1/plugin/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -180,3 +180,7 @@ func (s *Service) Heartbeat(req *HeartbeatReq) (*HeartbeatRes, error) {

return &heartbeatRes, nil
}

func (s *Service) Shutdown(req *ShutdownReq) (*ShutdownRes, error) {
return &ShutdownRes{}, nil
}
146 changes: 25 additions & 121 deletions providers/arista/provider/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,15 +24,12 @@ const (
)

type Service struct {
plugin.Service
runtimes map[uint32]*plugin.Runtime
lastConnectionID uint32
*plugin.Service
}

func Init() *Service {
return &Service{
runtimes: map[uint32]*plugin.Runtime{},
lastConnectionID: 0,
Service: plugin.NewService(),
}
}

Expand Down Expand Up @@ -89,9 +86,6 @@ func (s *Service) ParseCLI(req *plugin.ParseCLIReq) (*plugin.ParseCLIRes, error)
// Shutdown is automatically called when the shell closes.
// It is not necessary to implement this method.
// If you want to do some cleanup, you can do it here.
func (s *Service) Shutdown(req *plugin.ShutdownReq) (*plugin.ShutdownRes, error) {
return &plugin.ShutdownRes{}, nil
}

func (s *Service) MockConnect(req *plugin.ConnectReq, callback plugin.ProviderCallback) (*plugin.ConnectRes, error) {
return nil, errors.New("mock connect not yet implemented")
Expand Down Expand Up @@ -129,37 +123,34 @@ func (s *Service) connect(req *plugin.ConnectReq, callback plugin.ProviderCallba

asset := req.Asset
conf := asset.Connections[0]
var conn *connection.AristaConnection
var err error

switch conf.Type {
default:
s.lastConnectionID++
conn, err = connection.NewAristaConnection(s.lastConnectionID, asset, conf)
}

if err != nil {
return nil, err
}

var upstream *upstream.UpstreamClient
if req.Upstream != nil && !req.Upstream.Incognito {
upstream, err = req.Upstream.InitClient()
runtime, err := s.AddRuntime(func(connId uint32) (*plugin.Runtime, error) {
conn, err := connection.NewAristaConnection(connId, asset, conf)
if err != nil {
return nil, err
}
}

asset.Connections[0].Id = conn.ID()
s.runtimes[conn.ID()] = &plugin.Runtime{
Connection: conn,
Callback: callback,
HasRecording: req.HasRecording,
CreateResource: resources.CreateResource,
Upstream: upstream,
}

return conn, err
var upstream *upstream.UpstreamClient
if req.Upstream != nil && !req.Upstream.Incognito {
upstream, err = req.Upstream.InitClient()
if err != nil {
return nil, err
}
}
asset.Connections[0].Id = connId

return &plugin.Runtime{
Connection: conn,
Callback: callback,
HasRecording: req.HasRecording,
CreateResource: resources.CreateResource,
NewResource: resources.NewResource,
GetData: resources.GetData,
SetData: resources.SetData,
Upstream: upstream,
}, nil
})
return runtime.Connection.(*connection.AristaConnection), err
}

func (s *Service) detect(asset *inventory.Asset, conn *connection.AristaConnection) error {
Expand Down Expand Up @@ -194,90 +185,3 @@ func (s *Service) detect(asset *inventory.Asset, conn *connection.AristaConnecti
asset.PlatformIds = []string{id}
return nil
}

func (s *Service) GetData(req *plugin.DataReq) (*plugin.DataRes, error) {
runtime, ok := s.runtimes[req.Connection]
if !ok {
return nil, errors.New("connection " + strconv.FormatUint(uint64(req.Connection), 10) + " not found")
}

args := plugin.PrimitiveArgsToRawDataArgs(req.Args, runtime)

if req.ResourceId == "" && req.Field == "" {
res, err := resources.NewResource(runtime, req.Resource, args)
if err != nil {
return nil, err
}

rd := llx.ResourceData(res, res.MqlName()).Result()
return &plugin.DataRes{
Data: rd.Data,
}, nil
}

resource, ok := runtime.Resources.Get(req.Resource + "\x00" + req.ResourceId)
if !ok {
// Note: Since resources are internally always created, there are only very
// few cases where we arrive here:
// 1. The caller is wrong. Possibly a mixup with IDs
// 2. The resource was loaded from a recording, but the field is not
// in the recording. Thus the resource was never created inside the
// plugin. We will attempt to create the resource and see if the field
// can be computed.
if !runtime.HasRecording {
return nil, errors.New("resource '" + req.Resource + "' (id: " + req.ResourceId + ") doesn't exist")
}

args, err := runtime.ResourceFromRecording(req.Resource, req.ResourceId)
if err != nil {
return nil, errors.New("attempted to load resource '" + req.Resource + "' (id: " + req.ResourceId + ") from recording failed: " + err.Error())
}

resource, err = resources.CreateResource(runtime, req.Resource, args)
if err != nil {
return nil, errors.New("attempted to create resource '" + req.Resource + "' (id: " + req.ResourceId + ") from recording failed: " + err.Error())
}
}

return resources.GetData(resource, req.Field, args), nil
}

func (s *Service) StoreData(req *plugin.StoreReq) (*plugin.StoreRes, error) {
runtime, ok := s.runtimes[req.Connection]
if !ok {
return nil, errors.New("connection " + strconv.FormatUint(uint64(req.Connection), 10) + " not found")
}

var errs []string
for i := range req.Resources {
info := req.Resources[i]

args, err := plugin.ProtoArgsToRawDataArgs(info.Fields)
if err != nil {
errs = append(errs, "failed to add cached "+info.Name+" (id: "+info.Id+"), failed to parse arguments")
continue
}

resource, ok := runtime.Resources.Get(info.Name + "\x00" + info.Id)
if !ok {
resource, err = resources.CreateResource(runtime, info.Name, args)
if err != nil {
errs = append(errs, "failed to add cached "+info.Name+" (id: "+info.Id+"), creation failed: "+err.Error())
continue
}

runtime.Resources.Set(info.Name+"\x00"+info.Id, resource)
}

for k, v := range args {
if err := resources.SetData(resource, k, v); err != nil {
errs = append(errs, "failed to add cached "+info.Name+" (id: "+info.Id+"), field error: "+err.Error())
}
}
}

if len(errs) != 0 {
return nil, errors.New(strings.Join(errs, ", "))
}
return &plugin.StoreRes{}, nil
}
7 changes: 0 additions & 7 deletions providers/k8s/provider/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -95,13 +95,6 @@ func (s *Service) ParseCLI(req *plugin.ParseCLIReq) (*plugin.ParseCLIRes, error)
return &res, nil
}

// Shutdown is automatically called when the shell closes.
// It is not necessary to implement this method.
// If you want to do some cleanup, you can do it here.
func (s *Service) Shutdown(req *plugin.ShutdownReq) (*plugin.ShutdownRes, error) {
return &plugin.ShutdownRes{}, nil
}

func (s *Service) MockConnect(req *plugin.ConnectReq, callback plugin.ProviderCallback) (*plugin.ConnectRes, error) {
return nil, errors.New("mock connect not yet implemented")
}
Expand Down

0 comments on commit d5a37cc

Please sign in to comment.