Skip to content
Open
Show file tree
Hide file tree
Changes from all 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
1,313 changes: 1,313 additions & 0 deletions app/schemas/com.nextcloud.client.database.NextcloudDatabase/101.json

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,8 @@ import com.owncloud.android.lib.resources.shares.OCShare.Companion.NO_PERMISSION
import com.owncloud.android.lib.resources.shares.OCShare.Companion.READ_PERMISSION_FLAG
import com.owncloud.android.lib.resources.shares.OCShare.Companion.SHARE_PERMISSION_FLAG
import com.owncloud.android.lib.resources.shares.ShareType
import com.owncloud.android.lib.resources.status.CapabilityBooleanType
import com.owncloud.android.lib.resources.status.OCCapability
import com.owncloud.android.ui.activity.FileDisplayActivity
import com.owncloud.android.ui.fragment.util.SharePermissionManager
import com.owncloud.android.utils.ScreenshotTest
Expand All @@ -46,6 +48,8 @@ import org.hamcrest.CoreMatchers.anyOf
import org.hamcrest.CoreMatchers.`is`
import org.hamcrest.CoreMatchers.not
import org.junit.Assert.assertEquals
import org.junit.Assert.assertFalse
import org.junit.Assert.assertTrue
import org.junit.Before
import org.junit.Rule
import org.junit.Test
Expand Down Expand Up @@ -892,4 +896,55 @@ class FileDetailSharingFragmentIT : AbstractIT() {
assertEquals("Failed for permission: $permission", expected, SharePermissionManager.isFileRequest(share))
}
}

@Test
fun internalLinkUsesPrettyPathWhenModRewriteWorking() {
launchActivity<TestActivity>().use { scenario ->
var sut: FileDetailSharingFragment? = null
scenario.onActivity { activity ->
sut = FileDetailSharingFragment.newInstance(file, user)
activity.addFragment(sut)
activity.supportFragmentManager.executePendingTransactions()
}

val capabilities = OCCapability().apply { modRewriteWorking = CapabilityBooleanType.TRUE }
val link = sut!!.createInternalLink(user, file, capabilities)

assertTrue(link.endsWith("/f/" + file.localId))
assertFalse(link.contains("/index.php/"))
}
}

@Test
fun internalLinkUsesDefaultPathWhenModRewriteNotWorking() {
launchActivity<TestActivity>().use { scenario ->
var sut: FileDetailSharingFragment? = null
scenario.onActivity { activity ->
sut = FileDetailSharingFragment.newInstance(file, user)
activity.addFragment(sut)
activity.supportFragmentManager.executePendingTransactions()
}

val capabilities = OCCapability().apply { modRewriteWorking = CapabilityBooleanType.FALSE }
val link = sut!!.createInternalLink(user, file, capabilities)

assertTrue(link.endsWith("/index.php/f/" + file.localId))
}
}

@Test
fun internalLinkFallsBackToDefaultPathWhenCapabilitiesNull() {
launchActivity<TestActivity>().use { scenario ->
var sut: FileDetailSharingFragment? = null
scenario.onActivity { activity ->
sut = FileDetailSharingFragment.newInstance(file, user)
activity.addFragment(sut)
activity.supportFragmentManager.executePendingTransactions()
}

val link = sut!!.createInternalLink(user, file, null)

assertTrue(link.endsWith("/index.php/f/" + file.localId))
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ import com.nextcloud.client.database.migrations.DatabaseMigrationUtil
import com.nextcloud.client.database.migrations.MIGRATION_88_89
import com.nextcloud.client.database.migrations.MIGRATION_97_98
import com.nextcloud.client.database.migrations.MIGRATION_99_100
import com.nextcloud.client.database.migrations.MIGRATION_100_101
import com.nextcloud.client.database.migrations.Migration67to68
import com.nextcloud.client.database.migrations.RoomMigration
import com.nextcloud.client.database.migrations.addLegacyMigrations
Expand Down Expand Up @@ -99,6 +100,7 @@ import com.owncloud.android.db.ProviderMeta
// manual migration used for 97 to 98
AutoMigration(from = 98, to = 99)
// manual migration used for 99 to 100
// manual migration used for 100 to 101
],
exportSchema = true
)
Expand Down Expand Up @@ -139,6 +141,7 @@ abstract class NextcloudDatabase : RoomDatabase() {
.addMigrations(MIGRATION_88_89)
.addMigrations(MIGRATION_97_98)
.addMigrations(MIGRATION_99_100)
.addMigrations(MIGRATION_100_101)
.build()
}
return instance!!
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,9 @@ data class CapabilityEntity(
@ColumnInfo(name = ProviderTableMeta.CAPABILITIES_HAS_VALID_SUBSCRIPTION)
val hasValidSubscription: Int?,
@ColumnInfo(name = ProviderTableMeta.CAPABILITIES_CLIENT_INTEGRATION_JSON)
val clientIntegrationJson: String?
val clientIntegrationJson: String?,
@ColumnInfo(name = ProviderTableMeta.CAPABILITIES_MOD_REWRITE_WORKING)
val modRewriteWorking: Int?
)

