 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Index ¶
- Constants
- Variables
- func DoRequest(subscribe func(topics []types.TopicChannel, messageErrors chan error) error, ...) (*types.MessageEnvelope, error)
- func GenerateTLSForClientClientOptions(brokerURL string, tlsConfigurationOptions TlsConfigurationOptions, ...) (*tls.Config, error)
- func Load(config map[string]string, des interface{}) error
- type BrokerURLErr
- type CertificateErr
- type CriticalOperationManager
- type InvalidTopicErr
- type MissingConfigurationErr
- type NoopClient
- func (n NoopClient) Connect() error
- func (n NoopClient) Disconnect() error
- func (n NoopClient) Publish(message types.MessageEnvelope, topic string) error
- func (n NoopClient) PublishBinaryData(data []byte, topic string) error
- func (n NoopClient) PublishWithSizeLimit(message types.MessageEnvelope, topic string, limit int64) error
- func (n NoopClient) RegisterCriticalOperation(finishSignal chan struct{})
- func (n NoopClient) Request(message types.MessageEnvelope, targetServiceName string, requestTopic string, ...) (*types.MessageEnvelope, error)
- func (n NoopClient) Subscribe(topics []types.TopicChannel, messageErrors chan error) error
- func (n NoopClient) SubscribeBinaryData(topics []types.TopicChannel, messageErrors chan error) error
- func (n NoopClient) Unsubscribe(topics ...string) error
- func (n NoopClient) WaitForCriticalOperations(timeout time.Duration) bool
 
