]> nmode's Git Repositories - signal-cli/commitdiff
Correctly send to multiple recipients
authorAsamK <asamk@gmx.de>
Tue, 7 Jul 2015 10:07:01 +0000 (12:07 +0200)
committerAsamK <asamk@gmx.de>
Tue, 7 Jul 2015 10:07:01 +0000 (12:07 +0200)
src/main/java/cli/Main.java

index adeb5262588295bfdf3ece96b7c3aa95c8479ff4..35b7c254cc5f58aa5b2a826dda00fe3a6b44a86a 100644 (file)
@@ -21,9 +21,10 @@ import net.sourceforge.argparse4j.impl.Arguments;
 import net.sourceforge.argparse4j.inf.*;
 import org.apache.commons.io.IOUtils;
 import org.whispersystems.textsecure.api.TextSecureMessageSender;
-import org.whispersystems.textsecure.api.crypto.UntrustedIdentityException;
 import org.whispersystems.textsecure.api.messages.*;
 import org.whispersystems.textsecure.api.messages.multidevice.TextSecureSyncMessage;
+import org.whispersystems.textsecure.api.push.TextSecureAddress;
+import org.whispersystems.textsecure.api.push.exceptions.EncapsulatedExceptions;
 import org.whispersystems.textsecure.api.util.InvalidNumberException;
 
 import java.io.File;
@@ -150,13 +151,20 @@ public class Main {
                     messageBuilder.withAttachments(textSecureAttachments);
                 }
                 TextSecureDataMessage message = messageBuilder.build();
+
+                List<TextSecureAddress> recipients = new ArrayList<>(ns.<String>getList("recipient").size());
                 for (String recipient : ns.<String>getList("recipient")) {
                     try {
-                        messageSender.sendMessage(m.getPushAddress(recipient), message);
-                    } catch (UntrustedIdentityException | IOException | InvalidNumberException e) {
-                        System.out.println("Failed to send message  to \"" + recipient + "\": " + e.getMessage());
+                        recipients.add(m.getPushAddress(recipient));
+                    } catch (InvalidNumberException e) {
+                        System.out.println("Failed to send message to \"" + recipient + "\": " + e.getMessage());
                     }
                 }
+                try {
+                    messageSender.sendMessage(recipients, message);
+                } catch (IOException | EncapsulatedExceptions e) {
+                    System.out.println("Failed to send message: " + e.getMessage());
+                }
                 break;
             case "receive":
                 if (!m.isRegistered()) {