Draft: big refactor

This commit is contained in:
2025-09-16 16:03:27 +08:00
parent f527230f1e
commit 85fa3dfe73
47 changed files with 1166 additions and 351 deletions

View File

@@ -11,6 +11,5 @@ func InitDB(ctx context.Context, db *bun.DB) error {
return db.ResetModel(ctx,
(*models.User)(nil),
(*models.UserStatus)(nil),
(*models.Room)(nil),
)
}

View File

@@ -14,7 +14,7 @@ func ReadConfig(ctx context.Context) {
viper.AddConfigPath(".")
if err := viper.ReadInConfig(); err != nil {
if _, ok := err.(viper.ConfigFileNotFoundError); !ok {
tracing.Logger.Ctx(ctx).
tracing.Logger.
Panic("failed to read config file",
zap.Error(err))
panic(err)

77
utils/udp.go Normal file
View File

@@ -0,0 +1,77 @@
package utils
import (
"fmt"
"net"
"github.com/vmihailenco/msgpack/v5"
)
type UDPPayload struct {
MagicNumber int `msgpack:"magicNumber"`
Data string `msgpack:"data"`
}
const (
BUFFER_SIZE int = 1024
MAGIC_NUMBER int = 114514
)
func ListenUDP(
port string,
doneCh chan struct{},
) (string, error) {
addr, err := net.ResolveUDPAddr("udp", ":"+port)
if err != nil {
return "", fmt.Errorf("failed to resolve address, %w", err)
}
conn, err := net.ListenUDP("udp", addr)
if err != nil {
return "", fmt.Errorf("failed to listen on addr '%v', %w", addr, err)
}
defer conn.Close()
dataCh := make(chan string)
go func() {
for {
buffer := make([]byte, BUFFER_SIZE)
n, _, err := conn.ReadFromUDP(buffer)
if err != nil {
continue
}
var payload UDPPayload
err = msgpack.Unmarshal(buffer[:n], &payload)
if err == nil && payload.MagicNumber == MAGIC_NUMBER {
dataCh <- payload.Data
return
}
}
}()
select {
case <-doneCh:
return "", nil
case data := <-dataCh:
return data, nil
}
return "", fmt.Errorf("failed to receive data")
}
func SendPayload(endpoint, data string) error {
conn, err := net.Dial("udp", endpoint)
if err != nil {
return fmt.Errorf("failed to dial endpoint")
}
defer conn.Close()
_, err = conn.Write([]byte(data))
if err != nil {
return fmt.Errorf("failed to send payload")
}
return nil
}