Overview
| Correctness | |
| 8 | error AppLinkUrlError: URI invalid | 
| 3 | error
ForegroundServiceType: Missing foregroundServiceTypeattribute in manifest | 
| 1 | warning
UseSwitchCompatOrMaterialCode: Replace usage of Switchwidget | 
| Correctness:Messages | |
| 1 | warning PluralsCandidate: Potential Plurals | 
| Security | |
| 1 | warning UnsafeIntentLaunch: Launched Unsafe Intent | 
| 1 | warning AcceptsUserCertificates: Allowing User Certificates | 
| 1 | warning InsecureBaseConfiguration: Insecure Base Configuration | 
| Performance | |
| 14 | warning NotifyDataSetChanged: Invalidating All RecyclerView Data | 
| 9 | warning StaticFieldLeak: Static Field Leaks | 
| 2 | warning NestedWeights: Nested layout weights | 
| 10 | warning Overdraw: Overdraw: Painting regions more than once | 
| 1 | warning UsableSpace: Using getUsableSpace() | 
| Usability:Icons | |
| 1 | warning
IconXmlAndPng: Icon is specified both as .xmlfile and as a bitmap | 
| Included Additional Checks (92) | |
| Disabled Checks (52) | 
URI invalid
../../src/main/AndroidManifest.xml:162: 
159 <category android:name="android.intent.category.BROWSABLE" /> 160 161 <data android:scheme="http" /> 162 <data android:host="*" /> 163 <data android:pathPattern="/f/..*" /> 164 </intent-filter> 165 <intent-filter android:autoVerify="true">../../src/main/AndroidManifest.xml:172:
169 <category android:name="android.intent.category.BROWSABLE" /> 170 171 <data android:scheme="http" /> 172 <data android:host="*" /> 173 <data android:pathPattern="/..*/f/..*" /> 174 </intent-filter> 175 <intent-filter android:autoVerify="true">../../src/main/AndroidManifest.xml:182:
179 <category android:name="android.intent.category.BROWSABLE" /> 180 181 <data android:scheme="http" /> 182 <data android:host="*" /> 183 <data android:pathPattern="/..*/..*/f/..*" /> 184 </intent-filter> 185 <intent-filter android:autoVerify="true">../../src/main/AndroidManifest.xml:192:
189 <category android:name="android.intent.category.BROWSABLE" /> 190 191 <data android:scheme="http" /> 192 <data android:host="*" /> 193 <data android:pathPattern="/..*/..*/..*/f/..*" /> 194 </intent-filter> 195 <intent-filter android:autoVerify="true">../../src/main/AndroidManifest.xml:202:
199 <category android:name="android.intent.category.BROWSABLE" /> 200 201 <data android:scheme="https" /> 202 <data android:host="*" /> 203 <data android:pathPattern="/f/..*" /> 204 </intent-filter> 205 <intent-filter android:autoVerify="true">../../src/main/AndroidManifest.xml:212:
209 <category android:name="android.intent.category.BROWSABLE" /> 210 211 <data android:scheme="https" /> 212 <data android:host="*" /> 213 <data android:pathPattern="/..*/f/..*" /> 214 </intent-filter> 215 <intent-filter android:autoVerify="true">../../src/main/AndroidManifest.xml:222:
219 <category android:name="android.intent.category.BROWSABLE" /> 220 221 <data android:scheme="https" /> 222 <data android:host="*" /> 223 <data android:pathPattern="/..*/..*/f/..*" /> 224 </intent-filter> 225 <intent-filter android:autoVerify="true">../../src/main/AndroidManifest.xml:232:
229 <category android:name="android.intent.category.BROWSABLE" /> 230 231 <data android:scheme="https" /> 232 <data android:host="*" /> 233 <data android:pathPattern="/..*/..*/..*/f/..*" /> 234 <!-- path pattern to handle deep link --> 235 <data android:pathPattern="/app/..*" />
    AppLinkUrlError
    Correctness
    Error
    Priority 5/10
              Missing foregroundServiceType attribute in manifest
