From 3e3ae5f86586e50cf9d0df501401ef47c5d29a65 Mon Sep 17 00:00:00 2001 From: Moxie Marlinspike Date: Mon, 28 Aug 2017 17:57:07 -0700 Subject: [PATCH] Adjust profile key sharing based on sync messages // FREEBIE --- .../thoughtcrime/securesms/jobs/PushDecryptJob.java | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java b/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java index 389a526b2a..11166c6050 100644 --- a/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java +++ b/src/org/thoughtcrime/securesms/jobs/PushDecryptJob.java @@ -429,6 +429,18 @@ public class PushDecryptJob extends ContextJob { handleUnknownGroupMessage(envelope, message.getMessage().getGroupInfo().get()); } + if (message.getMessage().getProfileKey().isPresent()) { + Recipient recipient = null; + + if (message.getDestination().isPresent()) recipient = Recipient.from(context, Address.fromExternal(context, message.getDestination().get()), false); + else if (message.getMessage().getGroupInfo().isPresent()) recipient = Recipient.from(context, Address.fromSerialized(GroupUtil.getEncodedId(message.getMessage().getGroupInfo().get().getGroupId(), false)), false); + + + if (recipient != null && !recipient.isSystemContact() && !recipient.isProfileSharing()) { + DatabaseFactory.getRecipientDatabase(context).setProfileSharing(recipient, true); + } + } + if (threadId != null) { DatabaseFactory.getThreadDatabase(getContext()).setRead(threadId, true); MessageNotifier.updateNotification(getContext(), masterSecret.getMasterSecret().orNull());