1
0
Fork 0
mirror of https://github.com/postmannen/ctrl.git synced 2025-01-07 04:49:17 +00:00

disabled the allow receivers functionality

This commit is contained in:
postmannen 2021-09-08 04:29:11 +02:00
parent cb0f27d48f
commit 8a49afa9ad
2 changed files with 52 additions and 38 deletions

View file

@ -650,6 +650,8 @@ For CliCommand message to a node named "ship1" of type Command and it wants an A
## TODO ## TODO
### Make the actual output errors of CMD's executed be put in the error message
### Fix bug when new flags are added to an existing config and the value is always set to 0 and not it's default ### Fix bug when new flags are added to an existing config and the value is always set to 0 and not it's default
Add a set flag to the configuration so we can know if a value have been set or is a default value. We can then loop over the whole struct to check if new fields have been added and give it the appropriate default value. Add a set flag to the configuration so we can know if a value have been set or is a default value. We can then loop over the whole struct to check if new fields have been added and give it the appropriate default value.

View file

@ -337,28 +337,34 @@ func (p process) subscriberHandler(natsConn *nats.Conn, thisNode string, msg *na
sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er) sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
} }
out := []byte("not allowed from " + message.FromNode) var out []byte
//var err error
// Check if we are allowed to receive from that host // NB:
_, arOK1 := p.allowedReceivers[message.FromNode] // The commented out code below is for the allowed recievers functionality
_, arOK2 := p.allowedReceivers["*"] // for the REQ type specified at startup. Keeping the code for now, but it
// is probably redundant since the same information can be specified in
// the broker config
//
// // out := []byte("not allowed from " + message.FromNode)
// // Check if we are allowed to receive from that host
// _, arOK1 := p.allowedReceivers[message.FromNode]
// _, arOK2 := p.allowedReceivers["*"]
//
// if arOK1 || arOK2 {
// // Start the method handler for that specific subject type.
// // The handler started here is what actually doing the action
// // that executed a CLI command, or writes to a log file on
// // the node who received the message.
out, err = mh.handler(p, message, thisNode)
if arOK1 || arOK2 { if err != nil {
// Start the method handler for that specific subject type. er := fmt.Errorf("error: subscriberHandler: handler method failed: %v", err)
// The handler started here is what actually doing the action
// that executed a CLI command, or writes to a log file on
// the node who received the message.
out, err = mh.handler(p, message, thisNode)
if err != nil {
er := fmt.Errorf("error: subscriberHandler: handler method failed: %v", err)
sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
}
} else {
er := fmt.Errorf("info: we don't allow receiving from: %v, %v", message.FromNode, p.subject)
sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er) sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
} }
// } else {
// er := fmt.Errorf("info: we don't allow receiving from: %v, %v", message.FromNode, p.subject)
// sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
// }
// Send a confirmation message back to the publisher // Send a confirmation message back to the publisher
natsConn.Publish(msg.Reply, out) natsConn.Publish(msg.Reply, out)
@ -371,29 +377,35 @@ func (p process) subscriberHandler(natsConn *nats.Conn, thisNode string, msg *na
sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er) sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
} }
// Check if we are allowed to receive from that host // NB:
_, arOK1 := p.allowedReceivers[message.FromNode] // The commented out code below is for the allowed recievers functionality
_, arOK2 := p.allowedReceivers["*"] // for the REQ type specified at startup. Keeping the code for now, but it
// is probably redundant since the same information can be specified in
// the broker config
//
// // Check if we are allowed to receive from that host
// _, arOK1 := p.allowedReceivers[message.FromNode]
// _, arOK2 := p.allowedReceivers["*"]
//
// if arOK1 || arOK2 {
//
// // Start the method handler for that specific subject type.
// // The handler started here is what actually doing the action
// // that executed a CLI command, or writes to a log file on
// // the node who received the message.
// //
// // since we don't send a reply for a NACK message, we don't care about the
// // out return when calling mf.handler
_, err := mf.handler(p, message, thisNode)
if arOK1 || arOK2 { if err != nil {
er := fmt.Errorf("error: subscriberHandler: handler method failed: %v", err)
// Start the method handler for that specific subject type.
// The handler started here is what actually doing the action
// that executed a CLI command, or writes to a log file on
// the node who received the message.
//
// since we don't send a reply for a NACK message, we don't care about the
// out return when calling mf.handler
_, err := mf.handler(p, message, thisNode)
if err != nil {
er := fmt.Errorf("error: subscriberHandler: handler method failed: %v", err)
sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
}
} else {
er := fmt.Errorf("info: we don't allow receiving from: %v, %v", message.FromNode, p.subject)
sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er) sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
} }
// } else {
// er := fmt.Errorf("info: we don't allow receiving from: %v, %v", message.FromNode, p.subject)
// sendErrorLogMessage(p.configuration, p.processes.metrics, p.toRingbufferCh, Node(thisNode), er)
// }
default: default:
er := fmt.Errorf("info: did not find that specific type of command: %#v", p.subject.CommandOrEvent) er := fmt.Errorf("info: did not find that specific type of command: %#v", p.subject.CommandOrEvent)