Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(10)

Unified Diff: chrome/android/java/src/org/chromium/chrome/browser/notifications/WebApkNotificationClient.java

Issue 2974573002: Refactor WebApkServiceConnectionManager. (Closed)
Patch Set: Check bindService()'s return value. Created 3 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/android/java/src/org/chromium/chrome/browser/notifications/WebApkNotificationClient.java
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/notifications/WebApkNotificationClient.java b/chrome/android/java/src/org/chromium/chrome/browser/notifications/WebApkNotificationClient.java
index 7d34867a787b8048f9b15b0f7950fb8367c612a8..a272721443549b4e4b9d23b2b5f1b65db1aac0f0 100644
--- a/chrome/android/java/src/org/chromium/chrome/browser/notifications/WebApkNotificationClient.java
+++ b/chrome/android/java/src/org/chromium/chrome/browser/notifications/WebApkNotificationClient.java
@@ -12,8 +12,8 @@ import android.os.Build;
import android.os.RemoteException;
import org.chromium.base.ContextUtils;
-import org.chromium.base.Log;
-import org.chromium.webapk.lib.client.WebApkServiceConnectionManager;
+import org.chromium.webapk.lib.client.WebApkIdentityServiceClient;
+import org.chromium.webapk.lib.client.WebApkServiceClient;
import org.chromium.webapk.lib.runtime_library.IWebApkApi;
/**
@@ -21,70 +21,48 @@ import org.chromium.webapk.lib.runtime_library.IWebApkApi;
* context of a WebAPK, enriching the notification with the WebAPK's small icon when available.
*/
public class WebApkNotificationClient {
- private static final String TAG = "cr_WebApk";
-
- // Callback which catches RemoteExceptions thrown due to IWebApkApi failure.
- private abstract static class ApiUseCallback
- implements WebApkServiceConnectionManager.ConnectionCallback {
- public abstract void useApi(IWebApkApi api) throws RemoteException;
-
- @Override
- public void onConnected(IWebApkApi api) {
- try {
- useApi(api);
- } catch (RemoteException e) {
- Log.w(TAG, "WebApkAPI use failed.", e);
- }
- }
- }
-
/**
- * Connect to a WebAPK's bound service, build a notification and hand it over to the WebAPK to
+ * Connects to a WebAPK's bound service, builds a notification and hand it over to the WebAPK to
* display. Handing over the notification makes the notification look like it originated from
* the WebAPK - not Chrome - in the Android UI.
*/
public static void notifyNotification(final String webApkPackage,
final NotificationBuilderBase notificationBuilder, final String platformTag,
final int platformID) {
- final ApiUseCallback connectionCallback = new ApiUseCallback() {
- @Override
- public void useApi(IWebApkApi api) throws RemoteException {
- int smallIconId = api.getSmallIconId();
- // Prior to Android M, the small icon had to be from the resources of the app whose
- // NotificationManager is used in {@link NotificationManager#notify()}. On Android
- // M+, the small icon has to be from the resources of the app whose context is
- // passed to the {@link Notification.Builder()} constructor.
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
- // Android M+ introduced
- // {@link Notification.Builder#setSmallIcon(Bitmap icon)}.
- if (!notificationBuilder.hasSmallIconBitmap()) {
- notificationBuilder.setSmallIcon(
- decodeImageResource(webApkPackage, smallIconId));
+ final WebApkServiceClient.ApiUseCallback connectionCallback =
+ new WebApkServiceClient.ApiUseCallback() {
+ @Override
+ public void useApi(IWebApkApi api) throws RemoteException {
+ int smallIconId = api.getSmallIconId();
+ // Prior to Android M, the small icon had to be from the resources of the
+ // app whose NotificationManager is used in
+ // {@link NotificationManager#notify()}. On Android M+, the small icon has
+ // to be from the resources of the app whose context is passed to the
+ // {@link Notification.Builder()} constructor.
+ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
+ // Android M+ introduced
+ // {@link Notification.Builder#setSmallIcon(Bitmap icon)}.
+ if (!notificationBuilder.hasSmallIconBitmap()) {
+ notificationBuilder.setSmallIcon(
+ decodeImageResource(webApkPackage, smallIconId));
+ }
+ } else {
+ notificationBuilder.setSmallIcon(smallIconId);
+ }
+ api.notifyNotification(
+ platformTag, platformID, notificationBuilder.build());
}
- } else {
- notificationBuilder.setSmallIcon(smallIconId);
- }
- api.notifyNotification(platformTag, platformID, notificationBuilder.build());
- }
- };
+ };
- WebApkServiceConnectionManager.getInstance().connect(
+ WebApkServiceClient.notifyNotification(
ContextUtils.getApplicationContext(), webApkPackage, connectionCallback);
}
- /**
- * Cancel notification previously shown by WebAPK.
- */
+ /** Cancel notification previously shown by WebAPK. */
public static void cancelNotification(
- String webApkPackage, final String platformTag, final int platformID) {
- final ApiUseCallback connectionCallback = new ApiUseCallback() {
- @Override
- public void useApi(IWebApkApi api) throws RemoteException {
- api.cancelNotification(platformTag, platformID);
- }
- };
- WebApkServiceConnectionManager.getInstance().connect(
- ContextUtils.getApplicationContext(), webApkPackage, connectionCallback);
+ String webApkPackage, WebApkIdentityServiceClient.CheckRuntimeHostCallback callback) {
+ WebApkIdentityServiceClient.checkWebApkRuntimeHostAsync(
Yaron 2017/07/14 19:52:04 Shouldn't this be cancelNotification?
Xi Han 2017/07/14 22:00:56 Thanks for catching it!
+ ContextUtils.getApplicationContext(), webApkPackage, callback);
}
/** Decodes bitmap from WebAPK's resources. */

Powered by Google App Engine
This is Rietveld 408576698