refactor to have all DB executive functions be in api/
This commit is contained in:
61
api/db.go
61
api/db.go
@@ -81,23 +81,78 @@ func dbGetAllMessages() ([]*Message, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func dbAddUser(id int64, name string) error {
|
func dbAddUser(id int64, name string) error {
|
||||||
|
currentData := db.ExecDB("users")
|
||||||
|
if currentData == nil {
|
||||||
|
return fmt.Errorf("error reading users database")
|
||||||
|
}
|
||||||
|
|
||||||
|
users, ok := currentData["users"].([]interface{})
|
||||||
|
if !ok {
|
||||||
|
return fmt.Errorf("users data is in an unexpected format")
|
||||||
|
}
|
||||||
|
|
||||||
user := map[string]interface{}{
|
user := map[string]interface{}{
|
||||||
"ID": float64(id), // JSON numbers are float64 by default
|
"ID": float64(id), // JSON numbers are float64 by default
|
||||||
"Name": name,
|
"Name": name,
|
||||||
}
|
}
|
||||||
return db.AddUser(user)
|
|
||||||
|
users = append(users, user)
|
||||||
|
return db.WriteDB("users", users)
|
||||||
}
|
}
|
||||||
|
|
||||||
func dbAddMessage(message *Message) error {
|
func dbAddMessage(message *Message) error {
|
||||||
|
currentData := db.ExecDB("messages")
|
||||||
|
if currentData == nil {
|
||||||
|
return fmt.Errorf("error reading messages database")
|
||||||
|
}
|
||||||
|
|
||||||
|
messages, ok := currentData["messages"].([]interface{})
|
||||||
|
if !ok {
|
||||||
|
return fmt.Errorf("messages data is in an unexpected format")
|
||||||
|
}
|
||||||
|
|
||||||
dbMessage := map[string]interface{}{
|
dbMessage := map[string]interface{}{
|
||||||
"ID": message.ID,
|
"ID": message.ID,
|
||||||
"UserID": message.UserID, // JSON numbers are float64
|
"UserID": message.UserID, // JSON numbers are float64
|
||||||
"Body": message.Body,
|
"Body": message.Body,
|
||||||
"Timestamp": message.Timestamp,
|
"Timestamp": message.Timestamp,
|
||||||
}
|
}
|
||||||
return db.AddMessage(dbMessage)
|
|
||||||
|
messages = append(messages, dbMessage)
|
||||||
|
return db.WriteDB("messages", messages)
|
||||||
}
|
}
|
||||||
|
|
||||||
func dbDeleteMessage(id string) error {
|
func dbDeleteMessage(id string) error {
|
||||||
return db.DeleteMessage(id)
|
currentData := db.ExecDB("messages")
|
||||||
|
if currentData == nil {
|
||||||
|
return fmt.Errorf("error reading messages database")
|
||||||
|
}
|
||||||
|
|
||||||
|
messages, ok := currentData["messages"].([]interface{})
|
||||||
|
if !ok {
|
||||||
|
return fmt.Errorf("messages data is in an unexpected format")
|
||||||
|
}
|
||||||
|
|
||||||
|
var updatedMessages []interface{}
|
||||||
|
found := false
|
||||||
|
|
||||||
|
for _, m := range messages {
|
||||||
|
message, ok := m.(map[string]interface{})
|
||||||
|
if !ok {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if messageID, ok := message["ID"].(string); ok && messageID == id {
|
||||||
|
found = true
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
updatedMessages = append(updatedMessages, message)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !found {
|
||||||
|
return fmt.Errorf("message with ID %s not found", id)
|
||||||
|
}
|
||||||
|
|
||||||
|
return db.WriteDB("messages", updatedMessages)
|
||||||
}
|
}
|
||||||
|
@@ -71,58 +71,3 @@ func WriteDB(db_name string, data interface{}) error {
|
|||||||
fmt.Printf("Successfully wrote to %s DB\n", db_name)
|
fmt.Printf("Successfully wrote to %s DB\n", db_name)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func AddUser(user map[string]interface{}) error {
|
|
||||||
currentData := ExecDB("users")
|
|
||||||
if currentData == nil {
|
|
||||||
return fmt.Errorf("error reading users database")
|
|
||||||
}
|
|
||||||
|
|
||||||
users := currentData["users"].([]interface{})
|
|
||||||
users = append(users, user)
|
|
||||||
return WriteDB("users", users)
|
|
||||||
}
|
|
||||||
|
|
||||||
func AddMessage(message map[string]interface{}) error {
|
|
||||||
currentData := ExecDB("messages")
|
|
||||||
if currentData == nil {
|
|
||||||
return fmt.Errorf("error reading messages database")
|
|
||||||
}
|
|
||||||
|
|
||||||
messages := currentData["messages"].([]interface{})
|
|
||||||
messages = append(messages, message)
|
|
||||||
return WriteDB("messages", messages)
|
|
||||||
}
|
|
||||||
|
|
||||||
func DeleteMessage(messageID string) error {
|
|
||||||
currentData := ExecDB("messages")
|
|
||||||
if currentData == nil {
|
|
||||||
return fmt.Errorf("error reading messages database")
|
|
||||||
}
|
|
||||||
|
|
||||||
messages, ok := currentData["messages"].([]interface{})
|
|
||||||
if !ok {
|
|
||||||
return fmt.Errorf("messages data is in an unexpected format")
|
|
||||||
}
|
|
||||||
|
|
||||||
var updatedMessages []interface{}
|
|
||||||
found := false
|
|
||||||
|
|
||||||
for _, value := range messages {
|
|
||||||
if item, ok := value.(map[string]interface{}); ok {
|
|
||||||
if id, exists := item["ID"]; exists {
|
|
||||||
if idStr, ok := id.(string); ok && idStr == messageID {
|
|
||||||
found = true
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
updatedMessages = append(updatedMessages, value)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !found {
|
|
||||||
return fmt.Errorf("message with ID %s not found", messageID)
|
|
||||||
}
|
|
||||||
|
|
||||||
return WriteDB("messages", updatedMessages)
|
|
||||||
}
|
|
||||||
|
Reference in New Issue
Block a user