kubectl-persistent-logger/main.go

87 lines
1.6 KiB
Go
Raw Normal View History

2022-05-29 19:04:02 +00:00
package main
import (
"context"
"flag"
2022-06-09 18:56:44 +00:00
"fmt"
2022-05-29 19:04:02 +00:00
"log"
2022-05-30 10:10:58 +00:00
"os"
2022-05-29 19:04:02 +00:00
"git.netflux.io/rob/kubectl-persistent-logger/logs"
"k8s.io/client-go/dynamic"
2022-05-29 19:04:02 +00:00
"k8s.io/client-go/kubernetes"
clientconfig "sigs.k8s.io/controller-runtime/pkg/client/config"
2022-05-29 19:04:02 +00:00
)
2022-06-09 18:56:44 +00:00
var (
gitChanges = "unknown"
gitSHA1 = "unknown"
buildTime = "unknown"
)
2022-05-29 19:04:02 +00:00
func main() {
2022-05-31 04:11:44 +00:00
var (
container string
strictExist bool
2022-06-09 18:56:44 +00:00
version bool
2022-05-31 04:11:44 +00:00
)
flag.StringVar(&container, "container", "", "name of a specific container")
flag.BoolVar(&strictExist, "strict", false, "require deployment to exist on launch")
2022-06-09 18:56:44 +00:00
flag.BoolVar(&version, "version", false, "print version and exit")
2022-05-29 19:04:02 +00:00
flag.Parse()
2022-06-09 18:56:44 +00:00
if version {
fmt.Fprintf(os.Stderr, "kubectl-persistent-logger, gitSHA1 = %s, gitChanges = %s, buildTime = %v\n", gitSHA1, gitChanges, buildTime)
os.Exit(0)
}
var params logs.WatcherParams
switch len(flag.Args()) {
case 1:
// TODO: handle type/name style
flag.Usage()
os.Exit(1)
case 2:
kind, err := logs.ParseType(flag.Arg(0))
if err != nil {
log.Fatal(err)
}
params = logs.WatcherParams{
Type: kind,
Name: flag.Arg(1),
Namespace: "default",
}
default:
flag.Usage()
os.Exit(1)
}
cfg, err := clientconfig.GetConfig()
2022-05-29 19:04:02 +00:00
if err != nil {
log.Fatal(err)
}
clientset, err := kubernetes.NewForConfig(cfg)
2022-05-29 19:04:02 +00:00
if err != nil {
log.Fatal(err)
}
dynamicclient, err := dynamic.NewForConfig(cfg)
if err != nil {
log.Fatal(err)
}
2022-05-29 19:04:02 +00:00
ctx := context.Background()
2022-05-31 04:11:44 +00:00
watcher := logs.NewWatcher(
params,
logs.KubernetesClient{Typed: clientset, Untyped: dynamicclient},
2022-06-01 17:19:55 +00:00
logs.NewPodWatcher,
2022-05-31 04:11:44 +00:00
os.Stdout,
)
2022-05-29 19:04:02 +00:00
if err := watcher.Watch(ctx); err != nil {
log.Fatal(err)
}
}