card

package
v1.2.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 10, 2021 License: Apache-2.0 Imports: 5 Imported by: 0

Documentation

Overview

微信卡券接口

Index

Constants

View Source
const (
	// 卡券Code展示类型
	BIZSERVICEDELIVER  = "BIZ_SERVICE_DELIVER "  // 文本
	BIZSERVICEFREEPARK = "BIZ_SERVICE_FREE_PARK" // 一维码
	BIZSERVICEWITHPET  = "BIZ_SERVICE_WITH_PET"  // 二维码
	BIZSERVICEFREEWIFI = "BIZ_SERVICE_FREE_WIFI" // 一维码无code显示
)
View Source
const (
	// 卡券Code展示类型
	CodeTypeText        = "CODE_TYPE_TEXT"         // 文本
	CodeTypeBarCode     = "CODE_TYPE_BARCODE"      // 一维码
	CodeTypeQrcode      = "CODE_TYPE_QRCODE"       // 二维码
	CodeTypeOnlyBarCode = "CODE_TYPE_ONLY_BARCODE" // 一维码无code显示
	CodeTypeOnlyQrcode  = "CODE_TYPE_ONLY_QRCODE"  // 二维码无code显示
)
View Source
const (
	// 卡券的状态
	CardStatusNotVerify  = "CARD_STATUS_NOT_VERIFY"  // 待审核
	CardStatusVerifyFail = "CARD_STATUS_VERIFY_FALL" // 审核失败
	CardStatusVerifyOk   = "CARD_STATUS_VERIFY_OK"   // 通过审核
	CardStatusDelete     = "CARD_STATUS_DELETE"      // 卡券被商户删除
	CardStatusDispatch   = "CARD_STATUS_DISPATCH"    // 在公众平台投放过的卡券
)
View Source
const (
	// DateInfo类型
	DateInfoTypeFixTimeRange = "DATE_TYPE_FIX_TIME_RANGE" // 表示固定日期区间
	DateInfoTypeFixTerm      = "DATE_TYPE_FIX_TERM"       // 表示固定时长(自领取后按天算)
	DateInfoTypePermanent    = "DATE_TYPE_PERMANENT"      // 表示永久有效(会员卡类型专用)
)
View Source
const (
	// 卡券类型
	CardTypeGeneralCoupon = "GENERAL_COUPON" // 优惠券
	CardTypeGroupon       = "GROUPON"        // 团购券
	CardTypeCash          = "CASH"           // 代金券
	CardTypeDiscount      = "DISCOUNT"       // 折扣券
	CardTypeGift          = "GIFT"           // 礼品券
	CardTypeMemberCard    = "MEMBER_CARD"    // 会员卡
	CardTypeMeetingTicket = "MEETING_TICKET" // 会议门票
	CardTypeScenicTicket  = "SCENIC_TICKET"  // 景区门票
	CardTypeMovieTicket   = "MOVIE_TICKET"   // 电影票
	CardTypeBoardingPass  = "BOARDING_PASS"  // 飞机票
)
View Source
const (
	// 推送到公众号URL上的事件类型
	EventTypeCardPassCheck            core.EventType = "card_pass_check"              // 卡券通过审核
	EventTypeCardNotPassCheck         core.EventType = "card_not_pass_check"          // 卡券未通过审核
	EventTypeUserGiftingCard          core.EventType = "user_gifting_card"            // 转赠事件推送
	EventTypeUserGetCard              core.EventType = "user_get_card"                // 领取事件推送
	EventTypeUserDelCard              core.EventType = "user_del_card"                // 删除事件推送
	EventTypeUserConsumeCard          core.EventType = "user_consume_card"            // 核销事件推送
	EventTypeUserViewCard             core.EventType = "user_view_card"               // 进入会员卡事件推送
	EventTypeUserEnterSessionFromCard core.EventType = "user_enter_session_from_card" // 从卡券进入公众号会话事件推送
	EventTypeCardSkuRemind            core.EventType = "card_sku_remind"              // 库存报警事件

	EventTypeGiftCardPayDone    core.EventType = "giftcard_pay_done"    // 用户购买礼品卡付款成功
	EventTypeGiftCardUserAccept core.EventType = "giftcard_user_accept" // 用户领取礼品卡成功
)

Variables

This section is empty.

Functions

func Create

func Create(clt *core.Client, card *Card) (cardId string, err error)

创建卡券.

func Delete

