mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 20:24:21 +01:00
* Fixes * Fixes to domain layer: * Add Leaf bool field to know to fix the returned list of leaves * Add non-persisted UnsignedForfeitTxs to RoundFinalizationStarted * Store only error msg when round fails instead of full error * Fix wallet interface: * Add Close() to close conn with wallet * Add GetAsset() to fix missing asset err when calling Transfer() * Fix gocron scheduler to correctly run/build the project * Fix badger repo implementation: * Fix datadirs of projection stores * Return error if current round not found * Fix round event deserialization * Fix TxBuilder interface & dummy impl: * Pass asp pubkey as arg of the defined functions * Fix connectorsToInputArgs to return the right number of ins * Fix getTxid() to return the id of an hex encoded tx too * Fix createConnectors() to return a tx if there's only 1 connector * Add leaf bool field to psetWithLevel in case a leaf is not in the last level * Fix node's isLeaf() check * Move to hex encoded pubkeys instead of ark encoded * Fix app layer: * Add Start() and Stop() to the interface & Expect raw pubkeys instead of strings as args * Source & cache pubkey from wallet at startup * Drop usage of scheduler and schedule next task based on occurred round events * Increase verbosity * Use hex instead of ark encoding to store receveirs' pubkeys * Lower faucet amount from 100k to 10k sats in total * Fix finalizeRound() to persist round events even if it failed * Add view() to forfeitTxMap to enrich RoundFinalizationEvent with unsigned forfeit txs * Add app config * Fix interface layer: * Remove repo manager from handler factory * Fix GetEventStream to forward events to stream once they arrive from app layer * Return missing unsigned forfeit txs in RoundFinalizationEvent * Fix extracting user pubkey from address * Add log interceptors * Add config struct * Add factory * Clean interface * Add config and launcher * Tidy deps & Set defaut round interval to 30secs for dev mode
64 lines
1.8 KiB
Go
64 lines
1.8 KiB
Go
package grpcservice
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
arkv1 "github.com/ark-network/ark/api-spec/protobuf/gen/ark/v1"
|
|
appconfig "github.com/ark-network/ark/internal/app-config"
|
|
interfaces "github.com/ark-network/ark/internal/interface"
|
|
"github.com/ark-network/ark/internal/interface/grpc/handlers"
|
|
"github.com/ark-network/ark/internal/interface/grpc/interceptors"
|
|
log "github.com/sirupsen/logrus"
|
|
"google.golang.org/grpc"
|
|
"google.golang.org/grpc/credentials/insecure"
|
|
)
|
|
|
|
type service struct {
|
|
config Config
|
|
appConfig *appconfig.Config
|
|
server *grpc.Server
|
|
}
|
|
|
|
func NewService(
|
|
svcConfig Config, appConfig *appconfig.Config,
|
|
) (interfaces.Service, error) {
|
|
if err := svcConfig.Validate(); err != nil {
|
|
return nil, fmt.Errorf("invalid service config: %s", err)
|
|
}
|
|
if err := appConfig.Validate(); err != nil {
|
|
return nil, fmt.Errorf("invalid app config: %s", err)
|
|
}
|
|
|
|
grpcConfig := []grpc.ServerOption{
|
|
interceptors.UnaryInterceptor(), interceptors.StreamInterceptor(),
|
|
}
|
|
if !svcConfig.NoTLS {
|
|
return nil, fmt.Errorf("tls termination not supported yet")
|
|
}
|
|
creds := insecure.NewCredentials()
|
|
grpcConfig = append(grpcConfig, grpc.Creds(creds))
|
|
server := grpc.NewServer(grpcConfig...)
|
|
handler := handlers.NewHandler(appConfig.AppService())
|
|
arkv1.RegisterArkServiceServer(server, handler)
|
|
return &service{svcConfig, appConfig, server}, nil
|
|
}
|
|
|
|
func (s *service) Start() error {
|
|
// nolint:all
|
|
go s.server.Serve(s.config.listener())
|
|
log.Infof("started listening at %s", s.config.address())
|
|
|
|
if err := s.appConfig.AppService().Start(); err != nil {
|
|
return fmt.Errorf("failed to start app service: %s", err)
|
|
}
|
|
log.Info("started app service")
|
|
return nil
|
|
}
|
|
|
|
func (s *service) Stop() {
|
|
s.server.Stop()
|
|
log.Info("stopped grpc server")
|
|
s.appConfig.AppService().Stop()
|
|
log.Info("stopped app service")
|
|
}
|