commons.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. /**
  2. * 此文件内容为常用的系统枚举及变量。
  3. */
  4. /**
  5. * 系统部署时的配置文件。
  6. *
  7. * @type {string}
  8. */
  9. "use strict";
  10. let configFile = "config.";
  11. if (process.env.IM_PROFILE === "prod") {
  12. configFile += "prod";
  13. } else if (process.env.IM_PROFILE === "prodPC") {
  14. configFile += "prodPC";
  15. } else if (process.env.IM_PROFILE === "test") {
  16. configFile += "test";
  17. } else {
  18. configFile += "dev";
  19. }
  20. exports.CONFIG_FILE = configFile;
  21. /**
  22. * 会话类型
  23. */
  24. const SESSION_TYPES = {
  25. SYSTEM: 0, // 系统会话
  26. MUC: 1, // MUC会话
  27. P2P: 2, // P2P
  28. GROUP: 3, // 固定组
  29. DISCUSSION: 4, // 临时讨论组
  30. PRESCRIPTION: 8, // 续方
  31. PRESCRIPTION_HOSPITAL:9,//医院在线复诊
  32. ONDOOR_NURSING:11 //上门护理
  33. };
  34. exports.SESSION_TYPES = SESSION_TYPES;
  35. /**
  36. * 会话状态
  37. */
  38. const TOPIC_STATUS = {
  39. NEW: 0, // 新建
  40. PROCEEDINGS: 1, // 进行中
  41. ENDED: 10 // 结束
  42. };
  43. exports.SESSION_STATUS = {
  44. PROCEEDINGS: 0, // 进行中
  45. ENDED:1 // 结束
  46. };
  47. /**
  48. * 会话业务类型
  49. */
  50. exports.SESSION_BUSINESS_TYPE = {
  51. PATIENT: 2,//针对患者
  52. DOCTOR: 1//针对医生
  53. };
  54. exports.TOPIC_STATUS = TOPIC_STATUS;
  55. /**
  56. * 会话参与者角色
  57. */
  58. const PARTICIPANT_ROLES = {
  59. HOST: 0,//主持者
  60. REGULAR: 1,//普通参与者
  61. BYSTANDER: 10//旁听者
  62. };
  63. exports.PARTICIPANT_ROLES = PARTICIPANT_ROLES;
  64. /**
  65. * 消息内容类型。
  66. */
  67. const CONTENT_TYPES = {
  68. PlainText: 1, // 信息
  69. Image: 2, // 图片信息
  70. Audio: 3, // 语音信息
  71. Article: 4, // 文章信息
  72. GoTo: 5, // 跳转信息,求组其他医生或者邀请其他医生发送的推送消息
  73. TopicBegin: 6, // 议题开始
  74. TopicEnd: 7, // 议题结束 10 11 系统发送的会话消息
  75. TopicInto: 14, // 进入议题 系统发送的会话消息
  76. Video:12,//视频
  77. System:13,//系统消息
  78. PrescriptionCheck:15,//续方审核消息消息
  79. typeToDescription: function (type, defaultDescription) {
  80. if (CONTENT_TYPES.Image == type) {
  81. return '[图片]';
  82. } else if (CONTENT_TYPES.Audio == type) {
  83. return '[语音]';
  84. }
  85. else if (CONTENT_TYPES.Video == type) {
  86. return '[视频]';
  87. }
  88. else if (type > 3) {
  89. return defaultDescription;
  90. }
  91. return false;
  92. }
  93. };
  94. exports.CONTENT_TYPES = CONTENT_TYPES;
  95. exports.SOCKET_TYPES={
  96. PATIENT:"patient",
  97. DOCTOR:"doctor",
  98. PC_DOCTOR:"pc_doctor",
  99. DEMO:"demo"
  100. }
  101. /**
  102. * 客户端平台。
  103. */
  104. exports.PLATFORM = {
  105. iOS: 0,
  106. Android: 1,
  107. PC: 3,
  108. Wechat: 10
  109. };
  110. /**
  111. * 组类型。
  112. */
  113. exports.GROUP_TYPE = {
  114. AdminTeam: 1,
  115. DiscussionGroup: 2
  116. };
  117. /**
  118. * 模型事件。
  119. *
  120. * @type {{Error: string, DataNotFound: string, OK: string}}
  121. */
  122. exports.MODEL_EVENTS = {
  123. Error: "error", // 数据库访问出错
  124. DataNotFound: "no_data", // 找不到指定的数据
  125. OK: "ok", // 操作结束或有数据返回
  126. Exists: "exists" // 数据已存在
  127. };
  128. /**
  129. * 整型最大值。
  130. */
  131. exports.MAX_INT = 9007199254740992;
  132. /**
  133. * 置顶会话基础分值,以此为下限向上递增。
  134. */
  135. exports.STICKY_SESSION_BASE_SCORE = 9000000000000;
  136. /**
  137. * 默认分页大小。
  138. */
  139. exports.DEFAULT_PAGE_SIZE = 100;
  140. /**
  141. * Redis Key列表与占位符。
  142. */
  143. const REDIS_KEY_REPLACER = "{id}";
  144. exports.REDIS_KEY_REPLACER = REDIS_KEY_REPLACER;
  145. exports.SESSION_USER_STATUS = {
  146. ONLINE: 0,
  147. OTHER: 1
  148. };
  149. exports.REDIS_KEYS = {
  150. Users: "users:",
  151. User: "users:" + REDIS_KEY_REPLACER,
  152. UserAppStatus: "users:" + REDIS_KEY_REPLACER + ":app_status",
  153. UserPcStatus: "users:" + REDIS_KEY_REPLACER + ":pc_status",
  154. UserWechatStatus: "users:" + REDIS_KEY_REPLACER + ":wechat_status",
  155. UserSessions: "users:" + REDIS_KEY_REPLACER + ":sessions",
  156. Sessions: "sessions:",
  157. Session: "sessions:" + REDIS_KEY_REPLACER,
  158. SessionParticipants: "participants:" + REDIS_KEY_REPLACER,
  159. SessionParticipantsRole: "participants:" + REDIS_KEY_REPLACER + ":role",
  160. Topics: "sessions:" + REDIS_KEY_REPLACER + ":topics",
  161. Topic: "topics:" + REDIS_KEY_REPLACER,
  162. Messages: "sessions:" + REDIS_KEY_REPLACER + ":messages",
  163. MessagesByTimestamp: "sessions:" + REDIS_KEY_REPLACER + ":messages_by_timestamp"
  164. };
  165. const DB_TABLES = {
  166. Doctors: "doctors",
  167. Patients: "patients",
  168. P2pMessages: "p2p_messages",
  169. MucMessages: "muc_messages",
  170. GroupMessages: "group_messages",
  171. DiscussionMessages: "discussion_messages",
  172. SystemMessages: "system_messages",
  173. Participants: "participants",
  174. Sessions: "sessions",
  175. Topics: "topics",
  176. StickySessions: "sticky_sessions",
  177. WlyyConsult:"wlyy_consults",
  178. WlyyConsultTeam:"wlyy.wlyy_consult_team",
  179. WlyyConsultS:"wlyy.wlyy_consult",
  180. sessionTypeToTableName: function (sessionType) {
  181. if (sessionType == SESSION_TYPES.SYSTEM)
  182. return DB_TABLES.SystemMessages;
  183. else if (sessionType == SESSION_TYPES.MUC)
  184. return DB_TABLES.MucMessages;
  185. else if (sessionType == SESSION_TYPES.P2P)
  186. return DB_TABLES.P2pMessages;
  187. else if (sessionType == SESSION_TYPES.GROUP)
  188. return DB_TABLES.GroupMessages;
  189. else if (sessionType == SESSION_TYPES.DISCUSSION)
  190. return DB_TABLES.DiscussionMessages;
  191. else if (sessionType == SESSION_TYPES.PRESCRIPTION)
  192. return DB_TABLES.MucMessages;
  193. else if (sessionType == SESSION_TYPES.PRESCRIPTION_HOSPITAL)
  194. return DB_TABLES.MucMessages;
  195. else if (sessionType == SESSION_TYPES.ONDOOR_NURSING)
  196. return DB_TABLES.MucMessages;
  197. else throw {message: "Unknown session type"};
  198. }
  199. };
  200. exports.DB_TABLES = DB_TABLES;