mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 12:14:21 +01:00
* [domain] add reverse boarding inputs in Payment struct * [tx-builder] support reverse boarding script * [wallet] add GetTransaction * [api-spec][application] add reverse boarding support in covenantless * [config] add reverse boarding config * [api-spec] add ReverseBoardingAddress RPC * [domain][application] support empty forfeits txs in EndFinalization events * [tx-builder] optional connector output in round tx * [btc-embedded] fix getTx and taproot finalizer * whitelist ReverseBoardingAddress RPC * [test] add reverse boarding integration test * [client] support reverse boarding * [sdk] support reverse boarding * [e2e] add sleep time after faucet * [test] run using bitcoin-core RPC * [tx-builder] fix GetSweepInput * [application][tx-builder] support reverse onboarding in covenant * [cli] support reverse onboarding in covenant CLI * [test] rework integration tests * [sdk] remove onchain wallet, replace by onboarding address * remove old onboarding protocols * [sdk] Fix RegisterPayment * [e2e] add more funds to covenant ASP * [e2e] add sleeping time * several fixes * descriptor boarding * remove boarding delay from info * [sdk] implement descriptor boarding * go mod tidy * fixes and revert error msgs * move descriptor pkg to common * add replace in go.mod * [sdk] fix unit tests * rename DescriptorInput --> BoardingInput * genrest in SDK * remove boarding input from domain * remove all "reverse boarding" * rename "onboarding" ==> "boarding" * remove outdate payment unit test * use tmpfs docker volument for compose testing files * several fixes
117 lines
2.5 KiB
Go
117 lines
2.5 KiB
Go
package badgerdb
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/ark-network/ark/server/internal/core/domain"
|
|
"github.com/dgraph-io/badger/v4"
|
|
"github.com/dgraph-io/badger/v4/options"
|
|
"github.com/timshannon/badgerhold/v4"
|
|
)
|
|
|
|
func createDB(dbDir string, logger badger.Logger) (*badgerhold.Store, error) {
|
|
isInMemory := len(dbDir) <= 0
|
|
|
|
opts := badger.DefaultOptions(dbDir)
|
|
opts.Logger = logger
|
|
|
|
if isInMemory {
|
|
opts.InMemory = true
|
|
} else {
|
|
opts.Compression = options.ZSTD
|
|
}
|
|
|
|
db, err := badgerhold.Open(badgerhold.Options{
|
|
Encoder: badgerhold.DefaultEncode,
|
|
Decoder: badgerhold.DefaultDecode,
|
|
SequenceBandwith: 100,
|
|
Options: opts,
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if !isInMemory {
|
|
ticker := time.NewTicker(30 * time.Minute)
|
|
|
|
go func() {
|
|
for {
|
|
<-ticker.C
|
|
if err := db.Badger().RunValueLogGC(0.5); err != nil && err != badger.ErrNoRewrite {
|
|
logger.Errorf("%s", err)
|
|
}
|
|
}
|
|
}()
|
|
}
|
|
|
|
return db, nil
|
|
}
|
|
|
|
func serializeEvents(events []domain.RoundEvent) (*eventsDTO, error) {
|
|
rawEvents := make([][]byte, 0, len(events))
|
|
for _, event := range events {
|
|
buf, err := serializeEvent(event)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
rawEvents = append(rawEvents, buf)
|
|
}
|
|
return &eventsDTO{rawEvents}, nil
|
|
}
|
|
|
|
func deserializeEvents(rawEvents [][]byte) ([]domain.RoundEvent, error) {
|
|
events := make([]domain.RoundEvent, 0)
|
|
for _, buf := range rawEvents {
|
|
event, err := deserializeEvent(buf)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
events = append(events, event)
|
|
}
|
|
return events, nil
|
|
}
|
|
|
|
func serializeEvent(event domain.RoundEvent) ([]byte, error) {
|
|
switch eventType := event.(type) {
|
|
default:
|
|
return json.Marshal(eventType)
|
|
}
|
|
}
|
|
|
|
func deserializeEvent(buf []byte) (domain.RoundEvent, error) {
|
|
{
|
|
var event = domain.RoundFailed{}
|
|
if err := json.Unmarshal(buf, &event); err == nil && len(event.Err) > 0 {
|
|
return event, nil
|
|
}
|
|
}
|
|
{
|
|
var event = domain.RoundFinalized{}
|
|
if err := json.Unmarshal(buf, &event); err == nil && len(event.Txid) > 0 {
|
|
return event, nil
|
|
}
|
|
}
|
|
{
|
|
var event = domain.RoundFinalizationStarted{}
|
|
if err := json.Unmarshal(buf, &event); err == nil && len(event.PoolTx) > 0 {
|
|
return event, nil
|
|
}
|
|
}
|
|
{
|
|
var event = domain.PaymentsRegistered{}
|
|
if err := json.Unmarshal(buf, &event); err == nil && len(event.Payments) > 0 {
|
|
return event, nil
|
|
}
|
|
}
|
|
{
|
|
var event = domain.RoundStarted{}
|
|
if err := json.Unmarshal(buf, &event); err == nil && event.Timestamp > 0 {
|
|
return event, nil
|
|
}
|
|
}
|
|
|
|
return nil, fmt.Errorf("unknown event")
|
|
}
|