package org.asamk.signal.manager.api;
-import org.asamk.signal.manager.groups.GroupId;
-import org.asamk.signal.manager.storage.recipients.RecipientAddress;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.whispersystems.signalservice.api.util.PhoneNumberFormatter;
record NoteToSelf() implements RecipientIdentifier {
- public static NoteToSelf INSTANCE = new NoteToSelf();
+ public static final NoteToSelf INSTANCE = new NoteToSelf();
@Override
public String getIdentifier() {
return new Uuid(UUID.fromString(identifier));
}
+ if (identifier.startsWith("PNI:")) {
+ final var pni = identifier.substring(4);
+ if (!UuidUtil.isUuid(pni)) {
+ throw new InvalidNumberException("Invalid PNI");
+ }
+ return new Pni(UUID.fromString(pni));
+ }
+
+ if (identifier.startsWith("u:")) {
+ return new Username(identifier.substring(2));
+ }
+
final var normalizedNumber = PhoneNumberFormatter.formatNumber(identifier, localNumber);
if (!normalizedNumber.equals(identifier)) {
final Logger logger = LoggerFactory.getLogger(RecipientIdentifier.class);
static Single fromAddress(RecipientAddress address) {
if (address.number().isPresent()) {
return new Number(address.number().get());
- } else if (address.uuid().isPresent()) {
- return new Uuid(address.uuid().get());
+ } else if (address.aci().isPresent()) {
+ return new Uuid(UUID.fromString(address.aci().get()));
+ } else if (address.pni().isPresent()) {
+ return new Pni(UUID.fromString(address.pni().get().substring(4)));
+ } else if (address.username().isPresent()) {
+ return new Username(address.username().get());
}
throw new AssertionError("RecipientAddress without identifier");
}
}
}
+ record Pni(UUID pni) implements Single {
+
+ @Override
+ public String getIdentifier() {
+ return "PNI:" + pni.toString();
+ }
+
+ @Override
+ public RecipientAddress toPartialRecipientAddress() {
+ return new RecipientAddress(null, getIdentifier(), null, null);
+ }
+ }
+
record Number(String number) implements Single {
@Override
@Override
public RecipientAddress toPartialRecipientAddress() {
- return new RecipientAddress(null, number);
+ return new RecipientAddress(number);
+ }
+ }
+
+ record Username(String username) implements Single {
+
+ @Override
+ public String getIdentifier() {
+ return "u:" + username;
+ }
+
+ @Override
+ public RecipientAddress toPartialRecipientAddress() {
+ return new RecipientAddress(null, null, null, username);
}
}