implement POST message creation

This commit is contained in:
2025-03-24 15:02:24 -04:00
parent e45b426e68
commit 2ec1738721
29 changed files with 1605 additions and 27 deletions

View File

@@ -2,6 +2,7 @@ package api
import (
"errors"
"fmt"
"time"
"git.dubyatp.xyz/chat-api-server/db"
@@ -36,11 +37,15 @@ func dbGetMessage(id string) (*Message, error) {
for _, m := range messages {
message := m.(map[string]interface{})
if message["ID"].(string) == id {
timestamp, err := time.Parse(time.RFC3339, message["Timestamp"].(string))
if err != nil {
return nil, fmt.Errorf("failed to parse timestamp: %v", err)
}
return &Message{
ID: message["ID"].(string),
UserID: int64(message["UserID"].(float64)),
Body: message["Body"].(string),
Timestamp: time.Time(time.Now()),
Timestamp: timestamp,
}, nil
}
}
@@ -58,11 +63,15 @@ func dbGetAllMessages() ([]*Message, error) {
var result []*Message
for _, m := range messages {
message := m.(map[string]interface{})
timestamp, err := time.Parse(time.RFC3339, message["Timestamp"].(string))
if err != nil {
return nil, fmt.Errorf("failed to parse timestamp: %v", err)
}
result = append(result, &Message{
ID: message["ID"].(string),
UserID: int64(message["UserID"].(float64)),
Body: message["Body"].(string),
Timestamp: time.Time(time.Now()),
Timestamp: timestamp,
})
}
if len(result) == 0 {
@@ -70,3 +79,21 @@ func dbGetAllMessages() ([]*Message, error) {
}
return result, nil
}
func dbAddUser(id int64, name string) error {
user := map[string]interface{}{
"ID": float64(id), // JSON numbers are float64 by default
"Name": name,
}
return db.AddUser(user)
}
func dbAddMessage(message *Message) error {
dbMessage := map[string]interface{}{
"ID": message.ID,
"UserID": message.UserID, // JSON numbers are float64
"Body": message.Body,
"Timestamp": message.Timestamp,
}
return db.AddMessage(dbMessage)
}