forked from apache/incubator-devlake
/
worklog_collector.go
86 lines (77 loc) · 2.32 KB
/
worklog_collector.go
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
package tasks
import (
"encoding/json"
"fmt"
"net/http"
"reflect"
"github.com/merico-dev/lake/plugins/core"
"github.com/merico-dev/lake/plugins/helper"
"github.com/merico-dev/lake/plugins/jira/models"
"github.com/merico-dev/lake/plugins/jira/tasks/apiv2models"
)
const RAW_WORKLOGS_TABLE = "jira_api_worklogs"
func CollectWorklogs(taskCtx core.SubTaskContext) error {
db := taskCtx.GetDb()
data := taskCtx.GetData().(*JiraTaskData)
since := data.Since
incremental := false
if since == nil {
var latestUpdated models.JiraWorklog
err := db.Where("source_id = ?", data.Source.ID).Order("updated DESC").Limit(1).Find(&latestUpdated).Error
if err != nil {
return fmt.Errorf("failed to get latest jira issue worklog record: %w", err)
}
if latestUpdated.IssueId > 0 {
since = &latestUpdated.Updated
incremental = true
}
}
logger := taskCtx.GetLogger()
sourceId := data.Source.ID
boardId := data.Options.BoardId
tx := db.Model(&models.JiraIssue{}).
Joins("left join _tool_jira_board_issues on _tool_jira_issues.issue_id = _tool_jira_board_issues.issue_id").
Select("_tool_jira_board_issues.issue_id").Where("_tool_jira_board_issues.source_id = ? AND _tool_jira_board_issues.board_id = ?", sourceId, boardId)
if since != nil {
tx = tx.Where("_tool_jira_issues.updated > ?", since)
}
cursor, err := tx.Rows()
if err != nil {
return err
}
iterator, err := helper.NewCursorIterator(db, cursor, reflect.TypeOf(apiv2models.Input{}))
if err != nil {
return err
}
collector, err := helper.NewApiCollector(helper.ApiCollectorArgs{
RawDataSubTaskArgs: helper.RawDataSubTaskArgs{
Ctx: taskCtx,
Params: JiraApiParams{
SourceId: data.Source.ID,
BoardId: data.Options.BoardId,
},
Table: RAW_WORKLOGS_TABLE,
},
Input: iterator,
ApiClient: data.ApiClient,
UrlTemplate: "api/2/issue/{{ .Input.IssueId }}/worklog",
PageSize: 50,
Incremental: incremental,
GetTotalPages: GetTotalPagesFromResponse,
ResponseParser: func(res *http.Response) ([]json.RawMessage, error) {
var data struct {
Worklogs []json.RawMessage `json:"worklogs"`
}
err := helper.UnmarshalResponse(res, &data)
if err != nil {
return nil, err
}
return data.Worklogs, nil
},
})
if err != nil {
logger.Error("collect board error:", err)
return err
}
return collector.Execute()
}