# 说明

返回符合查询条件的所有缺陷变更历史(分页显示,默认一页30条)

# 提示

如果需要做状态停留时长分析,请直接使用 获取状态流转时间接口

# SDK 方法名

nodeJs:

SDK使用方式 (opens new window)

插件中使用SDK

方法名::

getBugChanges
1

# url

https://api.tapd.cn/bug_changes

# 支持格式

JSON/XML(默认JSON格式)

# HTTP请求方式

GET

# 请求数限制

  • created 参数与 bug_id 参数二选一必填。即 bug_id、created 两个参数至少填写一个
  • 其中 created 参数要填写成日期格式,比如 created=2022-02-22,则返回 2022-02-22 这一天的变更历史
  • 默认返回 30 条。可通过传 limit 参数设置,最大取 200。也可以传 page 参数翻页

# 请求参数

字段名 必选 类型及范围 说明 特殊规则
workspace_id integer 项目ID
created datetime 创建时间 支持按天查询。比如 created=2022-02-22
bug_id integer 缺陷ID 支持多ID查询
id integer id 支持多ID查询
author string 变更人
field string 变更字段
old_value string 变更前
new_value string 变更后
memo string 备注
include_add_bug integer 设置返回创建缺陷的记录(值传1)
limit integer 设置返回数量限制,默认为30
page integer 返回当前数量限制下第N页的数据,默认为1(第一页)
order string 排序规则,规则:字段名 ASC或者DESC,然后 urlencode 如按创建时间逆序:order=created%20desc
fields string 设置获取的字段,多个字段间以','逗号隔开

# 调用示例及返回结果

# 获取项目下缺陷变更历史

# curl 使用 Basic Auth 鉴权调用示例

curl -u 'api_user:api_password' 'https://api.tapd.cn/bug_changes?workspace_id=10158231'

#

# 返回结果

{
    "status": 1,
    "data": [
        {
            "BugChange": {
                "id": "10101582315000015921",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "severity",
                "old_value": "serious",
                "new_value": "normal",
                "memo": null,
                "created": "2019-06-26 20:48:52",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015919",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "severity",
                "old_value": "fatal",
                "new_value": "serious",
                "memo": null,
                "created": "2019-06-26 20:47:24",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015917",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "priority",
                "old_value": "urgent",
                "new_value": "high",
                "memo": null,
                "created": "2019-06-26 20:47:21",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015915",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "current_owner",
                "old_value": null,
                "new_value": "anyechen;",
                "memo": null,
                "created": "2019-06-26 20:47:18",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015913",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "severity",
                "old_value": "normal",
                "new_value": "fatal",
                "memo": null,
                "created": "2019-06-26 20:47:02",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015911",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "priority",
                "old_value": "medium",
                "new_value": "urgent",
                "memo": null,
                "created": "2019-06-26 20:46:59",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "1010158231606851987",
                "bug_id": "1010158231500628817",
                "author": "anyechen",
                "field": "severity",
                "old_value": "serious",
                "new_value": "prompt",
                "memo": null,
                "created": "2018-01-12 14:45:29",
                "workspace_id": "10158231"
            }
        }
    ],
    "info": "success"
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97

获取缺陷ID为 1010158231500628815 的变更历史

# curl 使用 Basic Auth 鉴权调用示例

curl -u 'api_user:api_password' 'https://api.tapd.cn/bug_changes?workspace_id=10158231&bug_id=1010158231500628815'

#

# 返回结果

{
    "status": 1,
    "data": [
        {
            "BugChange": {
                "id": "10101582315000015921",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "severity",
                "old_value": "serious",
                "new_value": "normal",
                "memo": null,
                "created": "2019-06-26 20:48:52",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015919",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "severity",
                "old_value": "fatal",
                "new_value": "serious",
                "memo": null,
                "created": "2019-06-26 20:47:24",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015917",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "priority",
                "old_value": "urgent",
                "new_value": "high",
                "memo": null,
                "created": "2019-06-26 20:47:21",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015915",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "current_owner",
                "old_value": null,
                "new_value": "anyechen;",
                "memo": null,
                "created": "2019-06-26 20:47:18",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015913",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "severity",
                "old_value": "normal",
                "new_value": "fatal",
                "memo": null,
                "created": "2019-06-26 20:47:02",
                "workspace_id": "10158231"
            }
        },
        {
            "BugChange": {
                "id": "10101582315000015911",
                "bug_id": "1010158231500628815",
                "author": "anyechen",
                "field": "priority",
                "old_value": "medium",
                "new_value": "urgent",
                "memo": null,
                "created": "2019-06-26 20:46:59",
                "workspace_id": "10158231"
            }
        }
    ],
    "info": "success"
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84

# 缺陷变更历史字段说明

# 缺陷变更历史重要字段说明

字段 说明
id id
bug_id 缺陷ID
author 变更人
field 变更字段
old_value 变更前
new_value 变更后
memo 备注
created 创建时间
workspace_id 项目ID

# 最佳实践

# 做状态停留时长分析

如果需要做状态停留时长分析,请直接使用 获取状态流转时间接口

# 全量同步变更历史数据

如果需要同步项目全量状态变更历史数据,可以按照如下步骤:

  1. 使用获取缺陷数据接口,分页获取缺陷的ID。比如 https://api.tapd.cn/bugs?workspace_id=项目ID&limit=30&page=1&fields=id
  2. 根据步骤1获取到的缺陷ID,加到 bug_id 参数里面,分页获取变更历史数据。比如 https://api.tapd.cn/bug_changes?workspace_id=项目ID&bug_id=缺陷ID1,缺陷ID2,缺陷3&limit=30&page=1
  3. 重复步骤1、步骤2直到拿到所有缺陷的变更历史

# 增量同步变更历史数据

因为变更历史数据不会变,只增不减。所以可以传递 created 参数来增量获取变更历史数据。参考这样:

  1. 传递 created=日期 。比如 https://api.tapd.cn/bug_changes?workspace_id=项目ID&created=2022-02-22&limit=30&page=1 来获取某天的变更历史数据。
上次更新: 2024-05-16 14:58:20