Skip to content
This repository has been archived by the owner on Dec 3, 2024. It is now read-only.

Add another attempt to check write permissions on a folder (fixes #1971) #2057

Closed
wants to merge 4 commits into from
Closed
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@
import android.os.Build;
import android.os.Bundle;
import androidx.documentfile.provider.DocumentFile;

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please remove the new line.

import android.os.Environment;
import android.text.Editable;
import android.text.TextUtils;
import android.text.TextWatcher;
Expand Down Expand Up @@ -537,6 +539,10 @@ private void checkWriteAndUpdateUI() {
* Access level readwrite: folder can be configured "sendonly" or "sendreceive".
*/
mCanWriteToPath = Util.nativeBinaryCanWriteToPath(FolderActivity.this, mFolder.path);
if(!mCanWriteToPath){
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if(!mCanWriteToPath){
if (!mCanWriteToPath){

final File externalStorageDirectory = Environment.getExternalStorageDirectory();
mCanWriteToPath = Util.nativeBinaryCanWriteToPath2(externalStorageDirectory, mFolder.path);
}
if (mCanWriteToPath) {
binding.accessExplanationView.setText(R.string.folder_path_readwrite);
binding.folderType.setEnabled(true);
Expand Down
34 changes: 33 additions & 1 deletion app/src/main/java/com/nutomic/syncthingandroid/util/Util.java
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@
import android.content.Context;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager.NameNotFoundException;
import android.os.Build;
import android.preference.PreferenceManager;
import androidx.appcompat.app.AlertDialog;
import android.util.Log;
Expand Down Expand Up @@ -172,6 +171,38 @@ public static boolean nativeBinaryCanWriteToPath(Context context, String absolut
return true;
}

/**
* Returns if the syncthing binary would be able to write a file into
* the given folder given the configured access level.
*
* This uses the Android-native File API
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
* This uses the Android-native File API
* This uses the Android-native File API.

*/
public static Boolean nativeBinaryCanWriteToPath2(File externalStorageDir, String absoluteFolderPath) {
final String TOUCH_FILE_NAME = ".stwritetest";

// normalize path replacing ~ with external storage directory
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// normalize path replacing ~ with external storage directory
// Normalize path replacing ~ with external storage directory.

// this is consistent with what $HOME is set to in SyncthingRunnable
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// this is consistent with what $HOME is set to in SyncthingRunnable
// This is consistent with what $HOME is set to in SyncthingRunnable.

final String normalizedPath = absoluteFolderPath.replaceFirst("^~", externalStorageDir.getAbsolutePath());

// Write permission test file
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
// Write permission test file
// Write permission test file.

File touchFile = new File(normalizedPath, TOUCH_FILE_NAME);
final String touchFilePath = touchFile.getAbsolutePath();
try{
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
try{
try {

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please double-check whether the code follows the same convention as the current one (spacing, new lines, etc.).

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@tomasz1986 thank you for the review. I addressed the formatting issues you highlighted.

Boolean fileCreated = touchFile.createNewFile();
Log.d(TAG, String.format("%s createNewFile result %b", touchFilePath, fileCreated));
Boolean fileDeleted = touchFile.delete();
Log.d(TAG, String.format("%s delete result %b", touchFilePath, fileDeleted));
} catch (IOException e) {
Log.e(TAG, String.format("Failed to write test file '%s'", touchFilePath), e);
return false;
}

// Detected we have write permission.
Log.i(TAG, String.format("Successfully wrote test file '%s'", touchFile));

return true;
}

/**
* Run command in a shell and return the exit code.
*/
Expand Down Expand Up @@ -241,4 +272,5 @@ public static AlertDialog.Builder getAlertDialogBuilder(Context context)
{
return new MaterialAlertDialogBuilder(context);
}

wrobbins marked this conversation as resolved.
Show resolved Hide resolved
}