added a few TODOs in regards to the handling of inactive devices
This commit is contained in:
parent
04ac2264e8
commit
bfa63e13c5
|
@ -525,6 +525,7 @@ public class AxolotlService implements OnAdvancedStreamFeaturesLoaded {
|
||||||
if (packet.getType() == IqPacket.TYPE.TIMEOUT) {
|
if (packet.getType() == IqPacket.TYPE.TIMEOUT) {
|
||||||
Log.d(Config.LOGTAG, getLogprefix(account) + "Timeout received while retrieving own Device Ids.");
|
Log.d(Config.LOGTAG, getLogprefix(account) + "Timeout received while retrieving own Device Ids.");
|
||||||
} else {
|
} else {
|
||||||
|
//TODO consider calling registerDevices only after item-not-found to account for broken PEPs
|
||||||
Element item = mXmppConnectionService.getIqParser().getItem(packet);
|
Element item = mXmppConnectionService.getIqParser().getItem(packet);
|
||||||
Set<Integer> deviceIds = mXmppConnectionService.getIqParser().deviceIds(item);
|
Set<Integer> deviceIds = mXmppConnectionService.getIqParser().deviceIds(item);
|
||||||
Log.d(Config.LOGTAG, account.getJid().asBareJid() + ": retrieved own device list: " + deviceIds);
|
Log.d(Config.LOGTAG, account.getJid().asBareJid() + ": retrieved own device list: " + deviceIds);
|
||||||
|
@ -1162,8 +1163,8 @@ public class AxolotlService implements OnAdvancedStreamFeaturesLoaded {
|
||||||
Set<SignalProtocolAddress> addresses = new HashSet<>();
|
Set<SignalProtocolAddress> addresses = new HashSet<>();
|
||||||
for (Jid jid : getCryptoTargets(conversation)) {
|
for (Jid jid : getCryptoTargets(conversation)) {
|
||||||
Log.d(Config.LOGTAG, AxolotlService.getLogprefix(account) + "Finding devices without session for " + jid);
|
Log.d(Config.LOGTAG, AxolotlService.getLogprefix(account) + "Finding devices without session for " + jid);
|
||||||
Set<Integer> ids = deviceIds.get(jid);
|
final Set<Integer> ids = deviceIds.get(jid);
|
||||||
if (deviceIds.get(jid) != null && !ids.isEmpty()) {
|
if (ids != null && !ids.isEmpty()) {
|
||||||
for (Integer foreignId : ids) {
|
for (Integer foreignId : ids) {
|
||||||
SignalProtocolAddress address = new SignalProtocolAddress(jid.toString(), foreignId);
|
SignalProtocolAddress address = new SignalProtocolAddress(jid.toString(), foreignId);
|
||||||
if (sessions.get(address) == null) {
|
if (sessions.get(address) == null) {
|
||||||
|
|
|
@ -110,6 +110,7 @@ public class XmppAxolotlSession implements Comparable<XmppAxolotlSession> {
|
||||||
}
|
}
|
||||||
if (!status.isActive()) {
|
if (!status.isActive()) {
|
||||||
setTrust(status.toActive());
|
setTrust(status.toActive());
|
||||||
|
//TODO: also (re)add to device list?
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
throw new CryptoFailedException("not encrypting omemo message from fingerprint "+getFingerprint()+" because it was marked as compromised");
|
throw new CryptoFailedException("not encrypting omemo message from fingerprint "+getFingerprint()+" because it was marked as compromised");
|
||||||
|
|
|
@ -1076,7 +1076,7 @@ public class EditAccountActivity extends OmemoActivity implements OnAccountUpdat
|
||||||
hasKeys = true;
|
hasKeys = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (hasKeys && Config.supportOmemo()) {
|
if (hasKeys && Config.supportOmemo()) { //TODO: either the button should be visible if we print an active device or the device list should be fed with reactived devices
|
||||||
this.binding.otherDeviceKeysCard.setVisibility(View.VISIBLE);
|
this.binding.otherDeviceKeysCard.setVisibility(View.VISIBLE);
|
||||||
Set<Integer> otherDevices = mAccount.getAxolotlService().getOwnDeviceIds();
|
Set<Integer> otherDevices = mAccount.getAxolotlService().getOwnDeviceIds();
|
||||||
if (otherDevices == null || otherDevices.isEmpty()) {
|
if (otherDevices == null || otherDevices.isEmpty()) {
|
||||||
|
|
Loading…
Reference in a new issue