FireLeave_tool/connect/device_storage.go
2025-12-10 14:34:57 +08:00

198 lines
5.3 KiB
Go

package connect
import (
"FireLeave_tool/logger"
"encoding/json"
"fmt"
"os"
"path/filepath"
"strings"
)
var (
devicesBaseDir = "/data/devices"
deviceDataList []DeviceData
)
func InitializeDevicesFromServiceConfig() ([]DeviceData, error) {
deviceDataMutex.Lock()
defer deviceDataMutex.Unlock()
logger.Logger.Printf("Initializing device data from service configuration...")
// Ensure device directory exists
if err := os.MkdirAll(devicesBaseDir, 0755); err != nil {
logger.Logger.Printf("Failed to create device directory: %v", err)
return nil, err
}
logger.Logger.Printf("Device directory confirmed: %s", devicesBaseDir)
// Load from service configuration
configs, err := LoadServiceConfig()
if err != nil {
logger.Logger.Printf("Failed to load from service configuration: %v", err)
return nil, err
}
logger.Logger.Printf("Loaded %d devices from service configuration", len(configs))
deviceDataList = []DeviceData{}
for i, config := range configs {
processedData := ProcessDeviceDataForInference(config)
deviceDataList = append(deviceDataList, processedData)
if err := saveDeviceToFile(processedData); err != nil {
logger.Logger.Printf("Failed to save the device file [%s]: %v", processedData.DeviceUUID, err)
continue
}
logger.Logger.Printf("Processed device [%d]: UUID=%s", i, processedData.DeviceUUID)
}
logger.Logger.Printf("Device data initialization completed, %d devices", len(deviceDataList))
return deviceDataList, nil
}
func saveDeviceToFile(deviceData DeviceData) error {
filePath := filepath.Join(devicesBaseDir, fmt.Sprintf("device_%s.json", deviceData.DeviceUUID))
cleanedData := cleanDeviceData(deviceData)
data, err := json.MarshalIndent(cleanedData, "", " ")
if err != nil {
logger.Logger.Printf("Device data serialization failed: %v, Device data: %+v", err, cleanedData)
return fmt.Errorf("Device data serialization failed: %v", err)
}
if err := os.WriteFile(filePath, data, 0644); err != nil {
return fmt.Errorf("Failed to write device file: %v", err)
}
logger.Logger.Printf("Device data saved successfully: %s", filePath)
return nil
}
func cleanDeviceData(data DeviceData) DeviceData {
cleaned := data
cleaned.DeviceUUID = cleanString(data.DeviceUUID)
cleaned.TaskID = cleanString(data.TaskID)
cleaned.CameraRTSP = cleanString(data.CameraRTSP)
cleaned.CameraIP = cleanString(data.CameraIP)
cleaned.UploadURL = cleanString(data.UploadURL)
cleaned.DetectAreaStr = cleanString(data.DetectAreaStr)
if cleaned.Confidence < 0 || cleaned.Confidence > 100 {
cleaned.Confidence = 70
}
if cleaned.CameraChannel < 0 {
cleaned.CameraChannel = 0
}
if cleaned.PersonCount < 0 {
cleaned.PersonCount = 0
}
if cleaned.Temperature < 0 {
cleaned.Temperature = 0
}
if cleaned.TemperatureThreshold <= 0 {
cleaned.TemperatureThreshold = 45.0
}
return cleaned
}
func cleanString(s string) string {
return strings.Map(func(r rune) rune {
if r == 0xFFFD { // Unicode replacement character
return -1
}
if r < 32 && r != 9 && r != 10 && r != 13 { // Keep tab, newline, carriage return
return -1
}
return r
}, s)
}
func GetDeviceDataList() []DeviceData {
deviceDataMutex.Lock()
defer deviceDataMutex.Unlock()
if len(deviceDataList) == 0 {
logger.Logger.Printf("No device data in memory, loading from device files...")
if err := loadDevicesFromFiles(); err != nil {
logger.Logger.Printf("Failed to load from device files: %v", err)
return []DeviceData{}
}
}
result := make([]DeviceData, len(deviceDataList))
copy(result, deviceDataList)
return result
}
func loadDevicesFromFiles() error {
// Clear existing data
deviceDataList = []DeviceData{}
files, err := filepath.Glob(filepath.Join(devicesBaseDir, "device_*.json"))
if err != nil {
return fmt.Errorf("Failed to find device files: %v", err)
}
logger.Logger.Printf("Found %d device files", len(files))
for _, file := range files {
data, err := os.ReadFile(file)
if err != nil {
logger.Logger.Printf("Failed to read device file %s: %v", file, err)
continue
}
var deviceData DeviceData
if err := json.Unmarshal(data, &deviceData); err != nil {
logger.Logger.Printf("Failed to parse device file %s: %v", file, err)
continue
}
deviceDataList = append(deviceDataList, deviceData)
logger.Logger.Printf("Loaded device from file: UUID=%s", deviceData.DeviceUUID)
}
logger.Logger.Printf("Loaded %d devices from device files", len(deviceDataList))
return nil
}
func UpdateDeviceData(data DeviceData) error {
deviceDataMutex.Lock()
defer deviceDataMutex.Unlock()
//logger.Logger.Printf("Updating device data [%s]", data.DeviceUUID)
// Clean input data
cleanedData := cleanDeviceData(data)
found := false
for i, existing := range deviceDataList {
if existing.DeviceUUID == cleanedData.DeviceUUID {
deviceDataList[i] = cleanedData
found = true
//logger.Logger.Printf("Updated existing device: DeviceUUID=%s", cleanedData.DeviceUUID)
break
}
}
if !found {
logger.Logger.Printf("Adding new device to list: DeviceUUID=%s", cleanedData.DeviceUUID)
deviceDataList = append(deviceDataList, cleanedData)
}
if err := saveDeviceToFile(cleanedData); err != nil {
logger.Logger.Printf("Failed to save device file: %v", err)
return err
}
logger.Logger.Printf("Device data update completed: DeviceUUID=%s", cleanedData.DeviceUUID)
return nil
}