-
Notifications
You must be signed in to change notification settings - Fork 42
/
aweme_banded_list.go
85 lines (78 loc) · 2.86 KB
/
aweme_banded_list.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
package comment
import (
"strconv"
"github.com/bububa/oceanengine/marketing-api/model"
"github.com/bububa/oceanengine/marketing-api/util"
)
// AwemeBandedList 获取屏蔽用户列表 API Request
type AwemeBandedListRequest struct {
// AdvertiserID 广告主ID
AdvertiserID uint64 `json:"advertiser_id,omitempty"`
// AwemeID 为绑定的抖音号添加屏蔽词, 只允许传入1个,通过【获取绑定的抖音号】 接口获取,当is_apply_to_adv不传或为false时,aweme_id生效
AwemeID string `json:"aweme_id,omitempty"`
// IsApplyToAdv 是否应用于当前账户,当is_apply_to_adv不传或为false时,aweme_id生效
IsApplyToAdv bool `json:"is_apply_to_adv,omitempty"`
// BandedType 屏蔽类型,; 允许值:CUSTOM_TYPE:自定义规则,根据昵称关键词屏蔽;AWEME_TYPE:根据抖音id屏蔽。
BandedType string `json:"banded_type,omitempty"`
// AwemeUserID 抖音用户id
AwemeUserID string `json:"aweme_user_id,omitempty"`
// NicknameKeyword 昵称关键词,最大不超过20字
NicknameKeyword string `json:"nickname_keyword,omitempty"`
// Page 页数 默认值: 1
Page int `json:"page,omitempty"`
// PageSize 页面大小默认值: 10
PageSize int `json:"page_size,omitempty"`
}
// Encode implement GetRequest interface
func (r AwemeBandedListRequest) Encode() string {
values := util.GetUrlValues()
values.Set("advertiser_id", strconv.FormatUint(r.AdvertiserID, 10))
if r.AwemeID != "" {
values.Set("aweme_id", r.AwemeID)
}
if r.IsApplyToAdv {
values.Set("is_apply_to_adv", "true")
}
if r.BandedType != "" {
values.Set("banded_type", r.BandedType)
}
if r.AwemeUserID != "" {
values.Set("aweme_user_id", r.AwemeUserID)
}
if r.NicknameKeyword != "" {
values.Set("nickname_keyword", r.NicknameKeyword)
}
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
}
// AwemeBandedListResponse 获取屏蔽用户列表 API Response
type AwemeBandedListResponse struct {
model.BaseResponse
// Data json 返回值
Data *AwemeBandedListResponseData `json:"data,omitempty"`
}
// AwemeBandedListResponseData json 返回值
type AwemeBandedListResponseData struct {
// PageInfo 分页信息
PageInfo *model.PageInfo `json:"page_info,omitempty"`
// List 结果列表
List []BandedAweme `json:"list,omitempty"`
}
// BandedAweme 屏蔽用户
type BandedAweme struct {
// AwemeUserID 抖音id
AwemeUserID string `json:"aweme_user_id,omitempty"`
// AwemeName 抖音昵称
AwemeName string `json:"aweme_name,omitempty"`
// BandedType 屏蔽类型,CUSTOM_TYPE:自定义规则,根据昵称关键词屏蔽;AWEME_TYPE:根据抖音id屏蔽。
BandedType string `json:"banded_type,omitempty"`
// NicknameKeyword 昵称关键词
NicknameKeyword string `json:"nickname_keyword,omitempty"`
}