mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-11 19:03:39 +00:00
Share profile key when initiating a conversation
// FREEBIE
This commit is contained in:
parent
c11f2eddf5
commit
5942e93a33
@ -1594,6 +1594,7 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
boolean forceSms = sendButton.isManualSelection() && sendButton.getSelectedTransport().isSms();
|
boolean forceSms = sendButton.isManualSelection() && sendButton.getSelectedTransport().isSms();
|
||||||
int subscriptionId = sendButton.getSelectedTransport().getSimSubscriptionId().or(-1);
|
int subscriptionId = sendButton.getSelectedTransport().getSimSubscriptionId().or(-1);
|
||||||
long expiresIn = recipient.getExpireMessages() * 1000;
|
long expiresIn = recipient.getExpireMessages() * 1000;
|
||||||
|
boolean initiating = threadId == -1;
|
||||||
|
|
||||||
Log.w(TAG, "isManual Selection: " + sendButton.isManualSelection());
|
Log.w(TAG, "isManual Selection: " + sendButton.isManualSelection());
|
||||||
Log.w(TAG, "forceSms: " + forceSms);
|
Log.w(TAG, "forceSms: " + forceSms);
|
||||||
@ -1605,9 +1606,9 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
} else if (!forceSms && identityRecords.isUntrusted()) {
|
} else if (!forceSms && identityRecords.isUntrusted()) {
|
||||||
handleUntrustedRecipients();
|
handleUntrustedRecipients();
|
||||||
} else if (attachmentManager.isAttachmentPresent() || recipient.isGroupRecipient() || recipient.getAddress().isEmail()) {
|
} else if (attachmentManager.isAttachmentPresent() || recipient.isGroupRecipient() || recipient.getAddress().isEmail()) {
|
||||||
sendMediaMessage(forceSms, expiresIn, subscriptionId);
|
sendMediaMessage(forceSms, expiresIn, subscriptionId, initiating);
|
||||||
} else {
|
} else {
|
||||||
sendTextMessage(forceSms, expiresIn, subscriptionId);
|
sendTextMessage(forceSms, expiresIn, subscriptionId, initiating);
|
||||||
}
|
}
|
||||||
} catch (RecipientFormattingException ex) {
|
} catch (RecipientFormattingException ex) {
|
||||||
Toast.makeText(ConversationActivity.this,
|
Toast.makeText(ConversationActivity.this,
|
||||||
@ -1621,13 +1622,13 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void sendMediaMessage(final boolean forceSms, final long expiresIn, final int subscriptionId)
|
private void sendMediaMessage(final boolean forceSms, final long expiresIn, final int subscriptionId, boolean initiating)
|
||||||
throws InvalidMessageException
|
throws InvalidMessageException
|
||||||
{
|
{
|
||||||
sendMediaMessage(forceSms, getMessage(), attachmentManager.buildSlideDeck(), expiresIn, subscriptionId);
|
sendMediaMessage(forceSms, getMessage(), attachmentManager.buildSlideDeck(), expiresIn, subscriptionId, initiating);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ListenableFuture<Void> sendMediaMessage(final boolean forceSms, String body, SlideDeck slideDeck, final long expiresIn, final int subscriptionId)
|
private ListenableFuture<Void> sendMediaMessage(final boolean forceSms, String body, SlideDeck slideDeck, final long expiresIn, final int subscriptionId, final boolean initiating)
|
||||||
throws InvalidMessageException
|
throws InvalidMessageException
|
||||||
{
|
{
|
||||||
final SettableFuture<Void> future = new SettableFuture<>();
|
final SettableFuture<Void> future = new SettableFuture<>();
|
||||||
@ -1651,6 +1652,10 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
new AsyncTask<OutgoingMediaMessage, Void, Long>() {
|
new AsyncTask<OutgoingMediaMessage, Void, Long>() {
|
||||||
@Override
|
@Override
|
||||||
protected Long doInBackground(OutgoingMediaMessage... messages) {
|
protected Long doInBackground(OutgoingMediaMessage... messages) {
|
||||||
|
if (initiating) {
|
||||||
|
DatabaseFactory.getRecipientPreferenceDatabase(context).setProfileSharing(recipient.getAddress(), true);
|
||||||
|
}
|
||||||
|
|
||||||
return MessageSender.send(context, masterSecret, messages[0], threadId, forceSms, new SmsDatabase.InsertListener() {
|
return MessageSender.send(context, masterSecret, messages[0], threadId, forceSms, new SmsDatabase.InsertListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onComplete() {
|
public void onComplete() {
|
||||||
@ -1669,7 +1674,7 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
return future;
|
return future;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void sendTextMessage(final boolean forceSms, final long expiresIn, final int subscriptionId)
|
private void sendTextMessage(final boolean forceSms, final long expiresIn, final int subscriptionId, final boolean initiatingConversation)
|
||||||
throws InvalidMessageException
|
throws InvalidMessageException
|
||||||
{
|
{
|
||||||
final Context context = getApplicationContext();
|
final Context context = getApplicationContext();
|
||||||
@ -1687,6 +1692,10 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
new AsyncTask<OutgoingTextMessage, Void, Long>() {
|
new AsyncTask<OutgoingTextMessage, Void, Long>() {
|
||||||
@Override
|
@Override
|
||||||
protected Long doInBackground(OutgoingTextMessage... messages) {
|
protected Long doInBackground(OutgoingTextMessage... messages) {
|
||||||
|
if (initiatingConversation) {
|
||||||
|
DatabaseFactory.getRecipientPreferenceDatabase(context).setProfileSharing(recipient.getAddress(), true);
|
||||||
|
}
|
||||||
|
|
||||||
return MessageSender.send(context, masterSecret, messages[0], threadId, forceSms, new SmsDatabase.InsertListener() {
|
return MessageSender.send(context, masterSecret, messages[0], threadId, forceSms, new SmsDatabase.InsertListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onComplete() {
|
public void onComplete() {
|
||||||
@ -1780,11 +1789,12 @@ public class ConversationActivity extends PassphraseRequiredActionBarActivity
|
|||||||
boolean forceSms = sendButton.isManualSelection() && sendButton.getSelectedTransport().isSms();
|
boolean forceSms = sendButton.isManualSelection() && sendButton.getSelectedTransport().isSms();
|
||||||
int subscriptionId = sendButton.getSelectedTransport().getSimSubscriptionId().or(-1);
|
int subscriptionId = sendButton.getSelectedTransport().getSimSubscriptionId().or(-1);
|
||||||
long expiresIn = recipient.getExpireMessages() * 1000;
|
long expiresIn = recipient.getExpireMessages() * 1000;
|
||||||
|
boolean initiating = threadId == -1;
|
||||||
AudioSlide audioSlide = new AudioSlide(ConversationActivity.this, result.first, result.second, MediaUtil.AUDIO_AAC, true);
|
AudioSlide audioSlide = new AudioSlide(ConversationActivity.this, result.first, result.second, MediaUtil.AUDIO_AAC, true);
|
||||||
SlideDeck slideDeck = new SlideDeck();
|
SlideDeck slideDeck = new SlideDeck();
|
||||||
slideDeck.addSlide(audioSlide);
|
slideDeck.addSlide(audioSlide);
|
||||||
|
|
||||||
sendMediaMessage(forceSms, "", slideDeck, expiresIn, subscriptionId).addListener(new AssertedSuccessListener<Void>() {
|
sendMediaMessage(forceSms, "", slideDeck, expiresIn, subscriptionId, initiating).addListener(new AssertedSuccessListener<Void>() {
|
||||||
@Override
|
@Override
|
||||||
public void onSuccess(Void nothing) {
|
public void onSuccess(Void nothing) {
|
||||||
new AsyncTask<Void, Void, Void>() {
|
new AsyncTask<Void, Void, Void>() {
|
||||||
|
@ -104,7 +104,8 @@ public class DatabaseFactory {
|
|||||||
private static final int INTERNAL_DIRECTORY = 39;
|
private static final int INTERNAL_DIRECTORY = 39;
|
||||||
private static final int INTERNAL_SYSTEM_DISPLAY_NAME = 40;
|
private static final int INTERNAL_SYSTEM_DISPLAY_NAME = 40;
|
||||||
private static final int PROFILES = 41;
|
private static final int PROFILES = 41;
|
||||||
private static final int DATABASE_VERSION = 41;
|
private static final int PROFILE_SHARING_APPROVAL = 42;
|
||||||
|
private static final int DATABASE_VERSION = 42;
|
||||||
|
|
||||||
private static final String DATABASE_NAME = "messages.db";
|
private static final String DATABASE_NAME = "messages.db";
|
||||||
private static final Object lock = new Object();
|
private static final Object lock = new Object();
|
||||||
@ -1307,6 +1308,10 @@ public class DatabaseFactory {
|
|||||||
db.execSQL("ALTER TABLE recipient_preferences ADD COLUMN signal_profile_avatar TEXT DEFAULT NULL");
|
db.execSQL("ALTER TABLE recipient_preferences ADD COLUMN signal_profile_avatar TEXT DEFAULT NULL");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (oldVersion < PROFILE_SHARING_APPROVAL) {
|
||||||
|
db.execSQL("ALTER TABLE recipient_preferences ADD COLUMN profile_sharing_approval INTEGER DEFAULT 0");
|
||||||
|
}
|
||||||
|
|
||||||
db.setTransactionSuccessful();
|
db.setTransactionSuccessful();
|
||||||
db.endTransaction();
|
db.endTransaction();
|
||||||
}
|
}
|
||||||
|
@ -46,10 +46,11 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
private static final String SYSTEM_DISPLAY_NAME = "system_display_name";
|
private static final String SYSTEM_DISPLAY_NAME = "system_display_name";
|
||||||
private static final String SIGNAL_PROFILE_NAME = "signal_profile_name";
|
private static final String SIGNAL_PROFILE_NAME = "signal_profile_name";
|
||||||
private static final String SIGNAL_PROFILE_AVATAR = "signal_profile_avatar";
|
private static final String SIGNAL_PROFILE_AVATAR = "signal_profile_avatar";
|
||||||
|
private static final String PROFILE_SHARING = "profile_sharing_approval";
|
||||||
|
|
||||||
private static final String[] RECIPIENT_PROJECTION = new String[] {
|
private static final String[] RECIPIENT_PROJECTION = new String[] {
|
||||||
BLOCK, NOTIFICATION, VIBRATE, MUTE_UNTIL, COLOR, SEEN_INVITE_REMINDER, DEFAULT_SUBSCRIPTION_ID, EXPIRE_MESSAGES, REGISTERED,
|
BLOCK, NOTIFICATION, VIBRATE, MUTE_UNTIL, COLOR, SEEN_INVITE_REMINDER, DEFAULT_SUBSCRIPTION_ID, EXPIRE_MESSAGES, REGISTERED,
|
||||||
PROFILE_KEY, SYSTEM_DISPLAY_NAME, SIGNAL_PROFILE_NAME, SIGNAL_PROFILE_AVATAR
|
PROFILE_KEY, SYSTEM_DISPLAY_NAME, SIGNAL_PROFILE_NAME, SIGNAL_PROFILE_AVATAR, PROFILE_SHARING
|
||||||
};
|
};
|
||||||
|
|
||||||
static final List<String> TYPED_RECIPIENT_PROJECTION = Stream.of(RECIPIENT_PROJECTION)
|
static final List<String> TYPED_RECIPIENT_PROJECTION = Stream.of(RECIPIENT_PROJECTION)
|
||||||
@ -90,7 +91,8 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
SYSTEM_DISPLAY_NAME + " TEXT DEFAULT NULL, " +
|
SYSTEM_DISPLAY_NAME + " TEXT DEFAULT NULL, " +
|
||||||
PROFILE_KEY + " TEXT DEFAULT NULL, " +
|
PROFILE_KEY + " TEXT DEFAULT NULL, " +
|
||||||
SIGNAL_PROFILE_NAME + " TEXT DEFAULT NULL, " +
|
SIGNAL_PROFILE_NAME + " TEXT DEFAULT NULL, " +
|
||||||
SIGNAL_PROFILE_AVATAR + " TEXT DEFAULT NULL);";
|
SIGNAL_PROFILE_AVATAR + " TEXT DEFAULT NULL, " +
|
||||||
|
PROFILE_SHARING + " INTEGER DEFAULT 0);";
|
||||||
|
|
||||||
public RecipientPreferenceDatabase(Context context, SQLiteOpenHelper databaseHelper) {
|
public RecipientPreferenceDatabase(Context context, SQLiteOpenHelper databaseHelper) {
|
||||||
super(context, databaseHelper);
|
super(context, databaseHelper);
|
||||||
@ -143,6 +145,7 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
String systemDisplayName = cursor.getString(cursor.getColumnIndexOrThrow(SYSTEM_DISPLAY_NAME));
|
String systemDisplayName = cursor.getString(cursor.getColumnIndexOrThrow(SYSTEM_DISPLAY_NAME));
|
||||||
String signalProfileName = cursor.getString(cursor.getColumnIndexOrThrow(SIGNAL_PROFILE_NAME));
|
String signalProfileName = cursor.getString(cursor.getColumnIndexOrThrow(SIGNAL_PROFILE_NAME));
|
||||||
String signalProfileAvatar = cursor.getString(cursor.getColumnIndexOrThrow(SIGNAL_PROFILE_AVATAR));
|
String signalProfileAvatar = cursor.getString(cursor.getColumnIndexOrThrow(SIGNAL_PROFILE_AVATAR));
|
||||||
|
boolean profileSharing = cursor.getInt(cursor.getColumnIndexOrThrow(PROFILE_SHARING)) == 1;
|
||||||
|
|
||||||
MaterialColor color;
|
MaterialColor color;
|
||||||
byte[] profileKey = null;
|
byte[] profileKey = null;
|
||||||
@ -168,7 +171,7 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
notificationUri, color, seenInviteReminder,
|
notificationUri, color, seenInviteReminder,
|
||||||
defaultSubscriptionId, expireMessages, registered,
|
defaultSubscriptionId, expireMessages, registered,
|
||||||
profileKey, systemDisplayName, signalProfileName,
|
profileKey, systemDisplayName, signalProfileName,
|
||||||
signalProfileAvatar));
|
signalProfileAvatar, profileSharing));
|
||||||
}
|
}
|
||||||
|
|
||||||
public BulkOperationsHandle resetAllDisplayNames() {
|
public BulkOperationsHandle resetAllDisplayNames() {
|
||||||
@ -259,6 +262,12 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
updateOrInsert(address, contentValues);
|
updateOrInsert(address, contentValues);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setProfileSharing(@NonNull Address address, boolean enabled) {
|
||||||
|
ContentValues contentValues = new ContentValues(1);
|
||||||
|
contentValues.put(PROFILE_SHARING, enabled ? 1 : 0);
|
||||||
|
updateOrInsert(address, contentValues);
|
||||||
|
}
|
||||||
|
|
||||||
public Set<Address> getAllRecipients() {
|
public Set<Address> getAllRecipients() {
|
||||||
SQLiteDatabase db = databaseHelper.getReadableDatabase();
|
SQLiteDatabase db = databaseHelper.getReadableDatabase();
|
||||||
Set<Address> results = new HashSet<>();
|
Set<Address> results = new HashSet<>();
|
||||||
@ -366,6 +375,7 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
private final String systemDisplayName;
|
private final String systemDisplayName;
|
||||||
private final String signalProfileName;
|
private final String signalProfileName;
|
||||||
private final String signalProfileAvatar;
|
private final String signalProfileAvatar;
|
||||||
|
private final boolean profileSharing;
|
||||||
|
|
||||||
RecipientsPreferences(boolean blocked, long muteUntil,
|
RecipientsPreferences(boolean blocked, long muteUntil,
|
||||||
@NonNull VibrateState vibrateState,
|
@NonNull VibrateState vibrateState,
|
||||||
@ -378,7 +388,8 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
@Nullable byte[] profileKey,
|
@Nullable byte[] profileKey,
|
||||||
@Nullable String systemDisplayName,
|
@Nullable String systemDisplayName,
|
||||||
@Nullable String signalProfileName,
|
@Nullable String signalProfileName,
|
||||||
@Nullable String signalProfileAvatar)
|
@Nullable String signalProfileAvatar,
|
||||||
|
boolean profileSharing)
|
||||||
{
|
{
|
||||||
this.blocked = blocked;
|
this.blocked = blocked;
|
||||||
this.muteUntil = muteUntil;
|
this.muteUntil = muteUntil;
|
||||||
@ -393,6 +404,7 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
this.systemDisplayName = systemDisplayName;
|
this.systemDisplayName = systemDisplayName;
|
||||||
this.signalProfileName = signalProfileName;
|
this.signalProfileName = signalProfileName;
|
||||||
this.signalProfileAvatar = signalProfileAvatar;
|
this.signalProfileAvatar = signalProfileAvatar;
|
||||||
|
this.profileSharing = profileSharing;
|
||||||
}
|
}
|
||||||
|
|
||||||
public @Nullable MaterialColor getColor() {
|
public @Nullable MaterialColor getColor() {
|
||||||
@ -446,6 +458,10 @@ public class RecipientPreferenceDatabase extends Database {
|
|||||||
public @Nullable String getProfileAvatar() {
|
public @Nullable String getProfileAvatar() {
|
||||||
return signalProfileAvatar;
|
return signalProfileAvatar;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isProfileSharing() {
|
||||||
|
return profileSharing;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class BlockedReader {
|
public static class BlockedReader {
|
||||||
|
@ -55,6 +55,7 @@ public class GroupManager {
|
|||||||
|
|
||||||
if (!mms) {
|
if (!mms) {
|
||||||
groupDatabase.updateAvatar(groupId, avatarBytes);
|
groupDatabase.updateAvatar(groupId, avatarBytes);
|
||||||
|
DatabaseFactory.getRecipientPreferenceDatabase(context).setProfileSharing(Address.fromSerialized(groupId), true);
|
||||||
return sendGroupUpdate(context, masterSecret, groupId, memberAddresses, name, avatarBytes);
|
return sendGroupUpdate(context, masterSecret, groupId, memberAddresses, name, avatarBytes);
|
||||||
} else {
|
} else {
|
||||||
Recipient groupRecipient = RecipientFactory.getRecipientFor(context, Address.fromSerialized(groupId), true);
|
Recipient groupRecipient = RecipientFactory.getRecipientFor(context, Address.fromSerialized(groupId), true);
|
||||||
|
@ -70,18 +70,21 @@ public abstract class PushSendJob extends SendJob {
|
|||||||
Optional<RecipientsPreferences> recipientsPreferences = DatabaseFactory.getRecipientPreferenceDatabase(context)
|
Optional<RecipientsPreferences> recipientsPreferences = DatabaseFactory.getRecipientPreferenceDatabase(context)
|
||||||
.getRecipientsPreferences(address);
|
.getRecipientsPreferences(address);
|
||||||
|
|
||||||
if (recipientsPreferences.isPresent() && !TextUtils.isEmpty(recipientsPreferences.get().getSystemDisplayName())) {
|
if (!recipientsPreferences.isPresent()) return Optional.absent();
|
||||||
String profileKey = TextSecurePreferences.getProfileKey(context);
|
|
||||||
|
|
||||||
if (profileKey == null) {
|
boolean isSystemContact = !TextUtils.isEmpty(recipientsPreferences.get().getSystemDisplayName());
|
||||||
profileKey = Util.getSecret(32);
|
boolean isApproved = recipientsPreferences.get().isProfileSharing();
|
||||||
TextSecurePreferences.setProfileKey(context, profileKey);
|
|
||||||
}
|
|
||||||
|
|
||||||
return Optional.of(Base64.decode(profileKey));
|
if (!isSystemContact & !isApproved) return Optional.absent();
|
||||||
|
|
||||||
|
String profileKey = TextSecurePreferences.getProfileKey(context);
|
||||||
|
|
||||||
|
if (profileKey == null) {
|
||||||
|
profileKey = Util.getSecret(32);
|
||||||
|
TextSecurePreferences.setProfileKey(context, profileKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
return Optional.absent();
|
return Optional.of(Base64.decode(profileKey));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
throw new AssertionError(e);
|
throw new AssertionError(e);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user