Commit c8a8aa0d authored by zelig's avatar zelig Committed by Felix Lange

initial hook for crypto handshake (void, off by default)

parent 6b5f2580
......@@ -70,6 +70,7 @@ type Peer struct {
// These fields maintain the running protocols.
protocols []Protocol
runBaseProtocol bool // for testing
cryptoHandshake bool // for testing
runlock sync.RWMutex // protects running
running map[string]*proto
......@@ -141,6 +142,20 @@ func (p *Peer) Identity() ClientIdentity {
return p.identity
}
func (self *Peer) Pubkey() (pubkey []byte) {
self.infolock.Lock()
defer self.infolock.Unlock()
switch {
case self.identity != nil:
pubkey = self.identity.Pubkey()
case self.dialAddr != nil:
pubkey = self.dialAddr.Pubkey
case self.listenAddr != nil:
pubkey = self.listenAddr.Pubkey
}
return
}
// Caps returns the capabilities (supported subprotocols) of the remote peer.
func (p *Peer) Caps() []Cap {
p.infolock.Lock()
......@@ -207,6 +222,12 @@ func (p *Peer) loop() (reason DiscReason, err error) {
defer close(p.closed)
defer p.conn.Close()
if p.cryptoHandshake {
if err := p.handleCryptoHandshake(); err != nil {
return DiscProtocolError, err // no graceful disconnect
}
}
// read loop
readMsg := make(chan Msg)
readErr := make(chan error)
......@@ -307,6 +328,11 @@ func (p *Peer) dispatch(msg Msg, protoDone chan struct{}) (wait bool, err error)
return wait, nil
}
func (p *Peer) handleCryptoHandshake() (err error) {
return nil
}
func (p *Peer) startBaseProtocol() {
p.runlock.Lock()
defer p.runlock.Unlock()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment