Skip to content

Commit

Permalink
migrate google-workspace 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 0988c70 commit af511c9
Showing 1 changed file with 27 additions and 126 deletions.
153 changes: 27 additions & 126 deletions providers/google-workspace/provider/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@ package provider
import (
"errors"
"os"
"strconv"
"strings"

"github.com/rs/zerolog/log"
"go.mondoo.com/cnquery/v10/llx"
Expand All @@ -22,15 +20,12 @@ import (
const ConnectionType = "google-workspace"

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 @@ -128,13 +123,6 @@ func (s *Service) ParseCLI(req *plugin.ParseCLIReq) (*plugin.ParseCLIRes, error)
return &plugin.ParseCLIRes{Asset: &asset}, 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 Expand Up @@ -171,36 +159,36 @@ func (s *Service) connect(req *plugin.ConnectReq, callback plugin.ProviderCallba

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

switch conf.Type {
default:
s.lastConnectionID++
conn, err = connection.NewGoogleWorkspaceConnection(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.NewGoogleWorkspaceConnection(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,
}
var upstream *upstream.UpstreamClient
if req.Upstream != nil && !req.Upstream.Incognito {
upstream, err = req.Upstream.InitClient()
if err != nil {
return nil, err
}
}

return conn, 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
})
if err != nil {
return nil, err
}
return runtime.Connection.(*connection.GoogleWorkspaceConnection), err
}

func (s *Service) detect(asset *inventory.Asset, conn *connection.GoogleWorkspaceConnection) error {
Expand All @@ -217,90 +205,3 @@ func (s *Service) detect(asset *inventory.Asset, conn *connection.GoogleWorkspac
asset.PlatformIds = []string{"//platformid.api.mondoo.app/runtime/googleworkspace/customer/" + conn.CustomerID()}
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
}

0 comments on commit af511c9

Please sign in to comment.