1
0
Fork 0
mirror of https://github.com/postmannen/ctrl.git synced 2025-01-18 21:59:30 +00:00
ctrl/message_and_subject.go

148 lines
6.1 KiB
Go
Raw Normal View History

package ctrl
import (
"fmt"
"log"
"os"
)
// --- Message
type Message struct {
2021-12-29 08:29:11 +01:00
_ struct{} `cbor:",toarray"`
2021-08-25 16:17:33 +02:00
// The node to send the message to.
2021-06-29 08:21:42 +02:00
ToNode Node `json:"toNode" yaml:"toNode"`
2021-09-09 09:54:33 +02:00
// ToNodes to specify several hosts to send message to in the
// form of an slice/array.
2022-06-22 14:32:58 +02:00
// The ToNodes field is only a concept that exists when messages
// are injected f.ex. on a socket, and there they are directly
//converted into separate node messages for each node, and from
// there the ToNodes field is not used any more within the system.
// With other words, a message that exists within ctrl is always
2022-06-22 14:32:58 +02:00
// for just for a single node.
2021-08-25 16:17:33 +02:00
ToNodes []Node `json:"toNodes,omitempty" yaml:"toNodes,omitempty"`
// JetstreamToNode, the topic used to prefix the stream name with
// with the format NODES.<JetstreamToNode> .
JetstreamToNode Node `json:"jetstreamToNode" yaml:"jetstreamToNode"`
// The Unique ID of the message
ID int `json:"id" yaml:"id"`
2021-09-09 09:54:33 +02:00
// The actual data in the message. This is typically where we
// specify the cli commands to execute on a node, and this is
// also the field where we put the returned data in a reply
// message.
Data []byte `json:"data" yaml:"data"`
2021-09-09 09:54:33 +02:00
// Method, what request type to use, like REQCliCommand, REQHttpGet..
2021-04-13 13:50:00 +02:00
Method Method `json:"method" yaml:"method"`
// Additional arguments that might be needed when executing the
// method. Can be f.ex. an ip address if it is a tcp sender, or the
// shell command to execute in a cli session.
MethodArgs []string `json:"methodArgs" yaml:"methodArgs"`
2022-01-31 10:06:14 +01:00
// ArgSignature is the ed25519 signature of the methodArgs.
ArgSignature []byte `json:"argSignature" yaml:"argSignature"`
2021-04-13 13:50:00 +02:00
// ReplyMethod, is the method to use for the reply message.
// By default the reply method will be set to log to file, but
// you can override it setting your own here.
ReplyMethod Method `json:"replyMethod" yaml:"replyMethod"`
// Additional arguments that might be needed when executing the reply
// method. Can be f.ex. an ip address if it is a tcp sender, or the
// shell command to execute in a cli session.
ReplyMethodArgs []string `json:"replyMethodArgs" yaml:"replyMethodArgs"`
2021-09-22 16:08:55 +02:00
// IsReply are used to tell that this is a reply message. By default
// the system sends the output of a request method back to the node
// the message originated from. If it is a reply method we want the
// result of the reply message to be sent to the central server, so
// we can use this value if set to swap the toNode, and fromNode
// fields.
IsReply bool `json:"isReply" yaml:"isReply"`
2021-04-13 13:50:00 +02:00
// From what node the message originated
2022-01-26 09:23:02 +01:00
FromNode Node `json:"fromNode" yaml:"fromNode"`
// ACKTimeout for waiting for an ack message
ACKTimeout int `json:"ACKTimeout" yaml:"ACKTimeout"`
// RetryWait specified the time in seconds to wait between retries.
RetryWait int `json:"retryWait" yaml:"retryWait"`
// IsSubPublishedMsg enables timeout of publishing process, and is used together with process.isSubProcess to be able to terminate the sub processes publishers.
IsSubPublishedMsg bool `json:"isSubPublishedMsg" yaml:"isSubPublishedMsg"`
// Resend retries
Retries int `json:"retries" yaml:"retries"`
// The ACK timeout of the new message created via a request event.
ReplyACKTimeout int `json:"replyACKTimeout" yaml:"replyACKTimeout"`
2021-03-11 17:14:43 +01:00
// The retries of the new message created via a request event.
2021-04-13 14:37:17 +02:00
ReplyRetries int `json:"replyRetries" yaml:"replyRetries"`
2021-03-11 17:14:43 +01:00
// Timeout for long a process should be allowed to operate
MethodTimeout int `json:"methodTimeout" yaml:"methodTimeout"`
2021-09-16 12:37:46 +02:00
// Timeout for long a process should be allowed to operate
ReplyMethodTimeout int `json:"replyMethodTimeout" yaml:"replyMethodTimeout"`
2021-04-07 07:00:40 +02:00
// Directory is a string that can be used to create the
//directory structure when saving the result of some method.
// For example "syslog","metrics", or "metrics/mysensor"
// The type is typically used in the handler of a method.
Directory string `json:"directory" yaml:"directory"`
2021-09-09 09:54:33 +02:00
// FileName is used to be able to set a wanted name
2021-04-07 07:00:40 +02:00
// on a file being saved as the result of data being handled
// by a method handler.
FileName string `json:"fileName" yaml:"fileName"`
// PreviousMessage are used for example if a reply message is
// generated and we also need a copy of the details of the the
// initial request message.
PreviousMessage *Message
2022-06-20 11:17:23 +02:00
// Schedule
Schedule []int `json:"schedule" yaml:"schedule"`
}
// --- Subject
2021-08-16 13:01:12 +02:00
// Node is the type definition for the node who receive or send a message.
2021-06-29 08:21:42 +02:00
type Node string
// subject contains the representation of a subject to be used with one
// specific process
type Subject struct {
2021-08-16 13:01:12 +02:00
// node, the name of the node to receive the message.
ToNode string `json:"node" yaml:"toNode"`
// method, what is this message doing, etc. CLICommand, Syslog, etc.
Method Method `json:"method" yaml:"method"`
}
// newSubject will return a new variable of the type subject, and insert
2022-06-07 11:52:30 +02:00
// all the values given as arguments. It will create the channel
// to receive new messages on the specific subject.
2022-06-07 11:52:30 +02:00
// The function will also verify that there is a methodHandler defined
// for the Request type.
func newSubject(method Method, node string) Subject {
// Get the Event type for the Method.
ma := method.GetMethodsAvailable()
_, ok := ma.CheckIfExists(method)
//mh, ok := ma.Methodhandlers[method]
if !ok {
2023-01-12 12:01:01 +01:00
log.Printf("error: newSubject: no Event type specified for the method: %v\n", method)
os.Exit(1)
}
return Subject{
ToNode: node,
Method: method,
}
}
2022-06-07 11:52:30 +02:00
// newSubjectNoVerifyHandler will return a new variable of the type subject, and insert
// all the values given as arguments. It will create the channel
// to receive new messages on the specific subject.
// The function will not verify that there is a methodHandler defined
// for the Request type.
func newSubjectNoVerifyHandler(method Method, node string) Subject {
// Get the Event type for the Method.
return Subject{
ToNode: node,
Method: method,
2022-06-07 11:52:30 +02:00
}
}
// subjectName is the complete representation of a subject
type subjectName string
2021-08-16 13:01:12 +02:00
// Return a value of the subjectName for the subject as used with nats subject.
func (s Subject) name() subjectName {
return subjectName(fmt.Sprintf("%s.%s", s.ToNode, s.Method))
}