AVS 通信模块之AVSConnectionManager

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和端口号)已改变
posted @ 2018-11-07 18:04  {[(沙加)]}  阅读(656)  评论(0编辑  收藏  举报