正在查看: aeroLINE CREW v5.0.1 应用的 RNFetchBlobFS.java JAVA 源代码文件
本页面展示 JAVA 反编译生成的源代码文件,支持语法高亮显示。 仅供安全研究与技术分析使用,严禁用于任何非法用途。请遵守相关法律法规。
正在查看: aeroLINE CREW v5.0.1 应用的 RNFetchBlobFS.java JAVA 源代码文件
本页面展示 JAVA 反编译生成的源代码文件,支持语法高亮显示。 仅供安全研究与技术分析使用,严禁用于任何非法用途。请遵守相关法律法规。
package com.RNFetchBlob;
import android.content.res.AssetFileDescriptor;
import android.media.MediaScannerConnection;
import android.net.Uri;
import android.os.AsyncTask;
import android.os.Build;
import android.os.Environment;
import android.os.StatFs;
import android.util.Base64;
import androidx.core.app.NotificationCompat;
import androidx.work.Data;
import com.RNFetchBlob.Utils.PathResolver;
import com.bumptech.glide.load.Key;
import com.facebook.common.util.UriUtil;
import com.facebook.react.bridge.Arguments;
import com.facebook.react.bridge.Callback;
import com.facebook.react.bridge.Promise;
import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.bridge.ReadableArray;
import com.facebook.react.bridge.WritableArray;
import com.facebook.react.bridge.WritableMap;
import com.facebook.react.modules.core.DeviceEventManagerModule;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.nio.charset.Charset;
import java.security.MessageDigest;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.UUID;
class RNFetchBlobFS {
private static HashMap<String, RNFetchBlobFS> fileStreams = new HashMap<>();
private DeviceEventManagerModule.RCTDeviceEventEmitter emitter;
private ReactApplicationContext mCtx;
private String encoding = RNFetchBlobConst.RNFB_RESPONSE_BASE64;
private OutputStream writeStreamInstance = null;
RNFetchBlobFS(ReactApplicationContext reactApplicationContext) {
this.mCtx = reactApplicationContext;
this.emitter = (DeviceEventManagerModule.RCTDeviceEventEmitter) reactApplicationContext.getJSModule(DeviceEventManagerModule.RCTDeviceEventEmitter.class);
}
static void writeFile(String str, String str2, String str3, boolean z, Promise promise) {
int length;
FileOutputStream fileOutputStream;
try {
File file = new File(str);
File parentFile = file.getParentFile();
if (!file.exists()) {
if (parentFile != null && !parentFile.exists() && !parentFile.mkdirs()) {
promise.reject("EUNSPECIFIED", "Failed to create parent directory of '" + str + "'");
return;
}
if (!file.createNewFile()) {
promise.reject("ENOENT", "File '" + str + "' does not exist and could not be created");
return;
}
}
if (str2.equalsIgnoreCase(RNFetchBlobConst.DATA_ENCODE_URI)) {
String normalizePath = normalizePath(str3);
File file2 = new File(normalizePath);
if (!file2.exists()) {
promise.reject("ENOENT", "No such file '" + str + "' ('" + normalizePath + "')");
return;
}
byte[] bArr = new byte[Data.MAX_DATA_BYTES];
FileInputStream fileInputStream = null;
try {
FileInputStream fileInputStream2 = new FileInputStream(file2);
try {
fileOutputStream = new FileOutputStream(file, z);
length = 0;
while (true) {
try {
int read = fileInputStream2.read(bArr);
if (read <= 0) {
break;
}
fileOutputStream.write(bArr, 0, read);
length += read;
} catch (Throwable th) {
th = th;
fileInputStream = fileInputStream2;
if (fileInputStream != null) {
fileInputStream.close();
}
if (fileOutputStream != null) {
fileOutputStream.close();
}
throw th;
}
}
fileInputStream2.close();
fileOutputStream.close();
} catch (Throwable th2) {
th = th2;
fileOutputStream = null;
}
} catch (Throwable th3) {
th = th3;
fileOutputStream = null;
}
} else {
byte[] stringToBytes = stringToBytes(str3, str2);
FileOutputStream fileOutputStream2 = new FileOutputStream(file, z);
try {
fileOutputStream2.write(stringToBytes);
length = stringToBytes.length;
} finally {
fileOutputStream2.close();
}
}
promise.resolve(Integer.valueOf(length));
} catch (FileNotFoundException unused) {
promise.reject("ENOENT", "File '" + str + "' does not exist and could not be created, or it is a directory");
} catch (Exception e) {
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void writeFile(String str, ReadableArray readableArray, boolean z, Promise promise) {
try {
File file = new File(str);
File parentFile = file.getParentFile();
if (!file.exists()) {
if (parentFile != null && !parentFile.exists() && !parentFile.mkdirs()) {
promise.reject("ENOTDIR", "Failed to create parent directory of '" + str + "'");
return;
}
if (!file.createNewFile()) {
promise.reject("ENOENT", "File '" + str + "' does not exist and could not be created");
return;
}
}
FileOutputStream fileOutputStream = new FileOutputStream(file, z);
try {
byte[] bArr = new byte[readableArray.size()];
for (int i = 0; i < readableArray.size(); i++) {
bArr[i] = (byte) readableArray.getInt(i);
}
fileOutputStream.write(bArr);
fileOutputStream.close();
promise.resolve(Integer.valueOf(readableArray.size()));
} catch (Throwable th) {
fileOutputStream.close();
throw th;
}
} catch (FileNotFoundException unused) {
promise.reject("ENOENT", "File '" + str + "' does not exist and could not be created");
} catch (Exception e) {
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void readFile(java.lang.String r8, java.lang.String r9, com.facebook.react.bridge.Promise r10) {
throw new UnsupportedOperationException("Method not decompiled: com.RNFetchBlob.RNFetchBlobFS.readFile(java.lang.String, java.lang.String, com.facebook.react.bridge.Promise):void");
}
static Map<String, Object> getSystemfolders(ReactApplicationContext reactApplicationContext) {
HashMap hashMap = new HashMap();
hashMap.put("DocumentDir", reactApplicationContext.getFilesDir().getAbsolutePath());
hashMap.put("CacheDir", reactApplicationContext.getCacheDir().getAbsolutePath());
hashMap.put("DCIMDir", Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DCIM).getAbsolutePath());
hashMap.put("PictureDir", Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES).getAbsolutePath());
hashMap.put("MusicDir", Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_MUSIC).getAbsolutePath());
hashMap.put("DownloadDir", Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DOWNLOADS).getAbsolutePath());
hashMap.put("MovieDir", Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_MOVIES).getAbsolutePath());
hashMap.put("RingtoneDir", Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_RINGTONES).getAbsolutePath());
if (Environment.getExternalStorageState().equals("mounted")) {
hashMap.put("SDCardDir", Environment.getExternalStorageDirectory().getAbsolutePath());
File externalFilesDir = reactApplicationContext.getExternalFilesDir(null);
if (externalFilesDir != null) {
hashMap.put("SDCardApplicationDir", externalFilesDir.getParentFile().getAbsolutePath());
} else {
hashMap.put("SDCardApplicationDir", "");
}
}
hashMap.put("MainBundleDir", reactApplicationContext.getApplicationInfo().dataDir);
return hashMap;
}
public static void getSDCardDir(Promise promise) {
if (Environment.getExternalStorageState().equals("mounted")) {
promise.resolve(Environment.getExternalStorageDirectory().getAbsolutePath());
} else {
promise.reject("RNFetchBlob.getSDCardDir", "External storage not mounted");
}
}
public static void getSDCardApplicationDir(ReactApplicationContext reactApplicationContext, Promise promise) {
if (Environment.getExternalStorageState().equals("mounted")) {
try {
promise.resolve(reactApplicationContext.getExternalFilesDir(null).getParentFile().getAbsolutePath());
return;
} catch (Exception e) {
promise.reject("RNFetchBlob.getSDCardApplicationDir", e.getLocalizedMessage());
return;
}
}
promise.reject("RNFetchBlob.getSDCardApplicationDir", "External storage not mounted");
}
static String getTmpPath(String str) {
return RNFetchBlob.RCTContext.getFilesDir() + "/RNFetchBlobTmp_" + str;
}
void readStream(java.lang.String r17, java.lang.String r18, int r19, int r20, java.lang.String r21) {
throw new UnsupportedOperationException("Method not decompiled: com.RNFetchBlob.RNFetchBlobFS.readStream(java.lang.String, java.lang.String, int, int, java.lang.String):void");
}
void writeStream(String str, String str2, boolean z, Callback callback) {
try {
File file = new File(str);
File parentFile = file.getParentFile();
if (!file.exists()) {
if (parentFile != null && !parentFile.exists() && !parentFile.mkdirs()) {
callback.invoke("ENOTDIR", "Failed to create parent directory of '" + str + "'");
return;
}
if (!file.createNewFile()) {
callback.invoke("ENOENT", "File '" + str + "' does not exist and could not be created");
return;
}
} else if (file.isDirectory()) {
callback.invoke("EISDIR", "Expecting a file but '" + str + "' is a directory");
return;
}
FileOutputStream fileOutputStream = new FileOutputStream(str, z);
this.encoding = str2;
String uuid = UUID.randomUUID().toString();
fileStreams.put(uuid, this);
this.writeStreamInstance = fileOutputStream;
callback.invoke(null, null, uuid);
} catch (Exception e) {
callback.invoke("EUNSPECIFIED", "Failed to create write stream at path `" + str + "`; " + e.getLocalizedMessage());
}
}
static void writeChunk(String str, String str2, Callback callback) {
RNFetchBlobFS rNFetchBlobFS = fileStreams.get(str);
try {
rNFetchBlobFS.writeStreamInstance.write(stringToBytes(str2, rNFetchBlobFS.encoding));
callback.invoke(new Object[0]);
} catch (Exception e) {
callback.invoke(e.getLocalizedMessage());
}
}
static void writeArrayChunk(String str, ReadableArray readableArray, Callback callback) {
try {
OutputStream outputStream = fileStreams.get(str).writeStreamInstance;
byte[] bArr = new byte[readableArray.size()];
for (int i = 0; i < readableArray.size(); i++) {
bArr[i] = (byte) readableArray.getInt(i);
}
outputStream.write(bArr);
callback.invoke(new Object[0]);
} catch (Exception e) {
callback.invoke(e.getLocalizedMessage());
}
}
static void closeStream(String str, Callback callback) {
try {
OutputStream outputStream = fileStreams.get(str).writeStreamInstance;
fileStreams.remove(str);
outputStream.close();
callback.invoke(new Object[0]);
} catch (Exception e) {
callback.invoke(e.getLocalizedMessage());
}
}
static void unlink(String str, Callback callback) {
try {
deleteRecursive(new File(normalizePath(str)));
callback.invoke(null, true);
} catch (Exception e) {
callback.invoke(e.getLocalizedMessage(), false);
}
}
private static void deleteRecursive(File file) throws IOException {
if (file.isDirectory()) {
File[] listFiles = file.listFiles();
if (listFiles == null) {
throw new NullPointerException("Received null trying to list files of directory '" + file + "'");
}
for (File file2 : listFiles) {
deleteRecursive(file2);
}
}
if (file.delete()) {
return;
}
throw new IOException("Failed to delete '" + file + "'");
}
static void mkdir(String str, Promise promise) {
File file = new File(str);
if (file.exists()) {
StringBuilder sb = new StringBuilder();
sb.append(file.isDirectory() ? "Folder" : "File");
sb.append(" '");
sb.append(str);
sb.append("' already exists");
promise.reject("EEXIST", sb.toString());
return;
}
try {
if (!file.mkdirs()) {
promise.reject("EUNSPECIFIED", "mkdir failed to create some or all directories in '" + str + "'");
return;
}
promise.resolve(true);
} catch (Exception e) {
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void cp(java.lang.String r6, java.lang.String r7, com.facebook.react.bridge.Callback r8) {
throw new UnsupportedOperationException("Method not decompiled: com.RNFetchBlob.RNFetchBlobFS.cp(java.lang.String, java.lang.String, com.facebook.react.bridge.Callback):void");
}
static void mv(String str, String str2, Callback callback) {
File file = new File(str);
if (!file.exists()) {
callback.invoke("Source file at path `" + str + "` does not exist");
return;
}
try {
FileInputStream fileInputStream = new FileInputStream(str);
FileOutputStream fileOutputStream = new FileOutputStream(str2);
byte[] bArr = new byte[1024];
while (true) {
int read = fileInputStream.read(bArr);
if (read != -1) {
fileOutputStream.write(bArr, 0, read);
} else {
fileInputStream.close();
fileOutputStream.flush();
file.delete();
callback.invoke(new Object[0]);
return;
}
}
} catch (FileNotFoundException unused) {
callback.invoke("Source file not found.");
} catch (Exception e) {
callback.invoke(e.toString());
}
}
static void exists(String str, Callback callback) {
if (isAsset(str)) {
try {
RNFetchBlob.RCTContext.getAssets().openFd(str.replace(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET, ""));
callback.invoke(true, false);
return;
} catch (IOException unused) {
callback.invoke(false, false);
return;
}
}
String normalizePath = normalizePath(str);
if (normalizePath != null) {
callback.invoke(Boolean.valueOf(new File(normalizePath).exists()), Boolean.valueOf(new File(normalizePath).isDirectory()));
} else {
callback.invoke(false, false);
}
}
static void ls(String str, Promise promise) {
try {
String normalizePath = normalizePath(str);
File file = new File(normalizePath);
if (!file.exists()) {
promise.reject("ENOENT", "No such file '" + normalizePath + "'");
return;
}
if (!file.isDirectory()) {
promise.reject("ENOTDIR", "Not a directory '" + normalizePath + "'");
return;
}
String[] list = new File(normalizePath).list();
WritableArray createArray = Arguments.createArray();
for (String str2 : list) {
createArray.pushString(str2);
}
promise.resolve(createArray);
} catch (Exception e) {
e.printStackTrace();
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void slice(String str, String str2, int i, int i2, String str3, Promise promise) {
try {
String normalizePath = normalizePath(str);
File file = new File(normalizePath);
if (file.isDirectory()) {
promise.reject("EISDIR", "Expecting a file but '" + normalizePath + "' is a directory");
return;
}
if (!file.exists()) {
promise.reject("ENOENT", "No such file '" + normalizePath + "'");
return;
}
int length = (int) file.length();
int min = Math.min(length, i2) - i;
FileInputStream fileInputStream = new FileInputStream(new File(normalizePath));
FileOutputStream fileOutputStream = new FileOutputStream(new File(str2));
int skip = (int) fileInputStream.skip(i);
if (skip != i) {
promise.reject("EUNSPECIFIED", "Skipped " + skip + " instead of the specified " + i + " bytes, size is " + length);
return;
}
byte[] bArr = new byte[Data.MAX_DATA_BYTES];
int i3 = 0;
while (i3 < min) {
int read = fileInputStream.read(bArr, 0, Data.MAX_DATA_BYTES);
int i4 = min - i3;
if (read <= 0) {
break;
}
fileOutputStream.write(bArr, 0, Math.min(i4, read));
i3 += read;
}
fileInputStream.close();
fileOutputStream.flush();
fileOutputStream.close();
promise.resolve(str2);
} catch (Exception e) {
e.printStackTrace();
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void lstat(String str, final Callback callback) {
new AsyncTask<String, Integer, Integer>() {
@Override
public Integer doInBackground(String... strArr) {
WritableArray createArray = Arguments.createArray();
if (strArr[0] == null) {
Callback.this.invoke("the path specified for lstat is either `null` or `undefined`.");
return 0;
}
File file = new File(strArr[0]);
if (!file.exists()) {
Callback.this.invoke("failed to lstat path `" + strArr[0] + "` because it does not exist or it is not a folder");
return 0;
}
if (file.isDirectory()) {
for (String str2 : file.list()) {
createArray.pushMap(RNFetchBlobFS.statFile(file.getPath() + "/" + str2));
}
} else {
createArray.pushMap(RNFetchBlobFS.statFile(file.getAbsolutePath()));
}
Callback.this.invoke(null, createArray);
return 0;
}
}.execute(normalizePath(str));
}
static void stat(String str, Callback callback) {
try {
String normalizePath = normalizePath(str);
WritableMap statFile = statFile(normalizePath);
if (statFile == null) {
callback.invoke("failed to stat path `" + normalizePath + "` because it does not exist or it is not a folder", null);
} else {
callback.invoke(null, statFile);
}
} catch (Exception e) {
callback.invoke(e.getLocalizedMessage());
}
}
static WritableMap statFile(String str) {
try {
String normalizePath = normalizePath(str);
WritableMap createMap = Arguments.createMap();
if (isAsset(normalizePath)) {
String replace = normalizePath.replace(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET, "");
AssetFileDescriptor openFd = RNFetchBlob.RCTContext.getAssets().openFd(replace);
createMap.putString("filename", replace);
createMap.putString(RNFetchBlobConst.RNFB_RESPONSE_PATH, normalizePath);
createMap.putString("type", UriUtil.LOCAL_ASSET_SCHEME);
createMap.putString("size", String.valueOf(openFd.getLength()));
createMap.putInt("lastModified", 0);
} else {
File file = new File(normalizePath);
if (!file.exists()) {
return null;
}
createMap.putString("filename", file.getName());
createMap.putString(RNFetchBlobConst.RNFB_RESPONSE_PATH, file.getPath());
createMap.putString("type", file.isDirectory() ? "directory" : UriUtil.LOCAL_FILE_SCHEME);
createMap.putString("size", String.valueOf(file.length()));
createMap.putString("lastModified", String.valueOf(file.lastModified()));
}
return createMap;
} catch (Exception unused) {
return null;
}
}
void scanFile(String[] strArr, String[] strArr2, final Callback callback) {
try {
MediaScannerConnection.scanFile(this.mCtx, strArr, strArr2, new MediaScannerConnection.OnScanCompletedListener() {
@Override
public void onScanCompleted(String str, Uri uri) {
callback.invoke(null, true);
}
});
} catch (Exception e) {
callback.invoke(e.getLocalizedMessage(), null);
}
}
static void hash(String str, String str2, Promise promise) {
try {
HashMap hashMap = new HashMap();
hashMap.put("md5", "MD5");
hashMap.put("sha1", "SHA-1");
hashMap.put("sha224", "SHA-224");
hashMap.put("sha256", "SHA-256");
hashMap.put("sha384", "SHA-384");
hashMap.put("sha512", "SHA-512");
if (!hashMap.containsKey(str2)) {
promise.reject("EINVAL", "Invalid algorithm '" + str2 + "', must be one of md5, sha1, sha224, sha256, sha384, sha512");
return;
}
File file = new File(str);
if (file.isDirectory()) {
promise.reject("EISDIR", "Expecting a file but '" + str + "' is a directory");
return;
}
if (!file.exists()) {
promise.reject("ENOENT", "No such file '" + str + "'");
return;
}
MessageDigest messageDigest = MessageDigest.getInstance((String) hashMap.get(str2));
FileInputStream fileInputStream = new FileInputStream(str);
byte[] bArr = new byte[1048576];
if (file.length() != 0) {
while (true) {
int read = fileInputStream.read(bArr);
if (read == -1) {
break;
} else {
messageDigest.update(bArr, 0, read);
}
}
}
StringBuilder sb = new StringBuilder();
for (byte b : messageDigest.digest()) {
sb.append(String.format("%02x", Byte.valueOf(b)));
}
promise.resolve(sb.toString());
} catch (Exception e) {
e.printStackTrace();
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void createFile(String str, String str2, String str3, Promise promise) {
try {
File file = new File(str);
boolean createNewFile = file.createNewFile();
if (str3.equals(RNFetchBlobConst.DATA_ENCODE_URI)) {
File file2 = new File(str2.replace(RNFetchBlobConst.FILE_PREFIX, ""));
if (!file2.exists()) {
promise.reject("ENOENT", "Source file : " + str2 + " does not exist");
return;
}
FileInputStream fileInputStream = new FileInputStream(file2);
FileOutputStream fileOutputStream = new FileOutputStream(file);
byte[] bArr = new byte[Data.MAX_DATA_BYTES];
for (int read = fileInputStream.read(bArr); read > 0; read = fileInputStream.read(bArr)) {
fileOutputStream.write(bArr, 0, read);
}
fileInputStream.close();
fileOutputStream.close();
} else {
if (!createNewFile) {
promise.reject("EEXIST", "File `" + str + "` already exists");
return;
}
new FileOutputStream(file).write(stringToBytes(str2, str3));
}
promise.resolve(str);
} catch (Exception e) {
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void createFileASCII(String str, ReadableArray readableArray, Promise promise) {
try {
File file = new File(str);
if (!file.createNewFile()) {
promise.reject("EEXIST", "File at path `" + str + "` already exists");
return;
}
FileOutputStream fileOutputStream = new FileOutputStream(file);
byte[] bArr = new byte[readableArray.size()];
for (int i = 0; i < readableArray.size(); i++) {
bArr[i] = (byte) readableArray.getInt(i);
}
fileOutputStream.write(bArr);
promise.resolve(str);
} catch (Exception e) {
promise.reject("EUNSPECIFIED", e.getLocalizedMessage());
}
}
static void df(Callback callback) {
StatFs statFs = new StatFs(Environment.getDataDirectory().getPath());
WritableMap createMap = Arguments.createMap();
if (Build.VERSION.SDK_INT >= 18) {
createMap.putString("internal_free", String.valueOf(statFs.getFreeBytes()));
createMap.putString("internal_total", String.valueOf(statFs.getTotalBytes()));
StatFs statFs2 = new StatFs(Environment.getExternalStorageDirectory().getPath());
createMap.putString("external_free", String.valueOf(statFs2.getFreeBytes()));
createMap.putString("external_total", String.valueOf(statFs2.getTotalBytes()));
}
callback.invoke(null, createMap);
}
static void removeSession(ReadableArray readableArray, final Callback callback) {
new AsyncTask<ReadableArray, Integer, Integer>() {
@Override
public Integer doInBackground(ReadableArray... readableArrayArr) {
try {
ArrayList arrayList = new ArrayList();
for (int i = 0; i < readableArrayArr[0].size(); i++) {
String string = readableArrayArr[0].getString(i);
File file = new File(string);
if (file.exists() && !file.delete()) {
arrayList.add(string);
}
}
if (arrayList.isEmpty()) {
Callback.this.invoke(null, true);
} else {
StringBuilder sb = new StringBuilder();
sb.append("Failed to delete: ");
Iterator it = arrayList.iterator();
while (it.hasNext()) {
sb.append((String) it.next());
sb.append(", ");
}
Callback.this.invoke(sb.toString());
}
} catch (Exception e) {
Callback.this.invoke(e.getLocalizedMessage());
}
return Integer.valueOf(readableArrayArr[0].size());
}
}.execute(readableArray);
}
private static byte[] stringToBytes(String str, String str2) {
if (str2.equalsIgnoreCase("ascii")) {
return str.getBytes(Charset.forName("US-ASCII"));
}
if (str2.toLowerCase().contains(RNFetchBlobConst.RNFB_RESPONSE_BASE64)) {
return Base64.decode(str, 2);
}
if (str2.equalsIgnoreCase(RNFetchBlobConst.RNFB_RESPONSE_UTF8)) {
return str.getBytes(Charset.forName(Key.STRING_CHARSET_NAME));
}
return str.getBytes(Charset.forName("US-ASCII"));
}
private void emitStreamEvent(String str, String str2, String str3) {
WritableMap createMap = Arguments.createMap();
createMap.putString(NotificationCompat.CATEGORY_EVENT, str2);
createMap.putString("detail", str3);
this.emitter.emit(str, createMap);
}
private void emitStreamEvent(String str, String str2, WritableArray writableArray) {
WritableMap createMap = Arguments.createMap();
createMap.putString(NotificationCompat.CATEGORY_EVENT, str2);
createMap.putArray("detail", writableArray);
this.emitter.emit(str, createMap);
}
private void emitStreamEvent(String str, String str2, String str3, String str4) {
WritableMap createMap = Arguments.createMap();
createMap.putString(NotificationCompat.CATEGORY_EVENT, str2);
createMap.putString("code", str3);
createMap.putString("detail", str4);
this.emitter.emit(str, createMap);
}
private static InputStream inputStreamFromPath(String str) throws IOException {
if (str.startsWith(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET)) {
return RNFetchBlob.RCTContext.getAssets().open(str.replace(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET, ""));
}
return new FileInputStream(new File(str));
}
private static boolean isPathExists(String str) {
if (str.startsWith(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET)) {
try {
RNFetchBlob.RCTContext.getAssets().open(str.replace(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET, ""));
return true;
} catch (IOException unused) {
return false;
}
}
return new File(str).exists();
}
static boolean isAsset(String str) {
return str != null && str.startsWith(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET);
}
static String normalizePath(String str) {
if (str == null) {
return null;
}
if (!str.matches("\\w+\\:.*")) {
return str;
}
if (str.startsWith("file://")) {
return str.replace("file://", "");
}
return str.startsWith(RNFetchBlobConst.FILE_PREFIX_BUNDLE_ASSET) ? str : PathResolver.getRealPathFromURI(RNFetchBlob.RCTContext, Uri.parse(str));
}
}