package dao import ( "context" "errors" "fmt" "github.com/rs/zerolog/log" v1 "k8s.io/api/core/v1" "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured" "k8s.io/apimachinery/pkg/labels" "k8s.io/apimachinery/pkg/runtime" ) type Service struct { Generic } var _ Accessor = &Service{} var _ Loggable = &Service{} // Logs tail logs for all pods represented by this Service. func (s *Service) TailLogs(ctx context.Context, c chan<- string, opts LogOptions) error { log.Debug().Msgf("Tailing Service %q", opts.Path) o, err := s.Get(string(s.gvr), opts.Path, labels.Everything()) if err != nil { return err } var svc v1.Service err = runtime.DefaultUnstructuredConverter.FromUnstructured(o.(*unstructured.Unstructured).Object, &svc) if err != nil { return errors.New("expecting Service resource") } if svc.Spec.Selector == nil || len(svc.Spec.Selector) == 0 { return fmt.Errorf("no valid selector found on Service %s", opts.Path) } return podLogs(ctx, c, svc.Spec.Selector, opts) }