2022-04-28 18:35:02 +02:00
|
|
|
package redis
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
2023-12-04 11:22:49 +01:00
|
|
|
"log/slog"
|
2022-04-28 18:35:02 +02:00
|
|
|
|
2023-03-01 18:22:31 +01:00
|
|
|
"github.com/redis/go-redis/v9"
|
2022-04-28 18:35:02 +02:00
|
|
|
|
2022-09-22 11:46:36 +02:00
|
|
|
"code.icb4dc0.de/prskr/nurse/check"
|
|
|
|
"code.icb4dc0.de/prskr/nurse/config"
|
|
|
|
"code.icb4dc0.de/prskr/nurse/grammar"
|
2023-12-04 16:59:10 +01:00
|
|
|
"code.icb4dc0.de/prskr/nurse/internal/retry"
|
2022-09-22 11:46:36 +02:00
|
|
|
"code.icb4dc0.de/prskr/nurse/validation"
|
2022-04-28 18:35:02 +02:00
|
|
|
)
|
|
|
|
|
2022-05-08 11:00:22 +02:00
|
|
|
var _ check.SystemChecker = (*PingCheck)(nil)
|
2022-04-28 18:35:02 +02:00
|
|
|
|
|
|
|
type PingCheck struct {
|
|
|
|
redis.UniversalClient
|
2022-06-09 22:12:45 +02:00
|
|
|
validators validation.Validator[redis.Cmder]
|
2022-04-28 18:35:02 +02:00
|
|
|
Message string
|
|
|
|
}
|
|
|
|
|
2023-12-04 16:59:10 +01:00
|
|
|
func (p *PingCheck) Execute(ctx check.Context) error {
|
|
|
|
logger := slog.Default().With(
|
2023-12-04 11:22:49 +01:00
|
|
|
slog.String("check", "redis.PING"),
|
|
|
|
slog.String("msg", p.Message),
|
|
|
|
)
|
|
|
|
|
2023-12-04 16:59:10 +01:00
|
|
|
return retry.Retry(ctx, ctx.AttemptCount(), ctx.AttemptTimeout(), func(ctx context.Context, attempt int) error {
|
|
|
|
logger.Debug("Execute check", slog.Int("attempt", attempt))
|
2022-08-07 12:22:21 +02:00
|
|
|
|
2023-12-04 16:59:10 +01:00
|
|
|
if p.Message == "" {
|
|
|
|
return p.Ping(ctx).Err()
|
2022-08-07 12:22:21 +02:00
|
|
|
}
|
|
|
|
|
2023-12-04 16:59:10 +01:00
|
|
|
if resp, err := p.Do(ctx, "PING", p.Message).Text(); err != nil {
|
|
|
|
return err
|
|
|
|
} else if resp != p.Message {
|
|
|
|
return fmt.Errorf("expected value %s got %s", p.Message, resp)
|
|
|
|
}
|
2022-04-28 18:35:02 +02:00
|
|
|
|
2023-12-04 16:59:10 +01:00
|
|
|
return nil
|
|
|
|
})
|
2022-04-28 18:35:02 +02:00
|
|
|
}
|
|
|
|
|
2022-05-08 11:00:22 +02:00
|
|
|
func (p *PingCheck) UnmarshalCheck(c grammar.Check, lookup config.ServerLookup) error {
|
2022-04-28 18:35:02 +02:00
|
|
|
const (
|
|
|
|
serverOnlyArgCount = 1
|
|
|
|
serverAndMessageArgCount = 2
|
|
|
|
)
|
|
|
|
|
2022-06-09 17:20:06 +02:00
|
|
|
val, _ := GenericCommandValidatorFor("PONG")
|
2022-06-09 22:12:45 +02:00
|
|
|
|
|
|
|
validators := validation.Chain[redis.Cmder]{}
|
|
|
|
validators = append(validators, val)
|
|
|
|
|
|
|
|
p.validators = validators
|
2022-04-28 18:35:02 +02:00
|
|
|
|
|
|
|
init := c.Initiator
|
|
|
|
switch len(init.Params) {
|
|
|
|
case 0:
|
|
|
|
return grammar.ErrMissingServer
|
|
|
|
case serverAndMessageArgCount:
|
|
|
|
if msg, err := init.Params[1].AsString(); err != nil {
|
|
|
|
return err
|
|
|
|
} else {
|
2022-06-09 17:20:06 +02:00
|
|
|
val, _ := GenericCommandValidatorFor(msg)
|
2022-06-09 22:12:45 +02:00
|
|
|
p.validators = validation.Chain[redis.Cmder]{val}
|
2022-04-28 18:35:02 +02:00
|
|
|
}
|
|
|
|
fallthrough
|
|
|
|
case serverOnlyArgCount:
|
2022-05-08 11:00:22 +02:00
|
|
|
if cli, err := clientFromParam(init.Params[0], lookup); err != nil {
|
2022-04-28 18:35:02 +02:00
|
|
|
return err
|
|
|
|
} else {
|
|
|
|
p.UniversalClient = cli
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
default:
|
|
|
|
return grammar.ErrAmbiguousParamCount
|
|
|
|
}
|
|
|
|
}
|