mirror of
https://codeberg.org/monocles/monocles_chat.git
synced 2025-01-15 22:22:22 +01:00
support location attribute on enable
(cherry picked from commit f7b5124fd3e47d6a95b6f094e34adccf9b42a107)
This commit is contained in:
parent
c5cb8245e8
commit
7f997cbaa7
1 changed files with 46 additions and 11 deletions
|
@ -17,6 +17,7 @@ import androidx.annotation.NonNull;
|
|||
import androidx.annotation.Nullable;
|
||||
import androidx.core.util.Consumer;
|
||||
|
||||
import com.google.common.base.MoreObjects;
|
||||
import com.google.common.base.Optional;
|
||||
import com.google.common.base.Preconditions;
|
||||
import com.google.common.base.Strings;
|
||||
|
@ -183,7 +184,7 @@ public class XmppConnection implements Runnable {
|
|||
private boolean isBound = false;
|
||||
private Element streamFeatures;
|
||||
private Element boundStreamFeatures;
|
||||
private String streamId = null;
|
||||
private StreamId streamId = null;
|
||||
private int stanzasReceived = 0;
|
||||
private int stanzasSent = 0;
|
||||
private int stanzasSentBeforeAuthentication;
|
||||
|
@ -459,6 +460,12 @@ public class XmppConnection implements Runnable {
|
|||
+ storedBackupResult);
|
||||
}
|
||||
}
|
||||
final StreamId streamId = this.streamId;
|
||||
final Resolver.Result resumeLocation = streamId == null ? null : streamId.location;
|
||||
if (resumeLocation != null) {
|
||||
Log.d(Config.LOGTAG,account.getJid().asBareJid()+": injected resume location on position 0");
|
||||
results.add(0, resumeLocation);
|
||||
}
|
||||
final Resolver.Result seeOtherHost = this.seeOtherHostResolverResult;
|
||||
if (seeOtherHost != null) {
|
||||
Log.d(Config.LOGTAG,account.getJid().asBareJid()+": injected see-other-host on position 0");
|
||||
|
@ -1082,18 +1089,27 @@ public class XmppConnection implements Runnable {
|
|||
}
|
||||
|
||||
private void processEnabled(final Element enabled) {
|
||||
final String streamId;
|
||||
final String id;
|
||||
if (enabled.getAttributeAsBoolean("resume")) {
|
||||
streamId = enabled.getAttribute("id");
|
||||
Log.d(
|
||||
Config.LOGTAG,
|
||||
account.getJid().asBareJid().toString()
|
||||
+ ": stream management enabled (resumable)");
|
||||
id = enabled.getAttribute("id");
|
||||
} else {
|
||||
id = null;
|
||||
}
|
||||
final String locationAttribute = enabled.getAttribute("location");
|
||||
final Resolver.Result currentResolverResult = this.currentResolverResult;
|
||||
final Resolver.Result location;
|
||||
if (Strings.isNullOrEmpty(locationAttribute) || currentResolverResult == null) {
|
||||
location = null;
|
||||
} else {
|
||||
location = currentResolverResult.seeOtherHost(locationAttribute);
|
||||
}
|
||||
final StreamId streamId = id == null ? null : new StreamId(id, location);
|
||||
if (streamId == null) {
|
||||
Log.d(Config.LOGTAG, account.getJid().asBareJid() + ": stream management enabled");
|
||||
} else {
|
||||
Log.d(
|
||||
Config.LOGTAG,
|
||||
account.getJid().asBareJid().toString() + ": stream management enabled");
|
||||
streamId = null;
|
||||
account.getJid().asBareJid() + ": stream management enabled. resume at: " + streamId.location);
|
||||
}
|
||||
this.streamId = streamId;
|
||||
this.stanzasReceived = 0;
|
||||
|
@ -1529,7 +1545,7 @@ public class XmppConnection implements Runnable {
|
|||
+ ": resuming after stanza #"
|
||||
+ stanzasReceived);
|
||||
}
|
||||
final ResumePacket resume = new ResumePacket(this.streamId, stanzasReceived);
|
||||
final ResumePacket resume = new ResumePacket(this.streamId.id, stanzasReceived);
|
||||
this.mSmCatchupMessageCounter.set(0);
|
||||
this.mWaitingForSmCatchup.set(true);
|
||||
this.tagWriter.writeStanzaAsync(resume);
|
||||
|
@ -1711,7 +1727,7 @@ public class XmppConnection implements Runnable {
|
|||
authenticate.addChild(generateBindRequest(bind));
|
||||
}
|
||||
if (inlineStreamManagement && streamId != null) {
|
||||
final ResumePacket resume = new ResumePacket(this.streamId, stanzasReceived);
|
||||
final ResumePacket resume = new ResumePacket(this.streamId.id, stanzasReceived);
|
||||
this.mSmCatchupMessageCounter.set(0);
|
||||
this.mWaitingForSmCatchup.set(true);
|
||||
authenticate.addChild(resume);
|
||||
|
@ -2909,6 +2925,25 @@ public class XmppConnection implements Runnable {
|
|||
}
|
||||
}
|
||||
|
||||
private static class StreamId {
|
||||
public final String id;
|
||||
public final Resolver.Result location;
|
||||
|
||||
private StreamId(String id, Resolver.Result location) {
|
||||
this.id = id;
|
||||
this.location = location;
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public String toString() {
|
||||
return MoreObjects.toStringHelper(this)
|
||||
.add("id", id)
|
||||
.add("location", location)
|
||||
.toString();
|
||||
}
|
||||
}
|
||||
|
||||
private static class StateChangingError extends Error {
|
||||
private final Account.State state;
|
||||
|
||||
|
|
Loading…
Reference in a new issue