2020-01-16 15:56:57 +01:00
|
|
|
package broker
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2020-01-22 15:01:07 +01:00
|
|
|
"encoding/json"
|
2020-01-17 13:51:11 +01:00
|
|
|
"fmt"
|
2020-01-16 15:56:57 +01:00
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/segmentio/kafka-go"
|
2020-01-22 15:01:07 +01:00
|
|
|
"github.com/sirupsen/logrus"
|
2020-01-17 13:51:11 +01:00
|
|
|
"gitlab.dcso.lolcat/LABS/styx/models"
|
2020-01-16 15:56:57 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func SetUpKafkaConnecter() (*kafka.Conn, error) {
|
|
|
|
topic := "styx"
|
|
|
|
partition := 0
|
|
|
|
conn, err := kafka.DialLeader(context.Background(), "tcp", "localhost:9092", topic, partition)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
conn.SetDeadline(time.Now().Add(10 * time.Second))
|
|
|
|
|
|
|
|
return conn, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func ProduceEvent(conn *kafka.Conn, message string) error {
|
|
|
|
// SetWriteDeadline sets the deadline for future Write calls and any
|
|
|
|
// currently-blocked Write call. Even if write times out, it may return n > 0,
|
|
|
|
// indicating that some of the data was successfully written. A zero value for t
|
|
|
|
// means Write will not time out.
|
|
|
|
conn.SetWriteDeadline(time.Now().Add(10 * time.Second))
|
|
|
|
|
|
|
|
_, err := conn.WriteMessages(
|
|
|
|
kafka.Message{Value: []byte("one!")},
|
|
|
|
kafka.Message{Value: []byte("two!")},
|
|
|
|
kafka.Message{Value: []byte("three!")},
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-01-17 13:51:11 +01:00
|
|
|
func SendEventToKafka(conn *kafka.Conn, node models.Node) error {
|
|
|
|
conn.SetWriteDeadline(time.Now().Add(10 * time.Second))
|
2020-01-22 15:01:07 +01:00
|
|
|
packaged, _ := json.Marshal(node)
|
|
|
|
_, err := conn.WriteMessages(kafka.Message{Value: packaged})
|
2020-01-17 13:51:11 +01:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2020-01-16 15:56:57 +01:00
|
|
|
|
2020-01-17 13:51:11 +01:00
|
|
|
return nil
|
2020-01-16 15:56:57 +01:00
|
|
|
}
|
2020-01-21 16:50:50 +01:00
|
|
|
|
|
|
|
func ReadEventFromKafka() {
|
|
|
|
r := kafka.NewReader(kafka.ReaderConfig{
|
|
|
|
Brokers: []string{"localhost:9092"},
|
|
|
|
Topic: "styx",
|
|
|
|
Partition: 0,
|
|
|
|
MinBytes: 10e3,
|
|
|
|
MaxBytes: 10e6,
|
|
|
|
})
|
|
|
|
r.SetOffset(42)
|
|
|
|
defer r.Close()
|
|
|
|
|
|
|
|
for {
|
|
|
|
m, err := r.ReadMessage(context.Background())
|
|
|
|
if err != nil {
|
2020-01-22 15:01:07 +01:00
|
|
|
logrus.Error("error reading message:", err)
|
2020-01-21 16:50:50 +01:00
|
|
|
}
|
|
|
|
|
2020-01-22 15:01:07 +01:00
|
|
|
var node models.Node
|
|
|
|
json.Unmarshal(m.Value, &node)
|
|
|
|
fmt.Println(node.Data.Data.LeafCert.AllDomains)
|
|
|
|
|
2020-01-21 16:50:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|