nurse/protocols/redis/get.go

66 lines
1.4 KiB
Go
Raw Normal View History

2022-04-28 18:35:02 +02:00
package redis
import (
"context"
"log/slog"
2022-04-28 18:35:02 +02:00
"github.com/redis/go-redis/v9"
2022-04-28 18:35:02 +02:00
"code.icb4dc0.de/prskr/nurse/internal/retry"
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"
"code.icb4dc0.de/prskr/nurse/validation"
2022-04-28 18:35:02 +02:00
)
var _ check.SystemChecker = (*GetCheck)(nil)
2022-04-28 18:35:02 +02:00
type GetCheck struct {
redis.UniversalClient
2022-06-09 22:12:45 +02:00
validators validation.Validator[redis.Cmder]
2022-04-28 18:35:02 +02:00
Key string
}
func (g *GetCheck) Execute(ctx check.Context) error {
logger := slog.Default().With(
slog.String("check", "redis.GET"),
slog.String("key", g.Key),
)
return retry.Retry(ctx, ctx.AttemptCount(), ctx.AttemptTimeout(), func(ctx context.Context, attempt int) error {
logger.Debug("Execute check", slog.Int("attempt", attempt))
cmd := g.Get(ctx, g.Key)
2022-04-28 18:35:02 +02:00
if err := cmd.Err(); err != nil {
return err
}
2022-04-28 18:35:02 +02:00
return g.validators.Validate(cmd)
})
2022-04-28 18:35:02 +02:00
}
func (g *GetCheck) UnmarshalCheck(c grammar.Check, lookup config.ServerLookup) error {
2022-04-28 18:35:02 +02:00
const serverAndKeyArgsNumber = 2
inst := c.Initiator
if err := grammar.ValidateParameterCount(inst.Params, serverAndKeyArgsNumber); err != nil {
return err
}
var err error
if g.UniversalClient, err = clientFromParam(inst.Params[0], lookup); err != nil {
2022-04-28 18:35:02 +02:00
return err
}
if g.Key, err = inst.Params[1].AsString(); err != nil {
return err
}
2022-06-09 22:12:45 +02:00
if g.validators, err = registry.ValidatorsForFilters(c.Validators); err != nil {
return err
}
2022-04-28 18:35:02 +02:00
return nil
}