Files
eko/internal/server/api/api.go

82 lines
2.4 KiB
Go

package api
import (
"context"
"crypto/ed25519"
"database/sql"
"log"
"strconv"
"strings"
"github.com/kyren223/eko/internal/data"
"github.com/kyren223/eko/internal/packet"
"github.com/kyren223/eko/internal/server/session"
"github.com/kyren223/eko/pkg/snowflake"
)
func SendMessage(ctx context.Context, sess *session.Session, request *packet.SendMessage) packet.Payload {
if (request.ReceiverID != nil) == (request.FrequencyID != nil) {
return &packet.Error{Error: "either receiver id or frequency id must exist"}
}
content := strings.TrimSpace(request.Content)
if content == "" {
return &packet.Error{Error: "message content must not be blank"}
}
queries := data.New(db)
message, err := queries.CreateMessage(ctx, data.CreateMessageParams{
ID: sess.Manager().Node().Generate(),
SenderID: sess.ID(),
Content: content,
FrequencyID: request.FrequencyID,
ReceiverID: request.ReceiverID,
})
if err != nil {
log.Println(sess.Addr(), "database error:", err, "in SendMessage")
return &packet.Error{Error: "internal server error"}
}
return &packet.MessagesInfo{Messages: []data.Message{message}}
}
func RequestMessages(ctx context.Context, sess *session.Session, request *packet.RequestMessages) packet.Payload {
queries := data.New(db)
var messages []data.Message
var err error
if request.FrequencyID != nil && request.ReceiverID == nil {
messages, err = queries.GetFrequencyMessages(ctx, request.FrequencyID)
} else if request.ReceiverID != nil && request.FrequencyID == nil {
messages, err = queries.GetDirectMessages(ctx, data.GetDirectMessagesParams{
User1: sess.ID(),
User2: request.ReceiverID,
})
} else {
return &packet.Error{Error: "either receiver id or frequency id must exist"}
}
if err != nil {
log.Println("database error when retrieving messages:", err)
return &packet.Error{Error: "internal server error"}
}
return &packet.MessagesInfo{Messages: messages}
}
func CreateOrGetUser(ctx context.Context, node *snowflake.Node, pubKey ed25519.PublicKey) (data.User, error) {
queries := data.New(db)
user, err := queries.GetUserByPublicKey(ctx, pubKey)
if err == sql.ErrNoRows {
id := node.Generate()
user, err = queries.CreateUser(ctx, data.CreateUserParams{
ID: id,
Name: "User" + strconv.FormatInt(id.Time()%1000, 10),
PublicKey: pubKey,
})
}
if err != nil {
return data.User{}, err
}
return user, nil
}