-
Notifications
You must be signed in to change notification settings - Fork 43
/
get.go
114 lines (107 loc) · 3.81 KB
/
get.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
package comment
import (
"encoding/json"
"strconv"
"github.com/bububa/oceanengine/marketing-api/enum"
"github.com/bububa/oceanengine/marketing-api/model"
"github.com/bububa/oceanengine/marketing-api/util"
)
// GetRequest 获取评论列表 API Request
type GetRequest struct {
// AdvertiserID 广告主ID
AdvertiserID uint64 `json:"advertiser_id,omitempty"`
// StartTime 查询起始时间,格式:yyyy-MM-dd,若不填,默认6天前(即获取最近七天的内容)
StartTime string `json:"start_time,omitempty"`
// EndTime 查询截止时间,格式:yyyy-MM-dd,若不填,默认当天
EndTime string `json:"end_time,omitempty"`
// OrderField 排序字段,允许值:
// REPLY_COUNT按评论回复数量排序
// LIKE_COUNT 按点赞数量排序
// CREATE_TIME 按评论时间排序(默认值)
OrderField string `json:"order_field,omitempty"`
// OrderType 排序类型,允许值:
// ASC: 升序
// DESC: 降序(默认值)
OrderType enum.OrderType `json:"order_type,omitempty"`
// Page 页数 默认值: 1
Page int `json:"page,omitempty"`
// PageSize 页面大小默认值: 10
PageSize int `json:"page_size,omitempty"`
// Filtering 过滤条件,若此字段不传,或传空则视为无限制条件
Filtering *GetFilter `json:"filtering,omitempty"`
}
type GetFilter struct {
// AdIDs 计划id列表,一次最多10个
AdIDs []uint64 `json:"ad_ids,omitempty"`
// ItemIDs 广告视频id列表,一次最多100个,仅当platform_version=V2时传入生效,可通过【获取抖音授权关系】获取item_id和视频相关信息
ItemIDs []uint64 `json:"item_ids,omitempty"`
// LevelType 查询的评论等级,可选值:
// LEVEL_ALL: 所有评论(默认值)
// LEVEL_ONE: 一级评论
// LEVEL_TWO: 二级评论
LevelType enum.CommentLevelType `json:"level_type,omitempty"`
// IsReplied 是否已回复
IsReplied bool `json:"is_replied,omitempty"`
// HideStatus 隐藏状态, 可选值:
// ALL: 全部(默认值)
// HIDE: 已隐藏
// NOT_HIDE: 未隐藏
HideStatus enum.CommentHideStatus `json:"hide_status,omitempty"`
// EmotionType 评论情感, 可选值:
// NEGATIVE: 负向评论
// NEUTRAL: 中性评论
// POSITIVE: 正向评论
EmotionType enum.CommentEmotionType `json:"emotion_type,omitempty"`
// Content 评论关键词,最长支持10个字符
Content string `json:"content,omitempty"`
// AuthorIDs 视频作者抖音id,最多支持100个
AuthorIDs []uint64 `json:"author_ids,omitempty"`
// CommentType 评论内容类型,不传返回所有评论,允许值:
// IMAGE_COMMENT 图片评论
// IMAGE_TEXT_COMMENT 图文评论
// TEXT_COMMENT 文字评论
CommentType enum.CommentType `json:"comment_type,omitempty"`
}
// Encode implement GetRequest interface
func (r GetRequest) Encode() string {
values := util.GetUrlValues()
values.Set("advertiser_id", strconv.FormatUint(r.AdvertiserID, 10))
if r.Filtering != nil {
bs, _ := json.Marshal(r.Filtering)
values.Set("filtering", string(bs))
}
if r.OrderField != "" {
values.Set("order_field", r.OrderField)
}
if r.OrderType != "" {
values.Set("order_type", string(r.OrderType))
}
if r.StartTime != "" {
values.Set("start_time", r.StartTime)
}
if r.EndTime != "" {
values.Set("end_time", r.EndTime)
}
if r.Page > 0 {
values.Set("page", strconv.Itoa(r.Page))
}
if r.PageSize > 0 {
values.Set("page_size", strconv.Itoa(r.PageSize))
}
ret := values.Encode()
util.PutUrlValues(values)
return ret
}
// GetResponse 获取评论列表 API Response
type GetResponse struct {
model.BaseResponse
// Data json 返回值
Data *GetResponseData `json:"data,omitempty"`
}
// GetResponseData json 返回值
type GetResponseData struct {
// PageInfo 分页信息
PageInfo *model.PageInfo `json:"page_info,omitempty"`
// CommentsList 评论列表
CommentsList []Comment `json:"comment_list,omitempty"`
}