github.com/bububa/oceanengine/marketing-api@v0.0.0-20210315120513-0b953137f7a6/model/report/get_request.go (about) 1 package report 2 3 import ( 4 "encoding/json" 5 "net/url" 6 "strconv" 7 "time" 8 9 "github.com/bububa/oceanengine/marketing-api/enum" 10 ) 11 12 type GetRequest struct { 13 AgentID uint64 `json:"agent_id,omitempty"` // 代理商id。 14 AdvertiserID uint64 `json:"advertiser_id,omitempty"` // 广告主ID 15 StartDate time.Time `json:"start_date,omitempty"` // 起始日期,格式YYYY-MM-DD,只支持查询2016-10-26及以后的日期 16 EndDate time.Time `json:"end_date,omitempty"` // 结束日期,格式YYYY-MM-DD,只支持查询2016-10-26及以后的日期,时间跨度不能超过30天 17 GroupBy []enum.StatGroupBy `json:"group_by,omitempty"` // 分组条件默认为 STAT_GROUP_BY_FIELD_STAT_TIME 18 TimeGranularity enum.StatTimeGranularity `json:"time_granularity,omitempty"` // 时间粒度, 默认值: STAT_TIME_GRANULARITY_DAILY 19 OrderField string `json:"order_field,omitempty"` // 排序字段,所有的统计指标均可参与排序 20 OrderType enum.OrderType `json:"order_type,omitempty"` // 排序方式;默认值: DESC;允许值: ASC, DESC 21 Page int `json:"page,omitempty"` // 页码;默认值: 1 22 PageSize int `json:"page_size,omitempty"` // 页面大小,即每页展示的数据量;默认值: 20;取值范围: 1-1000 23 Filtering *StatFiltering `json:"filtering,omitempty"` // 过滤字段,json格式,支持字段如下 24 } 25 26 type StatFiltering struct { 27 AdvertiserIDs []uint64 `json:"advertiser_ids,omitempty"` // 广告主 id 列表,若选填该字段,则最少应上传1个广告主id,最多支持同时查询100个广告主。 28 Active string `json:"active,omitempty"` // 用户活跃状态。可选枚举值: ACTIVE表示活跃用户,SILENT表示沉默用户,ALL表示所有用户。不填写该字段则默认值为ALL。 29 FirstIndustry string `json:"first_industry,omitempty"` // 一级行业名称 30 SecondIndustry string `json:"secondy_industry,omitempty"` // 二级行业名称 31 AccountSource enum.AccountSource `json:"account_source,omitempty"` // 账户类型。可选枚举值: LUBAN_ACCOUNT,NORMAL_ADVERTISER 32 AccountStatus enum.AccountStatus `json:"account_status,omitempty"` // 账户状态 33 StartAuditPassTime string `json:"start_audit_pass_time,omitempty"` // 过审时间范围的开始时间。闭区间。格式:YYYY-MM-DD。表示过滤出账户资质审核通过时间在给定的过审时间范围内的广告主数据。 34 EndAuditPassTime string `json:"end_audit_pass_time,omitempty"` // 过审时间范围的结束时间。闭区间。格式:YYYY-MM-DD。表示过滤出账户资质审核通过时间在给定的过审时间范围内的广告主数据。 35 CampaignIDs []uint64 `json:"campaign_ids,omitempty"` // 广告组id列表:按照campaign_id过滤,最多支持100个 36 CampaignName string `json:"campaign_name,omitempty"` // 广告组名称:按照campaign_name过滤,字符串长度限制1-30 37 AdIDs []uint64 `json:"ad_ids,omitempty"` // 广告计划id列表:按照 ad_id 过滤,最多支持100个 38 AdName string `json:"ad_name,omitempty"` // 广告计划名称:按照ad_name过滤,字符串长度限制1-30 39 CreativeIDs []uint64 `json:"creative_ids,omitempty"` // 广告创意id列表:按照 creative_id 过滤,最多支持100个 40 InventoryTypes []enum.StatInventoryType `json:"inventory_types,omitempty"` // 广告位置列表:按照广告位置过滤 41 Pricings []enum.PricingType `json:"pricings,omitempty"` // 出价方式列表:按照出价方式过滤 42 ImageModes []enum.ImageMode `json:"image_modes,omitempty"` // 素材类型列表:按照类型过滤 43 CreativeMaterialModes []string `json:"creative_material_modes,omitempty"` // 创意类型列表:按照创意类型过滤,STATIC_ASSEMBLE 表示程序化创意,INTERVENE表示自定义创意 44 LandingTypes []enum.LandingType `json:"landing_types,omitempty"` // 推广目的列表:按照广告组推广目的过滤, 允许值: "LINK","APP","DPA","GOODS","STORE","SHOP","AWEME" 45 Status enum.CreativeStatus `json:"status,omitempty"` // 广告创意状态:按照广告创意状态过滤,默认为返回“所有不包含已删除”,如果要返回所有包含已删除有对应枚举表示 46 } 47 48 func (r GetRequest) Encode() string { 49 values := &url.Values{} 50 values.Set("start_date", r.StartDate.Format("2006-01-02")) 51 values.Set("end_date", r.EndDate.Format("2006-01-02")) 52 if r.AgentID > 0 { 53 values.Set("agent_id", strconv.FormatUint(r.AgentID, 10)) 54 } 55 if r.AdvertiserID > 0 { 56 values.Set("advertiser_id", strconv.FormatUint(r.AdvertiserID, 10)) 57 } 58 if r.GroupBy != nil { 59 groupBy, _ := json.Marshal(r.GroupBy) 60 values.Set("group_by", string(groupBy)) 61 } 62 if r.TimeGranularity != "" { 63 values.Set("time_granularity", string(r.TimeGranularity)) 64 } 65 if r.OrderField != "" { 66 values.Set("order_field", r.OrderField) 67 } 68 if r.OrderType != "" { 69 values.Set("order_type", string(r.OrderType)) 70 } 71 if r.Page > 0 { 72 values.Set("page", strconv.Itoa(r.Page)) 73 } 74 if r.PageSize > 0 { 75 values.Set("page_size", strconv.Itoa(r.PageSize)) 76 } 77 if r.Filtering != nil { 78 filtering, _ := json.Marshal(r.Filtering) 79 values.Set("filtering", string(filtering)) 80 } 81 return values.Encode() 82 }