- type PEMDecoder
- type PublishHostURLErr
- type SubscribeHostURLErr
- type TlsConfigurationOptions
- type X509CaCertCreator
- type X509CaCertLoader
- type X509KeyLoader
- type X509KeyPairCreator
Constants ¶
const ( // Client identifier configurations Username = "Username" Password = "Password" ClientId = "ClientId" // Connection configuration names ConnectTimeout = "ConnectTimeout" AutoReconnect = "AutoReconnect" // TLS configuration names SkipCertVerify = "SkipCertVerify" CertFile = "CertFile" KeyFile = "KeyFile" CaFile = "CaFile" KeyPEMBlock = "KeyPEMBlock" CertPEMBlock = "CertPEMBlock" CaPEMBlock = "CaPEMBlock" // MQTT Specifics Qos = "Qos" KeepAlive = "KeepAlive" Retained = "Retained" CleanSession = "CleanSession" // NATS specifics RetryOnFailedConnect = "RetryOnFailedConnect" Format = "Format" QueueGroup = "QueueGroup" ExactlyOnce = "ExactlyOnce" // NATS JetStream specifics Durable = "Durable" Subject = "Subject" AutoProvision = "AutoProvision" Deliver = "Deliver" DefaultPubRetryAttempts = "DefaultPubRetryAttempts" )
Variables ¶
var TlsSchemes = []string{"tcps", "ssl", "tls", "nats"}
    Functions ¶
func DoRequest ¶
func DoRequest( subscribe func(topics []types.TopicChannel, messageErrors chan error) error, unsubscribe func(topics ...string) error, publish func(message types.MessageEnvelope, topic string) error, requestMessage types.MessageEnvelope, requestTopic string, responseTopicPrefix string, requestTimeout time.Duration) (*types.MessageEnvelope, error)
DoRequest publishes a request containing a RequestID to the specified topic, then subscribes to a response topic which contains the RequestID. Once the response is received, the response topic is unsubscribed and the response data is returned. If no response is received within the timeout period, a timed out error returned.
func GenerateTLSForClientClientOptions ¶
func GenerateTLSForClientClientOptions( brokerURL string, tlsConfigurationOptions TlsConfigurationOptions, certCreator X509KeyPairCreator, certLoader X509KeyLoader, caCertCreator X509CaCertCreator, caCertLoader X509CaCertLoader, pemDecoder PEMDecoder) (*tls.Config, error)
GenerateTLSForClientClientOptions creates a tls.Config which can be used when configuring the underlying client. If TLS is not needed then nil will be returned which can be used to signal no TLS is needed to the client.
func Load ¶
load by reflect to check map key and then fetch the value. This function ignores properties that have not been provided from the source. Therefore it is recommended to provide a destination struct with reasonable defaults.
NOTE: This logic was borrowed from device-mqtt-go and some additional logic was added to accommodate more types. https://github.com/edgexfoundry/device-mqtt-go/blob/a0d50c6e03a7f7dcb28f133885c803ffad3ec502/internal/driver/config.go#L74-L101
Types ¶
type BrokerURLErr ¶
type BrokerURLErr struct {
	// contains filtered or unexported fields
}
    BrokerURLErr represents an error associated parsing a broker's URL.
func NewBrokerURLErr ¶
func NewBrokerURLErr(description string) BrokerURLErr
NewBrokerURLErr constructs a new BrokerURLErr
func (BrokerURLErr) Error ¶
func (bue BrokerURLErr) Error() string
type CertificateErr ¶
type CertificateErr struct {
	// contains filtered or unexported fields
}
    CertificateErr represents an error associated with interacting with a Certificate.
func NewCertificateErr ¶
func NewCertificateErr(message string) CertificateErr
NewCertificateErr constructs a new CertificateErr
func (CertificateErr) Error ¶
func (ce CertificateErr) Error() string
type CriticalOperationManager ¶
type CriticalOperationManager struct {
	// contains filtered or unexported fields
}
    CriticalOperationManager provides critical operation management functionality
func NewCriticalOperationManager ¶
func NewCriticalOperationManager() *CriticalOperationManager
NewCriticalOperationManager creates a new critical operations manager
func (*CriticalOperationManager) RegisterCriticalOperation ¶
func (m *CriticalOperationManager) RegisterCriticalOperation(finishSignal chan struct{})
RegisterCriticalOperation registers a critical operation with a finish signal channel
func (*CriticalOperationManager) WaitForCriticalOperations ¶
func (m *CriticalOperationManager) WaitForCriticalOperations(timeout time.Duration) bool
WaitForCriticalOperations waits for all critical operations to complete within the specified timeout returns true if all operations completed, false if timeout occurred
type InvalidTopicErr ¶
type InvalidTopicErr struct {
	// contains filtered or unexported fields
}
    func NewInvalidTopicErr ¶
func NewInvalidTopicErr(topic string, description string) InvalidTopicErr
func (InvalidTopicErr) Error ¶
func (ite InvalidTopicErr) Error() string
type MissingConfigurationErr ¶
type MissingConfigurationErr struct {
	// contains filtered or unexported fields
}
    func NewMissingConfigurationErr ¶
func NewMissingConfigurationErr(missingConfiguration string, message string) MissingConfigurationErr
func (MissingConfigurationErr) Error ¶
func (mce MissingConfigurationErr) Error() string
type NoopClient ¶
type NoopClient struct{}
    func (NoopClient) Connect ¶
func (n NoopClient) Connect() error
func (NoopClient) Disconnect ¶
func (n NoopClient) Disconnect() error
func (NoopClient) Publish ¶
func (n NoopClient) Publish(message types.MessageEnvelope, topic string) error
func (NoopClient) PublishBinaryData ¶
func (n NoopClient) PublishBinaryData(data []byte, topic string) error
func (NoopClient) PublishWithSizeLimit ¶
func (n NoopClient) PublishWithSizeLimit(message types.MessageEnvelope, topic string, limit int64) error
func (NoopClient) RegisterCriticalOperation ¶
func (n NoopClient) RegisterCriticalOperation(finishSignal chan struct{})
func (NoopClient) Request ¶
func (n NoopClient) Request(message types.MessageEnvelope, targetServiceName string, requestTopic string, timeout time.Duration) (*types.MessageEnvelope, error)
func (NoopClient) Subscribe ¶
func (n NoopClient) Subscribe(topics []types.TopicChannel, messageErrors chan error) error
func (NoopClient) SubscribeBinaryData ¶
func (n NoopClient) SubscribeBinaryData(topics []types.TopicChannel, messageErrors chan error) error
func (NoopClient) Unsubscribe ¶
func (n NoopClient) Unsubscribe(topics ...string) error
func (NoopClient) WaitForCriticalOperations ¶
func (n NoopClient) WaitForCriticalOperations(timeout time.Duration) bool
type PEMDecoder ¶
PEMDecoder defines the function signature for finding the next PEM formatted block in the input. It returns that block and the remainder of the input.
type PublishHostURLErr ¶
type PublishHostURLErr struct {
	// contains filtered or unexported fields
}
    func NewPublishHostURLErr ¶
func NewPublishHostURLErr(message string) PublishHostURLErr
func (PublishHostURLErr) Error ¶
func (p PublishHostURLErr) Error() string
type SubscribeHostURLErr ¶
type SubscribeHostURLErr struct {
	// contains filtered or unexported fields
}
    func NewSubscribeHostURLErr ¶
func NewSubscribeHostURLErr(message string) SubscribeHostURLErr
func (SubscribeHostURLErr) Error ¶
func (p SubscribeHostURLErr) Error() string
type TlsConfigurationOptions ¶
type TlsConfigurationOptions struct {
	SkipCertVerify bool
	CertFile       string
	KeyFile        string
	CaFile         string
	KeyPEMBlock    string
	CertPEMBlock   string
	CaPEMBlock     string
}
    func CreateDefaultTlsConfigurationOptions ¶
func CreateDefaultTlsConfigurationOptions() TlsConfigurationOptions
type X509CaCertCreator ¶
type X509CaCertCreator func(caCertPEMBlock []byte) (*x509.Certificate, error)
X509CaCertCreator defines the function signature for creating a CA certificate based on PEM encoding.
type X509CaCertLoader ¶
X509CaCertLoader defines the function signature for loading a PEM formatted block from the given CA certificate file.
type X509KeyLoader ¶
type X509KeyLoader func(certFile string, keyFile string) (tls.Certificate, error)
X509KeyLoader defines a function signature for loading a tls.Certificate from cert and key files.
type X509KeyPairCreator ¶
type X509KeyPairCreator func(certPEMBlock []byte, keyPEMBlock []byte) (tls.Certificate, error)
X509KeyPairCreator defines the function signature for creating a tls.Certificate based on PEM encoding.