summaryrefslogtreecommitdiff
path: root/change.go
diff options
context:
space:
mode:
Diffstat (limited to 'change.go')
-rw-r--r--change.go131
1 files changed, 131 insertions, 0 deletions
diff --git a/change.go b/change.go
new file mode 100644
index 0000000..840b6d5
--- /dev/null
+++ b/change.go
@@ -0,0 +1,131 @@
+package virtbuf
+
+import (
+ // "reflect"
+
+ "errors"
+ "fmt"
+ "time"
+
+ "google.golang.org/protobuf/types/known/anypb"
+ "google.golang.org/protobuf/types/known/timestamppb"
+ "google.golang.org/protobuf/types/known/wrapperspb"
+
+ "go.wit.com/log"
+)
+
+func convertToAnypb(x any) *anypb.Any {
+ switch v := x.(type) {
+ case int64:
+ var a *anypb.Any
+ a, _ = anypb.New(wrapperspb.Int64(x.(int64)))
+ return a
+ case string:
+ var a *anypb.Any
+ a, _ = anypb.New(wrapperspb.String(x.(string)))
+ return a
+ case int:
+ var a *anypb.Any
+ a, _ = anypb.New(wrapperspb.Int64(x.(int64)))
+ return a
+ case bool:
+ var a *anypb.Any
+ a, _ = anypb.New(wrapperspb.Bool(x.(bool)))
+ return a
+ default:
+ log.Error(errors.New("convertToAnypb() unknown type"), "v =", v, "x =", x)
+ return nil
+ }
+ return nil
+}
+
+func convertToString(x any) string {
+ switch v := x.(type) {
+ case int64:
+ return fmt.Sprintf("%d", x.(int64))
+ case string:
+ return x.(string)
+ case int:
+ return fmt.Sprintf("%d", x.(int))
+ case uint:
+ return fmt.Sprintf("%d", x.(uint))
+ case bool:
+ if x.(bool) {
+ return "true"
+ }
+ return "false"
+ default:
+ log.Info("convertToSTring() unknown type", v)
+ log.Error(errors.New("convertToSTring() unknown type"), "v =", v, "x =", x)
+ return ""
+ }
+ return ""
+}
+
+// Wrapping the int into a protobuf message
+func (d *Droplet) NewChangeEvent(fname string, origval any, newval any) *Event {
+ var e *Event
+ e = new(Event)
+
+ e.Droplet = d.Hostname
+ e.OrigVal = convertToString(origval)
+ e.NewVal = convertToString(newval)
+ e.FieldName = fname
+
+ now := time.Now()
+ e.Start = timestamppb.New(now)
+
+ // this also works, but it's a bit overkill
+ // e.NewAny = convertToAnypb(newval)
+
+ // me.events.Events = append(me.events.Events, e)
+ // stuff := me.events.FormatJSON()
+ // log.Info("events:", stuff)
+ return e
+}
+
+// work in progress
+func NewAddEvent(a any, fname string, newval any) *Event {
+ var e *Event
+ e = new(Event)
+
+ switch v := a.(type) {
+ case *Droplet:
+ var d *Droplet
+ d = a.(*Droplet)
+ e.Droplet = d.Hostname
+ case *Cluster:
+ e.Droplet = "Cluster"
+ case nil:
+ e.Droplet = "<nil>"
+ default:
+ log.Info("newAddEvent() unknown type", v)
+ e.Droplet = "on something somewhere"
+ }
+
+ e.NewVal = convertToString(newval)
+ e.FieldName = fname
+
+ now := time.Now()
+ e.Start = timestamppb.New(now)
+
+ return e
+}
+
+// update the droplet memory
+func (d *Droplet) SetMemory(b int64) *Event {
+ oldm := HumanFormatBytes(d.Memory)
+ newm := HumanFormatBytes(b)
+ if d.Memory == b {
+ // log.Info("droplet", d.Hostname, "memory unchanged", oldm, "to", newm)
+ return nil
+ }
+ log.Info("droplet", d.Hostname, "memory change from", oldm, "to", newm)
+
+ return d.NewChangeEvent("Droplet.Memory", d.Memory, b)
+}
+
+// update the droplet memory
+func (d *Droplet) SetCpus(b int64) {
+ log.Info("Set the number of cpus for the droplet", b)
+}