Fix intent for api, fix slection dialog in demo
This commit is contained in:
@@ -11,10 +11,10 @@
|
|||||||
<!-- android:key="aidl_demo2" -->
|
<!-- android:key="aidl_demo2" -->
|
||||||
<!-- android:title="AIDL Demo (ACCESS_KEYS permission)" /> -->
|
<!-- android:title="AIDL Demo (ACCESS_KEYS permission)" /> -->
|
||||||
<!-- </PreferenceCategory> -->
|
<!-- </PreferenceCategory> -->
|
||||||
<PreferenceCategory android:title="Crypto Provider" >
|
<PreferenceCategory android:title="OpenPGP Provider" >
|
||||||
<Preference
|
<Preference
|
||||||
android:key="crypto_provider_demo"
|
android:key="openpgp_provider_demo"
|
||||||
android:title="Crypto Provider" />
|
android:title="OpenPGP Provider" />
|
||||||
</PreferenceCategory>
|
</PreferenceCategory>
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
@@ -50,7 +50,7 @@ public class BaseActivity extends PreferenceActivity {
|
|||||||
// find preferences
|
// find preferences
|
||||||
mIntentDemo = (Preference) findPreference("intent_demo");
|
mIntentDemo = (Preference) findPreference("intent_demo");
|
||||||
mContentProviderDemo = (Preference) findPreference("content_provider_demo");
|
mContentProviderDemo = (Preference) findPreference("content_provider_demo");
|
||||||
mCryptoProvider = (Preference) findPreference("crypto_provider_demo");
|
mCryptoProvider = (Preference) findPreference("openpgp_provider_demo");
|
||||||
mAidlDemo = (Preference) findPreference("aidl_demo");
|
mAidlDemo = (Preference) findPreference("aidl_demo");
|
||||||
mAidlDemo2 = (Preference) findPreference("aidl_demo2");
|
mAidlDemo2 = (Preference) findPreference("aidl_demo2");
|
||||||
|
|
||||||
|
|||||||
@@ -186,12 +186,12 @@ public class OpenPgpProviderActivity extends Activity {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class OpenPGPProviderElement {
|
private static class OpenPgpProviderElement {
|
||||||
private String packageName;
|
private String packageName;
|
||||||
private String simpleName;
|
private String simpleName;
|
||||||
private Drawable icon;
|
private Drawable icon;
|
||||||
|
|
||||||
public OpenPGPProviderElement(String packageName, String simpleName, Drawable icon) {
|
public OpenPgpProviderElement(String packageName, String simpleName, Drawable icon) {
|
||||||
this.packageName = packageName;
|
this.packageName = packageName;
|
||||||
this.simpleName = simpleName;
|
this.simpleName = simpleName;
|
||||||
this.icon = icon;
|
this.icon = icon;
|
||||||
@@ -206,7 +206,7 @@ public class OpenPgpProviderActivity extends Activity {
|
|||||||
private void selectCryptoProvider() {
|
private void selectCryptoProvider() {
|
||||||
Intent intent = new Intent(IOpenPgpService.class.getName());
|
Intent intent = new Intent(IOpenPgpService.class.getName());
|
||||||
|
|
||||||
final ArrayList<OpenPGPProviderElement> providerList = new ArrayList<OpenPGPProviderElement>();
|
final ArrayList<OpenPgpProviderElement> providerList = new ArrayList<OpenPgpProviderElement>();
|
||||||
|
|
||||||
List<ResolveInfo> resInfo = getPackageManager().queryIntentServices(intent, 0);
|
List<ResolveInfo> resInfo = getPackageManager().queryIntentServices(intent, 0);
|
||||||
if (!resInfo.isEmpty()) {
|
if (!resInfo.isEmpty()) {
|
||||||
@@ -218,7 +218,8 @@ public class OpenPgpProviderActivity extends Activity {
|
|||||||
String simpleName = String.valueOf(resolveInfo.serviceInfo
|
String simpleName = String.valueOf(resolveInfo.serviceInfo
|
||||||
.loadLabel(getPackageManager()));
|
.loadLabel(getPackageManager()));
|
||||||
Drawable icon = resolveInfo.serviceInfo.loadIcon(getPackageManager());
|
Drawable icon = resolveInfo.serviceInfo.loadIcon(getPackageManager());
|
||||||
providerList.add(new OpenPGPProviderElement(packageName, simpleName, icon));
|
providerList.add(new OpenPgpProviderElement(packageName, simpleName, icon));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AlertDialog.Builder alert = new AlertDialog.Builder(this);
|
AlertDialog.Builder alert = new AlertDialog.Builder(this);
|
||||||
@@ -226,9 +227,12 @@ public class OpenPgpProviderActivity extends Activity {
|
|||||||
alert.setCancelable(false);
|
alert.setCancelable(false);
|
||||||
|
|
||||||
if (!providerList.isEmpty()) {
|
if (!providerList.isEmpty()) {
|
||||||
|
// add "disable OpenPGP provider"
|
||||||
|
providerList.add(0, new OpenPgpProviderElement(null, "Disable OpenPGP Provider", getResources()
|
||||||
|
.getDrawable(android.R.drawable.ic_menu_close_clear_cancel)));
|
||||||
|
|
||||||
// Init ArrayAdapter with Crypto Providers
|
// Init ArrayAdapter with OpenPGP Providers
|
||||||
ListAdapter adapter = new ArrayAdapter<OpenPGPProviderElement>(this,
|
ListAdapter adapter = new ArrayAdapter<OpenPgpProviderElement>(this,
|
||||||
android.R.layout.select_dialog_item, android.R.id.text1, providerList) {
|
android.R.layout.select_dialog_item, android.R.id.text1, providerList) {
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
// User super class to create the View
|
// User super class to create the View
|
||||||
@@ -252,6 +256,11 @@ public class OpenPgpProviderActivity extends Activity {
|
|||||||
public void onClick(DialogInterface dialog, int position) {
|
public void onClick(DialogInterface dialog, int position) {
|
||||||
String packageName = providerList.get(position).packageName;
|
String packageName = providerList.get(position).packageName;
|
||||||
|
|
||||||
|
if (packageName == null) {
|
||||||
|
dialog.cancel();
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
|
||||||
// bind to service
|
// bind to service
|
||||||
mCryptoServiceConnection = new OpenPgpServiceConnection(
|
mCryptoServiceConnection = new OpenPgpServiceConnection(
|
||||||
OpenPgpProviderActivity.this, packageName);
|
OpenPgpProviderActivity.this, packageName);
|
||||||
@@ -276,4 +285,3 @@ public class OpenPgpProviderActivity extends Activity {
|
|||||||
ad.show();
|
ad.show();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|||||||
@@ -380,7 +380,7 @@
|
|||||||
<!-- android:permission="org.sufficientlysecure.keychain.permission.ACCESS_API" /> -->
|
<!-- android:permission="org.sufficientlysecure.keychain.permission.ACCESS_API" /> -->
|
||||||
|
|
||||||
|
|
||||||
<!-- OpenPGP Remote Service API internal -->
|
<!-- OpenPGP API internal classes (not exported) -->
|
||||||
|
|
||||||
<activity
|
<activity
|
||||||
android:name="org.sufficientlysecure.keychain.openpgp_api.OpenPgpServiceActivity"
|
android:name="org.sufficientlysecure.keychain.openpgp_api.OpenPgpServiceActivity"
|
||||||
@@ -399,7 +399,7 @@
|
|||||||
android:configChanges="orientation|screenSize|keyboardHidden|keyboard"
|
android:configChanges="orientation|screenSize|keyboardHidden|keyboard"
|
||||||
android:exported="false" />
|
android:exported="false" />
|
||||||
|
|
||||||
<!-- OpenPGP Remote Service API -->
|
<!-- OpenPGP API -->
|
||||||
|
|
||||||
<service
|
<service
|
||||||
android:name="org.sufficientlysecure.keychain.openpgp_api.OpenPgpService"
|
android:name="org.sufficientlysecure.keychain.openpgp_api.OpenPgpService"
|
||||||
@@ -407,7 +407,7 @@
|
|||||||
android:exported="true"
|
android:exported="true"
|
||||||
android:process=":openpgp_api" >
|
android:process=":openpgp_api" >
|
||||||
<intent-filter>
|
<intent-filter>
|
||||||
<action android:name="org.openintents.crypto.ICryptoService" />
|
<action android:name="org.openintents.openpgp.IOpenPgpService" />
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
|
|
||||||
<meta-data
|
<meta-data
|
||||||
|
|||||||
Reference in New Issue
Block a user