/
get_search_logs.go
67 lines (54 loc) · 1.52 KB
/
get_search_logs.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
package api
import (
"github.com/gin-gonic/gin"
"github.com/sirupsen/logrus"
)
const hardLimitOfQueryResult = 1000 * 1000 // 1,000,000
type logData struct {
Tag string `json:"tag"`
Timestamp int64 `json:"timestamp"`
Log interface{} `json:"log"`
}
type GetSearchLogMetaData struct {
searchMetaData
Total int64 `json:"total"`
SubTotal int64 `json:"sub_total"`
Offset int64 `json:"offset"`
Limit int64 `json:"limit"`
Tags []string `json:"tags"`
}
type GetSearchLogsResponse struct {
ID searchID `json:"search_id"`
Logs []*logData `json:"logs"`
MetaData GetSearchLogMetaData `json:"metadata"`
}
func (x MinervaHandler) GetSearchLogs(c *gin.Context) (*Response, Error) {
id := searchID(c.Param("search_id"))
Logger.WithFields(logrus.Fields{
"args": x,
"searchID": id,
}).Info("Start getSearchLogs")
resp := GetSearchLogsResponse{
ID: id,
}
meta, err := x.getMetaData(id)
if err != nil {
return nil, err
}
resp.MetaData.searchMetaData = *meta
if resp.MetaData.Status == statusSuccess {
s3path := meta.outputPath
logSet, err := loadLogs(x.Region, s3path, c)
if err != nil {
return nil, err
}
resp.Logs = logSet.Logs
resp.MetaData.Total = logSet.Total
resp.MetaData.Offset = logSet.Filter.Offset
resp.MetaData.Limit = logSet.Filter.Limit
resp.MetaData.SubTotal = logSet.SubTotal
resp.MetaData.Tags = logSet.Tags
}
Logger.WithField("resp", resp).Debug("Done getSearchLogs")
return &Response{200, &resp}, nil
}