Documentation
¶
Index ¶
- Constants
- func BuildRequestObject(path string, requestObj interface{}, secret string, encrypted ...bool) ([]byte, error)
- func ValidProtocolNonce(nonce string) bool
- type AuthToken
- type ClientEventHandler
- func (h *ClientEventHandler) OnClose(socket *gws.Conn, err error)
- func (h *ClientEventHandler) OnMessage(socket *gws.Conn, message *gws.Message)
- func (h *ClientEventHandler) OnOpen(socket *gws.Conn)
- func (h *ClientEventHandler) OnPing(socket *gws.Conn, payload []byte)
- func (h *ClientEventHandler) OnPong(socket *gws.Conn, payload []byte)
- type HttpSDK
- func (s *HttpSDK) AuthObject(object func() (interface{}, error))
- func (s *HttpSDK) AuthToken(object AuthToken)
- func (s *HttpSDK) GetAuth() AuthToken
- func (s *HttpSDK) GetPublicKey() (*crypto.MLKEM1024Object, *node.PublicKey, crypto.Cipher, error)
- func (s *HttpSDK) PostByPlan01(path string, requestObj, responseObj interface{}, encrypted bool) error
- func (s *HttpSDK) PostByPlan2(path string, requestObj, responseObj interface{}) error
- func (s *HttpSDK) ResetAuth() error
- func (s *HttpSDK) SetClientNo(usr int64)
- func (s *HttpSDK) SetLanguage(language string)
- func (s *HttpSDK) SetMLDSA87Object(usr int64, prkB64, peerPubB64 string) error
- func (s *HttpSDK) SetTimeout(timeout int64)
- type MessageHandler
- type RPC
- func (r *RPC) AddCipher(usr int64, cipher crypto.Cipher) *RPC
- func (r *RPC) AddLocalCache(_ cache.Cache) *RPC
- func (r *RPC) Call(router string, requestObj, responseObj proto.Message, encrypted bool) error
- func (r *RPC) CallWithTimeout(router string, requestObj, responseObj proto.Message, encrypted bool, ...) error
- func (r *RPC) Close() error
- func (r *RPC) Connect() error
- func (r *RPC) SetClientNo(usr int64) *RPC
- func (r *RPC) SetLanguage(language string) *RPC
- func (r *RPC) SetSSL(ssl bool) *RPC
- func (r *RPC) SetTimeout(timeout int64) *RPC
- type SocketSDK
- func (s *SocketSDK) AuthObject(object interface{})
- func (s *SocketSDK) AuthToken(object AuthToken)
- func (s *SocketSDK) Close()
- func (s *SocketSDK) ConnectWebSocket() error
- func (s *SocketSDK) ConnectWebSocketWithRawAuth(path, authHeader string) error
- func (s *SocketSDK) DisableReconnect()
- func (s *SocketSDK) DisconnectWebSocket()
- func (s *SocketSDK) EnableReconnect()
- func (s *SocketSDK) ForceReconnect() error
- func (s *SocketSDK) GetAuth() AuthToken
- func (s *SocketSDK) GetClientNo() int64
- func (s *SocketSDK) GetDomain() string
- func (s *SocketSDK) GetReconnectStatus() (enabled bool, attempts int, maxAttempts int, reconnecting bool, ...)
- func (s *SocketSDK) GetSSL() bool
- func (s *SocketSDK) GetSubscriptions() map[string]*Subscription
- func (s *SocketSDK) GetWebSocketPlan2Auth(keyRouter string, timeout int64) (string, []byte, error)
- func (s *SocketSDK) IsWebSocketConnected() bool
- func (s *SocketSDK) LoginByWebSocketPlan2(loginRouter string, requestObj interface{}, sharedKey []byte, timeout int64) error
- func (s *SocketSDK) LoginByWebSocketPlan2Auto(keyRouter, loginRouter string, requestObj, responseObj interface{}, ...) error
- func (s *SocketSDK) SendWebSocketMessage(router string, requestObj, responseObj interface{}, ...) error
- func (s *SocketSDK) SendWebSocketPlan2Message(router string, requestObj, responseObj interface{}, sharedKey []byte, ...) error
- func (s *SocketSDK) SendWebSocketRawBody(body *node.JsonBody, waitResponse bool, timeout int64) (*node.JsonResp, error)
- func (s *SocketSDK) SetBroadcastKey(key string)
- func (s *SocketSDK) SetClientNo(clientNo int64)
- func (s *SocketSDK) SetDomain(domain string)
- func (s *SocketSDK) SetHealthPing(t int)
- func (s *SocketSDK) SetLanguage(language string)
- func (s *SocketSDK) SetMLDSA87Object(usr int64, prkB64, peerPubB64 string) error
- func (s *SocketSDK) SetPushMessageCallback(callback func(router string, data []byte))
- func (s *SocketSDK) SetRawAuthorization(auth string)
- func (s *SocketSDK) SetReconnectConfig(enabled bool, maxAttempts int, initialInterval, maxInterval time.Duration)
- func (s *SocketSDK) SetSSL(ssl bool)
- func (s *SocketSDK) SetTimeout(timeout int64)
- func (s *SocketSDK) SetTokenExpiredCallback(callback func())
- func (s *SocketSDK) SetWebSocketPath(path string) error
- func (s *SocketSDK) SubscribeMessage(router string, handler MessageHandler) (subscriptionID string, err error)
- func (s *SocketSDK) UnsubscribeMessage(router string) error
- type Subscription
Constants ¶
const (
DefaultWsRoute = "/ws" // 默认WebSocket路由路径
)
WebSocket客户端常量
Variables ¶
This section is empty.
Functions ¶
func BuildRequestObject ¶ added in v1.0.146
func BuildRequestObject(path string, requestObj interface{}, secret string, encrypted ...bool) ([]byte, error)
BuildRequestObject 构建标准的API请求数据 用于生成符合FreeGo协议的请求JSON数据
协议格式:
{
"d": "数据(Base64或AES加密)",
"t": 时间戳,
"n": Nonce随机数,
"p": Plan模式(0=Base64, 1=AES),
"s": HMAC-SHA256签名
}
构建流程: 1. JSON序列化请求对象 2. 根据encrypted参数选择编码方式 3. 生成时间戳和Nonce 4. 计算HMAC-SHA256签名 5. 构建完整的请求JSON
参数:
- path: API路径,用于签名计算
- requestObj: 请求数据对象,会被JSON序列化
- secret: HMAC签名密钥
- encrypted: 可选参数,是否使用AES加密 (默认false)
返回值:
- []byte: 构建好的请求JSON字节数组
- error: 构建失败时的错误信息
兼容性: - 这是早期版本的构建函数 - 新代码推荐使用PostByPlan01或PostByPlan2方法 - 主要用于向后兼容和简单场景
注意: - 不支持 ML-DSA 外层签名(仅 Plan2 路径使用) - 使用固定的AES-CBC加密 (非GCM模式) - HMAC签名算法略有不同
func ValidProtocolNonce ¶ added in v1.1.22
ValidProtocolNonce 供测试与外部校验:Nonce 解码后须为 32 字节。
Types ¶
type AuthToken ¶ added in v1.0.98
type AuthToken struct {
Token string `json:"token"` // JWT认证令牌
Secret string `json:"secret"` // 动态生成的AES密钥(Base64编码)
Expired int64 `json:"expired"` // 令牌过期时间戳(Unix秒)
}
AuthToken 认证令牌结构体 包含JWT token、动态secret和过期时间
func (AuthToken) MarshalEasyJSON ¶ added in v1.1.12
MarshalEasyJSON supports easyjson.Marshaler interface
func (AuthToken) MarshalJSON ¶ added in v1.1.12
MarshalJSON supports json.Marshaler interface
func (*AuthToken) UnmarshalEasyJSON ¶ added in v1.1.12
UnmarshalEasyJSON supports easyjson.Unmarshaler interface
func (*AuthToken) UnmarshalJSON ¶ added in v1.1.12
UnmarshalJSON supports json.Unmarshaler interface
type ClientEventHandler ¶ added in v1.1.12
type ClientEventHandler struct {
// contains filtered or unexported fields
}
ClientEventHandler gws 客户端事件处理器
func (*ClientEventHandler) OnClose ¶ added in v1.1.12
func (h *ClientEventHandler) OnClose(socket *gws.Conn, err error)
func (*ClientEventHandler) OnMessage ¶ added in v1.1.12
func (h *ClientEventHandler) OnMessage(socket *gws.Conn, message *gws.Message)
func (*ClientEventHandler) OnOpen ¶ added in v1.1.12
func (h *ClientEventHandler) OnOpen(socket *gws.Conn)
type HttpSDK ¶
type HttpSDK struct {
Domain string // API域名 (如: https://api.example.com)
AuthDomain string // 认证域名 (可选,用于/key和/login接口)
KeyPath string // 公钥获取路径 (默认: /key)
LoginPath string // 登录路径 (默认: /login)
ClientNo int64 // 客户端编号
// contains filtered or unexported fields
}
HttpSDK FreeGo HTTP客户端SDK Plan0/1:JWT + HMAC(可选 AES-GCM);Plan2:ML-KEM + ML-DSA + AES-GCM
使用模式: - PostByPlan2: Plan2 匿名访问(ML-KEM + ML-DSA,须 SetMLDSA87Object) - PostByPlan01: Plan0/1 登录后访问(JWT + HMAC,无外层 Valid)
func NewHttpSDK ¶ added in v1.1.0
func NewHttpSDK() *HttpSDK
NewHttpSDK 创建新的HttpSDK实例并设置默认值 提供便捷的构造函数,避免手动初始化所有字段
默认值: - KeyPath: "/key" - LoginPath: "/login" - timeout: 120秒 - language: "zh-CN"
返回值:
- *HttpSDK: 初始化的HttpSDK实例
使用示例:
sdk := NewHttpSDK() sdk.Domain = "https://api.example.com" sdk.ClientNo = 12345
func (*HttpSDK) AuthObject ¶ added in v1.0.98
AuthObject 设置登录认证对象 用于存储用户名、密码等登录凭据 自动登录时会使用此对象调用登录接口
参数:
- object: 认证对象,包含用户名密码等信息
注意: 请使用指针对象以避免数据拷贝
func (*HttpSDK) AuthToken ¶ added in v1.0.98
AuthToken 设置JWT认证令牌 设置登录成功后获得的令牌,用于后续API调用的身份认证
参数:
- object: AuthToken结构体,包含token、secret、expired字段
安全特性: - Token: JWT令牌,用于身份验证 - Secret: 动态生成的AES密钥,用于数据加密 - Expired: 令牌过期时间
注意: 此方法会覆盖之前设置的令牌
func (*HttpSDK) GetPublicKey ¶
GetPublicKey 获取服务端 ML-KEM 封装公钥并执行客户端封装(Plan2 /key)。
func (*HttpSDK) PostByPlan01 ¶ added in v1.1.22
func (s *HttpSDK) PostByPlan01(path string, requestObj, responseObj interface{}, encrypted bool) error
PostByPlan01 通过 JWT 认证发送 POST 请求(Plan0/1,无外层 Valid 签名) 适用于登录后的业务 API 调用,使用令牌进行身份认证
安全协议栈: 1. TLS 1.2+ (网络层加密) 2. JWT令牌认证 (身份验证) 3. AES-GCM或Base64 (数据加密,可选) 4. HMAC-SHA256 (数据完整性)
执行流程: 1. 检查认证状态,自动登录 (如果需要) 2. 获取认证令牌 (Token + Secret) 3. 根据encrypted参数选择加密方式 4. 生成HMAC-SHA256签名 5. 发送HTTP请求 (Authorization头) 6. 验证响应HMAC签名 7. 解密响应数据
参数:
- path: API路径,如"/user/info"
- requestObj: 请求数据对象
- responseObj: 响应数据对象指针
- encrypted: 是否使用AES-GCM加密 (true=Plan1, false=Plan0)
返回值:
- error: 请求失败时的错误信息
安全特性: - JWT令牌认证: 身份验证和授权 - 动态Secret: 每次登录生成新的AES密钥 - 可选加密: 支持明文(Base64)和加密传输 - 外层 Valid 签名仅 Plan2(PostByPlan2)使用 ML-DSA
使用场景: - 用户登录后的业务API调用 - 需要身份认证的接口 - 中等安全要求的场景
性能特点: - 比 PostByPlan2(Plan2 / ML-KEM 协商)更快:复用令牌,无每请求协商 - 支持高并发 (令牌复用) - 适合高频API调用
注意: - 需要预先登录或设置有效的authToken - 会自动处理令牌过期和续期
func (*HttpSDK) PostByPlan2 ¶ added in v1.1.22
PostByPlan2 通过 ML-KEM + HKDF + AES-GCM + ML-DSA 发送 POST(Plan2,匿名场景)
安全协议栈 (从下到上): 1. TLS 1.2+(传输层,由部署保证) 2. ML-KEM 共享秘密 + HKDF → 会话密钥,再 AES-256-GCM 3. HMAC-SHA256 完整性 4. 双向 ML-DSA
执行流程: 1. GetPublicKey:服务端 ML-KEM 封装公钥 + 客户端封装 2. ML-KEM 得到共享字节 3. HKDF 派生对称密钥 4. AES-GCM 加密请求体 5. HMAC-SHA256 6. ML-DSA 签名 7. 发送请求 8. 校验响应 HMAC / ML-DSA 9. AES-GCM 解密响应
参数:
- path: API路径,如"/user/info"
- requestObj: 请求数据对象 (会自动JSON序列化)
- responseObj: 响应数据对象指针 (会自动JSON反序列化)
返回值:
- error: 请求失败时的错误信息
安全特性: - 前向保密性 (PFS): 每次请求使用新密钥 - 完美前向保密: ML-KEM 每次协商独立共享秘密 - 双向认证: 客户端和服务端相互验证身份 - 防重放攻击: 时间戳 + Nonce机制
使用场景: - 金融交易API - 敏感数据传输 - 匿名访问但需要高安全性的接口
注意: - 每次调用都会执行完整的密钥协商流程 - 适合低频但高安全要求的API调用
func (*HttpSDK) SetClientNo ¶ added in v1.1.0
func (*HttpSDK) SetLanguage ¶ added in v1.0.107
SetLanguage 设置HTTP请求语言头 用于服务端国际化支持
参数:
- language: 语言代码,如"zh-CN"、"en-US"等
HTTP头: 设置为"Language: {language}"
func (*HttpSDK) SetMLDSA87Object ¶ added in v1.1.22
SetMLDSA87Object 配置 Plan2 客户端身份:本端 ML-DSA-87 私钥 + 服务端 ML-DSA 公钥(与 HttpNode.AddCipher 镜像)。
func (*HttpSDK) SetTimeout ¶ added in v1.0.101
SetTimeout 设置HTTP请求超时时间 控制单个API请求的最大等待时间
参数:
- timeout: 超时时间(秒),0表示使用默认120秒
默认值: 120秒 建议值: 根据网络状况设置,如30-300秒
type MessageHandler ¶ added in v1.1.0
MessageHandler 消息处理器接口
type RPC ¶ added in v1.1.0
RPC FreeGo gRPC 客户端 SDK AddCipher:*crypto.MLDSA87Object(CreateMLDSA87WithBase64:本端私钥 + 对端公钥)。 当前仅支持明文 P=0:s = SHA256(规范字段),e = ML-DSA.Sign(本端私钥, SHA256(规范字段));暂不支持 P=1。
func (*RPC) AddLocalCache ¶ added in v1.1.0
AddLocalCache 明文 RPCX 当前不在客户端使用本地缓存;保留链式 API。
func (*RPC) CallWithTimeout ¶ added in v1.1.0
func (*RPC) SetClientNo ¶ added in v1.1.0
func (*RPC) SetLanguage ¶ added in v1.1.0
func (*RPC) SetTimeout ¶ added in v1.1.0
type SocketSDK ¶ added in v1.1.0
type SocketSDK struct {
// contains filtered or unexported fields
}
func NewSocketSDK ¶ added in v1.1.0
NewSocketSDK 创建新的WebSocket SDK实例并设置默认值
domain: API域名,如"api.example.com"
默认值: - timeout: 120秒 - maxReconnectAttempts: -1(无限重连,可由 SetReconnectConfig 改为有限次数) - reconnectInterval: 1秒 - maxReconnectInterval: 8秒 - HealthPing: 15秒(建议 10–15,内部不超过 15)
返回值:
- *SocketSDK: 初始化的WebSocket SDK实例
使用示例:
sdk := NewSocketSDK("api.example.com")
sdk.AuthToken(AuthToken{...})
sdk.SetClientNo(12345)
func (*SocketSDK) AuthObject ¶ added in v1.1.0
func (s *SocketSDK) AuthObject(object interface{})
AuthObject 设置WebSocket客户端的登录认证对象 用于存储用户名、密码等登录凭据,自动登录时会使用此对象调用登录接口 object: 认证对象,包含用户名密码等信息,请使用指针对象避免数据拷贝
func (*SocketSDK) AuthToken ¶ added in v1.1.0
AuthToken 设置WebSocket客户端的JWT认证令牌 设置登录成功后获得的令牌,用于后续WebSocket消息的身份认证 object: AuthToken结构体,包含token、secret、expired字段
func (*SocketSDK) Close ¶ added in v1.1.0
func (s *SocketSDK) Close()
Close 主动关闭整个 SDK(停止所有重连和连接),并等待所有 goroutine 退出
func (*SocketSDK) ConnectWebSocket ¶ added in v1.1.0
ConnectWebSocket 建立WebSocket连接并启动相关服务(默认 /ws,可通过 SetWebSocketPath 覆盖)。 返回: 连接成功返回nil,否则返回连接失败的错误信息
func (*SocketSDK) ConnectWebSocketWithRawAuth ¶ added in v1.1.12
ConnectWebSocketWithRawAuth 使用自定义 Authorization 头建立连接(适合 plan2 首连)。
func (*SocketSDK) DisableReconnect ¶ added in v1.1.0
func (s *SocketSDK) DisableReconnect()
DisableReconnect 禁用自动重连
func (*SocketSDK) DisconnectWebSocket ¶ added in v1.1.0
func (s *SocketSDK) DisconnectWebSocket()
DisconnectWebSocket 断开WebSocket连接,停止所有相关服务
func (*SocketSDK) EnableReconnect ¶ added in v1.1.0
func (s *SocketSDK) EnableReconnect()
func (*SocketSDK) ForceReconnect ¶ added in v1.1.0
ForceReconnect 强制重新连接WebSocket,适用于连接异常恢复 返回: 重连成功返回nil,否则返回重连失败的错误信息
func (*SocketSDK) GetClientNo ¶ added in v1.1.14
GetClientNo 返回当前客户端编号(只读)。
func (*SocketSDK) GetReconnectStatus ¶ added in v1.1.0
func (*SocketSDK) GetSubscriptions ¶ added in v1.1.0
func (s *SocketSDK) GetSubscriptions() map[string]*Subscription
GetSubscriptions 获取所有活跃的订阅
func (*SocketSDK) GetWebSocketPlan2Auth ¶ added in v1.1.12
GetWebSocketPlan2Auth 通过 /key 路由完成 key 协商,返回用于重连的 raw Authorization 与共享密钥。
func (*SocketSDK) IsWebSocketConnected ¶ added in v1.1.0
IsWebSocketConnected 检查WebSocket连接是否处于活跃状态 返回: true表示连接正常,false表示连接已断开
func (*SocketSDK) LoginByWebSocketPlan2 ¶ added in v1.1.12
func (s *SocketSDK) LoginByWebSocketPlan2(loginRouter string, requestObj interface{}, sharedKey []byte, timeout int64) error
LoginByWebSocketPlan2 通过 WebSocket plan2 登录,并自动写入 AuthToken。
func (*SocketSDK) LoginByWebSocketPlan2Auto ¶ added in v1.1.12
func (s *SocketSDK) LoginByWebSocketPlan2Auto(keyRouter, loginRouter string, requestObj, responseObj interface{}, timeout int64) error
LoginByWebSocketPlan2Auto 自动完成 WS plan2 的 key + login 全流程,并将登录响应写入 responseObj。 连接路径默认使用 SDK 当前路径配置(默认 /ws,可通过 SetWebSocketPath 覆盖)。
func (*SocketSDK) SendWebSocketMessage ¶ added in v1.1.0
func (s *SocketSDK) SendWebSocketMessage(router string, requestObj, responseObj interface{}, waitResponse, encryptRequest bool, timeout int64) error
SendWebSocketMessage 发送WebSocket业务消息并可选等待响应 router: 业务路由标识符,用于服务端路由分发 requestObj: 请求数据对象 responseObj: 响应数据对象,用于接收服务端返回数据(当waitResponse=true时) waitResponse: 是否等待服务端响应 encryptRequest: 是否对请求数据进行加密 timeout: 等待响应的超时时间(秒) 返回: 发送成功返回nil,否则返回发送失败的错误信息
func (*SocketSDK) SendWebSocketPlan2Message ¶ added in v1.1.12
func (s *SocketSDK) SendWebSocketPlan2Message(router string, requestObj, responseObj interface{}, sharedKey []byte, timeout int64) error
SendWebSocketPlan2Message 发送 plan2 消息(AES-GCM + HMAC + ML-DSA),用于 key/login 等流程。
func (*SocketSDK) SendWebSocketRawBody ¶ added in v1.1.12
func (s *SocketSDK) SendWebSocketRawBody(body *node.JsonBody, waitResponse bool, timeout int64) (*node.JsonResp, error)
SendWebSocketRawBody 直接发送已构造好的 JsonBody(用于 plan2/key-login 等自定义流程)。
func (*SocketSDK) SetBroadcastKey ¶ added in v1.1.5
SetBroadcastKey 广播数据密钥
func (*SocketSDK) SetClientNo ¶ added in v1.1.0
func (*SocketSDK) SetDomain ¶ added in v1.1.14
SetDomain 设置 WebSocket 连接的域名或 host:port(如 api.example.com 或 api.example.com:443)。
func (*SocketSDK) SetHealthPing ¶ added in v1.1.0
SetHealthPing 设置心跳间隔(秒)。建议 10–15 秒,与服务端读超时策略匹配;内部限制最大 15 秒,超过则按 15 秒生效。
func (*SocketSDK) SetLanguage ¶ added in v1.1.0
SetLanguage 设置WebSocket请求的语言标识 language: 语言代码,如"zh-CN"、"en-US",用于服务端国际化支持
func (*SocketSDK) SetMLDSA87Object ¶ added in v1.1.22
SetMLDSA87Object 配置 Plan2 WebSocket 客户端身份(与服务端 WsServer.AddCipher 镜像)。
func (*SocketSDK) SetPushMessageCallback ¶ added in v1.1.0
SetPushMessageCallback 设置服务端主动推送消息的回调函数
func (*SocketSDK) SetRawAuthorization ¶ added in v1.1.12
SetRawAuthorization 设置连接时直接使用的 Authorization 头(如 plan2 场景)。
func (*SocketSDK) SetReconnectConfig ¶ added in v1.1.0
func (*SocketSDK) SetTimeout ¶ added in v1.1.0
SetTimeout 设置WebSocket请求的超时时间 timeout: 超时时间(秒),控制WebSocket消息发送和等待响应的最大时间
func (*SocketSDK) SetTokenExpiredCallback ¶ added in v1.1.0
func (s *SocketSDK) SetTokenExpiredCallback(callback func())
func (*SocketSDK) SetWebSocketPath ¶ added in v1.1.12
SetWebSocketPath 设置连接路径。默认固定 /ws,若要覆盖需显式调用本方法。
func (*SocketSDK) SubscribeMessage ¶ added in v1.1.0
func (s *SocketSDK) SubscribeMessage(router string, handler MessageHandler) (subscriptionID string, err error)
SubscribeMessage 订阅指定路由的消息 SubscribeMessage 订阅指定路由的消息推送 router: 要订阅的路由标识符 handler: 消息处理函数,当接收到对应路由的消息时会被调用 返回: 订阅ID和可能的错误信息
func (*SocketSDK) UnsubscribeMessage ¶ added in v1.1.0
UnsubscribeMessage 取消消息订阅 UnsubscribeMessage 取消订阅指定路由的消息推送 router: 要取消订阅的路由标识符 返回: 取消订阅成功返回nil,否则返回错误信息
type Subscription ¶ added in v1.1.0
type Subscription struct {
ID string
Router string
Handler MessageHandler
// contains filtered or unexported fields
}
Subscription 订阅信息