support location attribute on enable

(cherry picked from commit f7b5124fd3e47d6a95b6f094e34adccf9b42a107)
This commit is contained in:
Daniel Gultsch 2023-12-01 18:29:52 +01:00 committed by 12aw
parent c5cb8245e8
commit 7f997cbaa7

View file

@ -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;