diff options
Diffstat (limited to 'OpenKeychain/src/main')
23 files changed, 483 insertions, 402 deletions
| diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpDecryptVerify.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpDecryptVerify.java index aa85b1082..b2b633ed7 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpDecryptVerify.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpDecryptVerify.java @@ -60,7 +60,6 @@ import java.io.InputStream;  import java.io.OutputStream;  import java.net.URLConnection;  import java.security.SignatureException; -import java.util.Date;  import java.util.Iterator;  import java.util.Set; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpImportExport.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpImportExport.java index 511086489..06415cf8a 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpImportExport.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpImportExport.java @@ -33,11 +33,11 @@ import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.service.KeychainIntentService; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogLevel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogType; -import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog; -import org.sufficientlysecure.keychain.service.OperationResults.ImportKeyResult; -import org.sufficientlysecure.keychain.service.OperationResults.SaveKeyringResult; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogLevel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogType; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.OperationLog; +import org.sufficientlysecure.keychain.service.results.ImportKeyResult; +import org.sufficientlysecure.keychain.service.results.SaveKeyringResult;  import org.sufficientlysecure.keychain.util.IterableIterator;  import org.sufficientlysecure.keychain.util.Log;  import org.sufficientlysecure.keychain.util.ProgressScaler; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java index 9bfea2414..ad592a3e9 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java @@ -46,11 +46,11 @@ import org.spongycastle.openpgp.operator.jcajce.JcePBESecretKeyDecryptorBuilder;  import org.spongycastle.openpgp.operator.jcajce.JcePBESecretKeyEncryptorBuilder;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogLevel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogType; -import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog; -import org.sufficientlysecure.keychain.service.OperationResults.EditKeyResult; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogLevel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogType; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.OperationLog; +import org.sufficientlysecure.keychain.service.results.EditKeyResult;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel.Algorithm;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel.Curve; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java index df5738187..fea314f41 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java @@ -35,9 +35,9 @@ import org.spongycastle.openpgp.PGPUtil;  import org.spongycastle.openpgp.operator.jcajce.JcaKeyFingerprintCalculator;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogLevel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogType; -import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogLevel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogType; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.OperationLog;  import org.sufficientlysecure.keychain.util.IterableIterator;  import org.sufficientlysecure.keychain.util.Log; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java index af7bdb139..f71fcbd80 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java @@ -54,11 +54,11 @@ import org.sufficientlysecure.keychain.provider.KeychainContract.Keys;  import org.sufficientlysecure.keychain.provider.KeychainContract.UserIds;  import org.sufficientlysecure.keychain.remote.AccountSettings;  import org.sufficientlysecure.keychain.remote.AppSettings; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogLevel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogType; -import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog; -import org.sufficientlysecure.keychain.service.OperationResults.ConsolidateResult; -import org.sufficientlysecure.keychain.service.OperationResults.SaveKeyringResult; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogLevel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogType; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.OperationLog; +import org.sufficientlysecure.keychain.service.results.ConsolidateResult; +import org.sufficientlysecure.keychain.service.results.SaveKeyringResult;  import org.sufficientlysecure.keychain.util.ParcelableFileCache;  import org.sufficientlysecure.keychain.util.IterableIterator;  import org.sufficientlysecure.keychain.util.Log; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java index 46a557da3..4bf750121 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java @@ -30,8 +30,7 @@ import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.helper.ActionBarHelper;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.remote.AccountSettings; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.ui.CertifyKeyActivity; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel;  import org.sufficientlysecure.keychain.util.Log;  public class AccountSettingsActivity extends ActionBarActivity { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsFragment.java index 04c202019..d21d83574 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsFragment.java @@ -26,19 +26,15 @@ import android.view.View;  import android.view.ViewGroup;  import android.widget.AdapterView;  import android.widget.AdapterView.OnItemSelectedListener; -import android.widget.Button;  import android.widget.Spinner;  import android.widget.TextView; -import android.widget.Toast;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.pgp.KeyRing; -import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException; -import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.remote.AccountSettings; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.service.OperationResults; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.SaveKeyringResult;  import org.sufficientlysecure.keychain.ui.CreateKeyActivity;  import org.sufficientlysecure.keychain.ui.adapter.KeyValueSpinnerAdapter;  import org.sufficientlysecure.keychain.ui.widget.KeySpinner; @@ -176,7 +172,7 @@ public class AccountSettingsFragment extends Fragment {              case REQUEST_CODE_CREATE_KEY: {                  if (resultCode == Activity.RESULT_OK) {                      if (data != null && data.hasExtra(OperationResultParcel.EXTRA_RESULT)) { -                        OperationResults.SaveKeyringResult result = data.getParcelableExtra(OperationResultParcel.EXTRA_RESULT); +                        SaveKeyringResult result = data.getParcelableExtra(OperationResultParcel.EXTRA_RESULT);                          mSelectKeySpinner.setSelectedKeyId(result.mRingMasterKeyId);                      } else {                          Log.e(Constants.TAG, "missing result!"); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java index 885d06857..8cc05231e 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java @@ -32,7 +32,7 @@ import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.remote.AppSettings; -import org.sufficientlysecure.keychain.service.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel;  import org.sufficientlysecure.keychain.util.Log;  public class AppSettingsActivity extends ActionBarActivity { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java index e664570ac..92917fa51 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java @@ -55,13 +55,14 @@ import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRingData;  import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.provider.KeychainDatabase;  import org.sufficientlysecure.keychain.provider.ProviderHelper; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogLevel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogType; -import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog; -import org.sufficientlysecure.keychain.service.OperationResults.ConsolidateResult; -import org.sufficientlysecure.keychain.service.OperationResults.EditKeyResult; -import org.sufficientlysecure.keychain.service.OperationResults.ImportKeyResult; -import org.sufficientlysecure.keychain.service.OperationResults.SaveKeyringResult; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogLevel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogType; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.OperationLog; +import org.sufficientlysecure.keychain.service.results.ConsolidateResult; +import org.sufficientlysecure.keychain.service.results.EditKeyResult; +import org.sufficientlysecure.keychain.service.results.ImportKeyResult; +import org.sufficientlysecure.keychain.service.results.SaveKeyringResult;  import org.sufficientlysecure.keychain.util.ParcelableFileCache;  import org.sufficientlysecure.keychain.util.InputData;  import org.sufficientlysecure.keychain.util.Log; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResults.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResults.java deleted file mode 100644 index ad8fb2f7a..000000000 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResults.java +++ /dev/null @@ -1,348 +0,0 @@ -/* - * Copyright (C) 2014 Dominik Schürmann <dominik@dominikschuermann.de> - * Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com> - * - * 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.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.SuperToast.Duration; -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.pgp.CanonicalizedKeyRing; -import org.sufficientlysecure.keychain.pgp.UncachedKeyRing; -import org.sufficientlysecure.keychain.ui.LogDisplayActivity; -import org.sufficientlysecure.keychain.ui.LogDisplayFragment; - -public abstract class OperationResults { - -    /** This is a simple subclass meant to contain only a single log message. This log -     * message is also shown without a log button in the createNotify SuperToast. */ -    public static class SingletonResult extends OperationResultParcel { - -        /** Construct from a parcel - trivial because we have no extra data. */ -        public SingletonResult(Parcel source) { -            super(source); -        } - -        public SingletonResult(int result, LogLevel level, LogType reason) { -            super(result, new OperationLog()); -            // Prepare the log -            mLog.add(level, reason, 0); -        } - -        @Override -        public SuperCardToast createNotify(final Activity activity) { - -            // there is exactly one error msg - use that one -            String str = activity.getString(mLog.iterator().next().mType.getMsgId()); -            int color; - -            // Determine color by result type -            if (cancelled()) { -                color = Style.RED; -            } else if (success()) { -                if (getLog().containsWarnings()) { -                    color = Style.ORANGE; -                } else { -                    color = Style.GREEN; -                } -            } else { -                color = Style.RED; -            } - -            SuperCardToast toast = new SuperCardToast(activity, SuperToast.Type.STANDARD, -                    Style.getStyle(color, SuperToast.Animations.POPUP)); -            toast.setText(str); -            toast.setDuration(SuperToast.Duration.EXTRA_LONG); -            toast.setIndeterminate(false); -            toast.setSwipeToDismiss(true); -            return toast; - -        } - -        public static Creator<SingletonResult> CREATOR = new Creator<SingletonResult>() { -            public SingletonResult createFromParcel(final Parcel source) { -                return new SingletonResult(source); -            } - -            public SingletonResult[] newArray(final int size) { -                return new SingletonResult[size]; -            } -        }; - -    } - -    public static class ImportKeyResult extends OperationResultParcel { - -        public final int mNewKeys, mUpdatedKeys, mBadKeys, mSecret; - -        // At least one new key -        public static final int RESULT_OK_NEWKEYS = 8; -        // At least one updated key -        public static final int RESULT_OK_UPDATED = 16; -        // At least one key failed (might still be an overall success) -        public static final int RESULT_WITH_ERRORS = 32; - -        // No keys to import... -        public static final int RESULT_FAIL_NOTHING = 64 + 1; - -        public boolean isOkBoth() { -            return (mResult & (RESULT_OK_NEWKEYS | RESULT_OK_UPDATED)) -                    == (RESULT_OK_NEWKEYS | RESULT_OK_UPDATED); -        } - -        public boolean isOkNew() { -            return (mResult & RESULT_OK_NEWKEYS) == RESULT_OK_NEWKEYS; -        } - -        public boolean isOkUpdated() { -            return (mResult & RESULT_OK_UPDATED) == RESULT_OK_UPDATED; -        } - -        public boolean isFailNothing() { -            return (mResult & RESULT_FAIL_NOTHING) == RESULT_FAIL_NOTHING; -        } - -        public ImportKeyResult(Parcel source) { -            super(source); -            mNewKeys = source.readInt(); -            mUpdatedKeys = source.readInt(); -            mBadKeys = source.readInt(); -            mSecret = source.readInt(); -        } - -        public ImportKeyResult(int result, OperationLog log, -                               int newKeys, int updatedKeys, int badKeys, int secret) { -            super(result, log); -            mNewKeys = newKeys; -            mUpdatedKeys = updatedKeys; -            mBadKeys = badKeys; -            mSecret = secret; -        } - -        @Override -        public void writeToParcel(Parcel dest, int flags) { -            super.writeToParcel(dest, flags); -            dest.writeInt(mNewKeys); -            dest.writeInt(mUpdatedKeys); -            dest.writeInt(mBadKeys); -            dest.writeInt(mSecret); -        } - -        public static Creator<ImportKeyResult> CREATOR = new Creator<ImportKeyResult>() { -            public ImportKeyResult createFromParcel(final Parcel source) { -                return new ImportKeyResult(source); -            } - -            public ImportKeyResult[] newArray(final int size) { -                return new ImportKeyResult[size]; -            } -        }; - -        public SuperCardToast createNotify(final Activity activity) { - -            int resultType = getResult(); - -            String str; -            int duration, color; - -            // Not an overall failure -            if ((resultType & OperationResultParcel.RESULT_ERROR) == 0) { -                String withWarnings; - -                duration = Duration.EXTRA_LONG; -                color = Style.GREEN; -                withWarnings = ""; - -                // Any warnings? -                if ((resultType & ImportKeyResult.RESULT_WARNINGS) > 0) { -                    duration = 0; -                    color = Style.ORANGE; -                    withWarnings += activity.getString(R.string.import_with_warnings); -                } -                if ((resultType & ImportKeyResult.RESULT_CANCELLED) > 0) { -                    duration = 0; -                    color = Style.ORANGE; -                    withWarnings += activity.getString(R.string.import_with_cancelled); -                } - -                // New and updated keys -                if (this.isOkBoth()) { -                    str = activity.getResources().getQuantityString( -                            R.plurals.import_keys_added_and_updated_1, mNewKeys, mNewKeys); -                    str += " " + activity.getResources().getQuantityString( -                            R.plurals.import_keys_added_and_updated_2, mUpdatedKeys, mUpdatedKeys, withWarnings); -                } else if (isOkUpdated()) { -                    str = activity.getResources().getQuantityString( -                            R.plurals.import_keys_updated, mUpdatedKeys, mUpdatedKeys, withWarnings); -                } else if (isOkNew()) { -                    str = activity.getResources().getQuantityString( -                            R.plurals.import_keys_added, mNewKeys, mNewKeys, withWarnings); -                } else { -                    duration = 0; -                    color = Style.RED; -                    str = "internal error"; -                } - -            } else { -                duration = 0; -                color = Style.RED; -                if (isFailNothing()) { -                    str = activity.getString((resultType & ImportKeyResult.RESULT_CANCELLED) > 0 -                                    ? R.string.import_error_nothing_cancelled -                                    : R.string.import_error_nothing); -                } else { -                    str = activity.getString(R.string.import_error); -                } -            } - -            boolean button = getLog() != null && !getLog().isEmpty(); -            SuperCardToast toast = new SuperCardToast(activity, -                    button ? SuperToast.Type.BUTTON : SuperToast.Type.STANDARD, -                    Style.getStyle(color, SuperToast.Animations.POPUP)); -            toast.setText(str); -            toast.setDuration(duration); -            toast.setIndeterminate(duration == 0); -            toast.setSwipeToDismiss(true); -            // If we have a log and it's non-empty, show a View Log button -            if (button) { -                toast.setButtonIcon(R.drawable.ic_action_view_as_list, -                        activity.getResources().getString(R.string.view_log)); -                toast.setButtonTextColor(activity.getResources().getColor(R.color.black)); -                toast.setTextColor(activity.getResources().getColor(R.color.black)); -                toast.setOnClickWrapper(new OnClickWrapper("supercardtoast", -                        new SuperToast.OnClickListener() { -                            @Override -                            public void onClick(View view, Parcelable token) { -                                Intent intent = new Intent( -                                        activity, LogDisplayActivity.class); -                                intent.putExtra(LogDisplayFragment.EXTRA_RESULT, ImportKeyResult.this); -                                activity.startActivity(intent); -                            } -                        } -                )); -            } - -            return toast; - -        } - -    } - -    public static class EditKeyResult extends OperationResultParcel { - -        private transient UncachedKeyRing mRing; -        public final long mRingMasterKeyId; - -        public EditKeyResult(int result, OperationLog log, -                             UncachedKeyRing ring) { -            super(result, log); -            mRing = ring; -            mRingMasterKeyId = ring != null ? ring.getMasterKeyId() : Constants.key.none; -        } - -        public UncachedKeyRing getRing() { -            return mRing; -        } - -        public EditKeyResult(Parcel source) { -            super(source); -            mRingMasterKeyId = source.readLong(); -        } - -        @Override -        public void writeToParcel(Parcel dest, int flags) { -            super.writeToParcel(dest, flags); -            dest.writeLong(mRingMasterKeyId); -        } - -        public static Creator<EditKeyResult> CREATOR = new Creator<EditKeyResult>() { -            public EditKeyResult createFromParcel(final Parcel source) { -                return new EditKeyResult(source); -            } - -            public EditKeyResult[] newArray(final int size) { -                return new EditKeyResult[size]; -            } -        }; - -    } - - -    public static class SaveKeyringResult extends OperationResultParcel { - -        public final long mRingMasterKeyId; - -        public SaveKeyringResult(int result, OperationLog log, -                                 CanonicalizedKeyRing ring) { -            super(result, log); -            mRingMasterKeyId = ring != null ? ring.getMasterKeyId() : Constants.key.none; -        } - -        // Some old key was updated -        public static final int UPDATED = 4; - -        // Public key was saved -        public static final int SAVED_PUBLIC = 8; -        // Secret key was saved (not exclusive with public!) -        public static final int SAVED_SECRET = 16; - -        public boolean updated() { -            return (mResult & UPDATED) == UPDATED; -        } - -        public SaveKeyringResult(Parcel source) { -            super(source); -            mRingMasterKeyId = source.readLong(); -        } - -        @Override -        public void writeToParcel(Parcel dest, int flags) { -            super.writeToParcel(dest, flags); -            dest.writeLong(mRingMasterKeyId); -        } - -        public static Creator<SaveKeyringResult> CREATOR = new Creator<SaveKeyringResult>() { -            public SaveKeyringResult createFromParcel(final Parcel source) { -                return new SaveKeyringResult(source); -            } - -            public SaveKeyringResult[] newArray(final int size) { -                return new SaveKeyringResult[size]; -            } -        }; -    } - -    public static class ConsolidateResult extends OperationResultParcel { - -        public ConsolidateResult(int result, OperationLog log) { -            super(result, log); -        } - -    } - -} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/ConsolidateResult.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/ConsolidateResult.java new file mode 100644 index 000000000..31f4cabc3 --- /dev/null +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/ConsolidateResult.java @@ -0,0 +1,27 @@ +/* + * Copyright (C) 2014 Dominik Schürmann <dominik@dominikschuermann.de> + * Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com> + * + * 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.service.results; + +public class ConsolidateResult extends OperationResultParcel { + +    public ConsolidateResult(int result, OperationLog log) { +        super(result, log); +    } + +} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/EditKeyResult.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/EditKeyResult.java new file mode 100644 index 000000000..169ed9f36 --- /dev/null +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/EditKeyResult.java @@ -0,0 +1,63 @@ +/* + * Copyright (C) 2014 Dominik Schürmann <dominik@dominikschuermann.de> + * Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com> + * + * 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.service.results; + +import android.os.Parcel; + +import org.sufficientlysecure.keychain.Constants; +import org.sufficientlysecure.keychain.pgp.UncachedKeyRing; + +public class EditKeyResult extends OperationResultParcel { + +    private transient UncachedKeyRing mRing; +    public final long mRingMasterKeyId; + +    public EditKeyResult(int result, OperationLog log, +                         UncachedKeyRing ring) { +        super(result, log); +        mRing = ring; +        mRingMasterKeyId = ring != null ? ring.getMasterKeyId() : Constants.key.none; +    } + +    public UncachedKeyRing getRing() { +        return mRing; +    } + +    public EditKeyResult(Parcel source) { +        super(source); +        mRingMasterKeyId = source.readLong(); +    } + +    @Override +    public void writeToParcel(Parcel dest, int flags) { +        super.writeToParcel(dest, flags); +        dest.writeLong(mRingMasterKeyId); +    } + +    public static Creator<EditKeyResult> CREATOR = new Creator<EditKeyResult>() { +        public EditKeyResult createFromParcel(final Parcel source) { +            return new EditKeyResult(source); +        } + +        public EditKeyResult[] newArray(final int size) { +            return new EditKeyResult[size]; +        } +    }; + +} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/ImportKeyResult.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/ImportKeyResult.java new file mode 100644 index 000000000..62b5b1b52 --- /dev/null +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/ImportKeyResult.java @@ -0,0 +1,192 @@ +/* + * Copyright (C) 2014 Dominik Schürmann <dominik@dominikschuermann.de> + * Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com> + * + * 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.service.results; + +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.SuperToast.Duration; +import com.github.johnpersano.supertoasts.util.OnClickWrapper; +import com.github.johnpersano.supertoasts.util.Style; + +import org.sufficientlysecure.keychain.R; +import org.sufficientlysecure.keychain.ui.LogDisplayActivity; +import org.sufficientlysecure.keychain.ui.LogDisplayFragment; + +public class ImportKeyResult extends OperationResultParcel { + +    public final int mNewKeys, mUpdatedKeys, mBadKeys, mSecret; + +    // At least one new key +    public static final int RESULT_OK_NEWKEYS = 8; +    // At least one updated key +    public static final int RESULT_OK_UPDATED = 16; +    // At least one key failed (might still be an overall success) +    public static final int RESULT_WITH_ERRORS = 32; + +    // No keys to import... +    public static final int RESULT_FAIL_NOTHING = 64 + 1; + +    public boolean isOkBoth() { +        return (mResult & (RESULT_OK_NEWKEYS | RESULT_OK_UPDATED)) +                == (RESULT_OK_NEWKEYS | RESULT_OK_UPDATED); +    } + +    public boolean isOkNew() { +        return (mResult & RESULT_OK_NEWKEYS) == RESULT_OK_NEWKEYS; +    } + +    public boolean isOkUpdated() { +        return (mResult & RESULT_OK_UPDATED) == RESULT_OK_UPDATED; +    } + +    public boolean isFailNothing() { +        return (mResult & RESULT_FAIL_NOTHING) == RESULT_FAIL_NOTHING; +    } + +    public ImportKeyResult(Parcel source) { +        super(source); +        mNewKeys = source.readInt(); +        mUpdatedKeys = source.readInt(); +        mBadKeys = source.readInt(); +        mSecret = source.readInt(); +    } + +    public ImportKeyResult(int result, OperationLog log, +                           int newKeys, int updatedKeys, int badKeys, int secret) { +        super(result, log); +        mNewKeys = newKeys; +        mUpdatedKeys = updatedKeys; +        mBadKeys = badKeys; +        mSecret = secret; +    } + +    @Override +    public void writeToParcel(Parcel dest, int flags) { +        super.writeToParcel(dest, flags); +        dest.writeInt(mNewKeys); +        dest.writeInt(mUpdatedKeys); +        dest.writeInt(mBadKeys); +        dest.writeInt(mSecret); +    } + +    public static Creator<ImportKeyResult> CREATOR = new Creator<ImportKeyResult>() { +        public ImportKeyResult createFromParcel(final Parcel source) { +            return new ImportKeyResult(source); +        } + +        public ImportKeyResult[] newArray(final int size) { +            return new ImportKeyResult[size]; +        } +    }; + +    public SuperCardToast createNotify(final Activity activity) { + +        int resultType = getResult(); + +        String str; +        int duration, color; + +        // Not an overall failure +        if ((resultType & OperationResultParcel.RESULT_ERROR) == 0) { +            String withWarnings; + +            duration = Duration.EXTRA_LONG; +            color = Style.GREEN; +            withWarnings = ""; + +            // Any warnings? +            if ((resultType & ImportKeyResult.RESULT_WARNINGS) > 0) { +                duration = 0; +                color = Style.ORANGE; +                withWarnings += activity.getString(R.string.import_with_warnings); +            } +            if ((resultType & ImportKeyResult.RESULT_CANCELLED) > 0) { +                duration = 0; +                color = Style.ORANGE; +                withWarnings += activity.getString(R.string.import_with_cancelled); +            } + +            // New and updated keys +            if (this.isOkBoth()) { +                str = activity.getResources().getQuantityString( +                        R.plurals.import_keys_added_and_updated_1, mNewKeys, mNewKeys); +                str += " " + activity.getResources().getQuantityString( +                        R.plurals.import_keys_added_and_updated_2, mUpdatedKeys, mUpdatedKeys, withWarnings); +            } else if (isOkUpdated()) { +                str = activity.getResources().getQuantityString( +                        R.plurals.import_keys_updated, mUpdatedKeys, mUpdatedKeys, withWarnings); +            } else if (isOkNew()) { +                str = activity.getResources().getQuantityString( +                        R.plurals.import_keys_added, mNewKeys, mNewKeys, withWarnings); +            } else { +                duration = 0; +                color = Style.RED; +                str = "internal error"; +            } + +        } else { +            duration = 0; +            color = Style.RED; +            if (isFailNothing()) { +                str = activity.getString((resultType & ImportKeyResult.RESULT_CANCELLED) > 0 +                                ? R.string.import_error_nothing_cancelled +                                : R.string.import_error_nothing); +            } else { +                str = activity.getString(R.string.import_error); +            } +        } + +        boolean button = getLog() != null && !getLog().isEmpty(); +        SuperCardToast toast = new SuperCardToast(activity, +                button ? SuperToast.Type.BUTTON : SuperToast.Type.STANDARD, +                Style.getStyle(color, SuperToast.Animations.POPUP)); +        toast.setText(str); +        toast.setDuration(duration); +        toast.setIndeterminate(duration == 0); +        toast.setSwipeToDismiss(true); +        // If we have a log and it's non-empty, show a View Log button +        if (button) { +            toast.setButtonIcon(R.drawable.ic_action_view_as_list, +                    activity.getResources().getString(R.string.view_log)); +            toast.setButtonTextColor(activity.getResources().getColor(R.color.black)); +            toast.setTextColor(activity.getResources().getColor(R.color.black)); +            toast.setOnClickWrapper(new OnClickWrapper("supercardtoast", +                    new SuperToast.OnClickListener() { +                        @Override +                        public void onClick(View view, Parcelable token) { +                            Intent intent = new Intent( +                                    activity, LogDisplayActivity.class); +                            intent.putExtra(LogDisplayFragment.EXTRA_RESULT, ImportKeyResult.this); +                            activity.startActivity(intent); +                        } +                    } +            )); +        } + +        return toast; + +    } + +} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResultParcel.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/OperationResultParcel.java index 02caca145..580072957 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/OperationResultParcel.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/OperationResultParcel.java @@ -16,7 +16,7 @@   * along with this program.  If not, see <http://www.gnu.org/licenses/>.   */ -package org.sufficientlysecure.keychain.service; +package org.sufficientlysecure.keychain.service.results;  import android.app.Activity;  import android.content.Intent; @@ -49,6 +49,7 @@ import java.util.List;   * list (ie, enum) of all possible log types, which should in all cases be tied   * to string resource ids.   * + * TODO ideally, this class should be abstract, and all actual results of a specific subclass   *   */  public class OperationResultParcel implements Parcelable { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/SaveKeyringResult.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/SaveKeyringResult.java new file mode 100644 index 000000000..0edb9c617 --- /dev/null +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/SaveKeyringResult.java @@ -0,0 +1,68 @@ +/* + * Copyright (C) 2014 Dominik Schürmann <dominik@dominikschuermann.de> + * Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com> + * + * 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.service.results; + +import android.os.Parcel; + +import org.sufficientlysecure.keychain.Constants; +import org.sufficientlysecure.keychain.pgp.CanonicalizedKeyRing; + +public class SaveKeyringResult extends OperationResultParcel { + +    public final long mRingMasterKeyId; + +    public SaveKeyringResult(int result, OperationLog log, +                             CanonicalizedKeyRing ring) { +        super(result, log); +        mRingMasterKeyId = ring != null ? ring.getMasterKeyId() : Constants.key.none; +    } + +    // Some old key was updated +    public static final int UPDATED = 4; + +    // Public key was saved +    public static final int SAVED_PUBLIC = 8; +    // Secret key was saved (not exclusive with public!) +    public static final int SAVED_SECRET = 16; + +    public boolean updated() { +        return (mResult & UPDATED) == UPDATED; +    } + +    public SaveKeyringResult(Parcel source) { +        super(source); +        mRingMasterKeyId = source.readLong(); +    } + +    @Override +    public void writeToParcel(Parcel dest, int flags) { +        super.writeToParcel(dest, flags); +        dest.writeLong(mRingMasterKeyId); +    } + +    public static Creator<SaveKeyringResult> CREATOR = new Creator<SaveKeyringResult>() { +        public SaveKeyringResult createFromParcel(final Parcel source) { +            return new SaveKeyringResult(source); +        } + +        public SaveKeyringResult[] newArray(final int size) { +            return new SaveKeyringResult[size]; +        } +    }; +} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/SingletonResult.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/SingletonResult.java new file mode 100644 index 000000000..5022c46a7 --- /dev/null +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/results/SingletonResult.java @@ -0,0 +1,83 @@ +/* + * Copyright (C) 2014 Dominik Schürmann <dominik@dominikschuermann.de> + * Copyright (C) 2014 Vincent Breitmoser <v.breitmoser@mugenguild.com> + * + * 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.service.results; + +import android.app.Activity; +import android.os.Parcel; + +import com.github.johnpersano.supertoasts.SuperCardToast; +import com.github.johnpersano.supertoasts.SuperToast; +import com.github.johnpersano.supertoasts.util.Style; + +/** This is a simple subclass meant to contain only a single log message. This log + * message is also shown without a log button in the createNotify SuperToast. */ +public class SingletonResult extends OperationResultParcel { + +    /** Construct from a parcel - trivial because we have no extra data. */ +    public SingletonResult(Parcel source) { +        super(source); +    } + +    public SingletonResult(int result, LogLevel level, LogType reason) { +        super(result, new OperationLog()); +        // Prepare the log +        mLog.add(level, reason, 0); +    } + +    @Override +    public SuperCardToast createNotify(final Activity activity) { + +        // there is exactly one error msg - use that one +        String str = activity.getString(mLog.iterator().next().mType.getMsgId()); +        int color; + +        // Determine color by result type +        if (cancelled()) { +            color = Style.RED; +        } else if (success()) { +            if (getLog().containsWarnings()) { +                color = Style.ORANGE; +            } else { +                color = Style.GREEN; +            } +        } else { +            color = Style.RED; +        } + +        SuperCardToast toast = new SuperCardToast(activity, SuperToast.Type.STANDARD, +                Style.getStyle(color, SuperToast.Animations.POPUP)); +        toast.setText(str); +        toast.setDuration(SuperToast.Duration.EXTRA_LONG); +        toast.setIndeterminate(false); +        toast.setSwipeToDismiss(true); +        return toast; + +    } + +    public static Creator<SingletonResult> CREATOR = new Creator<SingletonResult>() { +        public SingletonResult createFromParcel(final Parcel source) { +            return new SingletonResult(source); +        } + +        public SingletonResult[] newArray(final int size) { +            return new SingletonResult[size]; +        } +    }; + +} diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java index d921f3cc0..fb2184362 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java @@ -54,7 +54,7 @@ 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.results.OperationResultParcel;  import org.sufficientlysecure.keychain.service.PassphraseCacheService;  import org.sufficientlysecure.keychain.ui.adapter.UserIdsAdapter;  import org.sufficientlysecure.keychain.ui.dialog.PassphraseDialogFragment; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java index ec4f2e337..a645f18a9 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java @@ -39,10 +39,10 @@ import org.sufficientlysecure.keychain.pgp.KeyRing;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.service.KeychainIntentService;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.service.OperationResults; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel.Algorithm; +import org.sufficientlysecure.keychain.service.results.SaveKeyringResult;  import org.sufficientlysecure.keychain.util.Log;  public class CreateKeyFinalFragment extends Fragment { @@ -140,7 +140,7 @@ public class CreateKeyFinalFragment extends Fragment {                      if (returnData == null) {                          return;                      } -                    final OperationResults.SaveKeyringResult result = +                    final SaveKeyringResult result =                              returnData.getParcelable(OperationResultParcel.EXTRA_RESULT);                      if (result == null) {                          Log.e(Constants.TAG, "result == null"); @@ -189,7 +189,7 @@ public class CreateKeyFinalFragment extends Fragment {          getActivity().startService(intent);      } -    private void uploadKey(final OperationResults.SaveKeyringResult saveKeyResult) { +    private void uploadKey(final SaveKeyringResult saveKeyResult) {          // Send all information needed to service to upload key in other thread          final Intent intent = new Intent(getActivity(), KeychainIntentService.class); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java index 8feef5e46..8bde3f295 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java @@ -48,10 +48,10 @@ import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.provider.ProviderHelper.NotFoundException;  import org.sufficientlysecure.keychain.service.KeychainIntentService;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogLevel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogType; -import org.sufficientlysecure.keychain.service.OperationResults.SingletonResult; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogLevel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogType; +import org.sufficientlysecure.keychain.service.results.SingletonResult;  import org.sufficientlysecure.keychain.service.PassphraseCacheService;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel;  import org.sufficientlysecure.keychain.ui.adapter.SubkeysAdapter; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java index 3e949cfae..732e59e32 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java @@ -46,8 +46,8 @@ import org.sufficientlysecure.keychain.keyimport.ParcelableKeyRing;  import org.sufficientlysecure.keychain.pgp.PgpKeyHelper;  import org.sufficientlysecure.keychain.service.KeychainIntentService;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.service.OperationResults.ImportKeyResult; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.ImportKeyResult;  import org.sufficientlysecure.keychain.ui.adapter.PagerTabStripAdapter;  import org.sufficientlysecure.keychain.ui.widget.SlidingTabLayout;  import org.sufficientlysecure.keychain.util.ParcelableFileCache; 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 65c4b8605..1b3bb06c3 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListActivity.java @@ -34,8 +34,8 @@ import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.provider.KeychainDatabase;  import org.sufficientlysecure.keychain.service.KeychainIntentService;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.service.OperationResults.ConsolidateResult; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.ConsolidateResult;  import org.sufficientlysecure.keychain.util.Log;  import org.sufficientlysecure.keychain.util.Notify; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java index 1202de1b7..ddc57b8aa 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayFragment.java @@ -37,9 +37,9 @@ import android.widget.TextView;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.service.OperationResultParcel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogEntryParcel; -import org.sufficientlysecure.keychain.service.OperationResultParcel.LogLevel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogEntryParcel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel.LogLevel;  import org.sufficientlysecure.keychain.util.Log;  import java.util.HashMap; 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 5d8e13349..ef0b95bcc 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java @@ -56,7 +56,7 @@ import org.sufficientlysecure.keychain.pgp.PgpKeyHelper;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; -import org.sufficientlysecure.keychain.service.OperationResultParcel; +import org.sufficientlysecure.keychain.service.results.OperationResultParcel;  import org.sufficientlysecure.keychain.ui.adapter.PagerTabStripAdapter;  import org.sufficientlysecure.keychain.ui.widget.SlidingTabLayout;  import org.sufficientlysecure.keychain.ui.widget.SlidingTabLayout.TabColorizer; | 
