/* * 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 args = intent.hasExtra(ARGS) ? ImmutableList.copyOf(intent.getStringArrayExtra(ARGS)) : ImmutableList.of(); try { Futures.addCallback( command.run(args), new FutureCallback() { @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); } } }