mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-01-24 16:47:32 +01:00
Simplify external dir handling again -- prefer the primary dir
The primary external dir is often a user-partition on the internal storage medium. This one is safe in multi-user environments. The "removable storage" (sdcard) on the other hand can be read by everyone. If the former is not available or not writable, use the latter. closes #153
This commit is contained in:
parent
8920f5e95b
commit
d4f070f0aa
@ -92,7 +92,7 @@ public class AppManagerActivity extends Activity {
|
||||
}
|
||||
}
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
LOG.error("Error getting cached apps: " + e.getMessage(), e);
|
||||
}
|
||||
return cachedAppList;
|
||||
}
|
||||
|
@ -3,6 +3,9 @@ package nodomain.freeyourgadget.gadgetbridge.devices.pebble;
|
||||
import android.content.Context;
|
||||
import android.net.Uri;
|
||||
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
|
||||
@ -16,6 +19,7 @@ import nodomain.freeyourgadget.gadgetbridge.model.GenericItem;
|
||||
import nodomain.freeyourgadget.gadgetbridge.util.FileUtils;
|
||||
|
||||
public class PBWInstallHandler implements InstallHandler {
|
||||
private static final Logger LOG = LoggerFactory.getLogger(PBWInstallHandler.class);
|
||||
|
||||
private final Context mContext;
|
||||
private PBWReader mPBWReader;
|
||||
@ -110,7 +114,7 @@ public class PBWInstallHandler implements InstallHandler {
|
||||
destDir.mkdirs();
|
||||
FileUtils.copyFile(pbwFile, new File(destDir + "/" + app.getUUID().toString() + ".pbw"));
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
LOG.error("Installation failed: " + e.getMessage(), e);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -491,7 +491,7 @@ public class PebbleIoThread extends GBDeviceIoThread {
|
||||
try {
|
||||
installApp(Uri.fromFile(new File(FileUtils.getExternalFilesDir() + "/pbw-cache/" + appMgmt.uuid.toString() + ".pbw")), appMgmt.token);
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
LOG.error("Error installing app: " + e.getMessage(), e);
|
||||
}
|
||||
break;
|
||||
default:
|
||||
|
@ -2,6 +2,7 @@ package nodomain.freeyourgadget.gadgetbridge.util;
|
||||
|
||||
import android.content.Context;
|
||||
import android.os.Environment;
|
||||
import android.support.annotation.NonNull;
|
||||
import android.util.Log;
|
||||
|
||||
import java.io.ByteArrayOutputStream;
|
||||
@ -42,7 +43,8 @@ public class FileUtils {
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the existing external storage dir.
|
||||
* Returns the existing external storage dir. The directory is guaranteed to
|
||||
* exist and to be writable.
|
||||
*
|
||||
* @throws IOException when the directory is not available
|
||||
*/
|
||||
@ -72,6 +74,17 @@ public class FileUtils {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a list of directories to write to. The list is sorted by priority,
|
||||
* i.e. the first directory should be preferred, the last one is the least
|
||||
* preferred one.
|
||||
*
|
||||
* Note that the directories may not exist, so it is not guaranteed that you
|
||||
* can actually write to them. But when created, they *should* be writable.
|
||||
* @return the list of writable directories
|
||||
* @throws IOException
|
||||
*/
|
||||
@NonNull
|
||||
private static List<File> getWritableExternalFilesDirs() throws IOException {
|
||||
Context context = GBApplication.getContext();
|
||||
File[] dirs = context.getExternalFilesDirs(null);
|
||||
@ -87,17 +100,13 @@ public class FileUtils {
|
||||
if (!dir.exists() && !dir.mkdirs()) {
|
||||
continue;
|
||||
}
|
||||
// if (!dir.canWrite() || !Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState(dir))) {
|
||||
// the first directory is also the primary external storage, i.e. the same as Environment.getExternalFilesDir()
|
||||
// TODO: check the mount state of *all* dirs when switching to later API level
|
||||
if (!dir.canWrite() || (i == 0 && !Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState()))) {
|
||||
Log.i(TAG, "ignoring non-writable external storage dir: " + dir);
|
||||
continue;
|
||||
}
|
||||
// if (Environment.isExternalStorageEmulated(dir)) {
|
||||
if (i == 0 && Environment.isExternalStorageEmulated()) {
|
||||
result.add(dir); // add last
|
||||
} else {
|
||||
result.add(0, dir); // add first
|
||||
}
|
||||
result.add(dir); // add last
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user