mirror of
https://github.com/ClusterCockpit/cc-metric-store.git
synced 2025-01-14 00:09:20 +01:00
Enable basic authentication for NATS
This commit is contained in:
parent
83d1cb2a98
commit
7201251600
@ -76,9 +76,11 @@ All durations are specified as string that will be parsed [like this](https://pk
|
|||||||
- `scope`: Unused at the moment, should be something like `"node"`, `"socket"` or `"hwthread"`
|
- `scope`: Unused at the moment, should be something like `"node"`, `"socket"` or `"hwthread"`
|
||||||
- `nats`:
|
- `nats`:
|
||||||
- `address`: Url of NATS.io server, example: "nats://localhost:4222"
|
- `address`: Url of NATS.io server, example: "nats://localhost:4222"
|
||||||
|
- `username` and `password`: Optional, if provided use those for the connection
|
||||||
|
- `subscribe-to`: Where to expect the measurements to be published
|
||||||
- `http-api`:
|
- `http-api`:
|
||||||
- `address`: Address to bind to, for example `0.0.0.0:8080`
|
- `address`: Address to bind to, for example `0.0.0.0:8080`
|
||||||
- `https-cert-file` and `https-key-file`: Optional, if provided enable HTTPS using those files as certificate/key.
|
- `https-cert-file` and `https-key-file`: Optional, if provided enable HTTPS using those files as certificate/key
|
||||||
- `jwt-public-key`: Base64 encoded string, use this to verify requests to the HTTP API
|
- `jwt-public-key`: Base64 encoded string, use this to verify requests to the HTTP API
|
||||||
- `retention-on-memory`: Keep all values in memory for at least that amount of time
|
- `retention-on-memory`: Keep all values in memory for at least that amount of time
|
||||||
- `checkpoints`:
|
- `checkpoints`:
|
||||||
|
@ -21,7 +21,12 @@ type Metric struct {
|
|||||||
// function. handleLine will be called for each line recieved via nats.
|
// function. handleLine will be called for each line recieved via nats.
|
||||||
// Send `true` through the done channel for gracefull termination.
|
// Send `true` through the done channel for gracefull termination.
|
||||||
func ReceiveNats(conf *NatsConfig, handleLine func(dec *lineprotocol.Decoder) error, workers int, ctx context.Context) error {
|
func ReceiveNats(conf *NatsConfig, handleLine func(dec *lineprotocol.Decoder) error, workers int, ctx context.Context) error {
|
||||||
nc, err := nats.Connect(conf.Address)
|
var opts []nats.Option
|
||||||
|
if conf.Username != "" && conf.Password != "" {
|
||||||
|
opts = append(opts, nats.UserInfo(conf.Username, conf.Password))
|
||||||
|
}
|
||||||
|
|
||||||
|
nc, err := nats.Connect(conf.Address, opts...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -48,11 +53,11 @@ func ReceiveNats(conf *NatsConfig, handleLine func(dec *lineprotocol.Decoder) er
|
|||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
sub, err = nc.Subscribe("updates", func(m *nats.Msg) {
|
sub, err = nc.Subscribe(conf.SubscribeTo, func(m *nats.Msg) {
|
||||||
msgs <- m
|
msgs <- m
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
sub, err = nc.Subscribe("updates", func(m *nats.Msg) {
|
sub, err = nc.Subscribe(conf.SubscribeTo, func(m *nats.Msg) {
|
||||||
dec := lineprotocol.NewDecoderWithBytes(m.Data)
|
dec := lineprotocol.NewDecoderWithBytes(m.Data)
|
||||||
if err := handleLine(dec); err != nil {
|
if err := handleLine(dec); err != nil {
|
||||||
log.Printf("error: %s\n", err.Error())
|
log.Printf("error: %s\n", err.Error())
|
||||||
@ -64,7 +69,7 @@ func ReceiveNats(conf *NatsConfig, handleLine func(dec *lineprotocol.Decoder) er
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
log.Printf("NATS subscription to 'updates' on '%s' established\n", conf.Address)
|
log.Printf("NATS subscription to '%s' on '%s' established\n", conf.SubscribeTo, conf.Address)
|
||||||
|
|
||||||
<-ctx.Done()
|
<-ctx.Done()
|
||||||
err = sub.Unsubscribe()
|
err = sub.Unsubscribe()
|
||||||
|
@ -39,6 +39,13 @@ type HttpConfig struct {
|
|||||||
type NatsConfig struct {
|
type NatsConfig struct {
|
||||||
// Address of the nats server
|
// Address of the nats server
|
||||||
Address string `json:"address"`
|
Address string `json:"address"`
|
||||||
|
|
||||||
|
// Channel name
|
||||||
|
SubscribeTo string `json:"subscribe-to"`
|
||||||
|
|
||||||
|
// Username/Password, optional
|
||||||
|
Username string `json:"username"`
|
||||||
|
Password string `json:"password"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type Config struct {
|
type Config struct {
|
||||||
|
Loading…
Reference in New Issue
Block a user