func Delete(clt *core.Client, cardId string) (err error)

删除卡券

func ModifyStock

func ModifyStock(clt *core.Client, cardId string, increaseNum int) (err error)

库存修改接口. cardId: 卡券ID increaseNum: 增加库存数量, 可以为负数

func Sign

func Sign(strs []string) (signature string)

卡券通用签名方法.

将 strs 里面的字符串字典排序, 然后拼接成一个字符串后做 sha1 签名.

func Update

func Update(clt *core.Client, cardId string, card *Card) (sendCheck bool, err error)

更改卡券信息接口.

sendCheck: 是否提交审核,false为修改后不会重新提审,true为修改字段后重新提审,该卡券的状态变为审核中。

Types

type Abstract

type Abstract struct {
	Abstract      string       `json:"abstract"`                  // 封面摘要简介。
	IconUrlList   []string     `json:"icon_url_list,omitempty"`   // 封面图片列表,仅支持填入一 个封面图片链接, 上传图片接口 上传获取图片获得链接,填写 非CDN链接会报错,并在此填入。 建议图片尺寸像素850*350
	TextImageList []*TextImage `json:"text_image_list,omitempty"` // type为DATE_TYPE_FIX_TIME_RANGE时专用,表示结束时间,建议设置为截止日期的23:59:59过期。(东八区时间,单位为秒)
}

type AdvancedInfo

type AdvancedInfo struct {
	UseCondition    *UseCondition `json:"use_condition,omitempty"` // 使用门槛(条件)字段,若不填写使用条件则在券面拼写 :无最低消费限制,全场通用,不限品类;并在使用说明显示: 可与其他优惠共享
	Abstract        *Abstract     `json:"abstract,omitempty"`      // 使用门槛(条件)字段,若不填写使用条件则在券面拼写 :无最低消费限制,全场通用,不限品类;并在使用说明显示: 可与其他优惠共享
	TimeLimit       []*TimeLimit  `json:"time_limit,omitempty"`    // 使用门槛(条件)字段,若不填写使用条件则在券面拼写 :无最低消费限制,全场通用,不限品类;并在使用说明显示: 可与其他优惠共享
	BusinessService []string      `json:"business_service"`        //	商家服务类型: BIZ_SERVICE_DELIVER 外卖服务; BIZ_SERVICE_FREE_PARK 停车位; BIZ_SERVICE_WITH_PET 可带宠物; BIZ_SERVICE_FREE_WIFI 免费wifi, 可多选
}

基本的卡券数据, 所有卡券通用

type BatchGetQuery

type BatchGetQuery struct {
	Offset     int      `json:"offset"`                // 查询卡列表的起始偏移量,从0开始,即offset: 5是指从从列表里的第六个开始读取。
	Count      int      `json:"count"`                 // 需要查询的卡片的数量(数量最大50)。
	StatusList []string `json:"status_list,omitempty"` // 支持开发者拉出指定状态的卡券列表,例:仅拉出通过审核的卡券。
}

type BatchGetResult

type BatchGetResult struct {
	TotalNum   int      `json:"total_num"`
	ItemNum    int      `json:"item_num"`
	CardIdList []string `json:"card_id_list"`
}

func BatchGet

func BatchGet(clt *core.Client, query *BatchGetQuery) (rslt *BatchGetResult, err error)

批量查询卡列表.

type BoardingPass

type BoardingPass struct {
	BaseInfo      *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo  *AdvancedInfo `json:"advanced_info,omitempty"`
	From          string        `json:"from,omitempty"`           // 起点, 上限为18 个汉字
	To            string        `json:"to,omitempty"`             // 终点, 上限为18 个汉字
	Flight        string        `json:"flight,omitempty"`         // 航班
	Gate          string        `json:"gate,omitempty"`           // 登机口. 如发生登机口变更, 建议商家实时调用该接口变更
	CheckinURL    string        `json:"check_in_url,omitempty"`   // 在线值机的链接
	AirModel      string        `json:"air_model,omitempty"`      // 机型, 上限为8 个汉字
	DepartureTime int64         `json:"departure_time,omitempty"` // 起飞时间. Unix 时间戳格式
	LandingTime   int64         `json:"landing_time,omitempty"`   // 降落时间. Unix 时间戳格式
	BoardingTime  string        `json:"boarding_time,omitempty"`  // 登机时间, 只显示"时分"不显示日期, 按时间戳格式填写. 如发生登机时间变更, 建议商家实时调用该接口变更.
}

飞机票

type Card

type Card struct {
	CardType string `json:"card_type,omitempty"`

	GeneralCoupon *GeneralCoupon `json:"general_coupon,omitempty"`
	Groupon       *Groupon       `json:"groupon,omitempty"`
	Cash          *Cash          `json:"cash,omitempty"`
	Discount      *Discount      `json:"discount,omitempty"`
	Gift          *Gift          `json:"gift,omitempty"`
	MemberCard    *MemberCard    `json:"member_card,omitempty"`
	MeetingTicket *MeetingTicket `json:"meeting_ticket,omitempty"`
	ScenicTicket  *ScenicTicket  `json:"scenic_ticket,omitempty"`
	MovieTicket   *MovieTicket   `json:"movie_ticket,omitempty"`
	BoardingPass  *BoardingPass  `json:"boarding_pass,omitempty"`
}

卡券数据结构

func Get

func Get(clt *core.Client, cardId string) (card *Card, err error)

查看卡券详情.

type CardBaseInfo

type CardBaseInfo struct {
	CardId string `json:"id,omitempty"`     // 查询的时候有返回
	Status string `json:"status,omitempty"` // 查询的时候有返回
	AppId  string `json:"appid,omitempty"`  // 查询的时候有返回

	LogoURL     string    `json:"logo_url,omitempty"`    // 卡券的商户logo,建议像素为300*300。
	CodeType    string    `json:"code_type,omitempty"`   // Code展示类型
	BrandName   string    `json:"brand_name,omitempty"`  // 商户名字,字数上限为12个汉字。
	Title       string    `json:"title,omitempty"`       // 卡券名,字数上限为9个汉字。(建议涵盖卡券属性、服务及金额)。
	SubTitle    string    `json:"sub_title,omitempty"`   // 券名的副标题, 字数上限为18个汉字。
	Color       string    `json:"color,omitempty"`       // 券颜色。按色彩规范标注填写Color010-Color100。
	Notice      string    `json:"notice,omitempty"`      // 卡券使用提醒,字数上限为16个汉字。
	Description string    `json:"description,omitempty"` // 卡券使用说明,字数上限为1024个汉字。
	SKU         *SKU      `json:"sku,omitempty"`         // 商品信息。
	DateInfo    *DateInfo `json:"date_info,omitempty"`   // 使用日期,有效期的信息。

	UseCustomCode             *bool   `json:"use_custom_code,omitempty"`            // 是否自定义Code码。填写true或false,默认为false。通常自有优惠码系统的开发者选择自定义Code码,并在卡券投放时带入Code码
	BindOpenId                *bool   `json:"bind_openid,omitempty"`                // 是否指定用户领取,填写true或false。默认为false。通常指定特殊用户群体投放卡券或防止刷券时选择指定用户领取。
	ServicePhone              string  `json:"service_phone,omitempty"`              // 客服电话。
	LocationIdList            []int64 `json:"location_id_list,omitempty"`           // 门店位置poiid。
	Source                    string  `json:"source,omitempty"`                     // 第三方来源名,例如同程旅游、大众点评。
	CustomURLName             string  `json:"custom_url_name,omitempty"`            // 自定义跳转外链的入口名字。
	CustomURLSubTitle         string  `json:"custom_url_sub_title,omitempty"`       // 显示在入口右侧的提示语。
	CustomURL                 string  `json:"custom_url,omitempty"`                 // 自定义跳转的URL。
	PromotionURLName          string  `json:"promotion_url_name,omitempty"`         // 营销场景的自定义入口名称。
	PromotionURLSubTitle      string  `json:"promotion_url_sub_title,omitempty"`    // 显示在营销入口右侧的提示语。
	PromotionURL              string  `json:"promotion_url,omitempty"`              // 入口跳转外链的地址链接。
	CustomAppBrandUserName    string  `json:"custom_app_brand_user_name,omitempty"` // 自定义使用入口跳转小程序的user_name,格式为原始id+@app
	CustomAppBrandPass        string  `json:"custom_app_brand_pass,omitempty"`      // 自定义使用入口小程序页面地址
	CenterTitle               string  `json:"center_title,omitempty"`
	CenterSubTitle            string  `json:"center_sub_title,omitempty"`
	CenterURL                 string  `json:"center_url,omitempty"`
	CenterAppBrandUserName    string  `json:"center_app_brand_user_name,omitempty"`    // 自定义居中使用入口小程序页面地址
	CenterAppBrandPass        string  `json:"center_app_brand_pass,omitempty"`         // 小程序的user_name
	PromotionAppBrandUserName string  `json:"promotion_app_brand_user_name,omitempty"` // 自定义营销入口小程序页面地址
	PromotionAppBrandPass     string  `json:"promotion_app_brand_pass,omitempty"`      // 自定义营销入口小程序页面地址
	GetLimit                  *int    `json:"get_limit,omitempty"`                     // 每人可领券的数量限制,不填写默认为50。
	UseLimit                  *int    `json:"use_limit,omitempty"`                     // 每人使用次数限制.
	CanShare                  *bool   `json:"can_share,omitempty"`                     // 卡券领取页面是否可分享。
	CanGiveFriend             *bool   `json:"can_give_friend,omitempty"`               // 卡券是否可转赠。
}

基本的卡券数据, 所有卡券通用

type CardNotPassCheckEvent

type CardNotPassCheckEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType    core.EventType `xml:"Event"        json:"Event"`  // 事件类型, card_not_pass_check
	CardId       string         `xml:"CardId"       json:"CardId"` // 卡券ID
	RefuseReason string         `xml:"RefuseReason" json:"RefuseReason"`
}

卡券未通过审核, 微信会把这个事件推送到开发者填写的URL

func GetCardNotPassCheckEvent

func GetCardNotPassCheckEvent(msg *core.MixedMsg) *CardNotPassCheckEvent

type CardPassCheckEvent

type CardPassCheckEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType core.EventType `xml:"Event"  json:"Event"`  // 事件类型, card_pass_check
	CardId    string         `xml:"CardId" json:"CardId"` // 卡券ID
}

卡券通过审核, 微信会把这个事件推送到开发者填写的URL

func GetCardPassCheckEvent

func GetCardPassCheckEvent(msg *core.MixedMsg) *CardPassCheckEvent

type CardSkuRemindEvent

type CardSkuRemindEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType core.EventType `xml:"Event"  json:"Event"`  // 事件类型, card_sku_remind
	CardId    string         `xml:"CardId" json:"CardId"` // 卡券ID
	Detail    string         `xml:"Detail" json:"Detail"` // 报警详细信息
}

库存报警事件

func GetCardSkuRemindEvent

func GetCardSkuRemindEvent(msg *core.MixedMsg) *CardSkuRemindEvent

type Cash

type Cash struct {
	BaseInfo     *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo *AdvancedInfo `json:"advanced_info,omitempty"`
	LeastCost    *int          `json:"least_cost,omitempty"`  // 代金券专用, 表示起用金额(单位为分)
	ReduceCost   *int          `json:"reduce_cost,omitempty"` // 代金券专用, 表示减免金额(单位为分)
}

代金券

type Color

type Color struct {
	Name  string `json:"name"`
	Value string `json:"value"`
}

func GetColors

func GetColors(clt *core.Client) (colors []Color, err error)

获取卡券最新的颜色列表.

type DateInfo

type DateInfo struct {
	Type           string `json:"type"`                       // 使用时间的类型, DATE_TYPE_FIX_TIME_RANGE 表示固定日期区间,DATE_TYPE_FIX_TERM表示固定时长(自领取后按天算)
	BeginTimestamp int64  `json:"begin_timestamp,omitempty"`  // type为DATE_TYPE_FIX_TIME_RANGE时专用,表示起用时间。从1970年1月1日00:00:00至起用时间的秒数,最终需转换为字符串形态传入。(东八区时间,单位为秒)
	EndTimestamp   int64  `json:"end_timestamp,omitempty"`    // type为DATE_TYPE_FIX_TIME_RANGE时专用,表示结束时间,建议设置为截止日期的23:59:59过期。(东八区时间,单位为秒)
	FixedTerm      *int   `json:"fixed_term,omitempty"`       // type为DATE_TYPE_FIX_TERM时专用,表示自领取后多少天内有效,领取后当天有效填写0。(单位为天)
	FixedBeginTerm *int   `json:"fixed_begin_term,omitempty"` // type为DATE_TYPE_FIX_TERM时专用,表示自领取后多少天开始生效。(单位为天)
}

type Discount

type Discount struct {
	BaseInfo     *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo *AdvancedInfo `json:"advanced_info,omitempty"`
	Discount     *int          `json:"discount,omitempty"` // 折扣券专用, 表示打折额度(百分比). 填30 就是七折.
}

折扣券

type GeneralCoupon

type GeneralCoupon struct {
	BaseInfo      *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo  *AdvancedInfo `json:"advanced_info,omitempty"`
	DefaultDetail string        `json:"default_detail,omitempty"` // 优惠券专用, 填写优惠详情
}

优惠券

type Gift

type Gift struct {
	BaseInfo     *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo *AdvancedInfo `json:"advanced_info,omitempty"`
	Gift         string        `json:"gift,omitempty"` // 礼品券专用, 表示礼品名字
}

礼品券

type GiftCardPayDoneEvent

type GiftCardPayDoneEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType core.EventType `xml:"Event"   json:"Event"`   // 事件类型,此处为giftcard_pay_done标识订单完成事件
	PageId    string         `xml:"PageId"  json:"PageId"`  // 货架的id
	OrderId   string         `xml:"OrderId" json:"OrderId"` // 订单号
}

用户购买礼品卡付款成功

func GetGiftCardPayDoneEvent

func GetGiftCardPayDoneEvent(msg *core.MixedMsg) *GiftCardPayDoneEvent

type GiftCardUserAcceptEvent

type GiftCardUserAcceptEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType core.EventType `xml:"Event"   json:"Event"`   // 事件类型,此处为giftcard_user_accept标识订单完成事件
	PageId    string         `xml:"PageId"  json:"PageId"`  // 货架的id
	OrderId   string         `xml:"OrderId" json:"OrderId"` // 订单号
}

用户领取礼品卡成功

func GetGiftCardUserAcceptEvent

func GetGiftCardUserAcceptEvent(msg *core.MixedMsg) *GiftCardUserAcceptEvent

type Groupon

type Groupon struct {
	BaseInfo     *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo *AdvancedInfo `json:"advanced_info,omitempty"`
	DealDetail   string        `json:"deal_detail,omitempty"` // 团购券专用,团购详情
}

团购券

type MeetingTicket

type MeetingTicket struct {
	BaseInfo      *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo  *AdvancedInfo `json:"advanced_info,omitempty"`
	MeetingDetail string        `json:"meeting_detail,omitempty"` // 会议详情
	MapURL        string        `json:"map_url,omitempty"`        // 会议导览图
}

会议门票

type MemberCard

type MemberCard struct {
	BaseInfo                *CardBaseInfo          `json:"base_info,omitempty"`
	BackgroundPicURL        string                 `json:"background_pic_url,omitempty"`
	AdvancedInfo            *AdvancedInfo          `json:"advanced_info,omitempty"`
	Prerogative             string                 `json:"prerogative,omitempty"`                 // 会员卡特权说明
	SupplyBonus             *bool                  `json:"supply_bonus,omitempty"`                // 显示积分,填写true或false,如填写true,积分相关字段均为必填
	BonusURL                string                 `json:"bonus_url,omitempty"`                   // 设置跳转外链查看积分详情。仅适用于积分无法通过激活接口同步的情况下使用该字段。
	SupplyBalance           *bool                  `json:"supply_balance,omitempty"`              // 是否支持储值,填写true或false。如填写true,储值相关字段均为必填。
	BonusAppBrandUserName   string                 `json:"bonus_app_brand_user_name,omitempty"`   // 自定义信息类目小程序user_name,格式为原始id+@app
	BonusAppBrandPass       string                 `json:"bonus_app_brand_pass,omitempty"`        // 自定义信息类目小程序的页面路径
	BalanceURL              string                 `json:"balance_url,omitempty"`                 // 设置跳转外链查看余额详情。仅适用于余额无法通过激活接口同步的情况下使用该字段。
	BonusClearedRules       string                 `json:"bonus_cleared,omitempty"`               // 积分清零规则。
	BonusRule               *MemberCardBonusRule   `json:"bonus_rule,omitempty"`                  // 积分规则的json结构。
	BonusRules              string                 `json:"bonus_rules,omitempty"`                 // 积分规则。
	BonusCleared            string                 `json:"bonus_cleared,omitempty"`               // 积分规则。
	BalanceRules            string                 `json:"balance_rules,omitempty"`               // 储值说明。
	BalanceAppBrandUserName string                 `json:"balance_app_brand_user_name,omitempty"` // 自定义信息类目小程序user_name,格式为原始id+@app
	BalanceAppBrandPass     string                 `json:"balance_app_brand_pass,omitempty"`      // 自定义信息类目小程序的页面路径
	WxActivate              *bool                  `json:"wx_activate,omitempty"`
	AutoActivate            *bool                  `json:"auto_activate,omitempty"`
	ActivateURL             string                 `json:"activate_url,omitempty"`      // 激活会员卡的url。
	NeedPushOnView          *bool                  `json:"need_push_on_view,omitempty"` // 填写true为用户点击进入会员卡时推送事件,默认为false。
	CustomField1            *MemberCardCustomField `json:"custom_field1,omitempty"`     // 自定义会员信息类目,会员卡激活后显示。
	CustomField2            *MemberCardCustomField `json:"custom_field2,omitempty"`     // 自定义会员信息类目,会员卡激活后显示。
	CustomField3            *MemberCardCustomField `json:"custom_field3,omitempty"`     // 自定义会员信息类目,会员卡激活后显示。
	CustomCell1             *MemberCardCustomCell  `json:"custom_cell1,omitempty"`      // 自定义会员信息类目,会员卡激活后显示。
	Discount                *int                   `json:"discount,omitempty"`          // 会员卡买单的折扣信息,表示打折额度(百分比). 填30 就是七折.
}

会员卡

type MemberCardBonusRule

type MemberCardBonusRule struct {
	CostMoneyUnit         int `json:"cost_money_unit"`          // 积分消费单元 例如 每消费100元
	IncreaseBonus         int `json:"increase_bonus"`           // 赠送积分数目
	MaxIncreaseBonus      int `json:"max_increase_bonus"`       // 最多赠送积分
	InitIncreaseBonus     int `json:"init_increase_bonus"`      // 开卡赠送积分
	CostBonusUnit         int `json:"cost_bonus_unit"`          // 积分抵扣单元 例如 每100积分
	ReduceMoney           int `json:"reduce_money"`             // 积分抵扣金额 例如 抵扣20元
	LeastMoneyToUserBonus int `json:"least_money_to_use_bonus"` // 抵扣条件 使用积分最低消费金额
	MaxReduceBonus        int `json:"max_reduce_bonus"`         // 单次消费最多使用积分
}

type MemberCardCustomCell

type MemberCardCustomCell struct {
	Name             string `json:"name,omitempty"`                // 入口名称。
	Tips             string `json:"tips,omitempty"`                // 入口右侧提示语,6个汉字内。
	URL              string `json:"url,omitempty"`                 // 入口跳转链接。
	AppBrandUserName string `json:"app_brand_user_name,omitempty"` // 自定义信息类目小程序user_name,格式为原始id+@app
	AppBrandPass     string `json:"app_brand_pass,omitempty"`      // 自定义信息类目小程序的页面路径
}

type MemberCardCustomField

type MemberCardCustomField struct {
	// 会员信息类目名称:
	//
	// FIELD_NAME_TYPE_LEVEL        等级
	// FIELD_NAME_TYPE_COUPON       优惠券
	// FIELD_NAME_TYPE_STAMP        印花
	// FIELD_NAME_TYPE_DISCOUNT     折扣
	// FIELD_NAME_TYPE_ACHIEVEMEN   成就
	// FIELD_NAME_TYPE_MILEAGE      里程
	NameType         string `json:"name_type,omitempty"`
	URL              string `json:"url,omitempty"`                 // 点击类目跳转外链url
	AppBrandUserName string `json:"app_brand_user_name,omitempty"` // 自定义信息类目小程序user_name,格式为原始id+@app
	AppBrandPass     string `json:"app_brand_pass,omitempty"`      // 自定义信息类目小程序的页面路径
}

type MovieTicket

type MovieTicket struct {
	BaseInfo     *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo *AdvancedInfo `json:"advanced_info,omitempty"`
	Detail       string        `json:"detail,omitempty"` // 电影票详情
}

电影票

type SKU

type SKU struct {
	Quantity int `json:"quantity"` // 卡券库存的数量,不支持填写0,上限为100000000。
}

type ScenicTicket

type ScenicTicket struct {
	BaseInfo     *CardBaseInfo `json:"base_info,omitempty"`
	AdvancedInfo *AdvancedInfo `json:"advanced_info,omitempty"`
	TicketClass  string        `json:"ticket_class,omitempty"` // 票类型, 例如平日全票, 套票等
	GuideURL     string        `json:"guide_url,omitempty"`    // 导览图url
}

景区门票

type TextImage

type TextImage struct {
	ImageUrl string `json:"image_url"`      // 图片链接,必须调用 上传图片接口 上传图片获得链接,并在此填入, 否则报错
	Text     string `json:"text,omitempty"` // 图文描述
}

type TimeLimit

type TimeLimit struct {
	Type        string `json:"type"`                   // 限制类型枚举值:支持填入 MONDAY 周一 TUESDAY 周二 WEDNESDAY 周三 THURSDAY 周四 FRIDAY 周五 SATURDAY 周六 SUNDAY 周日 此处只控制显示, 不控制实际使用逻辑,不填默认不显示
	BeginHour   int64  `json:"begin_hour,omitempty"`   // 当前type类型下的起始时间(小时) ,如当前结构体内填写了MONDAY, 此处填写了10,则此处表示周一 10:00可用
	BeginMinute int64  `json:"begin_minute,omitempty"` // 	当前type类型下的起始时间(分钟) ,如当前结构体内填写了MONDAY, begin_hour填写10,此处填写了59, 则此处表示周一 10:59可用
	EndHour     *int   `json:"end_hour,omitempty"`     // 当前type类型下的结束时间(小时) ,如当前结构体内填写了MONDAY, 此处填写了20, 则此处表示周一 10:00-20:00可用
	EndMinute   *int   `json:"end_minute,omitempty"`   //当前type类型下的结束时间(分钟) ,如当前结构体内填写了MONDAY, begin_hour填写10,此处填写了59, 则此处表示周一 10:59-00:59可用
}

type UseCondition

type UseCondition struct {
	AcceptCategory          string `json:"accept_category,omitempty"`             //指定可用的商品类目,仅用于代金券类型 ,填入后将在券面拼写适用于xxx
	RejectCategory          string `json:"reject_category,omitempty"`             // 指定不可用的商品类目,仅用于代金券类型 ,填入后将在券面拼写不适用于xxxx
	LeastCost               int    `json:"least_cost,omitempty"`                  // 满减门槛字段,可用于兑换券和代金券 ,填入后将在全面拼写消费满xx元可用。
	ObjectUseFor            string `json:"object_use_for,omitempty"`              //购买xx可用类型门槛,仅用于兑换 ,填入后自动拼写购买xxx可用。
	CanUseWithOtherDiscount *bool  `json:"can_use_with_other_discount,omitempty"` //不可以与其他类型共享门槛 ,填写false时系统将在使用须知里 拼写“不可与其他优惠共享”, 填写true时系统将在使用须知里 拼写“可与其他优惠共享”, 默认为true
}

type UserConsumeCardEvent

type UserConsumeCardEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType     core.EventType `xml:"Event"         json:"Event"`         // 事件类型, user_consume_card
	CardId        string         `xml:"CardId"        json:"CardId"`        // 卡券ID
	UserCardCode  string         `xml:"UserCardCode"  json:"UserCardCode"`  // 商户自定义code 值. 非自定code 推送为空串
	ConsumeSource string         `xml:"ConsumeSource" json:"ConsumeSource"` // 核销来源。支持开发者统计API核销(FROM_API)、公众平台核销(FROM_MP)、卡券商户助手核销(FROM_MOBILE_HELPER)(核销员微信号)
	LocationName  string         `xml:"LocationName"  json:"LocationName"`  // 门店名称,当前卡券核销的门店名称(只有通过自助核销和买单核销时才会出现该字段)
	StaffOpenId   string         `xml:"StaffOpenId"   json:"StaffOpenId"`   // 核销该卡券核销员的openid(只有通过卡券商户助手核销时才会出现)
	VerifyCode    string         `xml:"VerifyCode"    json:"VerifyCode"`    // 自助核销时,用户输入的验证码
	RemarkAmount  string         `xml:"RemarkAmount"  json:"RemarkAmount"`  // 自助核销时,用户输入的备注金额
	OuterStr      string         `xml:"OuterStr"      json:"OuterStr"`      // 开发者发起核销时传入的自定义参数,用于进行核销渠道统计
}

核销事件推送

func GetUserConsumeCardEvent

func GetUserConsumeCardEvent(msg *core.MixedMsg) *UserConsumeCardEvent

type UserDelCardEvent

type UserDelCardEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType    core.EventType `xml:"Event"        json:"Event"`        // 事件类型, user_del_card
	CardId       string         `xml:"CardId"       json:"CardId"`       // 卡券ID
	UserCardCode string         `xml:"UserCardCode" json:"UserCardCode"` // 商户自定义code 值. 非自定code 推送为空串
}

用户在删除卡券时, 微信会把这个事件推送到开发者填写的URL.

func GetUserDelCardEvent

func GetUserDelCardEvent(msg *core.MixedMsg) *UserDelCardEvent

type UserEnterSessionFromCardEvent

type UserEnterSessionFromCardEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType    core.EventType `xml:"Event"        json:"Event"`        // 事件类型, user_view_card
	CardId       string         `xml:"CardId"       json:"CardId"`       // 卡券ID
	UserCardCode string         `xml:"UserCardCode" json:"UserCardCode"` // 商户自定义code 值. 非自定code 推送为空串
}

从卡券进入公众号会话事件推送

func GetUserEnterSessionFromCardEvent

func GetUserEnterSessionFromCardEvent(msg *core.MixedMsg) *UserEnterSessionFromCardEvent

type UserGetCardEvent

type UserGetCardEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType           core.EventType `xml:"Event"               json:"Event"`           // 事件类型, user_get_card
	CardId              string         `xml:"CardId"              json:"CardId"`          // 卡券ID
	IsGiveByFriend      int            `xml:"IsGiveByFriend"      json:"IsGiveByFriend"`  // 是否为转赠, 1 代表是, 0 代表否.
	FriendUserName      string         `xml:"FriendUserName"      json:"FriendUserName"`  // 赠送方账号(一个OpenID), "IsGiveByFriend"为1 时填写该参数.
	UserCardCode        string         `xml:"UserCardCode"        json:"UserCardCode"`    // code 序列号. 自定义code 及非自定义code的卡券被领取后都支持事件推送.
	OldUserCardCode     string         `xml:"OldUserCardCode"     json:"OldUserCardCode"` // 转赠前的code序列号。
	OuterId             int64          `xml:"OuterId"             json:"OuterId"`         // 领取场景值, 用于领取渠道数据统计. 可在生成二维码接口及添加JS API 接口中自定义该字段的整型值.
	OuterStr            string         `xml:"OuterStr"            json:"OuterStr"`
	IsRestoreMemberCard int            `xml:"IsRestoreMemberCard" json:"IsRestoreMemberCard"`
	IsRecommendByFriend int            `xml:"IsRecommendByFriend" json:"IsRecommendByFriend"`
	UnionId             string         `xml:"UnionId"             json:"UnionId"`
}

用户在领取卡券时, 微信会把这个事件推送到开发者填写的URL.

func GetUserGetCardEvent

func GetUserGetCardEvent(msg *core.MixedMsg) *UserGetCardEvent

type UserGiftingCardEvent

type UserGiftingCardEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType      core.EventType `xml:"Event"          json:"Event"`
	CardId         string         `xml:"CardId"         json:"CardId"`
	UserCardCode   string         `xml:"UserCardCode"   json:"UserCardCode"`
	IsReturnBack   int            `xml:"IsReturnBack"   json:"IsReturnBack"`
	FriendUserName string         `xml:"FriendUserName" json:"FriendUserName"`
	IsChatRoom     int            `xml:"IsChatRoom"     json:"IsChatRoom"`
}

转赠事件推送.

func GetUserGiftingCardEvent

func GetUserGiftingCardEvent(msg *core.MixedMsg) *UserGiftingCardEvent

type UserViewCardEvent

type UserViewCardEvent struct {
	XMLName struct{} `xml:"xml" json:"-"`
	core.MsgHeader

	EventType    core.EventType `xml:"Event"        json:"Event"`        // 事件类型, user_view_card
	CardId       string         `xml:"CardId"       json:"CardId"`       // 卡券ID
	UserCardCode string         `xml:"UserCardCode" json:"UserCardCode"` // 商户自定义code 值. 非自定code 推送为空串
}

用户在进入会员卡时, 微信会把这个事件推送到开发者填写的URL

func GetUserViewCardEvent

func GetUserViewCardEvent(msg *core.MixedMsg) *UserViewCardEvent

Directories

Path Synopsis
see github.com/charsunny/wechat/mp/datacube
see github.com/charsunny/wechat/mp/datacube

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL