Some checks failed
DCO action / DCO (pull_request) Successful in 59s
Vulncheck / Vulncheck (pull_request) Successful in 1m4s
Pre-commit hooks / Pre-commit (pull_request) Successful in 1m55s
Build / Build Components (pull_request) Successful in 2m4s
Tests and linters / Staticcheck (pull_request) Successful in 2m38s
Tests and linters / Lint (pull_request) Successful in 3m16s
Tests and linters / Run gofumpt (pull_request) Successful in 3m54s
Tests and linters / Tests (pull_request) Successful in 4m12s
Tests and linters / gopls check (pull_request) Successful in 4m31s
Tests and linters / Tests with -race (pull_request) Successful in 4m38s
OCI image / Build container images (push) Failing after 18s
Vulncheck / Vulncheck (push) Successful in 1m2s
Pre-commit hooks / Pre-commit (push) Successful in 1m39s
Build / Build Components (push) Successful in 1m45s
Tests and linters / Staticcheck (push) Successful in 2m18s
Tests and linters / Run gofumpt (push) Successful in 2m46s
Tests and linters / Lint (push) Successful in 3m5s
Tests and linters / Tests with -race (push) Successful in 3m23s
Tests and linters / Tests (push) Successful in 3m52s
Tests and linters / gopls check (push) Successful in 4m18s
Signed-off-by: Alexander Chuprov <a.chuprov@yadro.com>
39 lines
1.1 KiB
Go
39 lines
1.1 KiB
Go
package nodevalidation
|
|
|
|
import (
|
|
"context"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/innerring/processors/netmap"
|
|
apinetmap "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/netmap"
|
|
)
|
|
|
|
// CompositeValidator wraps `netmap.NodeValidator`s.
|
|
//
|
|
// For correct operation, CompositeValidator must be created
|
|
// using the constructor (New). After successful creation,
|
|
// the CompositeValidator is immediately ready to work through
|
|
// API.
|
|
type CompositeValidator struct {
|
|
validators []netmap.NodeValidator
|
|
}
|
|
|
|
// New creates a new instance of the CompositeValidator.
|
|
//
|
|
// The created CompositeValidator does not require additional
|
|
// initialization and is completely ready for work.
|
|
func New(validators ...netmap.NodeValidator) *CompositeValidator {
|
|
return &CompositeValidator{validators}
|
|
}
|
|
|
|
// VerifyAndUpdate passes apinetmap.NodeInfo to wrapped validators.
|
|
//
|
|
// If error appears, returns it immediately.
|
|
func (c *CompositeValidator) VerifyAndUpdate(ctx context.Context, ni *apinetmap.NodeInfo) error {
|
|
for _, v := range c.validators {
|
|
if err := v.VerifyAndUpdate(ctx, ni); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|