diff options
26 files changed, 149 insertions, 867 deletions
| diff --git a/.gitmodules b/.gitmodules index 687126e37..ca01e1ac6 100644 --- a/.gitmodules +++ b/.gitmodules @@ -7,9 +7,6 @@  [submodule "extern/zxing-qr-code"]  	path = extern/zxing-qr-code  	url = https://github.com/open-keychain/zxing-qr-code.git -[submodule "extern/AppMsg"] -	path = extern/AppMsg -	url = https://github.com/open-keychain/Android-AppMsg.git  [submodule "extern/spongycastle"]  	path = extern/spongycastle  	url = https://github.com/open-keychain/spongycastle.git @@ -30,4 +27,4 @@  	url = https://github.com/open-keychain/KeybaseLib.git  [submodule "extern/minidns"]  	path = extern/minidns -	url = https://github.com/open-keychain/minidns.git
\ No newline at end of file +	url = https://github.com/open-keychain/minidns.git diff --git a/OpenKeychain/build.gradle b/OpenKeychain/build.gradle index 11fa54a57..f42787806 100644 --- a/OpenKeychain/build.gradle +++ b/OpenKeychain/build.gradle @@ -15,7 +15,6 @@ dependencies {      compile project(':extern:spongycastle:pg')      compile project(':extern:spongycastle:pkix')      compile project(':extern:spongycastle:prov') -    compile project(':extern:AppMsg:library')      compile project(':extern:SuperToasts:supertoasts')      compile project(':extern:minidns')      compile project(':extern:KeybaseLib:Lib') diff --git a/OpenKeychain/src/main/AndroidManifest.xml b/OpenKeychain/src/main/AndroidManifest.xml index af09019e8..484c826f5 100644 --- a/OpenKeychain/src/main/AndroidManifest.xml +++ b/OpenKeychain/src/main/AndroidManifest.xml @@ -91,11 +91,6 @@              android:label="@string/title_create_key"              android:windowSoftInputMode="stateHidden" />          <activity -            android:name=".ui.EditKeyActivityOld" -            android:configChanges="orientation|screenSize|keyboardHidden|keyboard" -            android:label="@string/title_edit_key" -            android:windowSoftInputMode="stateHidden" /> -        <activity              android:name=".ui.EditKeyActivity"              android:configChanges="orientation|screenSize|keyboardHidden|keyboard"              android:label="@string/title_edit_key" diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentServiceHandler.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentServiceHandler.java index 755827482..0cdbe708e 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentServiceHandler.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentServiceHandler.java @@ -25,12 +25,11 @@ import android.os.Message;  import android.support.v4.app.FragmentActivity;  import android.support.v4.app.FragmentManager; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.ui.dialog.ProgressDialogFragment;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  public class KeychainIntentServiceHandler extends Handler { @@ -102,9 +101,9 @@ public class KeychainIntentServiceHandler extends Handler {                  // show error from service                  if (data.containsKey(DATA_ERROR)) { -                    AppMsg.makeText(mActivity, +                    Notify.showNotify(mActivity,                              mActivity.getString(R.string.error_message, data.getString(DATA_ERROR)), -                            AppMsg.STYLE_ALERT).show(); +                            Notify.Style.ERROR);                  }                  break; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResultParcel.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResultParcel.java index e55ec5568..d80c508c3 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResultParcel.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResultParcel.java @@ -1,10 +1,20 @@  package org.sufficientlysecure.keychain.service; +import android.app.Activity; +import android.content.Intent;  import android.os.Parcel;  import android.os.Parcelable; +import android.view.View; + +import com.github.johnpersano.supertoasts.SuperCardToast; +import com.github.johnpersano.supertoasts.SuperToast; +import com.github.johnpersano.supertoasts.util.OnClickWrapper; +import com.github.johnpersano.supertoasts.util.Style;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; +import org.sufficientlysecure.keychain.ui.LogDisplayActivity; +import org.sufficientlysecure.keychain.ui.LogDisplayFragment;  import org.sufficientlysecure.keychain.util.IterableIterator;  import org.sufficientlysecure.keychain.util.Log; @@ -24,6 +34,9 @@ import java.util.List;   *   */  public class OperationResultParcel implements Parcelable { + +    public static final String EXTRA_RESULT = "operation_result"; +      /** Holds the overall result, the number specifying varying degrees of success. The first bit       * is 0 on overall success, 1 on overall failure. All other bits may be used for more specific       * conditions. */ @@ -113,6 +126,43 @@ public class OperationResultParcel implements Parcelable {          }      } +    public SuperCardToast createNotify(final Activity activity) { + +        int resultType = getResult(); + +        String str; +        int duration, color; + +        // Not an overall failure +        if ((resultType & OperationResultParcel.RESULT_ERROR) == 0) { + +            if (getLog().containsWarnings()) { +                duration = 0; +                color = Style.ORANGE; +            } else { +                duration = SuperToast.Duration.LONG; +                color = Style.GREEN; +            } + +            str = activity.getString(R.string.import_error); + +        } else { +            duration = 0; +            color = Style.RED; +            str = activity.getString(R.string.import_error); +        } + +        SuperCardToast toast = new SuperCardToast(activity, +                SuperToast.Type.STANDARD, Style.getStyle(color, SuperToast.Animations.POPUP)); +        toast.setText(str); +        toast.setDuration(duration); +        toast.setIndeterminate(duration == 0); +        toast.setSwipeToDismiss(true); + +        return toast; + +    } +      /** This is an enum of all possible log events.       *       * Element names should generally be prefixed with MSG_XX_ where XX is an @@ -132,6 +182,8 @@ public class OperationResultParcel implements Parcelable {       */      public static enum LogType { +        INTERNAL_ERROR (R.string.internal_error), +          // import public          MSG_IP(R.string.msg_ip),          MSG_IP_APPLY_BATCH (R.string.msg_ip_apply_batch), @@ -339,6 +391,14 @@ public class OperationResultParcel implements Parcelable {              mParcels.add(new OperationResultParcel.LogEntryParcel(level, type, indent, (Object[]) null));          } +        public LogEntryParcel getResultId() { +            LogEntryParcel entry = get(size()-1); +            if (entry.mLevel != LogLevel.OK && entry.mLevel != LogLevel.ERROR) { +                return new LogEntryParcel(LogLevel.ERROR, LogType.INTERNAL_ERROR, 0); +            } +            return entry; +        } +          public boolean containsWarnings() {              for(LogEntryParcel entry : new IterableIterator<LogEntryParcel>(mParcels.iterator())) {                  if (entry.mLevel == LogLevel.WARN || entry.mLevel == LogLevel.ERROR) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResults.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResults.java index fd3d4ed00..39c11a855 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResults.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResults.java @@ -80,7 +80,7 @@ public abstract class OperationResults {              }          }; -        public void displayNotify(final Activity activity) { +        public SuperCardToast createNotify(final Activity activity) {              int resultType = getResult(); @@ -88,7 +88,7 @@ public abstract class OperationResults {              int duration, color;              // Not an overall failure -            if ((resultType & ImportResult.RESULT_ERROR) == 0) { +            if ((resultType & OperationResultParcel.RESULT_ERROR) == 0) {                  String withWarnings;                  // Any warnings? @@ -157,7 +157,8 @@ public abstract class OperationResults {                          }                  ));              } -            toast.show(); + +            return toast;          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java index 7ac229b91..301b4ad40 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java @@ -41,8 +41,6 @@ import android.widget.ListView;  import android.widget.Spinner;  import android.widget.TextView; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.helper.Preferences; @@ -52,10 +50,12 @@ import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.provider.KeychainContract.UserIds;  import org.sufficientlysecure.keychain.service.KeychainIntentService;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; +import org.sufficientlysecure.keychain.service.OperationResultParcel;  import org.sufficientlysecure.keychain.service.PassphraseCacheService;  import org.sufficientlysecure.keychain.ui.adapter.UserIdsAdapter;  import org.sufficientlysecure.keychain.ui.dialog.PassphraseDialogFragment;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import java.util.ArrayList; @@ -246,8 +246,8 @@ public class CertifyKeyActivity extends ActionBarActivity implements          // Bail out if there is not at least one user id selected          ArrayList<String> userIds = mUserIdsAdapter.getSelectedUserIds();          if (userIds.isEmpty()) { -            AppMsg.makeText(CertifyKeyActivity.this, "No User IDs to sign selected!", -                    AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(CertifyKeyActivity.this, "No Notify.Style IDs to sign selected!", +                    Notify.Style.ERROR);              return;          } @@ -274,8 +274,8 @@ public class CertifyKeyActivity extends ActionBarActivity implements                  if (message.arg1 == KeychainIntentServiceHandler.MESSAGE_OKAY) { -                    AppMsg.makeText(CertifyKeyActivity.this, R.string.key_certify_success, -                            AppMsg.STYLE_INFO).show(); +                    Notify.showNotify(CertifyKeyActivity.this, R.string.key_certify_success, +                            Notify.Style.INFO);                      // check if we need to send the key to the server or not                      if (mUploadKeyCheckbox.isChecked()) { @@ -327,8 +327,10 @@ public class CertifyKeyActivity extends ActionBarActivity implements                  super.handleMessage(message);                  if (message.arg1 == KeychainIntentServiceHandler.MESSAGE_OKAY) { -                    AppMsg.makeText(CertifyKeyActivity.this, R.string.key_send_success, -                            AppMsg.STYLE_INFO).show(); +                    Intent intent = new Intent(); +                    intent.putExtra(OperationResultParcel.EXTRA_RESULT, message.getData()); +                    Notify.showNotify(CertifyKeyActivity.this, R.string.key_send_success, +                            Notify.Style.INFO);                      setResult(RESULT_OK);                      finish(); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFileFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFileFragment.java index c12b5b7be..56dfdbd95 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFileFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFileFragment.java @@ -34,8 +34,6 @@ import android.widget.CheckBox;  import android.widget.EditText;  import android.widget.ImageButton; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.helper.FileHelper; @@ -129,7 +127,6 @@ public class DecryptFileFragment extends DecryptFragment {          }          if (mInputFilename.equals("")) { -            //AppMsg.makeText(getActivity(), R.string.no_file_selected, AppMsg.STYLE_ALERT).show();              Notify.showNotify(getActivity(), R.string.no_file_selected, Notify.Style.ERROR);              return;          } @@ -137,11 +134,8 @@ public class DecryptFileFragment extends DecryptFragment {          if (mInputUri == null && mInputFilename.startsWith("file")) {              File file = new File(mInputFilename);              if (!file.exists() || !file.isFile()) { -                AppMsg.makeText( -                        getActivity(), -                        getString(R.string.error_message, -                                getString(R.string.error_file_not_found)), AppMsg.STYLE_ALERT) -                        .show(); +                Notify.showNotify(getActivity(), getString(R.string.error_message, +                                getString(R.string.error_file_not_found)), Notify.Style.ERROR);                  return;              }          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptMessageFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptMessageFragment.java index 46462f924..cf7a0b4b8 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptMessageFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptMessageFragment.java @@ -28,8 +28,6 @@ import android.view.View.OnClickListener;  import android.view.ViewGroup;  import android.widget.EditText; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.compatibility.ClipboardReflection; @@ -38,6 +36,7 @@ import org.sufficientlysecure.keychain.pgp.PgpHelper;  import org.sufficientlysecure.keychain.service.KeychainIntentService;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import java.util.regex.Matcher; @@ -107,12 +106,10 @@ public class DecryptMessageFragment extends DecryptFragment {                  mCiphertext = matcher.group(1);                  decryptStart(null);              } else { -                AppMsg.makeText(getActivity(), R.string.error_invalid_data, AppMsg.STYLE_ALERT) -                        .show(); +                Notify.showNotify(getActivity(), R.string.error_invalid_data, Notify.Style.ERROR);              }          } else { -            AppMsg.makeText(getActivity(), R.string.error_invalid_data, AppMsg.STYLE_ALERT) -                    .show(); +            Notify.showNotify(getActivity(), R.string.error_invalid_data, Notify.Style.ERROR);          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyActivityOld.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyActivityOld.java deleted file mode 100644 index 70ccb8800..000000000 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyActivityOld.java +++ /dev/null @@ -1,744 +0,0 @@ -/* - * Copyright (C) 2012-2014 Dominik Schürmann <dominik@dominikschuermann.de> - * Copyright (C) 2010-2014 Thialfihar <thi@thialfihar.org> - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program.  If not, see <http://www.gnu.org/licenses/>. - */ - -package org.sufficientlysecure.keychain.ui; - -import android.content.Context; -import android.content.DialogInterface; -import android.content.Intent; -import android.net.Uri; -import android.os.Bundle; -import android.os.Handler; -import android.os.Message; -import android.os.Messenger; -import android.support.v4.app.ActivityCompat; -import android.support.v7.app.ActionBarActivity; -import android.view.LayoutInflater; -import android.view.View; -import android.view.View.OnClickListener; -import android.view.ViewGroup; -import android.widget.Button; -import android.widget.CheckBox; -import android.widget.CompoundButton; -import android.widget.CompoundButton.OnCheckedChangeListener; -import android.widget.LinearLayout; -import android.widget.Toast; - -import com.devspark.appmsg.AppMsg; - -import org.sufficientlysecure.keychain.Constants; -import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.helper.ActionBarHelper; -import org.sufficientlysecure.keychain.helper.ExportHelper; -import org.sufficientlysecure.keychain.pgp.KeyRing; -import org.sufficientlysecure.keychain.pgp.UncachedSecretKey; -import org.sufficientlysecure.keychain.pgp.WrappedSecretKey; -import org.sufficientlysecure.keychain.pgp.WrappedSecretKeyRing; -import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException; -import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings; -import org.sufficientlysecure.keychain.provider.ProviderHelper; -import org.sufficientlysecure.keychain.service.PassphraseCacheService; -import org.sufficientlysecure.keychain.ui.dialog.CustomAlertDialogBuilder; -import org.sufficientlysecure.keychain.ui.dialog.PassphraseDialogFragment; -import org.sufficientlysecure.keychain.ui.dialog.SetPassphraseDialogFragment; -import org.sufficientlysecure.keychain.ui.widget.Editor; -import org.sufficientlysecure.keychain.ui.widget.Editor.EditorListener; -import org.sufficientlysecure.keychain.ui.widget.KeyEditor; -import org.sufficientlysecure.keychain.ui.widget.SectionView; -import org.sufficientlysecure.keychain.ui.widget.UserIdEditor; -import org.sufficientlysecure.keychain.util.Log; - -import java.util.ArrayList; -import java.util.Calendar; -import java.util.List; -import java.util.Vector; - -public class EditKeyActivityOld extends ActionBarActivity implements EditorListener { - -    // Actions for internal use only: -    public static final String ACTION_CREATE_KEY = Constants.INTENT_PREFIX + "CREATE_KEY"; -    public static final String ACTION_EDIT_KEY = Constants.INTENT_PREFIX + "EDIT_KEY"; - -    // possible extra keys -    public static final String EXTRA_USER_IDS = "user_ids"; -    public static final String EXTRA_NO_PASSPHRASE = "no_passphrase"; -    public static final String EXTRA_GENERATE_DEFAULT_KEYS = "generate_default_keys"; - -    // EDIT -    private Uri mDataUri; - -    private SectionView mUserIdsView; -    private SectionView mKeysView; - -    private String mCurrentPassphrase = null; -    private String mNewPassphrase = null; -    private String mSavedNewPassphrase = null; -    private boolean mIsPassphraseSet; -    private boolean mNeedsSaving; -    private boolean mIsBrandNewKeyring = false; - -    private Button mChangePassphrase; - -    private CheckBox mNoPassphrase; - -    Vector<String> mUserIds; -    Vector<UncachedSecretKey> mKeys; -    Vector<Integer> mKeysUsages; -    boolean mMasterCanSign = true; - -    ExportHelper mExportHelper; - -    public boolean needsSaving() { -        mNeedsSaving = (mUserIdsView == null) ? false : mUserIdsView.needsSaving(); -        mNeedsSaving |= (mKeysView == null) ? false : mKeysView.needsSaving(); -        mNeedsSaving |= hasPassphraseChanged(); -        mNeedsSaving |= mIsBrandNewKeyring; -        return mNeedsSaving; -    } - - -    public void somethingChanged() { -        ActivityCompat.invalidateOptionsMenu(this); -    } - -    public void onDeleted(Editor e, boolean wasNewItem) { -        somethingChanged(); -    } - -    public void onEdited() { -        somethingChanged(); -    } - -    @Override -    public void onCreate(Bundle savedInstanceState) { -        super.onCreate(savedInstanceState); - -        mExportHelper = new ExportHelper(this); - -        // Inflate a "Done"/"Cancel" custom action bar view -        ActionBarHelper.setTwoButtonView(getSupportActionBar(), -                R.string.btn_save, R.drawable.ic_action_save, -                new View.OnClickListener() { -                    @Override -                    public void onClick(View v) { -                        // Save -                        saveClicked(); -                    } -                }, R.string.menu_key_edit_cancel, R.drawable.ic_action_cancel, -                new View.OnClickListener() { -                    @Override -                    public void onClick(View v) { -                        // Cancel -                        cancelClicked(); -                    } -                } -        ); - -        mUserIds = new Vector<String>(); -        mKeys = new Vector<UncachedSecretKey>(); -        mKeysUsages = new Vector<Integer>(); - -        // Catch Intents opened from other apps -        Intent intent = getIntent(); -        String action = intent.getAction(); -        if (ACTION_CREATE_KEY.equals(action)) { -            handleActionCreateKey(intent); -        } else if (ACTION_EDIT_KEY.equals(action)) { -            handleActionEditKey(intent); -        } -    } - -    /** -     * Handle intent action to create new key -     * -     * @param intent -     */ -    private void handleActionCreateKey(Intent intent) { -        Bundle extras = intent.getExtras(); - -        mCurrentPassphrase = ""; -        mIsBrandNewKeyring = true; - -        if (extras != null) { -            // if userId is given, prefill the fields -            if (extras.containsKey(EXTRA_USER_IDS)) { -                Log.d(Constants.TAG, "UserIds are given!"); -                mUserIds.add(extras.getString(EXTRA_USER_IDS)); -            } - -            // if no passphrase is given -            if (extras.containsKey(EXTRA_NO_PASSPHRASE)) { -                boolean noPassphrase = extras.getBoolean(EXTRA_NO_PASSPHRASE); -                if (noPassphrase) { -                    // check "no passphrase" checkbox and remove button -                    mNoPassphrase.setChecked(true); -                    mChangePassphrase.setVisibility(View.GONE); -                } -            } - -            // generate key -            if (extras.containsKey(EXTRA_GENERATE_DEFAULT_KEYS)) { -                /* -                boolean generateDefaultKeys = extras.getBoolean(EXTRA_GENERATE_DEFAULT_KEYS); -                if (generateDefaultKeys) { - -                    // fill values for this action -                    Bundle data = new Bundle(); -                    data.putString(KeychainIntentService.GENERATE_KEY_SYMMETRIC_PASSPHRASE, -                            mCurrentPassphrase); - -                    serviceIntent.putExtra(KeychainIntentService.EXTRA_DATA, data); - -                    // Message is received after generating is done in KeychainIntentService -                    KeychainIntentServiceHandler saveHandler = new KeychainIntentServiceHandler( -                            this, getResources().getQuantityString(R.plurals.progress_generating, 1), -                            ProgressDialog.STYLE_HORIZONTAL, true, - -                            new DialogInterface.OnCancelListener() { -                                @Override -                                public void onCancel(DialogInterface dialog) { -                                    // Stop key generation on cancel -                                    stopService(serviceIntent); -                                    EditKeyActivity.this.setResult(Activity.RESULT_CANCELED); -                                    EditKeyActivity.this.finish(); -                                } -                            }) { - -                        @Override -                        public void handleMessage(Message message) { -                            // handle messages by standard KeychainIntentServiceHandler first -                            super.handleMessage(message); - -                            if (message.arg1 == KeychainIntentServiceHandler.MESSAGE_OKAY) { -                                // get new key from data bundle returned from service -                                Bundle data = message.getDataAsStringList(); - -                                ArrayList<UncachedSecretKey> newKeys = -                                        PgpConversionHelper.BytesToPGPSecretKeyList(data -                                                .getByteArray(KeychainIntentService.RESULT_NEW_KEY)); - -                                ArrayList<Integer> keyUsageFlags = data.getIntegerArrayList( -                                        KeychainIntentService.RESULT_KEY_USAGES); - -                                if (newKeys.size() == keyUsageFlags.size()) { -                                    for (int i = 0; i < newKeys.size(); ++i) { -                                        mKeys.add(newKeys.get(i)); -                                        mKeysUsages.add(keyUsageFlags.get(i)); -                                    } -                                } - -                                buildLayout(true); -                            } -                        } -                    }; - -                    // Create a new Messenger for the communication back -                    Messenger messenger = new Messenger(saveHandler); -                    serviceIntent.putExtra(KeychainIntentService.EXTRA_MESSENGER, messenger); - -                    saveHandler.showProgressDialog(this); - -                    // start service with intent -                    startService(serviceIntent); -                } -                */ -            } -        } else { -            buildLayout(false); -        } -    } - -    /** -     * Handle intent action to edit existing key -     * -     * @param intent -     */ -    private void handleActionEditKey(Intent intent) { -        mDataUri = intent.getData(); -        if (mDataUri == null) { -            Log.e(Constants.TAG, "Intent data missing. Should be Uri of key!"); -            finish(); -        } else { -            Log.d(Constants.TAG, "uri: " + mDataUri); - -            try { -                Uri secretUri = KeyRings.buildUnifiedKeyRingUri(mDataUri); -                WrappedSecretKeyRing keyRing = new ProviderHelper(this).getWrappedSecretKeyRing(secretUri); - -                mMasterCanSign = keyRing.getSecretKey().canCertify(); -                for (WrappedSecretKey key : keyRing.secretKeyIterator()) { -                    // Turn into uncached instance -                    mKeys.add(key.getUncached()); -                    mKeysUsages.add(key.getKeyUsage()); // get usage when view is created -                } - -                boolean isSet = false; -                for (String userId : keyRing.getSecretKey().getUserIds()) { -                    Log.d(Constants.TAG, "Added userId " + userId); -                    if (!isSet) { -                        isSet = true; -                        String[] parts = KeyRing.splitUserId(userId); -                        if (parts[0] != null) { -                            setTitle(parts[0]); -                        } -                    } -                    mUserIds.add(userId); -                } - -                buildLayout(false); - -                mCurrentPassphrase = ""; -                mIsPassphraseSet = keyRing.hasPassphrase(); -                if (!mIsPassphraseSet) { -                    // check "no passphrase" checkbox and remove button -                    mNoPassphrase.setChecked(true); -                    mChangePassphrase.setVisibility(View.GONE); -                } - -            } catch (ProviderHelper.NotFoundException e) { -                Log.e(Constants.TAG, "Keyring not found: " + e.getMessage(), e); -                Toast.makeText(this, R.string.error_no_secret_key_found, Toast.LENGTH_SHORT).show(); -                finish(); -            } - -        } -    } - -    /** -     * Shows the dialog to set a new passphrase -     */ -    private void showSetPassphraseDialog() { -        // Message is received after passphrase is cached -        Handler returnHandler = new Handler() { -            @Override -            public void handleMessage(Message message) { -                if (message.what == SetPassphraseDialogFragment.MESSAGE_OKAY) { -                    Bundle data = message.getData(); - -                    // set new returned passphrase! -                    mNewPassphrase = data -                            .getString(SetPassphraseDialogFragment.MESSAGE_NEW_PASSPHRASE); - -                    updatePassphraseButtonText(); -                    somethingChanged(); -                } -            } -        }; - -        // Create a new Messenger for the communication back -        Messenger messenger = new Messenger(returnHandler); - -        // set title based on isPassphraseSet() -        int title; -        if (isPassphraseSet()) { -            title = R.string.title_change_passphrase; -        } else { -            title = R.string.title_set_passphrase; -        } - -        SetPassphraseDialogFragment setPassphraseDialog = SetPassphraseDialogFragment.newInstance( -                messenger, null, title); - -        setPassphraseDialog.show(getSupportFragmentManager(), "setPassphraseDialog"); -    } - -    /** -     * Build layout based on mUserId, mKeys and mKeysUsages Vectors. It creates Views for every user -     * id and key. -     * -     * @param newKeys -     */ -    private void buildLayout(boolean newKeys) { -        setContentView(R.layout.edit_key_activity); - -        // find views -        mChangePassphrase = (Button) findViewById(R.id.edit_key_btn_change_passphrase); -        mNoPassphrase = (CheckBox) findViewById(R.id.edit_key_no_passphrase); -        // Build layout based on given userIds and keys - -        LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE); - -        LinearLayout container = (LinearLayout) findViewById(R.id.edit_key_container); -        if (mIsPassphraseSet) { -            mChangePassphrase.setText(getString(R.string.btn_change_passphrase)); -        } -        mUserIdsView = (SectionView) inflater.inflate(R.layout.edit_key_section, container, false); -        mUserIdsView.setType(SectionView.TYPE_USER_ID); -        mUserIdsView.setCanBeEdited(mMasterCanSign); -        mUserIdsView.setUserIds(mUserIds); -        mUserIdsView.setEditorListener(this); -        container.addView(mUserIdsView); -        mKeysView = (SectionView) inflater.inflate(R.layout.edit_key_section, container, false); -        mKeysView.setType(SectionView.TYPE_KEY); -        mKeysView.setCanBeEdited(mMasterCanSign); -        mKeysView.setKeys(mKeys, mKeysUsages, newKeys); -        mKeysView.setEditorListener(this); -        container.addView(mKeysView); - -        updatePassphraseButtonText(); - -        mChangePassphrase.setOnClickListener(new OnClickListener() { -            public void onClick(View v) { -                showSetPassphraseDialog(); -            } -        }); - -        // disable passphrase when no passphrase checkbox is checked! -        mNoPassphrase.setOnCheckedChangeListener(new OnCheckedChangeListener() { - -            @Override -            public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { -                if (isChecked) { -                    // remove passphrase -                    mSavedNewPassphrase = mNewPassphrase; -                    mNewPassphrase = ""; -                    mChangePassphrase.setVisibility(View.GONE); -                } else { -                    mNewPassphrase = mSavedNewPassphrase; -                    mChangePassphrase.setVisibility(View.VISIBLE); -                } -                somethingChanged(); -            } -        }); -    } - -    private long getMasterKeyId() { -        if (mKeysView.getEditors().getChildCount() == 0) { -            return 0; -        } -        return ((KeyEditor) mKeysView.getEditors().getChildAt(0)).getValue().getKeyId(); -    } - -    public boolean isPassphraseSet() { -        if (mNoPassphrase.isChecked()) { -            return true; -        } else if ((mIsPassphraseSet) -                || (mNewPassphrase != null && !mNewPassphrase.equals(""))) { -            return true; -        } else { -            return false; -        } -    } - -    public boolean hasPassphraseChanged() { -        if (mNoPassphrase != null) { -            if (mNoPassphrase.isChecked()) { -                return mIsPassphraseSet; -            } else { -                return (mNewPassphrase != null && !mNewPassphrase.equals("")); -            } -        } else { -            return false; -        } -    } - -    private void saveClicked() { -        final long masterKeyId = getMasterKeyId(); -        if (needsSaving()) { //make sure, as some versions don't support invalidateOptionsMenu -            try { -                if (!isPassphraseSet()) { -                    throw new PgpGeneralException(this.getString(R.string.set_a_passphrase)); -                } - -                String passphrase; -                if (mIsPassphraseSet) { -                    passphrase = PassphraseCacheService.getCachedPassphrase(this, masterKeyId); -                } else { -                    passphrase = ""; -                } -                if (passphrase == null) { -                    PassphraseDialogFragment.show(this, masterKeyId, -                            new Handler() { -                                @Override -                                public void handleMessage(Message message) { -                                    if (message.what == PassphraseDialogFragment.MESSAGE_OKAY) { -                                        mCurrentPassphrase = PassphraseCacheService.getCachedPassphrase( -                                                EditKeyActivityOld.this, masterKeyId); -                                        checkEmptyIDsWanted(); -                                    } -                                } -                            }); -                } else { -                    mCurrentPassphrase = passphrase; -                    checkEmptyIDsWanted(); -                } -            } catch (PgpGeneralException e) { -                AppMsg.makeText(this, getString(R.string.error_message, e.getMessage()), -                        AppMsg.STYLE_ALERT).show(); -            } -        } else { -            AppMsg.makeText(this, R.string.error_change_something_first, AppMsg.STYLE_ALERT).show(); -        } -    } - -    private void checkEmptyIDsWanted() { -        try { -            ArrayList<String> userIDs = getUserIds(mUserIdsView); -            List<Boolean> newIDs = mUserIdsView.getNewIDFlags(); -            ArrayList<String> originalIDs = mUserIdsView.getOriginalIDs(); -            int curID = 0; -            for (String userID : userIDs) { -                if (userID.equals("") && (!userID.equals(originalIDs.get(curID)) || newIDs.get(curID))) { -                    CustomAlertDialogBuilder alert = new CustomAlertDialogBuilder( -                            EditKeyActivityOld.this); - -                    alert.setIcon(R.drawable.ic_dialog_alert_holo_light); -                    alert.setTitle(R.string.warning); -                    alert.setMessage(EditKeyActivityOld.this.getString(R.string.ask_empty_id_ok)); - -                    alert.setPositiveButton(EditKeyActivityOld.this.getString(android.R.string.yes), -                            new DialogInterface.OnClickListener() { -                                public void onClick(DialogInterface dialog, int id) { -                                    dialog.dismiss(); -                                    finallySaveClicked(); -                                } -                            } -                    ); -                    alert.setNegativeButton(this.getString(android.R.string.no), -                            new DialogInterface.OnClickListener() { -                                public void onClick(DialogInterface dialog, int id) { -                                    dialog.dismiss(); -                                } -                            } -                    ); -                    alert.setCancelable(false); -                    alert.show(); -                    return; -                } -                curID++; -            } -        } catch (PgpGeneralException e) { -            Log.e(Constants.TAG, getString(R.string.error_message, e.getMessage())); -            AppMsg.makeText(this, getString(R.string.error_message, e.getMessage()), AppMsg.STYLE_ALERT).show(); -        } -        finallySaveClicked(); -    } - -    private boolean[] toPrimitiveArray(final List<Boolean> booleanList) { -        final boolean[] primitives = new boolean[booleanList.size()]; -        int index = 0; -        for (Boolean object : booleanList) { -            primitives[index++] = object; -        } -        return primitives; -    } - -    private void finallySaveClicked() { -            /* -        try { -            // Send all information needed to service to edit key in other thread -            Intent intent = new Intent(this, KeychainIntentService.class); - -            intent.setAction(KeychainIntentService.ACTION_SAVE_KEYRING); - -            OldSaveKeyringParcel saveParams = new OldSaveKeyringParcel(); -            saveParams.userIds = getUserIds(mUserIdsView); -            saveParams.originalIDs = mUserIdsView.getOriginalIDs(); -            saveParams.deletedIDs = mUserIdsView.getDeletedIDs(); -            saveParams.newIDs = toPrimitiveArray(mUserIdsView.getNewIDFlags()); -            saveParams.primaryIDChanged = mUserIdsView.primaryChanged(); -            saveParams.moddedKeys = toPrimitiveArray(mKeysView.getNeedsSavingArray()); -            saveParams.deletedKeys = mKeysView.getDeletedKeys(); -            saveParams.keysExpiryDates = getKeysExpiryDates(mKeysView); -            saveParams.keysUsages = getKeysUsages(mKeysView); -            saveParams.mNewPassphrase = mNewPassphrase; -            saveParams.oldPassphrase = mCurrentPassphrase; -            saveParams.newKeys = toPrimitiveArray(mKeysView.getNewKeysArray()); -            saveParams.keys = getKeys(mKeysView); -            saveParams.originalPrimaryID = mUserIdsView.getOriginalPrimaryID(); - -            // fill values for this action -            Bundle data = new Bundle(); -            data.putBoolean(KeychainIntentService.SAVE_KEYRING_CAN_SIGN, mMasterCanSign); -            data.putParcelable(KeychainIntentService.SAVE_KEYRING_PARCEL, saveParams); - -            intent.putExtra(KeychainIntentService.EXTRA_DATA, data); - -            // Message is received after saving is done in KeychainIntentService -            KeychainIntentServiceHandler saveHandler = new KeychainIntentServiceHandler(this, -                    getString(R.string.progress_saving), ProgressDialog.STYLE_HORIZONTAL) { -                public void handleMessage(Message message) { -                    // handle messages by standard KeychainIntentServiceHandler first -                    super.handleMessage(message); - -                    if (message.arg1 == KeychainIntentServiceHandler.MESSAGE_OKAY) { -                        Intent data = new Intent(); - -                        // return uri pointing to new created key -                        Uri uri = KeyRings.buildGenericKeyRingUri(getMasterKeyId()); -                        data.setData(uri); - -                        setResult(RESULT_OK, data); -                        finish(); -                    } -                } -            }; - -            // Create a new Messenger for the communication back -            Messenger messenger = new Messenger(saveHandler); -            intent.putExtra(KeychainIntentService.EXTRA_MESSENGER, messenger); - -            saveHandler.showProgressDialog(this); - -            // start service with intent -            startService(intent); -        } catch (PgpGeneralException e) { -            Log.e(Constants.TAG, getString(R.string.error_message, e.getMessage())); -            AppMsg.makeText(this, getString(R.string.error_message, e.getMessage()), -                    AppMsg.STYLE_ALERT).show(); -        } -            */ -    } - -    private void cancelClicked() { -        if (needsSaving()) { //ask if we want to save -            CustomAlertDialogBuilder alert = new CustomAlertDialogBuilder( -                    EditKeyActivityOld.this); - -            alert.setIcon(R.drawable.ic_dialog_alert_holo_light); -            alert.setTitle(R.string.warning); -            alert.setMessage(EditKeyActivityOld.this.getString(R.string.ask_save_changed_key)); - -            alert.setPositiveButton(EditKeyActivityOld.this.getString(android.R.string.yes), -                    new DialogInterface.OnClickListener() { -                        public void onClick(DialogInterface dialog, int id) { -                            dialog.dismiss(); -                            saveClicked(); -                        } -                    }); -            alert.setNegativeButton(this.getString(android.R.string.no), -                    new DialogInterface.OnClickListener() { -                        public void onClick(DialogInterface dialog, int id) { -                            dialog.dismiss(); -                            setResult(RESULT_CANCELED); -                            finish(); -                        } -                    }); -            alert.setCancelable(false); -            alert.show(); -        } else { -            setResult(RESULT_CANCELED); -            finish(); -        } -    } - -    /** -     * Returns user ids from the SectionView -     * -     * @param userIdsView -     * @return -     */ -    private ArrayList<String> getUserIds(SectionView userIdsView) throws PgpGeneralException { -        ArrayList<String> userIds = new ArrayList<String>(); - -        ViewGroup userIdEditors = userIdsView.getEditors(); - -        boolean gotMainUserId = false; -        for (int i = 0; i < userIdEditors.getChildCount(); ++i) { -            UserIdEditor editor = (UserIdEditor) userIdEditors.getChildAt(i); -            String userId; -            userId = editor.getValue(); - -            if (editor.isMainUserId()) { -                userIds.add(0, userId); -                gotMainUserId = true; -            } else { -                userIds.add(userId); -            } -        } - -        if (userIds.size() == 0) { -            throw new PgpGeneralException(getString(R.string.error_key_needs_a_user_id)); -        } - -        if (!gotMainUserId) { -            throw new PgpGeneralException(getString(R.string.error_main_user_id_must_not_be_empty)); -        } - -        return userIds; -    } - -    /** -     * Returns keys from the SectionView -     * -     * @param keysView -     * @return -     */ -    private ArrayList<UncachedSecretKey> getKeys(SectionView keysView) throws PgpGeneralException { -        ArrayList<UncachedSecretKey> keys = new ArrayList<UncachedSecretKey>(); - -        ViewGroup keyEditors = keysView.getEditors(); - -        if (keyEditors.getChildCount() == 0) { -            throw new PgpGeneralException(getString(R.string.error_key_needs_master_key)); -        } - -        for (int i = 0; i < keyEditors.getChildCount(); ++i) { -            KeyEditor editor = (KeyEditor) keyEditors.getChildAt(i); -            keys.add(editor.getValue()); -        } - -        return keys; -    } - -    /** -     * Returns usage selections of keys from the SectionView -     * -     * @param keysView -     * @return -     */ -    private ArrayList<Integer> getKeysUsages(SectionView keysView) throws PgpGeneralException { -        ArrayList<Integer> keysUsages = new ArrayList<Integer>(); - -        ViewGroup keyEditors = keysView.getEditors(); - -        if (keyEditors.getChildCount() == 0) { -            throw new PgpGeneralException(getString(R.string.error_key_needs_master_key)); -        } - -        for (int i = 0; i < keyEditors.getChildCount(); ++i) { -            KeyEditor editor = (KeyEditor) keyEditors.getChildAt(i); -            keysUsages.add(editor.getUsage()); -        } - -        return keysUsages; -    } - -    private ArrayList<Calendar> getKeysExpiryDates(SectionView keysView) throws PgpGeneralException { -        ArrayList<Calendar> keysExpiryDates = new ArrayList<Calendar>(); - -        ViewGroup keyEditors = keysView.getEditors(); - -        if (keyEditors.getChildCount() == 0) { -            throw new PgpGeneralException(getString(R.string.error_key_needs_master_key)); -        } - -        for (int i = 0; i < keyEditors.getChildCount(); ++i) { -            KeyEditor editor = (KeyEditor) keyEditors.getChildAt(i); -            keysExpiryDates.add(editor.getExpiryDate()); -        } - -        return keysExpiryDates; -    } - -    private void updatePassphraseButtonText() { -        mChangePassphrase.setText(isPassphraseSet() ? getString(R.string.btn_change_passphrase) -                : getString(R.string.btn_set_passphrase)); -    } - -} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFileFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFileFragment.java index f5d89d186..6ff8d421b 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFileFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFileFragment.java @@ -37,8 +37,6 @@ import android.widget.EditText;  import android.widget.ImageButton;  import android.widget.Spinner; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.helper.FileHelper; @@ -51,6 +49,7 @@ import org.sufficientlysecure.keychain.ui.dialog.FileDialogFragment;  import org.sufficientlysecure.keychain.ui.dialog.PassphraseDialogFragment;  import org.sufficientlysecure.keychain.util.Choice;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import java.io.File; @@ -218,18 +217,18 @@ public class EncryptFileFragment extends Fragment {          }          if (mInputFilename.equals("")) { -            AppMsg.makeText(getActivity(), R.string.no_file_selected, AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(getActivity(), R.string.no_file_selected, Notify.Style.ERROR);              return;          }          if (mInputUri == null && !mInputFilename.startsWith("content")) {              File file = new File(mInputFilename);              if (!file.exists() || !file.isFile()) { -                AppMsg.makeText( +                Notify.showNotify(                          getActivity(),                          getString(R.string.error_message, -                                getString(R.string.error_file_not_found)), AppMsg.STYLE_ALERT) -                        .show(); +                                getString(R.string.error_file_not_found)), Notify.Style.ERROR +                );                  return;              }          } @@ -240,13 +239,13 @@ public class EncryptFileFragment extends Fragment {              boolean gotPassphrase = (mEncryptInterface.getPassphrase() != null                      && mEncryptInterface.getPassphrase().length() != 0);              if (!gotPassphrase) { -                AppMsg.makeText(getActivity(), R.string.passphrase_must_not_be_empty, AppMsg.STYLE_ALERT) -                        .show(); +                Notify.showNotify(getActivity(), R.string.passphrase_must_not_be_empty, Notify.Style.ERROR) +                        ;                  return;              }              if (!mEncryptInterface.getPassphrase().equals(mEncryptInterface.getPassphraseAgain())) { -                AppMsg.makeText(getActivity(), R.string.passphrases_do_not_match, AppMsg.STYLE_ALERT).show(); +                Notify.showNotify(getActivity(), R.string.passphrases_do_not_match, Notify.Style.ERROR);                  return;              }          } else { @@ -256,13 +255,13 @@ public class EncryptFileFragment extends Fragment {                      && mEncryptInterface.getEncryptionKeys().length > 0);              if (!gotEncryptionKeys) { -                AppMsg.makeText(getActivity(), R.string.select_encryption_key, AppMsg.STYLE_ALERT).show(); +                Notify.showNotify(getActivity(), R.string.select_encryption_key, Notify.Style.ERROR);                  return;              }              if (!gotEncryptionKeys && mEncryptInterface.getSignatureKey() == 0) { -                AppMsg.makeText(getActivity(), R.string.select_encryption_or_signature_key, -                        AppMsg.STYLE_ALERT).show(); +                Notify.showNotify(getActivity(), R.string.select_encryption_or_signature_key, +                        Notify.Style.ERROR);                  return;              } @@ -345,8 +344,8 @@ public class EncryptFileFragment extends Fragment {                  super.handleMessage(message);                  if (message.arg1 == KeychainIntentServiceHandler.MESSAGE_OKAY) { -                    AppMsg.makeText(getActivity(), R.string.encrypt_sign_successful, -                            AppMsg.STYLE_INFO).show(); +                    Notify.showNotify(getActivity(), R.string.encrypt_sign_successful, +                            Notify.Style.INFO);                      if (mDeleteAfter.isChecked()) {                          // Create and show dialog to delete original file diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptMessageFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptMessageFragment.java index 8a6103b16..e1760b4ed 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptMessageFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptMessageFragment.java @@ -30,8 +30,6 @@ import android.view.View;  import android.view.ViewGroup;  import android.widget.TextView; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.compatibility.ClipboardReflection; @@ -41,6 +39,7 @@ import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler;  import org.sufficientlysecure.keychain.service.PassphraseCacheService;  import org.sufficientlysecure.keychain.ui.dialog.PassphraseDialogFragment;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  public class EncryptMessageFragment extends Fragment {      public static final String ARG_TEXT = "text"; @@ -126,13 +125,12 @@ public class EncryptMessageFragment extends Fragment {              boolean gotPassphrase = (mEncryptInterface.getPassphrase() != null                      && mEncryptInterface.getPassphrase().length() != 0);              if (!gotPassphrase) { -                AppMsg.makeText(getActivity(), R.string.passphrase_must_not_be_empty, AppMsg.STYLE_ALERT) -                        .show(); +                Notify.showNotify(getActivity(), R.string.passphrase_must_not_be_empty, Notify.Style.ERROR);                  return;              }              if (!mEncryptInterface.getPassphrase().equals(mEncryptInterface.getPassphraseAgain())) { -                AppMsg.makeText(getActivity(), R.string.passphrases_do_not_match, AppMsg.STYLE_ALERT).show(); +                Notify.showNotify(getActivity(), R.string.passphrases_do_not_match, Notify.Style.ERROR);                  return;              } @@ -143,8 +141,8 @@ public class EncryptMessageFragment extends Fragment {                      && mEncryptInterface.getEncryptionKeys().length > 0);              if (!gotEncryptionKeys && mEncryptInterface.getSignatureKey() == 0) { -                AppMsg.makeText(getActivity(), R.string.select_encryption_or_signature_key, -                        AppMsg.STYLE_ALERT).show(); +                Notify.showNotify(getActivity(), R.string.select_encryption_or_signature_key, +                        Notify.Style.ERROR);                  return;              } @@ -226,9 +224,8 @@ public class EncryptMessageFragment extends Fragment {                      if (toClipboard) {                          ClipboardReflection.copyToClipboard(getActivity(), output); -                        AppMsg.makeText(getActivity(), -                                R.string.encrypt_sign_clipboard_successful, AppMsg.STYLE_INFO) -                                .show(); +                        Notify.showNotify(getActivity(), +                                R.string.encrypt_sign_clipboard_successful, Notify.Style.INFO);                      } else {                          Intent sendIntent = new Intent(Intent.ACTION_SEND); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListActivity.java index 095762283..aaf9f7cbf 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListActivity.java @@ -22,8 +22,6 @@ import android.os.Bundle;  import android.view.Menu;  import android.view.MenuItem; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.helper.ExportHelper; @@ -31,6 +29,7 @@ import org.sufficientlysecure.keychain.helper.Preferences;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.provider.KeychainDatabase;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import java.io.IOException; @@ -90,21 +89,21 @@ public class KeyListActivity extends DrawerActivity {              case R.id.menu_key_list_debug_read:                  try {                      KeychainDatabase.debugRead(this); -                    AppMsg.makeText(this, "Restored from backup", AppMsg.STYLE_CONFIRM).show(); +                    Notify.showNotify(this, "Restored Notify.Style backup", Notify.Style.INFO);                      getContentResolver().notifyChange(KeychainContract.KeyRings.CONTENT_URI, null);                  } catch (IOException e) {                      Log.e(Constants.TAG, "IO Error", e); -                    AppMsg.makeText(this, "IO Error: " + e.getMessage(), AppMsg.STYLE_ALERT).show(); +                    Notify.showNotify(this, "IO Notify.Style: " + e.getMessage(), Notify.Style.ERROR);                  }                  return true;              case R.id.menu_key_list_debug_write:                  try {                      KeychainDatabase.debugWrite(this); -                    AppMsg.makeText(this, "Backup successful", AppMsg.STYLE_CONFIRM).show(); -                } catch (IOException e) { +                    Notify.showNotify(this, "Backup Notify.Style", Notify.Style.INFO); +                } catch(IOException e) {                      Log.e(Constants.TAG, "IO Error", e); -                    AppMsg.makeText(this, "IO Error: " + e.getMessage(), AppMsg.STYLE_ALERT).show(); +                    Notify.showNotify(this, "IO Notify.Style: " + e.getMessage(), Notify.Style.ERROR);                  }                  return true; @@ -129,4 +128,4 @@ public class KeyListActivity extends DrawerActivity {          startActivity(intent);      } -}
\ No newline at end of file +} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java index 9d0a80406..c8f6b7b1e 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java @@ -52,8 +52,6 @@ import android.widget.ListView;  import android.widget.TextView;  import android.widget.Button; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.helper.ExportHelper; @@ -62,6 +60,7 @@ import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.ui.dialog.DeleteKeyDialogFragment;  import org.sufficientlysecure.keychain.util.Highlighter;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import java.util.Date;  import java.util.HashMap; @@ -104,10 +103,10 @@ public class KeyListFragment extends LoaderFragment              @Override              public void onClick(View v) { -                Intent intent = new Intent(getActivity(), EditKeyActivityOld.class); -                intent.setAction(EditKeyActivityOld.ACTION_CREATE_KEY); -                intent.putExtra(EditKeyActivityOld.EXTRA_GENERATE_DEFAULT_KEYS, true); -                intent.putExtra(EditKeyActivityOld.EXTRA_USER_IDS, ""); // show user id view +                Intent intent = new Intent(getActivity(), EditKeyActivity.class); +                intent.setAction(EditKeyActivity.ACTION_CREATE_KEY); +                intent.putExtra(EditKeyActivity.EXTRA_GENERATE_DEFAULT_KEYS, true); +                intent.putExtra(EditKeyActivity.EXTRA_USER_IDS, ""); // show user id view                  startActivityForResult(intent, 0);              }          }); @@ -339,8 +338,8 @@ public class KeyListFragment extends LoaderFragment      public void showDeleteKeyDialog(final ActionMode mode, long[] masterKeyIds, boolean hasSecret) {          // Can only work on singular secret keys          if(hasSecret && masterKeyIds.length > 1) { -            AppMsg.makeText(getActivity(), R.string.secret_cannot_multiple, -                    AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(getActivity(), R.string.secret_cannot_multiple, +                    Notify.Style.ERROR);              return;          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java index a9cd0976b..b8b2542ce 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java @@ -44,8 +44,6 @@ import android.view.MenuItem;  import android.view.View;  import android.view.Window; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.helper.ContactHelper; @@ -54,11 +52,13 @@ import org.sufficientlysecure.keychain.pgp.KeyRing;  import org.sufficientlysecure.keychain.pgp.PgpKeyHelper;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.provider.ProviderHelper; +import org.sufficientlysecure.keychain.service.OperationResultParcel;  import org.sufficientlysecure.keychain.service.OperationResults.ImportResult;  import org.sufficientlysecure.keychain.ui.adapter.PagerTabStripAdapter;  import org.sufficientlysecure.keychain.ui.widget.SlidingTabLayout.TabColorizer;  import org.sufficientlysecure.keychain.util.Log;  import org.sufficientlysecure.keychain.ui.widget.SlidingTabLayout; +import org.sufficientlysecure.keychain.util.Notify;  import java.util.Date;  import java.util.HashMap; @@ -295,7 +295,7 @@ public class ViewKeyActivity extends ActionBarActivity implements                  }              }          } catch (ProviderHelper.NotFoundException e) { -            AppMsg.makeText(this, R.string.error_key_not_found, AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(this, R.string.error_key_not_found, Notify.Style.ERROR);              Log.e(Constants.TAG, "Key not found", e);          }          return super.onOptionsItemSelected(item); @@ -352,22 +352,11 @@ public class ViewKeyActivity extends ActionBarActivity implements      @Override      protected void onActivityResult(int requestCode, int resultCode, Intent data) { -        switch (requestCode) { -            case REQUEST_CODE_LOOKUP_KEY: { -                if (resultCode == Activity.RESULT_OK) { -                    ImportResult result = data.getParcelableExtra(ImportKeysActivity.EXTRA_RESULT); -                    if (result != null) { -                        result.displayNotify(this); -                    } -                } -                break; -            } - -            default: { -                super.onActivityResult(requestCode, resultCode, data); - -                break; -            } +        if (data.hasExtra(OperationResultParcel.EXTRA_RESULT)) { +            OperationResultParcel result = data.getParcelableExtra(OperationResultParcel.EXTRA_RESULT); +            result.createNotify(this).show(); +        } else { +            super.onActivityResult(requestCode, resultCode, data);          }      } @@ -455,8 +444,8 @@ public class ViewKeyActivity extends ActionBarActivity implements          public void handleMessage(Message msg) {              switch (msg.what) {                  case NFC_SENT: -                    AppMsg.makeText(ViewKeyActivity.this, R.string.nfc_successful, -                            AppMsg.STYLE_INFO).show(); +                    Notify.showNotify( +                            ViewKeyActivity.this, R.string.nfc_successful, Notify.Style.INFO);                      break;              }          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyMainFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyMainFragment.java index f0636cf2c..2a0f518d8 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyMainFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyMainFragment.java @@ -29,8 +29,6 @@ import android.view.View;  import android.view.ViewGroup;  import android.widget.ListView; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException; @@ -40,6 +38,7 @@ import org.sufficientlysecure.keychain.provider.KeychainContract.UserIds;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.ui.adapter.UserIdsAdapter;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import java.util.Date; @@ -225,7 +224,7 @@ public class ViewKeyMainFragment extends LoaderFragment implements      private void encrypt(Uri dataUri) {          // If there is no encryption key, don't bother.          if (!mHasEncrypt) { -            AppMsg.makeText(getActivity(), R.string.error_no_encrypt_subkey, AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(getActivity(), R.string.error_no_encrypt_subkey, Notify.Style.ERROR);              return;          }          try { @@ -246,7 +245,7 @@ public class ViewKeyMainFragment extends LoaderFragment implements      private void certify(Uri dataUri) {          Intent signIntent = new Intent(getActivity(), CertifyKeyActivity.class);          signIntent.setData(dataUri); -        startActivity(signIntent); +        startActivityForResult(signIntent, 0);      }      private void editKey(Uri dataUri) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java index 52b573f47..c2339c25f 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java @@ -33,8 +33,6 @@ import android.view.ViewGroup;  import android.widget.ImageView;  import android.widget.TextView; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.compatibility.ClipboardReflection; @@ -47,6 +45,7 @@ import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.ui.dialog.ShareNfcDialogFragment;  import org.sufficientlysecure.keychain.ui.dialog.ShareQrCodeDialogFragment;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import org.sufficientlysecure.keychain.util.QrCodeUtils;  import java.io.IOException; @@ -171,13 +170,13 @@ public class ViewKeyShareFragment extends LoaderFragment implements                  } else {                      message = getResources().getString(R.string.key_copied_to_clipboard);                  } -                AppMsg.makeText(getActivity(), message, AppMsg.STYLE_INFO).show(); +                Notify.showNotify(getActivity(), message, Notify.Style.OK);              } else {                  // Android will fail with android.os.TransactionTooLargeException if key is too big                  // see http://www.lonestarprod.com/?p=34                  if (content.length() >= 86389) { -                    AppMsg.makeText(getActivity(), R.string.key_too_big_for_sharing, -                            AppMsg.STYLE_ALERT).show(); +                    Notify.showNotify(getActivity(), R.string.key_too_big_for_sharing, +                            Notify.Style.ERROR);                      return;                  } @@ -195,13 +194,13 @@ public class ViewKeyShareFragment extends LoaderFragment implements              }          } catch (PgpGeneralException e) {              Log.e(Constants.TAG, "error processing key!", e); -            AppMsg.makeText(getActivity(), R.string.error_key_processing, AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(getActivity(), R.string.error_key_processing, Notify.Style.ERROR);          } catch (IOException e) {              Log.e(Constants.TAG, "error processing key!", e); -            AppMsg.makeText(getActivity(), R.string.error_key_processing, AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(getActivity(), R.string.error_key_processing, Notify.Style.ERROR);          } catch (ProviderHelper.NotFoundException e) {              Log.e(Constants.TAG, "key not found!", e); -            AppMsg.makeText(getActivity(), R.string.error_key_not_found, AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(getActivity(), R.string.error_key_not_found, Notify.Style.ERROR);          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/ShareQrCodeDialogFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/ShareQrCodeDialogFragment.java index 24608784b..eb779f401 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/ShareQrCodeDialogFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/ShareQrCodeDialogFragment.java @@ -27,14 +27,13 @@ import android.view.View;  import android.widget.ImageView;  import android.widget.TextView; -import com.devspark.appmsg.AppMsg; -  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.pgp.PgpKeyHelper;  import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.util.Log; +import org.sufficientlysecure.keychain.util.Notify;  import org.sufficientlysecure.keychain.util.QrCodeUtils;  public class ShareQrCodeDialogFragment extends DialogFragment { @@ -87,7 +86,7 @@ public class ShareQrCodeDialogFragment extends DialogFragment {                      KeyRings.FINGERPRINT, ProviderHelper.FIELD_TYPE_BLOB);              if (blob == null) {                  Log.e(Constants.TAG, "key not found!"); -                AppMsg.makeText(getActivity(), R.string.error_key_not_found, AppMsg.STYLE_ALERT).show(); +                Notify.showNotify(getActivity(), R.string.error_key_not_found, Notify.Style.ERROR);                  return null;              } @@ -97,7 +96,7 @@ public class ShareQrCodeDialogFragment extends DialogFragment {              setQrCode(content);          } catch (ProviderHelper.NotFoundException e) {              Log.e(Constants.TAG, "key not found!", e); -            AppMsg.makeText(getActivity(), R.string.error_key_not_found, AppMsg.STYLE_ALERT).show(); +            Notify.showNotify(getActivity(), R.string.error_key_not_found, Notify.Style.ERROR);              return null;          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Notify.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Notify.java index 67f81fb24..22e3f5d66 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Notify.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Notify.java @@ -29,7 +29,7 @@ import com.github.johnpersano.supertoasts.SuperToast;   */  public class Notify { -    public static enum Style {OK, WARN, ERROR} +    public static enum Style {OK, WARN, INFO, ERROR}      /**       * Shows a simple in-layout notification with the CharSequence given as parameter diff --git a/OpenKeychain/src/main/res/layout/certify_key_activity.xml b/OpenKeychain/src/main/res/layout/certify_key_activity.xml index bb43fa805..1443ffd46 100644 --- a/OpenKeychain/src/main/res/layout/certify_key_activity.xml +++ b/OpenKeychain/src/main/res/layout/certify_key_activity.xml @@ -1,6 +1,5 @@  <?xml version="1.0" encoding="UTF-8"?>  <ScrollView xmlns:android="http://schemas.android.com/apk/res/android" -    xmlns:bootstrapbutton="http://schemas.android.com/apk/res-auto"      xmlns:tools="http://schemas.android.com/tools"      android:layout_width="wrap_content"      android:layout_height="match_parent"> diff --git a/OpenKeychain/src/main/res/layout/key_list_activity.xml b/OpenKeychain/src/main/res/layout/key_list_activity.xml index c4c2c35cb..156351887 100644 --- a/OpenKeychain/src/main/res/layout/key_list_activity.xml +++ b/OpenKeychain/src/main/res/layout/key_list_activity.xml @@ -4,6 +4,12 @@      android:layout_width="match_parent"      android:layout_height="match_parent" > +    <LinearLayout +        android:id="@+id/card_container" +        android:layout_width="match_parent" +        android:layout_height="wrap_content" +        android:orientation="vertical" /> +      <include layout="@layout/key_list_content"/>      <include layout="@layout/drawer_list" /> diff --git a/OpenKeychain/src/main/res/values/colors.xml b/OpenKeychain/src/main/res/values/colors.xml index c0042d215..449a09003 100644 --- a/OpenKeychain/src/main/res/values/colors.xml +++ b/OpenKeychain/src/main/res/values/colors.xml @@ -5,6 +5,7 @@      <color name="emphasis_dark">#9933cc</color>      <color name="bg_gray">#cecbce</color>      <color name="tertiary_text_light">#808080</color> +    <color name="alert">#ffdd3333</color>      <color name="holo_gray_light">#33999999</color>      <color name="holo_gray_bright">#33CCCCCC</color> diff --git a/OpenKeychain/src/main/res/values/strings.xml b/OpenKeychain/src/main/res/values/strings.xml index d1a20813b..4519688ac 100644 --- a/OpenKeychain/src/main/res/values/strings.xml +++ b/OpenKeychain/src/main/res/values/strings.xml @@ -686,6 +686,7 @@      <string name="passp_cache_notif_pwd">Password</string>      <!-- unsorted --> +    <string name="internal_error">Internal error!</string>      <string name="section_certifier_id">Certifier</string>      <string name="section_cert">Certificate Details</string>      <string name="label_user_id">Identity</string> @@ -221,10 +221,6 @@ Some parts and some libraries are Apache License v2, MIT X11 License (see below)    https://github.com/Bearded-Hen/Android-Bootstrap      MIT License -* Android AppMsg   -  https://github.com/johnkil/Android-AppMsg   -  Apache License v2 -  ### Images  * icon.svg      modified version of kgpg_key2_kopete.svgz diff --git a/extern/AppMsg b/extern/AppMsg deleted file mode 160000 -Subproject 61e74741909a712db2e0d31ddffa5b7cf37c21f diff --git a/settings.gradle b/settings.gradle index d8802320c..31ee13c8a 100644 --- a/settings.gradle +++ b/settings.gradle @@ -9,7 +9,6 @@ include ':extern:spongycastle:core'  include ':extern:spongycastle:pg'  include ':extern:spongycastle:pkix'  include ':extern:spongycastle:prov' -include ':extern:AppMsg:library'  include ':extern:SuperToasts:supertoasts'  include ':extern:minidns'  include ':extern:KeybaseLib:Lib' | 
