summaryrefslogtreecommitdiff
path: root/java/com/android/dialer/commandline
diff options
context:
space:
mode:
authortwyen <twyen@google.com>2018-03-19 18:12:47 -0700
committerCopybara-Service <copybara-piper@google.com>2018-03-19 19:06:18 -0700
commit9239dd2e7e62c15002860f90730d3cc63deae179 (patch)
tree56f18a640411600b2badf9cb4f4007d6f4259c48 /java/com/android/dialer/commandline
parent356db9a88f70435150aa58a33c94d08ae44bc22e (diff)
Implement call command
NUI dialpad is still broken. Test: Unit tests PiperOrigin-RevId: 189674304 Change-Id: I58d114ed45839f8ff85a3a0e48c3d200337915c9
Diffstat (limited to 'java/com/android/dialer/commandline')
-rw-r--r--java/com/android/dialer/commandline/CommandLineModule.java7
-rw-r--r--java/com/android/dialer/commandline/impl/CallCommand.java83
2 files changed, 89 insertions, 1 deletions
diff --git a/java/com/android/dialer/commandline/CommandLineModule.java b/java/com/android/dialer/commandline/CommandLineModule.java
index 9022d6cd5..612155662 100644
--- a/java/com/android/dialer/commandline/CommandLineModule.java
+++ b/java/com/android/dialer/commandline/CommandLineModule.java
@@ -17,6 +17,7 @@
package com.android.dialer.commandline;
import com.android.dialer.commandline.impl.Blocking;
+import com.android.dialer.commandline.impl.CallCommand;
import com.android.dialer.commandline.impl.Echo;
import com.android.dialer.commandline.impl.Help;
import com.android.dialer.commandline.impl.Version;
@@ -43,13 +44,16 @@ public abstract class CommandLineModule {
private final Version version;
private final Echo echo;
private final Blocking blocking;
+ private final CallCommand callCommand;
@Inject
- AospCommandInjector(Help help, Version version, Echo echo, Blocking blocking) {
+ AospCommandInjector(
+ Help help, Version version, Echo echo, Blocking blocking, CallCommand callCommand) {
this.help = help;
this.version = version;
this.echo = echo;
this.blocking = blocking;
+ this.callCommand = callCommand;
}
public CommandSupplier.Builder inject(CommandSupplier.Builder builder) {
@@ -57,6 +61,7 @@ public abstract class CommandLineModule {
builder.addCommand("version", version);
builder.addCommand("echo", echo);
builder.addCommand("blocking", blocking);
+ builder.addCommand("call", callCommand);
return builder;
}
}
diff --git a/java/com/android/dialer/commandline/impl/CallCommand.java b/java/com/android/dialer/commandline/impl/CallCommand.java
new file mode 100644
index 000000000..a6d78f4de
--- /dev/null
+++ b/java/com/android/dialer/commandline/impl/CallCommand.java
@@ -0,0 +1,83 @@
+/*
+ * 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.impl;
+
+import android.content.Context;
+import android.content.Intent;
+import android.support.annotation.NonNull;
+import android.telecom.PhoneAccount;
+import android.telecom.PhoneAccountHandle;
+import android.telecom.TelecomManager;
+import com.android.dialer.buildtype.BuildType;
+import com.android.dialer.buildtype.BuildType.Type;
+import com.android.dialer.callintent.CallInitiationType;
+import com.android.dialer.callintent.CallIntentBuilder;
+import com.android.dialer.commandline.Arguments;
+import com.android.dialer.commandline.Command;
+import com.android.dialer.inject.ApplicationContext;
+import com.android.dialer.precall.PreCall;
+import com.google.common.util.concurrent.Futures;
+import com.google.common.util.concurrent.ListenableFuture;
+import javax.inject.Inject;
+
+/** Make calls. Requires bugfood build. */
+public class CallCommand implements Command {
+
+ private final Context appContext;
+
+ @Inject
+ CallCommand(@ApplicationContext Context appContext) {
+ this.appContext = appContext;
+ }
+
+ @NonNull
+ @Override
+ public String getShortDescription() {
+ return "make a call";
+ }
+
+ @NonNull
+ @Override
+ public String getUsage() {
+ return "call number\n\nuse 'voicemail' to call voicemail";
+ }
+
+ @Override
+ @SuppressWarnings("missingPermission")
+ public ListenableFuture<String> run(Arguments args) throws IllegalCommandLineArgumentException {
+ if (BuildType.get() != Type.BUGFOOD) {
+ throw new SecurityException("Bugfood only command");
+ }
+ String number = args.expectPositional(0, "number");
+ TelecomManager telecomManager = appContext.getSystemService(TelecomManager.class);
+ PhoneAccountHandle phoneAccountHandle =
+ telecomManager.getDefaultOutgoingPhoneAccount(PhoneAccount.SCHEME_TEL);
+ CallIntentBuilder callIntentBuilder;
+ if ("voicemail".equals(number)) {
+ callIntentBuilder =
+ CallIntentBuilder.forVoicemail(phoneAccountHandle, CallInitiationType.Type.DIALPAD);
+ } else {
+ callIntentBuilder = new CallIntentBuilder(number, CallInitiationType.Type.DIALPAD);
+ }
+
+ Intent intent = PreCall.getIntent(appContext, callIntentBuilder);
+ intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
+ appContext.startActivity(intent);
+
+ return Futures.immediateFuture("Calling " + number);
+ }
+}