2
0
mirror of https://github.com/lightninglabs/loop synced 2024-11-04 06:00:21 +00:00
loop/swap.go

127 lines
2.8 KiB
Go
Raw Normal View History

package loop
2019-03-06 20:13:50 +00:00
import (
"context"
"time"
"github.com/lightninglabs/lndclient"
"github.com/lightninglabs/loop/loopdb"
"github.com/lightninglabs/loop/swap"
2019-03-06 20:13:50 +00:00
"github.com/lightningnetwork/lnd/lntypes"
)
type swapKit struct {
hash lntypes.Hash
height int32
log *swap.PrefixLog
2019-03-06 20:13:50 +00:00
lastUpdateTime time.Time
cost loopdb.SwapCost
state loopdb.SwapState
2019-03-06 20:13:50 +00:00
contract *loopdb.SwapContract
swapType swap.Type
swapConfig
2019-03-06 20:13:50 +00:00
}
func newSwapKit(hash lntypes.Hash, swapType swap.Type, cfg *swapConfig,
contract *loopdb.SwapContract) *swapKit {
2019-03-06 20:13:50 +00:00
log := &swap.PrefixLog{
2019-03-06 20:13:50 +00:00
Hash: hash,
2019-10-28 16:06:07 +00:00
Logger: log,
2019-03-06 20:13:50 +00:00
}
return &swapKit{
swapConfig: *cfg,
hash: hash,
log: log,
state: loopdb.StateInitiated,
2019-03-06 20:13:50 +00:00
contract: contract,
swapType: swapType,
}
}
// GetHtlcScriptVersion returns the correct HTLC script version for the passed
// protocol version.
func GetHtlcScriptVersion(
protocolVersion loopdb.ProtocolVersion) swap.ScriptVersion {
2022-04-24 20:29:13 +00:00
// Unrecorded protocol version implies that there was no protocol
// version stored along side a serialized swap that we're resuming in
// which case the swap was initiated with HTLC v1 script.
if protocolVersion == loopdb.ProtocolVersionUnrecorded {
return swap.HtlcV1
}
// If the swap was initiated before we had our v2 script, use v1.
if protocolVersion < loopdb.ProtocolVersionHtlcV2 {
return swap.HtlcV1
}
// If the swap was initiated before we had our v3 script, use v2.
if protocolVersion < loopdb.ProtocolVersionHtlcV3 {
return swap.HtlcV2
}
2022-04-24 20:29:13 +00:00
return swap.HtlcV3
}
// IsTaproot returns true if the swap referenced by the passed swap contract
// uses the v3 (taproot) htlc.
func IsTaprootSwap(swapContract *loopdb.SwapContract) bool {
return GetHtlcScriptVersion(swapContract.ProtocolVersion) == swap.HtlcV3
}
// getHtlc composes and returns the on-chain swap script.
func (s *swapKit) getHtlc(outputType swap.HtlcOutputType) (*swap.Htlc, error) {
return swap.NewHtlc(
GetHtlcScriptVersion(s.contract.ProtocolVersion),
s.contract.CltvExpiry, s.contract.SenderKey,
s.contract.ReceiverKey, s.hash, outputType,
s.swapConfig.lnd.ChainParams,
)
2019-03-06 20:13:50 +00:00
}
// swapInfo constructs and returns a filled SwapInfo from
// the swapKit.
func (s *swapKit) swapInfo() *SwapInfo {
return &SwapInfo{
2019-03-06 20:13:50 +00:00
SwapContract: *s.contract,
SwapHash: s.hash,
SwapType: s.swapType,
LastUpdate: s.lastUpdateTime,
SwapStateData: loopdb.SwapStateData{
State: s.state,
2019-05-15 12:01:27 +00:00
Cost: s.cost,
},
2019-03-06 20:13:50 +00:00
}
}
type genericSwap interface {
execute(mainCtx context.Context, cfg *executeConfig,
height int32) error
}
type swapConfig struct {
lnd *lndclient.LndServices
store loopdb.SwapStore
2019-03-06 20:13:50 +00:00
server swapServerClient
}
2020-06-08 10:53:07 +00:00
func newSwapConfig(lnd *lndclient.LndServices, store loopdb.SwapStore,
server swapServerClient) *swapConfig {
return &swapConfig{
lnd: lnd,
store: store,
server: server,
}
}