forked from HimbeerserverDE/multiserver
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlisten.go
114 lines (91 loc) · 1.99 KB
/
listen.go
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
package main
import (
"errors"
"net"
"sync"
"github.com/anon55555/mt/rudp"
)
var ErrPlayerLimitReached = errors.New("player limit reached")
type Listener struct {
*rudp.Listener
mu sync.RWMutex
peers map[*Peer]struct{}
}
var listener *Listener
func Listen(conn net.PacketConn) *Listener {
return &Listener{
Listener: rudp.Listen(conn),
peers: make(map[*Peer]struct{}),
}
}
// Accept waits for and returns a connecting Peer
// You should keep calling this until it returns ErrClosed
// so it doesn't leak a goroutine
func (l *Listener) Accept() (*Peer, error) {
rp, err := l.Listener.Accept()
if err != nil {
return nil, err
}
clt := &Peer{Peer: rp}
l.mu.Lock()
l.peers[clt] = struct{}{}
l.mu.Unlock()
go func() {
<-clt.Disco()
l.mu.Lock()
delete(l.peers, clt)
l.mu.Unlock()
}()
clt.aoIDs = make(map[uint16]bool)
clt.modChs = make(map[string]bool)
maxPeers, ok := GetConfKey("player_limit").(int)
if !ok {
maxPeers = int(^uint(0) >> 1)
}
if GetPeerCount() >= maxPeers {
data := []byte{
0, ToClientAccessDenied,
AccessDeniedTooManyUsers, 0, 0, 0, 0,
}
_, err := clt.Send(rudp.Pkt{Data: data})
if err != nil {
return nil, err
}
return nil, ErrPlayerLimitReached
}
connectedPeers++
return clt, nil
}
// GetPeerByUsername returns the Peer that is using name for
// authentication
func (l *Listener) GetPeerByUsername(name string) *Peer {
l.mu.RLock()
defer l.mu.RUnlock()
for peer := range l.peers {
if string(peer.username) == name {
return peer
}
}
return nil
}
// GetPeers returns an array containing all connected client Peers
func (l *Listener) GetPeers() []*Peer {
l.mu.RLock()
defer l.mu.RUnlock()
var r []*Peer
for p := range l.peers {
r = append(r, p)
}
return r
}
// SetListener is used to make a listener available globally
// This can only be done once
func SetListener(l *Listener) {
if listener == nil {
listener = l
}
}
// GetListener returns the global listener
func GetListener() *Listener {
return listener
}