diff --git a/CHANGELOG b/CHANGELOG
index 112fa2c1e..14d193576 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,3 +1,22 @@
+2.0.2 (2016-02-02)
+=========================
+
+- Fix regression in database writer that caused it to strip certain special
+ characters (characters from Unicode plane > 0).
+- Fix bug in repair function that caused it to strip non-ASCII characters.
+
+2.0.1 (2016-01-31)
+=========================
+
+- Flush temporary file before opening attachment. [#390]
+- Disable password generator when showing entry in history mode. [#422]
+- Strip invalid XML chars when writing databases. [#392]
+- Add repair function to fix databases with invalid XML chars. [#392]
+- Display custom icons scaled. [#322]
+- Allow opening databases that have no password and keyfile. [#391]
+- Fix crash when importing .kdb files with invalid icon ids. [#425]
+- Update translations.
+
2.0 (2015-12-06)
=========================
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 886ee4c18..21c46fa57 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -33,8 +33,8 @@ option(WITH_TESTS "Enable building of unit tests" ON)
option(WITH_GUI_TESTS "Enable building of GUI tests" OFF)
option(WITH_DEV_BUILD "Use only for development. Disables/warns about deprecated methods." OFF)
-set(KEEPASSX_VERSION "2.0")
-set(KEEPASSX_VERSION_NUM "2.0")
+set(KEEPASSX_VERSION "2.0.2")
+set(KEEPASSX_VERSION_NUM "2.0.2")
if("${CMAKE_C_COMPILER}" MATCHES "clang$" OR "${CMAKE_C_COMPILER_ID}" STREQUAL "Clang")
set(CMAKE_COMPILER_IS_CLANG 1)
diff --git a/share/translations/keepassx_da.ts b/share/translations/keepassx_da.ts
index d66ed8fa0..0ee8cc335 100644
--- a/share/translations/keepassx_da.ts
+++ b/share/translations/keepassx_da.ts
@@ -13,6 +13,10 @@
RevisionRevision
+
+ Using:
+ Bruger:
+ AutoType
@@ -828,6 +832,16 @@ Vil du alligevel gemme?
Unable to calculate master keyKan ikke beregne hovednøgle
+
+ The selected file is an old KeePass 1 database (.kdb).
+
+You can import it by clicking on Database > 'Import KeePass 1 database'.
+This is a one-way migration. You won't be able to open the imported database with the old KeePassX 0.4 version.
+ Den valgte fil er en gammel KeePass 1 databasefil (.kdb).
+
+Du kan importere den ved at klikke på Database > 'Importér KeePass 1 database'.
+Dette er en envejs konvertering. Du vil ikke være i stand til at åbne den importerede database med den gamle KeePassX 0.4 version.
+ Main
diff --git a/share/translations/keepassx_en.ts b/share/translations/keepassx_en.ts
index 07fcb3e17..ef014cb0a 100644
--- a/share/translations/keepassx_en.ts
+++ b/share/translations/keepassx_en.ts
@@ -172,6 +172,42 @@
+
+ DatabaseRepairWidget
+
+ Repair database
+
+
+
+ Error
+
+
+
+ Can't open key file
+
+
+
+ Database opened fine. Nothing to do.
+
+
+
+ Unable to open the database.
+
+
+
+ Success
+
+
+
+ The database has been successfully repaired
+You can now save it.
+
+
+
+ Unable to repair the database.
+
+
+DatabaseSettingsWidget
@@ -1022,6 +1058,30 @@ This is a one-way migration. You won't be able to open the imported databas
Export to CSV file
+
+ Repair database
+
+
+
+ KeePass 2 Database
+
+
+
+ All files
+
+
+
+ Save repaired database
+
+
+
+ Error
+
+
+
+ Writing the database failed.
+
+ PasswordGeneratorWidget
diff --git a/share/translations/keepassx_fr.ts b/share/translations/keepassx_fr.ts
index 66311609a..31944bbe6 100644
--- a/share/translations/keepassx_fr.ts
+++ b/share/translations/keepassx_fr.ts
@@ -13,6 +13,10 @@
RevisionVersion
+
+ Using:
+ Utilise :
+ AutoType
@@ -79,7 +83,7 @@
Key files
- Fichiers de clé
+ Fichiers-clésAll files
@@ -120,7 +124,7 @@
Failed to set %1 as the Key file:
%2
- Impossible de définir %1 comme fichier-clé:
+ Impossible de définir %1 comme fichier-clé :
%2
@@ -286,7 +290,7 @@ Voulez-vous quand même l'ouvrir ? Dans ce cas, elle sera ouverte en lectur
Lock database
- Verrouiiler la base de données
+ Verrouiller la base de donnéesCan't lock the database as you are currently editing it.
@@ -449,7 +453,7 @@ Voulez-vous quand même la sauvegarder ?
Unable to save the attachment:
- Impossible d'enregistrer le fichier attaché:
+ Impossible d'enregistrer le fichier attaché :
@@ -532,7 +536,7 @@ Voulez-vous quand même la sauvegarder ?
Set custom sequence:
- Définir une séquence personnalisé :
+ Définir une séquence personnalisée :
@@ -562,7 +566,7 @@ Voulez-vous quand même la sauvegarder ?
Username:
- Non d'utilisateur :
+ Nom d'utilisateur :Password:
@@ -755,7 +759,7 @@ Voulez-vous quand même la sauvegarder ?
Username
- Non d'utilisateur
+ Nom d'utilisateurURL
@@ -792,7 +796,7 @@ Voulez-vous quand même la sauvegarder ?
Not a KeePass database.
- Ce n'est pas une base de donnée KeePass.
+ Ce n'est pas une base de données KeePass.Unsupported encryption algorithm.
@@ -800,7 +804,7 @@ Voulez-vous quand même la sauvegarder ?
Unsupported KeePass database version.
- Version de base de donnée KeePass non supportée.
+ Version de base de données KeePass non supportée.Root
@@ -815,20 +819,30 @@ Voulez-vous quand même la sauvegarder ?
KeePass2ReaderNot a KeePass database.
- Ce n'est pas une base de donnée KeePass.
+ Ce n'est pas une base de données KeePass.Unsupported KeePass database version.
- Version de base de donnée KeePass non supportée.
+ Version de base de données KeePass non supportée.Wrong key or database file is corrupt.
- Mauvaise clé ou fichier de base de donnée corrompu.
+ Mauvaise clé ou fichier de base de données corrompu.Unable to calculate master keyImpossible de calculer la clé maître
+
+ The selected file is an old KeePass 1 database (.kdb).
+
+You can import it by clicking on Database > 'Import KeePass 1 database'.
+This is a one-way migration. You won't be able to open the imported database with the old KeePassX 0.4 version.
+ Le fichier sélectionné est une ancienne base de données pour KeePass 1 (.kdb).
+
+Vous pouvez l'importer en cliquant sur "Base de données" > "Importer une base de données KeePass 1".
+Ceci est une migration à sens unique. Vous ne serez plus en mesure d'ouvrir la base de données importée avec l'ancienne version KeePassX version 0.4.
+ Main
@@ -861,7 +875,7 @@ Voulez-vous quand même la sauvegarder ?
Copy attribute to clipboard
- Copier l'attribut dans le presse-papiers
+ Copier l'attribut dans le presse-papierGroups
@@ -881,19 +895,19 @@ Voulez-vous quand même la sauvegarder ?
Open database
- Ouvrir une base de donnée
+ Ouvrir une base de donnéesSave database
- Enregistrer la base de donnée
+ Enregistrer la base de donnéesClose database
- Fermer la base de donnée
+ Fermer la base de donnéesNew database
- Nouvelle base de donnée
+ Nouvelle base de donnéesAdd new entry
@@ -921,7 +935,7 @@ Voulez-vous quand même la sauvegarder ?
Save database as
- Enregistrer la base de donnée sous
+ Enregistrer la base de données sousChange master key
@@ -929,11 +943,11 @@ Voulez-vous quand même la sauvegarder ?
Database settings
- Paramètre de la base de donnée
+ Paramètres de la base de donnéesImport KeePass 1 database
- Importer une base de donnée KeePass 1
+ Importer une base de données KeePass 1Clone entry
@@ -945,11 +959,11 @@ Voulez-vous quand même la sauvegarder ?
Copy username to clipboard
- Copier le nom d'utilisateur dans le presse-papiers
+ Copier le nom d'utilisateur dans le presse-papierCopy password to clipboard
- Copier le mot de passe dans le presse-papiers
+ Copier le mot de passe dans le presse-papierSettings
@@ -1020,7 +1034,7 @@ Voulez-vous quand même la sauvegarder ?
Character Types
- Types de caractère
+ Types de caractèresUpper Case Letters
@@ -1055,7 +1069,7 @@ Voulez-vous quand même la sauvegarder ?
QCommandLineParserDisplays version information.
- Afficher les informations de version
+ Afficher les informations de version.Displays this help.
@@ -1166,7 +1180,7 @@ Voulez-vous quand même la sauvegarder ?
SettingsWidgetApplication Settings
- Paramètre de l'application
+ Paramètres de l'applicationGeneral
@@ -1185,19 +1199,19 @@ Voulez-vous quand même la sauvegarder ?
Open previous databases on startup
- Ouvrir les base de données précédentes au démarrage
+ Ouvrir les bases de données précédentes au démarrageAutomatically save on exit
- Sauvegarde automatiquement à la sortie
+ Sauvegarder automatiquement à la sortieAutomatically save after every change
- Sauvegarde automatiquement après chaque modification
+ Sauvegarder automatiquement après chaque modificationMinimize when copying to clipboard
- Réduire lors de la copie dans le presse-papiers
+ Réduire lors de la copie dans le presse-papierUse group icon on entry creation
@@ -1232,7 +1246,7 @@ Voulez-vous quand même la sauvegarder ?
SettingsWidgetSecurityClear clipboard after
- Vider le presse-papiers après
+ Vider le presse-papier après sec
@@ -1240,7 +1254,7 @@ Voulez-vous quand même la sauvegarder ?
Lock databases after inactivity of
- Verrouiller les bases de donnée après une inactivité de
+ Verrouiller les bases de données après une inactivité deShow passwords in cleartext by default
@@ -1255,7 +1269,7 @@ Voulez-vous quand même la sauvegarder ?
UnlockDatabaseWidgetUnlock database
- Déverrouiller la base de donnée
+ Déverrouiller la base de données
@@ -1273,7 +1287,7 @@ Voulez-vous quand même la sauvegarder ?
filename of the password database to open (*.kdbx)
- Nom de fichier de la base de donnée de mot de pass à ouvrir (*.kdbx)
+ Nom de fichier de la base de données de mot de passe à ouvrir (*.kdbx)path to a custom config file
diff --git a/share/translations/keepassx_id.ts b/share/translations/keepassx_id.ts
index b4d5f7d3b..9b210f604 100644
--- a/share/translations/keepassx_id.ts
+++ b/share/translations/keepassx_id.ts
@@ -13,6 +13,10 @@
RevisionRevisi
+
+ Using:
+ Menggunakan:
+ AutoType
@@ -79,7 +83,7 @@
Key files
- Berkas Kunci
+ Berkas kunciAll files
@@ -99,7 +103,7 @@
Select a key file
- Pilih sebuah berkas kunci
+ Pilih berkas kunciQuestion
@@ -111,7 +115,7 @@
Different passwords supplied.
- Sandi yang berbeda diberikan.
+ Sandi berbeda.Failed to set key file
@@ -428,7 +432,7 @@ Apakah Anda tetap ingin menyimpannya?
Different passwords supplied.
- Kata sandi yang berbeda diberikan.
+ Sandi berbeda.New attribute
@@ -586,7 +590,7 @@ Apakah Anda tetap ingin menyimpannya?
Presets
-
+ PrasetelNotes:
@@ -829,6 +833,16 @@ Apakah Anda tetap ingin menyimpannya?
Unable to calculate master keyTidak bisa mengkalkulasi kunci utama
+
+ The selected file is an old KeePass 1 database (.kdb).
+
+You can import it by clicking on Database > 'Import KeePass 1 database'.
+This is a one-way migration. You won't be able to open the imported database with the old KeePassX 0.4 version.
+ Berkas yang dipilih adalah basis data KeePass 1 yang lama (.kdb).
+
+Anda bisa mengimpornya dengan mengklik Basis Data > 'Impor basis data KeePass 1'.
+Ini adalah migrasi satu arah. Anda tidak akan bisa lagi membuka basis data yang diimpor dengan versi lama KeePassX 0.4.
+ Main
diff --git a/share/translations/keepassx_it.ts b/share/translations/keepassx_it.ts
index 8c9048dfb..ad9af9084 100644
--- a/share/translations/keepassx_it.ts
+++ b/share/translations/keepassx_it.ts
@@ -13,6 +13,10 @@
RevisionRevisione
+
+ Using:
+ In uso:
+ AutoType
@@ -48,7 +52,7 @@
Select entry to Auto-Type:
- Selezionare una voce per Auto-Type:
+ Seleziona una voce per Auto-Type:
@@ -59,11 +63,11 @@
Enter password:
- Inserire password:
+ Inserisci password:Repeat password:
- Ripetere password:
+ Ripeti password:Key file
@@ -75,7 +79,7 @@
Create
- Creare
+ CreaKey files
@@ -87,7 +91,7 @@
Create Key File...
- Creare file chiave...
+ Crea file chiave...Error
@@ -120,18 +124,19 @@
Failed to set %1 as the Key file:
%2
- Impossibile impostare %1 come file Chiave: %2
+ Impossibile impostare %1 come file chiave:
+%2DatabaseOpenWidgetEnter master key
- Inserire password
+ Inserisci la chiave principaleKey File:
- File Chiave:
+ File chiave:Password:
@@ -139,7 +144,7 @@
Browse
- Sfogliare
+ SfogliaError
@@ -159,7 +164,7 @@
Key files
- Files chiave
+ File chiaveSelect key file
@@ -170,7 +175,7 @@
DatabaseSettingsWidgetDatabase name:
- Nome database:
+ Nome del database:Database description:
@@ -178,7 +183,7 @@
Transform rounds:
- Rounds di trasformazione:
+ Round di trasformazione:Default username:
@@ -186,7 +191,7 @@
Use recycle bin:
- Utilizzare cestino:
+ Utilizza cestino: MiB
@@ -254,7 +259,7 @@
"%1" was modified.
Save changes?
- "%1" è stata modificata.
+ "%1" è stata modificato.
Salvare le modifiche?
@@ -263,11 +268,11 @@ Salvare le modifiche?
Writing the database failed.
- Scrittura del database fallita.
+ Scrittura del database non riuscita.Save database as
- Salvare database come
+ Salva database comeNew database
@@ -280,18 +285,18 @@ Salvare le modifiche?
The database you are trying to open is locked by another instance of KeePassX.
Do you want to open it anyway? Alternatively the database is opened read-only.
- Il Database che stai tentando di aprire è bloccato da un'altra esecuzione di KeePassX.
-Vuoi aprirlo comunque? In alternativa, il database verrà aperto in sola lettura.
+ Il database che stai tentando di aprire è bloccato da un'altra istanza di KeePassX.
+Vuoi aprirlo comunque? Altrimenti il database verrà aperto in sola lettura.Lock database
- Bloccare database
+ Blocca databaseCan't lock the database as you are currently editing it.
Please press cancel to finish your changes or discard them.
- Non è possibile bloccare il database nel modo in cui lo stai modificando.
-Premere annulla per terminare le modifiche o scartarle .
+ Non è possibile bloccare il database dato che lo stai modificando.
+Premere Annulla per completare le modifiche o scartarle.This database has never been saved.
@@ -323,12 +328,12 @@ Annullare le modifiche e chiudere comunque?
Writing the CSV file failed.
- Scrittura del file CSV fallita.
+ Scrittura del file CSV non riuscita.The database you are trying to save as is locked by another instance of KeePassX.
Do you want to save it anyway?
- Il database che si sta tentando di salvare è bloccato da un'altra istanza di KeePassX.
+ Il database che stai tentando di salvare è bloccato da un'altra istanza di KeePassX.
Vuoi salvare comunque?
@@ -336,7 +341,7 @@ Vuoi salvare comunque?
DatabaseWidgetChange master key
- Cambia password principale
+ Cambia chiave principaleDelete entry?
@@ -457,15 +462,15 @@ Vuoi salvare comunque?
%n week(s)
- %n settimana(e)%n settimana(e)
+ %n settimana%n settimane%n month(s)
- %n mese(i)%n mese(i)
+ %n mese%n mesi1 year
- 1 anno
+ Un anno
@@ -476,15 +481,15 @@ Vuoi salvare comunque?
Add
- Aggiungere
+ AggiungiEdit
- Modificare
+ ModificaRemove
- Rimuovere
+ RimuoviAttachments
@@ -492,26 +497,26 @@ Vuoi salvare comunque?
Save
- Salvare
+ SalvaOpen
- Aprire
+ ApriEditEntryWidgetAutoTypeEnable Auto-Type for this entry
- Abilitare Auto-Type per questa voce
+ Abilita Auto-Type per questa voceInherit default Auto-Type sequence from the group
- Ereditare la sequenza predefinita di Auto-Type dal gruppo
+ Eredita la sequenza predefinita di Auto-Type dal gruppoUse custom Auto-Type sequence:
- Usare sequenza personalizzata di Auto-Type:
+ Usa sequenza personalizzata di Auto-Type:+
@@ -527,30 +532,30 @@ Vuoi salvare comunque?
Use default sequence
- Usare sequenza predefinita
+ Usa sequenza predefinitaSet custom sequence:
- Impostare sequenza personalizzata:
+ Imposta sequenza personalizzata:EditEntryWidgetHistoryShow
- Mostrare
+ MostraRestore
- Ripristinare
+ RipristinaDelete
- Eliminare
+ EliminaDelete all
- Eliminare tutti
+ Elimina tutti
@@ -569,7 +574,7 @@ Vuoi salvare comunque?
Repeat:
- Ripetere:
+ Ripeti:Gen.
@@ -585,7 +590,7 @@ Vuoi salvare comunque?
Presets
- Presets
+ PreimpostazioniNotes:
@@ -624,7 +629,7 @@ Vuoi salvare comunque?
Inherit from parent group (%1)
- Ereditare dal gruppo genitore (%1)
+ Eredita dal gruppo genitore (%1)
@@ -643,7 +648,7 @@ Vuoi salvare comunque?
Search
- Cercare
+ CercaAuto-type
@@ -651,30 +656,30 @@ Vuoi salvare comunque?
Use default auto-type sequence of parent group
- Ereditare la sequenza predefinita di auto-type dal gruppo
+ Eredita la sequenza predefinita di auto-type dal gruppoSet default auto-type sequence
- Usare sequenza auto-type predefinita
+ Usa sequenza di auto-type predefinitaEditWidgetIconsUse default icon
- Usare icona predefinita
+ Usa icona predefinitaUse custom icon
- Usare icona personalizzata
+ Usa icona personalizzataAdd custom icon
- Aggiungere icona personalizzata
+ Aggiungi icona personalizzataDelete custom icon
- Rimuovere icona personalizzata
+ Rimuovi icona personalizzataImages
@@ -686,7 +691,7 @@ Vuoi salvare comunque?
Select Image
- Seleziona Immagine
+ Seleziona immagineCan't delete icon!
@@ -694,18 +699,18 @@ Vuoi salvare comunque?
Can't delete icon. Still used by %n item(s).
- Impossibile eliminare l'icona in quanto è in uso da %n voce(i).Impossibile eliminare l'icona in quanto è in uso da %n voce(i).
+ Impossibile eliminare l'icona in quanto è in uso da %n voce.Impossibile eliminare l'icona in quanto è in uso da %n voci.EditWidgetPropertiesCreated:
- Creato:
+ Creazione:Modified:
- Modificato:
+ Modifica:Accessed:
@@ -713,7 +718,7 @@ Vuoi salvare comunque?
Uuid:
- Uuid:
+ UUID:
@@ -754,7 +759,7 @@ Vuoi salvare comunque?
Username
- Nome Utente
+ Nome utenteURL
@@ -772,7 +777,7 @@ Vuoi salvare comunque?
KeePass1OpenWidgetImport KeePass1 database
- Importare database KeePass1
+ Importa database KeePass1Error
@@ -787,7 +792,7 @@ Vuoi salvare comunque?
KeePass1ReaderUnable to read keyfile.
- Impossibile leggere il file chiave.
+ Impossibile leggere il file della chiave.Not a KeePass database.
@@ -807,7 +812,7 @@ Vuoi salvare comunque?
Unable to calculate master key
- Impossibile calcolare la chiave master
+ Impossibile calcolare la chiave principale
@@ -822,11 +827,21 @@ Vuoi salvare comunque?
Wrong key or database file is corrupt.
- Password errata o file database corrotto.
+ Chiave errata o file del database danneggiato.Unable to calculate master key
- Impossibile calcolare la chiave master
+ Impossibile calcolare la chiave principale
+
+
+ The selected file is an old KeePass 1 database (.kdb).
+
+You can import it by clicking on Database > 'Import KeePass 1 database'.
+This is a one-way migration. You won't be able to open the imported database with the old KeePassX 0.4 version.
+ Il file selezionato è un vecchio database KeePass 1 (.kdb).
+
+Puoi importarlo facendo clic su Database > 'Importa database KeePass 1'.
+Questa è una migrazione in una sola direzione. Non potrai aprire il database importato con la vecchia versione 0.4 di KeePassX.
@@ -872,23 +887,23 @@ Vuoi salvare comunque?
Quit
- Uscire
+ EsciAbout
- A Proposito
+ InformazioniOpen database
- Aprire database
+ Apri databaseSave database
- Salvare database
+ Salva databaseClose database
- Chiudere database
+ Chiudi databaseNew database
@@ -896,35 +911,35 @@ Vuoi salvare comunque?
Add new entry
- Aggiungere nuova voce
+ Aggiungi nuova voceView/Edit entry
- Visualizzare/Modificare voce
+ Visualizza/modifica voceDelete entry
- Eliminare voce
+ Elimina voceAdd new group
- Aggiungere nuovo gruppo
+ Aggiungi nuovo gruppoEdit group
- Modificare gruppo
+ Modifica gruppoDelete group
- Eliminare gruppo
+ Elimina gruppoSave database as
- Salvare database come
+ Salva database comeChange master key
- Cambiare password principale
+ Cambia chiave principaleDatabase settings
@@ -932,7 +947,7 @@ Vuoi salvare comunque?
Import KeePass 1 database
- Importare database KeePass 1
+ Importa database KeePass 1Clone entry
@@ -940,15 +955,15 @@ Vuoi salvare comunque?
Find
- Trovare
+ TrovaCopy username to clipboard
- Copiare nome utente negli appunti
+ Copia nome utente negli appuntiCopy password to clipboard
- Copiare password negli appunti
+ Copia password negli appuntiSettings
@@ -956,15 +971,15 @@ Vuoi salvare comunque?
Perform Auto-Type
- Eseguire Auto-Type
+ Esegui Auto-TypeOpen URL
- Aprire URL
+ Apri URLLock databases
- Bloccare database
+ Blocca databaseTitle
@@ -1039,26 +1054,26 @@ Vuoi salvare comunque?
Exclude look-alike characters
- Escludere caratteri simili
+ Escludi caratteri similiEnsure that the password contains characters from every group
- Assicurare che la password contenga caratteri di ogni gruppo
+ Verifica che la password contenga caratteri di ogni gruppoAccept
- Accettare
+ AccettaQCommandLineParserDisplays version information.
- Mostrare informazioni sulla versione.
+ Mostra informazioni sulla versione.Displays this help.
- Mostrare questo aiuto.
+ Mostra questo aiuto.Unknown option '%1'.
@@ -1101,7 +1116,7 @@ Vuoi salvare comunque?
Writing canceled by application
- Scrittura cancellata dall'applicazione
+ Scrittura annullata dall'applicazionePartial write. Partition full?
@@ -1146,7 +1161,7 @@ Vuoi salvare comunque?
SearchWidgetFind:
- Trovare:
+ Trova:Case sensitive
@@ -1184,23 +1199,23 @@ Vuoi salvare comunque?
Open previous databases on startup
- Aprire precedente database all'avvio
+ Apri il database precedente all'avvioAutomatically save on exit
- Salvare automaticamente all'uscita
+ Salva automaticamente all'uscitaAutomatically save after every change
- Salvare automaticamente dopo ogni modifica
+ Salva automaticamente dopo ogni modificaMinimize when copying to clipboard
- Minimizzare quando si copia negli appunti
+ Minimizza quando si copia negli appuntiUse group icon on entry creation
- Usare l'icona del gruppo alla creazione di una voce
+ Usa l'icona del gruppo alla creazione di una voceGlobal Auto-Type shortcut
@@ -1208,7 +1223,7 @@ Vuoi salvare comunque?
Use entry title to match windows for global auto-type
- Utilizzare il titolo della voce per abbinare la finestra per auto-type globale
+ Utilizza il titolo della voce per abbinare la finestra per auto-type globaleLanguage
@@ -1224,14 +1239,14 @@ Vuoi salvare comunque?
Remember last key files
- Ricorda gli ultimi files chiave
+ Ricorda gli ultimi file di chiaviSettingsWidgetSecurityClear clipboard after
- Pulire appunti dopo
+ Pulisci appunti dopo sec
@@ -1239,22 +1254,22 @@ Vuoi salvare comunque?
Lock databases after inactivity of
- Bloccare i database dopo un'inattività di
+ Blocca i database dopo un'inattività diShow passwords in cleartext by default
- Mostrare la password in chiaro in maniera predefinita
+ Mostra la password in chiaro in maniera predefinitaAlways ask before performing auto-type
- Chiedere sempre prima di eseguire auto-type
+ Chiedi sempre prima di eseguire auto-typeUnlockDatabaseWidgetUnlock database
- Sbloccare database
+ Sblocca database
@@ -1272,7 +1287,7 @@ Vuoi salvare comunque?
filename of the password database to open (*.kdbx)
- nome del file del database da aprire (*.kdbx)
+ nome del file di database da aprire (*.kdbx)path to a custom config file
diff --git a/share/translations/keepassx_sv.ts b/share/translations/keepassx_sv.ts
index bafb1c109..ff8126c58 100644
--- a/share/translations/keepassx_sv.ts
+++ b/share/translations/keepassx_sv.ts
@@ -13,6 +13,10 @@
RevisionRevision
+
+ Using:
+ Använder:
+ AutoType
@@ -291,7 +295,7 @@ Vill du öppna den ändå? Databasen kommer då att öppnas skrivskyddad.
Can't lock the database as you are currently editing it.
Please press cancel to finish your changes or discard them.
- Kan inte låsa databasen eftersom du håller på att redigera den.
+ Kan inte låsa databasen eftersom du håller på att redigera den.
Tryck avbryt för att ansluta dina ändringar alternativt kasta dem.
@@ -829,6 +833,13 @@ Vill du spara endå?Unable to calculate master keyKunde inte räkna nu master-nyckeln
+
+ The selected file is an old KeePass 1 database (.kdb).
+
+You can import it by clicking on Database > 'Import KeePass 1 database'.
+This is a one-way migration. You won't be able to open the imported database with the old KeePassX 0.4 version.
+
+ Main
@@ -849,7 +860,7 @@ Vill du spara endå?
Recent databases
- Senast använda databser
+ Senast använda databaserHelp
@@ -1185,11 +1196,11 @@ Vill du spara endå?
Open previous databases on startup
- Öppna senaste databasen är programmet startar
+ Öppna senaste databasen när programmet startarAutomatically save on exit
- Spara automatiskt är applikationen anslutas
+ Spara automatiskt när applikationen anslutasAutomatically save after every change
diff --git a/share/translations/keepassx_uk.ts b/share/translations/keepassx_uk.ts
index 2b4774ee6..18d124a18 100644
--- a/share/translations/keepassx_uk.ts
+++ b/share/translations/keepassx_uk.ts
@@ -13,6 +13,10 @@
RevisionРевізія
+
+ Using:
+ Використання:
+ AutoType
@@ -828,6 +832,16 @@ Do you want to save it anyway?
Unable to calculate master keyНеможливо вирахувати майстер-пароль
+
+ The selected file is an old KeePass 1 database (.kdb).
+
+You can import it by clicking on Database > 'Import KeePass 1 database'.
+This is a one-way migration. You won't be able to open the imported database with the old KeePassX 0.4 version.
+ Обрано файл сховища попередньої версії KeePass 1 (.kdb).
+
+Ви можете імпортувати його, натиснувши Сховище > 'Імпортувати сховище KeePass 1'.
+Це односторонній спосіб міграції. Ви не зможете відкрити імпортоване сховище в попередній версії KeePassX 0.4.
+ Main
diff --git a/src/format/KeePass1Reader.cpp b/src/format/KeePass1Reader.cpp
index 24a944293..89775b507 100644
--- a/src/format/KeePass1Reader.cpp
+++ b/src/format/KeePass1Reader.cpp
@@ -901,10 +901,10 @@ bool KeePass1Reader::parseCustomIcons4(const QByteArray& data)
QByteArray entryUuid = data.mid(pos, 16);
pos += 16;
- int iconId = Endian::bytesToUInt32(data.mid(pos, 4), KeePass1::BYTEORDER);
+ quint32 iconId = Endian::bytesToUInt32(data.mid(pos, 4), KeePass1::BYTEORDER);
pos += 4;
- if (m_entryUuids.contains(entryUuid) && (iconId < iconUuids.size())) {
+ if (m_entryUuids.contains(entryUuid) && (iconId < static_cast(iconUuids.size()))) {
m_entryUuids[entryUuid]->setIcon(iconUuids[iconId]);
}
}
@@ -917,10 +917,10 @@ bool KeePass1Reader::parseCustomIcons4(const QByteArray& data)
quint32 groupId = Endian::bytesToUInt32(data.mid(pos, 4), KeePass1::BYTEORDER);
pos += 4;
- int iconId = Endian::bytesToUInt32(data.mid(pos, 4), KeePass1::BYTEORDER);
+ quint32 iconId = Endian::bytesToUInt32(data.mid(pos, 4), KeePass1::BYTEORDER);
pos += 4;
- if (m_groupIds.contains(groupId) && (iconId < iconUuids.size())) {
+ if (m_groupIds.contains(groupId) && (iconId < static_cast(iconUuids.size()))) {
m_groupIds[groupId]->setIcon(iconUuids[iconId]);
}
}
diff --git a/src/format/KeePass2Repair.cpp b/src/format/KeePass2Repair.cpp
index 1b2d80d54..81ada2fda 100644
--- a/src/format/KeePass2Repair.cpp
+++ b/src/format/KeePass2Repair.cpp
@@ -66,7 +66,7 @@ KeePass2Repair::RepairResult KeePass2Repair::repairDatabase(QIODevice* device, c
// try to fix broken databases because of bug #392
for (int i = (xmlData.size() - 1); i >= 0; i--) {
- char ch = xmlData.at(i);
+ quint8 ch = static_cast(xmlData.at(i));
if (ch < 0x20 && ch != 0x09 && ch != 0x0A && ch != 0x0D) {
xmlData.remove(i, 1);
repairAction = true;
diff --git a/src/format/KeePass2XmlReader.cpp b/src/format/KeePass2XmlReader.cpp
index 2b975951e..40087a633 100644
--- a/src/format/KeePass2XmlReader.cpp
+++ b/src/format/KeePass2XmlReader.cpp
@@ -523,6 +523,7 @@ Group* KeePass2XmlReader::parseGroup()
if (m_strictMode) {
raiseError("Invalid group icon number");
}
+ iconId = 0;
}
else {
if (iconId >= DatabaseIcons::IconCount) {
@@ -702,6 +703,7 @@ Entry* KeePass2XmlReader::parseEntry(bool history)
if (m_strictMode) {
raiseError("Invalid entry icon number");
}
+ iconId = 0;
}
else {
entry->setIcon(iconId);
diff --git a/src/format/KeePass2XmlWriter.cpp b/src/format/KeePass2XmlWriter.cpp
index fbd0e54d2..7fd03cc07 100644
--- a/src/format/KeePass2XmlWriter.cpp
+++ b/src/format/KeePass2XmlWriter.cpp
@@ -550,11 +550,19 @@ QString KeePass2XmlWriter::colorPartToString(int value)
QString KeePass2XmlWriter::stripInvalidXml10Chars(QString str)
{
for (int i = str.size() - 1; i >= 0; i--) {
- const ushort uc = str.at(i).unicode();
+ const QChar ch = str.at(i);
+ const ushort uc = ch.unicode();
- if ((uc < 0x20 && uc != 0x09 && uc != 0x0A && uc != 0x0D)
- || (uc > 0xD7FF && uc < 0xE000)
- || (uc > 0xFFFD))
+ if (ch.isLowSurrogate() && i != 0 && str.at(i - 1).isHighSurrogate()) {
+ // keep valid surrogate pair
+ i--;
+ }
+ else if ((uc < 0x20 && uc != 0x09 && uc != 0x0A && uc != 0x0D) // control chracters
+ || (uc >= 0x7F && uc <= 0x84) // control chracters, valid but discouraged by XML
+ || (uc >= 0x86 && uc <= 0x9F) // control chracters, valid but discouraged by XML
+ || (uc > 0xFFFD) // noncharacter
+ || ch.isLowSurrogate() // single low surrogate
+ || ch.isHighSurrogate()) // single high surrogate
{
qWarning("Stripping invalid XML 1.0 codepoint %x", uc);
str.remove(i, 1);
diff --git a/src/gui/DatabaseOpenWidget.cpp b/src/gui/DatabaseOpenWidget.cpp
index 14f3baa06..00aae6b18 100644
--- a/src/gui/DatabaseOpenWidget.cpp
+++ b/src/gui/DatabaseOpenWidget.cpp
@@ -49,10 +49,6 @@ DatabaseOpenWidget::DatabaseOpenWidget(QWidget* parent)
connect(m_ui->editPassword, SIGNAL(textChanged(QString)), SLOT(activatePassword()));
connect(m_ui->comboKeyFile, SIGNAL(editTextChanged(QString)), SLOT(activateKeyFile()));
- connect(m_ui->checkPassword, SIGNAL(toggled(bool)), SLOT(setOkButtonEnabled()));
- connect(m_ui->checkKeyFile, SIGNAL(toggled(bool)), SLOT(setOkButtonEnabled()));
- connect(m_ui->comboKeyFile, SIGNAL(editTextChanged(QString)), SLOT(setOkButtonEnabled()));
-
connect(m_ui->buttonBox, SIGNAL(accepted()), SLOT(openDatabase()));
connect(m_ui->buttonBox, SIGNAL(rejected()), SLOT(reject()));
}
@@ -75,6 +71,7 @@ void DatabaseOpenWidget::load(const QString& filename)
}
}
+ m_ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(true);
m_ui->editPassword->setFocus();
}
@@ -99,9 +96,6 @@ void DatabaseOpenWidget::openDatabase()
{
KeePass2Reader reader;
CompositeKey masterKey = databaseKey();
- if (masterKey.isEmpty()) {
- return;
- }
QFile file(m_filename);
if (!file.open(QIODevice::ReadOnly)) {
@@ -172,14 +166,6 @@ void DatabaseOpenWidget::activateKeyFile()
m_ui->checkKeyFile->setChecked(true);
}
-void DatabaseOpenWidget::setOkButtonEnabled()
-{
- bool enable = m_ui->checkPassword->isChecked()
- || (m_ui->checkKeyFile->isChecked() && !m_ui->comboKeyFile->currentText().isEmpty());
-
- m_ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(enable);
-}
-
void DatabaseOpenWidget::browseKeyFile()
{
QString filters = QString("%1 (*);;%2 (*.key)").arg(tr("All files"), tr("Key files"));
diff --git a/src/gui/DatabaseOpenWidget.h b/src/gui/DatabaseOpenWidget.h
index 339bc2210..ba55e4c4a 100644
--- a/src/gui/DatabaseOpenWidget.h
+++ b/src/gui/DatabaseOpenWidget.h
@@ -54,7 +54,6 @@ protected Q_SLOTS:
private Q_SLOTS:
void activatePassword();
void activateKeyFile();
- void setOkButtonEnabled();
void browseKeyFile();
protected:
diff --git a/src/gui/DatabaseRepairWidget.cpp b/src/gui/DatabaseRepairWidget.cpp
index b7eeac212..f1b760f99 100644
--- a/src/gui/DatabaseRepairWidget.cpp
+++ b/src/gui/DatabaseRepairWidget.cpp
@@ -51,6 +51,7 @@ void DatabaseRepairWidget::openDatabase()
if (!key.load(keyFilename, &errorMsg)) {
MessageBox::warning(this, tr("Error"), tr("Can't open key file").append(":\n").append(errorMsg));
Q_EMIT editFinished(false);
+ return;
}
masterKey.addKey(key);
}
diff --git a/tests/TestKeePass2Writer.cpp b/tests/TestKeePass2Writer.cpp
index f955b5b88..60b7b90eb 100644
--- a/tests/TestKeePass2Writer.cpp
+++ b/tests/TestKeePass2Writer.cpp
@@ -132,7 +132,7 @@ void TestKeePass2Writer::testRepair()
{
QString brokenDbFilename = QString(KEEPASSX_TEST_DATA_DIR).append("/bug392.kdbx");
// master password = test
- // entry username: testuser\x10
+ // entry username: testuser\x10\x20AC
// entry password: testpw
CompositeKey key;
key.addKey(PasswordKey("test"));
@@ -152,7 +152,7 @@ void TestKeePass2Writer::testRepair()
QVERIFY(dbRepaired);
QCOMPARE(dbRepaired->rootGroup()->entries().size(), 1);
- QCOMPARE(dbRepaired->rootGroup()->entries().at(0)->username(), QString("testuser"));
+ QCOMPARE(dbRepaired->rootGroup()->entries().at(0)->username(), QString("testuser").append(QChar(0x20AC)));
QCOMPARE(dbRepaired->rootGroup()->entries().at(0)->password(), QString("testpw"));
}
diff --git a/tests/TestKeePass2XmlReader.cpp b/tests/TestKeePass2XmlReader.cpp
index ad6c575f1..f04c54806 100644
--- a/tests/TestKeePass2XmlReader.cpp
+++ b/tests/TestKeePass2XmlReader.cpp
@@ -67,6 +67,18 @@ QDateTime TestKeePass2XmlReader::genDT(int year, int month, int day, int hour, i
return QDateTime(date, time, Qt::UTC);
}
+QByteArray TestKeePass2XmlReader::strToBytes(const QString& str)
+{
+ QByteArray result;
+
+ for (int i = 0; i < str.size(); i++) {
+ result.append(str.at(i).unicode() >> 8);
+ result.append(str.at(i).unicode() & 0xFF);
+ }
+
+ return result;
+}
+
void TestKeePass2XmlReader::initTestCase()
{
QVERIFY(Crypto::init());
@@ -413,10 +425,35 @@ void TestKeePass2XmlReader::testInvalidXmlChars()
{
QScopedPointer dbWrite(new Database());
+ QString strPlainInvalid = QString().append(QChar(0x02)).append(QChar(0x19))
+ .append(QChar(0xFFFE)).append(QChar(0xFFFF));
+ QString strPlainValid = QString().append(QChar(0x09)).append(QChar(0x0A))
+ .append(QChar(0x20)).append(QChar(0xD7FF))
+ .append(QChar(0xE000)).append(QChar(0xFFFD));
+ // U+10437 in UTF-16: D801 DC37
+ // high low surrogate
+ QString strSingleHighSurrogate1 = QString().append(QChar(0xD801));
+ QString strSingleHighSurrogate2 = QString().append(QChar(0x31)).append(QChar(0xD801)).append(QChar(0x32));
+ QString strHighHighSurrogate = QString().append(QChar(0xD801)).append(QChar(0xD801));
+ QString strSingleLowSurrogate1 = QString().append(QChar(0xDC37));
+ QString strSingleLowSurrogate2 = QString().append(QChar((0x31))).append(QChar(0xDC37)).append(QChar(0x32));
+ QString strLowLowSurrogate = QString().append(QChar(0xDC37)).append(QChar(0xDC37));
+ QString strSurrogateValid1 = QString().append(QChar(0xD801)).append(QChar(0xDC37));
+ QString strSurrogateValid2 = QString().append(QChar(0x31)).append(QChar(0xD801)).append(QChar(0xDC37)).append(QChar(0x32));
+
Entry* entry = new Entry();
entry->setUuid(Uuid::random());
- entry->setNotes(QString("a %1 b %2 c %3").arg(QChar(0x02)).arg(QChar(0xD800)).arg(QChar(0xFFFE)));
entry->setGroup(dbWrite->rootGroup());
+ entry->attributes()->set("PlainInvalid", strPlainInvalid);
+ entry->attributes()->set("PlainValid", strPlainValid);
+ entry->attributes()->set("SingleHighSurrogate1", strSingleHighSurrogate1);
+ entry->attributes()->set("SingleHighSurrogate2", strSingleHighSurrogate2);
+ entry->attributes()->set("HighHighSurrogate", strHighHighSurrogate);
+ entry->attributes()->set("SingleLowSurrogate1", strSingleLowSurrogate1);
+ entry->attributes()->set("SingleLowSurrogate2", strSingleLowSurrogate2);
+ entry->attributes()->set("LowLowSurrogate", strLowLowSurrogate);
+ entry->attributes()->set("SurrogateValid1", strSurrogateValid1);
+ entry->attributes()->set("SurrogateValid2", strSurrogateValid2);
QBuffer buffer;
buffer.open(QIODevice::ReadWrite);
@@ -434,8 +471,19 @@ void TestKeePass2XmlReader::testInvalidXmlChars()
QVERIFY(!reader.hasError());
QVERIFY(!dbRead.isNull());
QCOMPARE(dbRead->rootGroup()->entries().size(), 1);
- // check that the invalid codepoints have been stripped
- QCOMPARE(dbRead->rootGroup()->entries().first()->notes(), QString("a b c "));
+ Entry* entryRead = dbRead->rootGroup()->entries().at(0);
+ EntryAttributes* attrRead = entryRead->attributes();
+
+ QCOMPARE(strToBytes(attrRead->value("PlainInvalid")), QByteArray());
+ QCOMPARE(strToBytes(attrRead->value("PlainValid")), strToBytes(strPlainValid));
+ QCOMPARE(strToBytes(attrRead->value("SingleHighSurrogate1")), QByteArray());
+ QCOMPARE(strToBytes(attrRead->value("SingleHighSurrogate2")), strToBytes(QString("12")));
+ QCOMPARE(strToBytes(attrRead->value("HighHighSurrogate")), QByteArray());
+ QCOMPARE(strToBytes(attrRead->value("SingleLowSurrogate1")), QByteArray());
+ QCOMPARE(strToBytes(attrRead->value("SingleLowSurrogate2")), strToBytes(QString("12")));
+ QCOMPARE(strToBytes(attrRead->value("LowLowSurrogate")), QByteArray());
+ QCOMPARE(strToBytes(attrRead->value("SurrogateValid1")), strToBytes(strSurrogateValid1));
+ QCOMPARE(strToBytes(attrRead->value("SurrogateValid2")), strToBytes(strSurrogateValid2));
}
void TestKeePass2XmlReader::cleanupTestCase()
diff --git a/tests/TestKeePass2XmlReader.h b/tests/TestKeePass2XmlReader.h
index 815dbcd65..b9be7b553 100644
--- a/tests/TestKeePass2XmlReader.h
+++ b/tests/TestKeePass2XmlReader.h
@@ -47,6 +47,7 @@ private Q_SLOTS:
private:
static QDateTime genDT(int year, int month, int day, int hour, int min, int second);
+ static QByteArray strToBytes(const QString& str);
Database* m_db;
};
diff --git a/tests/data/bug392.kdbx b/tests/data/bug392.kdbx
index c649f8dc2..0953d8677 100644
Binary files a/tests/data/bug392.kdbx and b/tests/data/bug392.kdbx differ