forked from TrueCloudLab/frostfs-node
Evgenii Stratonikov
4a080ecbb7
There is no need in a wrapper with many from-`interface{}` conversions. Signed-off-by: Evgenii Stratonikov <e.stratonikov@yadro.com>
39 lines
1,015 B
Go
39 lines
1,015 B
Go
package accounting
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/accounting"
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/services/util/response"
|
|
)
|
|
|
|
type ServiceExecutor interface {
|
|
Balance(context.Context, *accounting.BalanceRequestBody) (*accounting.BalanceResponseBody, error)
|
|
}
|
|
|
|
type executorSvc struct {
|
|
exec ServiceExecutor
|
|
respSvc *response.Service
|
|
}
|
|
|
|
// NewExecutionService wraps ServiceExecutor and returns Accounting Service interface.
|
|
func NewExecutionService(exec ServiceExecutor, respSvc *response.Service) Server {
|
|
return &executorSvc{
|
|
exec: exec,
|
|
respSvc: respSvc,
|
|
}
|
|
}
|
|
|
|
func (s *executorSvc) Balance(ctx context.Context, req *accounting.BalanceRequest) (*accounting.BalanceResponse, error) {
|
|
respBody, err := s.exec.Balance(ctx, req.GetBody())
|
|
if err != nil {
|
|
return nil, fmt.Errorf("could not execute Balance request: %w", err)
|
|
}
|
|
|
|
resp := new(accounting.BalanceResponse)
|
|
resp.SetBody(respBody)
|
|
|
|
s.respSvc.SetMeta(resp)
|
|
return resp, nil
|
|
}
|