1package com.netease.nimlib.sdk;
3import android.app.Application;
4import android.content.Context;
5import android.util.Log;
7import com.netease.nimlib.BuildConfig;
8import com.netease.nimlib.SDKCache;
9import com.netease.nimlib.SDKCacheUI;
10import com.netease.nimlib.SDKState;
11import com.netease.nimlib.SDKStateUI;
12import com.netease.nimlib.invocation.sync.base.APISyncHelper;
13import com.netease.nimlib.sdk.auth.LoginInfo;
14import com.netease.nimlib.sdk.msg.model.CaptureDeviceInfoConfig;
15import com.netease.nimlib.sdk.util.NIMUtil;
16import com.netease.nimlib.sdk.util.api.RequestResult;
17import com.netease.nimlib.util.storage.NimStorageUtil;
24 public static final String
TAG =
"NIMClient";
58 Log.i(
TAG,
"NIMClient init");
59 SDKCache.config(context, info, options);
99 Log.i(
TAG,
"NIMClient config");
100 SDKCache.config(context, info, options);
104 SDKState.setProcessTag(2);
121 Log.i(
TAG,
"NIMClient initSDK");
154 Log.i(
TAG,
"NIMClient initDelay");
158 SDKCache.config(context, info, options,
true,
true);
164 Log.i(
TAG,
"NIMClient initDelay");
165 SDKCache.config(context,
null, options,
false,
true,
true);
194 return SDKCacheUI.getService(clazz);
232 return APISyncHelper.syncRequest(future, time);
257 return APISyncHelper.syncRequest(future, 30 * 1000L);
266 String account = SDKCacheUI.getAccount();
280 String appKey = SDKCache.getAppKey();
286 }
catch (Exception e) {
297 return SDKStateUI.getStatus();
308 return SDKStateUI.getMode();
320 SDKCacheUI.toggleNotification(on);
333 SDKCacheUI.toggleRevokeMessageNotification(on);
345 SDKCacheUI.updateStatusBarNotificationConfig(
config);
358 SDKCacheUI.updateStrings(strings);
369 return NimStorageUtil.getRootPath();
378 return BuildConfig.VERSION_NAME;
399 SDKCacheUI.updateTokenSceneConfig(
config);
410 SDKCacheUI.updateCaptureDeviceInfoOption(captureDeviceInfoConfig);
SDK 核心接口类,用于初始化 SDK,获取各个服务能力接口,获取当前状态等功能。
static void initSDK()
[初始化 SDK 方式二] 在 UI 进程主线程上按需初始化 SDK(不放在 Application#onCreate() 中初始化)。与 NIMClient#config(Context,...
static String getCurrentAccount()
获取当前用户的 IM 账号(accid)。
static< T > RequestResult< T > syncRequest(InvocationFuture< T > future, long time)
在非 UI 线程中调用云信 SDK 异步 API,强制将异步调用转换为同步调用。
static void initDelay(Context context, LoginInfo info, SDKOptions options)
[初始化 SDK 方式三] 在 UI 进程主线程上按需初始化 SDK(不一定放在 Application#onCreate() 中初始化)。
static void updateCaptureDeviceInfoOption(CaptureDeviceInfoConfig captureDeviceInfoConfig)
更新获取设备信息的相关配置。包括配置是否获取产品型号、是否获取制造商信息、是否获取品牌信息,null 表示都可以获取,没有限制。
static void updateTokenSceneConfig(NosTokenSceneConfig config)
更新 SDK NOS Token 场景配置。对于 SDK NOS Token,云信 SDK 有默认值 ,若用户不单独配置,则直接采用默认值。
static void init(Context context, LoginInfo info, SDKOptions options)
[初始化 SDK 方式一] 在 Application#onCreate() 中调用该方法在应用启动时初始化 SDK。
static void updateStatusBarNotificationConfig(StatusBarNotificationConfig config)
更新通知栏消息提醒配置,包括是否需要振动提醒、是否需要响铃提醒等。
static void updateStrings(NimStrings strings)
更新系统文案。
static void config(Context context, LoginInfo info, SDKOptions options)
[初始化 SDK 方式二] 在 Application#onCreate() 中配置 SDK(仅仅是配置,不影响性能),具体可配置的参数同 NIMClient#init(Context,...
static< T > RequestResult< T > syncRequest(InvocationFuture< T > future)
在非 UI 线程调用云信 SDK 异步 API,强制将异步调用转换为同步调用。该接口已废弃,请使用 NIMClient#syncRequest(InvocationFuture,...
static void toggleRevokeMessageNotification(boolean on)
撤回消息需要通知栏提醒的开关。
static StatusCode getStatus()
获取当前用户的状态。
static String getSdkStorageDirPath()
获取 SDK 数据缓存目录路径。
static ModeCode getMode()
获取 SDK 当前的登录模式。
static< T > T getService(Class< T > clazz)
获取云信各服务接口。
static void initV2(Context context, SDKOptions options)
static void toggleNotification(boolean on)
通知栏消息提醒开关。
static String getSDKVersion()
运行时获取当前 SDK 版本号。
static String getAppKey()
获取当前应用的 AppKey。
SDK中用到的字符串定义。可用于开发者定制显示文案,以及实现SDK对多语言的支持。 目前仅新消息状态栏提醒处使用。如果应用程序没有提供,只用默认值。
SDK nos token场景配置,不配置的话,走默认值,默认值只有以下3种场景:
static int isMainProcessPure(Context context)
判断当前进程是否是主进程(纯净版本),不会有隐私不合规风险,但是不保证100判断正确
static boolean isMainProcess(Context context)