mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 20:24:21 +01:00
* api-spec: move the api-spec to root and init go.mod * go mod tidy * move buf files in the root as well * gh action for api-spec changes only * gh action for api-spec on push and pr * introduce go.work and remove all replaces * solve dependencies and force btcd/btcec@v2.3.3 * go work sync * force btcd/btcec@v2.3.3 * go mod tidy
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.Connectors) > 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")
|
|
}
|