TeamTalk路由服务器

路由相关信令和协议设计

复制代码
enum BuddyListCmdID {
  // ...... 暂时省略无关信令
  CID_BUDDY_LIST_USERS_STATUS_REQUEST = 522,
  CID_BUDDY_LIST_USERS_STATUS_RESPONSE = 523,
  // ...... 暂时省略无关信令
};

message IMUsersStatReq{
	//cmd id:		0x020a
	required uint32 user_id = 1;
	repeated uint32 user_id_list = 2;
	optional bytes attach_data = 20;
}

message IMUsersStatRsp{
	//cmd id:		0x020b
	required uint32 user_id = 1;
	repeated IM.BaseDefine.UserStat user_stat_list = 2;
	optional bytes attach_data = 20;
}

enum UserStatType{
	USER_STATUS_ONLINE 	= 1;
	USER_STATUS_OFFLINE	= 2;
	USER_STATUS_LEAVE	= 3;
}

流程图

具体代码逻辑

  1. 在 g_user_map 中根据 user_id 查找对应的状态

  2. 如果不在列表设置为下线状态;如果在列表设置为对应的状态;

  3. 组包回复

    void CRouteConn::_HandleUsersStatusRequest(CImPdu* pPdu)
    {
    IM::Buddy::IMUsersStatReq msg;
    CHECK_PB_PARSE_MSG(msg.ParseFromArray(pPdu->GetBodyData(), pPdu->GetBodyLength()));

    复制代码
     uint32_t request_id = msg.user_id();
     uint32_t query_count = msg.user_id_list_size();
     log("HandleUserStatusReq, req_id=%u, query_count=%u ", request_id, query_count);
    
     IM::Buddy::IMUsersStatRsp msg2;
     msg2.set_user_id(request_id);
     msg2.set_attach_data(msg.attach_data());
     list<user_stat_t> result_list;
     user_stat_t status;
     for(uint32_t i = 0; i < query_count; i++)
     {
         IM::BaseDefine::UserStat* user_stat = msg2.add_user_stat_list();
         uint32_t user_id = msg.user_id_list(i);
         user_stat->set_user_id(user_id);
         CUserInfo* pUser = GetUserInfo(user_id);
         if (pUser) {
             user_stat->set_status((::IM::BaseDefine::UserStatType) pUser->GetStatus()) ;
         }
     	else
     	{
             user_stat->set_status(USER_STATUS_OFFLINE) ;
     	}
     }
    
     // send back query user status
     CImPdu pdu;
     pdu.SetPBMsg(&msg2);
     pdu.SetServiceId(SID_BUDDY_LIST);
     pdu.SetCommandId(CID_BUDDY_LIST_USERS_STATUS_RESPONSE);
     pdu.SetSeqNum(pPdu->GetSeqNum());
     SendPdu(&pdu);

    }

    CUserInfo* GetUserInfo(uint32_t user_id)
    {
    CUserInfo* pUser = NULL;
    UserInfoMap_t::iterator it = g_user_map.find(user_id);
    if (it != g_user_map.end()) {
    pUser = it->second;
    }

    复制代码
     return pUser;

    }

相关推荐
码事漫谈5 分钟前
C++死锁深度解析:从成因到预防与避免
后端
码事漫谈10 分钟前
智能体颠覆教育行业:现状、应用与未来展望调研报告
后端
蓝-萧12 分钟前
【玩转全栈】----Django基本配置和介绍
java·后端
priority_key12 分钟前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
韩立学长12 分钟前
基于Springboot的旧时月历史论坛4099k6s9(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
cccccc语言我来了16 分钟前
(Linux (6):从包管理到工具探索,构建系统操作基础认知)
linux·运维·服务器
不染尘.1 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
似水এ᭄往昔1 小时前
【C++】--stack和queue
开发语言·c++
仰望—星空1 小时前
MiniEngine学习笔记 : CommandListManager
c++·windows·笔记·学习·cg·direct3d
wuk9981 小时前
CentOS7环境搭建L2TP服务器
运维·服务器