统一IM方案,Android端sdk
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

推送+IM.md 5.8KB

1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346
  1. [TOC]
  2. > 消息协议需要调研一下,需求可以服务端转发消息
  3. # 消息体
  4. ## 基础结构
  5. ```json
  6. {
  7. "id": "",
  8. "from": "",
  9. "to": "",
  10. "tenantNo": "",
  11. "target": "",
  12. "type": "Type",
  13. "content": {
  14. },
  15. "timestamp": 1675416709033,
  16. "isBackground": false
  17. }
  18. ```
  19. > 部分说明
  20. >
  21. > id 为发送端随机数,用来去重
  22. >
  23. > `单聊` -> from 发送者 to 接收者 服务器直接转发
  24. >
  25. > `群聊`-> 发送消息体:from发送者、to群、target接收者;接收消息体:from群、to接收者、target发送者
  26. ### Type
  27. ```java
  28. public enum MsgType {
  29. UNKNOWN(-1), // 未知消息
  30. TEXT(0), // 文本消息
  31. }
  32. ```
  33. ### 异常上报
  34. ### 文本(text)
  35. ```json
  36. {
  37. "text": ""
  38. }
  39. ```
  40. ### 图片(image)
  41. ```json
  42. {
  43. "storageId": "",
  44. "thumbnail": "",
  45. "thumbnailWidth": 100,
  46. "thumbnailHeight": 100
  47. }
  48. ```
  49. ### 语音(audio)
  50. ```json
  51. {
  52. "storageId": "",
  53. "duration": 152
  54. }
  55. ```
  56. ### 视频
  57. ```json
  58. {
  59. "storageId": "",
  60. "fileName": "",
  61. "fileSize": "",
  62. "duration": 100,
  63. "thumbnail": "",
  64. "thumbnailWidth": 100,
  65. "thumbnailHeight": 100
  66. }
  67. ```
  68. ### 文件
  69. ```json
  70. {
  71. "storageId": "",
  72. "fileName": "",
  73. "fileSize": "",
  74. "duration": 100,
  75. "mimeType": "video/3gpp"
  76. }
  77. ```
  78. ### 位置
  79. ```json
  80. ```
  81. ### 通知
  82. ```json
  83. {
  84. "title": "",
  85. "content": "",
  86. "action": "",
  87. "appid": "",
  88. "appName": "",
  89. "appLogo": "",
  90. "url": ""
  91. }
  92. ```
  93. ### 后台运行
  94. > 组织架构类,大数据,后台更新
  95. >
  96. > 视频通话邀请
  97. ```json
  98. {
  99. "type": "",
  100. "content": {}
  101. }
  102. ```
  103. ### 音视频通话
  104. ```json
  105. {
  106. "status": "",
  107. "avType": "",
  108. "uid": "",
  109. "roomId": "",
  110. "timestamp": 1675416709033,
  111. "useTime": 1675416709033,
  112. "agoraKey": 1675416709033
  113. }
  114. ```
  115. >
  116. >status
  117. >
  118. > //邀请invite 拒绝refuse 取消cancel 超时timeout 占线busy
  119. >
  120. > // 已在其他设备接听other_answer(256推送消息)
  121. >
  122. > // 已在其他设备拒绝other_refuse(根据fromid == account判断)
  123. >
  124. > uid // 前端展示邀请人所用
  125. >
  126. > useTime //本地纪录的用时,单位秒
  127. >
  128. > agoraKey //声网key
  129. ```java
  130. enum OsType {
  131. IOS(1),
  132. ANDROID(2),
  133. WEB(3),
  134. WINDOWS(4),
  135. UNKNOWN(-1)
  136. }
  137. ```
  138. ### 应用消息
  139. > 区分子应用,提高分配效率
  140. >
  141. > 处方单
  142. ```json
  143. {
  144. "title": "",
  145. "content": "",
  146. "action": "",
  147. "appid": "",
  148. "appName": "",
  149. "appLogo": "",
  150. "url": ""
  151. }
  152. ```
  153. ### 扩展
  154. > 应对未定义消息,细微拓展。
  155. >
  156. ```json
  157. {}
  158. ```
  159. ## 消息收发机制
  160. ```mermaid
  161. sequenceDiagram
  162. Title: 基础流程(MQTT)
  163. actor APP
  164. actor SDK
  165. actor 服务端
  166. actor 厂商
  167. critical 启动
  168. SDK -->> SDK: 获取设备信息、生成唯一码、获取对应厂商的pushTOken,缓存本地
  169. APP ->> SDK: 服务初始化,提供userId
  170. SDK ->> 服务端: 提供设备信息、唯一码、pushToken以及userId,注册im服务
  171. 服务端 -->> 服务端: 保证每一个唯一码只有一个对应的pushToken等信息(历史唯一码标识只为注销),生成account。
  172. 服务端 ->> SDK: 返回account,im服务器信息(域名,端口等)
  173. SDK -->> SDK: 连接im服务,订阅account
  174. end
  175. critical 发送消息
  176. APP ->> SDK: 发送消息api
  177. SDK ->> 服务端: 整理消息发送
  178. alt 单聊
  179. 服务端->>服务端: 原消息留档后发送
  180. else 群聊
  181. 服务端->>服务端: 原消息留档后,重构消息,发送给群里所有人。<br/>
  182. end
  183. 服务端 ->> SDK: 消息送达
  184. 服务端 ->> 厂商: 根据是否开启推送以及sdk是否在线,决定是否需要厂商推送
  185. 厂商 ->> APP: 厂商推送
  186. SDK ->> SDK: 去重(?修改状态,是同id消息,还是消息体体现)<br/>、存表
  187. SDK ->> APP: 通知消息送达
  188. alt im推送
  189. APP ->> APP: 根据实际情况,决定是直接使用通知里的消息,还是查表获取。
  190. else 厂商推送
  191. APP ->> APP: 点击通知栏动作(服务端可以配置)
  192. end
  193. end
  194. critical 应用消息
  195. Note right of 服务端: 第三方服务获取token(权限认证,类似有appId获取autoTOken之类)
  196. Note right of 服务端: 设置群组api、标签api等
  197. Note right of 服务端: 调用发送消息api
  198. alt 单聊、群聊
  199. 服务端->>服务端: 原消息留档后发送指定人员或者群组
  200. else 所有人
  201. 服务端->>服务端: 原消息留档后,发送到所有用户
  202. end
  203. 服务端 ->> SDK: 消息送达
  204. 服务端 ->> 厂商: 根据是否开启推送以及sdk是否在线,决定是否需要厂商推送
  205. 厂商 ->> APP: 厂商推送
  206. SDK ->> SDK: 去重(?修改状态,是同id消息,还是消息体体现)<br/>、存表
  207. SDK ->> APP: 通知消息送达
  208. alt im推送
  209. APP ->> APP: 根据实际情况,决定是直接使用通知里的消息,还是查表获取。
  210. else 厂商推送
  211. APP ->> APP: 点击通知栏动作(服务端可以配置)
  212. end
  213. end
  214. critical 历史消息、离线消息
  215. alt 历史消息
  216. APP ->> SDK: 获取离线消息api
  217. SDK ->> 服务端: 获取离线消息(开始时间)
  218. 服务端 ->> SDK: 消息送达
  219. SDK ->> APP: 通知消息送达
  220. APP ->> APP: 查表获取
  221. else 离线消息
  222. APP ->> SDK: 获取历史消息api
  223. SDK ->> 服务端: 获取离线消息
  224. 服务端 ->> 服务端: 根据target判断是获取所有还是单人
  225. 服务端 ->> SDK: 消息送达
  226. SDK ->> APP: 通知消息送达
  227. APP ->> APP: 查表获取
  228. end
  229. end
  230. critical 注销、停用推送
  231. par 停用推送
  232. APP ->> SDK: 请求关闭推送
  233. SDK ->> 服务端: 请求关闭推送
  234. 服务端 -->> 服务端: 关闭推送标识(或者直接删除pushtoken?)
  235. and 注销
  236. APP ->> SDK: 注销
  237. SDK ->> 服务端: 注销
  238. 服务端 -->> 服务端: 针对这个account对应的唯一码,修改状态为已注销
  239. end
  240. end
  241. ```