mirror of
https://github.com/grassrootseconomics/cic-custodial.git
synced 2024-11-21 22:06:47 +01:00
sub: update handlers for latest CHAIN.* events
* Minor fixes and improvements
This commit is contained in:
parent
21a17d2735
commit
b137088d38
@ -4,33 +4,52 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
|
||||||
"github.com/grassrootseconomics/cic-custodial/internal/store"
|
|
||||||
"github.com/nats-io/nats.go"
|
"github.com/nats-io/nats.go"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (s *Sub) handler(ctx context.Context, msg *nats.Msg) error {
|
type (
|
||||||
|
ChainEvent struct {
|
||||||
|
Block uint64 `json:"block"`
|
||||||
|
From string `json:"from"`
|
||||||
|
To string `json:"to"`
|
||||||
|
ContractAddress string `json:"contractAddress"`
|
||||||
|
Success bool `json:"success"`
|
||||||
|
TxHash string `json:"transactionHash"`
|
||||||
|
TxIndex uint `json:"transactionIndex"`
|
||||||
|
Value uint64 `json:"value"`
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
func (s *Sub) processEventHandler(ctx context.Context, msg *nats.Msg) error {
|
||||||
var (
|
var (
|
||||||
chainEvent store.MinimalTxInfo
|
chainEvent ChainEvent
|
||||||
)
|
)
|
||||||
|
|
||||||
if err := json.Unmarshal(msg.Data, &chainEvent); err != nil {
|
if err := json.Unmarshal(msg.Data, &chainEvent); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := s.cu.PgStore.UpdateOtxStatusFromChainEvent(ctx, chainEvent); err != nil {
|
if err := s.cu.Store.UpdateDispatchStatus(
|
||||||
|
ctx,
|
||||||
|
chainEvent.Success,
|
||||||
|
chainEvent.TxHash,
|
||||||
|
chainEvent.Block,
|
||||||
|
); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
switch msg.Subject {
|
if chainEvent.Success {
|
||||||
case "CHAIN.register":
|
switch msg.Subject {
|
||||||
if chainEvent.Success {
|
case "CHAIN.register":
|
||||||
if err := s.cu.PgStore.ActivateAccount(ctx, chainEvent.To); err != nil {
|
if err := s.cu.Store.ActivateAccount(ctx, chainEvent.To); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
case "CHAIN.gas":
|
if err := s.cu.Store.ResetGasQuota(ctx, chainEvent.To); err != nil {
|
||||||
if chainEvent.Success {
|
return err
|
||||||
if err := s.cu.PgStore.ResetGasQuota(ctx, chainEvent.To); err != nil {
|
}
|
||||||
|
case "CHAIN.gas":
|
||||||
|
if err := s.cu.Store.ResetGasQuota(ctx, chainEvent.To); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,19 +3,17 @@ package sub
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"time"
|
|
||||||
|
|
||||||
"github.com/grassrootseconomics/cic-custodial/internal/custodial"
|
"github.com/grassrootseconomics/cic-custodial/internal/custodial"
|
||||||
|
"github.com/grassrootseconomics/cic-custodial/pkg/util"
|
||||||
"github.com/nats-io/nats.go"
|
"github.com/nats-io/nats.go"
|
||||||
"github.com/zerodha/logf"
|
"github.com/zerodha/logf"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
durableId = "cic-custodial"
|
durableId = "cic-custodial"
|
||||||
pullStream = "CHAIN"
|
pullStream = "CHAIN"
|
||||||
pullSubject = "CHAIN.*"
|
pullSubject = "CHAIN.*"
|
||||||
actionTimeout = 5 * time.Second
|
|
||||||
waitDelay = 1 * time.Second
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
@ -67,7 +65,6 @@ func (s *Sub) Process() error {
|
|||||||
events, err := natsSub.Fetch(1)
|
events, err := natsSub.Fetch(1)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if errors.Is(err, nats.ErrTimeout) {
|
if errors.Is(err, nats.ErrTimeout) {
|
||||||
s.logg.Debug("sub: no msg to pull")
|
|
||||||
continue
|
continue
|
||||||
} else if errors.Is(err, nats.ErrConnectionClosed) {
|
} else if errors.Is(err, nats.ErrConnectionClosed) {
|
||||||
return nil
|
return nil
|
||||||
@ -78,15 +75,14 @@ func (s *Sub) Process() error {
|
|||||||
|
|
||||||
if len(events) > 0 {
|
if len(events) > 0 {
|
||||||
msg := events[0]
|
msg := events[0]
|
||||||
ctx, cancel := context.WithTimeout(context.Background(), actionTimeout)
|
ctx, cancel := context.WithTimeout(context.Background(), util.SLATimeout)
|
||||||
|
|
||||||
if err := s.handler(ctx, msg); err != nil {
|
if err := s.processEventHandler(ctx, msg); err != nil {
|
||||||
s.logg.Error("sub: handler error", "error", err)
|
s.logg.Error("sub: handler error", "error", err)
|
||||||
msg.Nak()
|
msg.Nak()
|
||||||
|
} else {
|
||||||
|
msg.Ack()
|
||||||
}
|
}
|
||||||
|
|
||||||
s.logg.Debug("sub: processed msg", "subject", msg.Subject)
|
|
||||||
msg.Ack()
|
|
||||||
cancel()
|
cancel()
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user