mirror of
https://code.briarproject.org/briar/briar.git
synced 2026-02-21 15:19:53 +01:00
Merge branch '40-forgotten-password' into 'master'
40 forgotten password * Moved the UI definition over to XML and added the forgotten password button * Code encapsulation in a new Base activity also enabling re-use between activities/fragments Closes #40 See merge request !10
This commit is contained in:
61
briar-android/res/layout/activity_password.xml
Normal file
61
briar-android/res/layout/activity_password.xml
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingBottom="@dimen/margin_activity_vertical"
|
||||||
|
android:paddingEnd="@dimen/margin_activity_horizontal"
|
||||||
|
android:paddingStart="@dimen/margin_activity_horizontal"
|
||||||
|
android:paddingTop="@dimen/margin_activity_vertical">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/title_password"
|
||||||
|
style="@style/BriarTextTitle"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_centerHorizontal="true"
|
||||||
|
android:padding="@dimen/margin_large"
|
||||||
|
android:text="@string/enter_password" />
|
||||||
|
|
||||||
|
<EditText
|
||||||
|
android:id="@+id/edit_password"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_below="@id/title_password"
|
||||||
|
android:hint="@string/password_hint"
|
||||||
|
android:imeOptions="actionDone"
|
||||||
|
android:inputType="textPassword"
|
||||||
|
android:lines="1"
|
||||||
|
android:maxLines="1" />
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btn_sign_in"
|
||||||
|
style="@style/BriarButton.Default"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_below="@id/edit_password"
|
||||||
|
android:layout_marginTop="@dimen/margin_xlarge"
|
||||||
|
android:onClick="onSignInClick"
|
||||||
|
android:text="@string/sign_in_button" />
|
||||||
|
|
||||||
|
<ProgressBar
|
||||||
|
android:id="@+id/progress_wheel"
|
||||||
|
style="?android:attr/progressBarStyleInverse"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_alignTop="@id/btn_sign_in"
|
||||||
|
android:visibility="invisible" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
style="@style/BriarTextBody"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_below="@id/btn_sign_in"
|
||||||
|
android:layout_centerHorizontal="true"
|
||||||
|
android:layout_marginTop="@dimen/margin_large"
|
||||||
|
android:clickable="true"
|
||||||
|
android:onClick="onForgottenPasswordClick"
|
||||||
|
android:text="@string/forgotten_password"
|
||||||
|
android:textColor="?android:attr/textColorLink" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
@@ -9,4 +9,9 @@
|
|||||||
<item name="android:textColor">@color/action_bar_text</item>
|
<item name="android:textColor">@color/action_bar_text</item>
|
||||||
<item name="android:background">@color/action_bar_background</item>
|
<item name="android:background">@color/action_bar_background</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
<style name="BriarButton.Default">
|
||||||
|
<item name="android:textAllCaps">true</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
@@ -14,4 +14,6 @@
|
|||||||
<color name="no_posts">#AAAAAA</color>
|
<color name="no_posts">#AAAAAA</color>
|
||||||
<color name="settings_title_text">#2D3E50</color>
|
<color name="settings_title_text">#2D3E50</color>
|
||||||
<color name="settings_title_underline">#2D3E50</color>
|
<color name="settings_title_underline">#2D3E50</color>
|
||||||
|
|
||||||
|
<color name="text_link">#2D3E50</color>
|
||||||
</resources>
|
</resources>
|
||||||
21
briar-android/res/values/dimens.xml
Normal file
21
briar-android/res/values/dimens.xml
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
<resources>
|
||||||
|
|
||||||
|
<!-- Default screen margins, per the Android Design guidelines. -->
|
||||||
|
<dimen name="margin_activity_horizontal">16dp</dimen>
|
||||||
|
<dimen name="margin_activity_vertical">16dp</dimen>
|
||||||
|
|
||||||
|
<dimen name="margin_seperator">1dp</dimen>
|
||||||
|
<dimen name="margin_tiny">2dp</dimen>
|
||||||
|
<dimen name="margin_small">4dp</dimen>
|
||||||
|
<dimen name="margin_medium">8dp</dimen>
|
||||||
|
<dimen name="margin_large">16dp</dimen>
|
||||||
|
<dimen name="margin_xlarge">32dp</dimen>
|
||||||
|
|
||||||
|
<!-- v2 dimens -->
|
||||||
|
<dimen name="text_size_tiny">12sp</dimen>
|
||||||
|
<dimen name="text_size_small">14sp</dimen>
|
||||||
|
<dimen name="text_size_medium">16sp</dimen>
|
||||||
|
<dimen name="text_size_large">20sp</dimen>
|
||||||
|
<dimen name="text_size_xlarge">34sp</dimen>
|
||||||
|
|
||||||
|
</resources>
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
|
|
||||||
|
|
||||||
<string name="app_name">Briar</string>
|
<string name="app_name">Briar</string>
|
||||||
<string name="crash_report_title">Briar Crash Report</string>
|
<string name="crash_report_title">Briar Crash Report</string>
|
||||||
<string name="ongoing_notification_title">Signed into Briar</string>
|
<string name="ongoing_notification_title">Signed into Briar</string>
|
||||||
@@ -13,6 +15,10 @@
|
|||||||
<string name="passwords_do_not_match">Passwords do not match</string>
|
<string name="passwords_do_not_match">Passwords do not match</string>
|
||||||
<string name="create_account_button">Create Account</string>
|
<string name="create_account_button">Create Account</string>
|
||||||
<string name="enter_password">Enter your password:</string>
|
<string name="enter_password">Enter your password:</string>
|
||||||
|
<string name="password_hint">Password</string>
|
||||||
|
<string name="yes">Yes</string>
|
||||||
|
<string name="no">No</string>
|
||||||
|
<string name="forgotten_password">I have forgotten my password</string>
|
||||||
<string name="try_again">Wrong password, try again:</string>
|
<string name="try_again">Wrong password, try again:</string>
|
||||||
<string name="sign_in_button">Sign In</string>
|
<string name="sign_in_button">Sign In</string>
|
||||||
<string name="startup_failed_notification_title">Briar could not start</string>
|
<string name="startup_failed_notification_title">Briar could not start</string>
|
||||||
@@ -104,4 +110,8 @@
|
|||||||
<string name="notify_sound_setting_default">Default ringtone</string>
|
<string name="notify_sound_setting_default">Default ringtone</string>
|
||||||
<string name="notify_sound_setting_disabled">None</string>
|
<string name="notify_sound_setting_disabled">None</string>
|
||||||
<string name="choose_ringtone_title">Choose ringtone</string>
|
<string name="choose_ringtone_title">Choose ringtone</string>
|
||||||
|
|
||||||
|
<!-- Dialogs -->
|
||||||
|
<string name="dialog_title_lost_password">Lost password</string>
|
||||||
|
<string name="dialog_message_lost_password">Password recovery is not possible. Do you wish to delete your user, all contacts, and re-register ?</string>
|
||||||
</resources>
|
</resources>
|
||||||
@@ -12,4 +12,21 @@
|
|||||||
<style name="WindowTitleBackground">
|
<style name="WindowTitleBackground">
|
||||||
<item name="android:background">@color/action_bar_background</item>
|
<item name="android:background">@color/action_bar_background</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
<style name="BriarButton">
|
||||||
|
<item name="android:textSize">@dimen/text_size_medium</item>
|
||||||
|
<item name="android:padding">@dimen/margin_large</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<style name="BriarButton.Default"/>
|
||||||
|
|
||||||
|
<style name="BriarTextTitle">
|
||||||
|
<item name="android:textSize">@dimen/text_size_medium</item>
|
||||||
|
<item name="android:textColor">@android:color/primary_text_light</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<style name="BriarTextBody">
|
||||||
|
<item name="android:textSize">@dimen/text_size_small</item>
|
||||||
|
<item name="android:textColor">@android:color/primary_text_light</item>
|
||||||
|
</style>
|
||||||
</resources>
|
</resources>
|
||||||
59
briar-android/src/org/briarproject/android/BaseActivity.java
Normal file
59
briar-android/src/org/briarproject/android/BaseActivity.java
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
package org.briarproject.android;
|
||||||
|
|
||||||
|
import static android.view.inputmethod.InputMethodManager.HIDE_IMPLICIT_ONLY;
|
||||||
|
import static org.briarproject.android.TestingConstants.PREVENT_SCREENSHOTS;
|
||||||
|
import static android.view.WindowManager.LayoutParams.FLAG_SECURE;
|
||||||
|
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.inputmethod.InputMethodManager;
|
||||||
|
|
||||||
|
import roboguice.activity.RoboActivity;
|
||||||
|
|
||||||
|
public abstract class BaseActivity extends RoboActivity {
|
||||||
|
|
||||||
|
private final static String PREFS_DB = "db";
|
||||||
|
private final static String KEY_DB_KEY = "key";
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
|
if (PREVENT_SCREENSHOTS) getWindow().addFlags(FLAG_SECURE);
|
||||||
|
}
|
||||||
|
|
||||||
|
private SharedPreferences getBriarPrefs(String prefsName) {
|
||||||
|
return getSharedPreferences(prefsName, MODE_PRIVATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected String getDbKeyInHex() {
|
||||||
|
return getBriarPrefs(PREFS_DB).getString(KEY_DB_KEY, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void clearPrefs(String prefsName) {
|
||||||
|
SharedPreferences.Editor editor = getBriarPrefs(prefsName).edit();
|
||||||
|
editor.clear();
|
||||||
|
editor.apply();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void clearDbPrefs() {
|
||||||
|
this.clearPrefs(PREFS_DB);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void gotoAndFinish(Class classInstance, int resultCode) {
|
||||||
|
if (resultCode != Integer.MIN_VALUE)
|
||||||
|
setResult(resultCode);
|
||||||
|
startActivity(new Intent(this, classInstance));
|
||||||
|
finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void gotoAndFinish(Class classInstance) {
|
||||||
|
gotoAndFinish(classInstance, Integer.MIN_VALUE);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void hideSoftKeyboard() {
|
||||||
|
Object o = getSystemService(INPUT_METHOD_SERVICE);
|
||||||
|
((InputMethodManager) o).toggleSoftInput(HIDE_IMPLICIT_ONLY, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -25,7 +25,7 @@ import android.os.IBinder;
|
|||||||
import android.view.inputmethod.InputMethodManager;
|
import android.view.inputmethod.InputMethodManager;
|
||||||
|
|
||||||
@SuppressLint("Registered")
|
@SuppressLint("Registered")
|
||||||
public class BriarActivity extends RoboActivity {
|
public class BriarActivity extends BaseActivity {
|
||||||
|
|
||||||
public static final int REQUEST_PASSWORD = 1;
|
public static final int REQUEST_PASSWORD = 1;
|
||||||
|
|
||||||
@@ -45,7 +45,6 @@ public class BriarActivity extends RoboActivity {
|
|||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle state) {
|
public void onCreate(Bundle state) {
|
||||||
super.onCreate(state);
|
super.onCreate(state);
|
||||||
if (PREVENT_SCREENSHOTS) getWindow().addFlags(FLAG_SECURE);
|
|
||||||
if (databaseConfig.getEncryptionKey() != null) startAndBindService();
|
if (databaseConfig.getEncryptionKey() != null) startAndBindService();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -45,7 +45,6 @@ import org.briarproject.android.util.LayoutUtils;
|
|||||||
import org.briarproject.android.util.ListLoadingProgressBar;
|
import org.briarproject.android.util.ListLoadingProgressBar;
|
||||||
import org.briarproject.api.android.AndroidExecutor;
|
import org.briarproject.api.android.AndroidExecutor;
|
||||||
import org.briarproject.api.system.FileUtils;
|
import org.briarproject.api.system.FileUtils;
|
||||||
import org.briarproject.system.AndroidFileUtils;
|
|
||||||
import org.briarproject.util.StringUtils;
|
import org.briarproject.util.StringUtils;
|
||||||
|
|
||||||
import android.annotation.SuppressLint;
|
import android.annotation.SuppressLint;
|
||||||
@@ -71,12 +70,14 @@ import android.widget.LinearLayout;
|
|||||||
import android.widget.ScrollView;
|
import android.widget.ScrollView;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import javax.inject.Inject;
|
||||||
|
|
||||||
public class CrashReportActivity extends Activity implements OnClickListener {
|
public class CrashReportActivity extends Activity implements OnClickListener {
|
||||||
|
|
||||||
private static final Logger LOG =
|
private static final Logger LOG =
|
||||||
Logger.getLogger(CrashReportActivity.class.getName());
|
Logger.getLogger(CrashReportActivity.class.getName());
|
||||||
|
|
||||||
private final FileUtils fileUtils = new AndroidFileUtils();
|
@Inject private FileUtils fileUtils;
|
||||||
private final AndroidExecutor androidExecutor = new AndroidExecutorImpl();
|
private final AndroidExecutor androidExecutor = new AndroidExecutorImpl();
|
||||||
|
|
||||||
private ScrollView scroll = null;
|
private ScrollView scroll = null;
|
||||||
|
|||||||
@@ -1,138 +1,106 @@
|
|||||||
package org.briarproject.android;
|
package org.briarproject.android;
|
||||||
|
|
||||||
import static android.text.InputType.TYPE_CLASS_TEXT;
|
|
||||||
import static android.text.InputType.TYPE_TEXT_VARIATION_PASSWORD;
|
|
||||||
import static android.view.Gravity.CENTER;
|
|
||||||
import static android.view.Gravity.CENTER_HORIZONTAL;
|
|
||||||
import static android.view.View.GONE;
|
import static android.view.View.GONE;
|
||||||
import static android.view.View.VISIBLE;
|
import static android.view.View.VISIBLE;
|
||||||
import static android.view.WindowManager.LayoutParams.FLAG_SECURE;
|
|
||||||
import static android.view.inputmethod.InputMethodManager.HIDE_IMPLICIT_ONLY;
|
|
||||||
import static android.widget.LinearLayout.VERTICAL;
|
|
||||||
import static org.briarproject.android.TestingConstants.PREVENT_SCREENSHOTS;
|
|
||||||
import static org.briarproject.android.util.CommonLayoutParams.MATCH_MATCH;
|
|
||||||
import static org.briarproject.android.util.CommonLayoutParams.WRAP_WRAP;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.util.concurrent.Executor;
|
import java.util.concurrent.Executor;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
import org.briarproject.R;
|
import org.briarproject.R;
|
||||||
import org.briarproject.android.util.FixedVerticalSpace;
|
|
||||||
import org.briarproject.android.util.LayoutUtils;
|
|
||||||
import org.briarproject.api.crypto.CryptoComponent;
|
import org.briarproject.api.crypto.CryptoComponent;
|
||||||
import org.briarproject.api.crypto.CryptoExecutor;
|
import org.briarproject.api.crypto.CryptoExecutor;
|
||||||
import org.briarproject.api.crypto.SecretKey;
|
import org.briarproject.api.crypto.SecretKey;
|
||||||
import org.briarproject.api.db.DatabaseConfig;
|
import org.briarproject.api.db.DatabaseConfig;
|
||||||
|
import org.briarproject.api.system.FileUtils;
|
||||||
import org.briarproject.util.StringUtils;
|
import org.briarproject.util.StringUtils;
|
||||||
|
|
||||||
import roboguice.activity.RoboActivity;
|
import android.app.AlertDialog;
|
||||||
import android.content.Intent;
|
import android.content.DialogInterface;
|
||||||
import android.content.SharedPreferences;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.text.Editable;
|
import android.text.Editable;
|
||||||
import android.view.KeyEvent;
|
import android.view.KeyEvent;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.View.OnClickListener;
|
import android.view.inputmethod.EditorInfo;
|
||||||
import android.view.inputmethod.InputMethodManager;
|
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.EditText;
|
import android.widget.EditText;
|
||||||
import android.widget.LinearLayout;
|
|
||||||
import android.widget.ProgressBar;
|
import android.widget.ProgressBar;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import android.widget.TextView.OnEditorActionListener;
|
import android.widget.TextView.OnEditorActionListener;
|
||||||
|
|
||||||
public class PasswordActivity extends RoboActivity {
|
public class PasswordActivity extends BaseActivity {
|
||||||
|
|
||||||
@Inject @CryptoExecutor private Executor cryptoExecutor;
|
@Inject @CryptoExecutor private Executor cryptoExecutor;
|
||||||
private TextView enterPassword = null;
|
private Button signInButton;
|
||||||
private EditText passwordEntry = null;
|
private ProgressBar progress;
|
||||||
private Button signInButton = null;
|
private TextView title;
|
||||||
private ProgressBar progress = null;
|
private EditText password;
|
||||||
|
|
||||||
|
private byte[] encrypted;
|
||||||
|
|
||||||
// Fields that are accessed from background threads must be volatile
|
// Fields that are accessed from background threads must be volatile
|
||||||
@Inject private volatile CryptoComponent crypto;
|
@Inject private volatile CryptoComponent crypto;
|
||||||
@Inject private volatile DatabaseConfig databaseConfig;
|
@Inject private volatile DatabaseConfig databaseConfig;
|
||||||
|
@Inject private FileUtils fileUtils;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle state) {
|
public void onCreate(Bundle state) {
|
||||||
super.onCreate(state);
|
super.onCreate(state);
|
||||||
|
|
||||||
if (PREVENT_SCREENSHOTS) getWindow().addFlags(FLAG_SECURE);
|
String hex = getDbKeyInHex();
|
||||||
|
|
||||||
SharedPreferences prefs = getSharedPreferences("db", MODE_PRIVATE);
|
|
||||||
String hex = prefs.getString("key", null);
|
|
||||||
if (hex == null || !databaseConfig.databaseExists()) {
|
if (hex == null || !databaseConfig.databaseExists()) {
|
||||||
// Storage has been deleted - clean up and return to setup
|
clearDbPrefs();
|
||||||
prefs.edit().clear().commit();
|
|
||||||
delete(databaseConfig.getDatabaseDirectory());
|
|
||||||
setResult(RESULT_CANCELED);
|
|
||||||
startActivity(new Intent(this, SetupActivity.class));
|
|
||||||
finish();
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final byte[] encrypted = StringUtils.fromHexString(hex);
|
encrypted = StringUtils.fromHexString(hex);
|
||||||
|
|
||||||
LinearLayout layout = new LinearLayout(this);
|
setContentView(R.layout.activity_password);
|
||||||
layout.setLayoutParams(MATCH_MATCH);
|
signInButton = (Button)findViewById(R.id.btn_sign_in);
|
||||||
layout.setOrientation(VERTICAL);
|
progress = (ProgressBar)findViewById(R.id.progress_wheel);
|
||||||
layout.setGravity(CENTER_HORIZONTAL);
|
title = (TextView)findViewById(R.id.title_password);
|
||||||
int pad = LayoutUtils.getPadding(this);
|
password = (EditText)findViewById(R.id.edit_password);
|
||||||
layout.setPadding(pad, pad, pad, pad);
|
password.setOnEditorActionListener(new OnEditorActionListener() {
|
||||||
|
@Override
|
||||||
enterPassword = new TextView(this);
|
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
|
||||||
enterPassword.setGravity(CENTER);
|
if (actionId == EditorInfo.IME_ACTION_DONE) {
|
||||||
enterPassword.setTextSize(18);
|
validatePassword(encrypted, password.getText());
|
||||||
enterPassword.setText(R.string.enter_password);
|
}
|
||||||
layout.addView(enterPassword);
|
return false;
|
||||||
|
|
||||||
passwordEntry = new EditText(this);
|
|
||||||
passwordEntry.setId(1);
|
|
||||||
passwordEntry.setMaxLines(1);
|
|
||||||
int inputType = TYPE_CLASS_TEXT | TYPE_TEXT_VARIATION_PASSWORD;
|
|
||||||
passwordEntry.setInputType(inputType);
|
|
||||||
passwordEntry.setOnEditorActionListener(new OnEditorActionListener() {
|
|
||||||
public boolean onEditorAction(TextView v, int action, KeyEvent e) {
|
|
||||||
validatePassword(encrypted, passwordEntry.getText());
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
layout.addView(passwordEntry);
|
|
||||||
|
|
||||||
// Adjusting the padding of buttons and EditTexts has the wrong results
|
|
||||||
layout.addView(new FixedVerticalSpace(this));
|
|
||||||
|
|
||||||
signInButton = new Button(this);
|
|
||||||
signInButton.setLayoutParams(WRAP_WRAP);
|
|
||||||
signInButton.setText(R.string.sign_in_button);
|
|
||||||
signInButton.setOnClickListener(new OnClickListener() {
|
|
||||||
public void onClick(View v) {
|
|
||||||
validatePassword(encrypted, passwordEntry.getText());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
layout.addView(signInButton);
|
|
||||||
|
|
||||||
progress = new ProgressBar(this);
|
|
||||||
progress.setLayoutParams(WRAP_WRAP);
|
|
||||||
progress.setIndeterminate(true);
|
|
||||||
progress.setVisibility(GONE);
|
|
||||||
layout.addView(progress);
|
|
||||||
setContentView(layout);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void delete(File f) {
|
@Override
|
||||||
if (f.isFile()) f.delete();
|
protected void clearDbPrefs() {
|
||||||
else if (f.isDirectory()) for (File child : f.listFiles()) delete(child);
|
super.clearDbPrefs();
|
||||||
|
fileUtils.deleteFileOrDir(databaseConfig.getDatabaseDirectory());
|
||||||
|
gotoAndFinish(SetupActivity.class, RESULT_CANCELED);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onSignInClick(View v) {
|
||||||
|
validatePassword(encrypted, password.getText());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onForgottenPasswordClick(View v) {
|
||||||
|
// TODO Encapsulate the dialog in a re-usable fragment
|
||||||
|
AlertDialog.Builder builder = new AlertDialog.Builder(this);
|
||||||
|
builder.setTitle(R.string.dialog_title_lost_password);
|
||||||
|
builder.setMessage(R.string.dialog_message_lost_password);
|
||||||
|
builder.setNegativeButton(R.string.no, null);
|
||||||
|
builder.setPositiveButton(R.string.yes, new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
clearDbPrefs();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
AlertDialog dialog = builder.create();
|
||||||
|
dialog.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void validatePassword(final byte[] encrypted, Editable e) {
|
private void validatePassword(final byte[] encrypted, Editable e) {
|
||||||
if (progress == null) return; // Not created yet
|
hideSoftKeyboard();
|
||||||
// Hide the soft keyboard
|
|
||||||
Object o = getSystemService(INPUT_METHOD_SERVICE);
|
|
||||||
((InputMethodManager) o).toggleSoftInput(HIDE_IMPLICIT_ONLY, 0);
|
|
||||||
// Replace the button with a progress bar
|
// Replace the button with a progress bar
|
||||||
signInButton.setVisibility(GONE);
|
signInButton.setVisibility(View.INVISIBLE);
|
||||||
progress.setVisibility(VISIBLE);
|
progress.setVisibility(VISIBLE);
|
||||||
// Decrypt the database key in a background thread
|
// Decrypt the database key in a background thread
|
||||||
final String password = e.toString();
|
final String password = e.toString();
|
||||||
@@ -152,10 +120,10 @@ public class PasswordActivity extends RoboActivity {
|
|||||||
private void tryAgain() {
|
private void tryAgain() {
|
||||||
runOnUiThread(new Runnable() {
|
runOnUiThread(new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
enterPassword.setText(R.string.try_again);
|
title.setText(R.string.try_again);
|
||||||
passwordEntry.setText("");
|
|
||||||
signInButton.setVisibility(VISIBLE);
|
signInButton.setVisibility(VISIBLE);
|
||||||
progress.setVisibility(GONE);
|
progress.setVisibility(GONE);
|
||||||
|
password.setText("");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,17 +0,0 @@
|
|||||||
package org.briarproject.system;
|
|
||||||
|
|
||||||
import org.briarproject.api.system.FileUtils;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
public class AndroidFileUtils implements FileUtils {
|
|
||||||
|
|
||||||
public long getTotalSpace(File f) throws IOException {
|
|
||||||
return f.getTotalSpace();
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getFreeSpace(File f) throws IOException {
|
|
||||||
return f.getUsableSpace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -14,7 +14,7 @@ public class AndroidSystemModule extends AbstractModule {
|
|||||||
bind(Clock.class).to(SystemClock.class);
|
bind(Clock.class).to(SystemClock.class);
|
||||||
bind(Timer.class).to(SystemTimer.class);
|
bind(Timer.class).to(SystemTimer.class);
|
||||||
bind(SeedProvider.class).to(AndroidSeedProvider.class);
|
bind(SeedProvider.class).to(AndroidSeedProvider.class);
|
||||||
bind(FileUtils.class).to(AndroidFileUtils.class);
|
bind(FileUtils.class).to(FileUtilsImpl.class);
|
||||||
bind(LocationUtils.class).to(AndroidLocationUtils.class);
|
bind(LocationUtils.class).to(AndroidLocationUtils.class);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,4 +8,6 @@ public interface FileUtils {
|
|||||||
long getTotalSpace(File f) throws IOException;
|
long getTotalSpace(File f) throws IOException;
|
||||||
|
|
||||||
long getFreeSpace(File f) throws IOException;
|
long getFreeSpace(File f) throws IOException;
|
||||||
|
|
||||||
|
void deleteFileOrDir(File f);
|
||||||
}
|
}
|
||||||
|
|||||||
25
briar-core/src/org/briarproject/system/FileUtilsImpl.java
Normal file
25
briar-core/src/org/briarproject/system/FileUtilsImpl.java
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package org.briarproject.system;
|
||||||
|
|
||||||
|
import org.briarproject.api.system.FileUtils;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class FileUtilsImpl implements FileUtils {
|
||||||
|
|
||||||
|
public long getTotalSpace(File f) throws IOException {
|
||||||
|
return f.getTotalSpace(); // Requires Java 1.6
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getFreeSpace(File f) throws IOException {
|
||||||
|
return f.getUsableSpace(); // Requires Java 1.6
|
||||||
|
}
|
||||||
|
|
||||||
|
public void deleteFileOrDir(File f) {
|
||||||
|
if (f.isFile())
|
||||||
|
f.delete();
|
||||||
|
else if (f.isDirectory())
|
||||||
|
for (File child : f.listFiles())
|
||||||
|
deleteFileOrDir(child);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
package org.briarproject.system;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import org.briarproject.api.system.FileUtils;
|
|
||||||
|
|
||||||
class DesktopFileUtils implements FileUtils {
|
|
||||||
|
|
||||||
public long getTotalSpace(File f) throws IOException {
|
|
||||||
return f.getTotalSpace(); // Requires Java 1.6
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getFreeSpace(File f) throws IOException {
|
|
||||||
return f.getUsableSpace(); // Requires Java 1.6
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -15,6 +15,6 @@ public class DesktopSystemModule extends AbstractModule {
|
|||||||
bind(Timer.class).to(SystemTimer.class);
|
bind(Timer.class).to(SystemTimer.class);
|
||||||
if (OsUtils.isLinux())
|
if (OsUtils.isLinux())
|
||||||
bind(SeedProvider.class).to(LinuxSeedProvider.class);
|
bind(SeedProvider.class).to(LinuxSeedProvider.class);
|
||||||
bind(FileUtils.class).to(DesktopFileUtils.class);
|
bind(FileUtils.class).to(FileUtilsImpl.class);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import com.google.inject.AbstractModule;
|
|||||||
|
|
||||||
import org.briarproject.api.db.DatabaseConfig;
|
import org.briarproject.api.db.DatabaseConfig;
|
||||||
import org.briarproject.api.system.FileUtils;
|
import org.briarproject.api.system.FileUtils;
|
||||||
|
import org.briarproject.system.FileUtilsImpl;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
|
||||||
@@ -25,6 +26,6 @@ public class TestDatabaseModule extends AbstractModule {
|
|||||||
|
|
||||||
protected void configure() {
|
protected void configure() {
|
||||||
bind(DatabaseConfig.class).toInstance(config);
|
bind(DatabaseConfig.class).toInstance(config);
|
||||||
bind(FileUtils.class).to(TestFileUtils.class);
|
bind(FileUtils.class).to(FileUtilsImpl.class);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,17 +0,0 @@
|
|||||||
package org.briarproject;
|
|
||||||
|
|
||||||
import org.briarproject.api.system.FileUtils;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
public class TestFileUtils implements FileUtils {
|
|
||||||
|
|
||||||
public long getTotalSpace(File f) throws IOException {
|
|
||||||
return f.getTotalSpace();
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getFreeSpace(File f) throws IOException {
|
|
||||||
return f.getUsableSpace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -2,7 +2,6 @@ package org.briarproject.db;
|
|||||||
|
|
||||||
import org.briarproject.BriarTestCase;
|
import org.briarproject.BriarTestCase;
|
||||||
import org.briarproject.TestDatabaseConfig;
|
import org.briarproject.TestDatabaseConfig;
|
||||||
import org.briarproject.TestFileUtils;
|
|
||||||
import org.briarproject.TestMessage;
|
import org.briarproject.TestMessage;
|
||||||
import org.briarproject.TestUtils;
|
import org.briarproject.TestUtils;
|
||||||
import org.briarproject.api.Author;
|
import org.briarproject.api.Author;
|
||||||
@@ -20,6 +19,7 @@ import org.briarproject.api.messaging.Message;
|
|||||||
import org.briarproject.api.messaging.MessageId;
|
import org.briarproject.api.messaging.MessageId;
|
||||||
import org.briarproject.api.transport.Endpoint;
|
import org.briarproject.api.transport.Endpoint;
|
||||||
import org.briarproject.api.transport.TemporarySecret;
|
import org.briarproject.api.transport.TemporarySecret;
|
||||||
|
import org.briarproject.system.FileUtilsImpl;
|
||||||
import org.briarproject.system.SystemClock;
|
import org.briarproject.system.SystemClock;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -1610,7 +1610,7 @@ public class H2DatabaseTest extends BriarTestCase {
|
|||||||
|
|
||||||
private Database<Connection> open(boolean resume) throws Exception {
|
private Database<Connection> open(boolean resume) throws Exception {
|
||||||
Database<Connection> db = new H2Database(new TestDatabaseConfig(testDir,
|
Database<Connection> db = new H2Database(new TestDatabaseConfig(testDir,
|
||||||
MAX_SIZE), new TestFileUtils(), new SystemClock());
|
MAX_SIZE), new FileUtilsImpl(), new SystemClock());
|
||||||
if (!resume) TestUtils.deleteTestDirectory(testDir);
|
if (!resume) TestUtils.deleteTestDirectory(testDir);
|
||||||
db.open();
|
db.open();
|
||||||
return db;
|
return db;
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package org.briarproject.plugins.file;
|
package org.briarproject.plugins.file;
|
||||||
|
|
||||||
|
import com.google.inject.Inject;
|
||||||
import org.briarproject.BriarTestCase;
|
import org.briarproject.BriarTestCase;
|
||||||
import org.briarproject.TestFileUtils;
|
|
||||||
import org.briarproject.TestUtils;
|
import org.briarproject.TestUtils;
|
||||||
import org.briarproject.api.ContactId;
|
import org.briarproject.api.ContactId;
|
||||||
import org.briarproject.api.plugins.TransportConnectionWriter;
|
import org.briarproject.api.plugins.TransportConnectionWriter;
|
||||||
@@ -34,7 +34,7 @@ public class RemovableDrivePluginTest extends BriarTestCase {
|
|||||||
|
|
||||||
private final File testDir = TestUtils.getTestDirectory();
|
private final File testDir = TestUtils.getTestDirectory();
|
||||||
private final ContactId contactId = new ContactId(234);
|
private final ContactId contactId = new ContactId(234);
|
||||||
private final FileUtils fileUtils = new TestFileUtils();
|
@Inject private FileUtils fileUtils;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
|
|||||||
Reference in New Issue
Block a user