aboutsummaryrefslogtreecommitdiff
path: root/users.go
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2024-12-30 01:23:40 +0000
committerRunxi Yu <me@runxiyu.org>2024-12-30 01:23:40 +0000
commitdce03955174abe5ad83c01c930e3bf47fe39d8ce (patch)
treecf4cddc3f83bc6eb9efd5be959d349fa47606c84 /users.go
parentReformat (diff)
downloadmeseircd-dce03955174abe5ad83c01c930e3bf47fe39d8ce.tar.gz
meseircd-dce03955174abe5ad83c01c930e3bf47fe39d8ce.tar.zst
meseircd-dce03955174abe5ad83c01c930e3bf47fe39d8ce.zip
Revamp
Diffstat (limited to 'users.go')
-rw-r--r--users.go95
1 files changed, 0 insertions, 95 deletions
diff --git a/users.go b/users.go
deleted file mode 100644
index d94a0fe..0000000
--- a/users.go
+++ /dev/null
@@ -1,95 +0,0 @@
-package main
-
-import (
- "net"
- "sync"
-
- "git.sr.ht/~runxiyu/meseircd/meselog"
-)
-
-type User struct {
- Clients []*Client
- UID uint64
- Nick string
- Ident string
- Gecos string
- Host string
- Caps map[string]struct{}
- Extra map[string]any
- Server *Server
- State ClientState
-}
-
-func (user *User) SendToLocalClients(msg SMsg) (numSent uint) {
- for _, c := range user.Clients {
- if c.Server != self {
- continue
- }
- err := c.Send(msg)
- if err == nil {
- numSent++
- }
- }
- return
-}
-
-func (user *User) ClientSource() string {
- // TODO: Edge cases where these aren't available
- return user.Nick + "!" + user.Ident + "@" + user.Host
-}
-
-func (user *User) ServerSource() uint64 {
- return user.UID
-}
-
-// func (user *User) Delete() {
-// if client.conn != nil {
-// (*client.conn).Close()
-// }
-// if !cidToClient.CompareAndDelete(client.CID, client) {
-// meselog.Error("cid inconsistent", "cid", client.CID, "client", client)
-// }
-// if client.State >= ClientStateRegistered || client.Nick != "*" {
-// if !nickToClient.CompareAndDelete(client.Nick, client) {
-// meselog.Error("nick inconsistent", "nick", client.Nick, "client", client)
-// }
-// }
-// }
-
-func NewLocalUser(conn *net.Conn) (*User, error) {
- var uidPart uint32
- {
- uidPartCountLock.Lock()
- defer uidPartCountLock.Unlock()
- if uidPartCount == ^uint32(0) { // UINT32_MAX
- return nil, ErrFullClients
- }
- uidPartCount++
- uidPart = uidPartCount
- }
- client := &Client{
- conn: conn,
- Server: self,
- State: ClientStatePreRegistration,
- Nick: "*",
- Caps: make(map[string]struct{}),
- Extra: make(map[string]any),
- CID: uint64(self.SID)<<32 | uint64(uidPart),
- }
- return client, nil
-}
-
-const (
- ClientStatePreRegistration ClientState = iota
- ClientStateCapabilities
- ClientStateCapabilitiesFinished
- ClientStateRegistered
- ClientStateRemote
-)
-
-var (
- cidToClient = sync.Map{}
- nickToClient = sync.Map{}
- uidPartCount uint32
- uidPartCountLock sync.Mutex
-)