1 package org
.asamk
.signal
.commands
;
3 import net
.sourceforge
.argparse4j
.impl
.Arguments
;
4 import net
.sourceforge
.argparse4j
.inf
.Namespace
;
5 import net
.sourceforge
.argparse4j
.inf
.Subparser
;
7 import org
.asamk
.signal
.OutputWriter
;
8 import org
.asamk
.signal
.commands
.exceptions
.CommandException
;
9 import org
.asamk
.signal
.commands
.exceptions
.IOErrorException
;
10 import org
.asamk
.signal
.manager
.Manager
;
11 import org
.whispersystems
.libsignal
.util
.guava
.Optional
;
14 import java
.io
.IOException
;
16 public class UpdateProfileCommand
implements JsonRpcLocalCommand
{
19 public String
getName() {
20 return "updateProfile";
24 public void attachToSubparser(final Subparser subparser
) {
25 subparser
.help("Set a name, about and avatar image for the user profile");
26 subparser
.addArgument("--given-name", "--name").help("New profile (given) name");
27 subparser
.addArgument("--family-name").help("New profile family name (optional)");
28 subparser
.addArgument("--about").help("New profile about text");
29 subparser
.addArgument("--about-emoji").help("New profile about emoji");
31 final var avatarOptions
= subparser
.addMutuallyExclusiveGroup();
32 avatarOptions
.addArgument("--avatar").help("Path to new profile avatar");
33 avatarOptions
.addArgument("--remove-avatar").action(Arguments
.storeTrue());
37 public void handleCommand(
38 final Namespace ns
, final Manager m
, final OutputWriter outputWriter
39 ) throws CommandException
{
40 var givenName
= ns
.getString("given-name");
41 var familyName
= ns
.getString("family-name");
42 var about
= ns
.getString("about");
43 var aboutEmoji
= ns
.getString("about-emoji");
44 var avatarPath
= ns
.getString("avatar");
45 boolean removeAvatar
= ns
.getBoolean("remove-avatar");
47 Optional
<File
> avatarFile
= removeAvatar
49 : avatarPath
== null ?
null : Optional
.of(new File(avatarPath
));
52 m
.setProfile(givenName
, familyName
, about
, aboutEmoji
, avatarFile
);
53 } catch (IOException e
) {
54 throw new IOErrorException("Update profile error: " + e
.getMessage(), e
);