mirror of
https://github.com/aljazceru/ark.git
synced 2025-12-17 12:14:21 +01:00
* [proto] add APIs to send and receive musig2 signing data * [common] add serialization functions for nonces and signatures * [application] implements tree signing * fix: remove old debug logs * [proto] cleaning * [common] fix musig2.go * [application] fixes and logs * [interface] fix: stop forwarding 2 times the events * [client] add musig2 support + sign the tree when joining a round * [interface] add new APIs into permissions.go * [application][proto] rework PingResponse (return all events type) * [common] split SetKeys into 2 distinct methods * [client] fixes according to musig2.go changes * [sdk] support tree signing + new PingResponse * [sdk] fixes * [application] revert event channel type * [application] use domain.RoundEvent as lastEvent type * [application] remove IsCovenantLess * comments * [application] revert roundAborted changes * [interface] remove bitcointree dependencie
165 lines
3.5 KiB
Go
165 lines
3.5 KiB
Go
package client
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/ark-network/ark/common/bitcointree"
|
|
"github.com/ark-network/ark/common/tree"
|
|
"github.com/decred/dcrd/dcrec/secp256k1/v4"
|
|
)
|
|
|
|
const (
|
|
GrpcClient = "grpc"
|
|
RestClient = "rest"
|
|
)
|
|
|
|
type RoundEvent interface {
|
|
isRoundEvent()
|
|
}
|
|
|
|
type ASPClient interface {
|
|
GetInfo(ctx context.Context) (*Info, error)
|
|
ListVtxos(ctx context.Context, addr string) ([]Vtxo, []Vtxo, error)
|
|
GetRound(ctx context.Context, txID string) (*Round, error)
|
|
GetRoundByID(ctx context.Context, roundID string) (*Round, error)
|
|
Onboard(
|
|
ctx context.Context, tx, userPubkey string, congestionTree tree.CongestionTree,
|
|
) error
|
|
RegisterPayment(
|
|
ctx context.Context, inputs []VtxoKey, ephemeralPublicKey string,
|
|
) (string, error)
|
|
ClaimPayment(
|
|
ctx context.Context, paymentID string, outputs []Output,
|
|
) error
|
|
GetEventStream(
|
|
ctx context.Context, paymentID string,
|
|
) (<-chan RoundEventChannel, error)
|
|
Ping(ctx context.Context, paymentID string) (RoundEvent, error)
|
|
FinalizePayment(
|
|
ctx context.Context, signedForfeitTxs []string,
|
|
) error
|
|
CreatePayment(
|
|
ctx context.Context, inputs []VtxoKey, outputs []Output,
|
|
) (string, []string, error)
|
|
CompletePayment(
|
|
ctx context.Context, signedRedeemTx string, signedUnconditionalForfeitTxs []string,
|
|
) error
|
|
SendTreeNonces(
|
|
ctx context.Context, roundID, cosignerPubkey string, nonces bitcointree.TreeNonces,
|
|
) error
|
|
SendTreeSignatures(
|
|
ctx context.Context, roundID, cosignerPubkey string, signatures bitcointree.TreePartialSigs,
|
|
) error
|
|
Close()
|
|
}
|
|
|
|
type Info struct {
|
|
Pubkey string
|
|
RoundLifetime int64
|
|
UnilateralExitDelay int64
|
|
RoundInterval int64
|
|
Network string
|
|
MinRelayFee int64
|
|
}
|
|
|
|
type RoundEventChannel struct {
|
|
Event RoundEvent
|
|
Err error
|
|
}
|
|
|
|
type VtxoKey struct {
|
|
Txid string
|
|
VOut uint32
|
|
}
|
|
|
|
type Vtxo struct {
|
|
VtxoKey
|
|
Amount uint64
|
|
RoundTxid string
|
|
ExpiresAt *time.Time
|
|
RedeemTx string
|
|
UnconditionalForfeitTxs []string
|
|
Pending bool
|
|
}
|
|
|
|
type Output struct {
|
|
Address string
|
|
Amount uint64
|
|
}
|
|
|
|
type RoundStage int
|
|
|
|
func (s RoundStage) String() string {
|
|
switch s {
|
|
case RoundStageRegistration:
|
|
return "ROUND_STAGE_REGISTRATION"
|
|
case RoundStageFinalization:
|
|
return "ROUND_STAGE_FINALIZATION"
|
|
case RoundStageFinalized:
|
|
return "ROUND_STAGE_FINALIZED"
|
|
case RoundStageFailed:
|
|
return "ROUND_STAGE_FAILED"
|
|
default:
|
|
return "ROUND_STAGE_UNDEFINED"
|
|
}
|
|
}
|
|
|
|
const (
|
|
RoundStageUndefined RoundStage = iota
|
|
RoundStageRegistration
|
|
RoundStageFinalization
|
|
RoundStageFinalized
|
|
RoundStageFailed
|
|
)
|
|
|
|
type Round struct {
|
|
ID string
|
|
StartedAt *time.Time
|
|
EndedAt *time.Time
|
|
Tx string
|
|
Tree tree.CongestionTree
|
|
ForfeitTxs []string
|
|
Connectors []string
|
|
Stage RoundStage
|
|
}
|
|
|
|
type RoundFinalizationEvent struct {
|
|
ID string
|
|
Tx string
|
|
ForfeitTxs []string
|
|
Tree tree.CongestionTree
|
|
Connectors []string
|
|
}
|
|
|
|
func (e RoundFinalizationEvent) isRoundEvent() {}
|
|
|
|
type RoundFinalizedEvent struct {
|
|
ID string
|
|
Txid string
|
|
}
|
|
|
|
func (e RoundFinalizedEvent) isRoundEvent() {}
|
|
|
|
type RoundFailedEvent struct {
|
|
ID string
|
|
Reason string
|
|
}
|
|
|
|
func (e RoundFailedEvent) isRoundEvent() {}
|
|
|
|
type RoundSigningStartedEvent struct {
|
|
ID string
|
|
UnsignedTree tree.CongestionTree
|
|
CosignersPublicKeys []*secp256k1.PublicKey
|
|
}
|
|
|
|
func (e RoundSigningStartedEvent) isRoundEvent() {}
|
|
|
|
type RoundSigningNoncesGeneratedEvent struct {
|
|
ID string
|
|
Nonces bitcointree.TreeNonces
|
|
}
|
|
|
|
func (e RoundSigningNoncesGeneratedEvent) isRoundEvent() {}
|