AVSConnectionManager 类为客户端无缝地管理与AVS的连接
功能简介
- 失败时连接重试
- 允许后续重新连接
- ping管理
- AVS服务器断开时周期重连服务器
- 允许客户端完全启用或禁用连接管理器
- 允许客户端重置AVSConnectionManager的内部逻辑
UML 图集
完整类图
精简类图
对象调用
依赖接口
- AVSConnectionManagerInterface
该类反映了客户端与AVS之间的连接以及如何观测它
- virtual void enable() = 0
- 启用AVSConnectionManager对象与AVS建立连接
- 调用此函数后尝试创建一个与AVS之间的连接
- 如果对象已连接则什么也不做
- virtual void disable() = 0
- 禁用AVSConnectionManager对象与AVS之间的连接
- 如果与AVS的连接已建立调用此函数将断开连接
- 如果未连接则什么也不做
- virtual bool isEnabled() = 0
- 返回是否启用AVSConnectionManager建立与AVS之间的连接
- virtual void reconnect() = 0
- 创建与AVS之间的一个新连接
- 如果已建立连接则断开当前连接并重新建立一个新的连接
- 如果未连接但处于尝试等待下一个连接的过程中,内部将采用重置策略并立刻尝试建立一个新的连接
- 如果enable未启用则什么也不做
- virtual bool isConnected() const = 0;
- 返回与AVS连接是否已建立,如果连接处于pending状态也会返回false
- virtual void addMessageObserver(std::shared_ptr(avsCommon::sdkInterfaces::MessageObserverInterface) observer) = 0
- 添加接收消息通知的观察者
- virtual void removeMessageObserver( std::shared_ptr(avsCommon::sdkInterfaces::MessageObserverInterface) observer) = 0
- 移除一个接收消息通知的观察者
- virtual void addConnectionStatusObserver(std::shared_ptr(ConnectionStatusObserverInterface) observer) = 0
- 添加连接状态变更通知的观察者
- 状态通知在更改函数返回前通知
- virtual void removeConnectionStatusObserver(std::shared_ptr(ConnectionStatusObserverInterface) observer) = 0
- 移除连接状态
- AbstractAVSConnectionManager
该类实现了AVSConnectionManagerInterface接口中添加和移除观察者及通知移除所有观察者的功能
- 实现 addConnectionStatusObserver 接口
- 添加新的连接状态观察者
- 将当前连接状态及更改原因通知给新增的观察者
- 实现 removeConnectionStatusObserver(std::shared_ptr(ConnectionStatusObserverInterface) observer) 接口
- 删除该连接状态观察者
- 构造函数 AbstractAVSConnectionManager(std::unordered_set(std::shared_ptr(ConnectionStatusObserverInterface)) observers))
- 观察对象集合赋值
- 默认状态为Status::DISCONNECTED
- 默认原因为ChangedReason::ACL_CLIENT_REQUEST
- void updateConnectionStatus(ConnectionStatusObserverInterface::Status status, ConnectionStatusObserverInterface::ChangedReason reason)
- 更新链接状态
- status 连接状态
- reason 更新原因
- void notifyObservers()
- 通知所有观察者当前连接状态及更新原因
- void clearObservers()
- 清空所有已注册连接状态通知的观察者
- MessageSenderInterface
指定一个发送消息的接口
- void sendMessage(std::shared_ptr(avs::MessageRequest) request) = 0
- 发送消息
- 该消息必须是异步实现的
- 内部先存储此消息直至连接可用才发送
- MessageRequest::onSendCompleted 回调函数处理发送结果
- 如果连接处于连接状态回调函数返回值合适的值,否则返回NOT_CONNECTED。
- MessageRouterObserverInterface
该类通过友元的方式允许MessageRouter及其继承类发送通知至此类,而不用通过公有方法中的注册观察者的方式。可接收连接状态通知和接收来自AVS的消息。
- virtual void onConnectionStatusChanged(ConnectionStatusObserverInterface::Status status, ConnectionStatusObserverInterface::ChangedReason reason) = 0
- 连接状态变更时该函数被调用
- virtual void receive(const std::string& contextId, const std::string& message) = 0
- 接收到AVS消息时该函数被调用
枚举值和常量
- ConnectionStatusObserverInterface
- Status 连接状态
- DISCONNECTED 客户端未与AVS服务器建立连接
- PENDING 客户端正尝试与AVS服务器建立连接
- CONNECTED 客户端与AVS服务器已建立连接
- ChangedReason 连接状态改变原因
- ACL_CLIENT_REQUEST 客户端通过公有API调用
- ACL_DISABLED 因为调用了AVSConnectionManagerInterface::disable()函数
- DNS_TIMEDOUT DNS解析超时
- CONNECTION_TIMEDOUT 连接超时
- CONNECTION_THROTTLED 服务器满负荷
- INVALID_AUTH LWA认证无效
- PING_TIMEDOUT PING超时
- WRITE_TIMEDOUT 往AVS服务器写数据超时
- READ_TIMEDOUT 从AVS服务器读数据超时
- FAILURE_PROTOCOL_ERROR 发生潜在的协议错误
- INTERNAL_ERROR ACL内部错误(ACL为AVS网络通信库)
- SERVER_INTERNAL_ERROR AVS服务器内部错误
- SERVER_SIDE_DISCONNECT AVS服务器请求客户端重连
- SERVER_ENDPOINT_CHANGED AVS服务器端点(IP和端口号)已改变
- Status 连接状态