../../src/main/java/com/nextcloud/utils/ForegroundServiceHelper.kt:31: 
28 ) { 29 if (isAboveOrEqualAndroid10) { 30 try { 31 ServiceCompat.startForeground( 32 service, 33 id, 34 notification,../../src/main/java/com/nextcloud/utils/ForegroundServiceHelper.kt:41:
38 Log.d(TAG, "Exception caught at ForegroundServiceHelper.startService: $e") 39 } 40 } else { 41 service.startForeground(id, notification) 42 } 43 }../../src/main/java/com/nextcloud/client/media/PlayerService.kt:67:
64 putExtra(IS_MEDIA_CONTROL_LAYOUT_READY, false) 65 } 66 LocalBroadcastManager.getInstance(applicationContext).sendBroadcast(intent) 67 startForeground(file) 68 } 69 70 override fun onStart() {
    ForegroundServiceType
    Correctness
    Error
    Priority 5/10
              Replace usage of Switch widget
../../src/main/java/com/owncloud/android/ui/ThemeableSwitchPreference.java:57: 
54 for (int i = 0; i < viewGroup.getChildCount(); i++) { 55 View child = viewGroup.getChildAt(i); 56 57 if (child instanceof Switch switchView) { 58 viewThemeUtils.platform.colorSwitch(switchView); 59 60 break;
Vendor: Android Open Source Project
Identifier: androidx.appcompat
Feedback: https://issuetracker.google.com/issues/new?component=460343
Identifier: androidx.appcompat
Feedback: https://issuetracker.google.com/issues/new?component=460343
    UseSwitchCompatOrMaterialCode
    Correctness
    Warning
    Priority 5/10
              Potential Plurals
../../src/main/res/values/strings.xml:175: 
172 <string name="uploader_error_message_source_file_not_found">File selected for upload not found. Please check whether the file exists.</string> 173 <string name="uploader_error_message_source_file_not_copied">Could not copy file to a temporary folder. Try to resend it.</string> 174 <string name="uploader_upload_files_behaviour">Upload option:</string> 175 <string name="file_upload_limit_message">You can upload up to %d files at once."</string> 176 <string name="file_upload_worker_same_file_already_exists">%s already exists, no conflict detected</string> 177 <string name="uploader_upload_files_behaviour_move_to_nextcloud_folder">Move file to %1$s folder</string> 178 <string name="uploader_upload_files_behaviour_only_upload">Keep file in source folder</string>
    PluralsCandidate
    Messages
    Correctness
    Warning
    Priority 5/10
              Launched Unsafe Intent
../../src/main/java/com/owncloud/android/ui/activity/FileDisplayActivity.kt:541: 
538 539 // region Handle Intents 540 @SuppressLint("UnsafeIntentLaunch") 541 override fun onNewIntent(intent: Intent) { 542 super.onNewIntent(intent) 543 setIntent(intent) 544 handleCommonIntents(intent)
592 } 593 594 finish() 595 startActivity(intent) 596 } 597 598 private fun handleAccountSwitchIntent(intent: Intent) {
    UnsafeIntentLaunch
    Security
    Warning
    Priority 6/10
              Allowing User Certificates
../../src/main/res/xml/network_security_config.xml:15: 
12 <!-- Trust preinstalled CAs --> 13 <certificates src="system"/> 14 <!-- Additionally trust user added CAs --> 15 <certificates src="user"/> 16 </trust-anchors> 17 </base-config> 18 </network-security-config>
    AcceptsUserCertificates
    Security
    Warning
    Priority 5/10
              Insecure Base Configuration
../../src/main/res/xml/network_security_config.xml:10: 
7 ~ SPDX-License-Identifier: AGPL-3.0-or-later OR GPL-2.0-only 8 --> 9 <network-security-config> 10 <base-config cleartextTrafficPermitted="true"> 11 <trust-anchors> 12 <!-- Trust preinstalled CAs --> 13 <certificates src="system"/>
    InsecureBaseConfiguration
    Security
    Warning
    Priority 5/10
              Invalidating All RecyclerView Data
../../src/main/java/com/owncloud/android/ui/adapter/ActivityAndVersionListAdapter.java:102: 
99 } 100 } 101 102 notifyDataSetChanged(); 103 } 104 105 @NonNull../../src/main/java/com/owncloud/android/ui/adapter/ActivityListAdapter.java:122:
119 values.add(activity); 120 } 121 } 122 notifyDataSetChanged(); 123 } 124 125 @NonNull../../src/main/java/com/nextcloud/client/etm/pages/EtmFileTransferFragment.kt:68:
65 66 fun setStatus(status: TransferManager.Status) { 67 transfers = listOf(status.pending, status.running, status.completed).flatten().reversed() 68 notifyDataSetChanged() 69 } 70 71 override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {../../src/main/java/com/nextcloud/client/etm/EtmMenuAdapter.kt:25:
22 var pages: List<EtmMenuEntry> = listOf() 23 set(value) { 24 field = value 25 notifyDataSetChanged() 26 } 27 28 class PageViewHolder(view: View, onClick: (Int) -> Unit) : RecyclerView.ViewHolder(view) {../../src/main/java/com/owncloud/android/ui/adapter/NotificationListAdapter.java:81:
78 public void setNotificationItems(List<Notification> notificationItems) { 79 notificationsList.clear(); 80 notificationsList.addAll(notificationItems); 81 notifyDataSetChanged(); 82 } 83 84 @NonNull+ 9 More Occurrences...
    NotifyDataSetChanged
    Performance
    Warning
    Priority 8/10
              Static Field Leaks
../../src/main/java/com/owncloud/android/ui/activity/ErrorsWhileCopyingHandlerActivity.java:197: 
194 /** 195 * Asynchronous task performing the move of all the local files to the ownCloud folder. 196 */ 197 private class MoveFilesTask extends AsyncTask<Void, Void, Boolean> { 198 199 /** 200 * Updates the UI before trying the movement../../src/main/java/com/owncloud/android/ui/asynctasks/FetchRemoteFileTask.java:33:
30 private final User user; 31 private final String fileId; 32 private final FileDataStorageManager storageManager; 33 private final FileDisplayActivity fileDisplayActivity; 34 private OCFile ocFile; 35 36 public FetchRemoteFileTask(User user,../../src/main/java/com/owncloud/android/ui/activities/data/files/FilesServiceApiImpl.java:60:
57 private final FilesServiceCallback<OCFile> callback; 58 private OCFile remoteOcFile; 59 private String errorMessage; 60 // TODO: Figure out a better way to do this than passing a BaseActivity reference. 61 private final BaseActivity baseActivity; 62 private final String fileUrl; 63 private final User user;../../src/main/java/com/nextcloud/client/logger/ui/LogsViewModel.kt:21:
18 import javax.inject.Inject 19 20 class LogsViewModel @Inject constructor( 21 private val context: Context, 22 clock: Clock, 23 asyncRunner: AsyncRunner, 24 private val logsRepository: LogsRepository../../src/main/java/com/owncloud/android/ui/asynctasks/NotificationExecuteActionTask.java:35:
32 private final NotificationListAdapter.NotificationViewHolder holder; 33 private final NextcloudClient client; 34 private final Notification notification; 35 private final NotificationsActivity notificationsActivity; 36 37 public NotificationExecuteActionTask(NextcloudClient client, 38 NotificationListAdapter.NotificationViewHolder holder,+ 4 More Occurrences...
    StaticFieldLeak
    Performance
    Warning
    Priority 6/10
              Nested layout weights
../../src/main/res/layout/first_run_activity.xml:27: 
24 android:id="@+id/contentPanel" 25 android:layout_width="match_parent" 26 android:layout_height="0dp" 27 android:layout_weight="1"/> 28 29 <com.owncloud.android.ui.whatsnew.ProgressIndicator 30 android:id="@+id/progressIndicator"../../src/main/res/layout/whats_new_activity.xml:50:
47 android:layout_width="0dp" 48 android:layout_height="match_parent" 49 android:layout_gravity="center_vertical|center_horizontal" 50 android:layout_weight="1" 51 android:gravity="center" 52 android:paddingLeft="0dp" 53 android:paddingRight="0dp"
    NestedWeights
    Performance
    Warning
    Priority 3/10
              Overdraw: Painting regions more than once
../../src/main/res/layout/activity_edit_image.xml:13: 
10 xmlns:app="http://schemas.android.com/apk/res-auto" 11 android:layout_width="match_parent" 12 android:layout_height="match_parent" 13 android:background="@color/black"> 14 15 <androidx.appcompat.widget.Toolbar 16 android:id="@+id/toolbar"../../src/main/res/layout/activity_row.xml:12:
9 android:id="@+id/list_item" 10 android:layout_width="match_parent" 11 android:layout_height="@dimen/activity_row_layout_height" 12 android:background="?android:attr/activatedBackgroundIndicator" 13 android:minWidth="@dimen/activity_row_layout_min_width_independent" 14 android:orientation="horizontal" 15 android:paddingEnd="@dimen/standard_padding"../../src/main/res/layout/activity_splash.xml:12:
9 xmlns:app="http://schemas.android.com/apk/res-auto" 10 android:layout_width="match_parent" 11 android:layout_height="match_parent" 12 android:background="@color/primary"> 13 14 <androidx.appcompat.widget.AppCompatImageView 15 android:id="@+id/ivSplash"../../src/main/res/layout/dialog_preview_video.xml:15:
12 android:layout_width="match_parent" 13 android:layout_height="match_parent" 14 android:layout_gravity="center" 15 android:background="@color/black" 16 app:show_buffering="always" />../../src/main/res/layout/drawer_header.xml:15:
12 android:id="@+id/drawer_header_view" 13 android:layout_width="match_parent" 14 android:layout_height="wrap_content" 15 android:background="@color/primary" 16 android:gravity="center" 17 android:orientation="vertical">+ 5 More Occurrences...
    Overdraw
    Performance
    Warning
    Priority 3/10
              Using getUsableSpace()
../../src/main/java/com/owncloud/android/utils/FileStorageUtils.java:236: 
233 */ 234 public static long getUsableSpace() { 235 File savePath = new File(MainApp.getStoragePath()); 236 return savePath.getUsableSpace(); 237 } 238 239 /**
    UsableSpace
    Performance
    Warning
    Priority 3/10
              Icon is specified both as .xml file and as a bitmap
    IconXmlAndPng
    Icons
    Usability
    Warning
    Priority 7/10
              Included Additional Checks
This card lists all the extra checks run by lint, provided from libraries,
build configuration and extra flags. This is included to help you verify
whether a particular check is included in analysis when configuring builds.
(Note that the list does not include the hundreds of built-in checks into lint,
only additional ones.)
              
              Disabled Checks
One or more issues were not run by lint, either
because the check is not enabled by default, or because
it was disabled with a command line flag or via one or
more 
              lint.xml configuration files in the project directories.
              Suppressing Warnings and Errors
Lint errors can be suppressed in a variety of ways:
1. With a
2. With a
3. With a //noinspection comment in the source code
4. With ignore flags specified in the
5. With a
6. With a
7. With the --ignore flag passed to lint.
To suppress a lint warning with an annotation, add a
To suppress a lint warning with a comment, add a
To suppress a lint warning in an XML file, add a
To suppress a lint warning in a
Here we specify a comma separated list of issue id's after the disable command. You can also use
To suppress lint warnings with a configuration XML file, create a file named
The format of the
To suppress lint checks from the command line, pass the --ignore flag with a comma separated list of ids to be suppressed, such as:
For more information, see https://developer.android.com/studio/write/lint.html#config
            
            1. With a
@SuppressLint annotation in the Java code2. With a
tools:ignore attribute in the XML file3. With a //noinspection comment in the source code
4. With ignore flags specified in the
build.gradle file, as explained below5. With a
lint.xml configuration file in the project6. With a
lint.xml configuration file passed to lint via the --config flag7. With the --ignore flag passed to lint.
To suppress a lint warning with an annotation, add a
@SuppressLint("id") annotation on the class, method or variable declaration closest to the warning instance you want to disable. The id can be one or more issue id's, such as "UnusedResources" or {"UnusedResources","UnusedIds"}, or it can be "all" to suppress all lint warnings in the given scope.To suppress a lint warning with a comment, add a
//noinspection id comment on the line before the statement with the error.To suppress a lint warning in an XML file, add a
tools:ignore="id" attribute on the element containing the error, or one of its surrounding elements. You also need to define the namespace for the tools prefix on the root element in your document, next to the xmlns:android declaration:xmlns:tools="http://schemas.android.com/tools"To suppress a lint warning in a
build.gradle file, add a section like this:
android {
    lintOptions {
        disable 'TypographyFractions','TypographyQuotes'
    }
}
Here we specify a comma separated list of issue id's after the disable command. You can also use
warning or error instead of disable to change the severity of issues.To suppress lint warnings with a configuration XML file, create a file named
lint.xml and place it at the root directory of the module in which it applies.The format of the
lint.xml file is something like the following:
<?xml version="1.0" encoding="UTF-8"?>
<lint>
    <!-- Ignore everything in the test source set -->
    <issue id="all">
        <ignore path="\*/test/\*" />
    </issue>
    <!-- Disable this given check in this project -->
    <issue id="IconMissingDensityFolder" severity="ignore" />
    <!-- Ignore the ObsoleteLayoutParam issue in the given files -->
    <issue id="ObsoleteLayoutParam">
        <ignore path="res/layout/activation.xml" />
        <ignore path="res/layout-xlarge/activation.xml" />
        <ignore regexp="(foo|bar)\.java" />
    </issue>
    <!-- Ignore the UselessLeaf issue in the given file -->
    <issue id="UselessLeaf">
        <ignore path="res/layout/main.xml" />
    </issue>
    <!-- Change the severity of hardcoded strings to "error" -->
    <issue id="HardcodedText" severity="error" />
</lint>
To suppress lint checks from the command line, pass the --ignore flag with a comma separated list of ids to be suppressed, such as:
$ lint --ignore UnusedResources,UselessLeaf /my/project/pathFor more information, see https://developer.android.com/studio/write/lint.html#config




