summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--pwmanager/pwmanager/pwmdoc.cpp8
1 files changed, 5 insertions, 3 deletions
diff --git a/pwmanager/pwmanager/pwmdoc.cpp b/pwmanager/pwmanager/pwmdoc.cpp
index a5df8f0..0ac5517 100644
--- a/pwmanager/pwmanager/pwmdoc.cpp
+++ b/pwmanager/pwmanager/pwmdoc.cpp
@@ -1,220 +1,220 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * copyright (C) 2003, 2004 by Michael Buesch * 3 * copyright (C) 2003, 2004 by Michael Buesch *
4 * email: mbuesch@freenet.de * 4 * email: mbuesch@freenet.de *
5 * * 5 * *
6 * This program is free software; you can redistribute it and/or modify * 6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License version 2 * 7 * it under the terms of the GNU General Public License version 2 *
8 * as published by the Free Software Foundation. * 8 * as published by the Free Software Foundation. *
9 * * 9 * *
10 ***************************************************************************/ 10 ***************************************************************************/
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 2.0 of pwmanager 14 * This file is originaly based on version 2.0 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 "pwmdoc.h" 20#include "pwmdoc.h"
21#include "pwmview.h" 21#include "pwmview.h"
22#include "blowfish.h" 22#include "blowfish.h"
23#include "sha1.h" 23#include "sha1.h"
24#include "globalstuff.h" 24#include "globalstuff.h"
25#include "gpasmanfile.h" 25#include "gpasmanfile.h"
26#include "serializer.h" 26#include "serializer.h"
27#include "compressgzip.h" 27#include "compressgzip.h"
28#include "compressbzip2.h" 28//US#include "compressbzip2.h"
29#include "randomizer.h" 29#include "randomizer.h"
30#include "pwminit.h" 30#include "pwminit.h"
31#include "libgcryptif.h" 31#include "libgcryptif.h"
32#ifdef PWM_EMBEDDED 32#ifdef PWM_EMBEDDED
33#include "pwmprefs.h" 33#include "pwmprefs.h"
34#include "kglobal.h" 34#include "kglobal.h"
35#endif 35#endif
36 36
37#include <kmessagebox.h> 37#include <kmessagebox.h>
38#include <libkcal/syncdefines.h> 38#include <libkcal/syncdefines.h>
39 39
40 40
41#ifdef CONFIG_KWALLETIF 41#ifdef CONFIG_KWALLETIF
42# include "kwalletemu.h" 42# include "kwalletemu.h"
43#endif // CONFIG_KWALLETIF 43#endif // CONFIG_KWALLETIF
44 44
45#include <qdatetime.h> 45#include <qdatetime.h>
46#include <qsize.h> 46#include <qsize.h>
47#include <qfileinfo.h> 47#include <qfileinfo.h>
48#include <qfile.h> 48#include <qfile.h>
49 49
50#include <stdio.h> 50#include <stdio.h>
51#include <stdlib.h> 51#include <stdlib.h>
52#include <errno.h> 52#include <errno.h>
53#include <string.h> 53#include <string.h>
54//US#include <iostream> 54//US#include <iostream>
55#include <algorithm> 55#include <algorithm>
56#include <sys/types.h> 56#include <sys/types.h>
57#include <sys/stat.h> 57#include <sys/stat.h>
58#include <unistd.h> 58#include <unistd.h>
59#include <stdint.h> 59#include <stdint.h>
60 60
61 61
62#ifdef PWM_EMBEDDED 62#ifdef PWM_EMBEDDED
63#ifndef Q_LONG 63#ifndef Q_LONG
64#define Q_LONG long 64#define Q_LONG long
65#endif 65#endif
66 66
67#ifndef Q_ULONG 67#ifndef Q_ULONG
68#define Q_ULONG unsigned long 68#define Q_ULONG unsigned long
69#endif 69#endif
70#endif //PWM_EMBEDDED 70#endif //PWM_EMBEDDED
71 71
72 72
73//TODO: reset to its normal value. 73//TODO: reset to its normal value.
74 #define META_CHECK_TIMER_INTERVAL10/*300*/ /* sek */ 74 #define META_CHECK_TIMER_INTERVAL10/*300*/ /* sek */
75 75
76using namespace std; 76using namespace std;
77 77
78 78
79void PwMDocList::add(PwMDoc *doc, const string &id) 79void PwMDocList::add(PwMDoc *doc, const string &id)
80{ 80{
81#ifdef PWM_DEBUG 81#ifdef PWM_DEBUG
82 // check for existance of object in debug mode only. 82 // check for existance of object in debug mode only.
83 vector<listItem>::iterator begin = docList.begin(), 83 vector<listItem>::iterator begin = docList.begin(),
84 end = docList.end(), 84 end = docList.end(),
85 i = begin; 85 i = begin;
86 while (i != end) { 86 while (i != end) {
87 if (i->doc == doc) { 87 if (i->doc == doc) {
88 BUG(); 88 BUG();
89 return; 89 return;
90 } 90 }
91 ++i; 91 ++i;
92 } 92 }
93#endif 93#endif
94 listItem newItem; 94 listItem newItem;
95 newItem.doc = doc; 95 newItem.doc = doc;
96 newItem.docId = id; 96 newItem.docId = id;
97 docList.push_back(newItem); 97 docList.push_back(newItem);
98} 98}
99 99
100void PwMDocList::edit(PwMDoc *doc, const string &newId) 100void PwMDocList::edit(PwMDoc *doc, const string &newId)
101{ 101{
102 vector<listItem>::iterator begin = docList.begin(), 102 vector<listItem>::iterator begin = docList.begin(),
103 end = docList.end(), 103 end = docList.end(),
104 i = begin; 104 i = begin;
105 while (i != end) { 105 while (i != end) {
106 if (i->doc == doc) { 106 if (i->doc == doc) {
107 i->docId = newId; 107 i->docId = newId;
108 return; 108 return;
109 } 109 }
110 ++i; 110 ++i;
111 } 111 }
112} 112}
113 113
114void PwMDocList::del(PwMDoc *doc) 114void PwMDocList::del(PwMDoc *doc)
115{ 115{
116 vector<listItem>::iterator begin = docList.begin(), 116 vector<listItem>::iterator begin = docList.begin(),
117 end = docList.end(), 117 end = docList.end(),
118 i = begin; 118 i = begin;
119 while (i != end) { 119 while (i != end) {
120 if (i->doc == doc) { 120 if (i->doc == doc) {
121 docList.erase(i); 121 docList.erase(i);
122 return; 122 return;
123 } 123 }
124 ++i; 124 ++i;
125 } 125 }
126} 126}
127 127
128bool PwMDocList::find(const string &id, listItem *ret) 128bool PwMDocList::find(const string &id, listItem *ret)
129{ 129{
130 vector<listItem>::iterator begin = docList.begin(), 130 vector<listItem>::iterator begin = docList.begin(),
131 end = docList.end(), 131 end = docList.end(),
132 i = begin; 132 i = begin;
133 while (i != end) { 133 while (i != end) {
134 if (i->docId == id) { 134 if (i->docId == id) {
135 if (ret) 135 if (ret)
136 *ret = *i; 136 *ret = *i;
137 return true; 137 return true;
138 } 138 }
139 ++i; 139 ++i;
140 } 140 }
141 return false; 141 return false;
142} 142}
143 143
144 144
145 145
146DocTimer::DocTimer(PwMDoc *_doc) 146DocTimer::DocTimer(PwMDoc *_doc)
147 : doc (_doc) 147 : doc (_doc)
148 , mpwLock (0) 148 , mpwLock (0)
149 , autoLockLock (0) 149 , autoLockLock (0)
150 , metaCheckLock (0) 150 , metaCheckLock (0)
151{ 151{
152 mpwTimer = new QTimer; 152 mpwTimer = new QTimer;
153 autoLockTimer = new QTimer; 153 autoLockTimer = new QTimer;
154 metaCheckTimer = new QTimer; 154 metaCheckTimer = new QTimer;
155 connect(mpwTimer, SIGNAL(timeout()), 155 connect(mpwTimer, SIGNAL(timeout()),
156 this, SLOT(mpwTimeout())); 156 this, SLOT(mpwTimeout()));
157 connect(autoLockTimer, SIGNAL(timeout()), 157 connect(autoLockTimer, SIGNAL(timeout()),
158 this, SLOT(autoLockTimeout())); 158 this, SLOT(autoLockTimeout()));
159 connect(metaCheckTimer, SIGNAL(timeout()), 159 connect(metaCheckTimer, SIGNAL(timeout()),
160 this, SLOT(metaCheckTimeout())); 160 this, SLOT(metaCheckTimeout()));
161} 161}
162 162
163DocTimer::~DocTimer() 163DocTimer::~DocTimer()
164{ 164{
165 delete mpwTimer; 165 delete mpwTimer;
166 delete autoLockTimer; 166 delete autoLockTimer;
167 delete metaCheckTimer; 167 delete metaCheckTimer;
168} 168}
169 169
170void DocTimer::start(TimerIDs timer) 170void DocTimer::start(TimerIDs timer)
171{ 171{
172 switch (timer) { 172 switch (timer) {
173 case id_mpwTimer: 173 case id_mpwTimer:
174 if (mpwTimer->isActive()) 174 if (mpwTimer->isActive())
175 mpwTimer->stop(); 175 mpwTimer->stop();
176 doc->setDocStatFlag(DOC_STAT_UNLOCK_WITHOUT_PW); 176 doc->setDocStatFlag(DOC_STAT_UNLOCK_WITHOUT_PW);
177 mpwTimer->start(conf()->confGlobPwTimeout() * 1000, true); 177 mpwTimer->start(conf()->confGlobPwTimeout() * 1000, true);
178 break; 178 break;
179 case id_autoLockTimer: 179 case id_autoLockTimer:
180 if (autoLockTimer->isActive()) 180 if (autoLockTimer->isActive())
181 autoLockTimer->stop(); 181 autoLockTimer->stop();
182 if (conf()->confGlobLockTimeout() > 0) 182 if (conf()->confGlobLockTimeout() > 0)
183 autoLockTimer->start(conf()->confGlobLockTimeout() * 1000, true); 183 autoLockTimer->start(conf()->confGlobLockTimeout() * 1000, true);
184 break; 184 break;
185 case id_metaCheckTimer: 185 case id_metaCheckTimer:
186 if (metaCheckTimer->isActive()) 186 if (metaCheckTimer->isActive())
187 metaCheckTimer->stop(); 187 metaCheckTimer->stop();
188 metaCheckTimer->start(META_CHECK_TIMER_INTERVAL * 1000, true); 188 metaCheckTimer->start(META_CHECK_TIMER_INTERVAL * 1000, true);
189 break; 189 break;
190 } 190 }
191} 191}
192 192
193void DocTimer::stop(TimerIDs timer) 193void DocTimer::stop(TimerIDs timer)
194{ 194{
195 switch (timer) { 195 switch (timer) {
196 case id_mpwTimer: 196 case id_mpwTimer:
197 mpwTimer->stop(); 197 mpwTimer->stop();
198 break; 198 break;
199 case id_autoLockTimer: 199 case id_autoLockTimer:
200 autoLockTimer->stop(); 200 autoLockTimer->stop();
201 break; 201 break;
202 case id_metaCheckTimer: 202 case id_metaCheckTimer:
203 metaCheckTimer->stop(); 203 metaCheckTimer->stop();
204 break; 204 break;
205 } 205 }
206} 206}
207 207
208void DocTimer::getLock(TimerIDs timer) 208void DocTimer::getLock(TimerIDs timer)
209{ 209{
210 switch (timer) { 210 switch (timer) {
211 case id_mpwTimer: 211 case id_mpwTimer:
212 ++mpwLock; 212 ++mpwLock;
213 break; 213 break;
214 case id_autoLockTimer: 214 case id_autoLockTimer:
215 ++autoLockLock; 215 ++autoLockLock;
216 break; 216 break;
217 case id_metaCheckTimer: 217 case id_metaCheckTimer:
218 ++metaCheckLock; 218 ++metaCheckLock;
219 break; 219 break;
220 } 220 }
@@ -1030,406 +1030,408 @@ bool PwMDoc::delEntry(unsigned int category, unsigned int index, bool dontFlagDi
1030 if (index > dti.dta[category].d.size() - 1) 1030 if (index > dti.dta[category].d.size() - 1)
1031 return false; 1031 return false;
1032 getDataChangedLock(); 1032 getDataChangedLock();
1033 if (!lockAt(category, index, false)) { 1033 if (!lockAt(category, index, false)) {
1034 putDataChangedLock(); 1034 putDataChangedLock();
1035 return false; 1035 return false;
1036 } 1036 }
1037 putDataChangedLock(); 1037 putDataChangedLock();
1038 int lvPos = dti.dta[category].d[index].listViewPos; 1038 int lvPos = dti.dta[category].d[index].listViewPos;
1039 1039
1040 // delete entry 1040 // delete entry
1041 dti.dta[category].d.erase(dti.dta[category].d.begin() + index); 1041 dti.dta[category].d.erase(dti.dta[category].d.begin() + index);
1042 1042
1043 unsigned int i, entries = numEntries(category); 1043 unsigned int i, entries = numEntries(category);
1044 if (!entries) { 1044 if (!entries) {
1045 // no more entries in this category, so 1045 // no more entries in this category, so
1046 // we can delete it, too. 1046 // we can delete it, too.
1047 BUG_ON(!delCategory(category)); 1047 BUG_ON(!delCategory(category));
1048 // delCategory() flags it dirty, so we need not to do so. 1048 // delCategory() flags it dirty, so we need not to do so.
1049 return true; 1049 return true;
1050 } 1050 }
1051 for (i = 0; i < entries; ++i) { 1051 for (i = 0; i < entries; ++i) {
1052 // decrement all listViewPositions that are greater than the deleted. 1052 // decrement all listViewPositions that are greater than the deleted.
1053 if (dti.dta[category].d[i].listViewPos > lvPos) 1053 if (dti.dta[category].d[i].listViewPos > lvPos)
1054 --dti.dta[category].d[i].listViewPos; 1054 --dti.dta[category].d[i].listViewPos;
1055 } 1055 }
1056 1056
1057 if (!dontFlagDirty) 1057 if (!dontFlagDirty)
1058 flagDirty(); 1058 flagDirty();
1059 return true; 1059 return true;
1060} 1060}
1061 1061
1062bool PwMDoc::editEntry(const QString &oldCategory, const QString &newCategory, 1062bool PwMDoc::editEntry(const QString &oldCategory, const QString &newCategory,
1063 unsigned int index, PwMDataItem *d, bool updateMeta) 1063 unsigned int index, PwMDataItem *d, bool updateMeta)
1064{ 1064{
1065 PWM_ASSERT(d); 1065 PWM_ASSERT(d);
1066 unsigned int oldCat = 0; 1066 unsigned int oldCat = 0;
1067 1067
1068 if (!findCategory(oldCategory, &oldCat)) { 1068 if (!findCategory(oldCategory, &oldCat)) {
1069 BUG(); 1069 BUG();
1070 return false; 1070 return false;
1071 } 1071 }
1072 1072
1073 return editEntry(oldCat, newCategory, index, d, updateMeta); 1073 return editEntry(oldCat, newCategory, index, d, updateMeta);
1074} 1074}
1075 1075
1076bool PwMDoc::editEntry(unsigned int oldCategory, const QString &newCategory, 1076bool PwMDoc::editEntry(unsigned int oldCategory, const QString &newCategory,
1077 unsigned int index, PwMDataItem *d, bool updateMeta) 1077 unsigned int index, PwMDataItem *d, bool updateMeta)
1078{ 1078{
1079 if (isDeepLocked()) 1079 if (isDeepLocked())
1080 return false; 1080 return false;
1081 if (updateMeta) { 1081 if (updateMeta) {
1082 d->meta.update = QDateTime::currentDateTime(); 1082 d->meta.update = QDateTime::currentDateTime();
1083 if (d->meta.create.isNull()) { 1083 if (d->meta.create.isNull()) {
1084 d->meta.create = d->meta.update; 1084 d->meta.create = d->meta.update;
1085 } 1085 }
1086 } 1086 }
1087 if (dti.dta[oldCategory].name != newCategory.latin1()) { 1087 if (dti.dta[oldCategory].name != newCategory.latin1()) {
1088 // the user changed the category. 1088 // the user changed the category.
1089 PwMerror ret; 1089 PwMerror ret;
1090 d->rev = 0; 1090 d->rev = 0;
1091 ret = addEntry(newCategory, d, true, false); 1091 ret = addEntry(newCategory, d, true, false);
1092 if (ret != e_success) 1092 if (ret != e_success)
1093 return false; 1093 return false;
1094 if (!delEntry(oldCategory, index, true)) 1094 if (!delEntry(oldCategory, index, true))
1095 return false; 1095 return false;
1096 } else { 1096 } else {
1097 d->rev = dti.dta[oldCategory].d[index].rev + 1; // increment revision counter. 1097 d->rev = dti.dta[oldCategory].d[index].rev + 1; // increment revision counter.
1098 dti.dta[oldCategory].d[index] = *d; 1098 dti.dta[oldCategory].d[index] = *d;
1099 } 1099 }
1100 flagDirty(); 1100 flagDirty();
1101 return true; 1101 return true;
1102} 1102}
1103 1103
1104unsigned int PwMDoc::numEntries(const QString &category) 1104unsigned int PwMDoc::numEntries(const QString &category)
1105{ 1105{
1106 unsigned int cat = 0; 1106 unsigned int cat = 0;
1107 1107
1108 if (!findCategory(category, &cat)) { 1108 if (!findCategory(category, &cat)) {
1109 BUG(); 1109 BUG();
1110 return 0; 1110 return 0;
1111 } 1111 }
1112 1112
1113 return numEntries(cat); 1113 return numEntries(cat);
1114} 1114}
1115 1115
1116bool PwMDoc::serializeDta(string *d) 1116bool PwMDoc::serializeDta(string *d)
1117{ 1117{
1118 PWM_ASSERT(d); 1118 PWM_ASSERT(d);
1119 Serializer ser; 1119 Serializer ser;
1120 if (!ser.serialize(dti)) 1120 if (!ser.serialize(dti))
1121 return false; 1121 return false;
1122 d->assign(ser.getXml()); 1122 d->assign(ser.getXml());
1123 if (!d->size()) 1123 if (!d->size())
1124 return false; 1124 return false;
1125 return true; 1125 return true;
1126} 1126}
1127 1127
1128bool PwMDoc::deSerializeDta(const string *d, bool entriesLocked) 1128bool PwMDoc::deSerializeDta(const string *d, bool entriesLocked)
1129{ 1129{
1130 PWM_ASSERT(d); 1130 PWM_ASSERT(d);
1131#ifndef PWM_EMBEDDED 1131#ifndef PWM_EMBEDDED
1132 try { 1132 try {
1133 1133
1134 Serializer ser(d->c_str()); 1134 Serializer ser(d->c_str());
1135 ser.setDefaultLockStat(entriesLocked); 1135 ser.setDefaultLockStat(entriesLocked);
1136 if (!ser.deSerialize(&dti)) 1136 if (!ser.deSerialize(&dti))
1137 return false; 1137 return false;
1138 } catch (PwMException) { 1138 } catch (PwMException) {
1139 return false; 1139 return false;
1140 } 1140 }
1141#else 1141#else
1142 Serializer ser(d->c_str()); 1142 Serializer ser(d->c_str());
1143 ser.setDefaultLockStat(entriesLocked); 1143 ser.setDefaultLockStat(entriesLocked);
1144 if (!ser.deSerialize(&dti)) 1144 if (!ser.deSerialize(&dti))
1145 return false; 1145 return false;
1146#endif 1146#endif
1147 1147
1148 emitDataChanged(this); 1148 emitDataChanged(this);
1149 return true; 1149 return true;
1150} 1150}
1151 1151
1152bool PwMDoc::getEntry(const QString &category, unsigned int index, 1152bool PwMDoc::getEntry(const QString &category, unsigned int index,
1153 PwMDataItem * d, bool unlockIfLocked) 1153 PwMDataItem * d, bool unlockIfLocked)
1154{ 1154{
1155 PWM_ASSERT(d); 1155 PWM_ASSERT(d);
1156 unsigned int cat = 0; 1156 unsigned int cat = 0;
1157 1157
1158 if (!findCategory(category, &cat)) { 1158 if (!findCategory(category, &cat)) {
1159 BUG(); 1159 BUG();
1160 return false; 1160 return false;
1161 } 1161 }
1162 1162
1163 return getEntry(cat, index, d, unlockIfLocked); 1163 return getEntry(cat, index, d, unlockIfLocked);
1164} 1164}
1165 1165
1166bool PwMDoc::getEntry(unsigned int category, unsigned int index, 1166bool PwMDoc::getEntry(unsigned int category, unsigned int index,
1167 PwMDataItem *d, bool unlockIfLocked) 1167 PwMDataItem *d, bool unlockIfLocked)
1168{ 1168{
1169 if (index > dti.dta[category].d.size() - 1) 1169 if (index > dti.dta[category].d.size() - 1)
1170 return false; 1170 return false;
1171 1171
1172 bool locked = isLocked(category, index); 1172 bool locked = isLocked(category, index);
1173 if (locked) { 1173 if (locked) {
1174 /* this entry is locked. We don't return a password, 1174 /* this entry is locked. We don't return a password,
1175 * until it's unlocked by the user by inserting 1175 * until it's unlocked by the user by inserting
1176 * chipcard or entering the mpw 1176 * chipcard or entering the mpw
1177 */ 1177 */
1178 if (unlockIfLocked) { 1178 if (unlockIfLocked) {
1179 if (!lockAt(category, index, false)) { 1179 if (!lockAt(category, index, false)) {
1180 return false; 1180 return false;
1181 } 1181 }
1182 locked = false; 1182 locked = false;
1183 } 1183 }
1184 } 1184 }
1185 1185
1186 *d = dti.dta[category].d[index]; 1186 *d = dti.dta[category].d[index];
1187 if (locked) 1187 if (locked)
1188 d->pw = LOCKED_STRING.latin1(); 1188 d->pw = LOCKED_STRING.latin1();
1189 1189
1190 return true; 1190 return true;
1191} 1191}
1192 1192
1193PwMerror PwMDoc::getCommentByLvp(const QString &category, int listViewPos, 1193PwMerror PwMDoc::getCommentByLvp(const QString &category, int listViewPos,
1194 string *foundComment) 1194 string *foundComment)
1195{ 1195{
1196 PWM_ASSERT(foundComment); 1196 PWM_ASSERT(foundComment);
1197 unsigned int cat = 0; 1197 unsigned int cat = 0;
1198 1198
1199 if (!findCategory(category, &cat)) 1199 if (!findCategory(category, &cat))
1200 return e_invalidArg; 1200 return e_invalidArg;
1201 1201
1202 unsigned int i, entries = numEntries(cat); 1202 unsigned int i, entries = numEntries(cat);
1203 for (i = 0; i < entries; ++i) { 1203 for (i = 0; i < entries; ++i) {
1204 if (dti.dta[cat].d[i].listViewPos == listViewPos) { 1204 if (dti.dta[cat].d[i].listViewPos == listViewPos) {
1205 *foundComment = dti.dta[cat].d[i].comment; 1205 *foundComment = dti.dta[cat].d[i].comment;
1206 if (dti.dta[cat].d[i].binary) 1206 if (dti.dta[cat].d[i].binary)
1207 return e_binEntry; 1207 return e_binEntry;
1208 return e_normalEntry; 1208 return e_normalEntry;
1209 } 1209 }
1210 } 1210 }
1211 BUG(); 1211 BUG();
1212 return e_generic; 1212 return e_generic;
1213} 1213}
1214 1214
1215bool PwMDoc::compressDta(string *d, char algo) 1215bool PwMDoc::compressDta(string *d, char algo)
1216{ 1216{
1217 PWM_ASSERT(d); 1217 PWM_ASSERT(d);
1218 switch (algo) { 1218 switch (algo) {
1219 case PWM_COMPRESS_GZIP: { 1219 case PWM_COMPRESS_GZIP: {
1220 CompressGzip comp; 1220 CompressGzip comp;
1221 return comp.compress(d); 1221 return comp.compress(d);
1222 } case PWM_COMPRESS_BZIP2: { 1222 /*US } case PWM_COMPRESS_BZIP2: {
1223 CompressBzip2 comp; 1223 CompressBzip2 comp;
1224 return comp.compress(d); 1224 return comp.compress(d);
1225*/
1225 } case PWM_COMPRESS_NONE: { 1226 } case PWM_COMPRESS_NONE: {
1226 return true; 1227 return true;
1227 } default: { 1228 } default: {
1228 BUG(); 1229 BUG();
1229 } 1230 }
1230 } 1231 }
1231 return false; 1232 return false;
1232} 1233}
1233 1234
1234bool PwMDoc::decompressDta(string *d, char algo) 1235bool PwMDoc::decompressDta(string *d, char algo)
1235{ 1236{
1236 PWM_ASSERT(d); 1237 PWM_ASSERT(d);
1237 switch (algo) { 1238 switch (algo) {
1238 case PWM_COMPRESS_GZIP: { 1239 case PWM_COMPRESS_GZIP: {
1239 CompressGzip comp; 1240 CompressGzip comp;
1240 return comp.decompress(d); 1241 return comp.decompress(d);
1241 } case PWM_COMPRESS_BZIP2: { 1242 /*US } case PWM_COMPRESS_BZIP2: {
1242 CompressBzip2 comp; 1243 CompressBzip2 comp;
1243 return comp.decompress(d); 1244 return comp.decompress(d);
1245 */
1244 } case PWM_COMPRESS_NONE: { 1246 } case PWM_COMPRESS_NONE: {
1245 return true; 1247 return true;
1246 } 1248 }
1247 } 1249 }
1248 return false; 1250 return false;
1249} 1251}
1250 1252
1251PwMerror PwMDoc::encrypt(string *d, const QString *pw, QFile *f, char algo) 1253PwMerror PwMDoc::encrypt(string *d, const QString *pw, QFile *f, char algo)
1252{ 1254{
1253 PWM_ASSERT(d); 1255 PWM_ASSERT(d);
1254 PWM_ASSERT(pw); 1256 PWM_ASSERT(pw);
1255 PWM_ASSERT(f); 1257 PWM_ASSERT(f);
1256 1258
1257 size_t encSize; 1259 size_t encSize;
1258 byte *encrypted = 0; 1260 byte *encrypted = 0;
1259 1261
1260 switch (algo) { 1262 switch (algo) {
1261 case PWM_CRYPT_BLOWFISH: { 1263 case PWM_CRYPT_BLOWFISH: {
1262 Blowfish::padNull(d); 1264 Blowfish::padNull(d);
1263 encSize = d->length(); 1265 encSize = d->length();
1264 encrypted = new byte[encSize]; 1266 encrypted = new byte[encSize];
1265 Blowfish bf; 1267 Blowfish bf;
1266 if (bf.bf_setkey((byte *) pw->latin1(), pw->length())) { 1268 if (bf.bf_setkey((byte *) pw->latin1(), pw->length())) {
1267 delete [] encrypted; 1269 delete [] encrypted;
1268 return e_weakPw; 1270 return e_weakPw;
1269 } 1271 }
1270 bf.bf_encrypt((byte *) encrypted, (byte *) d->c_str(), encSize); 1272 bf.bf_encrypt((byte *) encrypted, (byte *) d->c_str(), encSize);
1271 break; 1273 break;
1272 } 1274 }
1273 case PWM_CRYPT_AES128: 1275 case PWM_CRYPT_AES128:
1274 /*... fall through */ 1276 /*... fall through */
1275 case PWM_CRYPT_AES192: 1277 case PWM_CRYPT_AES192:
1276 case PWM_CRYPT_AES256: 1278 case PWM_CRYPT_AES256:
1277 case PWM_CRYPT_3DES: 1279 case PWM_CRYPT_3DES:
1278 case PWM_CRYPT_TWOFISH: 1280 case PWM_CRYPT_TWOFISH:
1279 case PWM_CRYPT_TWOFISH128: { 1281 case PWM_CRYPT_TWOFISH128: {
1280 if (!LibGCryptIf::available()) 1282 if (!LibGCryptIf::available())
1281 return e_cryptNotImpl; 1283 return e_cryptNotImpl;
1282 LibGCryptIf gc; 1284 LibGCryptIf gc;
1283 PwMerror err; 1285 PwMerror err;
1284 unsigned char *plain = new unsigned char[d->length() + 1024]; 1286 unsigned char *plain = new unsigned char[d->length() + 1024];
1285 memcpy(plain, d->c_str(), d->length()); 1287 memcpy(plain, d->c_str(), d->length());
1286 err = gc.encrypt(&encrypted, 1288 err = gc.encrypt(&encrypted,
1287 &encSize, 1289 &encSize,
1288 plain, 1290 plain,
1289 d->length(), 1291 d->length(),
1290 reinterpret_cast<const unsigned char *>(pw->latin1()), 1292 reinterpret_cast<const unsigned char *>(pw->latin1()),
1291 pw->length(), 1293 pw->length(),
1292 algo); 1294 algo);
1293 delete [] plain; 1295 delete [] plain;
1294 if (err != e_success) 1296 if (err != e_success)
1295 return e_cryptNotImpl; 1297 return e_cryptNotImpl;
1296 break; 1298 break;
1297 } 1299 }
1298 default: { 1300 default: {
1299 delete_ifnot_null_array(encrypted); 1301 delete_ifnot_null_array(encrypted);
1300 return e_cryptNotImpl; 1302 return e_cryptNotImpl;
1301 } } 1303 } }
1302 1304
1303 // write encrypted data to file 1305 // write encrypted data to file
1304 if (f->writeBlock(reinterpret_cast<const char *>(encrypted), 1306 if (f->writeBlock(reinterpret_cast<const char *>(encrypted),
1305 static_cast<Q_ULONG>(encSize)) 1307 static_cast<Q_ULONG>(encSize))
1306 != static_cast<Q_LONG>(encSize)) { 1308 != static_cast<Q_LONG>(encSize)) {
1307 delete_ifnot_null_array(encrypted); 1309 delete_ifnot_null_array(encrypted);
1308 return e_writeFile; 1310 return e_writeFile;
1309 } 1311 }
1310 delete_ifnot_null_array(encrypted); 1312 delete_ifnot_null_array(encrypted);
1311 return e_success; 1313 return e_success;
1312} 1314}
1313 1315
1314PwMerror PwMDoc::decrypt(string *d, unsigned int pos, const QString *pw, 1316PwMerror PwMDoc::decrypt(string *d, unsigned int pos, const QString *pw,
1315 char algo, QFile *f) 1317 char algo, QFile *f)
1316{ 1318{
1317 PWM_ASSERT(d); 1319 PWM_ASSERT(d);
1318 PWM_ASSERT(pw); 1320 PWM_ASSERT(pw);
1319 PWM_ASSERT(f); 1321 PWM_ASSERT(f);
1320 1322
1321 unsigned int cryptLen = f->size() - pos; 1323 unsigned int cryptLen = f->size() - pos;
1322 byte *encrypted = new byte[cryptLen]; 1324 byte *encrypted = new byte[cryptLen];
1323 byte *decrypted = new byte[cryptLen]; 1325 byte *decrypted = new byte[cryptLen];
1324 1326
1325 f->at(pos); 1327 f->at(pos);
1326#ifndef PWM_EMBEDDED 1328#ifndef PWM_EMBEDDED
1327 if (f->readBlock(reinterpret_cast<char *>(encrypted), 1329 if (f->readBlock(reinterpret_cast<char *>(encrypted),
1328 static_cast<Q_ULONG>(cryptLen)) 1330 static_cast<Q_ULONG>(cryptLen))
1329 != static_cast<Q_LONG>(cryptLen)) { 1331 != static_cast<Q_LONG>(cryptLen)) {
1330 delete [] encrypted; 1332 delete [] encrypted;
1331 delete [] decrypted; 1333 delete [] decrypted;
1332 return e_readFile; 1334 return e_readFile;
1333 } 1335 }
1334#else 1336#else
1335 if (f->readBlock((char *)(encrypted), 1337 if (f->readBlock((char *)(encrypted),
1336 (unsigned long)(cryptLen)) 1338 (unsigned long)(cryptLen))
1337 != (long)(cryptLen)) { 1339 != (long)(cryptLen)) {
1338 delete [] encrypted; 1340 delete [] encrypted;
1339 delete [] decrypted; 1341 delete [] decrypted;
1340 return e_readFile; 1342 return e_readFile;
1341 } 1343 }
1342#endif 1344#endif
1343 switch (algo) { 1345 switch (algo) {
1344 case PWM_CRYPT_BLOWFISH: { 1346 case PWM_CRYPT_BLOWFISH: {
1345 Blowfish bf; 1347 Blowfish bf;
1346 bf.bf_setkey((byte *) pw->latin1(), pw->length()); 1348 bf.bf_setkey((byte *) pw->latin1(), pw->length());
1347 bf.bf_decrypt(decrypted, encrypted, cryptLen); 1349 bf.bf_decrypt(decrypted, encrypted, cryptLen);
1348 break; 1350 break;
1349 } 1351 }
1350 case PWM_CRYPT_AES128: 1352 case PWM_CRYPT_AES128:
1351 /*... fall through */ 1353 /*... fall through */
1352 case PWM_CRYPT_AES192: 1354 case PWM_CRYPT_AES192:
1353 case PWM_CRYPT_AES256: 1355 case PWM_CRYPT_AES256:
1354 case PWM_CRYPT_3DES: 1356 case PWM_CRYPT_3DES:
1355 case PWM_CRYPT_TWOFISH: 1357 case PWM_CRYPT_TWOFISH:
1356 case PWM_CRYPT_TWOFISH128: { 1358 case PWM_CRYPT_TWOFISH128: {
1357 if (!LibGCryptIf::available()) 1359 if (!LibGCryptIf::available())
1358 return e_cryptNotImpl; 1360 return e_cryptNotImpl;
1359 LibGCryptIf gc; 1361 LibGCryptIf gc;
1360 PwMerror err; 1362 PwMerror err;
1361 err = gc.decrypt(&decrypted, 1363 err = gc.decrypt(&decrypted,
1362 &cryptLen, 1364 &cryptLen,
1363 encrypted, 1365 encrypted,
1364 cryptLen, 1366 cryptLen,
1365 reinterpret_cast<const unsigned char *>(pw->latin1()), 1367 reinterpret_cast<const unsigned char *>(pw->latin1()),
1366 pw->length(), 1368 pw->length(),
1367 algo); 1369 algo);
1368 if (err != e_success) { 1370 if (err != e_success) {
1369 delete [] encrypted; 1371 delete [] encrypted;
1370 delete [] decrypted; 1372 delete [] decrypted;
1371 return e_cryptNotImpl; 1373 return e_cryptNotImpl;
1372 } 1374 }
1373 break; 1375 break;
1374 } 1376 }
1375 default: { 1377 default: {
1376 delete [] encrypted; 1378 delete [] encrypted;
1377 delete [] decrypted; 1379 delete [] decrypted;
1378 return e_cryptNotImpl; 1380 return e_cryptNotImpl;
1379 } } 1381 } }
1380 delete [] encrypted; 1382 delete [] encrypted;
1381#ifndef PWM_EMBEDDED 1383#ifndef PWM_EMBEDDED
1382 d->assign(reinterpret_cast<const char *>(decrypted), 1384 d->assign(reinterpret_cast<const char *>(decrypted),
1383 static_cast<string::size_type>(cryptLen)); 1385 static_cast<string::size_type>(cryptLen));
1384#else 1386#else
1385 d->assign((const char *)(decrypted), 1387 d->assign((const char *)(decrypted),
1386 (string::size_type)(cryptLen)); 1388 (string::size_type)(cryptLen));
1387#endif 1389#endif
1388 delete [] decrypted; 1390 delete [] decrypted;
1389 if (algo == PWM_CRYPT_BLOWFISH) { 1391 if (algo == PWM_CRYPT_BLOWFISH) {
1390 if (!Blowfish::unpadNull(d)) { 1392 if (!Blowfish::unpadNull(d)) {
1391 BUG(); 1393 BUG();
1392 return e_readFile; 1394 return e_readFile;
1393 } 1395 }
1394 } 1396 }
1395 return e_success; 1397 return e_success;
1396} 1398}
1397 1399
1398PwMerror PwMDoc::checkDataHash(char dataHashType, const string *dataHash, 1400PwMerror PwMDoc::checkDataHash(char dataHashType, const string *dataHash,
1399 const string *dataStream) 1401 const string *dataStream)
1400{ 1402{
1401 PWM_ASSERT(dataHash); 1403 PWM_ASSERT(dataHash);
1402 PWM_ASSERT(dataStream); 1404 PWM_ASSERT(dataStream);
1403 switch(dataHashType) { 1405 switch(dataHashType) {
1404 case PWM_HASH_SHA1: { 1406 case PWM_HASH_SHA1: {
1405 Sha1 hash; 1407 Sha1 hash;
1406 hash.sha1_write((byte*)dataStream->c_str(), dataStream->length()); 1408 hash.sha1_write((byte*)dataStream->c_str(), dataStream->length());
1407 string ret = hash.sha1_read(); 1409 string ret = hash.sha1_read();
1408 if (ret != *dataHash) 1410 if (ret != *dataHash)
1409 return e_fileCorrupt; 1411 return e_fileCorrupt;
1410 break; 1412 break;
1411 } 1413 }
1412 case PWM_HASH_SHA256: 1414 case PWM_HASH_SHA256:
1413 /*... fall through */ 1415 /*... fall through */
1414 case PWM_HASH_SHA384: 1416 case PWM_HASH_SHA384:
1415 case PWM_HASH_SHA512: 1417 case PWM_HASH_SHA512:
1416 case PWM_HASH_MD5: 1418 case PWM_HASH_MD5:
1417 case PWM_HASH_RMD160: 1419 case PWM_HASH_RMD160:
1418 case PWM_HASH_TIGER: { 1420 case PWM_HASH_TIGER: {
1419 if (!LibGCryptIf::available()) 1421 if (!LibGCryptIf::available())
1420 return e_hashNotImpl; 1422 return e_hashNotImpl;
1421 LibGCryptIf gc; 1423 LibGCryptIf gc;
1422 PwMerror err; 1424 PwMerror err;
1423 unsigned char *buf; 1425 unsigned char *buf;
1424 size_t hashLen; 1426 size_t hashLen;
1425 err = gc.hash(&buf, 1427 err = gc.hash(&buf,
1426 &hashLen, 1428 &hashLen,
1427 reinterpret_cast<const unsigned char *>(dataStream->c_str()), 1429 reinterpret_cast<const unsigned char *>(dataStream->c_str()),
1428 dataStream->length(), 1430 dataStream->length(),
1429 dataHashType); 1431 dataHashType);
1430 if (err != e_success) 1432 if (err != e_success)
1431 return e_hashNotImpl; 1433 return e_hashNotImpl;
1432 string calcHash(reinterpret_cast<const char *>(buf), 1434 string calcHash(reinterpret_cast<const char *>(buf),
1433 static_cast<string::size_type>(hashLen)); 1435 static_cast<string::size_type>(hashLen));
1434 delete [] buf; 1436 delete [] buf;
1435 if (calcHash != *dataHash) 1437 if (calcHash != *dataHash)