卓 432e2a5996 发起和结束咨询的消息由系统发出,发送者ID记录操作人! | %!s(int64=8) %!d(string=hai) anos | |
---|---|---|
doc | %!s(int64=8) %!d(string=hai) anos | |
docker | %!s(int64=8) %!d(string=hai) anos | |
src | %!s(int64=8) %!d(string=hai) anos | |
test | %!s(int64=8) %!d(string=hai) anos | |
.gitignore | %!s(int64=8) %!d(string=hai) anos | |
readme.md | %!s(int64=8) %!d(string=hai) anos |
此项目是家庭医生的消息服务器,含医生端与患者端。医生端使用REST API收发消息,患者端使用Web Socket收发消息。
项目代码使用git管理,请安装git客户端并fork代码再下载修改。
数据库设计是将消息按通道分开:系统消息,个人消息及群消息。
对Windows环境,可以预先安装Node.js。对Linux环境,代码包中包含Node.js程序,第一次部署需要使用chmod为此增加执行权限chmod +x node
,之后通过以下命令启动消息服务器:
node app.armour.js
启动成功将出现如下日志:
[INFO] app.js(125,5): Starting IM server, version 1.0.5.20161107, running on port 3000, 2016-11-22 16:00:17
[INFO] app.js(126,5): Configuration profile: dev
测试框架使用mocha。REST客户端使用supertest。should模块提供断言测试。测试用例位于test目录,并根据模块划分。
部署服务之前需要配置环境变量IM_PROFILE,Windows平台直接在系统中配置,Linux平台在profile中配置:
export IM_PROFILE=prod
IM_PROFILE值将决定应用加载的配置文件,配置文件位于src/resources/config。IM_PROFILE值为prod, test, dev中的一个。若配置错误服务将无法运行。若未配置此参数则默认使用dev配置。
为保证服务正常运行,当服务异常退出时自动重启服务,IM服务器使用app.armour.js脚本,对进程添加保护:进程异常退出时,自动重启。为实现此目标,部署时通过appArmour启动服务即可实现进程的守护功能。
未完工
未完工
使用bearcat库。
使用bluebird库。
IM提供了开发SDK,一个JS脚本。客户端可以通过引用此脚本或将此脚本打包到资源中。此外,脚本使用jQuery作为基础环境,因此客户端需要预先引用jQuery脚本。客户端通过以下链接引用SDK文件
<script src='http://host:port/sdk/im.client.js'></script>
应用根据MVC模式设计。但REST API只用到Model与Controller两部分,与页面相关的会使用到View层。Model层代码位于model,View层代码位于views,Controller层分两处存放:
控制层提供两种类型的API:含有回调与不含回调。不含回调的API通过事件向外发送消息,用于与controller之间的交互。含回调的API通过回调与其他API交互,用于模型之间的交互。
实时与延时
Node.js支持同步与异步调用,也导致了异常错误处理与众不同。一个给定的函数,它处理异常的方式要么是同步(用 throw方式)要么是异步的(用 callback 或者 EventEmitter),不会两者兼具。 用户可以在回调函数里处理错误,也可以使用 try/catch捕获异常 ,但是不能一起用。
实际上,使用throw并且期望调用者使用 try/catch 是很罕见的,因为 NodeJS里的同步函数通常不会产生运行失败(主要的例外是类似于JSON.parse的用户输入验证函数)。
本节将简要描述服务所提供的API,包括消息收发,运行状态及成员维护等。API分为两种:REST与WebSocket。
REST API遵循REST最佳实践,规范命名URL中的每个部分。注意POST请求是将数据作为请求体发送。下文中的host:port分别表示服务所在的主机地址及端口。
1 发送系统消息
POST http://host:port/api/v1/chats/sm
参数格式
{
to: "Rose",
title: "System Message",
summary: "You have new job",
contentType: "1",
content: "The patient has been followed in the scheduler, please make new follow plan as soon as possible."
}
2 发送P2P消息
GET http://192.168.131.115:3000/api/v1/chats/pm
参数格式
{
from: 发送人ID,
to: 接收人ID,
contentType: 内容类型,1为普通文本,2为图片,3为语音,4为超链接,
content: "消息内容"
}
3 发送群消息
POST http://192.168.131.115:3000/api/v1/chats/gm
参数格式
{
from: 发送人ID,
at: at对象ID,
group: 组ID,
groupType: 组类别
contentType: 内容类型,1为普通文本,2为图片,3为语音,4为超链接,
content: "消息内容"
}
4 获取消息
GET http://192.168.131.115:3000/api/v1/chats/pm?user_id=xxx
参数:
Web Socket提供页面内长连接,并且能够通过Web Socket收发消息。