aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/pixart/messenger/entities/MucOptions.java
diff options
context:
space:
mode:
authorChristian Schneppe <christian@pix-art.de>2019-01-25 23:35:21 +0100
committerChristian Schneppe <christian@pix-art.de>2019-01-25 23:35:21 +0100
commitdf61e140b689b4455ac5461b68291f8507735330 (patch)
tree5a65d5e8c018ed014bfaf19950708a8a9d4d838d /src/main/java/de/pixart/messenger/entities/MucOptions.java
parent1aa574b7db21a54c12dba981eb4fb98e84f31c72 (diff)
normalize nicks before getting them from bookmarks or pep
Diffstat (limited to 'src/main/java/de/pixart/messenger/entities/MucOptions.java')
-rw-r--r--src/main/java/de/pixart/messenger/entities/MucOptions.java29
1 files changed, 21 insertions, 8 deletions
diff --git a/src/main/java/de/pixart/messenger/entities/MucOptions.java b/src/main/java/de/pixart/messenger/entities/MucOptions.java
index 6954995d9..01daad1bf 100644
--- a/src/main/java/de/pixart/messenger/entities/MucOptions.java
+++ b/src/main/java/de/pixart/messenger/entities/MucOptions.java
@@ -101,8 +101,9 @@ public class MucOptions {
return tookProposedNickFromBookmark;
}
- void notifyOfBookmarkNick(String nick) {
- if (nick != null && nick.trim().equals(getSelf().getFullJid().getResource())) {
+ void notifyOfBookmarkNick(final String nick) {
+ final String normalized = normalize(account.getJid(),nick);
+ if (normalized != null && normalized.equals(getSelf().getFullJid().getResource())) {
this.tookProposedNickFromBookmark = true;
}
}
@@ -388,15 +389,15 @@ public class MucOptions {
private String getProposedNick() {
final Bookmark bookmark = this.conversation.getBookmark();
- final String bookmarkedNick = bookmark == null ? null : bookmark.getNick();
- if (bookmarkedNick != null && !bookmarkedNick.trim().isEmpty()) {
+ final String bookmarkedNick = normalize(account.getJid(), bookmark == null ? null : bookmark.getNick());
+ if (bookmarkedNick != null) {
this.tookProposedNickFromBookmark = true;
- return bookmarkedNick.trim();
+ return bookmarkedNick;
} else if (!conversation.getJid().isBareJid()) {
return conversation.getJid().getResource();
} else {
- final String displayName = account.getDisplayName();
- if (TextUtils.isEmpty(displayName)) {
+ final String displayName = normalize(account.getJid(), account.getDisplayName());
+ if (displayName == null) {
return JidHelper.localPartOrFallback(account.getJid());
} else {
return displayName;
@@ -404,6 +405,18 @@ public class MucOptions {
}
}
+ private static String normalize(Jid account, String nick) {
+ if (account == null || TextUtils.isEmpty(nick)) {
+ return null;
+ }
+ try {
+ return account.withResource(nick).getResource();
+ } catch (IllegalArgumentException e) {
+ return null;
+ }
+
+ }
+
public String getActualNick() {
if (this.self.getName() != null) {
return this.self.getName();
@@ -531,7 +544,7 @@ public class MucOptions {
public Jid createJoinJid(String nick) {
try {
- return Jid.of(this.conversation.getJid().asBareJid().toString() + "/" + nick);
+ return conversation.getJid().withResource(nick);
} catch (final IllegalArgumentException e) {
return null;
}