Files
VptPassiveAdapter/api/sync_task.go
Jerry Yan 5722dd8e5a feat(core): 添加断连检测和命令执行功能
- 新增 ConnError 类型用于区分连接级错误和应用层错误
- 在 sync_task 中将网络请求错误包装为 ConnError
- 添加 DisconnectActionConfig 配置结构支持断连操作
- 在配置文件中增加 disconnectAction 配置项
- 实现 executeDisconnectCommand 函数支持跨平台命令执行
- 在主循环中添加断连检测逻辑和阈值判断
- 支持服务器连接恢复时重置断连状态
- 添加详细的日志记录用于断连状态追踪
2026-02-09 23:33:55 +08:00

67 lines
1.6 KiB
Go

package api
import (
"ZhenTuLocalPassiveAdapter/config"
"ZhenTuLocalPassiveAdapter/dto"
"ZhenTuLocalPassiveAdapter/logger"
"bytes"
"encoding/json"
"fmt"
"go.uber.org/zap"
"io"
"net/http"
)
// ConnError 表示与服务器的连接级错误(非 HTTP 应用层错误)
type ConnError struct {
Err error
}
func (e *ConnError) Error() string { return e.Err.Error() }
func (e *ConnError) Unwrap() error { return e.Err }
func SyncTask() ([]dto.Task, error) {
url := config.Config.Api.BaseUrl + "/sync"
requestBody := map[string]interface{}{
"version": "0.0.1",
"devices": config.Config.Devices,
}
jsonData, err := json.Marshal(requestBody)
if err != nil {
logger.Error("序列化JSON失败", zap.Error(err))
return nil, err
}
req, err := http.NewRequest("POST", url, bytes.NewBuffer(jsonData))
if err != nil {
logger.Error("创建请求失败", zap.Error(err))
return nil, err
}
req.Header.Set("Content-Type", "application/json")
resp, err := GetAPIClient().Do(req)
if err != nil {
logger.Error("发送请求失败", zap.Error(err))
return nil, &ConnError{Err: err}
}
defer resp.Body.Close()
body, err := io.ReadAll(resp.Body)
if err != nil {
logger.Error("读取响应体失败", zap.Error(err))
return nil, err
}
// 解析响应体为 map
var response dto.TaskListResponse
err = json.Unmarshal(body, &response)
if err != nil {
logger.Error("解析响应体失败",
zap.String("responseBody", string(body)),
zap.Error(err))
return nil, err
}
if response.Code != 200 {
logger.Error("响应错误码", zap.Int("code", response.Code))
return nil, fmt.Errorf(response.Msg)
}
return response.Data, nil
}