Skip to content

Commit

Permalink
Add YAML serialization
Browse files Browse the repository at this point in the history
  • Loading branch information
jhoxhaa committed Jun 3, 2024
1 parent 1b6c845 commit 647028d
Show file tree
Hide file tree
Showing 17 changed files with 182 additions and 0 deletions.
10 changes: 10 additions & 0 deletions pkg/schema/v1/config_map.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,16 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/database"
kcorev1 "k8s.io/api/core/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
"strings"
)

type ConfigMap struct {
Meta
Immutable types.Bool
Yaml string
Data []Data `db:"-"`
ConfigMapsData []ConfigMapData `db:"-"`
Labels []Label `db:"-"`
Expand Down Expand Up @@ -70,6 +74,12 @@ func (c *ConfigMap) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}

scheme := kruntime.NewScheme()
_ = kcorev1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kcorev1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, configMap)
c.Yaml = string(output)
}

func (c *ConfigMap) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/cron_job.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/database"
kbatchv1 "k8s.io/api/batch/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
"strings"
)

Expand All @@ -20,6 +23,7 @@ type CronJob struct {
Active int32
LastScheduleTime types.UnixMilli
LastSuccessfulTime types.UnixMilli
Yaml string
Labels []Label `db:"-"`
CronJobLabels []CronJobLabel `db:"-"`
}
Expand Down Expand Up @@ -87,6 +91,12 @@ func (c *CronJob) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}

scheme := kruntime.NewScheme()
_ = kbatchv1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kbatchv1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, cronJob)
c.Yaml = string(output)
}

func (c *CronJob) Relations() []database.Relation {
Expand Down
9 changes: 9 additions & 0 deletions pkg/schema/v1/daemon_set.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/strcase"
kappsv1 "k8s.io/api/apps/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
"strings"
)

Expand All @@ -20,6 +23,7 @@ type DaemonSet struct {
UpdateNumberScheduled int32
NumberAvailable int32
NumberUnavailable int32
Yaml string
Conditions []DaemonSetCondition `db:"-"`
Labels []Label `db:"-"`
DaemonSetLabels []DaemonSetLabel `db:"-"`
Expand Down Expand Up @@ -81,6 +85,11 @@ func (d *DaemonSet) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}
scheme := kruntime.NewScheme()
_ = kappsv1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kappsv1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, daemonSet)
d.Yaml = string(output)
}

func (d *DaemonSet) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/deployment.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/strcase"
kappsv1 "k8s.io/api/apps/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
"strings"
)

Expand All @@ -21,6 +24,7 @@ type Deployment struct {
ReadyReplicas int32
AvailableReplicas int32
UnavailableReplicas int32
Yaml string
Conditions []DeploymentCondition `db:"-"`
Labels []Label `db:"-"`
DeploymentLabels []DeploymentLabel `db:"-"`
Expand Down Expand Up @@ -96,6 +100,12 @@ func (d *Deployment) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}

scheme := kruntime.NewScheme()
_ = kappsv1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kappsv1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, deployment)
d.Yaml = string(output)
}

func (d *Deployment) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/event.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ import (
"github.com/icinga/icinga-go-library/types"
keventsv1 "k8s.io/api/events/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
)

type Event struct {
Expand All @@ -20,6 +23,7 @@ type Event struct {
FirstSeen types.UnixMilli
LastSeen types.UnixMilli
Count int32
Yaml string
}

func NewEvent() Resource {
Expand Down Expand Up @@ -51,6 +55,12 @@ func (e *Event) Obtain(k8s kmetav1.Object) {
e.LastSeen = types.UnixMilli(event.DeprecatedLastTimestamp.Time)
}
e.Count = event.DeprecatedCount

scheme := kruntime.NewScheme()
_ = keventsv1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), keventsv1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, event)
e.Yaml = string(output)
// e.FirstSeen = types.UnixMilli(event.EventTime.Time)
// if event.Series != nil {
// e.LastSeen = types.UnixMilli(event.Series.LastObservedTime.Time)
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/ingress.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,14 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/database"
networkingv1 "k8s.io/api/networking/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
)

type Ingress struct {
Meta
Yaml string
IngressTls []IngressTls `db:"-"`
IngressBackendService []IngressBackendService `db:"-"`
IngressBackendResource []IngressBackendResource `db:"-"`
Expand Down Expand Up @@ -154,6 +158,12 @@ func (i *Ingress) Obtain(k8s kmetav1.Object) {
}

}

scheme := kruntime.NewScheme()
_ = networkingv1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), networkingv1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, ingress)
i.Yaml = string(output)
}

func (i *Ingress) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/job.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/strcase"
kbatchv1 "k8s.io/api/batch/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
"strings"
)