@Suppress("LongMethod", "ReturnCount")
Expand Down Expand Up @@ -232,6 +234,7 @@ fun CapabilityEntity?.toOCCapability(): OCCapability {
capability.defaultPermissions = this.defaultPermissions ?: 0
capability.hasValidSubscription = intToBoolean(this.hasValidSubscription)
capability.clientIntegrationJson = this.clientIntegrationJson
capability.modRewriteWorking = intToBoolean(this.modRewriteWorking)

return capability
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
/*
* Nextcloud - Android Client
*
* SPDX-FileCopyrightText: 2026 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/

package com.nextcloud.client.database.migrations

import androidx.room.migration.Migration
import androidx.sqlite.db.SupportSQLiteDatabase
import com.nextcloud.client.database.migrations.model.SQLiteColumnType
import com.owncloud.android.db.ProviderMeta

@Suppress("MagicNumber")
val MIGRATION_100_101 = object : Migration(100, 101) {
override fun migrate(db: SupportSQLiteDatabase) {
DatabaseMigrationUtil.addColumnIfNotExists(
db,
ProviderMeta.ProviderTableMeta.CAPABILITIES_TABLE_NAME,
ProviderMeta.ProviderTableMeta.CAPABILITIES_MOD_REWRITE_WORKING,
SQLiteColumnType.INTEGER_DEFAULT_NULL
)

DatabaseMigrationUtil.resetCapabilities(db)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2415,6 +2415,8 @@ private ContentValues createContentValues(String accountName, OCCapability capab

contentValues.put(ProviderTableMeta.CAPABILITIES_CLIENT_INTEGRATION_JSON, capability.getClientIntegrationJson());

contentValues.put(ProviderTableMeta.CAPABILITIES_MOD_REWRITE_WORKING, capability.getModRewriteWorking().getValue());

return contentValues;
}

Expand Down Expand Up @@ -2612,6 +2614,8 @@ private OCCapability createCapabilityInstance(Cursor cursor) {
capability.setHasValidSubscription(getBoolean(cursor, ProviderTableMeta.CAPABILITIES_HAS_VALID_SUBSCRIPTION));

capability.setClientIntegrationJson(getString(cursor, ProviderTableMeta.CAPABILITIES_CLIENT_INTEGRATION_JSON));

capability.setModRewriteWorking(getBoolean(cursor, ProviderTableMeta.CAPABILITIES_MOD_REWRITE_WORKING));
}

return capability;
Expand Down
3 changes: 2 additions & 1 deletion app/src/main/java/com/owncloud/android/db/ProviderMeta.java
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
*/
public class ProviderMeta {
public static final String DB_NAME = "filelist";
public static final int DB_VERSION = 100;
public static final int DB_VERSION = 101;

private ProviderMeta() {
// No instance
Expand Down Expand Up @@ -293,6 +293,7 @@ static public class ProviderTableMeta implements BaseColumns {
public static final String CAPABILITIES_DEFAULT_PERMISSIONS = "default_permissions";
public static final String CAPABILITIES_HAS_VALID_SUBSCRIPTION = "has_valid_subscription";
public static final String CAPABILITIES_CLIENT_INTEGRATION_JSON = "client_integration_json";
public static final String CAPABILITIES_MOD_REWRITE_WORKING = "mod_rewrite_working";

//Columns of Uploads table
public static final String UPLOADS_LOCAL_PATH = "local_path";
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,6 @@
import com.owncloud.android.datamodel.OCFile;
import com.owncloud.android.datamodel.SharesType;
import com.owncloud.android.datamodel.e2e.v2.decrypted.DecryptedFolderMetadataFile;
import com.owncloud.android.lib.common.OwnCloudAccount;
import com.owncloud.android.lib.common.OwnCloudClient;
import com.owncloud.android.lib.common.operations.RemoteOperationResult;
import com.owncloud.android.lib.common.utils.Log_OC;
Expand Down Expand Up @@ -99,6 +98,8 @@ public class FileDetailSharingFragment extends Fragment implements ShareeListAda
private static final String TAG = "FileDetailSharingFragment";
private static final String ARG_FILE = "FILE";
private static final String ARG_USER = "USER";
private static final String INTERNAL_LINK_PATH_PRETTY = "/f/";
private static final String INTERNAL_LINK_PATH_DEFAULT = "/index.php/f/";

private OCFile file;
private User user;
Expand Down Expand Up @@ -464,18 +465,20 @@ private void setShareWithYou() {

@Override
public void copyInternalLink() {
OwnCloudAccount account = accountManager.getCurrentOwnCloudAccount();

if (account == null) {
if (user == null) {
DisplayUtils.showSnackMessage(this, R.string.could_not_retrieve_url);
return;
}

FileDisplayActivity.showShareLinkDialog(fileActivity, file, createInternalLink(account, file));
FileDisplayActivity.showShareLinkDialog(fileActivity, file, createInternalLink(user, file, capabilities));
}

private String createInternalLink(OwnCloudAccount account, OCFile file) {
return account.getBaseUri() + "/index.php/f/" + file.getLocalId();
@VisibleForTesting
String createInternalLink(User user, OCFile file, OCCapability capabilities) {
final String linkPath = (capabilities != null && capabilities.getModRewriteWorking().isTrue())
? INTERNAL_LINK_PATH_PRETTY
: INTERNAL_LINK_PATH_DEFAULT;
return user.getServer().getUri() + linkPath + file.getLocalId();
}

@Override
Expand Down
2 changes: 1 addition & 1 deletion gradle/libs.versions.toml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
androidCommonLibraryVersion = "0.33.2"
androidGifDrawableVersion = "1.2.31"
androidImageCropperVersion = "4.7.0"
androidLibraryVersion ="0282f675c8f11af9f1da91436f1fa95abe2333fe"
androidLibraryVersion ="PR2057-SNAPSHOT"
androidOpensslVersion = "3.5.6"
androidPluginVersion = "9.2.1"
androidsvgVersion = "1.4"
Expand Down
Loading