- 实现了Android SDK的完整IM功能接口,包括消息、群组、好友、会话等核心功能 - 添加了消息收发、历史记录、撤回编辑等完整的消息操作能力 - 实现了群组管理功能,包括创建、成员管理、权限设置等操作 - 添加了好友关系链管理,支持添加、删除、分组等操作 - 实现了会话管理功能,包括置顶、免打扰、已读状态等 - 添加了黑名单、资料管理、搜索等辅助功能 - 补齐了批量操作接口,提升客户端操作效率 - 实现了WebSocket连接管理和事件监听机制 - 添加了离线消息同步和状态管理功能
3.3 KiB
3.3 KiB
iOS 推送接入指南
模块:XuqmPush · 支持:APNs(默认)、FCM(可选)
1. 添加依赖
在 Package.swift 中按需引入:
.target(
name: "MyApp",
dependencies: [
.product(name: "XuqmPush", package: "XuqmGroup-iOSSDK"),
]
)
如需 FCM 支持,额外在 Xcode 中集成 FirebaseMessaging。
2. 申请通知权限
在应用启动时请求用户授权:
import XuqmPush
let granted = try await PushSDK.shared.requestAuthorization(options: [.alert, .badge, .sound])
if granted {
print("用户已授权通知")
}
requestAuthorization 内部会自动调用 UIApplication.shared.registerForRemoteNotifications(),无需额外处理。
3. 注册 APNs Token
在 AppDelegate 中转发系统回调:
import XuqmSDK
func application(
_ application: UIApplication,
didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data
) {
// 将 deviceToken 转发生给 SDK
XuqmSDK.shared.registerDeviceToken(deviceToken)
}
func application(
_ application: UIApplication,
didFailToRegisterForRemoteNotificationsWithError error: Error
) {
print("注册远程通知失败: \(error.localizedDescription)")
}
XuqmSDK.shared.login()成功后会自动将 APNs Token 上报到 Push 服务端,业务层无需手动调用PushSDK.shared.registerDeviceToken()。
4. FCM 支持(可选)
如需集成 Firebase Cloud Messaging:
- 在 Xcode 中添加
FirebaseMessaging依赖 - 配置
GoogleService-Info.plist - 在获取到 FCM Token 后手动注册:
import XuqmPush
// 在 Firebase Messaging 回调中获取 FCM Token
func messaging(_ messaging: Messaging, didReceiveRegistrationToken fcmToken: String?) {
guard let token = fcmToken else { return }
try await PushSDK.shared.registerFcmToken(token, userId: "user_001")
}
可通过 PushSDK.shared.isFcmAvailable 检查当前是否编译了 FCM:
if PushSDK.shared.isFcmAvailable {
print("FCM 模块已集成")
}
5. 接收推送消息
实现 PushMessageDelegate 处理推送消息:
import XuqmPush
class MyPushHandler: NSObject, PushMessageDelegate {
func pushSDK(_ sdk: PushSDK, didReceiveMessage message: PushMessage) {
// 应用在前台时收到通知
print("收到推送: \(message.title ?? "") - \(message.body ?? "")")
print("Payload: \(message.payload)")
}
func pushSDK(_ sdk: PushSDK, didTapNotification message: PushMessage) {
// 用户点击通知栏消息
print("用户点击了通知: \(message.title ?? "")")
// 可在此跳转至对应会话页面
}
}
// 设置代理
PushSDK.shared.delegate = MyPushHandler()
PushSDK 内部已实现 UNUserNotificationCenterDelegate,会自动处理前台展示和点击事件。业务层只需设置 delegate 即可接收回调。
6. 多模块统一登录
Push 模块与 IM、Update 模块共享同一套登录态:
// 登录成功后自动触发
try await XuqmSDK.shared.login(userId: "user_001", userSig: userSig)
// ↓ 自动触发
// · PushSDK 注册 APNs Token 并上报
7. 登出时注销 Token
try await PushSDK.shared.unregisterToken(userId: "user_001")