mirror of
https://github.com/postmannen/ctrl.git
synced 2025-01-05 20:09:16 +00:00
testing with message types
This commit is contained in:
parent
98d5c4b3da
commit
7d5b2bccb9
5 changed files with 44 additions and 30 deletions
13
cmd/main.go
13
cmd/main.go
|
@ -3,8 +3,11 @@ package main
|
|||
import (
|
||||
"flag"
|
||||
"log"
|
||||
"net/http"
|
||||
"os"
|
||||
|
||||
_ "net/http/pprof"
|
||||
|
||||
"github.com/RaaLabs/steward"
|
||||
)
|
||||
|
||||
|
@ -13,8 +16,18 @@ func main() {
|
|||
brokerAddress := flag.String("brokerAddress", "0", "the address of the message broker")
|
||||
modePublisher := flag.Bool("modePublisher", false, "set to true if it should be able to publish")
|
||||
modeSubscriber := flag.Bool("modeSubscriber", false, "set to true if it should be able to subscribe")
|
||||
profilingPort := flag.String("profilingPort", "", "The number of the profiling port")
|
||||
flag.Parse()
|
||||
|
||||
if *profilingPort != "" {
|
||||
// TODO REMOVE: Added for profiling
|
||||
|
||||
go func() {
|
||||
http.ListenAndServe("localhost:"+*profilingPort, nil)
|
||||
}()
|
||||
|
||||
}
|
||||
|
||||
s, err := steward.NewServer(*brokerAddress, *nodeName)
|
||||
if err != nil {
|
||||
log.Printf("error: failed to connect to broker: %v\n", err)
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
},
|
||||
"message":
|
||||
{
|
||||
"data": ["bash","-c","uname -a"],
|
||||
"data": ["bash","-c","ls -l"],
|
||||
"messageType":"Command"
|
||||
}
|
||||
}
|
||||
|
|
|
@ -18,26 +18,27 @@ func getMessagesFromFile(directoryToCheck string, fileName string, fileContentCh
|
|||
fileUpdated := make(chan bool)
|
||||
go fileWatcherStart(directoryToCheck, fileUpdated)
|
||||
|
||||
for {
|
||||
select {
|
||||
case <-fileUpdated:
|
||||
//load file, read it's content
|
||||
b, err := readTruncateMessageFile(fileName)
|
||||
if err != nil {
|
||||
log.Printf("error: reading file: %v", err)
|
||||
}
|
||||
for range fileUpdated {
|
||||
|
||||
// unmarshal the JSON into a struct
|
||||
js, err := jsonFromFileData(b)
|
||||
if err != nil {
|
||||
log.Printf("%v\n", err)
|
||||
}
|
||||
|
||||
// Send the data back to be consumed
|
||||
fileContentCh <- js
|
||||
//load file, read it's content
|
||||
b, err := readTruncateMessageFile(fileName)
|
||||
if err != nil {
|
||||
log.Printf("error: reading file: %v", err)
|
||||
}
|
||||
}
|
||||
|
||||
// unmarshal the JSON into a struct
|
||||
js, err := jsonFromFileData(b)
|
||||
if err != nil {
|
||||
log.Printf("%v\n", err)
|
||||
}
|
||||
|
||||
for i, _ := range js {
|
||||
fmt.Printf("messageType type: %T, messagetype contains: %#v\n", js[i].Subject.MessageType, js[i].Subject.MessageType)
|
||||
}
|
||||
|
||||
// Send the data back to be consumed
|
||||
fileContentCh <- js
|
||||
}
|
||||
}
|
||||
|
||||
type jsonFromFile struct {
|
||||
|
|
14
publisher.go
14
publisher.go
|
@ -76,6 +76,11 @@ func NewServer(brokerAddress string, nodeName string) (*server, error) {
|
|||
newMessagesCh: make(chan []jsonFromFile),
|
||||
}
|
||||
|
||||
return s, nil
|
||||
|
||||
}
|
||||
|
||||
func (s *server) PublisherStart() {
|
||||
// Start the error handler
|
||||
// TODO: For now it will just print the error messages to the
|
||||
// console.
|
||||
|
@ -94,11 +99,6 @@ func NewServer(brokerAddress string, nodeName string) (*server, error) {
|
|||
}
|
||||
}()
|
||||
|
||||
return s, nil
|
||||
|
||||
}
|
||||
|
||||
func (s *server) PublisherStart() {
|
||||
// start the checking of files for input messages
|
||||
go getMessagesFromFile("./", "inmsg.txt", s.newMessagesCh)
|
||||
|
||||
|
@ -182,7 +182,7 @@ type Subject struct {
|
|||
// node, the name of the node
|
||||
Node string `json:"node" yaml:"node"`
|
||||
// messageType, command/event
|
||||
MessageType string `json:"messageType" yaml:"messageType"`
|
||||
MessageType MessageType `json:"messageType" yaml:"messageType"`
|
||||
// method, what is this message doing, etc. shellcommand, syslog, etc.
|
||||
Method string `json:"method" yaml:"method"`
|
||||
// domain is used to differentiate services. Like there can be more
|
||||
|
@ -197,7 +197,7 @@ type Subject struct {
|
|||
// newSubject will return a new variable of the type subject, and insert
|
||||
// all the values given as arguments. It will also create the channel
|
||||
// to receive new messages on the specific subject.
|
||||
func newSubject(node string, messageType string, method string, domain string) Subject {
|
||||
func newSubject(node string, messageType MessageType, method string, domain string) Subject {
|
||||
return Subject{
|
||||
Node: node,
|
||||
MessageType: messageType,
|
||||
|
|
|
@ -25,14 +25,14 @@ func (s *server) RunSubscriber() {
|
|||
subject := fmt.Sprintf("%s.%s.%s.%s", s.nodeName, "command", "shellcommand", "shell")
|
||||
_, err := s.natsConn.Subscribe(subject, listenForMessage(s.natsConn, reqMsgCh, s.nodeName))
|
||||
if err != nil {
|
||||
fmt.Printf("error: Subscribe failed: %v\n", err)
|
||||
log.Printf("error: Subscribe failed: %v\n", err)
|
||||
}
|
||||
|
||||
// Do some further processing of the actual data we received in the
|
||||
// subscriber callback function.
|
||||
for {
|
||||
msg := <-reqMsgCh
|
||||
fmt.Printf("%v\n", msg)
|
||||
//fmt.Printf("%v\n", msg)
|
||||
switch msg.MessageType {
|
||||
case "Command":
|
||||
// Since the command to execute is at the first position in the
|
||||
|
@ -44,7 +44,7 @@ func (s *server) RunSubscriber() {
|
|||
cmd.Stdout = os.Stdout
|
||||
err := cmd.Start()
|
||||
if err != nil {
|
||||
fmt.Printf("error: execution of command failed: %v\n", err)
|
||||
log.Printf("error: execution of command failed: %v\n", err)
|
||||
}
|
||||
case "Event":
|
||||
// Since the command to execute is at the first position in the
|
||||
|
@ -56,7 +56,7 @@ func (s *server) RunSubscriber() {
|
|||
cmd.Stdout = os.Stdout
|
||||
err := cmd.Start()
|
||||
if err != nil {
|
||||
fmt.Printf("error: execution of command failed: %v\n", err)
|
||||
log.Printf("error: execution of command failed: %v\n", err)
|
||||
}
|
||||
default:
|
||||
log.Printf("info: did not find that specific type of command: %#v\n", msg.MessageType)
|
||||
|
@ -78,7 +78,7 @@ func listenForMessage(natsConn *nats.Conn, reqMsgCh chan Message, node string) f
|
|||
gobDec := gob.NewDecoder(buf)
|
||||
err := gobDec.Decode(&message)
|
||||
if err != nil {
|
||||
fmt.Printf("error: gob decoding failed: %v\n", err)
|
||||
log.Printf("error: gob decoding failed: %v\n", err)
|
||||
}
|
||||
|
||||
// Put the data recived on the channel for further processing
|
||||
|
|
Loading…
Reference in a new issue