Expand All @@ -24,6 +27,7 @@ type Job struct {
Active int32
Succeeded int32
Failed int32
Yaml string
Conditions []JobCondition `db:"-"`
Labels []Label `db:"-"`
JobLabels []JobLabel `db:"-"`
Expand Down Expand Up @@ -134,6 +138,12 @@ func (j *Job) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}

scheme := kruntime.NewScheme()
_ = kbatchv1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kbatchv1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, job)
j.Yaml = string(output)
}

func (j *Job) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/namespace.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,16 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/database"
kcorev1 "k8s.io/api/core/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
"strings"
)

type Namespace struct {
Meta
Phase string
Yaml string
Conditions []NamespaceCondition `db:"-"`
Labels []Label `db:"-"`
NamespaceLabels []NamespaceLabel `db:"-"`
Expand Down Expand Up @@ -64,6 +68,12 @@ func (n *Namespace) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}

scheme := kruntime.NewScheme()
_ = kcorev1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kcorev1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, namespace)
n.Yaml = string(output)
}

func (n *Namespace) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/node.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@ import (
"github.com/pkg/errors"
kcorev1 "k8s.io/api/core/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
knet "k8s.io/utils/net"
"net"
"strings"
Expand All @@ -22,6 +25,7 @@ type Node struct {
MemoryCapacity int64
MemoryAllocatable int64
PodCapacity int64
Yaml string
Conditions []NodeCondition `db:"-"`
Volumes []NodeVolume `db:"-"`
Labels []Label `db:"-"`
Expand Down Expand Up @@ -123,6 +127,12 @@ func (n *Node) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}

scheme := kruntime.NewScheme()
_ = kcorev1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kcorev1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, node)
n.Yaml = string(output)
}

func (n *Node) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/persistent_volume.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/strcase"
kcorev1 "k8s.io/api/core/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
ktypes "k8s.io/apimachinery/pkg/types"
)

Expand All @@ -22,6 +25,7 @@ type PersistentVolume struct {
Phase string
Reason string
Message string
Yaml string
Claim *PersistentVolumeClaimRef `db:"-"`
}

Expand Down Expand Up @@ -68,6 +72,12 @@ func (p *PersistentVolume) Obtain(k8s kmetav1.Object) {
Uid: persistentVolume.Spec.ClaimRef.UID,
}
}

scheme := kruntime.NewScheme()
_ = kcorev1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kcorev1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, persistentVolume)
p.Yaml = string(output)
}

func (p *PersistentVolume) Relations() []database.Relation {
Expand Down
17 changes: 17 additions & 0 deletions pkg/schema/v1/pod.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/strcase"
kcorev1 "k8s.io/api/core/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
ktypes "k8s.io/apimachinery/pkg/types"
"k8s.io/client-go/kubernetes"
"strings"
Expand All @@ -30,6 +33,7 @@ type Pod struct {
Message string
Qos string
RestartPolicy string
Yaml string
Conditions []PodCondition `db:"-"`
Containers []Container `db:"-"`
Owners []PodOwner `db:"-"`
Expand All @@ -40,6 +44,13 @@ type Pod struct {
factory *PodFactory
}

type PodYaml struct {
PodId types.Binary
Kind string
ApiVersion string
YamlData string
}

type PodCondition struct {
PodUuid types.UUID
Type string
Expand Down Expand Up @@ -265,6 +276,12 @@ func (p *Pod) Obtain(k8s kmetav1.Object) {
})
}
}

scheme := kruntime.NewScheme()
_ = kcorev1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kcorev1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, pod)
p.Yaml = string(output)
}

func (p *Pod) Relations() []database.Relation {
Expand Down
10 changes: 10 additions & 0 deletions pkg/schema/v1/pvc.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ import (
"github.com/icinga/icinga-kubernetes/pkg/strcase"
kcorev1 "k8s.io/api/core/v1"
kmetav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
kruntime "k8s.io/apimachinery/pkg/runtime"
kserializer "k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
"strings"
)

Expand Down Expand Up @@ -41,6 +44,7 @@ type Pvc struct {
VolumeName string
VolumeMode sql.NullString
StorageClass sql.NullString
Yaml string
Conditions []PvcCondition `db:"-"`
Labels []Label `db:"-"`
PvcLabels []PvcLabel `db:"-"`
Expand Down Expand Up @@ -118,6 +122,12 @@ func (p *Pvc) Obtain(k8s kmetav1.Object) {
LabelUuid: labelUuid,
})
}

scheme := kruntime.NewScheme()
_ = kcorev1.AddToScheme(scheme)
codec := kserializer.NewCodecFactory(scheme).EncoderForVersion(kjson.NewYAMLSerializer(kjson.DefaultMetaFactory, scheme, scheme), kcorev1.SchemeGroupVersion)
output, _ := kruntime.Encode(codec, pvc)
p.Yaml = string(output)
}

func (p *Pvc) Relations() []database.Relation {
Expand Down
Loading

0 comments on commit 647028d

Please sign in to comment.