| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 1 | package main |
| 2 | |
| 3 | import ( |
| 4 | "context" |
| 5 | "flag" |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 6 | "fmt" |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 7 | "io/ioutil" |
| 8 | "path" |
| 9 | |
| 10 | v1 "k8s.io/api/core/v1" |
| 11 | metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" |
| 12 | "k8s.io/client-go/kubernetes" |
| 13 | "k8s.io/client-go/rest" |
| giolekva | 95340e8 | 2021-11-08 21:36:55 +0400 | [diff] [blame] | 14 | |
| 15 | "github.com/miracl/conflate" |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 16 | ) |
| 17 | |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 18 | var baseFile = flag.String("base", "", "Path to the homeserver.yaml config file.") |
| 19 | var mergeWith = flag.String("merge-with", "", "Name of the file from config to merge.") |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 20 | var namespace = flag.String("namespace", "", "Namespace name.") |
| 21 | var configMapName = flag.String("config-map-name", "", "Name of the ConfigMap to create.") |
| 22 | |
| 23 | func createClient() *kubernetes.Clientset { |
| 24 | config, err := rest.InClusterConfig() |
| 25 | if err != nil { |
| 26 | panic(err.Error()) |
| 27 | } |
| 28 | cs, err := kubernetes.NewForConfig(config) |
| 29 | if err != nil { |
| 30 | panic(err.Error()) |
| 31 | } |
| 32 | return cs |
| 33 | } |
| 34 | |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 35 | func newConig(data []byte) *v1.ConfigMap { |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 36 | return &v1.ConfigMap{ |
| 37 | TypeMeta: metav1.TypeMeta{ |
| 38 | Kind: "ConfigMap", |
| 39 | APIVersion: "v1", |
| 40 | }, |
| 41 | ObjectMeta: metav1.ObjectMeta{ |
| 42 | Name: *configMapName, |
| 43 | }, |
| 44 | Data: map[string]string{ |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 45 | path.Base(*baseFile): string(data), |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 46 | }, |
| 47 | } |
| 48 | } |
| 49 | |
| 50 | func main() { |
| 51 | flag.Parse() |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 52 | client := createClient().CoreV1().ConfigMaps(*namespace) |
| giolekva | 95340e8 | 2021-11-08 21:36:55 +0400 | [diff] [blame] | 53 | conf := conflate.New() |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 54 | generated, err := ioutil.ReadFile(*baseFile) |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 55 | if err != nil { |
| 56 | panic(err) |
| 57 | } |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 58 | fmt.Printf("--- BASE:\n%s\n", string(generated)) |
| giolekva | 95340e8 | 2021-11-08 21:36:55 +0400 | [diff] [blame] | 59 | if err := conf.AddData(generated); err != nil { |
| 60 | panic(err) |
| 61 | } |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 62 | mergeWith, err := ioutil.ReadFile(*mergeWith) |
| giolekva | 95340e8 | 2021-11-08 21:36:55 +0400 | [diff] [blame] | 63 | if err != nil { |
| 64 | panic(err) |
| 65 | } |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 66 | fmt.Printf("--- MERGE WITH:\n%s\n", string(mergeWith)) |
| 67 | if err := conf.AddData(mergeWith); err != nil { |
| giolekva | 95340e8 | 2021-11-08 21:36:55 +0400 | [diff] [blame] | 68 | panic(err) |
| 69 | } |
| 70 | merged, err := conf.MarshalYAML() |
| 71 | if err != nil { |
| 72 | panic(err) |
| 73 | } |
| Giorgi Lekveishvili | 6d7dcb8 | 2023-12-20 14:44:42 +0400 | [diff] [blame^] | 74 | fmt.Printf("--- MERGED:\n%s\n", string(merged)) |
| 75 | config := newConig(merged) |
| giolekva | 95340e8 | 2021-11-08 21:36:55 +0400 | [diff] [blame] | 76 | if _, err := client.Create(context.TODO(), config, metav1.CreateOptions{}); err != nil { |
| 77 | panic(err) |
| 78 | } |
| giolekva | 56c1569 | 2021-10-20 11:44:54 +0400 | [diff] [blame] | 79 | } |