author | ulf69 <ulf69> | 2004-10-29 04:49:32 (UTC) |
---|---|---|
committer | ulf69 <ulf69> | 2004-10-29 04:49:32 (UTC) |
commit | 08a4582f8e5184b8abb7d97781c4fc37ee7edf90 (patch) (unidiff) | |
tree | 5131fbfb3992196cf9f4108f7d81b37365104a7d | |
parent | f8dd437160acec2959c462dd43d87f2a0920c0b9 (diff) | |
download | kdepimpi-08a4582f8e5184b8abb7d97781c4fc37ee7edf90.zip kdepimpi-08a4582f8e5184b8abb7d97781c4fc37ee7edf90.tar.gz kdepimpi-08a4582f8e5184b8abb7d97781c4fc37ee7edf90.tar.bz2 |
added category edit feature
-rw-r--r-- | pwmanager/pwmanager/editcategory.cpp | 188 | ||||
-rw-r--r-- | pwmanager/pwmanager/editcategory.h | 77 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwm.cpp | 69 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwm.h | 1 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwmanager.pro | 2 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwmanagerE.pro | 2 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwmdoc.cpp | 5 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwmdoc.h | 14 | ||||
-rw-r--r-- | pwmanager/pwmanager/pwmview.cpp | 10 | ||||
-rw-r--r-- | pwmanager/pwmanager/serializer.cpp | 44 |
10 files changed, 411 insertions, 1 deletions
diff --git a/pwmanager/pwmanager/editcategory.cpp b/pwmanager/pwmanager/editcategory.cpp new file mode 100644 index 0000000..4e55de8 --- a/dev/null +++ b/pwmanager/pwmanager/editcategory.cpp | |||
@@ -0,0 +1,188 @@ | |||
1 | /* | ||
2 | This file is part of PwManager/Platform independent. | ||
3 | Copyright (c) 2004 Ulf Schenk | ||
4 | |||
5 | This program is free software; you can redistribute it and/or modify | ||
6 | it under the terms of the GNU General Public License as published by | ||
7 | the Free Software Foundation; either version 2 of the License, or | ||
8 | (at your option) any later version. | ||
9 | |||
10 | This program is distributed in the hope that it will be useful, | ||
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | GNU General Public License for more details. | ||
14 | |||
15 | You should have received a copy of the GNU General Public License | ||
16 | along with this program; if not, write to the Free Software | ||
17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
18 | |||
19 | As a special exception, permission is given to link this program | ||
20 | with any edition of Qt, and distribute the resulting executable, | ||
21 | without including the source code for Qt in the source distribution. | ||
22 | |||
23 | $Id$ | ||
24 | */ | ||
25 | |||
26 | #include "editcategory.h" | ||
27 | #include "pwmdoc.h" | ||
28 | |||
29 | #include <qlayout.h> | ||
30 | #include <qlabel.h> | ||
31 | #include <qgroupbox.h> | ||
32 | #include <klocale.h> | ||
33 | #include <kcombobox.h> | ||
34 | #include <klineedit.h> | ||
35 | #include <qpushbutton.h> | ||
36 | |||
37 | |||
38 | /* | ||
39 | * Constructs a addEntryWnd as a child of 'parent', with the | ||
40 | * name 'name' and widget flags set to 'f'. | ||
41 | * | ||
42 | * The dialog will by default be modeless, unless you set 'modal' to | ||
43 | * TRUE to construct a modal dialog. | ||
44 | */ | ||
45 | editCategoryWnd::editCategoryWnd( PwMDoc* d, QWidget* parent, const char* name) | ||
46 | : KDialogBase( KDialogBase::Plain, i18n( "edit category descriptions" ), | ||
47 | Apply | User2 | Ok, | ||
48 | Ok, parent, name, true ), | ||
49 | doc(d) | ||
50 | { | ||
51 | findButton( Ok )->setText (i18n("Close" )) ; | ||
52 | findButton( User2 )->setText (i18n("Cancel" )) ; | ||
53 | connect(this,SIGNAL(user2Clicked()), SLOT(cancel_slot())); | ||
54 | enableButton( KDialogBase::Apply, false ); | ||
55 | |||
56 | |||
57 | QWidget *page = plainPage(); | ||
58 | QGridLayout *layout = new QGridLayout( page, 3, 1 ); | ||
59 | layout->setMargin( KDialogBase::marginHint() ); | ||
60 | layout->setSpacing( KDialogBase::spacingHint() ); | ||
61 | |||
62 | int i = 0; | ||
63 | categoryComboBox = new KComboBox( page ); | ||
64 | QLabel* label = new QLabel( categoryComboBox, i18n("Category:"), page ); | ||
65 | layout->addWidget( label, i, 0 ); | ||
66 | layout->addWidget( categoryComboBox, i, 1 ); | ||
67 | i++; | ||
68 | categoryComboBox->setEditable( FALSE ); | ||
69 | categoryComboBox->setSizeLimit( 100 ); | ||
70 | connect(categoryComboBox,SIGNAL(activated(const QString&)), SLOT(categorySelected(const QString&))); | ||
71 | |||
72 | |||
73 | descLineEdit = new KLineEdit( page, "descLineEdit" ); | ||
74 | label = new QLabel( descLineEdit, i18n("Text1 (Description):"), page ); | ||
75 | layout->addWidget( label, i, 0 ); | ||
76 | layout->addWidget( descLineEdit, i, 1 ); | ||
77 | connect( descLineEdit, SIGNAL( textChanged ( const QString & ) ), SLOT( widgetModified(const QString &) ) ); | ||
78 | i++; | ||
79 | |||
80 | usernameLineEdit = new KLineEdit( page, "usernameLineEdit" ); | ||
81 | label = new QLabel( usernameLineEdit, i18n("Text2 (Username):"), page ); | ||
82 | layout->addWidget( label, i, 0 ); | ||
83 | layout->addWidget( usernameLineEdit, i, 1 ); | ||
84 | connect( usernameLineEdit, SIGNAL( textChanged ( const QString & ) ), SLOT( widgetModified(const QString &) ) ); | ||
85 | i++; | ||
86 | |||
87 | pwLineEdit = new KLineEdit( page, "pwLineEdit" ); | ||
88 | label = new QLabel( pwLineEdit, i18n("Text3 (Password):"), page ); | ||
89 | layout->addWidget( label, i, 0 ); | ||
90 | layout->addWidget( pwLineEdit, i, 1 ); | ||
91 | connect( pwLineEdit, SIGNAL( textChanged ( const QString & ) ), SLOT( widgetModified(const QString &) ) ); | ||
92 | i++; | ||
93 | |||
94 | unsigned int count = doc->numCategories(); | ||
95 | |||
96 | for (unsigned int i = 0; i < count; ++i) { | ||
97 | categoryComboBox->insertItem(doc->getCategory(i)->c_str()); | ||
98 | } | ||
99 | |||
100 | //PwMCategoryItem* getCategoryEntry(unsigned int index) | ||
101 | // { return &(dti.dta[index]); } | ||
102 | |||
103 | |||
104 | |||
105 | } | ||
106 | |||
107 | /* | ||
108 | * Destroys the object and frees any allocated resources | ||
109 | */ | ||
110 | editCategoryWnd::~editCategoryWnd() | ||
111 | { | ||
112 | // no need to delete child widgets, Qt does it all for us | ||
113 | } | ||
114 | |||
115 | void editCategoryWnd::slotOk() | ||
116 | { | ||
117 | // qDebug( "addEntryWnd::slotOk(): Not implemented yet" ); | ||
118 | slotApply(); | ||
119 | accept(); | ||
120 | } | ||
121 | |||
122 | void editCategoryWnd::slotApply() | ||
123 | { | ||
124 | QString cat = categoryComboBox->currentText(); | ||
125 | |||
126 | unsigned int idx; | ||
127 | bool found = doc->findCategory(cat, &idx); | ||
128 | |||
129 | if (found == true) | ||
130 | { | ||
131 | PwMCategoryItem* catitem = doc->getCategoryEntry(idx); | ||
132 | |||
133 | catitem->desc_text = descLineEdit->text().latin1(); | ||
134 | catitem->name_text = usernameLineEdit->text().latin1(); | ||
135 | catitem->pw_text = pwLineEdit->text().latin1(); | ||
136 | enableButton( KDialogBase::Apply, false ); | ||
137 | return; | ||
138 | } | ||
139 | |||
140 | BUG(); | ||
141 | |||
142 | } | ||
143 | |||
144 | void editCategoryWnd::cancel_slot() | ||
145 | { | ||
146 | QString cat = categoryComboBox->currentText(); | ||
147 | categorySelected ( cat ); | ||
148 | } | ||
149 | |||
150 | void editCategoryWnd::setCurrCategory(const QString &cat) | ||
151 | { | ||
152 | int i, count = categoryComboBox->count(); | ||
153 | |||
154 | for (i = 0; i < count; ++i) { | ||
155 | if (categoryComboBox->text(i) == cat) { | ||
156 | categoryComboBox->setCurrentItem(i); | ||
157 | categorySelected ( cat ); | ||
158 | return; | ||
159 | } | ||
160 | } | ||
161 | BUG(); | ||
162 | } | ||
163 | |||
164 | void editCategoryWnd::categorySelected ( const QString & string ) | ||
165 | { | ||
166 | unsigned int idx; | ||
167 | bool found = doc->findCategory(string, &idx); | ||
168 | |||
169 | if (found == true) | ||
170 | { | ||
171 | PwMCategoryItem* catitem = doc->getCategoryEntry(idx); | ||
172 | |||
173 | descLineEdit->setText(catitem->desc_text.c_str()); | ||
174 | usernameLineEdit->setText(catitem->name_text.c_str()); | ||
175 | pwLineEdit->setText(catitem->pw_text.c_str()); | ||
176 | enableButton( KDialogBase::Apply, false ); | ||
177 | return; | ||
178 | } | ||
179 | |||
180 | BUG(); | ||
181 | |||
182 | } | ||
183 | |||
184 | void editCategoryWnd::widgetModified(const QString &) | ||
185 | { | ||
186 | enableButton( KDialogBase::Apply, true ); | ||
187 | } | ||
188 | |||
diff --git a/pwmanager/pwmanager/editcategory.h b/pwmanager/pwmanager/editcategory.h new file mode 100644 index 0000000..90b685b --- a/dev/null +++ b/pwmanager/pwmanager/editcategory.h | |||
@@ -0,0 +1,77 @@ | |||
1 | /* | ||
2 | This file is part of PwManager/Platform independent. | ||
3 | Copyright (c) 2004 Ulf Schenk | ||
4 | |||
5 | This program is free software; you can redistribute it and/or modify | ||
6 | it under the terms of the GNU General Public License as published by | ||
7 | the Free Software Foundation; either version 2 of the License, or | ||
8 | (at your option) any later version. | ||
9 | |||
10 | This program is distributed in the hope that it will be useful, | ||
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
13 | GNU General Public License for more details. | ||
14 | |||
15 | You should have received a copy of the GNU General Public License | ||
16 | along with this program; if not, write to the Free Software | ||
17 | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | ||
18 | |||
19 | As a special exception, permission is given to link this program | ||
20 | with any edition of Qt, and distribute the resulting executable, | ||
21 | without including the source code for Qt in the source distribution. | ||
22 | |||
23 | $Id$ | ||
24 | */ | ||
25 | |||
26 | #ifndef EDITCATEGORY_H | ||
27 | #define EDITCATEGORY_H | ||
28 | |||
29 | #include <qvariant.h> | ||
30 | #include <kdialogbase.h> | ||
31 | |||
32 | class QVBoxLayout; | ||
33 | class QHBoxLayout; | ||
34 | class QGridLayout; | ||
35 | class QSpacerItem; | ||
36 | class KLineEdit; | ||
37 | class QPushButton; | ||
38 | class KComboBox; | ||
39 | class QLabel; | ||
40 | class QGroupBox; | ||
41 | class QMultiLineEdit; | ||
42 | class PwMDoc; | ||
43 | |||
44 | class editCategoryWnd : public KDialogBase | ||
45 | { | ||
46 | Q_OBJECT | ||
47 | |||
48 | public: | ||
49 | editCategoryWnd( PwMDoc* doc, QWidget* parent = 0, const char* name = 0); | ||
50 | ~editCategoryWnd(); | ||
51 | |||
52 | void setCurrCategory(const QString &cat); | ||
53 | |||
54 | KComboBox* categoryComboBox; | ||
55 | KLineEdit* descLineEdit; | ||
56 | KLineEdit* usernameLineEdit; | ||
57 | KLineEdit* pwLineEdit; | ||
58 | |||
59 | //public slots: | ||
60 | // virtual void revealButton_slot(); | ||
61 | // virtual void generateButton_slot(); | ||
62 | // virtual void advancedCommentButton_slot(bool on); | ||
63 | |||
64 | protected slots: | ||
65 | virtual void slotOk(); | ||
66 | virtual void slotApply(); | ||
67 | virtual void cancel_slot(); | ||
68 | |||
69 | virtual void categorySelected ( const QString & string ); | ||
70 | virtual void widgetModified(const QString &); | ||
71 | |||
72 | private: | ||
73 | PwMDoc* doc; | ||
74 | |||
75 | }; | ||
76 | |||
77 | #endif // EDITCATEGORY_H | ||
diff --git a/pwmanager/pwmanager/pwm.cpp b/pwmanager/pwmanager/pwm.cpp index 6ae6e28..bd98d72 100644 --- a/pwmanager/pwmanager/pwm.cpp +++ b/pwmanager/pwmanager/pwm.cpp | |||
@@ -11,64 +11,65 @@ | |||
11 | 11 | ||
12 | /*************************************************************************** | 12 | /*************************************************************************** |
13 | * copyright (C) 2004 by Ulf Schenk | 13 | * copyright (C) 2004 by Ulf Schenk |
14 | * This file is originaly based on version 1.0.1 of pwmanager | 14 | * This file is originaly based on version 1.0.1 of pwmanager |
15 | * and was modified to run on embedded devices that run microkde | 15 | * and was modified to run on embedded devices that run microkde |
16 | * | 16 | * |
17 | * $Id$ | 17 | * $Id$ |
18 | **************************************************************************/ | 18 | **************************************************************************/ |
19 | 19 | ||
20 | #include <klocale.h> | 20 | #include <klocale.h> |
21 | #include <klistview.h> | 21 | #include <klistview.h> |
22 | #include <ktoolbar.h> | 22 | #include <ktoolbar.h> |
23 | #include <kfiledialog.h> | 23 | #include <kfiledialog.h> |
24 | #include <kiconloader.h> | 24 | #include <kiconloader.h> |
25 | #include <kmessagebox.h> | 25 | #include <kmessagebox.h> |
26 | 26 | ||
27 | #include <qstatusbar.h> | 27 | #include <qstatusbar.h> |
28 | 28 | ||
29 | #ifndef PWM_EMBEDDED | 29 | #ifndef PWM_EMBEDDED |
30 | #include <kmenubar.h> | 30 | #include <kmenubar.h> |
31 | #include <kstatusbar.h> | 31 | #include <kstatusbar.h> |
32 | #include <dcopclient.h> | 32 | #include <dcopclient.h> |
33 | #include "configwndimpl.h" | 33 | #include "configwndimpl.h" |
34 | #include "configuration.h" | 34 | #include "configuration.h" |
35 | #else | 35 | #else |
36 | #include <qmenubar.h> | 36 | #include <qmenubar.h> |
37 | #include <qmessagebox.h> | 37 | #include <qmessagebox.h> |
38 | #include <pwmprefs.h> | 38 | #include <pwmprefs.h> |
39 | #include <kpimglobalprefs.h> | 39 | #include <kpimglobalprefs.h> |
40 | #include <kcmconfigs/kcmpwmconfig.h> | 40 | #include <kcmconfigs/kcmpwmconfig.h> |
41 | #include <kcmconfigs/kcmkdepimconfig.h> | 41 | #include <kcmconfigs/kcmkdepimconfig.h> |
42 | #include <kcmultidialog.h> | 42 | #include <kcmultidialog.h> |
43 | #include "editcategory.h" | ||
43 | #endif | 44 | #endif |
44 | 45 | ||
45 | 46 | ||
46 | #ifndef DESKTOP_VERSION | 47 | #ifndef DESKTOP_VERSION |
47 | #include <qpe/global.h> | 48 | #include <qpe/global.h> |
48 | #endif | 49 | #endif |
49 | 50 | ||
50 | #include <qpixmap.h> | 51 | #include <qpixmap.h> |
51 | #include <qcheckbox.h> | 52 | #include <qcheckbox.h> |
52 | #include <qspinbox.h> | 53 | #include <qspinbox.h> |
53 | #include <qlineedit.h> | 54 | #include <qlineedit.h> |
54 | #include <qfileinfo.h> | 55 | #include <qfileinfo.h> |
55 | #include <qclipboard.h> | 56 | #include <qclipboard.h> |
56 | 57 | ||
57 | 58 | ||
58 | #include <stdio.h> | 59 | #include <stdio.h> |
59 | 60 | ||
60 | #include "pwm.h" | 61 | #include "pwm.h" |
61 | #include "pwminit.h" | 62 | #include "pwminit.h" |
62 | #include "pwmprint.h" | 63 | #include "pwmprint.h" |
63 | #include "addentrywndimpl.h" | 64 | #include "addentrywndimpl.h" |
64 | #include "globalstuff.h" | 65 | #include "globalstuff.h" |
65 | #include "findwndimpl.h" | 66 | #include "findwndimpl.h" |
66 | #include "csv.h" | 67 | #include "csv.h" |
67 | 68 | ||
68 | #ifdef CONFIG_KWALLETIF | 69 | #ifdef CONFIG_KWALLETIF |
69 | # include "kwalletif.h" | 70 | # include "kwalletif.h" |
70 | # include "kwalletemu.h" | 71 | # include "kwalletemu.h" |
71 | #endif | 72 | #endif |
72 | #ifdef CONFIG_KEYCARD | 73 | #ifdef CONFIG_KEYCARD |
73 | # include "pwmkeycard.h" | 74 | # include "pwmkeycard.h" |
74 | #endif | 75 | #endif |
@@ -88,64 +89,67 @@ enum { | |||
88 | BUTTON_POPUP_FILE_PRINT, | 89 | BUTTON_POPUP_FILE_PRINT, |
89 | BUTTON_POPUP_FILE_QUIT | 90 | BUTTON_POPUP_FILE_QUIT |
90 | }; | 91 | }; |
91 | // Button IDs for "manage" popup menu | 92 | // Button IDs for "manage" popup menu |
92 | enum { | 93 | enum { |
93 | BUTTON_POPUP_MANAGE_ADD = 0, | 94 | BUTTON_POPUP_MANAGE_ADD = 0, |
94 | BUTTON_POPUP_MANAGE_EDIT, | 95 | BUTTON_POPUP_MANAGE_EDIT, |
95 | BUTTON_POPUP_MANAGE_DEL, | 96 | BUTTON_POPUP_MANAGE_DEL, |
96 | BUTTON_POPUP_MANAGE_CHANGEMP | 97 | BUTTON_POPUP_MANAGE_CHANGEMP |
97 | }; | 98 | }; |
98 | // Button IDs for chipcard popup menu | 99 | // Button IDs for chipcard popup menu |
99 | enum { | 100 | enum { |
100 | #ifdef CONFIG_KEYCARD | 101 | #ifdef CONFIG_KEYCARD |
101 | BUTTON_POPUP_CHIPCARD_GENNEW = 0, | 102 | BUTTON_POPUP_CHIPCARD_GENNEW = 0, |
102 | BUTTON_POPUP_CHIPCARD_DEL, | 103 | BUTTON_POPUP_CHIPCARD_DEL, |
103 | BUTTON_POPUP_CHIPCARD_READID, | 104 | BUTTON_POPUP_CHIPCARD_READID, |
104 | BUTTON_POPUP_CHIPCARD_SAVEBACKUP, | 105 | BUTTON_POPUP_CHIPCARD_SAVEBACKUP, |
105 | BUTTON_POPUP_CHIPCARD_REPLAYBACKUP | 106 | BUTTON_POPUP_CHIPCARD_REPLAYBACKUP |
106 | #else // CONFIG_KEYCARD | 107 | #else // CONFIG_KEYCARD |
107 | BUTTON_POPUP_CHIPCARD_NO = 0 | 108 | BUTTON_POPUP_CHIPCARD_NO = 0 |
108 | #endif // CONFIG_KEYCARD | 109 | #endif // CONFIG_KEYCARD |
109 | }; | 110 | }; |
110 | // Button IDs for "view" popup menu | 111 | // Button IDs for "view" popup menu |
111 | enum { | 112 | enum { |
112 | BUTTON_POPUP_VIEW_FIND = 0, | 113 | BUTTON_POPUP_VIEW_FIND = 0, |
113 | BUTTON_POPUP_VIEW_LOCK, | 114 | BUTTON_POPUP_VIEW_LOCK, |
114 | BUTTON_POPUP_VIEW_DEEPLOCK, | 115 | BUTTON_POPUP_VIEW_DEEPLOCK, |
115 | BUTTON_POPUP_VIEW_UNLOCK | 116 | BUTTON_POPUP_VIEW_UNLOCK |
116 | }; | 117 | }; |
117 | // Button IDs for "options" popup menu | 118 | // Button IDs for "options" popup menu |
118 | enum { | 119 | enum { |
119 | BUTTON_POPUP_OPTIONS_CONFIG = 0 | 120 | BUTTON_POPUP_OPTIONS_CONFIG = 0 |
121 | #ifdef PWM_EMBEDDED | ||
122 | ,BUTTON_POPUP_OPTIONS_CATEGORY | ||
123 | #endif | ||
120 | }; | 124 | }; |
121 | // Button IDs for "export" popup menu (in "file" popup menu) | 125 | // Button IDs for "export" popup menu (in "file" popup menu) |
122 | enum { | 126 | enum { |
123 | BUTTON_POPUP_EXPORT_TEXT = 0, | 127 | BUTTON_POPUP_EXPORT_TEXT = 0, |
124 | BUTTON_POPUP_EXPORT_GPASMAN, | 128 | BUTTON_POPUP_EXPORT_GPASMAN, |
125 | BUTTON_POPUP_EXPORT_CSV | 129 | BUTTON_POPUP_EXPORT_CSV |
126 | #ifdef CONFIG_KWALLETIF | 130 | #ifdef CONFIG_KWALLETIF |
127 | ,BUTTON_POPUP_EXPORT_KWALLET | 131 | ,BUTTON_POPUP_EXPORT_KWALLET |
128 | #endif | 132 | #endif |
129 | }; | 133 | }; |
130 | // Button IDs for "import" popup menu (in "file" popup menu) | 134 | // Button IDs for "import" popup menu (in "file" popup menu) |
131 | enum { | 135 | enum { |
132 | BUTTON_POPUP_IMPORT_TEXT = 0, | 136 | BUTTON_POPUP_IMPORT_TEXT = 0, |
133 | BUTTON_POPUP_IMPORT_GPASMAN, | 137 | BUTTON_POPUP_IMPORT_GPASMAN, |
134 | BUTTON_POPUP_IMPORT_CSV | 138 | BUTTON_POPUP_IMPORT_CSV |
135 | #ifdef CONFIG_KWALLETIF | 139 | #ifdef CONFIG_KWALLETIF |
136 | ,BUTTON_POPUP_IMPORT_KWALLET | 140 | ,BUTTON_POPUP_IMPORT_KWALLET |
137 | #endif | 141 | #endif |
138 | }; | 142 | }; |
139 | 143 | ||
140 | #ifdef PWM_EMBEDDED | 144 | #ifdef PWM_EMBEDDED |
141 | // Button IDs for "help" popup menu | 145 | // Button IDs for "help" popup menu |
142 | enum { | 146 | enum { |
143 | BUTTON_POPUP_HELP_LICENSE = 0, | 147 | BUTTON_POPUP_HELP_LICENSE = 0, |
144 | BUTTON_POPUP_HELP_FAQ, | 148 | BUTTON_POPUP_HELP_FAQ, |
145 | BUTTON_POPUP_HELP_ABOUT, | 149 | BUTTON_POPUP_HELP_ABOUT, |
146 | BUTTON_POPUP_HELP_SYNC, | 150 | BUTTON_POPUP_HELP_SYNC, |
147 | BUTTON_POPUP_HELP_WHATSNEW | 151 | BUTTON_POPUP_HELP_WHATSNEW |
148 | }; | 152 | }; |
149 | #endif | 153 | #endif |
150 | 154 | ||
151 | // Button IDs for toolbar | 155 | // Button IDs for toolbar |
@@ -331,64 +335,70 @@ void PwM::initMenubar() | |||
331 | SLOT(replayCardBackup_slot()), 0, | 335 | SLOT(replayCardBackup_slot()), 0, |
332 | BUTTON_POPUP_CHIPCARD_REPLAYBACKUP); | 336 | BUTTON_POPUP_CHIPCARD_REPLAYBACKUP); |
333 | menuBar()->insertItem(i18n("&Chipcard manager"), chipcardPopup); | 337 | menuBar()->insertItem(i18n("&Chipcard manager"), chipcardPopup); |
334 | #endif // CONFIG_KEYCARD | 338 | #endif // CONFIG_KEYCARD |
335 | // "view" popup menu | 339 | // "view" popup menu |
336 | viewPopup->insertItem(QIconSet(picons->loadIcon("find", KIcon::Small)), | 340 | viewPopup->insertItem(QIconSet(picons->loadIcon("find", KIcon::Small)), |
337 | i18n("&Find"), this, | 341 | i18n("&Find"), this, |
338 | SLOT(find_slot()), 0, BUTTON_POPUP_VIEW_FIND); | 342 | SLOT(find_slot()), 0, BUTTON_POPUP_VIEW_FIND); |
339 | viewPopup->insertSeparator(); | 343 | viewPopup->insertSeparator(); |
340 | viewPopup->insertItem(QIconSet(picons->loadIcon("halfencrypted", KIcon::Small)), | 344 | viewPopup->insertItem(QIconSet(picons->loadIcon("halfencrypted", KIcon::Small)), |
341 | i18n("&Lock all entries"), this, | 345 | i18n("&Lock all entries"), this, |
342 | SLOT(lockWnd_slot()), 0, | 346 | SLOT(lockWnd_slot()), 0, |
343 | BUTTON_POPUP_VIEW_LOCK); | 347 | BUTTON_POPUP_VIEW_LOCK); |
344 | viewPopup->insertItem(QIconSet(picons->loadIcon("encrypted", KIcon::Small)), | 348 | viewPopup->insertItem(QIconSet(picons->loadIcon("encrypted", KIcon::Small)), |
345 | i18n("&Deep-lock all entries"), this, | 349 | i18n("&Deep-lock all entries"), this, |
346 | SLOT(deepLockWnd_slot()), 0, | 350 | SLOT(deepLockWnd_slot()), 0, |
347 | BUTTON_POPUP_VIEW_DEEPLOCK); | 351 | BUTTON_POPUP_VIEW_DEEPLOCK); |
348 | viewPopup->insertItem(QIconSet(picons->loadIcon("decrypted", KIcon::Small)), | 352 | viewPopup->insertItem(QIconSet(picons->loadIcon("decrypted", KIcon::Small)), |
349 | i18n("&Unlock all entries"), this, | 353 | i18n("&Unlock all entries"), this, |
350 | SLOT(unlockWnd_slot()), 0, | 354 | SLOT(unlockWnd_slot()), 0, |
351 | BUTTON_POPUP_VIEW_UNLOCK); | 355 | BUTTON_POPUP_VIEW_UNLOCK); |
352 | menuBar()->insertItem(i18n("&View"), viewPopup); | 356 | menuBar()->insertItem(i18n("&View"), viewPopup); |
353 | // "options" popup menu | 357 | // "options" popup menu |
354 | optionsPopup->insertItem(QIconSet(picons->loadIcon("configure", KIcon::Small)), | 358 | optionsPopup->insertItem(QIconSet(picons->loadIcon("configure", KIcon::Small)), |
355 | i18n("&Configure..."), this, | 359 | i18n("&Configure..."), this, |
356 | SLOT(config_slot()), | 360 | SLOT(config_slot()), |
357 | BUTTON_POPUP_OPTIONS_CONFIG); | 361 | BUTTON_POPUP_OPTIONS_CONFIG); |
358 | menuBar()->insertItem(i18n("&Options"), optionsPopup); | 362 | menuBar()->insertItem(i18n("&Options"), optionsPopup); |
359 | // "help" popup menu | 363 | // "help" popup menu |
360 | #ifndef PWM_EMBEDDED | 364 | #ifndef PWM_EMBEDDED |
361 | helpPopup = helpMenu(QString::null, false); | 365 | helpPopup = helpMenu(QString::null, false); |
362 | #else | 366 | #else |
367 | optionsPopup->insertItem(QIconSet(picons->loadIcon("configure", KIcon::Small)), | ||
368 | i18n("C&ategories..."), this, | ||
369 | SLOT(category_slot()), | ||
370 | BUTTON_POPUP_OPTIONS_CATEGORY); | ||
371 | |||
372 | |||
363 | menuBar()->insertItem(i18n("&Sync"), syncPopup); | 373 | menuBar()->insertItem(i18n("&Sync"), syncPopup); |
364 | 374 | ||
365 | 375 | ||
366 | 376 | ||
367 | 377 | ||
368 | 378 | ||
369 | helpPopup = new KPopupMenu(this); | 379 | helpPopup = new KPopupMenu(this); |
370 | 380 | ||
371 | 381 | ||
372 | helpPopup->insertItem(i18n("&License"), this, | 382 | helpPopup->insertItem(i18n("&License"), this, |
373 | SLOT(showLicense_slot()), 0, | 383 | SLOT(showLicense_slot()), 0, |
374 | BUTTON_POPUP_HELP_LICENSE); | 384 | BUTTON_POPUP_HELP_LICENSE); |
375 | 385 | ||
376 | helpPopup->insertItem(i18n("&Faq"), this, | 386 | helpPopup->insertItem(i18n("&Faq"), this, |
377 | SLOT(faq_slot()), 0, | 387 | SLOT(faq_slot()), 0, |
378 | BUTTON_POPUP_HELP_FAQ); | 388 | BUTTON_POPUP_HELP_FAQ); |
379 | 389 | ||
380 | helpPopup->insertItem(i18n("&About PwManager"), this, | 390 | helpPopup->insertItem(i18n("&About PwManager"), this, |
381 | SLOT(createAboutData_slot()), 0, | 391 | SLOT(createAboutData_slot()), 0, |
382 | BUTTON_POPUP_HELP_ABOUT); | 392 | BUTTON_POPUP_HELP_ABOUT); |
383 | 393 | ||
384 | helpPopup->insertItem(i18n("&Sync HowTo"), this, | 394 | helpPopup->insertItem(i18n("&Sync HowTo"), this, |
385 | SLOT(syncHowTo_slot()), 0, | 395 | SLOT(syncHowTo_slot()), 0, |
386 | BUTTON_POPUP_HELP_SYNC); | 396 | BUTTON_POPUP_HELP_SYNC); |
387 | 397 | ||
388 | helpPopup->insertItem(i18n("&What's New"), this, | 398 | helpPopup->insertItem(i18n("&What's New"), this, |
389 | SLOT(whatsnew_slot()), 0, | 399 | SLOT(whatsnew_slot()), 0, |
390 | BUTTON_POPUP_HELP_WHATSNEW); | 400 | BUTTON_POPUP_HELP_WHATSNEW); |
391 | 401 | ||
392 | #endif | 402 | #endif |
393 | menuBar()->insertItem(i18n("&Help"), helpPopup); | 403 | menuBar()->insertItem(i18n("&Help"), helpPopup); |
394 | 404 | ||
@@ -1362,64 +1372,123 @@ void PwM::copyToClipboard(const QString &s) | |||
1362 | cb->setText(s, QClipboard::Selection); | 1372 | cb->setText(s, QClipboard::Selection); |
1363 | cb->setText(s, QClipboard::Clipboard); | 1373 | cb->setText(s, QClipboard::Clipboard); |
1364 | #else | 1374 | #else |
1365 | cb->setText(s); | 1375 | cb->setText(s); |
1366 | 1376 | ||
1367 | #endif | 1377 | #endif |
1368 | 1378 | ||
1369 | } | 1379 | } |
1370 | 1380 | ||
1371 | 1381 | ||
1372 | void PwM::showStatMsg(const QString &msg) | 1382 | void PwM::showStatMsg(const QString &msg) |
1373 | { | 1383 | { |
1374 | #ifdef DESKTOP_VERSION | 1384 | #ifdef DESKTOP_VERSION |
1375 | statusBar()->message(msg, STATUSBAR_MSG_TIMEOUT * 1000); | 1385 | statusBar()->message(msg, STATUSBAR_MSG_TIMEOUT * 1000); |
1376 | #else | 1386 | #else |
1377 | qDebug("Statusbar : %s",msg.latin1()); | 1387 | qDebug("Statusbar : %s",msg.latin1()); |
1378 | Global::statusMessage(msg); | 1388 | Global::statusMessage(msg); |
1379 | #endif | 1389 | #endif |
1380 | } | 1390 | } |
1381 | 1391 | ||
1382 | void PwM::focusInEvent(QFocusEvent *e) | 1392 | void PwM::focusInEvent(QFocusEvent *e) |
1383 | { | 1393 | { |
1384 | if (e->gotFocus()) { | 1394 | if (e->gotFocus()) { |
1385 | emit gotFocus(this); | 1395 | emit gotFocus(this); |
1386 | } else if (e->lostFocus()) { | 1396 | } else if (e->lostFocus()) { |
1387 | emit lostFocus(this); | 1397 | emit lostFocus(this); |
1388 | } | 1398 | } |
1389 | } | 1399 | } |
1390 | 1400 | ||
1391 | 1401 | ||
1392 | #ifdef PWM_EMBEDDED | 1402 | #ifdef PWM_EMBEDDED |
1393 | 1403 | ||
1404 | void PwM::category_slot() | ||
1405 | { | ||
1406 | PwMDoc *doc = curDoc(); | ||
1407 | PWM_ASSERT(doc); | ||
1408 | doc->timer()->getLock(DocTimer::id_autoLockTimer); | ||
1409 | |||
1410 | editCategoryWnd w(doc, this, "editcategory"); | ||
1411 | /* | ||
1412 | vector<string> catList; | ||
1413 | doc->getCategoryList(&catList); | ||
1414 | unsigned i, size = catList.size(); | ||
1415 | for (i = 0; i < size; ++i) { | ||
1416 | w.addCategory(catList[i].c_str()); | ||
1417 | } | ||
1418 | w.setCurrCategory(view->getCurrentCategory()); | ||
1419 | if (pw) | ||
1420 | w.pwLineEdit->setText(*pw); | ||
1421 | */ | ||
1422 | w.setCurrCategory(view->getCurrentCategory()); | ||
1423 | |||
1424 | tryAgain: | ||
1425 | if (w.exec() == 1) | ||
1426 | { | ||
1427 | PwMDataItem d; | ||
1428 | |||
1429 | //US BUG: to initialize all values of curEntr with meaningfulldata, | ||
1430 | // we call clear on it. Reason: Metadata will be uninitialized otherwise. | ||
1431 | // another option would be to create a constructor for PwMDataItem | ||
1432 | d.clear(true); | ||
1433 | /* | ||
1434 | d.desc = w.getDescription().latin1(); | ||
1435 | d.name = w.getUsername().latin1(); | ||
1436 | d.pw = w.getPassword().latin1(); | ||
1437 | d.comment = w.getComment().latin1(); | ||
1438 | d.url = w.getUrl().latin1(); | ||
1439 | d.launcher = w.getLauncher().latin1(); | ||
1440 | PwMerror ret = doc->addEntry(w.getCategory(), &d); | ||
1441 | if (ret == e_entryExists) { | ||
1442 | KMessageBox::error(this, | ||
1443 | i18n | ||
1444 | ("An entry with this \"Description\",\n" | ||
1445 | "does already exist.\n" | ||
1446 | "Please select another description."), | ||
1447 | i18n("entry already exists.")); | ||
1448 | goto tryAgain; | ||
1449 | } else if (ret == e_maxAllowedEntr) { | ||
1450 | KMessageBox::error(this, i18n("The maximum possible number of\nentries" | ||
1451 | "has been reached.\nYou can't add more entries."), | ||
1452 | i18n("maximum number of entries")); | ||
1453 | doc->timer()->putLock(DocTimer::id_autoLockTimer); | ||
1454 | return; | ||
1455 | } | ||
1456 | */ | ||
1457 | } | ||
1458 | setVirgin(false); | ||
1459 | doc->timer()->putLock(DocTimer::id_autoLockTimer); | ||
1460 | } | ||
1461 | |||
1462 | |||
1394 | void PwM::whatsnew_slot() | 1463 | void PwM::whatsnew_slot() |
1395 | { | 1464 | { |
1396 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); | 1465 | KApplication::showFile( "KDE-Pim/Pi Version Info", "kdepim/WhatsNew.txt" ); |
1397 | } | 1466 | } |
1398 | 1467 | ||
1399 | void PwM::showLicense_slot() | 1468 | void PwM::showLicense_slot() |
1400 | { | 1469 | { |
1401 | KApplication::showLicence(); | 1470 | KApplication::showLicence(); |
1402 | } | 1471 | } |
1403 | 1472 | ||
1404 | void PwM::faq_slot() | 1473 | void PwM::faq_slot() |
1405 | { | 1474 | { |
1406 | KApplication::showFile( "PWM/Pi FAQ", "kdepim/pwmanager/pwmanagerFAQ.txt" ); | 1475 | KApplication::showFile( "PWM/Pi FAQ", "kdepim/pwmanager/pwmanagerFAQ.txt" ); |
1407 | } | 1476 | } |
1408 | 1477 | ||
1409 | void PwM::syncHowTo_slot() | 1478 | void PwM::syncHowTo_slot() |
1410 | { | 1479 | { |
1411 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); | 1480 | KApplication::showFile( "KDE-Pim/Pi Synchronization HowTo", "kdepim/SyncHowto.txt" ); |
1412 | } | 1481 | } |
1413 | 1482 | ||
1414 | 1483 | ||
1415 | void PwM::createAboutData_slot() | 1484 | void PwM::createAboutData_slot() |
1416 | { | 1485 | { |
1417 | QString version; | 1486 | QString version; |
1418 | #include <../version> | 1487 | #include <../version> |
1419 | ; | 1488 | ; |
1420 | QMessageBox::about( this, "About PwManager/Pi", | 1489 | QMessageBox::about( this, "About PwManager/Pi", |
1421 | "PwManager/Platform-independent\n" | 1490 | "PwManager/Platform-independent\n" |
1422 | "(PWM/Pi) " +version + " - " + | 1491 | "(PWM/Pi) " +version + " - " + |
1423 | #ifdef DESKTOP_VERSION | 1492 | #ifdef DESKTOP_VERSION |
1424 | "Desktop Edition\n" | 1493 | "Desktop Edition\n" |
1425 | #else | 1494 | #else |
diff --git a/pwmanager/pwmanager/pwm.h b/pwmanager/pwmanager/pwm.h index fb34bca..9fa9edc 100644 --- a/pwmanager/pwmanager/pwm.h +++ b/pwmanager/pwmanager/pwm.h | |||
@@ -150,64 +150,65 @@ public slots: | |||
150 | /** manage/delete triggered */ | 150 | /** manage/delete triggered */ |
151 | void deletePwd_slot(); | 151 | void deletePwd_slot(); |
152 | /** execute the "Launcher" entry */ | 152 | /** execute the "Launcher" entry */ |
153 | void execLauncher_slot(); | 153 | void execLauncher_slot(); |
154 | /** open browser with URL entry */ | 154 | /** open browser with URL entry */ |
155 | void goToURL_slot(); | 155 | void goToURL_slot(); |
156 | /** manage/changeMasterPwd triggered */ | 156 | /** manage/changeMasterPwd triggered */ |
157 | void changeMasterPwd_slot(); | 157 | void changeMasterPwd_slot(); |
158 | /** lock current document */ | 158 | /** lock current document */ |
159 | void lockWnd_slot(); | 159 | void lockWnd_slot(); |
160 | /** deeplock current document */ | 160 | /** deeplock current document */ |
161 | void deepLockWnd_slot(); | 161 | void deepLockWnd_slot(); |
162 | /** window/unlock triggered */ | 162 | /** window/unlock triggered */ |
163 | void unlockWnd_slot(); | 163 | void unlockWnd_slot(); |
164 | /** find item */ | 164 | /** find item */ |
165 | void find_slot(); | 165 | void find_slot(); |
166 | /** configure clicked */ | 166 | /** configure clicked */ |
167 | void config_slot(); | 167 | void config_slot(); |
168 | /** (de)activate the "change master pw" button in the menu-bar */ | 168 | /** (de)activate the "change master pw" button in the menu-bar */ |
169 | void activateMpButton(bool activate = true); | 169 | void activateMpButton(bool activate = true); |
170 | /** generate a new chipcard */ | 170 | /** generate a new chipcard */ |
171 | void genNewCard_slot(); | 171 | void genNewCard_slot(); |
172 | /** completely erase the current card */ | 172 | /** completely erase the current card */ |
173 | void eraseCard_slot(); | 173 | void eraseCard_slot(); |
174 | /** returns the ID number of the current card */ | 174 | /** returns the ID number of the current card */ |
175 | void readCardId_slot(); | 175 | void readCardId_slot(); |
176 | /** make backup image of the current card */ | 176 | /** make backup image of the current card */ |
177 | void makeCardBackup_slot(); | 177 | void makeCardBackup_slot(); |
178 | /** write backup image to current card */ | 178 | /** write backup image to current card */ |
179 | void replayCardBackup_slot(); | 179 | void replayCardBackup_slot(); |
180 | 180 | ||
181 | #ifdef PWM_EMBEDDED | 181 | #ifdef PWM_EMBEDDED |
182 | void category_slot(); | ||
182 | void whatsnew_slot(); | 183 | void whatsnew_slot(); |
183 | void showLicense_slot(); | 184 | void showLicense_slot(); |
184 | void faq_slot(); | 185 | void faq_slot(); |
185 | void createAboutData_slot(); | 186 | void createAboutData_slot(); |
186 | void syncHowTo_slot(); | 187 | void syncHowTo_slot(); |
187 | #endif | 188 | #endif |
188 | 189 | ||
189 | protected: | 190 | protected: |
190 | /** is this window virgin? */ | 191 | /** is this window virgin? */ |
191 | bool isVirgin() | 192 | bool isVirgin() |
192 | { return virgin; } | 193 | { return virgin; } |
193 | /** add/remove virginity */ | 194 | /** add/remove virginity */ |
194 | void setVirgin(bool v); | 195 | void setVirgin(bool v); |
195 | /** initialize the menubar */ | 196 | /** initialize the menubar */ |
196 | void initMenubar(); | 197 | void initMenubar(); |
197 | /** initialize the toolbar */ | 198 | /** initialize the toolbar */ |
198 | void initToolbar(); | 199 | void initToolbar(); |
199 | /** initialize the window-metrics */ | 200 | /** initialize the window-metrics */ |
200 | void initMetrics(); | 201 | void initMetrics(); |
201 | /** close-event */ | 202 | /** close-event */ |
202 | void closeEvent(QCloseEvent *e); | 203 | void closeEvent(QCloseEvent *e); |
203 | /** creates a new PwM-ListView and returns it */ | 204 | /** creates a new PwM-ListView and returns it */ |
204 | PwMView * makeNewListView(PwMDoc *doc); | 205 | PwMView * makeNewListView(PwMDoc *doc); |
205 | /** Window hide-event */ | 206 | /** Window hide-event */ |
206 | void hideEvent(QHideEvent *); | 207 | void hideEvent(QHideEvent *); |
207 | /** is this window minimized? */ | 208 | /** is this window minimized? */ |
208 | bool isMinimized() | 209 | bool isMinimized() |
209 | { | 210 | { |
210 | #ifndef PWM_EMBEDDED | 211 | #ifndef PWM_EMBEDDED |
211 | #if KDE_VERSION >= KDE_MAKE_VERSION(3, 2, 0) | 212 | #if KDE_VERSION >= KDE_MAKE_VERSION(3, 2, 0) |
212 | return KWin::windowInfo(winId()).isMinimized(); | 213 | return KWin::windowInfo(winId()).isMinimized(); |
213 | #else // KDE_VERSION | 214 | #else // KDE_VERSION |
diff --git a/pwmanager/pwmanager/pwmanager.pro b/pwmanager/pwmanager/pwmanager.pro index fbc0554..7efe45c 100644 --- a/pwmanager/pwmanager/pwmanager.pro +++ b/pwmanager/pwmanager/pwmanager.pro | |||
@@ -38,64 +38,65 @@ QMAKE_CXXFLAGS += /TP /GX /GR /Ehsc | |||
38 | #configwnd.ui \ | 38 | #configwnd.ui \ |
39 | #findwnd.ui \ | 39 | #findwnd.ui \ |
40 | #getmasterpwwnd.ui \ | 40 | #getmasterpwwnd.ui \ |
41 | #pwgenwnd.ui \ | 41 | #pwgenwnd.ui \ |
42 | #setmasterpwwnd.ui \ | 42 | #setmasterpwwnd.ui \ |
43 | #subtbledit.ui | 43 | #subtbledit.ui |
44 | 44 | ||
45 | #INTERFACES = \ | 45 | #INTERFACES = \ |
46 | #subtbledit.ui \ | 46 | #subtbledit.ui \ |
47 | 47 | ||
48 | 48 | ||
49 | 49 | ||
50 | #HEADERS = \ | 50 | #HEADERS = \ |
51 | #configuration_31compat.h \ | 51 | #configuration_31compat.h \ |
52 | #configuration.h \ | 52 | #configuration.h \ |
53 | #configwnd.h \ | 53 | #configwnd.h \ |
54 | #configwndimpl.h \ | 54 | #configwndimpl.h \ |
55 | #selftest.h | 55 | #selftest.h |
56 | #subtbledit.h \ | 56 | #subtbledit.h \ |
57 | #subtbleditimpl.h \ | 57 | #subtbleditimpl.h \ |
58 | #compressbzip2.h \ | 58 | #compressbzip2.h \ |
59 | 59 | ||
60 | HEADERS = \ | 60 | HEADERS = \ |
61 | addentrywnd_emb.h \ | 61 | addentrywnd_emb.h \ |
62 | addentrywndimpl.h \ | 62 | addentrywndimpl.h \ |
63 | base64.h \ | 63 | base64.h \ |
64 | binentrygen.h \ | 64 | binentrygen.h \ |
65 | blowfish.h \ | 65 | blowfish.h \ |
66 | commentbox.h \ | 66 | commentbox.h \ |
67 | compiler.h \ | 67 | compiler.h \ |
68 | compressgzip.h \ | 68 | compressgzip.h \ |
69 | csv.h \ | 69 | csv.h \ |
70 | editcategory.h \ | ||
70 | findwnd_emb.h \ | 71 | findwnd_emb.h \ |
71 | findwndimpl.h \ | 72 | findwndimpl.h \ |
72 | genpasswd.h \ | 73 | genpasswd.h \ |
73 | getkeycardwnd.h \ | 74 | getkeycardwnd.h \ |
74 | getmasterpwwnd_emb.h \ | 75 | getmasterpwwnd_emb.h \ |
75 | getmasterpwwndimpl.h \ | 76 | getmasterpwwndimpl.h \ |
76 | globalstuff.h \ | 77 | globalstuff.h \ |
77 | gpasmanfile.h \ | 78 | gpasmanfile.h \ |
78 | htmlgen.h \ | 79 | htmlgen.h \ |
79 | htmlparse.h \ | 80 | htmlparse.h \ |
80 | ipc.h \ | 81 | ipc.h \ |
81 | libgcryptif.h \ | 82 | libgcryptif.h \ |
82 | listobjselectwnd.h \ | 83 | listobjselectwnd.h \ |
83 | listviewpwm.h \ | 84 | listviewpwm.h \ |
84 | printtext.h \ | 85 | printtext.h \ |
85 | pwgenwnd_emb.h \ | 86 | pwgenwnd_emb.h \ |
86 | pwgenwndimpl.h \ | 87 | pwgenwndimpl.h \ |
87 | pwmdoc.h \ | 88 | pwmdoc.h \ |
88 | pwmdocui.h \ | 89 | pwmdocui.h \ |
89 | pwmexception.h \ | 90 | pwmexception.h \ |
90 | pwm.h \ | 91 | pwm.h \ |
91 | pwminit.h \ | 92 | pwminit.h \ |
92 | pwmprefs.h \ | 93 | pwmprefs.h \ |
93 | pwmprint.h \ | 94 | pwmprint.h \ |
94 | pwmtray.h \ | 95 | pwmtray.h \ |
95 | pwmview.h \ | 96 | pwmview.h \ |
96 | pwmviewstyle_0.h \ | 97 | pwmviewstyle_0.h \ |
97 | pwmviewstyle_1.h \ | 98 | pwmviewstyle_1.h \ |
98 | pwmviewstyle.h \ | 99 | pwmviewstyle.h \ |
99 | randomizer.h \ | 100 | randomizer.h \ |
100 | rc2.h \ | 101 | rc2.h \ |
101 | rencatwnd.h \ | 102 | rencatwnd.h \ |
@@ -104,64 +105,65 @@ setmasterpwwnd_emb.h \ | |||
104 | setmasterpwwndimpl.h \ | 105 | setmasterpwwndimpl.h \ |
105 | sha1.h \ | 106 | sha1.h \ |
106 | waitwnd.h \ | 107 | waitwnd.h \ |
107 | kcmconfigs/kcmpwmconfig.h \ | 108 | kcmconfigs/kcmpwmconfig.h \ |
108 | kcmconfigs/pwmconfigwidget.h | 109 | kcmconfigs/pwmconfigwidget.h |
109 | 110 | ||
110 | #sources that need not be build | 111 | #sources that need not be build |
111 | #SOURCES = \ | 112 | #SOURCES = \ |
112 | #advcommeditimpl.cpp \ | 113 | #advcommeditimpl.cpp \ |
113 | #configuration.cpp \ | 114 | #configuration.cpp \ |
114 | #configwnd.cpp \ | 115 | #configwnd.cpp \ |
115 | #configwndimpl.cpp \ | 116 | #configwndimpl.cpp \ |
116 | #configuration_31compat.cpp \ | 117 | #configuration_31compat.cpp \ |
117 | #htmlparse.cpp \ | 118 | #htmlparse.cpp \ |
118 | #printtext.cpp \ | 119 | #printtext.cpp \ |
119 | #selftest.cpp \ | 120 | #selftest.cpp \ |
120 | #pwmprint.cpp \ | 121 | #pwmprint.cpp \ |
121 | #spinforsignal.cpp | 122 | #spinforsignal.cpp |
122 | #subtbledit.cpp \ | 123 | #subtbledit.cpp \ |
123 | #subtbleditimpl.cpp \ | 124 | #subtbleditimpl.cpp \ |
124 | #compressbzip2.cpp | 125 | #compressbzip2.cpp |
125 | 126 | ||
126 | 127 | ||
127 | SOURCES = \ | 128 | SOURCES = \ |
128 | addentrywnd_emb.cpp \ | 129 | addentrywnd_emb.cpp \ |
129 | addentrywndimpl.cpp \ | 130 | addentrywndimpl.cpp \ |
130 | base64.cpp \ | 131 | base64.cpp \ |
131 | binentrygen.cpp \ | 132 | binentrygen.cpp \ |
132 | blowfish.cpp \ | 133 | blowfish.cpp \ |
133 | commentbox.cpp \ | 134 | commentbox.cpp \ |
134 | compressgzip.cpp \ | 135 | compressgzip.cpp \ |
135 | csv.cpp \ | 136 | csv.cpp \ |
137 | editcategory.cpp \ | ||
136 | findwnd_emb.cpp \ | 138 | findwnd_emb.cpp \ |
137 | findwndimpl.cpp \ | 139 | findwndimpl.cpp \ |
138 | genpasswd.cpp \ | 140 | genpasswd.cpp \ |
139 | getkeycardwnd.cpp \ | 141 | getkeycardwnd.cpp \ |
140 | getmasterpwwnd_emb.cpp \ | 142 | getmasterpwwnd_emb.cpp \ |
141 | getmasterpwwndimpl.cpp \ | 143 | getmasterpwwndimpl.cpp \ |
142 | globalstuff.cpp \ | 144 | globalstuff.cpp \ |
143 | gpasmanfile.cpp \ | 145 | gpasmanfile.cpp \ |
144 | htmlgen.cpp \ | 146 | htmlgen.cpp \ |
145 | ipc.cpp \ | 147 | ipc.cpp \ |
146 | libgcryptif.cpp \ | 148 | libgcryptif.cpp \ |
147 | listobjselectwnd.cpp \ | 149 | listobjselectwnd.cpp \ |
148 | listviewpwm.cpp \ | 150 | listviewpwm.cpp \ |
149 | main.cpp \ | 151 | main.cpp \ |
150 | pwgenwnd_emb.cpp \ | 152 | pwgenwnd_emb.cpp \ |
151 | pwgenwndimpl.cpp \ | 153 | pwgenwndimpl.cpp \ |
152 | pwm.cpp \ | 154 | pwm.cpp \ |
153 | pwmdoc.cpp \ | 155 | pwmdoc.cpp \ |
154 | pwmdocui.cpp \ | 156 | pwmdocui.cpp \ |
155 | pwmexception.cpp \ | 157 | pwmexception.cpp \ |
156 | pwminit.cpp \ | 158 | pwminit.cpp \ |
157 | pwmprefs.cpp \ | 159 | pwmprefs.cpp \ |
158 | pwmtray.cpp \ | 160 | pwmtray.cpp \ |
159 | pwmview.cpp \ | 161 | pwmview.cpp \ |
160 | pwmviewstyle_0.cpp \ | 162 | pwmviewstyle_0.cpp \ |
161 | pwmviewstyle_1.cpp \ | 163 | pwmviewstyle_1.cpp \ |
162 | pwmviewstyle.cpp \ | 164 | pwmviewstyle.cpp \ |
163 | randomizer.cpp \ | 165 | randomizer.cpp \ |
164 | rc2.cpp \ | 166 | rc2.cpp \ |
165 | rencatwnd.cpp \ | 167 | rencatwnd.cpp \ |
166 | serializer.cpp \ | 168 | serializer.cpp \ |
167 | setmasterpwwnd_emb.cpp \ | 169 | setmasterpwwnd_emb.cpp \ |
diff --git a/pwmanager/pwmanager/pwmanagerE.pro b/pwmanager/pwmanager/pwmanagerE.pro index e195178..6b68514 100644 --- a/pwmanager/pwmanager/pwmanagerE.pro +++ b/pwmanager/pwmanager/pwmanagerE.pro | |||
@@ -36,64 +36,65 @@ LIBS += $(GCC3EXTRALIB2) | |||
36 | #configwnd.ui \ | 36 | #configwnd.ui \ |
37 | #findwnd.ui \ | 37 | #findwnd.ui \ |
38 | #getmasterpwwnd.ui \ | 38 | #getmasterpwwnd.ui \ |
39 | #pwgenwnd.ui \ | 39 | #pwgenwnd.ui \ |
40 | #setmasterpwwnd.ui \ | 40 | #setmasterpwwnd.ui \ |
41 | #subtbledit.ui | 41 | #subtbledit.ui |
42 | 42 | ||
43 | #INTERFACES = \ | 43 | #INTERFACES = \ |
44 | #subtbledit.ui \ | 44 | #subtbledit.ui \ |
45 | 45 | ||
46 | 46 | ||
47 | 47 | ||
48 | #HEADERS = \ | 48 | #HEADERS = \ |
49 | #configuration_31compat.h \ | 49 | #configuration_31compat.h \ |
50 | #configuration.h \ | 50 | #configuration.h \ |
51 | #configwnd.h \ | 51 | #configwnd.h \ |
52 | #configwndimpl.h \ | 52 | #configwndimpl.h \ |
53 | #selftest.h | 53 | #selftest.h |
54 | #subtbledit.h \ | 54 | #subtbledit.h \ |
55 | #subtbleditimpl.h \ | 55 | #subtbleditimpl.h \ |
56 | #compressbzip2.h \ | 56 | #compressbzip2.h \ |
57 | 57 | ||
58 | HEADERS = \ | 58 | HEADERS = \ |
59 | addentrywnd_emb.h \ | 59 | addentrywnd_emb.h \ |
60 | addentrywndimpl.h \ | 60 | addentrywndimpl.h \ |
61 | base64.h \ | 61 | base64.h \ |
62 | binentrygen.h \ | 62 | binentrygen.h \ |
63 | blowfish.h \ | 63 | blowfish.h \ |
64 | commentbox.h \ | 64 | commentbox.h \ |
65 | compiler.h \ | 65 | compiler.h \ |
66 | compressgzip.h \ | 66 | compressgzip.h \ |
67 | csv.h \ | 67 | csv.h \ |
68 | editcategory.h \ | ||
68 | findwnd_emb.h \ | 69 | findwnd_emb.h \ |
69 | findwndimpl.h \ | 70 | findwndimpl.h \ |
70 | genpasswd.h \ | 71 | genpasswd.h \ |
71 | getkeycardwnd.h \ | 72 | getkeycardwnd.h \ |
72 | getmasterpwwnd_emb.h \ | 73 | getmasterpwwnd_emb.h \ |
73 | getmasterpwwndimpl.h \ | 74 | getmasterpwwndimpl.h \ |
74 | globalstuff.h \ | 75 | globalstuff.h \ |
75 | gpasmanfile.h \ | 76 | gpasmanfile.h \ |
76 | htmlgen.h \ | 77 | htmlgen.h \ |
77 | htmlparse.h \ | 78 | htmlparse.h \ |
78 | ipc.h \ | 79 | ipc.h \ |
79 | libgcryptif.h \ | 80 | libgcryptif.h \ |
80 | listobjselectwnd.h \ | 81 | listobjselectwnd.h \ |
81 | listviewpwm.h \ | 82 | listviewpwm.h \ |
82 | printtext.h \ | 83 | printtext.h \ |
83 | pwgenwnd_emb.h \ | 84 | pwgenwnd_emb.h \ |
84 | pwgenwndimpl.h \ | 85 | pwgenwndimpl.h \ |
85 | pwmdoc.h \ | 86 | pwmdoc.h \ |
86 | pwmdocui.h \ | 87 | pwmdocui.h \ |
87 | pwmexception.h \ | 88 | pwmexception.h \ |
88 | pwm.h \ | 89 | pwm.h \ |
89 | pwminit.h \ | 90 | pwminit.h \ |
90 | pwmprefs.h \ | 91 | pwmprefs.h \ |
91 | pwmprint.h \ | 92 | pwmprint.h \ |
92 | pwmtray.h \ | 93 | pwmtray.h \ |
93 | pwmview.h \ | 94 | pwmview.h \ |
94 | pwmviewstyle_0.h \ | 95 | pwmviewstyle_0.h \ |
95 | pwmviewstyle_1.h \ | 96 | pwmviewstyle_1.h \ |
96 | pwmviewstyle.h \ | 97 | pwmviewstyle.h \ |
97 | randomizer.h \ | 98 | randomizer.h \ |
98 | rc2.h \ | 99 | rc2.h \ |
99 | rencatwnd.h \ | 100 | rencatwnd.h \ |
@@ -102,64 +103,65 @@ setmasterpwwnd_emb.h \ | |||
102 | setmasterpwwndimpl.h \ | 103 | setmasterpwwndimpl.h \ |
103 | sha1.h \ | 104 | sha1.h \ |
104 | waitwnd.h \ | 105 | waitwnd.h \ |
105 | kcmconfigs/kcmpwmconfig.h \ | 106 | kcmconfigs/kcmpwmconfig.h \ |
106 | kcmconfigs/pwmconfigwidget.h | 107 | kcmconfigs/pwmconfigwidget.h |
107 | 108 | ||
108 | #sources that need not be build | 109 | #sources that need not be build |
109 | #SOURCES = \ | 110 | #SOURCES = \ |
110 | #advcommeditimpl.cpp \ | 111 | #advcommeditimpl.cpp \ |
111 | #configuration.cpp \ | 112 | #configuration.cpp \ |
112 | #configwnd.cpp \ | 113 | #configwnd.cpp \ |
113 | #configwndimpl.cpp \ | 114 | #configwndimpl.cpp \ |
114 | #configuration_31compat.cpp \ | 115 | #configuration_31compat.cpp \ |
115 | #htmlparse.cpp \ | 116 | #htmlparse.cpp \ |
116 | #printtext.cpp \ | 117 | #printtext.cpp \ |
117 | #selftest.cpp \ | 118 | #selftest.cpp \ |
118 | #pwmprint.cpp \ | 119 | #pwmprint.cpp \ |
119 | #spinforsignal.cpp | 120 | #spinforsignal.cpp |
120 | #subtbledit.cpp \ | 121 | #subtbledit.cpp \ |
121 | #subtbleditimpl.cpp \ | 122 | #subtbleditimpl.cpp \ |
122 | #compressbzip2.cpp | 123 | #compressbzip2.cpp |
123 | 124 | ||
124 | 125 | ||
125 | SOURCES = \ | 126 | SOURCES = \ |
126 | addentrywnd_emb.cpp \ | 127 | addentrywnd_emb.cpp \ |
127 | addentrywndimpl.cpp \ | 128 | addentrywndimpl.cpp \ |
128 | base64.cpp \ | 129 | base64.cpp \ |
129 | binentrygen.cpp \ | 130 | binentrygen.cpp \ |
130 | blowfish.cpp \ | 131 | blowfish.cpp \ |
131 | commentbox.cpp \ | 132 | commentbox.cpp \ |
132 | compressgzip.cpp \ | 133 | compressgzip.cpp \ |
133 | csv.cpp \ | 134 | csv.cpp \ |
135 | editcategory.cpp \ | ||
134 | findwnd_emb.cpp \ | 136 | findwnd_emb.cpp \ |
135 | findwndimpl.cpp \ | 137 | findwndimpl.cpp \ |
136 | genpasswd.cpp \ | 138 | genpasswd.cpp \ |
137 | getkeycardwnd.cpp \ | 139 | getkeycardwnd.cpp \ |
138 | getmasterpwwnd_emb.cpp \ | 140 | getmasterpwwnd_emb.cpp \ |
139 | getmasterpwwndimpl.cpp \ | 141 | getmasterpwwndimpl.cpp \ |
140 | globalstuff.cpp \ | 142 | globalstuff.cpp \ |
141 | gpasmanfile.cpp \ | 143 | gpasmanfile.cpp \ |
142 | htmlgen.cpp \ | 144 | htmlgen.cpp \ |
143 | ipc.cpp \ | 145 | ipc.cpp \ |
144 | libgcryptif.cpp \ | 146 | libgcryptif.cpp \ |
145 | listobjselectwnd.cpp \ | 147 | listobjselectwnd.cpp \ |
146 | listviewpwm.cpp \ | 148 | listviewpwm.cpp \ |
147 | main.cpp \ | 149 | main.cpp \ |
148 | pwgenwnd_emb.cpp \ | 150 | pwgenwnd_emb.cpp \ |
149 | pwgenwndimpl.cpp \ | 151 | pwgenwndimpl.cpp \ |
150 | pwm.cpp \ | 152 | pwm.cpp \ |
151 | pwmdoc.cpp \ | 153 | pwmdoc.cpp \ |
152 | pwmdocui.cpp \ | 154 | pwmdocui.cpp \ |
153 | pwmexception.cpp \ | 155 | pwmexception.cpp \ |
154 | pwminit.cpp \ | 156 | pwminit.cpp \ |
155 | pwmprefs.cpp \ | 157 | pwmprefs.cpp \ |
156 | pwmtray.cpp \ | 158 | pwmtray.cpp \ |
157 | pwmview.cpp \ | 159 | pwmview.cpp \ |
158 | pwmviewstyle_0.cpp \ | 160 | pwmviewstyle_0.cpp \ |
159 | pwmviewstyle_1.cpp \ | 161 | pwmviewstyle_1.cpp \ |
160 | pwmviewstyle.cpp \ | 162 | pwmviewstyle.cpp \ |
161 | randomizer.cpp \ | 163 | randomizer.cpp \ |
162 | rc2.cpp \ | 164 | rc2.cpp \ |
163 | rencatwnd.cpp \ | 165 | rencatwnd.cpp \ |
164 | serializer.cpp \ | 166 | serializer.cpp \ |
165 | setmasterpwwnd_emb.cpp \ | 167 | setmasterpwwnd_emb.cpp \ |
diff --git a/pwmanager/pwmanager/pwmdoc.cpp b/pwmanager/pwmanager/pwmdoc.cpp index 9043acc..ddbf4f2 100644 --- a/pwmanager/pwmanager/pwmdoc.cpp +++ b/pwmanager/pwmanager/pwmdoc.cpp | |||
@@ -1023,64 +1023,67 @@ PwMerror PwMDoc::addEntry(const QString &category, PwMDataItem *d, | |||
1023 | return e_entryExists; | 1023 | return e_entryExists; |
1024 | } | 1024 | } |
1025 | 1025 | ||
1026 | d->listViewPos = -1; | 1026 | d->listViewPos = -1; |
1027 | d->lockStat = conf()->confGlobNewEntrLockStat(); | 1027 | d->lockStat = conf()->confGlobNewEntrLockStat(); |
1028 | if (updateMeta) { | 1028 | if (updateMeta) { |
1029 | d->meta.create = QDateTime::currentDateTime(); | 1029 | d->meta.create = QDateTime::currentDateTime(); |
1030 | d->meta.update = d->meta.create; | 1030 | d->meta.update = d->meta.create; |
1031 | } | 1031 | } |
1032 | dti.dta[cat].d.push_back(*d); | 1032 | dti.dta[cat].d.push_back(*d); |
1033 | 1033 | ||
1034 | delAllEmptyCat(true); | 1034 | delAllEmptyCat(true); |
1035 | 1035 | ||
1036 | if (!dontFlagDirty) | 1036 | if (!dontFlagDirty) |
1037 | flagDirty(); | 1037 | flagDirty(); |
1038 | return e_success; | 1038 | return e_success; |
1039 | } | 1039 | } |
1040 | 1040 | ||
1041 | PwMerror PwMDoc::addCategory(const QString &category, unsigned int *categoryIndex, | 1041 | PwMerror PwMDoc::addCategory(const QString &category, unsigned int *categoryIndex, |
1042 | bool checkIfExist) | 1042 | bool checkIfExist) |
1043 | { | 1043 | { |
1044 | if (isDeepLocked()) { | 1044 | if (isDeepLocked()) { |
1045 | PwMerror ret; | 1045 | PwMerror ret; |
1046 | ret = deepLock(false); | 1046 | ret = deepLock(false); |
1047 | if (ret != e_success) | 1047 | if (ret != e_success) |
1048 | return e_lock; | 1048 | return e_lock; |
1049 | } | 1049 | } |
1050 | if (checkIfExist) { | 1050 | if (checkIfExist) { |
1051 | if (findCategory(category, categoryIndex)) | 1051 | if (findCategory(category, categoryIndex)) |
1052 | return e_categoryExists; | 1052 | return e_categoryExists; |
1053 | } | 1053 | } |
1054 | PwMCategoryItem item; | 1054 | PwMCategoryItem item; |
1055 | //US ENH: clear item to initialize with default values, or create a constructor | ||
1056 | item.clear(); | ||
1057 | |||
1055 | item.name = category.latin1(); | 1058 | item.name = category.latin1(); |
1056 | dti.dta.push_back(item); | 1059 | dti.dta.push_back(item); |
1057 | if (categoryIndex) | 1060 | if (categoryIndex) |
1058 | *categoryIndex = dti.dta.size() - 1; | 1061 | *categoryIndex = dti.dta.size() - 1; |
1059 | return e_success; | 1062 | return e_success; |
1060 | } | 1063 | } |
1061 | 1064 | ||
1062 | bool PwMDoc::delEntry(const QString &category, unsigned int index, bool dontFlagDirty) | 1065 | bool PwMDoc::delEntry(const QString &category, unsigned int index, bool dontFlagDirty) |
1063 | { | 1066 | { |
1064 | unsigned int cat = 0; | 1067 | unsigned int cat = 0; |
1065 | 1068 | ||
1066 | if (!findCategory(category, &cat)) { | 1069 | if (!findCategory(category, &cat)) { |
1067 | BUG(); | 1070 | BUG(); |
1068 | return false; | 1071 | return false; |
1069 | } | 1072 | } |
1070 | 1073 | ||
1071 | return delEntry(cat, index, dontFlagDirty); | 1074 | return delEntry(cat, index, dontFlagDirty); |
1072 | } | 1075 | } |
1073 | 1076 | ||
1074 | bool PwMDoc::delEntry(unsigned int category, unsigned int index, bool dontFlagDirty) | 1077 | bool PwMDoc::delEntry(unsigned int category, unsigned int index, bool dontFlagDirty) |
1075 | { | 1078 | { |
1076 | if (isDeepLocked()) | 1079 | if (isDeepLocked()) |
1077 | return false; | 1080 | return false; |
1078 | if (index > dti.dta[category].d.size() - 1) | 1081 | if (index > dti.dta[category].d.size() - 1) |
1079 | return false; | 1082 | return false; |
1080 | getDataChangedLock(); | 1083 | getDataChangedLock(); |
1081 | if (!lockAt(category, index, false)) { | 1084 | if (!lockAt(category, index, false)) { |
1082 | putDataChangedLock(); | 1085 | putDataChangedLock(); |
1083 | return false; | 1086 | return false; |
1084 | } | 1087 | } |
1085 | putDataChangedLock(); | 1088 | putDataChangedLock(); |
1086 | int lvPos = dti.dta[category].d[index].listViewPos; | 1089 | int lvPos = dti.dta[category].d[index].listViewPos; |
@@ -1851,64 +1854,66 @@ PwMerror PwMDoc::deepLock(bool lock, bool saveToFile) | |||
1851 | lockAt(DEFAULT_CATEGORY, 0, true); | 1854 | lockAt(DEFAULT_CATEGORY, 0, true); |
1852 | unsetDocStatFlag(DOC_STAT_DISK_DIRTY); | 1855 | unsetDocStatFlag(DOC_STAT_DISK_DIRTY); |
1853 | setDocStatFlag(DOC_STAT_DEEPLOCKED); | 1856 | setDocStatFlag(DOC_STAT_DEEPLOCKED); |
1854 | } else { | 1857 | } else { |
1855 | if (!isDeepLocked()) | 1858 | if (!isDeepLocked()) |
1856 | return e_lock; | 1859 | return e_lock; |
1857 | ret = openDoc(&filename, (conf()->confGlobUnlockOnOpen()) | 1860 | ret = openDoc(&filename, (conf()->confGlobUnlockOnOpen()) |
1858 | ? 0 : 1); | 1861 | ? 0 : 1); |
1859 | if (ret == e_wrongPw) { | 1862 | if (ret == e_wrongPw) { |
1860 | return e_wrongPw; | 1863 | return e_wrongPw; |
1861 | } else if (ret != e_success) { | 1864 | } else if (ret != e_success) { |
1862 | printDebug(string("PwMDoc::deepLock(false): ERR! openDoc() == ") | 1865 | printDebug(string("PwMDoc::deepLock(false): ERR! openDoc() == ") |
1863 | + tostr(static_cast<int>(ret))); | 1866 | + tostr(static_cast<int>(ret))); |
1864 | return e_lock; | 1867 | return e_lock; |
1865 | } | 1868 | } |
1866 | unsetDocStatFlag(DOC_STAT_DEEPLOCKED); | 1869 | unsetDocStatFlag(DOC_STAT_DEEPLOCKED); |
1867 | timer()->start(DocTimer::id_autoLockTimer); | 1870 | timer()->start(DocTimer::id_autoLockTimer); |
1868 | } | 1871 | } |
1869 | 1872 | ||
1870 | emitDataChanged(this); | 1873 | emitDataChanged(this); |
1871 | return e_success; | 1874 | return e_success; |
1872 | } | 1875 | } |
1873 | 1876 | ||
1874 | void PwMDoc::_deepUnlock() | 1877 | void PwMDoc::_deepUnlock() |
1875 | { | 1878 | { |
1876 | deepLock(false); | 1879 | deepLock(false); |
1877 | } | 1880 | } |
1878 | 1881 | ||
1879 | void PwMDoc::clearDoc() | 1882 | void PwMDoc::clearDoc() |
1880 | { | 1883 | { |
1881 | dti.clear(); | 1884 | dti.clear(); |
1882 | PwMCategoryItem d; | 1885 | PwMCategoryItem d; |
1886 | //US ENH: to initialize all members with meaningfull data. | ||
1887 | d.clear(); | ||
1883 | d.name = DEFAULT_CATEGORY.latin1(); | 1888 | d.name = DEFAULT_CATEGORY.latin1(); |
1884 | dti.dta.push_back(d); | 1889 | dti.dta.push_back(d); |
1885 | currentPw = ""; | 1890 | currentPw = ""; |
1886 | unsetDocStatFlag(DOC_STAT_UNLOCK_WITHOUT_PW); | 1891 | unsetDocStatFlag(DOC_STAT_UNLOCK_WITHOUT_PW); |
1887 | } | 1892 | } |
1888 | 1893 | ||
1889 | void PwMDoc::changeCurrentPw() | 1894 | void PwMDoc::changeCurrentPw() |
1890 | { | 1895 | { |
1891 | if (currentPw == "") | 1896 | if (currentPw == "") |
1892 | return; // doc hasn't been saved. No mpw available. | 1897 | return; // doc hasn't been saved. No mpw available. |
1893 | bool useChipcard = getDocStatFlag(DOC_STAT_USE_CHIPCARD); | 1898 | bool useChipcard = getDocStatFlag(DOC_STAT_USE_CHIPCARD); |
1894 | QString pw = requestMpwChange(¤tPw, &useChipcard); | 1899 | QString pw = requestMpwChange(¤tPw, &useChipcard); |
1895 | if (pw == "") | 1900 | if (pw == "") |
1896 | return; | 1901 | return; |
1897 | if (useChipcard) | 1902 | if (useChipcard) |
1898 | setDocStatFlag(DOC_STAT_USE_CHIPCARD); | 1903 | setDocStatFlag(DOC_STAT_USE_CHIPCARD); |
1899 | else | 1904 | else |
1900 | unsetDocStatFlag(DOC_STAT_USE_CHIPCARD); | 1905 | unsetDocStatFlag(DOC_STAT_USE_CHIPCARD); |
1901 | setCurrentPw(pw); | 1906 | setCurrentPw(pw); |
1902 | } | 1907 | } |
1903 | 1908 | ||
1904 | void PwMDoc::setListViewPos(const QString &category, unsigned int index, | 1909 | void PwMDoc::setListViewPos(const QString &category, unsigned int index, |
1905 | int pos) | 1910 | int pos) |
1906 | { | 1911 | { |
1907 | unsigned int cat = 0; | 1912 | unsigned int cat = 0; |
1908 | 1913 | ||
1909 | if (!findCategory(category, &cat)) { | 1914 | if (!findCategory(category, &cat)) { |
1910 | BUG(); | 1915 | BUG(); |
1911 | return; | 1916 | return; |
1912 | } | 1917 | } |
1913 | setListViewPos(cat, index, pos); | 1918 | setListViewPos(cat, index, pos); |
1914 | } | 1919 | } |
diff --git a/pwmanager/pwmanager/pwmdoc.h b/pwmanager/pwmanager/pwmdoc.h index 09923ab..ef81dfc 100644 --- a/pwmanager/pwmanager/pwmdoc.h +++ b/pwmanager/pwmanager/pwmdoc.h | |||
@@ -224,68 +224,77 @@ struct PwMDataItem | |||
224 | //all other field will not be checked. | 224 | //all other field will not be checked. |
225 | return true; | 225 | return true; |
226 | } | 226 | } |
227 | 227 | ||
228 | //US ENH: this sync method actually copies all values from the parameter like the =operator | 228 | //US ENH: this sync method actually copies all values from the parameter like the =operator |
229 | //does with two exceptions: listViewPos will not be changed, and the launcher only if required. | 229 | //does with two exceptions: listViewPos will not be changed, and the launcher only if required. |
230 | bool PwMDataItem::syncItem(const PwMDataItem &a, bool syncLauncher=true ) | 230 | bool PwMDataItem::syncItem(const PwMDataItem &a, bool syncLauncher=true ) |
231 | { | 231 | { |
232 | desc = a.desc; | 232 | desc = a.desc; |
233 | name = a.name; | 233 | name = a.name; |
234 | pw = a.pw; | 234 | pw = a.pw; |
235 | comment = a.comment; | 235 | comment = a.comment; |
236 | url = a.url; | 236 | url = a.url; |
237 | if (syncLauncher == true) | 237 | if (syncLauncher == true) |
238 | launcher = a.launcher; | 238 | launcher = a.launcher; |
239 | meta = a.meta; | 239 | meta = a.meta; |
240 | binary = a.binary; | 240 | binary = a.binary; |
241 | lockStat = a.lockStat; | 241 | lockStat = a.lockStat; |
242 | rev = a.rev; | 242 | rev = a.rev; |
243 | 243 | ||
244 | return true; | 244 | return true; |
245 | } | 245 | } |
246 | 246 | ||
247 | }; | 247 | }; |
248 | 248 | ||
249 | struct PwMCategoryItem | 249 | struct PwMCategoryItem |
250 | { | 250 | { |
251 | /** all PwMDataItems (all passwords) within this category */ | 251 | /** all PwMDataItems (all passwords) within this category */ |
252 | vector<PwMDataItem>d; | 252 | vector<PwMDataItem>d; |
253 | /** category name/description */ | 253 | /** category name/description */ |
254 | string name; | 254 | string name; |
255 | 255 | ||
256 | //US ENH: enhancements of the filestructure | ||
257 | /* each category stores the text for description,name and password */ | ||
258 | string desc_text; | ||
259 | string name_text; | ||
260 | string pw_text; | ||
261 | |||
256 | void clear() | 262 | void clear() |
257 | { | 263 | { |
258 | d.clear(); | 264 | d.clear(); |
259 | name = ""; | 265 | name = ""; |
266 | desc_text = "Description"; | ||
267 | name_text = "Username"; | ||
268 | pw_text = "Password"; | ||
260 | } | 269 | } |
261 | }; | 270 | }; |
262 | 271 | ||
263 | struct PwMSyncItem | 272 | struct PwMSyncItem |
264 | { | 273 | { |
265 | string syncName; | 274 | string syncName; |
266 | QDateTime lastSyncDate; | 275 | QDateTime lastSyncDate; |
267 | 276 | ||
268 | void clear() | 277 | void clear() |
269 | { | 278 | { |
270 | lastSyncDate = QDateTime(); | 279 | lastSyncDate = QDateTime(); |
271 | syncName = ""; | 280 | syncName = ""; |
272 | } | 281 | } |
273 | }; | 282 | }; |
274 | 283 | ||
275 | struct PwMItem | 284 | struct PwMItem |
276 | { | 285 | { |
277 | vector<PwMCategoryItem> dta; | 286 | vector<PwMCategoryItem> dta; |
278 | vector<PwMSyncItem> syncDta; | 287 | vector<PwMSyncItem> syncDta; |
279 | 288 | ||
280 | void clear() | 289 | void clear() |
281 | { | 290 | { |
282 | dta.clear(); | 291 | dta.clear(); |
283 | syncDta.clear(); | 292 | syncDta.clear(); |
284 | } | 293 | } |
285 | }; | 294 | }; |
286 | 295 | ||
287 | 296 | ||
288 | /** "Function Object" for sort()ing PwMDataItem::listViewPos */ | 297 | /** "Function Object" for sort()ing PwMDataItem::listViewPos */ |
289 | class dta_lvp_greater | 298 | class dta_lvp_greater |
290 | { | 299 | { |
291 | public: | 300 | public: |
@@ -756,54 +765,59 @@ protected: | |||
756 | /** get a document status flag */ | 765 | /** get a document status flag */ |
757 | bool getDocStatFlag(unsigned int statFlag) const | 766 | bool getDocStatFlag(unsigned int statFlag) const |
758 | { return (curDocStat & statFlag); } | 767 | { return (curDocStat & statFlag); } |
759 | /** set the "currentPassword" */ | 768 | /** set the "currentPassword" */ |
760 | void setCurrentPw(const QString &pw) | 769 | void setCurrentPw(const QString &pw) |
761 | { | 770 | { |
762 | currentPw = pw; | 771 | currentPw = pw; |
763 | setDocStatFlag(DOC_STAT_DISK_DIRTY); | 772 | setDocStatFlag(DOC_STAT_DISK_DIRTY); |
764 | } | 773 | } |
765 | /** make a backup-copy of the given file */ | 774 | /** make a backup-copy of the given file */ |
766 | bool backupFile(const QString &filePath); | 775 | bool backupFile(const QString &filePath); |
767 | /** copy a file from src to dst */ | 776 | /** copy a file from src to dst */ |
768 | bool copyFile(const QString &src, const QString &dst); | 777 | bool copyFile(const QString &src, const QString &dst); |
769 | 778 | ||
770 | 779 | ||
771 | public: | 780 | public: |
772 | #ifdef PWM_EMBEDDED | 781 | #ifdef PWM_EMBEDDED |
773 | //US ENH: this is the magic function that syncronizes the local doc with the remote doc. | 782 | //US ENH: this is the magic function that syncronizes the local doc with the remote doc. |
774 | PwMerror syncronize(KSyncManager* manager, PwMDoc* syncLocal, PwMDoc* syncRemote, int mode ); | 783 | PwMerror syncronize(KSyncManager* manager, PwMDoc* syncLocal, PwMDoc* syncRemote, int mode ); |
775 | 784 | ||
776 | //takePwMDataItem returns the following values | 785 | //takePwMDataItem returns the following values |
777 | // 0 equal | 786 | // 0 equal |
778 | // 1 take local | 787 | // 1 take local |
779 | // 2 take remote | 788 | // 2 take remote |
780 | // 3 cancel | 789 | // 3 cancel |
781 | int takePwMDataItem( PwMDataItem* local, PwMDataItem* remote, QDateTime lastSync, int mode , bool full ); | 790 | int takePwMDataItem( PwMDataItem* local, PwMDataItem* remote, QDateTime lastSync, int mode , bool full ); |
782 | 791 | ||
783 | //the following methods are the overwritten callbackmethods from the syncinterface | 792 | //the following methods are the overwritten callbackmethods from the syncinterface |
784 | virtual bool sync(KSyncManager* manager, QString filename, int mode); | 793 | virtual bool sync(KSyncManager* manager, QString filename, int mode); |
785 | virtual void removeSyncInfo( QString syncProfile); | 794 | virtual void removeSyncInfo( QString syncProfile); |
786 | 795 | ||
787 | #endif | 796 | #endif |
797 | //US ENH: helpermethods to return a whole category entry | ||
798 | /** returns a pointer to the categoryitem */ | ||
799 | PwMCategoryItem* getCategoryEntry(unsigned int index) | ||
800 | { return &(dti.dta[index]); } | ||
801 | |||
788 | private: | 802 | private: |
789 | //US ENH: helpermethods to access the sync data for a certain syncname. | 803 | //US ENH: helpermethods to access the sync data for a certain syncname. |
790 | // It returns the syncdatas index | 804 | // It returns the syncdatas index |
791 | bool findSyncData(const QString &syncname, unsigned int *index); | 805 | bool findSyncData(const QString &syncname, unsigned int *index); |
792 | 806 | ||
793 | /** add new syncdataentry */ | 807 | /** add new syncdataentry */ |
794 | PwMerror addSyncDataEntry(PwMSyncItem *d, bool dontFlagDirty = false); | 808 | PwMerror addSyncDataEntry(PwMSyncItem *d, bool dontFlagDirty = false); |
795 | 809 | ||
796 | /** returns a pointer to the syncdata */ | 810 | /** returns a pointer to the syncdata */ |
797 | PwMSyncItem* getSyncDataEntry(unsigned int index) | 811 | PwMSyncItem* getSyncDataEntry(unsigned int index) |
798 | { return &(dti.syncDta[index]); } | 812 | { return &(dti.syncDta[index]); } |
799 | 813 | ||
800 | /** delete entry */ | 814 | /** delete entry */ |
801 | bool delSyncDataEntry(unsigned int index, bool dontFlagDirty = false); | 815 | bool delSyncDataEntry(unsigned int index, bool dontFlagDirty = false); |
802 | 816 | ||
803 | PwMDataItem* findEntryByID(const QString &uid, unsigned int *category, unsigned int *index); | 817 | PwMDataItem* findEntryByID(const QString &uid, unsigned int *category, unsigned int *index); |
804 | 818 | ||
805 | QStringList getIDEntryList(); | 819 | QStringList getIDEntryList(); |
806 | 820 | ||
807 | }; | 821 | }; |
808 | 822 | ||
809 | #endif | 823 | #endif |
diff --git a/pwmanager/pwmanager/pwmview.cpp b/pwmanager/pwmanager/pwmview.cpp index 5aaf66e..7733028 100644 --- a/pwmanager/pwmanager/pwmview.cpp +++ b/pwmanager/pwmanager/pwmview.cpp | |||
@@ -231,64 +231,74 @@ void PwMView::shiftToView() | |||
231 | commentBox->clear(); | 231 | commentBox->clear(); |
232 | 232 | ||
233 | unsigned int catDocIndex; | 233 | unsigned int catDocIndex; |
234 | if (unlikely( | 234 | if (unlikely( |
235 | !(document()->findCategory(getCurrentCategory(), | 235 | !(document()->findCategory(getCurrentCategory(), |
236 | &catDocIndex)))) { | 236 | &catDocIndex)))) { |
237 | BUG(); | 237 | BUG(); |
238 | } | 238 | } |
239 | 239 | ||
240 | // ensure all listViewPos are set | 240 | // ensure all listViewPos are set |
241 | doc->ensureLvp(); | 241 | doc->ensureLvp(); |
242 | 242 | ||
243 | // clear all tmp-data vectors | 243 | // clear all tmp-data vectors |
244 | unsigned int i, entries = doc->numEntries(catDocIndex); | 244 | unsigned int i, entries = doc->numEntries(catDocIndex); |
245 | if (entries) { | 245 | if (entries) { |
246 | mainClass->setVirgin(false); | 246 | mainClass->setVirgin(false); |
247 | } | 247 | } |
248 | vector<PwMDataItem> tmpSorted; | 248 | vector<PwMDataItem> tmpSorted; |
249 | PwMDataItem currItem; | 249 | PwMDataItem currItem; |
250 | currItem.clear(); | 250 | currItem.clear(); |
251 | tmpSorted.insert(tmpSorted.begin(), entries, currItem); | 251 | tmpSorted.insert(tmpSorted.begin(), entries, currItem); |
252 | 252 | ||
253 | // Sort items and store them in tempoary tmpSorted. | 253 | // Sort items and store them in tempoary tmpSorted. |
254 | for (i = 0; i < entries; ++i) { | 254 | for (i = 0; i < entries; ++i) { |
255 | doc->getEntry(catDocIndex, i, &currItem); | 255 | doc->getEntry(catDocIndex, i, &currItem); |
256 | //qDebug("PwMView::shiftToView: %s, %i", currItem.desc.c_str(), currItem.listViewPos); | 256 | //qDebug("PwMView::shiftToView: %s, %i", currItem.desc.c_str(), currItem.listViewPos); |
257 | tmpSorted[currItem.listViewPos] = currItem; | 257 | tmpSorted[currItem.listViewPos] = currItem; |
258 | } | 258 | } |
259 | 259 | ||
260 | // shift tempoary data to ListView. | 260 | // shift tempoary data to ListView. |
261 | tmpDisableSort(); | 261 | tmpDisableSort(); |
262 | lv->clear(); | 262 | lv->clear(); |
263 | |||
264 | //US ENH: adjust the headers of the table according the category texts | ||
265 | { | ||
266 | PwMCategoryItem* catItem = doc->getCategoryEntry(catDocIndex); | ||
267 | // qDebug("PwMView::ShiftToView CAT: %i, %s", catDocIndex, catItem->name.c_str()); | ||
268 | lv->setColumnText(COLUMN_DESC, catItem->desc_text.c_str()); | ||
269 | lv->setColumnText(COLUMN_NAME, catItem->name_text.c_str()); | ||
270 | lv->setColumnText(COLUMN_PW, catItem->pw_text.c_str()); | ||
271 | } | ||
272 | |||
263 | QCheckListItem *newItem; | 273 | QCheckListItem *newItem; |
264 | vector<PwMDataItem>::iterator it = tmpSorted.begin(), | 274 | vector<PwMDataItem>::iterator it = tmpSorted.begin(), |
265 | end = tmpSorted.end(); | 275 | end = tmpSorted.end(); |
266 | while (it != end) { | 276 | while (it != end) { |
267 | newItem = new ListViewItemPwM(lv); | 277 | newItem = new ListViewItemPwM(lv); |
268 | newItem->setText(COLUMN_DESC, (*it).desc.c_str()); | 278 | newItem->setText(COLUMN_DESC, (*it).desc.c_str()); |
269 | if ((*it).binary) { | 279 | if ((*it).binary) { |
270 | newItem->setText(COLUMN_NAME, ""); | 280 | newItem->setText(COLUMN_NAME, ""); |
271 | newItem->setText(COLUMN_PW, i18n("<BINARY ENTRY>")); | 281 | newItem->setText(COLUMN_PW, i18n("<BINARY ENTRY>")); |
272 | newItem->setText(COLUMN_URL, ""); | 282 | newItem->setText(COLUMN_URL, ""); |
273 | newItem->setText(COLUMN_LAUNCHER, (*it).launcher.c_str()); | 283 | newItem->setText(COLUMN_LAUNCHER, (*it).launcher.c_str()); |
274 | } else { | 284 | } else { |
275 | newItem->setText(COLUMN_NAME, (*it).name.c_str()); | 285 | newItem->setText(COLUMN_NAME, (*it).name.c_str()); |
276 | if ((*it).lockStat) { | 286 | if ((*it).lockStat) { |
277 | newItem->setText(COLUMN_PW, QString((*it).pw.c_str()) | 287 | newItem->setText(COLUMN_PW, QString((*it).pw.c_str()) |
278 | + " " | 288 | + " " |
279 | + i18n("To unlock click the icon on the left.")); | 289 | + i18n("To unlock click the icon on the left.")); |
280 | } else { | 290 | } else { |
281 | newItem->setText(COLUMN_PW, (*it).pw.c_str()); | 291 | newItem->setText(COLUMN_PW, (*it).pw.c_str()); |
282 | } | 292 | } |
283 | newItem->setText(COLUMN_URL, (*it).url.c_str()); | 293 | newItem->setText(COLUMN_URL, (*it).url.c_str()); |
284 | newItem->setText(COLUMN_LAUNCHER, (*it).launcher.c_str()); | 294 | newItem->setText(COLUMN_LAUNCHER, (*it).launcher.c_str()); |
285 | } | 295 | } |
286 | newItem->setOn(!((*it).lockStat)); | 296 | newItem->setOn(!((*it).lockStat)); |
287 | lv->insertItem(newItem); | 297 | lv->insertItem(newItem); |
288 | ++it; | 298 | ++it; |
289 | } | 299 | } |
290 | tmpReEnableSort(); | 300 | tmpReEnableSort(); |
291 | 301 | ||
292 | if (cY || cX) | 302 | if (cY || cX) |
293 | lv->setContentsPos(cX, cY); | 303 | lv->setContentsPos(cX, cY); |
294 | } | 304 | } |
diff --git a/pwmanager/pwmanager/serializer.cpp b/pwmanager/pwmanager/serializer.cpp index 5753c1d..507fa30 100644 --- a/pwmanager/pwmanager/serializer.cpp +++ b/pwmanager/pwmanager/serializer.cpp | |||
@@ -10,133 +10,147 @@ | |||
10 | ***************************************************************************/ | 10 | ***************************************************************************/ |
11 | 11 | ||
12 | 12 | ||
13 | /*************************************************************************** | 13 | /*************************************************************************** |
14 | * copyright (C) 2004 by Ulf Schenk | 14 | * copyright (C) 2004 by Ulf Schenk |
15 | * This file is originaly based on version 1.1 of pwmanager | 15 | * This file is originaly based on version 1.1 of pwmanager |
16 | * and was modified to run on embedded devices that run microkde | 16 | * and was modified to run on embedded devices that run microkde |
17 | * | 17 | * |
18 | * $Id$ | 18 | * $Id$ |
19 | **************************************************************************/ | 19 | **************************************************************************/ |
20 | 20 | ||
21 | #include "serializer.h" | 21 | #include "serializer.h" |
22 | #include "pwmexception.h" | 22 | #include "pwmexception.h" |
23 | 23 | ||
24 | #ifdef PWM_EMBEDDED | 24 | #ifdef PWM_EMBEDDED |
25 | #include <kglobal.h> | 25 | #include <kglobal.h> |
26 | #include <klocale.h> | 26 | #include <klocale.h> |
27 | #endif | 27 | #endif |
28 | 28 | ||
29 | /* enable/disable serializer debugging (0/1) */ | 29 | /* enable/disable serializer debugging (0/1) */ |
30 | #define SERIALIZER_DEBUG0 | 30 | #define SERIALIZER_DEBUG0 |
31 | /* use the old xml tags for writing (0/1) */ | 31 | /* use the old xml tags for writing (0/1) */ |
32 | #define USE_OLD_TAGS 0 | 32 | #define USE_OLD_TAGS 0 |
33 | /* write a CDATA section (0/1) */ | 33 | /* write a CDATA section (0/1) */ |
34 | #define WRITE_CDATA_SEC 0 | 34 | #define WRITE_CDATA_SEC 0 |
35 | 35 | ||
36 | 36 | ||
37 | #define META_CREATE_DATE"c" | 37 | #define META_CREATE_DATE"c" |
38 | #define META_VALID_DATE "v" | 38 | #define META_VALID_DATE "v" |
39 | #define META_EXPIRE_DATE"e" | 39 | #define META_EXPIRE_DATE"e" |
40 | #define META_UPDATE_DATE"u" | 40 | #define META_UPDATE_DATE"u" |
41 | #define META_UPDATE_INT "i" | 41 | #define META_UPDATE_INT "i" |
42 | //US ENH : uniqueid | 42 | //US ENH : uniqueid and sync information |
43 | #define META_UNIQUEID "n" | 43 | #define META_UNIQUEID "n" |
44 | #define SYNC_ROOT "s" | 44 | #define SYNC_ROOT "s" |
45 | #define SYNC_TARGET_PREFIX "t" | 45 | #define SYNC_TARGET_PREFIX "t" |
46 | #define SYNC_TARGET_NAME "n" | 46 | #define SYNC_TARGET_NAME "n" |
47 | 47 | ||
48 | 48 | ||
49 | /* This is compatibility stuff. | 49 | /* This is compatibility stuff. |
50 | * The names of the entries have changed and here are the | 50 | * The names of the entries have changed and here are the |
51 | * new and old ones | 51 | * new and old ones |
52 | */ | 52 | */ |
53 | #define ROOT_MAGIC_OLD "PwM-xml-dat" | 53 | #define ROOT_MAGIC_OLD "PwM-xml-dat" |
54 | #define VER_STR_OLD "ver" | 54 | #define VER_STR_OLD "ver" |
55 | #define COMPAT_VER_OLD "0x02" | 55 | #define COMPAT_VER_OLD "0x02" |
56 | #define CAT_ROOT_OLD "categories" | 56 | #define CAT_ROOT_OLD "categories" |
57 | #define CAT_PREFIX_OLD "cat_" | 57 | #define CAT_PREFIX_OLD "cat_" |
58 | #define CAT_NAME_OLD "name" | 58 | #define CAT_NAME_OLD "name" |
59 | //US ENH : optional text for categories | ||
60 | #define CAT_TEXT_OLD "text" | ||
61 | |||
59 | #define ENTRY_PREFIX_OLD"entry_" | 62 | #define ENTRY_PREFIX_OLD"entry_" |
60 | #define ENTRY_DESC_OLD "desc" | 63 | #define ENTRY_DESC_OLD "desc" |
61 | #define ENTRY_NAME_OLD "name" | 64 | #define ENTRY_NAME_OLD "name" |
62 | #define ENTRY_PW_OLD "pw" | 65 | #define ENTRY_PW_OLD "pw" |
63 | #define ENTRY_COMMENT_OLD"comment" | 66 | #define ENTRY_COMMENT_OLD"comment" |
64 | #define ENTRY_URL_OLD "url" | 67 | #define ENTRY_URL_OLD "url" |
65 | #define ENTRY_LAUNCHER_OLD"launcher" | 68 | #define ENTRY_LAUNCHER_OLD"launcher" |
66 | #define ENTRY_LVP_OLD "listViewPos" | 69 | #define ENTRY_LVP_OLD "listViewPos" |
67 | #define ENTRY_BIN_OLD "b" | 70 | #define ENTRY_BIN_OLD "b" |
68 | #define ENTRY_META_OLD "m" | 71 | #define ENTRY_META_OLD "m" |
69 | 72 | ||
70 | #define ROOT_MAGIC_NEW "P" | 73 | #define ROOT_MAGIC_NEW "P" |
71 | #define VER_STR_NEW "v" | 74 | #define VER_STR_NEW "v" |
72 | #define COMPAT_VER_NEW "2" | 75 | #define COMPAT_VER_NEW "2" |
73 | #define CAT_ROOT_NEW "c" | 76 | #define CAT_ROOT_NEW "c" |
74 | #define CAT_PREFIX_NEW "c" | 77 | #define CAT_PREFIX_NEW "c" |
75 | #define CAT_NAME_NEW "n" | 78 | #define CAT_NAME_NEW "n" |
79 | //US ENH : optional text for categories | ||
80 | #define CAT_TEXT_NEW "t" | ||
81 | |||
76 | #define ENTRY_PREFIX_NEW"e" | 82 | #define ENTRY_PREFIX_NEW"e" |
77 | #define ENTRY_DESC_NEW "d" | 83 | #define ENTRY_DESC_NEW "d" |
78 | #define ENTRY_NAME_NEW "n" | 84 | #define ENTRY_NAME_NEW "n" |
79 | #define ENTRY_PW_NEW "p" | 85 | #define ENTRY_PW_NEW "p" |
80 | #define ENTRY_COMMENT_NEW"c" | 86 | #define ENTRY_COMMENT_NEW"c" |
81 | #define ENTRY_URL_NEW "u" | 87 | #define ENTRY_URL_NEW "u" |
82 | #define ENTRY_LAUNCHER_NEW"l" | 88 | #define ENTRY_LAUNCHER_NEW"l" |
83 | #define ENTRY_LVP_NEW "v" | 89 | #define ENTRY_LVP_NEW "v" |
84 | #define ENTRY_BIN_NEW ENTRY_BIN_OLD | 90 | #define ENTRY_BIN_NEW ENTRY_BIN_OLD |
85 | #define ENTRY_META_NEW ENTRY_META_OLD | 91 | #define ENTRY_META_NEW ENTRY_META_OLD |
86 | 92 | ||
87 | #if USE_OLD_TAGS != 0 | 93 | #if USE_OLD_TAGS != 0 |
88 | # define ROOT_MAGIC_WR ROOT_MAGIC_OLD | 94 | # define ROOT_MAGIC_WR ROOT_MAGIC_OLD |
89 | # define VER_STR_WR VER_STR_OLD | 95 | # define VER_STR_WR VER_STR_OLD |
90 | # define COMPAT_VER_WR COMPAT_VER_OLD | 96 | # define COMPAT_VER_WR COMPAT_VER_OLD |
91 | # define CAT_ROOT_WR CAT_ROOT_OLD | 97 | # define CAT_ROOT_WR CAT_ROOT_OLD |
92 | # define CAT_PREFIX_WR CAT_PREFIX_OLD | 98 | # define CAT_PREFIX_WR CAT_PREFIX_OLD |
93 | # define CAT_NAME_WR CAT_NAME_OLD | 99 | # define CAT_NAME_WR CAT_NAME_OLD |
100 | |||
101 | //US ENH : optional text for categories | ||
102 | # define CAT_TEXT_WR CAT_TEXT_OLD | ||
103 | |||
94 | # define ENTRY_PREFIX_WRENTRY_PREFIX_OLD | 104 | # define ENTRY_PREFIX_WRENTRY_PREFIX_OLD |
95 | # define ENTRY_DESC_WR ENTRY_DESC_OLD | 105 | # define ENTRY_DESC_WR ENTRY_DESC_OLD |
96 | # define ENTRY_NAME_WR ENTRY_NAME_OLD | 106 | # define ENTRY_NAME_WR ENTRY_NAME_OLD |
97 | # define ENTRY_PW_WR ENTRY_PW_OLD | 107 | # define ENTRY_PW_WR ENTRY_PW_OLD |
98 | # define ENTRY_COMMENT_WRENTRY_COMMENT_OLD | 108 | # define ENTRY_COMMENT_WRENTRY_COMMENT_OLD |
99 | # define ENTRY_URL_WR ENTRY_URL_OLD | 109 | # define ENTRY_URL_WR ENTRY_URL_OLD |
100 | # define ENTRY_LAUNCHER_WRENTRY_LAUNCHER_OLD | 110 | # define ENTRY_LAUNCHER_WRENTRY_LAUNCHER_OLD |
101 | # define ENTRY_LVP_WR ENTRY_LVP_OLD | 111 | # define ENTRY_LVP_WR ENTRY_LVP_OLD |
102 | # define ENTRY_BIN_WR ENTRY_BIN_OLD | 112 | # define ENTRY_BIN_WR ENTRY_BIN_OLD |
103 | # define ENTRY_META_WR ENTRY_META_OLD | 113 | # define ENTRY_META_WR ENTRY_META_OLD |
104 | #else | 114 | #else |
105 | # define ROOT_MAGIC_WR ROOT_MAGIC_NEW | 115 | # define ROOT_MAGIC_WR ROOT_MAGIC_NEW |
106 | # define VER_STR_WR VER_STR_NEW | 116 | # define VER_STR_WR VER_STR_NEW |
107 | # define COMPAT_VER_WR COMPAT_VER_NEW | 117 | # define COMPAT_VER_WR COMPAT_VER_NEW |
108 | # define CAT_ROOT_WR CAT_ROOT_NEW | 118 | # define CAT_ROOT_WR CAT_ROOT_NEW |
109 | # define CAT_PREFIX_WR CAT_PREFIX_NEW | 119 | # define CAT_PREFIX_WR CAT_PREFIX_NEW |
110 | # define CAT_NAME_WR CAT_NAME_NEW | 120 | # define CAT_NAME_WR CAT_NAME_NEW |
121 | |||
122 | //US ENH : optional text for categories | ||
123 | # define CAT_TEXT_WR CAT_TEXT_NEW | ||
124 | |||
111 | # define ENTRY_PREFIX_WRENTRY_PREFIX_NEW | 125 | # define ENTRY_PREFIX_WRENTRY_PREFIX_NEW |
112 | # define ENTRY_DESC_WR ENTRY_DESC_NEW | 126 | # define ENTRY_DESC_WR ENTRY_DESC_NEW |
113 | # define ENTRY_NAME_WR ENTRY_NAME_NEW | 127 | # define ENTRY_NAME_WR ENTRY_NAME_NEW |
114 | # define ENTRY_PW_WR ENTRY_PW_NEW | 128 | # define ENTRY_PW_WR ENTRY_PW_NEW |
115 | # define ENTRY_COMMENT_WRENTRY_COMMENT_NEW | 129 | # define ENTRY_COMMENT_WRENTRY_COMMENT_NEW |
116 | # define ENTRY_URL_WR ENTRY_URL_NEW | 130 | # define ENTRY_URL_WR ENTRY_URL_NEW |
117 | # define ENTRY_LAUNCHER_WRENTRY_LAUNCHER_NEW | 131 | # define ENTRY_LAUNCHER_WRENTRY_LAUNCHER_NEW |
118 | # define ENTRY_LVP_WR ENTRY_LVP_NEW | 132 | # define ENTRY_LVP_WR ENTRY_LVP_NEW |
119 | # define ENTRY_BIN_WR ENTRY_BIN_NEW | 133 | # define ENTRY_BIN_WR ENTRY_BIN_NEW |
120 | # define ENTRY_META_WR ENTRY_META_NEW | 134 | # define ENTRY_META_WR ENTRY_META_NEW |
121 | #endif | 135 | #endif |
122 | 136 | ||
123 | 137 | ||
124 | Serializer::Serializer() | 138 | Serializer::Serializer() |
125 | { | 139 | { |
126 | defaultLockStat = true; | 140 | defaultLockStat = true; |
127 | //US BUG: I needed to specify a document name. Otherwise impl will not be created for serializing | 141 | //US BUG: I needed to specify a document name. Otherwise impl will not be created for serializing |
128 | #ifndef PWM_EMBEDDED | 142 | #ifndef PWM_EMBEDDED |
129 | domDoc = new QDomDocument; | 143 | domDoc = new QDomDocument; |
130 | #else | 144 | #else |
131 | domDoc = new QDomDocument("mydoc"); | 145 | domDoc = new QDomDocument("mydoc"); |
132 | #endif | 146 | #endif |
133 | } | 147 | } |
134 | 148 | ||
135 | Serializer::Serializer(const QCString &buffer) | 149 | Serializer::Serializer(const QCString &buffer) |
136 | { | 150 | { |
137 | defaultLockStat = true; | 151 | defaultLockStat = true; |
138 | //US BUG: I needed to specify a document name. Otherwise impl will not be created for serializing | 152 | //US BUG: I needed to specify a document name. Otherwise impl will not be created for serializing |
139 | #ifndef PWM_EMBEDDED | 153 | #ifndef PWM_EMBEDDED |
140 | domDoc = new QDomDocument; | 154 | domDoc = new QDomDocument; |
141 | #else | 155 | #else |
142 | domDoc = new QDomDocument("mydoc"); | 156 | domDoc = new QDomDocument("mydoc"); |
@@ -242,83 +256,101 @@ bool Serializer::deSerialize(PwMItem *dta) | |||
242 | for (n = root.firstChild(); !n.isNull(); n = n.nextSibling()) { | 256 | for (n = root.firstChild(); !n.isNull(); n = n.nextSibling()) { |
243 | // find <categories> ... </categories> | 257 | // find <categories> ... </categories> |
244 | // <c> ... </c> | 258 | // <c> ... </c> |
245 | if (n.nodeName() == CAT_ROOT_NEW || | 259 | if (n.nodeName() == CAT_ROOT_NEW || |
246 | n.nodeName() == CAT_ROOT_OLD) { | 260 | n.nodeName() == CAT_ROOT_OLD) { |
247 | if (!readCategories(n, &(dta->dta))) { | 261 | if (!readCategories(n, &(dta->dta))) { |
248 | return false; | 262 | return false; |
249 | } | 263 | } |
250 | continue; | 264 | continue; |
251 | } | 265 | } |
252 | else if (n.nodeName() == SYNC_ROOT) { | 266 | else if (n.nodeName() == SYNC_ROOT) { |
253 | if (!readSyncData(n, &(dta->syncDta))) { | 267 | if (!readSyncData(n, &(dta->syncDta))) { |
254 | return false; | 268 | return false; |
255 | } | 269 | } |
256 | continue; | 270 | continue; |
257 | } | 271 | } |
258 | 272 | ||
259 | /* NOTE: We can stop processing here, as we | 273 | /* NOTE: We can stop processing here, as we |
260 | * don't have more nodes in root, yet. | 274 | * don't have more nodes in root, yet. |
261 | */ | 275 | */ |
262 | return false; | 276 | return false; |
263 | 277 | ||
264 | } | 278 | } |
265 | return true; | 279 | return true; |
266 | } | 280 | } |
267 | 281 | ||
268 | bool Serializer::readCategories(const QDomNode &n, | 282 | bool Serializer::readCategories(const QDomNode &n, |
269 | vector<PwMCategoryItem> *dta) | 283 | vector<PwMCategoryItem> *dta) |
270 | { | 284 | { |
271 | QDomNodeList nl(n.childNodes()); | 285 | QDomNodeList nl(n.childNodes()); |
272 | QDomNode cur; | 286 | QDomNode cur; |
273 | QString name; | 287 | QString name; |
288 | QString text; | ||
274 | unsigned int numCat = nl.count(), i; | 289 | unsigned int numCat = nl.count(), i; |
275 | PwMCategoryItem curCat; | 290 | PwMCategoryItem curCat; |
276 | vector<PwMDataItem> curEntr; | 291 | vector<PwMDataItem> curEntr; |
277 | 292 | ||
278 | if (!numCat) { | 293 | if (!numCat) { |
279 | printDebug("Serializer::readCategories(): empty"); | 294 | printDebug("Serializer::readCategories(): empty"); |
280 | return false; | 295 | return false; |
281 | } | 296 | } |
282 | for (i = 0; i < numCat; ++i) { | 297 | for (i = 0; i < numCat; ++i) { |
283 | cur = nl.item(i); | 298 | cur = nl.item(i); |
284 | if (cur.nodeName().left(1) == CAT_PREFIX_NEW || | 299 | if (cur.nodeName().left(1) == CAT_PREFIX_NEW || |
285 | cur.nodeName().left(4) == CAT_PREFIX_OLD) { | 300 | cur.nodeName().left(4) == CAT_PREFIX_OLD) { |
286 | name = cur.toElement().attribute(CAT_NAME_NEW); | 301 | name = cur.toElement().attribute(CAT_NAME_NEW); |
287 | if (name == QString::null) | 302 | if (name == QString::null) |
288 | name = cur.toElement().attribute(CAT_NAME_OLD); | 303 | name = cur.toElement().attribute(CAT_NAME_OLD); |
289 | PWM_ASSERT(name != QString::null); | 304 | PWM_ASSERT(name != QString::null); |
290 | PWM_ASSERT(name != ""); | 305 | PWM_ASSERT(name != ""); |
291 | curCat.clear(); | 306 | curCat.clear(); |
292 | curCat.name = name.latin1(); | 307 | curCat.name = name.latin1(); |
308 | |||
309 | //US ENH: new version might include text for description, name and pw | ||
310 | text = cur.toElement().attribute(CAT_TEXT_NEW); | ||
311 | if (text == QString::null) | ||
312 | text = cur.toElement().attribute(CAT_TEXT_OLD); | ||
313 | if (text != QString::null) | ||
314 | { | ||
315 | QStringList textlist = QStringList::split(";", text, true); | ||
316 | unsigned int num = textlist.count(); | ||
317 | if (num > 0) | ||
318 | curCat.desc_text = textlist[0].latin1(); | ||
319 | if (num > 1) | ||
320 | curCat.name_text = textlist[1].latin1(); | ||
321 | if (num > 2) | ||
322 | curCat.pw_text = textlist[2].latin1(); | ||
323 | } | ||
324 | |||
293 | if (!readEntries(cur, &curEntr)) { | 325 | if (!readEntries(cur, &curEntr)) { |
294 | dta->clear(); | 326 | dta->clear(); |
295 | return false; | 327 | return false; |
296 | } | 328 | } |
297 | curCat.d = curEntr; | 329 | curCat.d = curEntr; |
298 | dta->push_back(curCat); | 330 | dta->push_back(curCat); |
299 | } else { | 331 | } else { |
300 | printDebug("Serializer::readCategories(): uh? not a category?"); | 332 | printDebug("Serializer::readCategories(): uh? not a category?"); |
301 | } | 333 | } |
302 | } | 334 | } |
303 | return true; | 335 | return true; |
304 | } | 336 | } |
305 | 337 | ||
306 | bool Serializer::readEntries(const QDomNode &n, | 338 | bool Serializer::readEntries(const QDomNode &n, |
307 | vector<PwMDataItem> *dta) | 339 | vector<PwMDataItem> *dta) |
308 | { | 340 | { |
309 | QDomNodeList nl(n.childNodes()); | 341 | QDomNodeList nl(n.childNodes()); |
310 | QDomNode cur; | 342 | QDomNode cur; |
311 | unsigned int numEntr = nl.count(), i; | 343 | unsigned int numEntr = nl.count(), i; |
312 | PwMDataItem curEntr; | 344 | PwMDataItem curEntr; |
313 | //US BUG: to initialize all values of curEntr with meaningfulldata, | 345 | //US BUG: to initialize all values of curEntr with meaningfulldata, |
314 | // we call clear on it. Reason: Information in the file we will read might be incomplete. | 346 | // we call clear on it. Reason: Information in the file we will read might be incomplete. |
315 | // e.g. the metadata is missing. | 347 | // e.g. the metadata is missing. |
316 | curEntr.clear(true); | 348 | curEntr.clear(true); |
317 | 349 | ||
318 | dta->clear(); | 350 | dta->clear(); |
319 | for (i = 0; i < numEntr; ++i) { | 351 | for (i = 0; i < numEntr; ++i) { |
320 | cur = nl.item(i); | 352 | cur = nl.item(i); |
321 | if (cur.nodeName().left(1) == ENTRY_PREFIX_NEW || | 353 | if (cur.nodeName().left(1) == ENTRY_PREFIX_NEW || |
322 | cur.nodeName().left(6) == ENTRY_PREFIX_OLD) { | 354 | cur.nodeName().left(6) == ENTRY_PREFIX_OLD) { |
323 | if (!extractEntry(cur, &curEntr)) { | 355 | if (!extractEntry(cur, &curEntr)) { |
324 | return false; | 356 | return false; |
@@ -472,64 +504,74 @@ bool Serializer::checkValid() | |||
472 | return false; | 504 | return false; |
473 | } | 505 | } |
474 | if (root.attribute(VER_STR_NEW) != COMPAT_VER_NEW && | 506 | if (root.attribute(VER_STR_NEW) != COMPAT_VER_NEW && |
475 | root.attribute(VER_STR_OLD) != COMPAT_VER_OLD) { | 507 | root.attribute(VER_STR_OLD) != COMPAT_VER_OLD) { |
476 | printDebug("Serializer: wrong version"); | 508 | printDebug("Serializer: wrong version"); |
477 | return false; | 509 | return false; |
478 | } | 510 | } |
479 | return true; | 511 | return true; |
480 | } | 512 | } |
481 | 513 | ||
482 | QDomElement Serializer::genNewRoot() | 514 | QDomElement Serializer::genNewRoot() |
483 | { | 515 | { |
484 | PWM_ASSERT(domDoc); | 516 | PWM_ASSERT(domDoc); |
485 | QDomElement root(domDoc->createElement(ROOT_MAGIC_WR)); | 517 | QDomElement root(domDoc->createElement(ROOT_MAGIC_WR)); |
486 | root.setAttribute(VER_STR_WR, COMPAT_VER_WR); | 518 | root.setAttribute(VER_STR_WR, COMPAT_VER_WR); |
487 | domDoc->appendChild(root); | 519 | domDoc->appendChild(root); |
488 | return root; | 520 | return root; |
489 | } | 521 | } |
490 | 522 | ||
491 | bool Serializer::addCategories(QDomElement *e, | 523 | bool Serializer::addCategories(QDomElement *e, |
492 | const vector<PwMCategoryItem> &dta) | 524 | const vector<PwMCategoryItem> &dta) |
493 | { | 525 | { |
494 | unsigned int numCat = dta.size(), i; | 526 | unsigned int numCat = dta.size(), i; |
495 | QString curId, curName; | 527 | QString curId, curName; |
496 | QDomElement curCat; | 528 | QDomElement curCat; |
497 | 529 | ||
498 | for (i = 0; i < numCat; ++i) { | 530 | for (i = 0; i < numCat; ++i) { |
499 | curId = CAT_PREFIX_WR; | 531 | curId = CAT_PREFIX_WR; |
500 | curId += tostr(i).c_str(); | 532 | curId += tostr(i).c_str(); |
501 | curName = dta[i].name.c_str(); | 533 | curName = dta[i].name.c_str(); |
502 | curCat = domDoc->createElement(curId); | 534 | curCat = domDoc->createElement(curId); |
503 | curCat.setAttribute(CAT_NAME_WR, curName); | 535 | curCat.setAttribute(CAT_NAME_WR, curName); |
536 | |||
537 | //US ENH: new version includes text for description, name and pw | ||
538 | QStringList curTextList; | ||
539 | curTextList << dta[i].desc_text.c_str(); | ||
540 | curTextList << dta[i].name_text.c_str(); | ||
541 | curTextList << dta[i].pw_text.c_str(); | ||
542 | QString text = curTextList.join(";"); | ||
543 | curCat.setAttribute(CAT_TEXT_WR, text); | ||
544 | |||
545 | |||
504 | if (!addEntries(&curCat, dta[i].d)) { | 546 | if (!addEntries(&curCat, dta[i].d)) { |
505 | return false; | 547 | return false; |
506 | } | 548 | } |
507 | e->appendChild(curCat); | 549 | e->appendChild(curCat); |
508 | } | 550 | } |
509 | return true; | 551 | return true; |
510 | } | 552 | } |
511 | 553 | ||
512 | bool Serializer::addEntries(QDomElement *e, | 554 | bool Serializer::addEntries(QDomElement *e, |
513 | const vector<PwMDataItem> &dta) | 555 | const vector<PwMDataItem> &dta) |
514 | { | 556 | { |
515 | unsigned int numEntr = dta.size(), i; | 557 | unsigned int numEntr = dta.size(), i; |
516 | QString curId; | 558 | QString curId; |
517 | QDomElement curEntr; | 559 | QDomElement curEntr; |
518 | 560 | ||
519 | for (i = 0; i < numEntr; ++i) { | 561 | for (i = 0; i < numEntr; ++i) { |
520 | curId = ENTRY_PREFIX_WR; | 562 | curId = ENTRY_PREFIX_WR; |
521 | curId += tostr(i).c_str(); | 563 | curId += tostr(i).c_str(); |
522 | curEntr = domDoc->createElement(curId); | 564 | curEntr = domDoc->createElement(curId); |
523 | if (!writeEntry(&curEntr, dta[i])) { | 565 | if (!writeEntry(&curEntr, dta[i])) { |
524 | return false; | 566 | return false; |
525 | } | 567 | } |
526 | e->appendChild(curEntr); | 568 | e->appendChild(curEntr); |
527 | } | 569 | } |
528 | return true; | 570 | return true; |
529 | } | 571 | } |
530 | 572 | ||
531 | bool Serializer::writeEntry(QDomElement *e, | 573 | bool Serializer::writeEntry(QDomElement *e, |
532 | const PwMDataItem &_dta) | 574 | const PwMDataItem &_dta) |
533 | { | 575 | { |
534 | #if WRITE_CDATA_SEC != 0 | 576 | #if WRITE_CDATA_SEC != 0 |
535 | # define new_text(x)domDoc->createCDATASection(x) | 577 | # define new_text(x)domDoc->createCDATASection(x) |