diff --git a/src/org/thoughtcrime/securesms/util/Base64.java b/library/src/org/whispersystems/textsecure/util/Base64.java similarity index 99% rename from src/org/thoughtcrime/securesms/util/Base64.java rename to library/src/org/whispersystems/textsecure/util/Base64.java index 11b56309c4..78f69555e3 100644 --- a/src/org/thoughtcrime/securesms/util/Base64.java +++ b/library/src/org/whispersystems/textsecure/util/Base64.java @@ -1,6 +1,4 @@ -package org.thoughtcrime.securesms.util; - -import java.io.IOException; +package org.whispersystems.textsecure.util; /** *
Encodes and decodes to and from Base64 notation.
diff --git a/library/src/org/whispersystems/textsecure/util/Util.java b/library/src/org/whispersystems/textsecure/util/Util.java new file mode 100644 index 0000000000..5bb37c358d --- /dev/null +++ b/library/src/org/whispersystems/textsecure/util/Util.java @@ -0,0 +1,58 @@ +package org.whispersystems.textsecure.util; + +import android.app.AlertDialog; +import android.content.Context; +import android.widget.EditText; + +import java.io.ByteArrayOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.security.NoSuchAlgorithmException; +import java.security.SecureRandom; + +public class Util { + public static boolean isEmpty(String value) { + return value == null || value.trim().length() == 0; + } + + public static boolean isEmpty(EditText value) { + return value == null || value.getText() == null || isEmpty(value.getText().toString()); + } + + public static boolean isEmpty(CharSequence value) { + return value == null || value.length() == 0; + } + + public static void showAlertDialog(Context context, String title, String message) { + AlertDialog.Builder dialog = new AlertDialog.Builder(context); + dialog.setTitle(title); + dialog.setMessage(message); + dialog.setIcon(android.R.drawable.ic_dialog_alert); + dialog.setPositiveButton(android.R.string.ok, null); + dialog.show(); + } + + public static String getSecret(int size) { + try { + byte[] secret = new byte[size]; + SecureRandom.getInstance("SHA1PRNG").nextBytes(secret); + return Base64.encodeBytes(secret); + } catch (NoSuchAlgorithmException nsae) { + throw new AssertionError(nsae); + } + } + + public static String readFully(InputStream in) throws IOException { + ByteArrayOutputStream bout = new ByteArrayOutputStream(); + byte[] buffer = new byte[4096]; + int read; + + while ((read = in.read(buffer)) != -1) { + bout.write(buffer, 0, read); + } + + in.close(); + + return new String(bout.toByteArray()); + } +} diff --git a/src/org/thoughtcrime/securesms/ConversationActivity.java b/src/org/thoughtcrime/securesms/ConversationActivity.java index 58314708a6..2225699d3a 100644 --- a/src/org/thoughtcrime/securesms/ConversationActivity.java +++ b/src/org/thoughtcrime/securesms/ConversationActivity.java @@ -29,7 +29,6 @@ import android.net.Uri; import android.os.AsyncTask; import android.os.Build; import android.os.Bundle; -import android.preference.PreferenceManager; import android.provider.ContactsContract; import android.telephony.PhoneNumberUtils; import android.text.Editable; @@ -90,7 +89,7 @@ import org.thoughtcrime.securesms.util.EncryptedCharacterCalculator; import org.thoughtcrime.securesms.util.InvalidMessageException; import org.thoughtcrime.securesms.util.MemoryCleaner; import org.thoughtcrime.securesms.util.TextSecurePreferences; -import org.thoughtcrime.securesms.util.Util; +import org.whispersystems.textsecure.util.Util; import java.io.IOException; import java.util.LinkedList; diff --git a/src/org/thoughtcrime/securesms/KeyScanningActivity.java b/src/org/thoughtcrime/securesms/KeyScanningActivity.java index a0fce06d20..fd84ae0208 100644 --- a/src/org/thoughtcrime/securesms/KeyScanningActivity.java +++ b/src/org/thoughtcrime/securesms/KeyScanningActivity.java @@ -21,7 +21,7 @@ import android.os.Bundle; import android.widget.Toast; import org.thoughtcrime.securesms.crypto.SerializableKey; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import org.thoughtcrime.securesms.util.Dialogs; import org.thoughtcrime.securesms.util.DynamicTheme; diff --git a/src/org/thoughtcrime/securesms/PassphraseCreateActivity.java b/src/org/thoughtcrime/securesms/PassphraseCreateActivity.java index e2098bfe48..c403e8c59c 100644 --- a/src/org/thoughtcrime/securesms/PassphraseCreateActivity.java +++ b/src/org/thoughtcrime/securesms/PassphraseCreateActivity.java @@ -16,10 +16,8 @@ */ package org.thoughtcrime.securesms; -import android.content.SharedPreferences; import android.os.AsyncTask; import android.os.Bundle; -import android.preference.PreferenceManager; import android.view.View; import android.widget.Button; import android.widget.EditText; @@ -30,8 +28,8 @@ import org.thoughtcrime.securesms.crypto.IdentityKeyUtil; import org.thoughtcrime.securesms.crypto.MasterSecret; import org.thoughtcrime.securesms.crypto.MasterSecretUtil; import org.thoughtcrime.securesms.util.MemoryCleaner; -import org.thoughtcrime.securesms.util.Util; import org.thoughtcrime.securesms.util.VersionTracker; +import org.whispersystems.textsecure.util.Util; /** * Activity for creating a user's local encryption passphrase. diff --git a/src/org/thoughtcrime/securesms/RegistrationActivity.java b/src/org/thoughtcrime/securesms/RegistrationActivity.java index 51453caf54..5ea755bdb7 100644 --- a/src/org/thoughtcrime/securesms/RegistrationActivity.java +++ b/src/org/thoughtcrime/securesms/RegistrationActivity.java @@ -24,8 +24,8 @@ import com.google.i18n.phonenumbers.AsYouTypeFormatter; import com.google.i18n.phonenumbers.NumberParseException; import com.google.i18n.phonenumbers.PhoneNumberUtil; import com.google.i18n.phonenumbers.Phonenumber; -import org.thoughtcrime.securesms.util.Util; import org.whispersystems.textsecure.util.PhoneNumberFormatter; +import org.whispersystems.textsecure.util.Util; /** * The register account activity. Begins the account registration process. diff --git a/src/org/thoughtcrime/securesms/RegistrationProgressActivity.java b/src/org/thoughtcrime/securesms/RegistrationProgressActivity.java index c038148fd6..736ed9274a 100644 --- a/src/org/thoughtcrime/securesms/RegistrationProgressActivity.java +++ b/src/org/thoughtcrime/securesms/RegistrationProgressActivity.java @@ -32,8 +32,8 @@ import com.actionbarsherlock.app.SherlockActivity; import org.thoughtcrime.securesms.gcm.PushServiceSocket; import org.thoughtcrime.securesms.gcm.RateLimitException; import org.thoughtcrime.securesms.service.RegistrationService; -import org.thoughtcrime.securesms.util.Util; import org.whispersystems.textsecure.util.PhoneNumberFormatter; +import org.whispersystems.textsecure.util.Util; import java.io.IOException; diff --git a/src/org/thoughtcrime/securesms/contacts/ContactAccessor.java b/src/org/thoughtcrime/securesms/contacts/ContactAccessor.java index a4984e8a0b..6fbacc0602 100644 --- a/src/org/thoughtcrime/securesms/contacts/ContactAccessor.java +++ b/src/org/thoughtcrime/securesms/contacts/ContactAccessor.java @@ -36,7 +36,7 @@ import android.util.Log; import org.thoughtcrime.securesms.crypto.IdentityKey; import org.thoughtcrime.securesms.crypto.InvalidKeyException; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import java.io.IOException; import java.lang.Long; diff --git a/src/org/thoughtcrime/securesms/crypto/AsymmetricMasterCipher.java b/src/org/thoughtcrime/securesms/crypto/AsymmetricMasterCipher.java index 82110752b7..92e2743e42 100644 --- a/src/org/thoughtcrime/securesms/crypto/AsymmetricMasterCipher.java +++ b/src/org/thoughtcrime/securesms/crypto/AsymmetricMasterCipher.java @@ -26,7 +26,7 @@ import javax.crypto.spec.SecretKeySpec; import org.bouncycastle.crypto.AsymmetricCipherKeyPair; import org.bouncycastle.crypto.agreement.ECDHBasicAgreement; import org.bouncycastle.crypto.params.ECPublicKeyParameters; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import org.thoughtcrime.securesms.util.Conversions; import org.thoughtcrime.securesms.util.InvalidMessageException; diff --git a/src/org/thoughtcrime/securesms/crypto/IdentityKeyUtil.java b/src/org/thoughtcrime/securesms/crypto/IdentityKeyUtil.java index e14c56f9ca..f210a6376d 100644 --- a/src/org/thoughtcrime/securesms/crypto/IdentityKeyUtil.java +++ b/src/org/thoughtcrime/securesms/crypto/IdentityKeyUtil.java @@ -30,7 +30,7 @@ import org.thoughtcrime.bouncycastle.asn1.ASN1Object; import org.thoughtcrime.bouncycastle.asn1.ASN1Sequence; import org.thoughtcrime.bouncycastle.asn1.DERInteger; import org.thoughtcrime.bouncycastle.asn1.DERSequence; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import org.thoughtcrime.securesms.util.Combiner; import org.thoughtcrime.securesms.util.Conversions; diff --git a/src/org/thoughtcrime/securesms/crypto/KeyExchangeMessage.java b/src/org/thoughtcrime/securesms/crypto/KeyExchangeMessage.java index 2a28518323..0a2776520a 100644 --- a/src/org/thoughtcrime/securesms/crypto/KeyExchangeMessage.java +++ b/src/org/thoughtcrime/securesms/crypto/KeyExchangeMessage.java @@ -17,13 +17,11 @@ package org.thoughtcrime.securesms.crypto; import android.content.Context; -import android.preference.PreferenceManager; import android.util.Log; -import org.thoughtcrime.securesms.ApplicationPreferencesActivity; import org.thoughtcrime.securesms.database.keys.LocalKeyRecord; import org.thoughtcrime.securesms.protocol.Message; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import org.thoughtcrime.securesms.util.Conversions; import java.io.IOException; diff --git a/src/org/thoughtcrime/securesms/crypto/MasterCipher.java b/src/org/thoughtcrime/securesms/crypto/MasterCipher.java index cc42fcff71..66867212a8 100644 --- a/src/org/thoughtcrime/securesms/crypto/MasterCipher.java +++ b/src/org/thoughtcrime/securesms/crypto/MasterCipher.java @@ -33,7 +33,7 @@ import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import org.bouncycastle.crypto.params.ECPrivateKeyParameters; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import org.thoughtcrime.securesms.util.Hex; import org.thoughtcrime.securesms.util.InvalidMessageException; diff --git a/src/org/thoughtcrime/securesms/crypto/MasterSecretUtil.java b/src/org/thoughtcrime/securesms/crypto/MasterSecretUtil.java index 410d80560f..45882c7625 100644 --- a/src/org/thoughtcrime/securesms/crypto/MasterSecretUtil.java +++ b/src/org/thoughtcrime/securesms/crypto/MasterSecretUtil.java @@ -23,7 +23,7 @@ import android.util.Log; import org.bouncycastle.crypto.AsymmetricCipherKeyPair; import org.bouncycastle.crypto.params.ECPrivateKeyParameters; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import java.io.IOException; import java.security.GeneralSecurityException; diff --git a/src/org/thoughtcrime/securesms/database/DatabaseFactory.java b/src/org/thoughtcrime/securesms/database/DatabaseFactory.java index f55d18855a..5863bb075a 100644 --- a/src/org/thoughtcrime/securesms/database/DatabaseFactory.java +++ b/src/org/thoughtcrime/securesms/database/DatabaseFactory.java @@ -31,9 +31,9 @@ import org.thoughtcrime.securesms.crypto.MasterCipher; import org.thoughtcrime.securesms.crypto.MasterSecret; import org.thoughtcrime.securesms.database.keys.SessionRecord; import org.thoughtcrime.securesms.notifications.MessageNotifier; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import org.thoughtcrime.securesms.util.InvalidMessageException; -import org.thoughtcrime.securesms.util.Util; +import org.whispersystems.textsecure.util.Util; import java.io.File; import java.io.FileInputStream; diff --git a/src/org/thoughtcrime/securesms/database/IdentityDatabase.java b/src/org/thoughtcrime/securesms/database/IdentityDatabase.java index 28d1062a68..02997625a1 100644 --- a/src/org/thoughtcrime/securesms/database/IdentityDatabase.java +++ b/src/org/thoughtcrime/securesms/database/IdentityDatabase.java @@ -31,7 +31,7 @@ import org.thoughtcrime.securesms.crypto.MasterSecret; import org.thoughtcrime.securesms.recipients.Recipient; import org.thoughtcrime.securesms.recipients.RecipientFactory; import org.thoughtcrime.securesms.recipients.Recipients; -import org.thoughtcrime.securesms.util.Base64; +import org.whispersystems.textsecure.util.Base64; import java.io.IOException; diff --git a/src/org/thoughtcrime/securesms/database/MmsDatabase.java b/src/org/thoughtcrime/securesms/database/MmsDatabase.java index 64901f9862..03355f4da9 100644 --- a/src/org/thoughtcrime/securesms/database/MmsDatabase.java +++ b/src/org/thoughtcrime/securesms/database/MmsDatabase.java @@ -44,7 +44,7 @@ import org.thoughtcrime.securesms.util.InvalidMessageException; import org.thoughtcrime.securesms.util.LRUCache; import org.thoughtcrime.securesms.util.ListenableFutureTask; import org.thoughtcrime.securesms.util.Trimmer; -import org.thoughtcrime.securesms.util.Util; +import org.whispersystems.textsecure.util.Util; import java.io.UnsupportedEncodingException; import java.lang.ref.SoftReference; @@ -133,7 +133,7 @@ public class MmsDatabase extends Database implements MmsSmsColumns { DELIVERY_TIME, DELIVERY_REPORT, BODY, PART_COUNT, ADDRESS }; - public static final ExecutorService slideResolver = Util.newSingleThreadedLifoExecutor(); + public static final ExecutorService slideResolver = org.thoughtcrime.securesms.util.Util.newSingleThreadedLifoExecutor(); private static final Map