1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
package multiplayer
import (
"time"
"github.com/boozec/rahanna/internal/logger"
"github.com/boozec/rahanna/pkg/p2p"
"go.uber.org/zap"
)
type GameNetwork struct {
server *p2p.TCPNetwork
me p2p.NetworkID
peer p2p.NetworkID
}
// Wrapper to a `TCPNetwork`
func NewGameNetwork(localID string, address string, onHandshake p2p.NetworkHandshakeFunc, logger *zap.Logger) *GameNetwork {
opts := p2p.TCPNetworkOpts{
ListenAddr: address,
HandshakeFn: onHandshake,
RetryDelay: time.Second * 2,
Logger: logger,
}
server := p2p.NewTCPNetwork(p2p.NetworkID(localID), opts)
return &GameNetwork{
server: server,
me: p2p.NetworkID(localID),
}
}
func (n *GameNetwork) Peer() p2p.NetworkID {
return n.peer
}
func (n *GameNetwork) Me() p2p.NetworkID {
return n.me
}
func (n *GameNetwork) Send(payload []byte) error {
return n.server.Send(n.peer, payload)
}
func (n *GameNetwork) AddPeer(remoteID p2p.NetworkID, addr string) {
n.peer = remoteID
n.server.AddPeer(remoteID, addr)
}
func (n *GameNetwork) AddReceiveFunction(f p2p.NetworkMessageReceiveFunc) {
n.server.OnReceiveFn = f
}
func (n *GameNetwork) Close() error {
err := n.server.Close()
logger, _ := logger.GetLogger()
if err != nil {
logger.Sugar().Errorf("Can't close connection for network '%+v': %s", n, err.Error())
} else {
logger.Sugar().Infof("Connection closed for network '%+v'", n)
}
return err
}
|