change message sending to work via http
This commit is contained in:
+15
-34
@@ -77,36 +77,18 @@ func sendToAllMessageCloseIfTimeout(message *map[string]any) {
|
||||
}
|
||||
}
|
||||
|
||||
func handleAuthenticatedMessage(client *Client, clientMessage *map[string]any) bool {
|
||||
subjectFlt, ok := (*clientMessage)["subject"].(float64)
|
||||
subject := uint32(subjectFlt)
|
||||
if !ok {
|
||||
var msg = map[string]any{
|
||||
"from": "server",
|
||||
"error": "subject invalid",
|
||||
}
|
||||
sendMessageCloseIfTimeout(client, &msg)
|
||||
return true
|
||||
}
|
||||
|
||||
content, ok := (*clientMessage)["content"].(string)
|
||||
if !ok {
|
||||
var msg = map[string]any{
|
||||
"from": "server",
|
||||
"error": "content invalid",
|
||||
}
|
||||
sendMessageCloseIfTimeout(client, &msg)
|
||||
return true
|
||||
}
|
||||
|
||||
group, err := CacheGetGroup(subject)
|
||||
func WsSendToGroup(ctx context.Context, groupId uint32, senderId uint32, message string) error {
|
||||
group, err := CacheGetGroup(groupId)
|
||||
if err != nil {
|
||||
var msg = map[string]any{
|
||||
"from": "server",
|
||||
"error": "subject invalid",
|
||||
return errors.New("group invalid")
|
||||
}
|
||||
|
||||
client, err := CacheGetClientById(senderId)
|
||||
if err == nil {
|
||||
err = DbSetClientById(ctx, client)
|
||||
if err != nil {
|
||||
return errors.New("non existing sender")
|
||||
}
|
||||
sendMessageCloseIfTimeout(client, &msg)
|
||||
return true
|
||||
}
|
||||
|
||||
for groupClientId := range group.Clients {
|
||||
@@ -119,16 +101,15 @@ func handleAuthenticatedMessage(client *Client, clientMessage *map[string]any) b
|
||||
"from": "group",
|
||||
"group": group.Id,
|
||||
"sender": client.Name,
|
||||
"content": content,
|
||||
"content": message,
|
||||
}
|
||||
sendMessageCloseIfTimeout(groupClient, &msg)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
var msg = map[string]any{
|
||||
"from": "server",
|
||||
}
|
||||
sendMessageCloseIfTimeout(client)
|
||||
|
||||
func handleAuthenticatedMessage(client *Client, clientMessage *map[string]any) bool {
|
||||
sendMessageCloseIfTimeout(client, clientMessage)
|
||||
return true
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user