为您的 JavaScript App 接入 LeanCloud 实时通讯服务。
master 分支为开发版本。 v2 分支上为 2.x 版本,将仅得到安全更新,相关文档参见 2.x 文档。
自 v3 起遵循 语义化版本。
安装稳定版本:
npm install leancloud-realtime --save
安装 v2 版本:
npm install leancloud-realtime@2 --save
- 浏览器 / WebView
- IE 10+ / Edge
- Chrome 31+
- Firefox latest
- iOS 8.0+
- Android 4.4+
- Node.js 0.12+
- React Native 0.26+
- 微信小程序 latest
package name | 描述 | 版本 | 文档 |
---|---|---|---|
leancloud-realtime-plugin-typed-messages | 富媒体消息 | API docs | |
leancloud-realtime-plugin-groupchat-receipts | 群聊已读回执 | API docs | |
leancloud-realtime-plugin-webrtc | WebRTC 客户端 | API docs |
- 如果你发现了新的 bug,或者有新的 feature request,请新建一个 issue
- 在使用过程中遇到了问题时
- 如果你购买了技术支持服务,请新建一个 ticket。
- 也可以在 论坛 提问、讨论。
如果你希望为这个项目贡献代码,请按以下步骤进行:
- Fork 这个项目,clone 到本地
- 在目录中执行
npm install
安装所需 Node.js 依赖包 - 在目录中执行
bower install
安装所需 web 依赖包 - 执行
grunt dev
浏览器打开 本地进行调试 - 编码,更新测试用例
- 运行
npm test
确保测试全部 pass - 提交改动,请遵循 conversational commit message 风格
- 发起 Pull Request 至 master 分支
.
├── demo
├── deploy.sh // 部署 gh-pages 分支
├── release.sh // 部署 dist 分支
├── dist // 打包产出 (dist 分支)
│ ├── realtime.browser.js // 浏览器用
│ ├── realtime.browser.min.js // 浏览器用(uglified)
│ ├── realtime.weapp.js // 微信小程序用
│ └── realtime.js // node 用
├── proto
│ ├── message-compiled.js // 使用 pbjs 生成的 message 类
│ ├── message.js // ES6 wrapper
│ └── message.proto // proto 原始文件
├── src // 源码
│ └── index.js // 打包入口
├── test // 测试用例
│ ├── browser // 浏览器测试入口
│ └── index.js // 测试入口
└── plugins
├── typed-messages // leancloud-realtime-plugin-typed-messages package
└── webrtc // leancloud-realtime-plugin-webrtc package
SDK 分为连接层与应用层两部分,只存在应用层对连接层公开 API 的调用,连接层对开发者不可见。
WebSocketPlus
:封装了 WebSocket。相比 w3 WebSocket,增加了以下特性:- 是一个有限状态机
- 实现了 Node.js EventEmitter 接口
- 超时与自动重连机制
- url 参数支持 Promise 及备用地址
Connection
:继承自WebSocketPlus
,增加了与业务相关的功能:- 根据 subprotocol 自动处理发送与接收的消息,应用层发送接收的均是 ProtoBuf Message 类
send
接口返回 Promise,在 server 回复后才算 send 成功- 实现了应用层 ping/pong
Realtime
:开发者使用 SDK 的入口,负责访问 router、创建 connection、创建与管理 clients、创建 messageParser(管理消息类型)、监听 connection 的消息并 dispatch 给对应的 clientClient
:所有的 clients 共享一个 connectionIMClient
:对应即时通讯中的「用户」,持有 connection 与 conversations,负责创建管理将收到的消息处理后在对应 conversation 上派发,所有的 IMClients 共享一个 messageParser
MessageParser
消息解析器,负责将一个 JSON 格式的消息 parse 为对应的 Message 类Conversation
:实现对话相关的操作ConversationQuery
:对话查询器
Messages
AVMessage
:接口描述,生成文档用Message
:消息基类TypedMessage
:类型消息基类,继承自Message
TextMessage
:文本消息,继承自TypedMessage
- 其他富媒体消息类(
FileMessage
及其子类、LocationMessage
)由于依赖 leancloud-storage,作为另一个独立 package 发布
export DEBUG=LC*
localStorage.setItem('debug', 'LC*');
更新 .proto 后请运行
npm run convert-pb
测试
npm run test:node -- --grep KEYWORDS
浏览器测试
# 在当前目录启动一个静态 server
# static . -p 8000
npm run test:browser
# open http://localhost:8000/test/browser/
生成 dist/realtime.*
npm run build
合并 PR 到 master 分支后持续集成会自动运行 npm build
与 npm run docs
,然后将 dist 目录推送到 dist 分支,将文档与 demo 推送到 gh-pages。
- 遵循 semver 提升
package.json
与bower.json
中的版本号 npm run changelog
生成新的changelog.md
,润色之- Commit
package.json
,bower.json
,changelog.md
- Push to remote
master
branch - 等待持续集成 pass
- 使用 GitHub 基于 dist 分支生成 pre-release 包(for bower)
- Fetch and checkout remote
dist
branch 并确认该提交的内容是即将发布的版本 - npm publish(
npm publish
,需 npm 协作者身份),如果是 pre-release 版本需要带 next tag - 如有更新,在 npm 上发布各个 plugin