mirror of
https://github.com/aljazceru/ark.git
synced 2026-01-16 02:04:20 +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
61 lines
1.2 KiB
Go
Executable File
61 lines
1.2 KiB
Go
Executable File
package main
|
|
|
|
import (
|
|
"os"
|
|
"os/signal"
|
|
"syscall"
|
|
|
|
appconfig "github.com/ark-network/ark/internal/app-config"
|
|
"github.com/ark-network/ark/internal/config"
|
|
grpcservice "github.com/ark-network/ark/internal/interface/grpc"
|
|
log "github.com/sirupsen/logrus"
|
|
)
|
|
|
|
//nolint:all
|
|
var (
|
|
version = "dev"
|
|
commit = "none"
|
|
date = "unknown"
|
|
)
|
|
|
|
func main() {
|
|
cfg, err := config.LoadConfig()
|
|
if err != nil {
|
|
log.WithError(err).Fatal("invalid config")
|
|
}
|
|
|
|
log.SetLevel(log.Level(cfg.LogLevel))
|
|
|
|
svcConfig := grpcservice.Config{
|
|
Port: cfg.Port,
|
|
NoTLS: cfg.NoTLS,
|
|
}
|
|
appConfig := &appconfig.Config{
|
|
DbType: cfg.DbType,
|
|
DbDir: cfg.DbDir,
|
|
RoundInterval: cfg.RoundInterval,
|
|
Network: cfg.Network,
|
|
SchedulerType: cfg.SchedulerType,
|
|
TxBuilderType: cfg.TxBuilderType,
|
|
WalletAddr: cfg.WalletAddr,
|
|
}
|
|
svc, err := grpcservice.NewService(svcConfig, appConfig)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
log.RegisterExitHandler(svc.Stop)
|
|
|
|
log.Info("starting service...")
|
|
if err := svc.Start(); err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
sigChan := make(chan os.Signal, 1)
|
|
signal.Notify(sigChan, syscall.SIGTERM, syscall.SIGINT)
|
|
<-sigChan
|
|
|
|
log.Info("shutting down service...")
|
|
log.Exit(0)
|
|
}
|