2022-11-17 07:37:29 -08:00
|
|
|
package vaa
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/certusone/wormhole/node/pkg/vaa"
|
2022-11-23 04:06:29 -08:00
|
|
|
"github.com/wormhole-foundation/wormhole-explorer/api/internal/pagination"
|
|
|
|
"github.com/wormhole-foundation/wormhole-explorer/api/response"
|
2022-11-17 07:37:29 -08:00
|
|
|
"go.uber.org/zap"
|
|
|
|
)
|
|
|
|
|
2022-11-23 04:06:29 -08:00
|
|
|
// Service definition.
|
2022-11-17 07:37:29 -08:00
|
|
|
type Service struct {
|
|
|
|
repo *Repository
|
|
|
|
logger *zap.Logger
|
|
|
|
}
|
|
|
|
|
2022-11-23 04:06:29 -08:00
|
|
|
// NewService create a new Service.
|
2022-11-17 07:37:29 -08:00
|
|
|
func NewService(r *Repository, logger *zap.Logger) *Service {
|
|
|
|
return &Service{repo: r, logger: logger.With(zap.String("module", "VaaService"))}
|
|
|
|
}
|
|
|
|
|
2022-11-23 04:06:29 -08:00
|
|
|
// FindAll get all the the vaa.
|
|
|
|
func (s *Service) FindAll(ctx context.Context, p *pagination.Pagination) (*response.Response[[]*VaaDoc], error) {
|
2022-11-17 07:37:29 -08:00
|
|
|
if p == nil {
|
|
|
|
p = pagination.FirstPage()
|
|
|
|
}
|
|
|
|
|
|
|
|
query := Query().SetPagination(p)
|
|
|
|
vaas, err := s.repo.Find(ctx, query)
|
2022-11-23 04:06:29 -08:00
|
|
|
res := response.Response[[]*VaaDoc]{Data: vaas}
|
2022-11-17 07:37:29 -08:00
|
|
|
return &res, err
|
|
|
|
}
|
|
|
|
|
2022-11-23 04:06:29 -08:00
|
|
|
// FindByChain get all the vaa by chainID.
|
|
|
|
func (s *Service) FindByChain(ctx context.Context, chain vaa.ChainID, p *pagination.Pagination) (*response.Response[[]*VaaDoc], error) {
|
2022-11-17 07:37:29 -08:00
|
|
|
query := Query().SetChain(chain).SetPagination(p)
|
|
|
|
vaas, err := s.repo.Find(ctx, query)
|
2022-11-23 04:06:29 -08:00
|
|
|
res := response.Response[[]*VaaDoc]{Data: vaas}
|
2022-11-17 07:37:29 -08:00
|
|
|
return &res, err
|
|
|
|
}
|
|
|
|
|
2022-11-23 04:06:29 -08:00
|
|
|
// FindByEmitter get all the vaa by chainID and emitter address.
|
|
|
|
func (s *Service) FindByEmitter(ctx context.Context, chain vaa.ChainID, emitter vaa.Address, p *pagination.Pagination) (*response.Response[[]*VaaDoc], error) {
|
2022-11-17 07:37:29 -08:00
|
|
|
query := Query().SetChain(chain).SetEmitter(emitter.String()).SetPagination(p)
|
|
|
|
vaas, err := s.repo.Find(ctx, query)
|
2022-11-23 04:06:29 -08:00
|
|
|
res := response.Response[[]*VaaDoc]{Data: vaas}
|
2022-11-17 07:37:29 -08:00
|
|
|
return &res, err
|
|
|
|
}
|
|
|
|
|
2022-11-23 04:06:29 -08:00
|
|
|
// FindById get a vaa by chainID, emitter address and sequence number.
|
2022-12-14 11:26:45 -08:00
|
|
|
func (s *Service) FindById(ctx context.Context, chain vaa.ChainID, emitter vaa.Address, seq string) (*response.Response[*VaaDoc], error) {
|
2022-11-17 07:37:29 -08:00
|
|
|
query := Query().SetChain(chain).SetEmitter(emitter.String()).SetSequence(seq)
|
|
|
|
vaas, err := s.repo.FindOne(ctx, query)
|
2022-11-23 04:06:29 -08:00
|
|
|
res := response.Response[*VaaDoc]{Data: vaas}
|
2022-11-17 07:37:29 -08:00
|
|
|
return &res, err
|
|
|
|
}
|
|
|
|
|
2022-11-23 05:15:16 -08:00
|
|
|
// GetVaaCount get a list a list of vaa count grouped by chainID.
|
|
|
|
func (s *Service) GetVaaCount(ctx context.Context, p *pagination.Pagination) (*response.Response[[]*VaaStats], error) {
|
|
|
|
if p == nil {
|
|
|
|
p = pagination.FirstPage()
|
|
|
|
}
|
|
|
|
query := Query().SetPagination(p)
|
|
|
|
stats, err := s.repo.GetVaaCount(ctx, query)
|
2022-11-23 04:06:29 -08:00
|
|
|
res := response.Response[[]*VaaStats]{Data: stats}
|
2022-11-17 07:37:29 -08:00
|
|
|
return &res, err
|
|
|
|
}
|