Agent 8 文档生成: - CLAUDE.md 项目上下文 - 各 package README (common/update/push/im/xwebview/license/log) - docs/架构总览.md - docs/模块待开发说明.md
106 行
3.2 KiB
Markdown
106 行
3.2 KiB
Markdown
# XuqmGroup RN SDK 架构总览
|
||
|
||
## 整体架构
|
||
|
||
```
|
||
宿主 App(YiwangxinApp4 等)
|
||
└── 初始化(方式A: 配置文件自动 / 方式B: 手动 initialize)
|
||
↓
|
||
@xuqm/rn-common (核心层 v0.4.0)
|
||
├── XuqmSDK.initialize() → 拉取 /api/sdk/config
|
||
├── XuqmSDK.setUserInfo() → 通知所有子 SDK(订阅者模式)
|
||
├── api/(useApi / usePageApi / apiRequest)
|
||
├── device(设备信息 / 厂商检测)
|
||
├── xwebview(JSBridge 桥接控制)
|
||
├── ui/(toast / alert / confirm)
|
||
└── logApiUrl / logEnabled(从平台配置获取)
|
||
↓ peerDep / 依赖
|
||
子 SDK(各自独立)
|
||
├── @xuqm/rn-update → OTA 热更新 / APK 更新
|
||
├── @xuqm/rn-push → 厂商推送(peerDep: rn-common)
|
||
├── @xuqm/rn-im → IM 会话 / 消息(peerDep: rn-common)
|
||
├── @xuqm/rn-xwebview → WebView UI 组件(peerDep: rn-common)
|
||
├── @xuqm/rn-license → 证书授权(peerDep: rn-common)
|
||
└── @xuqm/rn-log → 日志 / 追踪(peerDep: rn-common)
|
||
```
|
||
|
||
## 依赖关系
|
||
|
||
```
|
||
rn-common (核心,无 SDK 内部依赖)
|
||
↑ peerDep
|
||
├── rn-update (直接依赖 rn-common)
|
||
├── rn-push (peerDep rn-common)
|
||
├── rn-im (peerDep rn-common + watermelondb)
|
||
├── rn-xwebview (peerDep rn-common + webview + navigation)
|
||
├── rn-license (peerDep rn-common + quick-crypto)
|
||
└── rn-log (peerDep rn-common)
|
||
```
|
||
|
||
## 用户状态分发机制
|
||
|
||
```
|
||
XuqmSDK.setUserInfo(info)
|
||
├── PushSDK: 检测厂商 → 获取厂商配置 → 注册 token
|
||
├── ImSDK: 若 userSig 存在且 imEnabled → 自动登录 WebSocket
|
||
├── UpdateSDK: 更新 userId(用于定向更新)
|
||
└── LicenseSDK: 更新用户上下文
|
||
|
||
XuqmSDK.setUserInfo(null)
|
||
├── PushSDK: 解绑 token
|
||
├── ImSDK: 断开 WebSocket
|
||
└── 其他子 SDK: 清理用户状态
|
||
```
|
||
|
||
各子 SDK 在模块加载时通过 `_registerUserInfoHandler()` 注册处理器,无需 App 手动协调。
|
||
|
||
## 初始化流程
|
||
|
||
### 方式 A(自动)
|
||
|
||
```
|
||
Metro alias → @xuqm/autoinit-config → encrypted .xuqmconfig
|
||
↓ import 时触发
|
||
autoInit.ts → require('@xuqm/autoinit-config')
|
||
↓ 解密(PBKDF2 + AES-256-GCM)
|
||
initWithConfigFile() → initialize({ appKey, platformUrl })
|
||
↓ HTTP GET
|
||
/api/sdk/config → 返回 { apiUrl, imWsUrl, fileServiceUrl, ... }
|
||
```
|
||
|
||
### 方式 B(手动)
|
||
|
||
```
|
||
App 代码调用 XuqmSDK.initialize({ appKey })
|
||
↓ HTTP GET
|
||
/api/sdk/config → 解析平台配置
|
||
↓
|
||
各子 SDK 就绪(等待 setUserInfo 触发具体功能)
|
||
```
|
||
|
||
## 数据流
|
||
|
||
```
|
||
App 代码
|
||
↓ 调用 API
|
||
子 SDK(update/push/im/license/log)
|
||
↓ 使用 apiRequest()
|
||
rn-common http.ts
|
||
↓ 附加 Bearer Token + 处理响应
|
||
平台服务(tenant-service / im-service / push-service / update-service / log-service)
|
||
```
|
||
|
||
## 包发布
|
||
|
||
所有包发布到 Nexus npm 私有仓库:`https://nexus.xuqinmin.com/repository/npm-hosted/`
|
||
|
||
```bash
|
||
# 发布单个包
|
||
cd packages/common && npm publish
|
||
|
||
# 发布所有包
|
||
for pkg in common update push im xwebview license log; do
|
||
cd packages/$pkg && npm publish && cd ../..
|
||
done
|
||
```
|