better muc invitations. clearified the creation of ad hoc mucs with an alert dialog
This commit is contained in:
		
							parent
							
								
									841c6e04a9
								
							
						
					
					
						commit
						8cd59bb944
					
				|  | @ -62,8 +62,8 @@ | ||||||
|             android:windowSoftInputMode="stateHidden" > |             android:windowSoftInputMode="stateHidden" > | ||||||
|         </activity> |         </activity> | ||||||
|         <activity |         <activity | ||||||
|             android:name="eu.siacs.conversations.ui.NewConversationActivity" |             android:name="eu.siacs.conversations.ui.ContactsActivity" | ||||||
|             android:label="@string/title_activity_new_conversation" |             android:label="@string/title_activity_contacts" | ||||||
|             android:parentActivityName="eu.siacs.conversations.ui.ConversationActivity" |             android:parentActivityName="eu.siacs.conversations.ui.ConversationActivity" | ||||||
|             android:windowSoftInputMode="stateHidden" > |             android:windowSoftInputMode="stateHidden" > | ||||||
|             <meta-data |             <meta-data | ||||||
|  |  | ||||||
|  | @ -26,6 +26,10 @@ | ||||||
|         android:showAsAction="ifRoom" |         android:showAsAction="ifRoom" | ||||||
|         android:icon="@drawable/ic_action_group" |         android:icon="@drawable/ic_action_group" | ||||||
|         android:title="@string/action_muc_details" /> |         android:title="@string/action_muc_details" /> | ||||||
|  |        <item | ||||||
|  |         android:id="@+id/action_invite" | ||||||
|  |         android:showAsAction="never" | ||||||
|  |         android:title="@string/invite_contacts" /> | ||||||
|      |      | ||||||
|     <item |     <item | ||||||
|         android:id="@+id/action_archive" |         android:id="@+id/action_archive" | ||||||
|  |  | ||||||
|  | @ -15,4 +15,8 @@ | ||||||
|         android:id="@+id/action_invite" |         android:id="@+id/action_invite" | ||||||
|         android:showAsAction="ifRoom" |         android:showAsAction="ifRoom" | ||||||
|         android:title="@string/invite_contacts" /> |         android:title="@string/invite_contacts" /> | ||||||
|  |   <item | ||||||
|  |         android:id="@+id/action_invite_to_existing" | ||||||
|  |         android:showAsAction="never" | ||||||
|  |         android:title="@string/invite_contacts_to_existing" /> | ||||||
| </menu> | </menu> | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ | ||||||
|     <string name="action_muc_details">Conferenece details</string> |     <string name="action_muc_details">Conferenece details</string> | ||||||
|     <string name="action_secure">Secure conversation</string> |     <string name="action_secure">Secure conversation</string> | ||||||
|     <string name="action_add_account">Add account</string> |     <string name="action_add_account">Add account</string> | ||||||
|     <string name="title_activity_new_conversation">New Conversation</string> |     <string name="title_activity_contacts">Contacts</string> | ||||||
|     <string name="just_now">just now</string> |     <string name="just_now">just now</string> | ||||||
|     <string name="sending">sending…</string> |     <string name="sending">sending…</string> | ||||||
|     <string name="announce_pgp">Renew PGP announcement</string> |     <string name="announce_pgp">Renew PGP announcement</string> | ||||||
|  | @ -31,4 +31,13 @@ | ||||||
|     <string name="no_otr_fingerprint">No OTR Fingerprint generated. Just go ahead an start an encrypted conversation</string> |     <string name="no_otr_fingerprint">No OTR Fingerprint generated. Just go ahead an start an encrypted conversation</string> | ||||||
|     <string name="start_conversation">Start Conversation</string> |     <string name="start_conversation">Start Conversation</string> | ||||||
|     <string name="invite_contacts">Invite Contacts</string> |     <string name="invite_contacts">Invite Contacts</string> | ||||||
|  |     <string name="invite_contacts_to_existing">Invite to existing conference</string> | ||||||
|  |     <string name="new_conference">Create new conference</string> | ||||||
|  |     <string name="cancel">Cancel</string> | ||||||
|  |     <string name="create_invite">Create \u0026 Invite</string> | ||||||
|  |     <string name="new_conference_explained">Do you want to create a new conference with a randomly generated address and invite the selected contacts to it?</string> | ||||||
|  |     <string name="no_open_mucs">No existing conferences</string> | ||||||
|  |     <string name="invitation_sent">Invitation sent</string> | ||||||
|  |     <string name="account_offline">Account offline</string> | ||||||
|  |     <string name="cant_invite_while_offline">You have to be online to invite people to conferences</string> | ||||||
| </resources> | </resources> | ||||||
|  |  | ||||||
|  | @ -72,7 +72,7 @@ public class XmppConnectionService extends Service { | ||||||
| 
 | 
 | ||||||
| 	private static final int PING_MAX_INTERVAL = 300; | 	private static final int PING_MAX_INTERVAL = 300; | ||||||
| 	private static final int PING_MIN_INTERVAL = 10; | 	private static final int PING_MIN_INTERVAL = 10; | ||||||
| 	private static final int PING_TIMEOUT = 2; | 	private static final int PING_TIMEOUT = 5; | ||||||
| 	private static final int CONNECT_TIMEOUT = 60; | 	private static final int CONNECT_TIMEOUT = 60; | ||||||
| 
 | 
 | ||||||
| 	private List<Account> accounts; | 	private List<Account> accounts; | ||||||
|  | @ -160,7 +160,7 @@ public class XmppConnectionService extends Service { | ||||||
| 					} | 					} | ||||||
| 					 | 					 | ||||||
| 				} else { | 				} else { | ||||||
| 					Log.d(LOGTAG, "unparsed message " + packet.toString()); | 					//Log.d(LOGTAG, "unparsed message " + packet.toString()); | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 			if ((message == null)||(message.getBody() == null)) { | 			if ((message == null)||(message.getBody() == null)) { | ||||||
|  | @ -199,19 +199,6 @@ public class XmppConnectionService extends Service { | ||||||
| 				accountChangedListener.onAccountListChangedListener(); | 				accountChangedListener.onAccountListChangedListener(); | ||||||
| 			} | 			} | ||||||
| 			if (account.getStatus() == Account.STATUS_ONLINE) { | 			if (account.getStatus() == Account.STATUS_ONLINE) { | ||||||
| 				if (account.getXmppConnection().hasFeatureRosterManagment()) { |  | ||||||
| 					updateRoster(account, null); |  | ||||||
| 				} |  | ||||||
| 				connectMultiModeConversations(account); |  | ||||||
| 				List<Conversation> conversations = getConversations(); |  | ||||||
| 				for (int i = 0; i < conversations.size(); ++i) { |  | ||||||
| 					if (conversations.get(i).getAccount() == account) { |  | ||||||
| 						sendUnsendMessages(conversations.get(i)); |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 				if (convChangedListener != null) { |  | ||||||
| 					convChangedListener.onConversationListChanged(); |  | ||||||
| 				} |  | ||||||
| 				scheduleWakeupCall(PING_MAX_INTERVAL, true); | 				scheduleWakeupCall(PING_MAX_INTERVAL, true); | ||||||
| 			} else if (account.getStatus() == Account.STATUS_OFFLINE) { | 			} else if (account.getStatus() == Account.STATUS_OFFLINE) { | ||||||
| 				if (!account.isOptionSet(Account.OPTION_DISABLED)) { | 				if (!account.isOptionSet(Account.OPTION_DISABLED)) { | ||||||
|  | @ -558,6 +545,19 @@ public class XmppConnectionService extends Service { | ||||||
| 			@Override | 			@Override | ||||||
| 			public void onBind(Account account) { | 			public void onBind(Account account) { | ||||||
| 				databaseBackend.clearPresences(account); | 				databaseBackend.clearPresences(account); | ||||||
|  | 				if (account.getXmppConnection().hasFeatureRosterManagment()) { | ||||||
|  | 					updateRoster(account, null); | ||||||
|  | 				} | ||||||
|  | 				connectMultiModeConversations(account); | ||||||
|  | 				List<Conversation> conversations = getConversations(); | ||||||
|  | 				for (int i = 0; i < conversations.size(); ++i) { | ||||||
|  | 					if (conversations.get(i).getAccount() == account) { | ||||||
|  | 						sendUnsendMessages(conversations.get(i)); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 				if (convChangedListener != null) { | ||||||
|  | 					convChangedListener.onConversationListChanged(); | ||||||
|  | 				} | ||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
| 		return connection; | 		return connection; | ||||||
|  |  | ||||||
|  | @ -1,9 +1,7 @@ | ||||||
| package eu.siacs.conversations.ui; | package eu.siacs.conversations.ui; | ||||||
| 
 | 
 | ||||||
| import java.io.UnsupportedEncodingException; | import java.io.UnsupportedEncodingException; | ||||||
| import java.math.BigInteger; |  | ||||||
| import java.net.URLDecoder; | import java.net.URLDecoder; | ||||||
| import java.security.SecureRandom; |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.Comparator; | import java.util.Comparator; | ||||||
|  | @ -13,9 +11,11 @@ import eu.siacs.conversations.R; | ||||||
| import eu.siacs.conversations.entities.Account; | import eu.siacs.conversations.entities.Account; | ||||||
| import eu.siacs.conversations.entities.Contact; | import eu.siacs.conversations.entities.Contact; | ||||||
| import eu.siacs.conversations.entities.Conversation; | import eu.siacs.conversations.entities.Conversation; | ||||||
|  | import eu.siacs.conversations.utils.CryptoHelper; | ||||||
| import eu.siacs.conversations.utils.UIHelper; | import eu.siacs.conversations.utils.UIHelper; | ||||||
| import eu.siacs.conversations.utils.Validator; | import eu.siacs.conversations.utils.Validator; | ||||||
| import android.os.Bundle; | import android.os.Bundle; | ||||||
|  | import android.preference.PreferenceManager; | ||||||
| import android.text.Editable; | import android.text.Editable; | ||||||
| import android.text.TextWatcher; | import android.text.TextWatcher; | ||||||
| import android.util.Log; | import android.util.Log; | ||||||
|  | @ -37,14 +37,17 @@ import android.widget.ListView; | ||||||
| import android.widget.ProgressBar; | import android.widget.ProgressBar; | ||||||
| import android.widget.TextView; | import android.widget.TextView; | ||||||
| import android.widget.ImageView; | import android.widget.ImageView; | ||||||
|  | import android.widget.Toast; | ||||||
| import android.annotation.SuppressLint; | import android.annotation.SuppressLint; | ||||||
| import android.app.AlertDialog; | import android.app.AlertDialog; | ||||||
|  | import android.app.AlertDialog.Builder; | ||||||
| import android.content.Context; | import android.content.Context; | ||||||
| import android.content.DialogInterface; | import android.content.DialogInterface; | ||||||
|  | import android.content.SharedPreferences; | ||||||
| import android.content.DialogInterface.OnClickListener; | import android.content.DialogInterface.OnClickListener; | ||||||
| import android.content.Intent; | import android.content.Intent; | ||||||
| 
 | 
 | ||||||
| public class NewConversationActivity extends XmppActivity { | public class ContactsActivity extends XmppActivity { | ||||||
| 
 | 
 | ||||||
| 	protected List<Contact> rosterContacts = new ArrayList<Contact>(); | 	protected List<Contact> rosterContacts = new ArrayList<Contact>(); | ||||||
| 	protected List<Contact> aggregatedContacts = new ArrayList<Contact>(); | 	protected List<Contact> aggregatedContacts = new ArrayList<Contact>(); | ||||||
|  | @ -57,6 +60,9 @@ public class NewConversationActivity extends XmppActivity { | ||||||
| 	private List<Account> accounts; | 	private List<Account> accounts; | ||||||
| 	private List<Contact> selectedContacts = new ArrayList<Contact>(); | 	private List<Contact> selectedContacts = new ArrayList<Contact>(); | ||||||
| 	 | 	 | ||||||
|  | 	private ContactsActivity activity = this; | ||||||
|  | 
 | ||||||
|  | 	private boolean useSubject = true; | ||||||
| 	private boolean isActionMode = false; | 	private boolean isActionMode = false; | ||||||
| 	private boolean inviteIntent = false; | 	private boolean inviteIntent = false; | ||||||
| 	private ActionMode actionMode = null; | 	private ActionMode actionMode = null; | ||||||
|  | @ -79,18 +85,22 @@ public class NewConversationActivity extends XmppActivity { | ||||||
| 				menu.findItem(R.id.action_start_conversation).setVisible(false); | 				menu.findItem(R.id.action_start_conversation).setVisible(false); | ||||||
| 				menu.findItem(R.id.action_contact_details).setVisible(false); | 				menu.findItem(R.id.action_contact_details).setVisible(false); | ||||||
| 				menu.findItem(R.id.action_invite).setVisible(false); | 				menu.findItem(R.id.action_invite).setVisible(false); | ||||||
| 			} else if ((selectedContacts.size() == 1)&&(!inviteIntent)) { | 				menu.findItem(R.id.action_invite_to_existing).setVisible(false); | ||||||
|  | 			} else if ((selectedContacts.size() == 1) && (!inviteIntent)) { | ||||||
| 				menu.findItem(R.id.action_start_conversation).setVisible(true); | 				menu.findItem(R.id.action_start_conversation).setVisible(true); | ||||||
| 				menu.findItem(R.id.action_contact_details).setVisible(true); | 				menu.findItem(R.id.action_contact_details).setVisible(true); | ||||||
| 				menu.findItem(R.id.action_invite).setVisible(false); | 				menu.findItem(R.id.action_invite).setVisible(false); | ||||||
| 			} else if (!inviteIntent){ | 				menu.findItem(R.id.action_invite_to_existing).setVisible(true); | ||||||
|  | 			} else if (!inviteIntent) { | ||||||
| 				menu.findItem(R.id.action_start_conversation).setVisible(true); | 				menu.findItem(R.id.action_start_conversation).setVisible(true); | ||||||
| 				menu.findItem(R.id.action_contact_details).setVisible(false); | 				menu.findItem(R.id.action_contact_details).setVisible(false); | ||||||
| 				menu.findItem(R.id.action_invite).setVisible(false); | 				menu.findItem(R.id.action_invite).setVisible(false); | ||||||
|  | 				menu.findItem(R.id.action_invite_to_existing).setVisible(true); | ||||||
| 			} else { | 			} else { | ||||||
| 				menu.findItem(R.id.action_invite).setVisible(true); | 				menu.findItem(R.id.action_invite).setVisible(true); | ||||||
| 				menu.findItem(R.id.action_start_conversation).setVisible(false); | 				menu.findItem(R.id.action_start_conversation).setVisible(false); | ||||||
| 				menu.findItem(R.id.action_contact_details).setVisible(false); | 				menu.findItem(R.id.action_contact_details).setVisible(false); | ||||||
|  | 				menu.findItem(R.id.action_invite_to_existing).setVisible(false); | ||||||
| 			} | 			} | ||||||
| 			return true; | 			return true; | ||||||
| 		} | 		} | ||||||
|  | @ -125,11 +135,42 @@ public class NewConversationActivity extends XmppActivity { | ||||||
| 				break; | 				break; | ||||||
| 			case R.id.action_invite: | 			case R.id.action_invite: | ||||||
| 				invite(); | 				invite(); | ||||||
| 		break; | 				break; | ||||||
|  | 			case R.id.action_invite_to_existing: | ||||||
|  | 				final List<Conversation> mucs = new ArrayList<Conversation>(); | ||||||
|  | 				for(Conversation conv : xmppConnectionService.getConversations()) { | ||||||
|  | 					if (conv.getMode() == Conversation.MODE_MULTI) { | ||||||
|  | 						mucs.add(conv); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 				AlertDialog.Builder builder = new AlertDialog.Builder(activity); | ||||||
|  | 				builder.setTitle(getString(R.string.invite_contacts_to_existing)); | ||||||
|  | 				if (mucs.size() >= 1) { | ||||||
|  | 					String[] options = new String[mucs.size()]; | ||||||
|  | 					for(int i = 0; i < options.length; ++i) { | ||||||
|  | 						options[i] = mucs.get(i).getName(useSubject); | ||||||
|  | 					} | ||||||
|  | 					builder.setItems(options, new OnClickListener() { | ||||||
|  | 						 | ||||||
|  | 						@Override | ||||||
|  | 						public void onClick(DialogInterface dialog, int which) { | ||||||
|  | 							Conversation conversation = mucs.get(which); | ||||||
|  | 							if (isOnline(conversation.getAccount())) { | ||||||
|  | 								xmppConnectionService.inviteToConference(conversation, selectedContacts); | ||||||
|  | 								Toast.makeText(activity, getString(R.string.invitation_sent), Toast.LENGTH_SHORT).show(); | ||||||
|  | 								actionMode.finish(); | ||||||
|  | 							} | ||||||
|  | 						} | ||||||
|  | 					}); | ||||||
|  | 				} else { | ||||||
|  | 					builder.setMessage(getString(R.string.no_open_mucs)); | ||||||
|  | 				} | ||||||
|  | 				builder.setNegativeButton(getString(R.string.cancel),null); | ||||||
|  | 				builder.create().show(); | ||||||
|  | 				break; | ||||||
| 			default: | 			default: | ||||||
| 				break; | 				break; | ||||||
| 			} | 			} | ||||||
| 			// TODO Auto-generated method stub |  | ||||||
| 			return false; | 			return false; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | @ -139,6 +180,20 @@ public class NewConversationActivity extends XmppActivity { | ||||||
| 		} | 		} | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
|  | 	private boolean isOnline(Account account) { | ||||||
|  | 		if (account.getStatus() == Account.STATUS_ONLINE) { | ||||||
|  | 			return true; | ||||||
|  | 		} else { | ||||||
|  | 			AlertDialog.Builder builder = new AlertDialog.Builder(this); | ||||||
|  | 			builder.setTitle(getString(R.string.account_offline)); | ||||||
|  | 			builder.setMessage(getString(R.string.cant_invite_while_offline)); | ||||||
|  | 			builder.setNegativeButton("OK", null); | ||||||
|  | 			builder.setIconAttribute(android.R.attr.alertDialogIcon); | ||||||
|  | 			builder.create().show(); | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| 	private void invite() { | 	private void invite() { | ||||||
| 		List<Conversation> conversations = xmppConnectionService | 		List<Conversation> conversations = xmppConnectionService | ||||||
| 				.getConversations(); | 				.getConversations(); | ||||||
|  | @ -151,7 +206,8 @@ public class NewConversationActivity extends XmppActivity { | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		if (conversation != null) { | 		if (conversation != null) { | ||||||
| 			xmppConnectionService.inviteToConference(conversation, selectedContacts); | 			xmppConnectionService.inviteToConference(conversation, | ||||||
|  | 					selectedContacts); | ||||||
| 		} | 		} | ||||||
| 		finish(); | 		finish(); | ||||||
| 	} | 	} | ||||||
|  | @ -162,34 +218,52 @@ public class NewConversationActivity extends XmppActivity { | ||||||
| 
 | 
 | ||||||
| 				@Override | 				@Override | ||||||
| 				public void onClick(DialogInterface dialog, int which) { | 				public void onClick(DialogInterface dialog, int which) { | ||||||
| 					startConference(accounts.get(which), selectedContacts); | 					startConference(accounts.get(which)); | ||||||
| 				} | 				} | ||||||
| 			}).show(); | 			}).show(); | ||||||
| 		} else { | 		} else { | ||||||
| 			startConference(accounts.get(0), selectedContacts); | 			startConference(accounts.get(0)); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	private void startConference(Account account, List<Contact> contacts) { | 	private void startConference(final Account account) { | ||||||
| 		SecureRandom random = new SecureRandom(); | 		if (isOnline(account)) { | ||||||
| 		String mucName = new BigInteger(100, random).toString(32); | 			AlertDialog.Builder builder = new AlertDialog.Builder(this); | ||||||
| 		String serverName = account.getXmppConnection().getMucServer(); | 			builder.setTitle(getString(R.string.new_conference)); | ||||||
| 		String jid = mucName + "@" + serverName; | 			builder.setMessage(getString(R.string.new_conference_explained)); | ||||||
| 		Conversation conversation = xmppConnectionService | 			builder.setNegativeButton(getString(R.string.cancel), null); | ||||||
| 				.findOrCreateConversation(account, jid, true); | 			builder.setPositiveButton(getString(R.string.create_invite), | ||||||
| 		StringBuilder subject = new StringBuilder(); | 					new OnClickListener() { | ||||||
| 		for (int i = 0; i < selectedContacts.size(); ++i) { | 	 | ||||||
| 			if (i + 1 != selectedContacts.size()) { | 						@Override | ||||||
| 				subject.append(selectedContacts.get(i).getDisplayName() + ", "); | 						public void onClick(DialogInterface dialog, int which) { | ||||||
| 			} else { | 							String mucName = CryptoHelper.randomMucName(); | ||||||
| 				subject.append(selectedContacts.get(i).getDisplayName()); | 							String serverName = account.getXmppConnection() | ||||||
| 			} | 									.getMucServer(); | ||||||
|  | 							String jid = mucName + "@" + serverName; | ||||||
|  | 							Conversation conversation = xmppConnectionService | ||||||
|  | 									.findOrCreateConversation(account, jid, true); | ||||||
|  | 							StringBuilder subject = new StringBuilder(); | ||||||
|  | 							subject.append(account.getUsername() + ", "); | ||||||
|  | 							for (int i = 0; i < selectedContacts.size(); ++i) { | ||||||
|  | 								if (i + 1 != selectedContacts.size()) { | ||||||
|  | 									subject.append(selectedContacts.get(i) | ||||||
|  | 											.getDisplayName() + ", "); | ||||||
|  | 								} else { | ||||||
|  | 									subject.append(selectedContacts.get(i) | ||||||
|  | 											.getDisplayName()); | ||||||
|  | 								} | ||||||
|  | 							} | ||||||
|  | 							xmppConnectionService.sendConversationSubject( | ||||||
|  | 									conversation, subject.toString()); | ||||||
|  | 							xmppConnectionService.inviteToConference(conversation, | ||||||
|  | 									selectedContacts); | ||||||
|  | 							switchToConversation(conversation, null); | ||||||
|  | 						} | ||||||
|  | 					}); | ||||||
|  | 			builder.create().show(); | ||||||
| 		} | 		} | ||||||
| 		xmppConnectionService.sendConversationSubject(conversation, |  | ||||||
| 				subject.toString()); |  | ||||||
| 		xmppConnectionService.inviteToConference(conversation, contacts); |  | ||||||
| 		switchToConversation(conversation, null); |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	protected void updateAggregatedContacts() { | 	protected void updateAggregatedContacts() { | ||||||
|  | @ -246,6 +320,8 @@ public class NewConversationActivity extends XmppActivity { | ||||||
| 	@Override | 	@Override | ||||||
| 	protected void onStart() { | 	protected void onStart() { | ||||||
| 		super.onStart(); | 		super.onStart(); | ||||||
|  | 		SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(activity); | ||||||
|  | 		this.useSubject = preferences.getBoolean("use_subject_in_muc", true); | ||||||
| 		inviteIntent = "invite".equals(getIntent().getAction()); | 		inviteIntent = "invite".equals(getIntent().getAction()); | ||||||
| 		if (inviteIntent) { | 		if (inviteIntent) { | ||||||
| 			contactsHeader.setVisibility(View.GONE); | 			contactsHeader.setVisibility(View.GONE); | ||||||
|  | @ -74,7 +74,7 @@ public class ConversationActivity extends XmppActivity { | ||||||
| 						if (conversationList.size() >= 1) { | 						if (conversationList.size() >= 1) { | ||||||
| 							swapConversationFragment(); | 							swapConversationFragment(); | ||||||
| 						} else { | 						} else { | ||||||
| 							startActivity(new Intent(getApplicationContext(), NewConversationActivity.class)); | 							startActivity(new Intent(getApplicationContext(), ContactsActivity.class)); | ||||||
| 							finish(); | 							finish(); | ||||||
| 						} | 						} | ||||||
| 					} | 					} | ||||||
|  | @ -249,12 +249,14 @@ public class ConversationActivity extends XmppActivity { | ||||||
| 		MenuItem menuArchive = (MenuItem) menu.findItem(R.id.action_archive); | 		MenuItem menuArchive = (MenuItem) menu.findItem(R.id.action_archive); | ||||||
| 		MenuItem menuMucDetails = (MenuItem) menu.findItem(R.id.action_muc_details); | 		MenuItem menuMucDetails = (MenuItem) menu.findItem(R.id.action_muc_details); | ||||||
| 		MenuItem menuContactDetails = (MenuItem) menu.findItem(R.id.action_contact_details); | 		MenuItem menuContactDetails = (MenuItem) menu.findItem(R.id.action_contact_details); | ||||||
|  | 		MenuItem menuInviteContacts = (MenuItem) menu.findItem(R.id.action_invite); | ||||||
| 		 | 		 | ||||||
| 		if ((spl.isOpen()&&(spl.isSlideable()))) { | 		if ((spl.isOpen()&&(spl.isSlideable()))) { | ||||||
| 			menuArchive.setVisible(false); | 			menuArchive.setVisible(false); | ||||||
| 			menuMucDetails.setVisible(false); | 			menuMucDetails.setVisible(false); | ||||||
| 			menuContactDetails.setVisible(false); | 			menuContactDetails.setVisible(false); | ||||||
| 			menuSecure.setVisible(false); | 			menuSecure.setVisible(false); | ||||||
|  | 			menuInviteContacts.setVisible(false); | ||||||
| 		} else { | 		} else { | ||||||
| 			((MenuItem) menu.findItem(R.id.action_add)).setVisible(!spl.isSlideable()); | 			((MenuItem) menu.findItem(R.id.action_add)).setVisible(!spl.isSlideable()); | ||||||
| 			if (this.getSelectedConversation()!=null) { | 			if (this.getSelectedConversation()!=null) { | ||||||
|  | @ -263,9 +265,11 @@ public class ConversationActivity extends XmppActivity { | ||||||
| 					menuContactDetails.setVisible(false); | 					menuContactDetails.setVisible(false); | ||||||
| 					menuSecure.setVisible(false); | 					menuSecure.setVisible(false); | ||||||
| 					menuArchive.setTitle("Leave conference"); | 					menuArchive.setTitle("Leave conference"); | ||||||
|  | 					menuInviteContacts.setVisible(true); | ||||||
| 				} else { | 				} else { | ||||||
| 					menuContactDetails.setVisible(true); | 					menuContactDetails.setVisible(true); | ||||||
| 					menuMucDetails.setVisible(false); | 					menuMucDetails.setVisible(false); | ||||||
|  | 					menuInviteContacts.setVisible(false); | ||||||
| 					if (this.getSelectedConversation().getLatestMessage().getEncryption() != Message.ENCRYPTION_NONE) { | 					if (this.getSelectedConversation().getLatestMessage().getEncryption() != Message.ENCRYPTION_NONE) { | ||||||
| 						menuSecure.setIcon(R.drawable.ic_action_secure); | 						menuSecure.setIcon(R.drawable.ic_action_secure); | ||||||
| 					} | 					} | ||||||
|  | @ -282,7 +286,7 @@ public class ConversationActivity extends XmppActivity { | ||||||
| 			spl.openPane(); | 			spl.openPane(); | ||||||
| 			break; | 			break; | ||||||
| 		case R.id.action_add: | 		case R.id.action_add: | ||||||
| 			startActivity(new Intent(this, NewConversationActivity.class)); | 			startActivity(new Intent(this, ContactsActivity.class)); | ||||||
| 			break; | 			break; | ||||||
| 		case R.id.action_archive: | 		case R.id.action_archive: | ||||||
| 			Conversation conv = getSelectedConversation(); | 			Conversation conv = getSelectedConversation(); | ||||||
|  | @ -319,6 +323,13 @@ public class ConversationActivity extends XmppActivity { | ||||||
| 			intent.putExtra("uuid", getSelectedConversation().getUuid()); | 			intent.putExtra("uuid", getSelectedConversation().getUuid()); | ||||||
| 			startActivity(intent); | 			startActivity(intent); | ||||||
| 			break; | 			break; | ||||||
|  | 		case R.id.action_invite: | ||||||
|  | 			Intent inviteIntent = new Intent(getApplicationContext(), | ||||||
|  | 					ContactsActivity.class); | ||||||
|  | 			inviteIntent.setAction("invite"); | ||||||
|  | 			inviteIntent.putExtra("uuid",selectedConversation.getUuid()); | ||||||
|  | 			startActivity(inviteIntent); | ||||||
|  | 			break; | ||||||
| 		case R.id.action_security: | 		case R.id.action_security: | ||||||
| 			final Conversation selConv = getSelectedConversation(); | 			final Conversation selConv = getSelectedConversation(); | ||||||
| 			View menuItemView = findViewById(R.id.action_security); | 			View menuItemView = findViewById(R.id.action_security); | ||||||
|  | @ -451,7 +462,7 @@ public class ConversationActivity extends XmppActivity { | ||||||
| 				finish(); | 				finish(); | ||||||
| 			} else if (conversationList.size() <= 0) { | 			} else if (conversationList.size() <= 0) { | ||||||
| 				//add no history | 				//add no history | ||||||
| 				startActivity(new Intent(this, NewConversationActivity.class)); | 				startActivity(new Intent(this, ContactsActivity.class)); | ||||||
| 				finish(); | 				finish(); | ||||||
| 			} else { | 			} else { | ||||||
| 				spl.openPane(); | 				spl.openPane(); | ||||||
|  |  | ||||||
|  | @ -326,7 +326,8 @@ public class ConversationFragment extends Fragment { | ||||||
| 	public void onStart() { | 	public void onStart() { | ||||||
| 		super.onStart(); | 		super.onStart(); | ||||||
| 		ConversationActivity activity = (ConversationActivity) getActivity(); | 		ConversationActivity activity = (ConversationActivity) getActivity(); | ||||||
| 
 | 		SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(activity); | ||||||
|  | 		this.useSubject = preferences.getBoolean("use_subject_in_muc", true); | ||||||
| 		if (activity.xmppConnectionServiceBound) { | 		if (activity.xmppConnectionServiceBound) { | ||||||
| 			this.onBackendConnected(); | 			this.onBackendConnected(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | @ -200,7 +200,7 @@ public class ManageAccountActivity extends XmppActivity { | ||||||
| 					if ((account.getStatus() == Account.STATUS_OFFLINE)||(account.getStatus() == Account.STATUS_TLS_ERROR)) { | 					if ((account.getStatus() == Account.STATUS_OFFLINE)||(account.getStatus() == Account.STATUS_TLS_ERROR)) { | ||||||
| 						activity.xmppConnectionService.reconnectAccount(accountList.get(position),true); | 						activity.xmppConnectionService.reconnectAccount(accountList.get(position),true); | ||||||
| 					} else if (account.getStatus() == Account.STATUS_ONLINE) { | 					} else if (account.getStatus() == Account.STATUS_ONLINE) { | ||||||
| 						activity.startActivity(new Intent(activity.getApplicationContext(),NewConversationActivity.class)); | 						activity.startActivity(new Intent(activity.getApplicationContext(),ContactsActivity.class)); | ||||||
| 					} else if (account.isOptionSet(Account.OPTION_REGISTER)) { | 					} else if (account.isOptionSet(Account.OPTION_REGISTER)) { | ||||||
| 						editAccount(account); | 						editAccount(account); | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
|  | @ -70,7 +70,7 @@ public class MucDetailsActivity extends XmppActivity { | ||||||
| 		@Override | 		@Override | ||||||
| 		public void onClick(View v) { | 		public void onClick(View v) { | ||||||
| 			Intent intent = new Intent(getApplicationContext(), | 			Intent intent = new Intent(getApplicationContext(), | ||||||
| 					NewConversationActivity.class); | 					ContactsActivity.class); | ||||||
| 			intent.setAction("invite"); | 			intent.setAction("invite"); | ||||||
| 			intent.putExtra("uuid",conversation.getUuid()); | 			intent.putExtra("uuid",conversation.getUuid()); | ||||||
| 			startActivity(intent); | 			startActivity(intent); | ||||||
|  |  | ||||||
|  | @ -1,9 +1,14 @@ | ||||||
| package eu.siacs.conversations.utils; | package eu.siacs.conversations.utils; | ||||||
| 
 | 
 | ||||||
|  | import java.security.SecureRandom; | ||||||
|  | import java.util.Random; | ||||||
|  | 
 | ||||||
| import android.util.Base64; | import android.util.Base64; | ||||||
| 
 | 
 | ||||||
| public class CryptoHelper { | public class CryptoHelper { | ||||||
| 	final protected static char[] hexArray = "0123456789ABCDEF".toCharArray(); | 	final protected static char[] hexArray = "0123456789ABCDEF".toCharArray(); | ||||||
|  | 	final protected static char[] vowels = "aeiou".toCharArray(); | ||||||
|  | 	final protected static char[] consonants ="bcdfghjklmnpqrstvwxyz".toCharArray(); | ||||||
| 	public static String bytesToHex(byte[] bytes) { | 	public static String bytesToHex(byte[] bytes) { | ||||||
| 	    char[] hexChars = new char[bytes.length * 2]; | 	    char[] hexChars = new char[bytes.length * 2]; | ||||||
| 	    for ( int j = 0; j < bytes.length; j++ ) { | 	    for ( int j = 0; j < bytes.length; j++ ) { | ||||||
|  | @ -31,4 +36,21 @@ public class CryptoHelper { | ||||||
| 		 | 		 | ||||||
| 		return Base64.encodeToString(saslBytes, Base64.DEFAULT); | 		return Base64.encodeToString(saslBytes, Base64.DEFAULT); | ||||||
| 	} | 	} | ||||||
|  | 	 | ||||||
|  | 	public static String randomMucName() { | ||||||
|  | 		Random random = new SecureRandom(); | ||||||
|  | 		return randomWord(3,random)+"."+randomWord(7,random); | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	protected static String randomWord(int lenght,Random random) { | ||||||
|  | 		StringBuilder builder = new StringBuilder(lenght); | ||||||
|  | 		for(int i = 0; i < lenght; ++i) { | ||||||
|  | 			if (i % 2 == 0) { | ||||||
|  | 				builder.append(consonants[random.nextInt(consonants.length)]); | ||||||
|  | 			} else { | ||||||
|  | 				builder.append(vowels[random.nextInt(vowels.length)]); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		return builder.toString(); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -220,6 +220,7 @@ public class XmppConnection implements Runnable { | ||||||
| 				tagWriter.writeStanzaAsync(r); | 				tagWriter.writeStanzaAsync(r); | ||||||
| 			} else if (nextTag.isStart("resumed")) { | 			} else if (nextTag.isStart("resumed")) { | ||||||
| 				tagReader.readElement(nextTag); | 				tagReader.readElement(nextTag); | ||||||
|  | 				sendPing(); | ||||||
| 				changeStatus(Account.STATUS_ONLINE); | 				changeStatus(Account.STATUS_ONLINE); | ||||||
| 				Log.d(LOGTAG,account.getJid()+": session resumed"); | 				Log.d(LOGTAG,account.getJid()+": session resumed"); | ||||||
| 			} else if (nextTag.isStart("r")) { | 			} else if (nextTag.isStart("r")) { | ||||||
|  | @ -543,10 +544,6 @@ public class XmppConnection implements Runnable { | ||||||
| 				String resource = packet.findChild("bind").findChild("jid") | 				String resource = packet.findChild("bind").findChild("jid") | ||||||
| 						.getContent().split("/")[1]; | 						.getContent().split("/")[1]; | ||||||
| 				account.setResource(resource); | 				account.setResource(resource); | ||||||
| 				if (bindListener !=null) { |  | ||||||
| 					bindListener.onBind(account); |  | ||||||
| 				} |  | ||||||
| 				account.setStatus(Account.STATUS_ONLINE); |  | ||||||
| 				if (streamFeatures.hasChild("sm")) { | 				if (streamFeatures.hasChild("sm")) { | ||||||
| 					EnablePacket enable = new EnablePacket(); | 					EnablePacket enable = new EnablePacket(); | ||||||
| 					tagWriter.writeStanzaAsync(enable); | 					tagWriter.writeStanzaAsync(enable); | ||||||
|  | @ -554,9 +551,10 @@ public class XmppConnection implements Runnable { | ||||||
| 				sendInitialPresence(); | 				sendInitialPresence(); | ||||||
| 				sendServiceDiscoveryInfo(); | 				sendServiceDiscoveryInfo(); | ||||||
| 				sendServiceDiscoveryItems(); | 				sendServiceDiscoveryItems(); | ||||||
| 				if (statusListener != null) { | 				if (bindListener !=null) { | ||||||
| 					statusListener.onStatusChanged(account); | 					bindListener.onBind(account); | ||||||
| 				} | 				} | ||||||
|  | 				account.setStatus(Account.STATUS_ONLINE); | ||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Daniel Gultsch
						Daniel Gultsch