blob: 8e8ee48dd8ff2374847d2f1c76e334fcc9708ae3 [file] [log] [blame]
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +02001package main
2
3import (
4 "context"
Mateusz Zalegab2cac082022-07-14 14:55:43 +02005 "log"
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +02006
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +02007 "google.golang.org/grpc"
8
Mateusz Zalega18a67b02022-08-02 13:37:50 +02009 "source.monogon.dev/metropolis/cli/metroctl/core"
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +020010)
11
Mateusz Zalegadb75e212022-08-04 17:31:34 +020012func dialAuthenticated(ctx context.Context) *grpc.ClientConn {
Mateusz Zalega18a67b02022-08-02 13:37:50 +020013 // Collect credentials, validate command parameters, and try dialing the
14 // cluster.
Serge Bazanskicf23ebc2023-03-14 17:02:04 +010015 ocert, opkey, err := core.GetOwnerCredentials(flags.configPath)
16 if err == core.NoCredentialsError {
Mateusz Zalega18a67b02022-08-02 13:37:50 +020017 log.Fatalf("You have to take ownership of the cluster first: %v", err)
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +020018 }
Mateusz Zalegadb75e212022-08-04 17:31:34 +020019 if len(flags.clusterEndpoints) == 0 {
20 log.Fatal("Please provide at least one cluster endpoint using the --endpoint parameter.")
21 }
Mateusz Zalega18a67b02022-08-02 13:37:50 +020022 cc, err := core.DialCluster(ctx, opkey, ocert, flags.proxyAddr, flags.clusterEndpoints, rpcLogger)
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +020023 if err != nil {
Mateusz Zalega18a67b02022-08-02 13:37:50 +020024 log.Fatalf("While dialing the cluster: %v", err)
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +020025 }
Mateusz Zalega18a67b02022-08-02 13:37:50 +020026 return cc
Mateusz Zalegad5f2f7a2022-07-05 18:48:56 +020027}