mirror of
https://github.com/moparisthebest/keepass2android
synced 2024-12-23 07:28:48 -05:00
fix crashes when keyfile filename is not yet encoded and when loading key file (no network in main thread!)
increase version
This commit is contained in:
parent
4ab8894503
commit
ff525bd655
@ -88,6 +88,8 @@ namespace keepass2android
|
||||
private const int RequestCodePrepareOtpAuxFile = 1001;
|
||||
private const int RequestCodeChallengeYubikey = 1002;
|
||||
private const int RequestCodeSelectKeyfile = 1003;
|
||||
private const int RequestCodePrepareKeyFile = 1004;
|
||||
|
||||
|
||||
private Task<MemoryStream> _loadDbTask;
|
||||
private IOConnectionInfo _ioConnection;
|
||||
@ -278,7 +280,22 @@ namespace keepass2android
|
||||
break;
|
||||
case (Result)FileStorageResults.FileUsagePrepared:
|
||||
if (requestCode == RequestCodePrepareDbFile)
|
||||
{
|
||||
if (KeyProviderType == KeyProviders.KeyFile)
|
||||
{
|
||||
var iocKeyfile = IOConnectionInfo.UnserializeFromString(_keyFileOrProvider);
|
||||
|
||||
App.Kp2a.GetFileStorage(iocKeyfile)
|
||||
.PrepareFileUsage(new FileStorageSetupInitiatorActivity(this, OnActivityResult, null), iocKeyfile,
|
||||
RequestCodePrepareKeyFile, false);
|
||||
}
|
||||
else
|
||||
PerformLoadDatabase();
|
||||
}
|
||||
if (requestCode == RequestCodePrepareKeyFile)
|
||||
{
|
||||
PerformLoadDatabase();
|
||||
}
|
||||
if (requestCode == RequestCodePrepareOtpAuxFile)
|
||||
{
|
||||
if (_keyFileOrProvider == KeyProviderIdChallenge)
|
||||
@ -551,7 +568,17 @@ namespace keepass2android
|
||||
else
|
||||
{
|
||||
SetIoConnectionFromIntent(_ioConnection, i);
|
||||
_keyFileOrProvider = i.GetStringExtra(KeyKeyfile);
|
||||
var keyFileFromIntent = i.GetStringExtra(KeyKeyfile);
|
||||
if (keyFileFromIntent != null)
|
||||
{
|
||||
Kp2aLog.Log("try get keyfile from intent");
|
||||
_keyFileOrProvider = IOConnectionInfo.SerializeToString(IOConnectionInfo.FromPath(keyFileFromIntent));
|
||||
Kp2aLog.Log("try get keyfile from intent ok");
|
||||
}
|
||||
else
|
||||
{
|
||||
_keyFileOrProvider = null;
|
||||
}
|
||||
_password = i.GetStringExtra(KeyPassword) ?? "";
|
||||
if (string.IsNullOrEmpty(_keyFileOrProvider))
|
||||
{
|
||||
@ -897,9 +924,45 @@ namespace keepass2android
|
||||
|
||||
private void PerformLoadDatabase()
|
||||
{
|
||||
//put loading into background thread to allow loading the key file (potentially over network)
|
||||
new SimpleLoadingDialog(this, GetString(Resource.String.loading),
|
||||
true, () =>
|
||||
{
|
||||
CompositeKey compositeKey;
|
||||
if (!CreateCompositeKey(out compositeKey)) return (() => { });
|
||||
return () => { PerformLoadDatabaseWithCompositeKey(compositeKey); };
|
||||
}).Execute();
|
||||
|
||||
//no need to check for validity of password because if this method is called, the Ok button was enabled (i.e. there was a valid password)
|
||||
CompositeKey compositeKey = new CompositeKey();
|
||||
|
||||
}
|
||||
|
||||
private void PerformLoadDatabaseWithCompositeKey(CompositeKey compositeKey)
|
||||
{
|
||||
CheckBox cbQuickUnlock = (CheckBox) FindViewById(Resource.Id.enable_quickunlock);
|
||||
App.Kp2a.SetQuickUnlockEnabled(cbQuickUnlock.Checked);
|
||||
|
||||
//avoid password being visible while loading:
|
||||
_showPassword = false;
|
||||
MakePasswordMaskedOrVisible();
|
||||
|
||||
Handler handler = new Handler();
|
||||
OnFinish onFinish = new AfterLoad(handler, this);
|
||||
_performingLoad = true;
|
||||
LoadDb task = (KeyProviderType == KeyProviders.Otp)
|
||||
? new SaveOtpAuxFileAndLoadDb(App.Kp2a, _ioConnection, _loadDbTask, compositeKey, _keyFileOrProvider,
|
||||
onFinish, this)
|
||||
: new LoadDb(App.Kp2a, _ioConnection, _loadDbTask, compositeKey, _keyFileOrProvider, onFinish);
|
||||
_loadDbTask = null; // prevent accidental re-use
|
||||
|
||||
SetNewDefaultFile();
|
||||
|
||||
new ProgressTask(App.Kp2a, this, task).Run();
|
||||
}
|
||||
|
||||
private bool CreateCompositeKey(out CompositeKey compositeKey)
|
||||
{
|
||||
//no need to check for validity of password because if this method is called, the Ok button was enabled (i.e. there was a valid password)
|
||||
compositeKey = new CompositeKey();
|
||||
compositeKey.AddUserKey(new KcpPassword(_password));
|
||||
if (KeyProviderType == KeyProviders.KeyFile)
|
||||
{
|
||||
@ -913,24 +976,22 @@ namespace keepass2android
|
||||
byte[] keyfileData = StreamToMemoryStream(stream).ToArray();
|
||||
compositeKey.AddUserKey(new KcpKeyFile(keyfileData, ioc, true));
|
||||
}
|
||||
|
||||
}
|
||||
catch (System.IO.FileNotFoundException e)
|
||||
{
|
||||
Kp2aLog.Log(e.ToString());
|
||||
Toast.MakeText(this, App.Kp2a.GetResourceString(UiStringKey.keyfile_does_not_exist), ToastLength.Long).Show();
|
||||
return;
|
||||
return false;
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Kp2aLog.Log(e.ToString());
|
||||
Toast.MakeText(this, e.Message, ToastLength.Long).Show();
|
||||
return;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else if (KeyProviderType == KeyProviders.Otp)
|
||||
{
|
||||
|
||||
try
|
||||
{
|
||||
var lOtps = GetOtpsFromUi();
|
||||
@ -942,7 +1003,7 @@ namespace keepass2android
|
||||
Kp2aLog.Log(e.ToString());
|
||||
Toast.MakeText(this, GetString(Resource.String.OtpKeyError), ToastLength.Long).Show();
|
||||
|
||||
return;
|
||||
return false;
|
||||
}
|
||||
compositeKey.AddUserKey(new KcpCustomKey(OathHotpKeyProv.Name, _otpInfo.Secret, true));
|
||||
}
|
||||
@ -951,7 +1012,7 @@ namespace keepass2android
|
||||
Spinner stpDataFmtSpinner = FindViewById<Spinner>(Resource.Id.otpsecret_format_spinner);
|
||||
EditText secretEdit = FindViewById<EditText>(Resource.Id.pass_otpsecret);
|
||||
|
||||
byte[] pbSecret = EncodingUtil.ParseKey(secretEdit.Text, (OtpDataFmt)stpDataFmtSpinner.SelectedItemPosition);
|
||||
byte[] pbSecret = EncodingUtil.ParseKey(secretEdit.Text, (OtpDataFmt) stpDataFmtSpinner.SelectedItemPosition);
|
||||
if (pbSecret != null)
|
||||
{
|
||||
compositeKey.AddUserKey(new KcpCustomKey(OathHotpKeyProv.Name, pbSecret, true));
|
||||
@ -959,34 +1020,14 @@ namespace keepass2android
|
||||
else
|
||||
{
|
||||
Toast.MakeText(this, Resource.String.CouldntParseOtpSecret, ToastLength.Long).Show();
|
||||
return;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
else if (KeyProviderType == KeyProviders.Challenge)
|
||||
{
|
||||
compositeKey.AddUserKey(new KcpCustomKey(KeeChallengeProv.Name, _challengeSecret, true));
|
||||
|
||||
}
|
||||
|
||||
CheckBox cbQuickUnlock = (CheckBox) FindViewById(Resource.Id.enable_quickunlock);
|
||||
App.Kp2a.SetQuickUnlockEnabled(cbQuickUnlock.Checked);
|
||||
|
||||
//avoid password being visible while loading:
|
||||
_showPassword = false;
|
||||
MakePasswordMaskedOrVisible();
|
||||
|
||||
Handler handler = new Handler();
|
||||
OnFinish onFinish = new AfterLoad(handler, this);
|
||||
_performingLoad = true;
|
||||
LoadDb task = (KeyProviderType == KeyProviders.Otp) ?
|
||||
new SaveOtpAuxFileAndLoadDb(App.Kp2a, _ioConnection, _loadDbTask, compositeKey, _keyFileOrProvider, onFinish, this)
|
||||
:
|
||||
new LoadDb(App.Kp2a, _ioConnection, _loadDbTask, compositeKey, _keyFileOrProvider, onFinish);
|
||||
_loadDbTask = null; // prevent accidental re-use
|
||||
|
||||
SetNewDefaultFile();
|
||||
|
||||
new ProgressTask(App.Kp2a, this, task).Run();
|
||||
else if (KeyProviderType == KeyProviders.Challenge)
|
||||
{
|
||||
compositeKey.AddUserKey(new KcpCustomKey(KeeChallengeProv.Name, _challengeSecret, true));
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
private List<string> GetOtpsFromUi()
|
||||
@ -1251,8 +1292,26 @@ namespace keepass2android
|
||||
private String GetKeyFile(String filename) {
|
||||
if ( _rememberKeyfile ) {
|
||||
string keyfile = App.Kp2a.FileDbHelper.GetKeyFileForFile(filename);
|
||||
if (keyfile == "")
|
||||
if (String.IsNullOrEmpty(keyfile))
|
||||
return null; //signal no key file
|
||||
|
||||
//test if the filename is properly encoded.
|
||||
try
|
||||
{
|
||||
Kp2aLog.Log("test if stored filename is ok");
|
||||
IOConnectionInfo.UnserializeFromString(keyfile);
|
||||
Kp2aLog.Log("...ok");
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
//it's not. This is probably because we're upgrading from app version <= 45
|
||||
//where the keyfile was stored plain text and not serialized
|
||||
Kp2aLog.Log("no, it's not: "+e.GetType().Name);
|
||||
var serializedKeyFile = IOConnectionInfo.SerializeToString(IOConnectionInfo.FromPath(keyfile));
|
||||
Kp2aLog.Log("now it is!");
|
||||
return serializedKeyFile;
|
||||
|
||||
}
|
||||
return keyfile;
|
||||
} else {
|
||||
return null;
|
||||
|
@ -1,5 +1,5 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:versionCode="46" android:versionName="0.9.5-preview" package="keepass2android.keepass2android" android:installLocation="auto">
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" android:versionCode="47" android:versionName="0.9.5-preview2" package="keepass2android.keepass2android" android:installLocation="auto">
|
||||
<uses-sdk android:minSdkVersion="14" android:targetSdkVersion="19" />
|
||||
<permission android:description="@string/permission_desc" android:icon="@drawable/ic_launcher" android:label="KP2A internal file browsing" android:name="keepass2android.keepass2android.permission.KP2aInternalFileBrowsing" android:protectionLevel="signature" />
|
||||
<application android:label="keepass2android" android:icon="@drawable/ic_launcher">
|
||||
|
145
src/keepass2android/Resources/Resource.designer.cs
generated
145
src/keepass2android/Resources/Resource.designer.cs
generated
@ -4667,53 +4667,56 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f0702eb
|
||||
public const int CertificateWarning = 2131165931;
|
||||
|
||||
// aapt resource value: 0x7f070309
|
||||
public const int ChangeLog = 2131165961;
|
||||
|
||||
// aapt resource value: 0x7f070308
|
||||
public const int ChangeLog = 2131165960;
|
||||
|
||||
// aapt resource value: 0x7f070307
|
||||
public const int ChangeLog_0_7 = 2131165959;
|
||||
|
||||
// aapt resource value: 0x7f070305
|
||||
public const int ChangeLog_0_8 = 2131165957;
|
||||
|
||||
// aapt resource value: 0x7f070304
|
||||
public const int ChangeLog_0_8_1 = 2131165956;
|
||||
|
||||
// aapt resource value: 0x7f070303
|
||||
public const int ChangeLog_0_8_2 = 2131165955;
|
||||
|
||||
// aapt resource value: 0x7f070302
|
||||
public const int ChangeLog_0_8_3 = 2131165954;
|
||||
|
||||
// aapt resource value: 0x7f070301
|
||||
public const int ChangeLog_0_8_4 = 2131165953;
|
||||
|
||||
// aapt resource value: 0x7f070300
|
||||
public const int ChangeLog_0_8_5 = 2131165952;
|
||||
|
||||
// aapt resource value: 0x7f0702ff
|
||||
public const int ChangeLog_0_8_6 = 2131165951;
|
||||
|
||||
// aapt resource value: 0x7f0702fe
|
||||
public const int ChangeLog_0_9 = 2131165950;
|
||||
|
||||
// aapt resource value: 0x7f0702fd
|
||||
public const int ChangeLog_0_9_1 = 2131165949;
|
||||
|
||||
// aapt resource value: 0x7f0702fc
|
||||
public const int ChangeLog_0_9_2 = 2131165948;
|
||||
|
||||
// aapt resource value: 0x7f0702fb
|
||||
public const int ChangeLog_0_9_3 = 2131165947;
|
||||
|
||||
// aapt resource value: 0x7f0702fa
|
||||
public const int ChangeLog_0_9_3_r5 = 2131165946;
|
||||
|
||||
// aapt resource value: 0x7f0702f9
|
||||
public const int ChangeLog_0_9_4 = 2131165945;
|
||||
public const int ChangeLog_0_7 = 2131165960;
|
||||
|
||||
// aapt resource value: 0x7f070306
|
||||
public const int ChangeLog_keptDonate = 2131165958;
|
||||
public const int ChangeLog_0_8 = 2131165958;
|
||||
|
||||
// aapt resource value: 0x7f070305
|
||||
public const int ChangeLog_0_8_1 = 2131165957;
|
||||
|
||||
// aapt resource value: 0x7f070304
|
||||
public const int ChangeLog_0_8_2 = 2131165956;
|
||||
|
||||
// aapt resource value: 0x7f070303
|
||||
public const int ChangeLog_0_8_3 = 2131165955;
|
||||
|
||||
// aapt resource value: 0x7f070302
|
||||
public const int ChangeLog_0_8_4 = 2131165954;
|
||||
|
||||
// aapt resource value: 0x7f070301
|
||||
public const int ChangeLog_0_8_5 = 2131165953;
|
||||
|
||||
// aapt resource value: 0x7f070300
|
||||
public const int ChangeLog_0_8_6 = 2131165952;
|
||||
|
||||
// aapt resource value: 0x7f0702ff
|
||||
public const int ChangeLog_0_9 = 2131165951;
|
||||
|
||||
// aapt resource value: 0x7f0702fe
|
||||
public const int ChangeLog_0_9_1 = 2131165950;
|
||||
|
||||
// aapt resource value: 0x7f0702fd
|
||||
public const int ChangeLog_0_9_2 = 2131165949;
|
||||
|
||||
// aapt resource value: 0x7f0702fc
|
||||
public const int ChangeLog_0_9_3 = 2131165948;
|
||||
|
||||
// aapt resource value: 0x7f0702fb
|
||||
public const int ChangeLog_0_9_3_r5 = 2131165947;
|
||||
|
||||
// aapt resource value: 0x7f0702fa
|
||||
public const int ChangeLog_0_9_4 = 2131165946;
|
||||
|
||||
// aapt resource value: 0x7f0702f9
|
||||
public const int ChangeLog_0_9_5 = 2131165945;
|
||||
|
||||
// aapt resource value: 0x7f070307
|
||||
public const int ChangeLog_keptDonate = 2131165959;
|
||||
|
||||
// aapt resource value: 0x7f0702f7
|
||||
public const int ChangeLog_title = 2131165943;
|
||||
@ -5600,11 +5603,11 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f070173
|
||||
public const int brackets = 2131165555;
|
||||
|
||||
// aapt resource value: 0x7f07030b
|
||||
public const int browser_intall_text = 2131165963;
|
||||
|
||||
// aapt resource value: 0x7f07030c
|
||||
public const int building_search_idx = 2131165964;
|
||||
public const int browser_intall_text = 2131165964;
|
||||
|
||||
// aapt resource value: 0x7f07030d
|
||||
public const int building_search_idx = 2131165965;
|
||||
|
||||
// aapt resource value: 0x7f0702b5
|
||||
public const int button_change_location = 2131165877;
|
||||
@ -5765,14 +5768,14 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f070119
|
||||
public const int db_key = 2131165465;
|
||||
|
||||
// aapt resource value: 0x7f07030d
|
||||
public const int decrypting_db = 2131165965;
|
||||
|
||||
// aapt resource value: 0x7f07030e
|
||||
public const int decrypting_entry = 2131165966;
|
||||
public const int decrypting_db = 2131165966;
|
||||
|
||||
// aapt resource value: 0x7f07030f
|
||||
public const int default_checkbox = 2131165967;
|
||||
public const int decrypting_entry = 2131165967;
|
||||
|
||||
// aapt resource value: 0x7f070310
|
||||
public const int default_checkbox = 2131165968;
|
||||
|
||||
// aapt resource value: 0x7f07010b
|
||||
public const int default_file_path = 2131165451;
|
||||
@ -5795,8 +5798,8 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f070120
|
||||
public const int design_key = 2131165472;
|
||||
|
||||
// aapt resource value: 0x7f070309
|
||||
public const int design_title = 2131165961;
|
||||
// aapt resource value: 0x7f07030a
|
||||
public const int design_title = 2131165962;
|
||||
|
||||
// aapt resource value: 0x7f070180
|
||||
public const int digits = 2131165568;
|
||||
@ -5858,8 +5861,8 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f070184
|
||||
public const int entry_accessed = 2131165572;
|
||||
|
||||
// aapt resource value: 0x7f070310
|
||||
public const int entry_and_or = 2131165968;
|
||||
// aapt resource value: 0x7f070311
|
||||
public const int entry_and_or = 2131165969;
|
||||
|
||||
// aapt resource value: 0x7f070196
|
||||
public const int entry_binaries = 2131165590;
|
||||
@ -5915,8 +5918,8 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f0702bd
|
||||
public const int error_adding_keyfile = 2131165885;
|
||||
|
||||
// aapt resource value: 0x7f070311
|
||||
public const int error_arc4 = 2131165969;
|
||||
// aapt resource value: 0x7f070312
|
||||
public const int error_arc4 = 2131165970;
|
||||
|
||||
// aapt resource value: 0x7f070197
|
||||
public const int error_can_not_handle_uri = 2131165591;
|
||||
@ -5930,8 +5933,8 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f07019a
|
||||
public const int error_database_exists = 2131165594;
|
||||
|
||||
// aapt resource value: 0x7f07030a
|
||||
public const int error_database_settings = 2131165962;
|
||||
// aapt resource value: 0x7f07030b
|
||||
public const int error_database_settings = 2131165963;
|
||||
|
||||
// aapt resource value: 0x7f07019b
|
||||
public const int error_database_settinoverrgs = 2131165595;
|
||||
@ -5960,8 +5963,8 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f0701a2
|
||||
public const int error_nopass = 2131165602;
|
||||
|
||||
// aapt resource value: 0x7f070312
|
||||
public const int error_out_of_memory = 2131165970;
|
||||
// aapt resource value: 0x7f070313
|
||||
public const int error_out_of_memory = 2131165971;
|
||||
|
||||
// aapt resource value: 0x7f0701a3
|
||||
public const int error_pass_gen_type = 2131165603;
|
||||
@ -5972,8 +5975,8 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f0701a5
|
||||
public const int error_rounds_not_number = 2131165605;
|
||||
|
||||
// aapt resource value: 0x7f070313
|
||||
public const int error_rounds_too_large = 2131165971;
|
||||
// aapt resource value: 0x7f070314
|
||||
public const int error_rounds_too_large = 2131165972;
|
||||
|
||||
// aapt resource value: 0x7f07023f
|
||||
public const int error_string_key = 2131165759;
|
||||
@ -6161,11 +6164,11 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f070204
|
||||
public const int insert_element_here = 2131165700;
|
||||
|
||||
// aapt resource value: 0x7f070314
|
||||
public const int install_from_market = 2131165972;
|
||||
|
||||
// aapt resource value: 0x7f070315
|
||||
public const int install_from_website = 2131165973;
|
||||
public const int install_from_market = 2131165973;
|
||||
|
||||
// aapt resource value: 0x7f070316
|
||||
public const int install_from_website = 2131165974;
|
||||
|
||||
// aapt resource value: 0x7f0701ba
|
||||
public const int invalid_algorithm = 2131165626;
|
||||
@ -6380,8 +6383,8 @@ namespace keepass2android
|
||||
// aapt resource value: 0x7f0701d4
|
||||
public const int menu_hide_password = 2131165652;
|
||||
|
||||
// aapt resource value: 0x7f070316
|
||||
public const int menu_homepage = 2131165974;
|
||||
// aapt resource value: 0x7f070317
|
||||
public const int menu_homepage = 2131165975;
|
||||
|
||||
// aapt resource value: 0x7f0701d5
|
||||
public const int menu_lock = 2131165653;
|
||||
|
@ -230,7 +230,7 @@
|
||||
<string name="QuickUnlockDefaultEnabled_title">Enable QuickUnlock by default</string>
|
||||
<string name="QuickUnlockDefaultEnabled_summary">Defines whether QuickUnlock is enabled by default or not.</string>
|
||||
<string name="ViewDatabaseSecure_title">Protect database display</string>
|
||||
<string name="ViewDatabaseSecure_summary">Protect database display</string>
|
||||
<string name="ViewDatabaseSecure_summary">If enabled, no screenshots are allowed and no thumbnail of the app is displayed in the Recent Apps list.</string>
|
||||
<string name="QuickUnlockIconHidden_title">Hide QuickUnlock icon</string>
|
||||
<string name="QuickUnlockIconHidden_summary">QuickUnlock unfortunately does not work without displaying a notification icon. Select this option to use a transparent icon.</string>
|
||||
<string name="QuickUnlockIconHidden16_title">Hide QuickUnlock icon</string>
|
||||
@ -498,6 +498,7 @@
|
||||
* Fixed issue with loading .kdb files (Keepass 1) on Nexus 5 with Android Lollipop\n
|
||||
* Added option to prevent taking screenshots/displaying app in recent apps list\n
|
||||
* Fixed issue with Google Drive file storage\n
|
||||
* Allow key files on deliberate storage types\n
|
||||
* Updated build tools --> apk size increased :-(\n
|
||||
I have promised some more changes. They will come with the next release - sorry. I wanted to publish these hot fixes as soon as possible.
|
||||
</string>
|
||||
|
Loading…
Reference in New Issue
Block a user