| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212 |
- //
- // Copyright (c) 2023 Tencent. All rights reserved.
- //
- //
- #import <UIKit/UIKit.h>
- #import <Foundation/Foundation.h>
- #import <UserNotifications/UserNotifications.h>
- @protocol TIMPushDelegate;
- @protocol TIMPushListener;
- @class TIMPushMessage;
- NS_ASSUME_NONNULL_BEGIN
- typedef void(^TIMPushCallback)(void);
- typedef void(^TIMPushValueCallback)(NSString *value);
- typedef void(^TIMPushSuccessCallback)(NSData * deviceToken);
- typedef void(^TIMPushFailedCallback)(int code, NSString * desc);
- typedef void(^TIMPushCallExperimentalAPISucc)(NSObject *object);
- typedef void(^TIMPushNotificationExtensionCallback)(UNNotificationContent *content) API_AVAILABLE(macos(10.14), ios(10.0), watchos(3.0), tvos(10.0));
- @interface TIMPushManager : NSObject
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //
- // (一)注册/反注册推送服务
- //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- /**
- * 1.1 注册推送服务
- *
- * @param sdkAppId 应用的 SDKAPPID
- * @param appKey 控制台为您分配的 secretKey
- *
- * @note 请注意:
- * - 如果您单独使用推送服务,请正确传递 sdkAppId 和 appkey 两个参数,即可注册推送服务
- * - 如果您已经集成 IM 产品,请在 IM 登录成功后调用该接口,将 appKey 参数设置为 nil,接入离线推送能力.
- */
- + (void)registerPush:(int)sdkAppId appKey:(NSString *)appKey
- succ:(TIMPushSuccessCallback)successCallback
- fail:(TIMPushFailedCallback)failedCallback NS_EXTENSION_UNAVAILABLE_IOS("This API is not supported in App Extension");
- /**
- * 1.2 取消注册
- *
- * @note
- * - 在退出登录时调用
- * - 如果您使用了 [TUILogin](https://github.com/TencentCloud/TIMSDK/blob/master/iOS/TUIKit/TUICore/TUILogin.h) 提供的 login/logout,无需再调用该接口
- */
- + (void)unRegisterPush:(TIMPushCallback)successCallback
- fail:(TIMPushFailedCallback)failedCallback
- NS_EXTENSION_UNAVAILABLE_IOS("This API is not supported in App Extension");
- /**
- * 1.3 注册离线推送服务成功后,获取注册 ID 标识, 即 RegistrationID
- *
- * @note 请注意:
- * - callback 回调值是 registerPush 时候传递的 userId
- * - 若传递 userId 为空,则为设备的标识 ID,卸载重装会改变。
- *
- */
- + (void)getRegistrationID:(TIMPushValueCallback)callback NS_EXTENSION_UNAVAILABLE_IOS("This API is not supported in App Extension");
- /**
- * 1.4 设置注册离线推送服务使用的推送 ID 标识, 即 RegistrationID,需要在注册推送服务之前调用
- *
- * @param registrationID 为设备的推送标识 ID,卸载重装会改变。
- *
- */
- + (void)setRegistrationID:(NSString *)registrationID callback:(TIMPushCallback)callback NS_EXTENSION_UNAVAILABLE_IOS("This API is not supported in App Extension");
- /**
- * 1.5 设置应用前台是否展示推送
- *
- * @param disable 如果值为 YES,则关闭前台推送;如果值为 NO,则开启前台推送展示。
- *
- */
- + (void)disablePostNotificationInForeground:(BOOL)disable NS_SWIFT_NAME(disablePostNotificationInForeground(disable:));
- /**
- * 1.6 实验性 API 接口
- *
- * @param api 接口名称
- * @param param 接口参数
- * @note 该接口提供一些实验性功能
- */
- + (void)callExperimentalAPI:(NSString *)api
- param:(NSObject * _Nullable)param
- succ:(TIMPushCallExperimentalAPISucc)succ
- fail:(TIMPushFailedCallback)fail NS_EXTENSION_UNAVAILABLE_IOS("This API is not supported in App Extension");
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //
- // (二) Push 全局监听
- //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- /**
- * 2.1 添加 Push 监听器
- */
- + (void)addPushListener:(id<TIMPushListener>)listener NS_SWIFT_NAME(addPushListener(listener:)) NS_EXTENSION_UNAVAILABLE_IOS("This API is not supported in App Extension");
- /**
- * 2.2. 移除 Push 监听器
- */
- + (void)removePushListener:(id<TIMPushListener>)listener NS_SWIFT_NAME(removePushListener(listener:)) NS_EXTENSION_UNAVAILABLE_IOS("This API is not supported in App Extension");
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //
- // (三)统计 TIMPush 的推送抵达率
- //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- /**
- * 3.1 统计 TIMPush 的推送抵达率 (按照需求选择启用)
- *
- * @note 请注意:
- * - 仅支持在 Notification Service Extension 的 '- didReceiveNotificationRequest:withContentHandler:' 方法中调用;
- * - appGroup 标识当前主 APP 和 Extension 之间共享的 APP Group,需要在主 APP 的 Capability 中配置 App Groups 能力。
- * - 可以点击[https://cloud.tencent.com/document/product/269/100627#a76b331f-3d49-48c9-99a9-5301c7d7fa99]查阅详细步骤
- */
- + (void)handleNotificationServiceRequest:(UNNotificationRequest *)request appGroupID:(NSString *)appGroupID callback:(TIMPushNotificationExtensionCallback)callback NS_SWIFT_NAME(handleNotificationServiceRequest(request:appGroupID:callback:));
- @end
- @protocol TIMPushListener <NSObject>
- /**
- * 收到 Push 消息
- *
- * @param message 消息
- */
- - (void)onRecvPushMessage:(TIMPushMessage *)message;
- /**
- * 收到 Push 消息撤回的通知
- *
- * @param messageID 消息唯一标识
- */
- - (void)onRevokePushMessage:(NSString *)messageID;
- /**
- * 点击通知栏消息回调
- *
- * @param ext 离线消息透传字段
- *
- */
- - (void)onNotificationClicked:(NSString *)ext;
- @end
- ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- //
- // 离线推送证书配置 与 点击事件处理回调
- //
- //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- @protocol TIMPushDelegate <UIApplicationDelegate>
- @optional
- /**
- * 离线推送证书的 ID
- * 您需要在 AppDelegate.m 中实现该方法,返回值为 IM 控制台分配的证书 ID
- *
- * 特别注意的是,该证书ID使用时需要对应您的运行环境:
- * 使用开发环境的证书ID,可以直接在Xcode上运行测试(Debug 即可调试推送)。
- * 使用生产环境的证书ID,需要您 Archive 出 release 包后进行测试。
- */
- - (int)businessID;
- /**
- * 主 APP 和 NSNotification Service Extension 所属的 App Group ID [可选]
- * 注意: 当您需要借助 iOS 10 特性来统计消息的抵达率时,推荐您设置此属性。
- * 详细步骤可查阅:https://cloud.tencent.com/document/product/269/100624#ae5590eb-b974-4226-9f1b-720fb0201c85
- */
- - (NSString *)applicationGroupID;
- /**
- * 收到远程推送(在线收到后触发、离线时点击通知栏通知触发)
- * 如果要自定义解析收到的远程推送通知,请在您的 AppDelegate 中实现该方法
- *
- * @note
- * - 如果返回 YES, TIMPush 将不在执行内置的 TUIKit 离线推送解析逻辑,完全交由您自行处理;
- * - 如果返回 NO,TIMPush 将继续执行内置的 TUIKit 离线推送解析逻辑,继续回调 - navigateToBuiltInChatViewController:groupID: 方法。
- */
- - (BOOL)onRemoteNotificationReceived:(nullable NSString *)notice;
- /**
- * 点击通知栏离线推送的通知后,跳转到自定义页面
- * 如果要实现跳转到聊天列表,请在您的 AppDelegate 中实现如下方法
- *
- * @note
- * - TIMPush 默认已经从离线推送中解析出当前推送的 userID 和 groupID
- * - 如果 groupID 不为空,说明当前点击的是群聊离线消息
- * - 如果 groupID 为空且 userID 不为空,说明当前点击的是单聊离线消息
- */
- - (void)navigateToBuiltInChatViewController:(nullable NSString *)userID
- groupID:(nullable NSString *)groupID NS_SWIFT_NAME(navigateToBuiltInChatViewController(userID:groupID:));
- @end
- @interface TIMPushMessage : NSObject
- // 离线推送标题
- @property (nonatomic, copy) NSString *title;
- // 离线推送内容
- @property (nonatomic, copy) NSString *desc;
- // 离线推送透传内容
- @property (nonatomic, copy) NSString *ext;
- // 消息唯一标识 ID
- @property (nonatomic, copy) NSString *messageID;
- @end
- NS_ASSUME_NONNULL_END
|