XuqmGroup-AndroidSDK/sdk-core/README.md
XuqmGroup c8a482a5c0 refactor: sdk-log → sdk-bugcollect
- 目录/包名/类名/Gradle plugin 全部重命名
- XLog → BugCollect
- logApiUrl/logEnabled → bugCollectApiUrl/bugCollectEnabled
- assembleDebug 通过

Co-Authored-By: Claude <noreply@anthropic.com>
2026-06-16 17:39:23 +08:00

94 行
2.5 KiB
Markdown

此文件含有模棱两可的 Unicode 字符

此文件含有可能会与其他字符混淆的 Unicode 字符。 如果您是想特意这样的,可以安全地忽略该警告。 使用 Escape 按钮显示他们。

# sdk-core
XuqmGroup Android SDK 核心模块。提供 SDK 初始化、HTTP 请求、Token 管理、文件操作、通用工具。
## 依赖
```kotlin
implementation("com.xuqm:sdk-core:VERSION")
```
## 初始化
### 方式 A — ContentProvider 自动初始化(推荐)
`config.xuqm` 放入 `src/main/assets/xuqm/`,SDK 在 App 启动时自动读取并初始化。
```kotlin
// XuqmInitializerProvider 自动触发,无需代码
```
### 方式 B — 手动初始化
```kotlin
// Application.onCreate() 中:
XuqmSDK.initialize(context, appKey = "xxx")
XuqmSDK.initialize(context, appKey = "xxx", platformUrl = "https://xxx")
```
## API
### XuqmSDK全局单例
| API | 说明 |
|-----|------|
| `XuqmSDK.initialize(context, appKey, platformUrl?, logLevel?)` | 手动初始化 |
| `XuqmSDK.awaitInitialization()` | 等待平台配置拉取coroutine |
| `XuqmSDK.isInitialized()` | 检查是否已初始化 |
| `XuqmSDK.setUserInfo(info)` | 设置用户信息,触发所有子模块登录 |
| `XuqmSDK.setUserInfo(null)` | 登出,触发全局登出 |
| `XuqmSDK.getUserId()` | 获取当前 userId |
| `XuqmSDK.getUserInfo()` | 获取当前用户信息 |
| `XuqmSDK.appKey` | 当前 appKey |
| `XuqmSDK.platformConfig` | 平台配置init 后可用) |
| `XuqmSDK.bugCollectApiUrl` | Bug 收集服务地址(从平台配置获取) |
| `XuqmSDK.bugCollectEnabled` | 是否启用 Bug 收集上报 |
| `XuqmSDK.useLocalServiceEndpoints(ip)` | 切换本地联调环境 |
| `XuqmSDK.tokenStore` | Token 存储EncryptedSharedPreferences |
### XuqmUserInfo
```kotlin
data class XuqmUserInfo(
val userId: String, // 必填
val userSig: String? = null, // IM 登录凭证(可选)
val name: String? = null,
val phone: String? = null,
val avatar: String? = null,
)
```
### TokenStore
基于 `EncryptedSharedPreferences` 持久化存储。
```kotlin
XuqmSDK.tokenStore.saveToken("eyJ...")
val token = XuqmSDK.tokenStore.getToken()
XuqmSDK.tokenStore.clear()
```
### ApiClient
基于 OkHttp 5 + Retrofit 3,自动附加 Bearer Token。
```kotlin
val service = RetrofitFactory.create(MyApiService::class.java)
```
### FileSDK
文件上传、下载、打开的统一入口(`com.xuqm.sdk.file`)。
```kotlin
// 上传
val result = FileSDK.upload(context, uri, onProgress = { /* 0-100 */ })
val result = FileSDK.uploadBytes(fileName, mimeType, bytes, onProgress)
// 下载
val file = FileSDK.download(context, url, fileName, destination, notificationTitle, onProgress)
// 打开
FileSDK.openFile(context, file)
```