Merge "Migrate SearchFeatureProviderImpl to Kotlin" into main
This commit is contained in:
@@ -1,81 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2017 The Android Open Source Project
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.android.settings.search;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.net.Uri;
|
|
||||||
import android.provider.Settings;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
|
|
||||||
import com.android.settingslib.search.SearchIndexableResources;
|
|
||||||
import com.android.settingslib.search.SearchIndexableResourcesMobile;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* FeatureProvider for the refactored search code.
|
|
||||||
*/
|
|
||||||
public class SearchFeatureProviderImpl implements SearchFeatureProvider {
|
|
||||||
|
|
||||||
private SearchIndexableResources mSearchIndexableResources;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void verifyLaunchSearchResultPageCaller(@NonNull Context context,
|
|
||||||
@NonNull String callerPackage) {
|
|
||||||
if (TextUtils.isEmpty(callerPackage)) {
|
|
||||||
throw new IllegalArgumentException("ExternalSettingsTrampoline intents "
|
|
||||||
+ "must be called with startActivityForResult");
|
|
||||||
}
|
|
||||||
final boolean isSettingsPackage = TextUtils.equals(callerPackage, context.getPackageName())
|
|
||||||
|| TextUtils.equals(getSettingsIntelligencePkgName(context), callerPackage);
|
|
||||||
final boolean isAllowlistedPackage = isSignatureAllowlisted(context, callerPackage);
|
|
||||||
if (isSettingsPackage || isAllowlistedPackage) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
throw new SecurityException("Search result intents must be called with from an "
|
|
||||||
+ "allowlisted package.");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public SearchIndexableResources getSearchIndexableResources() {
|
|
||||||
if (mSearchIndexableResources == null) {
|
|
||||||
mSearchIndexableResources = new SearchIndexableResourcesMobile();
|
|
||||||
}
|
|
||||||
return mSearchIndexableResources;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Intent buildSearchIntent(Context context, int pageId) {
|
|
||||||
return new Intent(Settings.ACTION_APP_SEARCH_SETTINGS)
|
|
||||||
.setPackage(getSettingsIntelligencePkgName(context))
|
|
||||||
.putExtra(Intent.EXTRA_REFERRER, buildReferrer(context, pageId));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected boolean isSignatureAllowlisted(Context context, String callerPackage) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static Uri buildReferrer(Context context, int pageId) {
|
|
||||||
return new Uri.Builder()
|
|
||||||
.scheme("android-app")
|
|
||||||
.authority(context.getPackageName())
|
|
||||||
.path(String.valueOf(pageId))
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
}
|
|
64
src/com/android/settings/search/SearchFeatureProviderImpl.kt
Normal file
64
src/com/android/settings/search/SearchFeatureProviderImpl.kt
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2024 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.search
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.content.Intent
|
||||||
|
import android.net.Uri
|
||||||
|
import android.provider.Settings
|
||||||
|
import com.android.settings.search.SearchIndexableResourcesFactory.createSearchIndexableResources
|
||||||
|
import com.android.settingslib.search.SearchIndexableResources
|
||||||
|
|
||||||
|
/** FeatureProvider for the refactored search code. */
|
||||||
|
open class SearchFeatureProviderImpl : SearchFeatureProvider {
|
||||||
|
private val lazySearchIndexableResources by lazy { createSearchIndexableResources() }
|
||||||
|
|
||||||
|
override fun verifyLaunchSearchResultPageCaller(context: Context, callerPackage: String) {
|
||||||
|
require(callerPackage.isNotEmpty()) {
|
||||||
|
"ExternalSettingsTrampoline intents must be called with startActivityForResult"
|
||||||
|
}
|
||||||
|
val isSettingsPackage = callerPackage == context.packageName
|
||||||
|
if (isSettingsPackage ||
|
||||||
|
callerPackage == getSettingsIntelligencePkgName(context) ||
|
||||||
|
isSignatureAllowlisted(context, callerPackage)) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
throw SecurityException(
|
||||||
|
"Search result intents must be called with from an allowlisted package.")
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun getSearchIndexableResources(): SearchIndexableResources =
|
||||||
|
lazySearchIndexableResources
|
||||||
|
|
||||||
|
override fun buildSearchIntent(context: Context, pageId: Int): Intent =
|
||||||
|
Intent(Settings.ACTION_APP_SEARCH_SETTINGS)
|
||||||
|
.setPackage(getSettingsIntelligencePkgName(context))
|
||||||
|
.putExtra(Intent.EXTRA_REFERRER, buildReferrer(context, pageId))
|
||||||
|
|
||||||
|
protected open fun isSignatureAllowlisted(context: Context, callerPackage: String): Boolean =
|
||||||
|
false
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
private fun buildReferrer(context: Context, pageId: Int): Uri =
|
||||||
|
Uri.Builder()
|
||||||
|
.scheme("android-app")
|
||||||
|
.authority(context.packageName)
|
||||||
|
.path(pageId.toString())
|
||||||
|
.build()
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,34 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2024 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.search;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
|
||||||
|
import com.android.settingslib.search.SearchIndexableResources;
|
||||||
|
import com.android.settingslib.search.SearchIndexableResourcesMobile;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates the {@link SearchIndexableResourcesMobile}.
|
||||||
|
* <p>
|
||||||
|
* Since this class is generated by annotation processor, so it can only be created in Java now.
|
||||||
|
*/
|
||||||
|
class SearchIndexableResourcesFactory {
|
||||||
|
@NonNull
|
||||||
|
static SearchIndexableResources createSearchIndexableResources() {
|
||||||
|
return new SearchIndexableResourcesMobile();
|
||||||
|
}
|
||||||
|
}
|
@@ -124,8 +124,8 @@ public class SearchFeatureProviderImplTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
@Test(expected = IllegalArgumentException.class)
|
||||||
public void verifyLaunchSearchResultPageCaller_nullCaller_shouldCrash() {
|
public void verifyLaunchSearchResultPageCaller_emptyCaller_shouldCrash() {
|
||||||
mProvider.verifyLaunchSearchResultPageCaller(mActivity, null /* caller */);
|
mProvider.verifyLaunchSearchResultPageCaller(mActivity, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = SecurityException.class)
|
@Test(expected = SecurityException.class)
|
||||||
|
Reference in New Issue
Block a user