gokrm

module
v0.0.0-...-c332a7c Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 13, 2021 License: MIT

README

gokrm : An Object-Kubernetes Resource-Mapper for Go

gokrm (pronounced go-kay-rem) is a Go library that provides tooling to build declarative, simple reconcilers for Kubernetes resources, using a single source of truth that can be a custom resource or a configuration value, and reflection, to dynamically introspect the soure type and generate the mapped resources.

Example

The following is an example of a SourceType mapped into a Deployment and Service:

// Type declaration
type sourceType struct {
  metav1.ObjectMeta

  Image     string `gokrmTarget:"Deployment" gokrmTargetField:"Spec.Template.Spec.Containers[0].Image"`
  Replicas  *int32 `gokrmTarget:"Deployment" gokrmTargetField:"Spec.Replicas"`
  ClusterIP string `gokrmTarget:"Service" gokrmTargetField:"Spec.ClusterIP"`
  Port      int32  `gokrmTarget:"Service" gokrmTargetField:"Spec.Ports[0].Port"`
}

Note the gokrmTarget and gokrmTargetField tags. They indicate where to map these fields to.

An example value

source := SourceType{
  ObjectMeta: metav1.ObjectMeta{
    Name:      "test",
    Namespace: "default",
  },
  Replicas:  intptr(10),
  ClusterIP: "1.1.1.1",
  Image:     "image:latest",
  Port:      8080,
}

Will result in the following resources being generated:

apiVersion: apps/v1
kind: Deployment
metadata:
  creationTimestamp: null
  name: test
  namespace: default
spec:
  replicas: 10
  selector: null
  strategy: {}
  template:
    metadata:
      creationTimestamp: null
    spec:
      containers:
      - image: image:latest
        name: ""
        resources: {}
status: {}
---
apiVersion: v1
kind: Service
metadata:
  creationTimestamp: null
  name: test
  namespace: default
spec:
  clusterIP: 1.1.1.1
  ports:
  - port: 8080
    targetPort: 0
status:
  loadBalancer: {}

Usage

Directories

Path Synopsis
pkg

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL