func push_example() {
	const (
		appKey       = "8b7127870ccae51a2c2e6da4"
		masterSecret = "55df2bc707d65fb39ca01325"
	)

	// platform 对象
	platform := push.NewPlatform()
	// 用 Add() 方法添加具体平台参数,可选: "all", "ios", "android"
	platform.Add("ios", "android")
	// 或者用 All() 方法设置所有平台
	// platform.All()

	// audience 对象,表示消息受众
	audience := push.NewAudience()
	audience.SetTag([]string{"广州", "深圳"})   // 设置 tag
	audience.SetTagAnd([]string{"北京", "女"}) // 设置 tag_and
	// 和 platform 一样,可以调用 All() 方法设置所有受众
	// audience.All()

	// notification 对象,表示 通知,传递 alert 属性初始化
	notification := push.NewNotification("Notification Alert")

	// android 平台专有的 notification,用 alert 属性初始化
	androidNotification := push.NewAndroidNotification("Android Notification Alert")
	androidNotification.Title = "title"
	androidNotification.AddExtra("key", "value")

	notification.Android = androidNotification

	// iOS 平台专有的 notification,用 alert 属性初始化
	iosNotification := push.NewIosNotification("iOS Notification Alert")
	iosNotification.Badge = 1
	// Validate 方法可以验证 iOS notification 是否合法
	// 一般情况下,开发者不需要直接调用此方法,这个方法会在构造 PushObject 时自动调用
	// iosNotification.Validate()

	notification.Ios = iosNotification

	// Windows Phone 平台专有的 notification,用 alert 属性初始化
	wpNotification := push.NewWinphoneNotification("Winphone Notification Alert")
	// 所有平台的专有 notification 都有 AddExtra 方法,用于添加 extra 信息
	wpNotification.AddExtra("key", "value")
	wpNotification.AddExtra("extra_key", "extra_value")

	notification.Winphone = wpNotification

	// message 对象,表示 透传消息,用 content 属性初始化
	message := push.NewMessage("Message Content must not be empty")
	message.Title = "Message Title"

	// option 对象,表示推送可选项
	options := push.NewOptions()
	// iOS 平台,是否推送生产环境,false 表示开发环境;如果不指定,就是生产环境
	options.ApnsProduction = true
	// Options 的 Validate 方法会对 time_to_live 属性做范围限制,以满足 JPush 的规范
	options.TimeToLive = 10000000
	// Options 的 Validate 方法会对 big_push_duration 属性做范围限制,以满足 JPush 的规范
	options.BigPushDuration = 1500

	payload := push.NewPushObject()
	payload.Platform = platform
	payload.Audience = audience
	payload.Notification = notification
	payload.Message = message
	payload.Options = options

	data, err := json.Marshal(payload)
	if err != nil {
		fmt.Println("json.Marshal PushObject failed:", err)
		os.Exit(1)
	}
	fmt.Println("payload:", string(data), "\n")

	// 创建 JPush 的客户端
	jclient := jpush.NewJPushClient(appKey, masterSecret)
	jclient.SetDebug(true)

	// Push 会推送到客户端
	// result, err := jclient.Push(payload)

	// PushValidate 的参数和 Push 完全一致
	// 区别在于,PushValidate 只会验证推送调用成功,不会向用户发送任何消息
	result, err := jclient.PushValidate(payload)
	if err != nil {
		fmt.Print("\nPushValidate failed:", err)
	} else {
		fmt.Println("\nPushValidate result:", result)
	}
}
Example #2
0
//推送消息
func (j *Jpush) PushDevice() (err error, result *push.PushResult) {
	// platform 对象
	platform := push.NewPlatform()
	// 用 Add() 方法添加具体平台参数,可选: "all", "ios", "android"
	platform.Add("ios")

	// audience 对象,表示消息受众
	audience := push.NewAudience()
	// 和 platform 一样,可以调用 All() 方法设置所有受众
	switch j.style {
	case "0":
		audience.All()
	case "1":
		audience.SetAlias(j.audience.([]string))
	case "2":
		audience.SetRegistrationId(j.audience.([]string))
	default:
		audience.All()
	}

	// notification 对象,表示 通知,传递 alert 属性初始化
	notification := push.NewNotification(j.title)

	// iOS 平台专有的 notification,用 alert 属性初始化
	iosNotification := push.NewIosNotification(j.title)
	iosNotification.Badge = 1

	//这里自定义 Key/value 信息,以供业务使用。
	if len(j.extras) > 0 {
		extrasMap := j.extras
		iosNotification.Extras = extrasMap
	}
	notification.Ios = iosNotification

	message := push.NewMessage(j.title)
	message.Title = j.title

	// option 对象,表示推送可选项
	options := push.NewOptions()
	// Options 的 Validate 方法会对 time_to_live 属性做范围限制,以满足 JPush 的规范
	options.TimeToLive = 86400
	// iOS 平台,是否推送生产环境,false 表示开发环境;如果不指定,就是生产环境
	options.ApnsProduction = true
	// 构建jpush推送的数据对象
	payload := push.NewPushObject()
	payload.Platform = platform
	payload.Audience = audience
	payload.Notification = notification
	payload.Message = message
	payload.Options = options

	//创建jpush对象
	jclient := jpush.NewJPushClient(appKey, masterSecret)

	//Push 会推送到客户端
	result, err = jclient.Push(payload)

	// PushValidate 的参数和 Push 完全一致
	// 区别在于,PushValidate 只会验证推送调用成功,不会向用户发送任何消息
	//result, err = jclient.PushValidate(payload)

	if err != nil {
		return err, result
	} else {
		return nil, result
	}
}