Skip to content
Snippets Groups Projects
telemetry.go 1.58 KiB
Newer Older
  • Learn to ignore specific revisions
  • Manuel Kieweg's avatar
    Manuel Kieweg committed
    package main
    
    import (
    	"code.fbi.h-da.de/cocsn/gosdn/forks/goarista/gnmi"
    	"code.fbi.h-da.de/cocsn/gosdn/nucleus"
    	"context"
    	"fmt"
    	gpb "github.com/openconfig/gnmi/proto/gnmi"
    	log "github.com/sirupsen/logrus"
    	"os"
    	"os/signal"
    	"syscall"
    	"time"
    )
    
    func main() {
    	log.SetLevel(log.DebugLevel)
    
    	sbi := &nucleus.AristaOC{}
    
    Manuel Kieweg's avatar
    Manuel Kieweg committed
    
    
    	device, err := nucleus.NewDevice("gnmi", sbi,
    		&nucleus.GnmiTransportOptions{
    			Addr:     "portainer.danet.fbi.h-da.de:6030",
    			Username: "admin",
    			Password: "arista",
    			SetNode:  sbi.SetNode(),
    			RespChan: make(chan *gpb.SubscribeResponse),
    			Encoding: gpb.Encoding_JSON_IETF,
    		})
    	if err != nil {
    		log.Debug(err)
    
    	pnd, err := nucleus.NewPND("openconfig", "a simple openconfig PND", sbi)
    
    	if err != nil {
    		log.Fatal(err)
    	}
    
    	if err := pnd.AddDevice(device); err != nil {
    
    Manuel Kieweg's avatar
    Manuel Kieweg committed
    		log.Fatal(err)
    	}
    
    	paths := []string{"/interfaces/interface/name"}
    
    	opts := &gnmi.SubscribeOptions{
    		UpdatesOnly:       false,
    		Prefix:            "",
    		Mode:              "stream",
    		StreamMode:        "sample",
    		SampleInterval:    uint64(10 * time.Second.Nanoseconds()),
    		SuppressRedundant: false,
    		HeartbeatInterval: uint64(time.Second.Nanoseconds()),
    		Paths:             gnmi.SplitPaths(paths),
    		Origin:            "",
    
    		Target:            "portainer.danet.fbi.h-da.de:6030",
    
    Manuel Kieweg's avatar
    Manuel Kieweg committed
    	}
    	done := make(chan os.Signal, 1)
    	signal.Notify(done, syscall.SIGILL, syscall.SIGTERM)
    
    Manuel Kieweg's avatar
    Manuel Kieweg committed
    	ctx := context.WithValue(context.Background(), "opts", opts)
    
    Manuel Kieweg's avatar
    Manuel Kieweg committed
    	go func() {
    
    		if err := device.Transport.Subscribe(ctx); err != nil {
    
    Manuel Kieweg's avatar
    Manuel Kieweg committed
    			log.Fatal(err)
    		}
    	}()
    	fmt.Println("awaiting signal")
    	<-done
    	fmt.Println("exiting")