- 1. 禅道介绍
- 1.1 关于禅道项目管理软件
- 1.2 如何获得支持
- 1.3 各版本功能差异
- 1.4 关注我们
- 2. 安装禅道
- 2.1. 环境搭建
- 2.1.1 搭建Ubuntu环境安装禅道
- 2.1.2 搭建Centos环境安装禅道
- 2.1.3 安装PHP的ioncube扩展
- 2.2. 安装禅道
- 2.2.1 选择适合您的安装方法
- 2.2.2 新版本禅道的安装升级
- 2.2.3 Windows一键安装包(新版)
- 2.2.4 Windows一键安装包(旧版)
- 2.2.5 linux用一键安装包(推荐)
- 2.2.6 使用源码包安装(各系统通用)
- 2.2.7 使用源码包安装(MAC系统)
- 2.2.8 基于禅道当前的一键安装包(Windows和Linux)如何源码安装旗舰版禅道
- 2.2.9 渠成命令行安装禅道
- 2.2.10 Docker和Kubernetes方式部署禅道
- 2.3 安装PHP的LDAP扩展
- 2.4 在线安装云禅道
- 2.5 安装 APCu扩展
- 2.6 安装DuckDB引擎
- 2.1. 环境搭建
- 3. 升级禅道
- 3.1. 升级禅道新版本
- 3.1.1 选择和自己环境对应的升级方式
- 3.1.2 通过源代码方式升级(通用)
- 3.1.3 windows一键安装包的升级
- 3.1.4 linux一键安装包升级
- 3.1.5 docker安装禅道-升级禅道
- 3.1.6 旧版Docker镜像升级说明
- 3.1.7 通过Roadrunner管理定时任务
- 3.2 如何安装ioncube扩展
- 3.1. 升级禅道新版本
- 4. 维护配置
- 4.1. 维护禅道
- 4.1.1 初始化管理脚本
- 4.1.2 备份禅道
- 4.1.3 恢复删除的资源
- 4.1.4 如何更新燃尽图
- 4.1.5 一键安装包如何实现mysql异机连接
- 4.1.6 linux一键安装包配置https
- 4.1.7 禅道一键安装包迁移/更新禅道一键安装包
- 4.2. 配置禅道
- 4.2.1 设置是否允许匿名访问
- 4.2.2 如何配置email发信
- 4.2.3 如何成为超级管理员
- 4.2.4 配置禅道系统为静态访问
- 4.2.5 去掉禅道访问地址中的zentao
- 4.2.6 linux一键安装包去掉禅道访问地址中的zentao
- 4.2.7 集成禅道和svn
- 4.2.8 集成禅道和git
- 4.2.9 在第三方应用中集成禅道
- 4.2.10 第三方应用配置免密登录禅道
- 4.2.11 第三方应用集成禅道客户端进行消息通知
- 4.2.12 集成webhook
- 4.2.13 集成ZDOO
- 4.2.14 客户端集成
- 4.2.15 浏览器通知的设置
- 4.2.16 集成钉钉工作消息通知
- 4.2.17 集成企业微信应用消息通知
- 4.2.18 集成企业微信群机器人
- 4.2.19 集成飞书群机器人
- 4.2.20 集成飞书消息通知
- 4.2.21 解决一键安装包密码口令弱的问题
- 4.3. 性能优化
- 4.3.1 nginx反向代理禅道502或504bad gateway错误
- 4.3.2 linux系统中配置session使用redis
- 4.3.3 缓存功能
- 4.1. 维护禅道
- 5. 快速入门
- 5.1. 新版本快速入门
- 5.1.1 新版本禅道的最简使用
- 5.1.2 20版本禅道的新增功能
- 5.1.3 20版本禅道的界面变化
- 5.1. 新版本快速入门
- 6. 按照角色使用
- 6.1. 管理员
- 6.2. 项目集负责人
- 6.3. 产品经理
- 6.4. 项目经理
- 6.5. 研发人员
- 6.5.1 参加产品计划会议,分解任务
- 6.5.2 领取任务,并每天更新任务
- 6.5.3 创建构建,提交测试
- 6.5.4 确认Bug,解决Bug
- 6.5.5 执行的综合、需求、Bug、任务看板
- 6.6. 测试人员
- 7. 功能介绍
- 7.1. 核心管理结构
- 7.1.1 项目集(Program)
- 7.1.2 项目(Project)
- 7.1.3 产品(Product)
- 7.1.4 执行(Execution)
- 7.1.5 管理模型
- 7.2. 地盘
- 7.3. 项目集
- 7.4. 产品
- 7.4.1 创建产品
- 7.4.2 维护模块
- 7.4.3 产品多分支/平台管理
- 7.4.4 维护计划
- 7.4.5 维护需求
- 7.4.6 需求的评审
- 7.4.7 创建发布
- 7.4.8 跟踪进度
- 7.4.9 业务需求&需求多层级
- 7.5. 项目
- 7.6. 执行
- 7.6.1 参加产品计划会议,分解任务
- 7.6.2 领取任务,并每天更新任务
- 7.6.3 创建构建,提交测试
- 7.6.4 确认Bug,解决Bug
- 7.6.5 执行的综合、需求、Bug、任务看板
- 7.7. 测试
- 7.8. 自动化测试
- 7.9 DevOps(解决方案)
- 7.10. 看板
- 7.10.1 通用看板功能
- 7.11. 资产库(旗舰版)
- 7.11.1 资产库管理(旗舰版)
- 7.12. 文档
- 7.13. BI
- 7.13.1 维度(企业版8.4+)
- 7.13.2 大屏(企业版8.4+)
- 7.13.3 透视表
- 7.13.4 透视表下钻
- 7.13.5 图表
- 7.13.6. 度量项
- 7.13.6.1 查看度量项
- 7.14. AI
- 7.14.1 AI小程序简介
- 7.14.2 创建与设计AI小程序
- 7.14.3 发布与禁用小程序
- 7.14.4 调试AI小程序
- 7.14.5 前台小程序的应用
- 7.14.6 AI小程序的导入导出
- 7.14.7 管理AI小程序权限
- 7.15. 组织
- 7.15.1 团队成员和工作信息
- 7.15.2 人力资源日历(需安装插件)
- 7.15.3 组织动态
- 7.15.4 公司信息
- 7.16. 后台设置
- 7.16.1 后台首页
- 7.16.2. 系统设置
- 7.16.3 功能开关
- 7.16.4. 人员管理
- 7.16.5. 模型配置
- 7.16.6. 功能配置
- 7.16.7 文档模板
- 7.16.8. 通知设置
- 7.16.9 插件管理
- 7.16.10 二次开发
- 7.16.11 数据导入
- 7.16.12. 权限维护和控制
- 7.16.12.1 项目集的权限维护和访问控制
- 7.16.12.2 产品的权限维护和访问控制
- 7.16.12.3 项目的权限维护和访问控制
- 7.16.12.4 执行的权限维护和访问控制
- 7.16.12.5 项目和执行的访问控制和数据关系
- 7.16.13. AI配置
- 7.16.14. DevOps设置
- 7.16.14.1. 资源
- 7.17. 办公
- 7.18. 客户端增强版会议SRS
- 7.18.1. 音视频会议配置
- 7.18.1.1 安装音视频服务端
- 7.18.1.2 安装SRS音视频服务端
- 7.18.1.3 开启和配置音视频功能
- 7.18.2. 发起会议
- 7.18.2.1 一对一会话中发起音视频会议
- 7.18.2.2 群组会话中发起音视频会议
- 7.18.2.3 独立发起音视频会议入口
- 7.18.3. 加入会议
- 7.18.3.1 分享音视频会议到会话
- 7.18.3.2 通过会议的ID加入会议
- 7.18.4. 预约会议
- 7.18.4.1 预约会议
- 7.18.5. 会议应用
- 7.18.5.1 音视频会议应用
- 7.18.1. 音视频会议配置
- 7.19. 客户端增强版会议Jitsi
- 7.20. 工作流
- 7.1. 核心管理结构
- 8. 其他相关
- 9. IPD版本功能介绍
- 9.1. 禅道IPD版介绍
- 9.1.1 关于禅道IPD版
- 9.1.2 禅道IPD版的核心流程
- 9.2. IPD版的安装和升级
- 9.2.1 选择适合您的安装方法
- 9.2.2 选择适合您的升级方法
- 9.3. 需求与市场管理界面
- 9.4. IPD研发管理界面
- 9.1. 禅道IPD版介绍
第三方应用集成禅道客户端进行消息通知 分享链接 /book/zentaopms/301.html?releaseID=17
本篇目录
禅道开源版11.0版本集成了禅道客户端功能。
禅道里的消息通知可以发送到禅道客户端,同时增加了消息通知接口。
与禅道集成的第三方应用,也可以通过该消息通知接口,将第三方应用的消息发送到禅道客户端里。
本文将详细介绍第三方应用如何集成禅道客户端进行消息通知。
一、设置应用集成
第三方应用要与禅道做集成,具体请参考:http://www.zentao.net/book/zentaopmshelp/integration-287.html
二、签名机制
第三方应用在请求喧喧数据时所调用的 API 的请求地址格式为:
/api.php?m=$moduleName&f=$methodName$params&code=$code&token=$token
以上请求地址格式中的变量定义如下:
-
$moduleName :要调用的 API 所属模块名称(通常为 “im”),必须提供;
-
$methodName :要调用的 API 所属模块内的方法名称,如果缺省则为 index ;
-
$params :要调用的 API 方法参数,如果没有参数可以留空,如果所调用的 API 方法有参数则将参数名和参数值通过通用网址查询字符串的形式插入到 $params 所在位置,例如 gid=XXX ;
-
$code :应用代号,必须提供;
-
$token :调用 API 时的数字签名。
例如获取讨论组 gid 为 64da14c3-c07a-45af-9c61-4e638de4af26 中的用户数据请求地址为:
/api.php?m=im&f=getChatUsers&code=myAppCode&token=f5633c34c0c551a16c1d63bceb38d6a8
签名算法
API 请求地址中的数字签名 $token 应该在每次调用时根据应用集成密匙生成,具体算法为:
$token = md5(md5($query) + $key)
以上公式包含的变量定义如下:
-
$query :请求地址中查询字符串(? 之后的部分)不包含 &token=$token 的部分;
-
$key :应用密匙(必须为小写形式)。
例如:
// 查询参数 var $query = 'm=chat&f=getChatUsers&code=myAppCode'; // 应用密匙 var $key = '3cd0914d656e90ab181f1d52ff352cfe'; // 计算签名字符串 var $token = md5(md5('m=im&f=getChatUsers&code=myAppCode') + '3cd0914d656e90ab181f1d52ff352cfe'); // 这样 $token 的计算值为 'f5633c34c0c551a16c1d63bceb38d6a8'
下面将详细说明第三方应用在完成和禅道的集成后如何通过禅道客户端进行消息通知。
三、通过禅道客户端进行消息通知
下面列出目前第三方应用可以使用的 API。
1. im/getGroupChats
此接口用于获取系统中的讨论组会话列表。
- 请求方式:GET;
- 模块名称:im;
- 方法名称:getGroupChats;
- 参数:无;
- 返回值:JSON 对象,该对象属性定义如下:
属性名称 | 类型 | 说明 |
---|---|---|
result | 字符串 | 如果为'success'则操作成功,如果为其他值则表示操作失败 |
message | 字符串 | 如果操作失败,则使用此属性返回失败原因提示文本 |
data | 对象 | 该对象定义了系统中的讨论组清单,对象属性名为讨论组的全局唯一 标识字符串(GID),属性对应的值为讨论组名称 |
下面为一个示例请求地址:
https://myxxb.com/api.php?m=im&f=getGroupChats&code=myAppCode&token=f5633c34c0c551a16c1d63bceb38d6a8
正常情况下返回值如下:
{
"result": "success",
"data": {
"30683aea-7a1f-4ec8-a6d6-834e0310fd7d": "第四期项目讨论",
"81c6ba89-00ab-4431-8e47-063556ae4886": "研发部",
"64da14c3-c07a-45af-9c61-4e638de4af26": "公司总群"
}
}
2. im/getChatUsers
此接口用于获取指定讨论组中的成员信息或者获取系统中全部成员信息。
-
请求方式:GET;
-
模块名称:im;
-
方法名称:getChatUsers;
-
参数:
- gid:设置为要获取用户成员信息的讨论组的全局唯一 标识字符串(GID),如果留空,则请求会返回系统所有成员信息。
-
返回值:JSON 对象,该对象属性定义如下:
属性名称 | 类型 | 说明 |
---|---|---|
result | 字符串 | 如果为'success'则操作成功,如果为其他值则表示操作失败 |
message | 字符串 | 如果操作失败,则使用此属性返回失败原因提示文本 |
data | 对象 | 该对象定义了成员清单,对象属性名为成员 ID,属性对应的值为成员显示名称 |
下面为获取 GID 为'30683aea-7a1f-4ec8-a6d6-834e0310fd7d'的讨论组成员信息的示例请求地址:
https://myxxb.com/api.php?m=im&f=getChatUsers&gid=30683aea-7a1f-4ec8-a6d6-834e0310fd7d&code=myAppCode&token=f5633c34c0c551a16c1d63bceb38d6a8
正常情况下返回值如下:
{
"result": "success",
"data": {
"1": "管理员",
"3": "张三",
"4": "李四"
}
}
3. im/sendNotification
此接口用于向通知中心(小喧喧)推送通知消息。
- 请求方式:POST;
- 模块名称:im;
- 方法名称:sendNotification;
- 参数:无;
- 返回值:JSON 对象,该对象属性定义如下:
属性名称 | 类型 | 说明 |
---|---|---|
result | 字符串 | 如果为'success'则操作成功,如果为其他值则表示操作失败 |
message | 字符串 | 如果操作失败,则使用此属性返回失败原因提示文本 |
将要推送的通知消息对象转换为 JSON 字符串形式,然后通过 POST 请求发送到服务器。
一个通知消息对象拥有如下属性:
属性名称 | 类型 | 可选性 | 说明 |
---|---|---|---|
users | 数组 | 特定条件必须 | 使用一个用户 ID 数组指定通知发送给哪些用户,例如[1, 4],也可以指定一个用户账号组成的数组,例如['admin', 'zhangsan', 'lisi'] |
title | 字符串 | 必须 | 通知消息的标题 |
subtitle | 字符串 | 可选 | 通知消息的副标题 |
content | 字符串 | 可选 | 通知消息的内容文本 |
contentType | 字符串 | 必须 | 可选值包括:'plain'表示纯文本,'text'表示 Markdown 格式的文本 |
url | 字符串 | 可选 | 该通知消息所指向的网页链接 |
actions | 对象数组 | 可选 | 使用 操作对象数组表示该通知支持的操作 |
sender | 对象 | 可选 | 通知的 发送方信息对象 |
通知的 操作对象包含如下属性:
属性名称 | 类型 | 可选性 | 说明 |
---|---|---|---|
label | 字符串 | 必须 | 操作按钮上显示的文本 |
icon | 字符串 | 可选 | 操作按钮上显示的图标 |
url | 字符串 | 必须 | 点击此操作按钮时要打开的页面链接 |
type | 字符串 | 可选 | 操作按钮类型,影响操作按钮外观,可选值包括'primary'、'success'、'danger'、'warning'、'info'、'important'、'special' |
发送方信息对象包容如下属性:
属性名称 | 类型 | 可选性 | 说明 |
---|---|---|---|
id | 字符串或数字 | 必须 | 标识发送方唯一身份的字符串或数字 |
name | 字符串 | 可选 | 发送方在界面上显示的名称 |
avatar | 字符串 | 必须 | 发送方头像图片链接地址 |
下面为一个发送通知消息的示例 POST 请求地址:
https://myxxb.com/api.php?m=im&f=sendNotification&code=myAppCode&token=f5633c34c0c551a16c1d63bceb38d6a8
下面为使用 JavaScript Fetch API 发起请求示例代码:
const notifycationData = {
users: [1, 3],
title: '测试通知消息',
subtitle: '测试通知消息副标题',
content: '**测试消息**内容',
contentType: 'text',
url: 'http://xuan.im',
actions: [
{
type: 'danger',
label: '更新日志',
url: 'https://xuan.im/page/changelogs.html'
}, {
type: 'normal',
label: '下载地址',
url: 'http://xuan.im/page/download.html'
}
],
sender: {
avatar: 'https://avatars2.githubusercontent.com/u/472425?s=460&v=4',
name: 'Catouse',
id: 'catouse'
}
};
const postUrl = 'https://myxxb.com/api.php?m=im&f=sendNotification&code=myAppCode&token=f5633c34c0c551a16c1d63bceb38d6a8';
fetch(postUrl, {
method: 'POST',
headers: {'Content-Type': 'application/json'},
body: JSON.stringify(data)
}).then(r => {
return r.json();
}).then(response => {
if (response && response.result === 'success') {
console.log('操作成功');
}
});
正常情况下返回值如下:
{ "result": "success" }
4. im/sendChatMessage
此接口用于向指定的讨论组推送通知消息。
- 请求方式:POST;
- 模块名称:im;
- 方法名称:sendChatMessage;
- 参数:无;
- 返回值:JSON 对象,该对象属性定义如下:
属性名称 | 类型 | 说明 |
---|---|---|
result | 字符串 | 如果为'success'则操作成功,如果为其他值则表示操作失败 |
message | 字符串 | 如果操作失败,则使用此属性返回失败原因提示文本 |
将要推送的通知消息对象转换为 JSON 字符串形式,然后通过 POST 请求发送到服务器。
一个通知消息对象拥有如下属性:
属性名称 | 类型 | 可选性 | 说明 |
---|---|---|---|
gid | 字符串 | 特定条件必须 | 为讨论组的全局唯一字符串,指定通知发送到的讨论组,当向讨论组发送通知时必须(即receiver为'group') |
title | 字符串 | 必须 | 通知消息的标题 |
subtitle | 字符串 | 可选 | 通知消息的副标题 |
content | 字符串 | 可选 | 通知消息的内容文本 |
contentType | 字符串 | 必须 | 可选值包括:'plain'表示纯文本,'text'表示 Markdown 格式的文本 |
url | 字符串 | 可选 | 该通知消息所指向的网页链接 |
actions | 对象数组 | 可选 | 使用 操作对象数组表示该通知支持的操作 |
sender | 对象 | 可选 | 通知的 发送方信息对象 |
通知的 操作对象包含如下属性:
属性名称 | 类型 | 可选性 | 说明 |
---|---|---|---|
label | 字符串 | 必须 | 操作按钮上显示的文本 |
icon | 字符串 | 可选 | 操作按钮上显示的图标 |
url | 字符串 | 必须 | 点击此操作按钮时要打开的页面链接 |
type | 字符串 | 可选 | 操作按钮类型,影响操作按钮外观,可选值包括'primary'、'success'、'danger'、'warning'、'info'、'important'、'special' |
发送方信息对象包容如下属性:
属性名称 | 类型 | 可选性 | 说明 |
---|---|---|---|
id | 字符串或数字 | 必须 | 标识发送方唯一身份的字符串或数字 |
name | 字符串 | 可选 | 发送方在界面上显示的名称 |
avatar | 字符串 | 必须 | 发送方头像图片链接地址 |
下面为一个发送通知消息的示例 POST 请求地址:
https://myxxb.com/api.php?m=im&f=sendChatMessage&code=myAppCode&token=f5633c34c0c551a16c1d63bceb38d6a8
下面为使用 JavaScript Fetch API 发起请求示例代码:
const notifycationData = {
gid: 'f3de9ff9-dcb4-49de-915b-377ee9143418',
title: '测试通知消息',
subtitle: '测试通知消息副标题',
content: '**测试消息**内容',
contentType: 'text',
url: 'http://xuan.im',
actions: [
{
type: 'danger',
label: '更新日志',
url: 'https://xuan.im/page/changelogs.html'
}, {
type: 'normal',
label: '下载地址',
url: 'http://xuan.im/page/download.html'
}
],
sender: {
avatar: 'https://avatars2.githubusercontent.com/u/472425?s=460&v=4',
name: 'Catouse',
id: 'catouse'
}
};
const postUrl = 'https://myxxb.com/api.php?m=im&f=sendChatMessage&code=myAppCode&token=f5633c34c0c551a16c1d63bceb38d6a8';
fetch(postUrl, {
method: 'POST',
headers: {'Content-Type': 'application/json'},
body: JSON.stringify(data)
}).then(r => {
return r.json();
}).then(response => {
if (response && response.result === 'success') {
console.log('操作成功');
}
});
正常情况下返回值如下:
{ "result": "success" }