diff options
author | Thialfihar <thialfihar@gmail.com> | 2010-05-18 15:23:25 +0000 |
---|---|---|
committer | Thialfihar <thialfihar@gmail.com> | 2010-05-18 15:23:25 +0000 |
commit | ed2cb1e525778d62949958bbf108687c571e4ebe (patch) | |
tree | e27fd3f422580b22b2a7f34bb0d4d53edccaa680 /src/org/thialfihar/android/apg/DecryptMessageActivity.java | |
parent | 42f1720bb32b5404ae9b78c0b042b143b6f507af (diff) | |
parent | 5b5e15c88663acfc282d42ff51cdceff1d9d4084 (diff) | |
download | open-keychain-ed2cb1e525778d62949958bbf108687c571e4ebe.tar.gz open-keychain-ed2cb1e525778d62949958bbf108687c571e4ebe.tar.bz2 open-keychain-ed2cb1e525778d62949958bbf108687c571e4ebe.zip |
overdue merge of 0.9.x into trunk
Diffstat (limited to 'src/org/thialfihar/android/apg/DecryptMessageActivity.java')
-rw-r--r-- | src/org/thialfihar/android/apg/DecryptMessageActivity.java | 343 |
1 files changed, 0 insertions, 343 deletions
diff --git a/src/org/thialfihar/android/apg/DecryptMessageActivity.java b/src/org/thialfihar/android/apg/DecryptMessageActivity.java deleted file mode 100644 index 179d5be55..000000000 --- a/src/org/thialfihar/android/apg/DecryptMessageActivity.java +++ /dev/null @@ -1,343 +0,0 @@ -/* - * Copyright (C) 2010 Thialfihar <thi@thialfihar.org> - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package org.thialfihar.android.apg; - -import java.io.ByteArrayInputStream; -import java.io.ByteArrayOutputStream; -import java.io.FileNotFoundException; -import java.io.IOException; -import java.io.InputStream; -import java.security.Security; -import java.security.SignatureException; -import java.util.regex.Matcher; - -import org.bouncycastle2.jce.provider.BouncyCastleProvider; -import org.bouncycastle2.openpgp.PGPException; -import org.bouncycastle2.util.Strings; - -import android.app.Activity; -import android.app.Dialog; -import android.app.ProgressDialog; -import android.content.Intent; -import android.net.Uri; -import android.os.Bundle; -import android.os.Handler; -import android.os.Message; -import android.text.ClipboardManager; -import android.view.View; -import android.view.View.OnClickListener; -import android.widget.Button; -import android.widget.EditText; -import android.widget.ImageView; -import android.widget.LinearLayout; -import android.widget.TextView; -import android.widget.Toast; - -public class DecryptMessageActivity extends Activity - implements Runnable, ProgressDialogUpdater, - AskForSecretKeyPassPhrase.PassPhraseCallbackInterface { - static final int GET_PUCLIC_KEYS = 1; - static final int GET_SECRET_KEY = 2; - - static final int DIALOG_DECRYPTING = 1; - - static final int MESSAGE_PROGRESS_UPDATE = 1; - static final int MESSAGE_DONE = 2; - - private long mDecryptionKeyId = 0; - private long mSignatureKeyId = 0; - - private String mReplyTo = null; - private String mSubject = null; - - private ProgressDialog mProgressDialog = null; - private Thread mRunningThread = null; - - private EditText mMessage = null; - private LinearLayout mSignatureLayout = null; - private ImageView mSignatureStatusImage = null; - private TextView mUserId = null; - private TextView mUserIdRest = null; - private Button mDecryptButton = null; - - private Handler mHandler = new Handler() { - @Override - public void handleMessage(Message msg) { - Bundle data = msg.getData(); - if (data != null) { - int type = data.getInt("type"); - switch (type) { - case MESSAGE_PROGRESS_UPDATE: { - String message = data.getString("message"); - if (mProgressDialog != null) { - if (message != null) { - mProgressDialog.setMessage(message); - } - mProgressDialog.setMax(data.getInt("max")); - mProgressDialog.setProgress(data.getInt("progress")); - } - break; - } - - case MESSAGE_DONE: { - removeDialog(DIALOG_DECRYPTING); - mProgressDialog = null; - mSignatureKeyId = 0; - String error = data.getString("error"); - String decryptedMessage = data.getString("decryptedMessage"); - if (error != null) { - Toast.makeText(DecryptMessageActivity.this, - "Error: " + data.getString("error"), - Toast.LENGTH_SHORT).show(); - } - mSignatureLayout.setVisibility(View.INVISIBLE); - if (decryptedMessage != null) { - mMessage.setText(decryptedMessage); - mDecryptButton.setText(R.string.btn_reply); - mDecryptButton.setOnClickListener(new OnClickListener() { - @Override - public void onClick(View v) { - replyClicked(); - } - }); - - if (data.getBoolean("signature")) { - String userId = data.getString("signatureUserId"); - mSignatureKeyId = data.getLong("signatureKeyId"); - mUserIdRest.setText("id: " + - Long.toHexString(mSignatureKeyId & 0xffffffffL)); - if (userId == null) { - userId = - getResources() - .getString( - R.string.unknown_user_id); - } - String chunks[] = userId.split(" <", 2); - userId = chunks[0]; - if (chunks.length > 1) { - mUserIdRest.setText("<" + chunks[1]); - } - mUserId.setText(userId); - - if (data.getBoolean("signatureSuccess")) { - mSignatureStatusImage.setImageResource(R.drawable.overlay_ok); - } else if (data.getBoolean("signatureUnknown")) { - mSignatureStatusImage.setImageResource(R.drawable.overlay_error); - } else { - mSignatureStatusImage.setImageResource(R.drawable.overlay_error); - } - mSignatureLayout.setVisibility(View.VISIBLE); - } - } - - break; - } - } - } - } - }; - - @Override - public void onCreate(Bundle savedInstanceState) { - super.onCreate(savedInstanceState); - setContentView(R.layout.decrypt_message); - - Apg.initialize(this); - - mMessage = (EditText) findViewById(R.id.message); - mDecryptButton = (Button) findViewById(R.id.btn_decrypt); - mSignatureLayout = (LinearLayout) findViewById(R.id.layout_signature); - mSignatureStatusImage = (ImageView) findViewById(R.id.ic_signature_status); - mUserId = (TextView) findViewById(R.id.main_user_id); - mUserIdRest = (TextView) findViewById(R.id.main_user_id_rest); - - Intent intent = getIntent(); - if (intent.getAction() != null && intent.getAction().equals(Intent.ACTION_VIEW)) { - Uri uri = intent.getData(); - try { - InputStream attachment = getContentResolver().openInputStream(uri); - ByteArrayOutputStream byteOut = new ByteArrayOutputStream(); - byte bytes[] = new byte[1 << 16]; - int length; - while ((length = attachment.read(bytes)) > 0) { - byteOut.write(bytes, 0, length); - } - byteOut.close(); - String data = Strings.fromUTF8ByteArray(byteOut.toByteArray()); - mMessage.setText(data); - } catch (FileNotFoundException e) { - // ignore, then - } catch (IOException e) { - // ignore, then - } - } else if (intent.getAction() != null && intent.getAction().equals(Apg.Intent.DECRYPT)) { - String data = intent.getExtras().getString("data"); - if (data != null) { - Matcher matcher = Apg.PGP_MESSAGE.matcher(data); - if (matcher.matches()) { - data = matcher.group(1); - mMessage.setText(data); - } - } - mReplyTo = intent.getExtras().getString("replyTo"); - mSubject = intent.getExtras().getString("subject"); - } else { - ClipboardManager clip = (ClipboardManager) getSystemService(CLIPBOARD_SERVICE); - String data = ""; - Matcher matcher = Apg.PGP_MESSAGE.matcher(clip.getText()); - if (matcher.matches()) { - data = matcher.group(1); - mMessage.setText(data); - Toast.makeText(this, R.string.using_clipboard_content, Toast.LENGTH_SHORT).show(); - } - } - - mSignatureLayout.setVisibility(View.INVISIBLE); - - mDecryptButton.setOnClickListener(new OnClickListener() { - @Override - public void onClick(View v) { - decryptClicked(); - } - }); - - if (mMessage.getText().length() > 0) { - mDecryptButton.performClick(); - } - } - - @Override - protected Dialog onCreateDialog(int id) { - switch (id) { - case DIALOG_DECRYPTING: { - mProgressDialog = new ProgressDialog(this); - mProgressDialog.setMessage("initializing..."); - mProgressDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL); - mProgressDialog.setCancelable(false); - return mProgressDialog; - } - - case AskForSecretKeyPassPhrase.DIALOG_PASS_PHRASE: { - return AskForSecretKeyPassPhrase.createDialog(this, mDecryptionKeyId, this); - } - } - - return super.onCreateDialog(id); - } - - @Override - public void setProgress(int progress, int max) { - Message msg = new Message(); - Bundle data = new Bundle(); - data.putInt("type", MESSAGE_PROGRESS_UPDATE); - data.putInt("progress", progress); - data.putInt("max", max); - msg.setData(data); - mHandler.sendMessage(msg); - } - - @Override - public void setProgress(String message, int progress, int max) { - Message msg = new Message(); - Bundle data = new Bundle(); - data.putInt("type", MESSAGE_PROGRESS_UPDATE); - data.putString("message", message); - data.putInt("progress", progress); - data.putInt("max", max); - msg.setData(data); - mHandler.sendMessage(msg); - } - - private void decryptClicked() { - String error = null; - ByteArrayInputStream in = - new ByteArrayInputStream(mMessage.getText().toString().getBytes()); - try { - mDecryptionKeyId = Apg.getDecryptionKeyId(in); - showDialog(AskForSecretKeyPassPhrase.DIALOG_PASS_PHRASE); - } catch (IOException e) { - error = e.getLocalizedMessage(); - } catch (Apg.GeneralException e) { - error = e.getLocalizedMessage(); - } - if (error != null) { - Toast.makeText(this, "Error: " + error, Toast.LENGTH_SHORT).show(); - } - } - - private void replyClicked() { - Intent intent = new Intent(this, EncryptMessageActivity.class); - intent.setAction(Apg.Intent.ENCRYPT); - String data = mMessage.getText().toString(); - data = data.replaceAll("(?m)^", "> "); - data = "\n\n" + data; - intent.putExtra("data", data); - intent.putExtra("subject", "Re: " + mSubject); - intent.putExtra("sendTo", mReplyTo); - intent.putExtra("eyId", mSignatureKeyId); - intent.putExtra("signatureKeyId", mDecryptionKeyId); - intent.putExtra("encryptionKeyIds", new long[] { mSignatureKeyId }); - startActivity(intent); - } - - public void passPhraseCallback(String passPhrase) { - Apg.setPassPhrase(passPhrase); - decryptStart(); - } - - private void decryptStart() { - showDialog(DIALOG_DECRYPTING); - mRunningThread = new Thread(this); - mRunningThread.start(); - } - - public void run() { - String error = null; - Security.addProvider(new BouncyCastleProvider()); - - Bundle data = new Bundle(); - Message msg = new Message(); - - ByteArrayInputStream in = - new ByteArrayInputStream(mMessage.getText().toString().getBytes()); - ByteArrayOutputStream out = new ByteArrayOutputStream(); - - try { - data = Apg.decrypt(in, out, Apg.getPassPhrase(), this); - } catch (PGPException e) { - error = e.getMessage(); - } catch (IOException e) { - error = e.getMessage(); - } catch (SignatureException e) { - error = e.getMessage(); - e.printStackTrace(); - } catch (Apg.GeneralException e) { - error = e.getMessage(); - } - - data.putInt("type", MESSAGE_DONE); - - if (error != null) { - data.putString("error", error); - } else { - data.putString("decryptedMessage", Strings.fromUTF8ByteArray(out.toByteArray())); - } - - msg.setData(data); - mHandler.sendMessage(msg); - } -} |