Search/node.go

157 lines
3.4 KiB
Go
Raw Permalink Normal View History

2024-06-29 19:27:48 +00:00
package main
import (
2024-06-30 21:20:52 +00:00
"bytes"
2024-08-08 11:35:50 +00:00
"crypto/rand"
2024-06-30 21:20:52 +00:00
"encoding/json"
2024-06-29 19:27:48 +00:00
"fmt"
"io/ioutil"
"net/http"
"time"
)
2024-06-30 21:20:52 +00:00
var (
2024-08-10 12:10:38 +00:00
authCode string
peers []string
hostID string
2024-06-29 19:27:48 +00:00
)
2024-06-30 21:20:52 +00:00
type Message struct {
ID string `json:"id"`
Type string `json:"type"`
Content string `json:"content"`
VisitedNodes []string `json:"visitedNodes"`
2024-06-30 21:20:52 +00:00
}
func loadNodeConfig() {
config := loadConfig()
2024-08-08 11:35:50 +00:00
authCode = config.AuthCode
2024-06-30 21:20:52 +00:00
peers = config.Peers
}
2024-06-29 19:27:48 +00:00
func generateHostID() (string, error) {
bytes := make([]byte, 16)
_, err := rand.Read(bytes)
2024-08-08 11:35:50 +00:00
if err != nil {
return "", fmt.Errorf("failed to generate host ID: %v", err)
2024-06-29 19:27:48 +00:00
}
return fmt.Sprintf("%x", bytes), nil
2024-08-08 11:35:50 +00:00
}
func sendMessage(serverAddr string, msg Message) error {
2024-08-08 19:59:10 +00:00
if serverAddr == "" {
return fmt.Errorf("server address is empty")
}
2024-08-08 11:35:50 +00:00
msgBytes, err := json.Marshal(msg)
if err != nil {
return fmt.Errorf("failed to marshal message: %v", err)
2024-06-30 21:20:52 +00:00
}
2024-06-29 19:27:48 +00:00
2024-08-08 11:35:50 +00:00
req, err := http.NewRequest("POST", serverAddr, bytes.NewBuffer(msgBytes))
if err != nil {
return fmt.Errorf("failed to create request: %v", err)
2024-06-29 19:27:48 +00:00
}
2024-08-08 11:35:50 +00:00
req.Header.Set("Content-Type", "application/json")
req.Header.Set("Authorization", authCode)
2024-06-29 19:27:48 +00:00
2024-08-08 11:35:50 +00:00
client := &http.Client{
Timeout: time.Second * 10,
}
resp, err := client.Do(req)
if err != nil {
return fmt.Errorf("failed to send request: %v", err)
}
defer resp.Body.Close()
if resp.StatusCode != http.StatusOK {
body, _ := ioutil.ReadAll(resp.Body)
return fmt.Errorf("server error: %s", body)
}
return nil
2024-06-30 21:20:52 +00:00
}
2024-08-08 11:35:50 +00:00
func handleNodeRequest(w http.ResponseWriter, r *http.Request) {
2024-07-05 01:08:35 +00:00
if r.Method != http.MethodPost {
http.Error(w, "Invalid request method", http.StatusMethodNotAllowed)
return
}
2024-08-08 11:35:50 +00:00
auth := r.Header.Get("Authorization")
if auth != authCode {
http.Error(w, "Unauthorized", http.StatusUnauthorized)
2024-07-05 01:08:35 +00:00
return
}
2024-08-08 11:35:50 +00:00
var msg Message
err := json.NewDecoder(r.Body).Decode(&msg)
if err != nil {
2024-07-05 01:08:35 +00:00
http.Error(w, "Error parsing JSON", http.StatusBadRequest)
return
}
2024-08-08 11:35:50 +00:00
defer r.Body.Close()
2024-07-05 01:08:35 +00:00
2024-08-10 11:27:23 +00:00
printDebug("Received message: %+v\n", msg)
2024-08-08 11:35:50 +00:00
w.Write([]byte("Message received"))
2024-07-05 01:08:35 +00:00
2024-08-08 11:35:50 +00:00
interpretMessage(msg)
2024-07-05 01:08:35 +00:00
}
2024-08-08 11:35:50 +00:00
func startNodeClient() {
for {
for _, peerAddr := range peers {
msg := Message{
ID: hostID,
2024-08-08 11:35:50 +00:00
Type: "test",
Content: "This is a test message from the client node",
}
err := sendMessage(peerAddr, msg)
if err != nil {
printWarn("Error sending message to %s: %v", peerAddr, err)
2024-08-08 11:35:50 +00:00
} else {
printInfo("Message sent successfully to: %s", peerAddr)
2024-08-08 11:35:50 +00:00
}
}
time.Sleep(10 * time.Second)
}
2024-07-05 01:08:35 +00:00
}
2024-06-30 21:20:52 +00:00
func interpretMessage(msg Message) {
switch msg.Type {
case "test":
2024-08-10 11:27:23 +00:00
printDebug("Received test message: %v", msg.Content)
2024-06-30 21:20:52 +00:00
case "update":
2024-08-10 11:27:23 +00:00
printDebug("Received update message: %v", msg.Content)
2024-06-30 21:20:52 +00:00
go update()
2024-07-05 01:08:35 +00:00
case "heartbeat":
handleHeartbeat(msg.Content)
case "election":
handleElection(msg.Content)
2024-08-08 19:59:10 +00:00
case "search-text":
handleSearchTextMessage(msg)
case "search-image":
handleSearchImageMessage(msg)
case "search-video":
handleSearchVideoMessage(msg)
case "search-file":
handleSearchFileMessage(msg)
case "search-forum":
handleSearchForumMessage(msg)
case "forum-results":
handleForumResultsMessage(msg)
2024-08-08 21:37:58 +00:00
case "text-results":
handleTextResultsMessage(msg)
2024-08-08 21:09:07 +00:00
case "image-results":
handleImageResultsMessage(msg)
2024-08-09 08:39:08 +00:00
case "video-results":
handleVideoResultsMessage(msg)
2024-08-09 08:39:08 +00:00
case "file-results":
handleFileResultsMessage(msg)
2024-06-30 21:20:52 +00:00
default:
2024-08-10 11:27:23 +00:00
printWarn("Received unknown message type: %v", msg.Type)
2024-06-30 21:20:52 +00:00
}
}