summaryrefslogtreecommitdiff
path: root/java/com/android/dialer/commandline/CommandLineReceiver.java
diff options
context:
space:
mode:
authortwyen <twyen@google.com>2018-01-16 16:16:47 -0800
committerCopybara-Service <copybara-piper@google.com>2018-01-16 16:18:22 -0800
commit15cf6dc111d59ebefee15a586ff511ccdc29b545 (patch)
tree017f1c63d9be2ba32219533274c134807312986e /java/com/android/dialer/commandline/CommandLineReceiver.java
parent3eca69f8ceb91537f72ca6df797bf4cfd93bc41b (diff)
Implement dialer command line interface
This CL adds a generic interface to perform action and retrieve data in dialer. Test: Unit tests PiperOrigin-RevId: 182128015 Change-Id: Ib45ce9808bd4e0e4a9c9e05c0017e19c3213bb0d
Diffstat (limited to 'java/com/android/dialer/commandline/CommandLineReceiver.java')
-rw-r--r--java/com/android/dialer/commandline/CommandLineReceiver.java91
1 files changed, 91 insertions, 0 deletions
diff --git a/java/com/android/dialer/commandline/CommandLineReceiver.java b/java/com/android/dialer/commandline/CommandLineReceiver.java
new file mode 100644
index 000000000..baaadf054
--- /dev/null
+++ b/java/com/android/dialer/commandline/CommandLineReceiver.java
@@ -0,0 +1,91 @@
+/*
+ * Copyright (C) 2018 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.dialer.commandline;
+
+import android.content.BroadcastReceiver;
+import android.content.Context;
+import android.content.Intent;
+import android.text.TextUtils;
+import com.android.dialer.buildtype.BuildType;
+import com.android.dialer.common.LogUtil;
+import com.google.common.collect.ImmutableList;
+import com.google.common.util.concurrent.FutureCallback;
+import com.google.common.util.concurrent.Futures;
+import com.google.common.util.concurrent.MoreExecutors;
+
+/**
+ * Receives broadcasts to the component from adb shell. Must be on bugfood or have debug logging
+ * enabled.
+ */
+public class CommandLineReceiver extends BroadcastReceiver {
+
+ public static final String COMMAND = "command";
+ public static final String ARGS = "args";
+ public static final String TAG = "tag";
+
+ @Override
+ public void onReceive(Context context, Intent intent) {
+ String outputTag = intent.getStringExtra(TAG);
+ if (outputTag == null) {
+ LogUtil.e("CommandLineReceiver", "missing tag");
+ return;
+ }
+ if (!LogUtil.isDebugEnabled() && BuildType.get() != BuildType.BUGFOOD) {
+ LogUtil.i(outputTag, "DISABLED");
+ return;
+ }
+ Command command =
+ CommandLineComponent.get(context)
+ .commandSupplier()
+ .get()
+ .get(intent.getStringExtra(COMMAND));
+ if (command == null) {
+ LogUtil.i(outputTag, "unknown command " + intent.getStringExtra(COMMAND));
+ return;
+ }
+
+ ImmutableList<String> args =
+ intent.hasExtra(ARGS)
+ ? ImmutableList.copyOf(intent.getStringArrayExtra(ARGS))
+ : ImmutableList.of();
+
+ try {
+ Futures.addCallback(
+ command.run(args),
+ new FutureCallback<String>() {
+ @Override
+ public void onSuccess(String response) {
+ if (TextUtils.isEmpty(response)) {
+ LogUtil.i(outputTag, "EMPTY");
+ } else {
+ LogUtil.i(outputTag, response);
+ }
+ }
+
+ @Override
+ public void onFailure(Throwable throwable) {
+ // LogUtil.e(tag, message, e) prints 2 entries where only the first one can be
+ // intercepted by the script. Compose the string instead.
+ LogUtil.e(outputTag, "error running command future", throwable);
+ }
+ },
+ MoreExecutors.directExecutor());
+ } catch (Throwable throwable) {
+ LogUtil.e(outputTag, "error running command", throwable);
+ }
+ }
+}