mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-01-19 05:45:21 +01:00
watchtower/server/interface: adds Server, Peer and DB
This commit is contained in:
parent
a3e1bb15c5
commit
48643a1747
66
watchtower/server/interface.go
Normal file
66
watchtower/server/interface.go
Normal file
@ -0,0 +1,66 @@
|
||||
package server
|
||||
|
||||
import (
|
||||
"io"
|
||||
"net"
|
||||
"time"
|
||||
|
||||
"github.com/btcsuite/btcd/btcec"
|
||||
"github.com/lightningnetwork/lnd/watchtower/wtdb"
|
||||
)
|
||||
|
||||
// Interface represents a simple, listen-only service that accepts watchtower
|
||||
// clients, and provides responses to their requests.
|
||||
type Interface interface {
|
||||
// InboundPeerConnected accepts a new watchtower client, and handles any
|
||||
// requests sent by the peer.
|
||||
InboundPeerConnected(Peer)
|
||||
|
||||
// Start sets up the watchtower server.
|
||||
Start() error
|
||||
|
||||
// Stop cleans up the watchtower's current connections and resources.
|
||||
Stop() error
|
||||
}
|
||||
|
||||
// Peer is the primary interface used to abstract watchtower clients.
|
||||
type Peer interface {
|
||||
io.WriteCloser
|
||||
|
||||
// ReadNextMessage pulls the next framed message from the client.
|
||||
ReadNextMessage() ([]byte, error)
|
||||
|
||||
// SetWriteDeadline specifies the time by which the client must have
|
||||
// read a message sent by the server. In practice, the connection is
|
||||
// buffered, so the client must read enough from the connection to
|
||||
// support the server adding another reply.
|
||||
SetWriteDeadline(time.Time) error
|
||||
|
||||
// SetReadDeadline specifies the time by which the client must send
|
||||
// another message.
|
||||
SetReadDeadline(time.Time) error
|
||||
|
||||
// RemotePub returns the client's public key.
|
||||
RemotePub() *btcec.PublicKey
|
||||
|
||||
// RemoteAddr returns the client's network address.
|
||||
RemoteAddr() net.Addr
|
||||
}
|
||||
|
||||
// DB provides the server access to session creation and retrieval, as well as
|
||||
// persisting state updates sent by clients.
|
||||
type DB interface {
|
||||
// InsertSessionInfo saves a newly agreed-upon session from a client.
|
||||
// This method should fail if a session with the same session id already
|
||||
// exists.
|
||||
InsertSessionInfo(*wtdb.SessionInfo) error
|
||||
|
||||
// GetSessionInfo retrieves the SessionInfo associated with the session
|
||||
// id, if it exists.
|
||||
GetSessionInfo(*wtdb.SessionID) (*wtdb.SessionInfo, error)
|
||||
|
||||
// InsertStateUpdate persists a state update sent by a client, and
|
||||
// validates the update against the current SessionInfo stored under the
|
||||
// update's session id..
|
||||
InsertStateUpdate(*wtdb.SessionStateUpdate) (uint16, error)
|
||||
}
|
Loading…
Reference in New Issue
Block a user