summaryrefslogtreecommitdiff
path: root/org.ifaa.android.manager/src
diff options
context:
space:
mode:
Diffstat (limited to 'org.ifaa.android.manager/src')
-rw-r--r--org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManager.java58
-rw-r--r--org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerFactory.java9
-rw-r--r--org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerImpl.java155
-rw-r--r--org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV2.java7
-rw-r--r--org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV3.java12
-rw-r--r--org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAService.java67
6 files changed, 67 insertions, 241 deletions
diff --git a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManager.java b/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManager.java
deleted file mode 100644
index d7ffc5a..0000000
--- a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManager.java
+++ /dev/null
@@ -1,58 +0,0 @@
-package org.ifaa.android.manager;
-
-import android.content.Context;
-import android.os.Build.VERSION;
-import android.os.SystemProperties;
-
-public abstract class IFAAManager {
- private static final int IFAA_VERSION_V2 = 2;
- private static final int IFAA_VERSION_V3 = 3;
- static int sIfaaVer;
- static boolean sIsFod = SystemProperties.getBoolean("ro.hardware.fp.fod", false);
-
- /**
- * 返回手机系统上支持的校验方式,目前IFAF协议1.0版本指纹为0x01、虹膜为0x02
- */
- public abstract int getSupportBIOTypes(Context context);
-
- /**
- * 启动系统的指纹/虹膜管理应用界面,让用户进行指纹录入。指纹录入是在系统的指纹管理应用中实现的,
- * 本函数的作用只是将指纹管理应用运行起来,直接进行页面跳转,方便用户录入。
- * @param context
- * @param authType 生物特征识别类型,指纹为1,虹膜为2
- * @return 0,成功启动指纹管理应用;-1,启动指纹管理应用失败。
- */
- public abstract int startBIOManager(Context context, int authType);
-
- /**
- * 通过ifaateeclient的so文件实现REE到TA的通道
- * @param context
- * @param param 用于传输到IFAA TA的数据buffer
- * @return IFAA TA返回给REE数据buffer
- */
- public native byte[] processCmd(Context context, byte[] param);
-
- /**
- * 获取设备型号,同一款机型型号需要保持一致
- */
- public abstract String getDeviceModel();
-
- /**
- * 获取IFAAManager接口定义版本,目前为1
- */
- public abstract int getVersion();
-
- /**
- * load so to communicate from REE to TEE
- */
- static {
- sIfaaVer = 1;
- if (sIsFod) {
- sIfaaVer = 3;
- } else if (VERSION.SDK_INT >= 24) {
- sIfaaVer = 2;
- } else {
- System.loadLibrary("teeclientjni");//teeclientjni for TA test binary //ifaateeclient
- }
- }
-}
diff --git a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerFactory.java b/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerFactory.java
deleted file mode 100644
index 0862444..0000000
--- a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerFactory.java
+++ /dev/null
@@ -1,9 +0,0 @@
-package org.ifaa.android.manager;
-
-import android.content.Context;
-
-public class IFAAManagerFactory {
- public static IFAAManager getIFAAManager(Context context, int authType) {
- return IFAAManagerImpl.getInstance();
- }
-}
diff --git a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerImpl.java b/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerImpl.java
deleted file mode 100644
index a3d31bd..0000000
--- a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerImpl.java
+++ /dev/null
@@ -1,155 +0,0 @@
-package org.ifaa.android.manager;
-
-import android.content.Context;
-import android.content.Intent;
-import android.net.wifi.WifiEnterpriseConfig;
-import android.os.Build;
-import android.os.Build.VERSION;
-import android.os.HwBinder;
-import android.os.HwBlob;
-import android.os.HwParcel;
-import android.os.IHwBinder;
-import android.os.RemoteException;
-import android.os.SystemProperties;
-import android.util.Slog;
-import java.util.ArrayList;
-import java.util.Arrays;
-import org.json.JSONObject;
-
-public class IFAAManagerImpl extends IFAAManagerV3 {
- private static final String TAG = "IfaaManagerImpl";
-
- private static volatile IFAAManagerImpl INSTANCE = null;
-
- private static final int IFAA_TYPE_FINGER = 0x01;
- private static final int IFAA_TYPE_IRIS = 0x02;
- private static final int IFAA_TYPE_SENSOR_FOD = 0x10;
-
- private static final int ACTIVITY_START_SUCCESS = 0;
- private static final int ACTIVITY_START_FAILED = -1;
-
- private static final int CODE_PROCESS_CMD = 1;
- private static final String INTERFACE_DESCRIPTOR = "vendor.xiaomi.hardware.mlipay@1.0::IMlipayService";
- private static final String SERVICE_NAME = "vendor.xiaomi.hardware.mlipay@1.0::IMlipayService";
-
- private static final String seperate = ",";
- private String mDevModel = null;
- private IHwBinder mService;
-
- public static IFAAManagerV3 getInstance() {
- if (INSTANCE == null) {
- synchronized (IFAAManagerImpl.class) {
- if (INSTANCE == null) {
- INSTANCE = new IFAAManagerImpl();
- }
- }
- }
- return INSTANCE;
- }
-
- private String initExtString() {
- String str = "";
- JSONObject location = new JSONObject();
- JSONObject fullView = new JSONObject();
- String str2 = SystemProperties.get("persist.sys.fp.fod.location.X_Y", "");
- String str3 = SystemProperties.get("persist.sys.fp.fod.size.width_height", "");
- try {
- if (validateVal(str2) && validateVal(str3)) {
- String[] split = str2.split(seperate);
- String[] split2 = str3.split(seperate);
- fullView.put("startX", Integer.parseInt(split[0]));
- fullView.put("startY", Integer.parseInt(split[1]));
- fullView.put("width", Integer.parseInt(split2[0]));
- fullView.put("height", Integer.parseInt(split2[1]));
- fullView.put("navConflict", true);
- location.put("type", 0);
- location.put("fullView", fullView);
- return location.toString();
- }
- Slog.e(TAG, "initExtString invalidate, xy:" + str2 + " wh:" + str3);
- return str;
- } catch (Exception e) {
- Slog.e(TAG, "Exception , xy:" + str2 + " wh:" + str3, e);
- return str;
- }
- }
-
- private boolean validateVal(String str) {
- return !"".equalsIgnoreCase(str) && str.contains(",");
- }
-
- public String getDeviceModel() {
- mDevModel = "xiaomi" + "-" + "wayne";
- Slog.i(TAG, "getDeviceModel deviceModel:" + mDevModel);
- return mDevModel;
- }
-
- public String getExtInfo(int authType, String keyExtInfo) {
- Slog.i(TAG, "getExtInfo:" + authType + WifiEnterpriseConfig.CA_CERT_ALIAS_DELIMITER + keyExtInfo);
- return initExtString();
- }
-
- public int getSupportBIOTypes(Context context) {
- int ifaaType = SystemProperties.getInt("persist.sys.ifaa", 0);
- String fpVendor = SystemProperties.get("persist.sys.fp.vendor", "");
- int supportBIOTypes = "none".equalsIgnoreCase(fpVendor) ? ifaaType & IFAA_TYPE_IRIS :
- ifaaType & (IFAA_TYPE_FINGER | IFAA_TYPE_IRIS);
- if ((supportBIOTypes & IFAA_TYPE_FINGER) == IFAA_TYPE_FINGER && sIsFod) {
- supportBIOTypes |= IFAA_TYPE_SENSOR_FOD;
- }
- return supportBIOTypes;
- }
-
- public int getVersion() {
- Slog.i(TAG, "getVersion sdk:" + VERSION.SDK_INT + " ifaaVer:" + sIfaaVer);
- return sIfaaVer;
- }
-
- public byte[] processCmdV2(Context context, byte[] data) {
- Slog.i(TAG, "processCmdV2 sdk:" + VERSION.SDK_INT);
- HwParcel hwParcel = new HwParcel();
- try {
- if (mService == null) {
- mService = HwBinder.getService(SERVICE_NAME, "default");
- }
- if (mService != null) {
- HwParcel hwParcel2 = new HwParcel();
- hwParcel2.writeInterfaceToken(INTERFACE_DESCRIPTOR);
- ArrayList arrayList = new ArrayList(Arrays.asList(HwBlob.wrapArray(data)));
- hwParcel2.writeInt8Vector(arrayList);
- hwParcel2.writeInt32(arrayList.size());
- mService.transact(CODE_PROCESS_CMD, hwParcel2, hwParcel, 0);
- hwParcel.verifySuccess();
- hwParcel2.releaseTemporaryStorage();
- ArrayList readInt8Vector = hwParcel.readInt8Vector();
- int size = readInt8Vector.size();
- byte[] result = new byte[size];
- for (int i = 0; i < size; i++) {
- result[i] = ((Byte) readInt8Vector.get(i)).byteValue();
- }
- return result;
- }
- } catch (RemoteException e) {
- Slog.e(TAG, "transact failed. " + e);
- } finally {
- hwParcel.release();
- }
- Slog.e(TAG, "processCmdV2, return null");
- return null;
- }
-
- public void setExtInfo(int authType, String keyExtInfo, String valExtInfo) {
- }
-
- public int startBIOManager(Context context, int authType) {
- int res = ACTIVITY_START_FAILED;
- if (authType == IFAA_TYPE_FINGER) {
- Intent intent = new Intent("android.settings.SECURITY_SETTINGS");
- intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
- context.startActivity(intent);
- res = ACTIVITY_START_SUCCESS;
- }
- Slog.i(TAG, "startBIOManager authType:" + authType + " res:" + res);
- return res;
- }
-}
diff --git a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV2.java b/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV2.java
deleted file mode 100644
index 2d7e3f5..0000000
--- a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV2.java
+++ /dev/null
@@ -1,7 +0,0 @@
-package org.ifaa.android.manager;
-
-import android.content.Context;
-
-public abstract class IFAAManagerV2 extends IFAAManager {
- public abstract byte[] processCmdV2(Context paramContext, byte[] paramArrayOfByte);
-}
diff --git a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV3.java b/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV3.java
deleted file mode 100644
index 50e677d..0000000
--- a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAManagerV3.java
+++ /dev/null
@@ -1,12 +0,0 @@
-package org.ifaa.android.manager;
-
-public abstract class IFAAManagerV3 extends IFAAManagerV2 {
- public static final String KEY_FINGERPRINT_FULLVIEW = "org.ifaa.ext.key.CUSTOM_VIEW";
- public static final String KEY_GET_SENSOR_LOCATION = "org.ifaa.ext.key.GET_SENSOR_LOCATION";
- public static final String VALUE_FINGERPRINT_DISABLE = "disable";
- public static final String VLAUE_FINGERPRINT_ENABLE = "enable";
-
- public abstract String getExtInfo(int authType, String keyExtInfo);
-
- public abstract void setExtInfo(int authType, String keyExtInfo, String valExtInfo);
-}
diff --git a/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAService.java b/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAService.java
new file mode 100644
index 0000000..14299d3
--- /dev/null
+++ b/org.ifaa.android.manager/src/org/ifaa/android/manager/IFAAService.java
@@ -0,0 +1,67 @@
+package org.ifaa.android.manager;
+
+import android.app.Service;
+import android.content.Intent;
+import android.os.HwBinder;
+import android.os.HwBlob;
+import android.os.HwParcel;
+import android.os.IBinder;
+import android.os.IHwBinder;
+import android.os.RemoteException;
+import android.util.Slog;
+import java.util.ArrayList;
+import java.util.Arrays;
+
+public class IFAAService extends Service {
+ private static final boolean DEBUG = false;
+ private static final String TAG = "IFAAService";
+
+ private final IBinder mIFAABinder = new IIFAAService.Stub() {
+ private static final String INTERFACE_DESCRIPTOR =
+ "vendor.xiaomi.hardware.mlipay@1.0::IMlipayService";
+ private static final String SERVICE_NAME =
+ "vendor.xiaomi.hardware.mlipay@1.0::IMlipayService";
+
+ private static final int CODE_PROCESS_CMD = 1;
+
+ private IHwBinder mService;
+
+ @Override
+ public byte[] processCmd_v2(byte[] param) {
+ HwParcel reply = new HwParcel();
+ try {
+ if (mService == null) {
+ mService = HwBinder.getService(SERVICE_NAME, "default");
+ }
+ if (mService != null) {
+ HwParcel data = new HwParcel();
+ data.writeInterfaceToken(INTERFACE_DESCRIPTOR);
+ ArrayList arrayList = new ArrayList(Arrays.asList(HwBlob.wrapArray(param)));
+ data.writeInt8Vector(arrayList);
+ data.writeInt32(arrayList.size());
+ mService.transact(CODE_PROCESS_CMD, data, reply, 0);
+ reply.verifySuccess();
+ data.releaseTemporaryStorage();
+ ArrayList readInt8Vector = reply.readInt8Vector();
+ int size = readInt8Vector.size();
+ byte[] result = new byte[size];
+ for (int i = 0; i < size; i++) {
+ result[i] = ((Byte) readInt8Vector.get(i)).byteValue();
+ }
+ return result;
+ }
+ } catch (RemoteException e) {
+ if (DEBUG) Slog.e(TAG, "transact failed. " + e);
+ } finally {
+ reply.release();
+ }
+ if (DEBUG) Slog.e(TAG, "processCmdV2, return null");
+ return null;
+ }
+ };
+
+ @Override
+ public IBinder onBind(Intent intent) {
+ return mIFAABinder;
+ }
+}