summaryrefslogtreecommitdiff
authoralwin <alwin>2004-01-03 13:09:15 (UTC)
committer alwin <alwin>2004-01-03 13:09:15 (UTC)
commit622bddce6d0cd41c765225f4743b23bf1667f3db (patch) (unidiff)
treefbe4e839e111e09fce0e64cc68f70f1deb4f7ee0
parent22564b62e15c1ea3feada5b2f9b6ec4d98b40c6b (diff)
downloadopie-622bddce6d0cd41c765225f4743b23bf1667f3db.zip
opie-622bddce6d0cd41c765225f4743b23bf1667f3db.tar.gz
opie-622bddce6d0cd41c765225f4743b23bf1667f3db.tar.bz2
better parsing of mails with recursive multipart content
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/mail/genericwrapper.cpp26
-rw-r--r--noncore/net/mail/genericwrapper.h2
-rw-r--r--noncore/net/mail/libmailwrapper/genericwrapper.cpp26
-rw-r--r--noncore/net/mail/libmailwrapper/genericwrapper.h2
4 files changed, 44 insertions, 12 deletions
diff --git a/noncore/net/mail/genericwrapper.cpp b/noncore/net/mail/genericwrapper.cpp
index 62116ba..714396b 100644
--- a/noncore/net/mail/genericwrapper.cpp
+++ b/noncore/net/mail/genericwrapper.cpp
@@ -1,365 +1,381 @@
1#include "genericwrapper.h" 1#include "genericwrapper.h"
2#include <libetpan/libetpan.h> 2#include <libetpan/libetpan.h>
3#include "mailtypes.h" 3#include "mailtypes.h"
4 4
5Genericwrapper::Genericwrapper() 5Genericwrapper::Genericwrapper()
6 : AbstractMail() 6 : AbstractMail()
7{ 7{
8 bodyCache.clear(); 8 bodyCache.clear();
9} 9}
10 10
11Genericwrapper::~Genericwrapper() 11Genericwrapper::~Genericwrapper()
12{ 12{
13 cleanMimeCache(); 13 cleanMimeCache();
14} 14}
15 15
16void Genericwrapper::fillSingleBody(RecPart&target,mailmessage*,mailmime*mime) 16void Genericwrapper::fillSingleBody(RecPart&target,mailmessage*,mailmime*mime)
17{ 17{
18 if (!mime) { 18 if (!mime) {
19 return; 19 return;
20 } 20 }
21 mailmime_field*field = 0; 21 mailmime_field*field = 0;
22 mailmime_single_fields fields; 22 mailmime_single_fields fields;
23 memset(&fields, 0, sizeof(struct mailmime_single_fields)); 23 memset(&fields, 0, sizeof(struct mailmime_single_fields));
24 if (mime->mm_mime_fields != NULL) { 24 if (mime->mm_mime_fields != NULL) {
25 mailmime_single_fields_init(&fields, mime->mm_mime_fields, 25 mailmime_single_fields_init(&fields, mime->mm_mime_fields,
26 mime->mm_content_type); 26 mime->mm_content_type);
27 } 27 }
28 28
29 mailmime_content*type = fields.fld_content; 29 mailmime_content*type = fields.fld_content;
30 clistcell*current; 30 clistcell*current;
31 if (!type) { 31 if (!type) {
32 target.setType("text"); 32 target.setType("text");
33 target.setSubtype("plain"); 33 target.setSubtype("plain");
34 } else { 34 } else {
35 target.setSubtype(type->ct_subtype); 35 target.setSubtype(type->ct_subtype);
36 switch(type->ct_type->tp_data.tp_discrete_type->dt_type) { 36 switch(type->ct_type->tp_data.tp_discrete_type->dt_type) {
37 case MAILMIME_DISCRETE_TYPE_TEXT: 37 case MAILMIME_DISCRETE_TYPE_TEXT:
38 target.setType("text"); 38 target.setType("text");
39 break; 39 break;
40 case MAILMIME_DISCRETE_TYPE_IMAGE: 40 case MAILMIME_DISCRETE_TYPE_IMAGE:
41 target.setType("image"); 41 target.setType("image");
42 break; 42 break;
43 case MAILMIME_DISCRETE_TYPE_AUDIO: 43 case MAILMIME_DISCRETE_TYPE_AUDIO:
44 target.setType("audio"); 44 target.setType("audio");
45 break; 45 break;
46 case MAILMIME_DISCRETE_TYPE_VIDEO: 46 case MAILMIME_DISCRETE_TYPE_VIDEO:
47 target.setType("video"); 47 target.setType("video");
48 break; 48 break;
49 case MAILMIME_DISCRETE_TYPE_APPLICATION: 49 case MAILMIME_DISCRETE_TYPE_APPLICATION:
50 target.setType("application"); 50 target.setType("application");
51 break; 51 break;
52 case MAILMIME_DISCRETE_TYPE_EXTENSION: 52 case MAILMIME_DISCRETE_TYPE_EXTENSION:
53 default: 53 default:
54 if (type->ct_type->tp_data.tp_discrete_type->dt_extension) { 54 if (type->ct_type->tp_data.tp_discrete_type->dt_extension) {
55 target.setType(type->ct_type->tp_data.tp_discrete_type->dt_extension); 55 target.setType(type->ct_type->tp_data.tp_discrete_type->dt_extension);
56 } 56 }
57 break; 57 break;
58 } 58 }
59 if (type->ct_parameters) { 59 if (type->ct_parameters) {
60 fillParameters(target,type->ct_parameters); 60 fillParameters(target,type->ct_parameters);
61 } 61 }
62 } 62 }
63 if (mime->mm_mime_fields && mime->mm_mime_fields->fld_list) { 63 if (mime->mm_mime_fields && mime->mm_mime_fields->fld_list) {
64 for (current=clist_begin(mime->mm_mime_fields->fld_list);current!=0;current=clist_next(current)) { 64 for (current=clist_begin(mime->mm_mime_fields->fld_list);current!=0;current=clist_next(current)) {
65 field = (mailmime_field*)current->data; 65 field = (mailmime_field*)current->data;
66 switch(field->fld_type) { 66 switch(field->fld_type) {
67 case MAILMIME_FIELD_TRANSFER_ENCODING: 67 case MAILMIME_FIELD_TRANSFER_ENCODING:
68 target.setEncoding(getencoding(field->fld_data.fld_encoding)); 68 target.setEncoding(getencoding(field->fld_data.fld_encoding));
69 break; 69 break;
70 case MAILMIME_FIELD_ID: 70 case MAILMIME_FIELD_ID:
71 target.setIdentifier(field->fld_data.fld_id); 71 target.setIdentifier(field->fld_data.fld_id);
72 break; 72 break;
73 case MAILMIME_FIELD_DESCRIPTION: 73 case MAILMIME_FIELD_DESCRIPTION:
74 target.setDescription(field->fld_data.fld_description); 74 target.setDescription(field->fld_data.fld_description);
75 break; 75 break;
76 default: 76 default:
77 break; 77 break;
78 } 78 }
79 } 79 }
80 } 80 }
81} 81}
82 82
83void Genericwrapper::fillParameters(RecPart&target,clist*parameters) 83void Genericwrapper::fillParameters(RecPart&target,clist*parameters)
84{ 84{
85 if (!parameters) {return;} 85 if (!parameters) {return;}
86 clistcell*current=0; 86 clistcell*current=0;
87 mailmime_parameter*param; 87 mailmime_parameter*param;
88 for (current=clist_begin(parameters);current!=0;current=clist_next(current)) { 88 for (current=clist_begin(parameters);current!=0;current=clist_next(current)) {
89 param = (mailmime_parameter*)current->data; 89 param = (mailmime_parameter*)current->data;
90 if (param) { 90 if (param) {
91 target.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); 91 target.addParameter(QString(param->pa_name).lower(),QString(param->pa_value));
92 } 92 }
93 } 93 }
94} 94}
95 95
96QString Genericwrapper::getencoding(mailmime_mechanism*aEnc) 96QString Genericwrapper::getencoding(mailmime_mechanism*aEnc)
97{ 97{
98 QString enc="7bit"; 98 QString enc="7bit";
99 if (!aEnc) return enc; 99 if (!aEnc) return enc;
100 switch(aEnc->enc_type) { 100 switch(aEnc->enc_type) {
101 case MAILMIME_MECHANISM_7BIT: 101 case MAILMIME_MECHANISM_7BIT:
102 enc = "7bit"; 102 enc = "7bit";
103 break; 103 break;
104 case MAILMIME_MECHANISM_8BIT: 104 case MAILMIME_MECHANISM_8BIT:
105 enc = "8bit"; 105 enc = "8bit";
106 break; 106 break;
107 case MAILMIME_MECHANISM_BINARY: 107 case MAILMIME_MECHANISM_BINARY:
108 enc = "binary"; 108 enc = "binary";
109 break; 109 break;
110 case MAILMIME_MECHANISM_QUOTED_PRINTABLE: 110 case MAILMIME_MECHANISM_QUOTED_PRINTABLE:
111 enc = "quoted-printable"; 111 enc = "quoted-printable";
112 break; 112 break;
113 case MAILMIME_MECHANISM_BASE64: 113 case MAILMIME_MECHANISM_BASE64:
114 enc = "base64"; 114 enc = "base64";
115 break; 115 break;
116 case MAILMIME_MECHANISM_TOKEN: 116 case MAILMIME_MECHANISM_TOKEN:
117 default: 117 default:
118 if (aEnc->enc_token) { 118 if (aEnc->enc_token) {
119 enc = QString(aEnc->enc_token); 119 enc = QString(aEnc->enc_token);
120 } 120 }
121 break; 121 break;
122 } 122 }
123 return enc; 123 return enc;
124} 124}
125 125
126void Genericwrapper::traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count) 126void Genericwrapper::traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count)
127{ 127{
128 if (current_rec >= 10) { 128 if (current_rec >= 10) {
129 qDebug("too deep recursion!"); 129 qDebug("too deep recursion!");
130 } 130 }
131 if (!message || !mime) { 131 if (!message || !mime) {
132 return; 132 return;
133 } 133 }
134 int r; 134 int r;
135 char*data = 0; 135 char*data = 0;
136 size_t len; 136 size_t len;
137 clistiter * cur = 0; 137 clistiter * cur = 0;
138 QString b; 138 QString b;
139 RecPart part; 139 RecPart part;
140 140
141 //current_count;
142
143 switch (mime->mm_type) { 141 switch (mime->mm_type) {
144 case MAILMIME_SINGLE: 142 case MAILMIME_SINGLE:
145 { 143 {
146 QValueList<int>countlist = recList; 144 QValueList<int>countlist = recList;
147 countlist.append(current_count); 145 countlist.append(current_count);
148 r = mailmessage_fetch_section(message,mime,&data,&len); 146 r = mailmessage_fetch_section(message,mime,&data,&len);
149 part.setSize(len); 147 part.setSize(len);
150 part.setPositionlist(countlist); 148 part.setPositionlist(countlist);
151 b = gen_attachment_id(); 149 b = gen_attachment_id();
152 part.setIdentifier(b); 150 part.setIdentifier(b);
153 fillSingleBody(part,message,mime); 151 fillSingleBody(part,message,mime);
154 if (part.Type()=="text" && target.Bodytext().isNull()) { 152 if (part.Type()=="text" && target.Bodytext().isNull()) {
155 encodedString*r = new encodedString(); 153 encodedString*r = new encodedString();
156 r->setContent(data,len); 154 r->setContent(data,len);
157 encodedString*res = decode_String(r,part.Encoding()); 155 encodedString*res = decode_String(r,part.Encoding());
156 if (countlist.count()>2) {
157 bodyCache[b]=r;
158 target.addPart(part);
159 } else {
160 delete r;
161 }
158 b = QString(res->Content()); 162 b = QString(res->Content());
159 delete r;
160 delete res; 163 delete res;
161 target.setBodytext(b); 164 target.setBodytext(b);
162 target.setDescription(part); 165 target.setDescription(part);
163 } else { 166 } else {
164 bodyCache[b]=new encodedString(data,len); 167 bodyCache[b]=new encodedString(data,len);
165 target.addPart(part); 168 target.addPart(part);
166 } 169 }
167 } 170 }
168 break; 171 break;
169 case MAILMIME_MULTIPLE: 172 case MAILMIME_MULTIPLE:
170 { 173 {
171 unsigned int ccount = current_count; 174 unsigned int ccount = 1;
175 mailmime*cbody=0;
176 QValueList<int>countlist = recList;
172 for (cur = clist_begin(mime->mm_data.mm_multipart.mm_mp_list) ; cur != NULL ; cur = clist_next(cur)) { 177 for (cur = clist_begin(mime->mm_data.mm_multipart.mm_mp_list) ; cur != NULL ; cur = clist_next(cur)) {
173 traverseBody(target,message, (mailmime*)clist_content(cur),recList,current_rec+1,ccount); 178 cbody = (mailmime*)clist_content(cur);
179 if (cbody->mm_type==MAILMIME_MULTIPLE) {
180 RecPart targetPart;
181 targetPart.setType("multipart");
182 countlist.append(current_count);
183 targetPart.setPositionlist(countlist);
184 target.addPart(targetPart);
185 }
186 traverseBody(target,message, cbody,countlist,current_rec+1,ccount);
187 if (cbody->mm_type==MAILMIME_MULTIPLE) {
188 countlist = recList;
189 }
174 ++ccount; 190 ++ccount;
175 } 191 }
176 } 192 }
177 break; 193 break;
178 case MAILMIME_MESSAGE: 194 case MAILMIME_MESSAGE:
179 { 195 {
180 QValueList<int>countlist = recList; 196 QValueList<int>countlist = recList;
181 countlist.append(current_count); 197 countlist.append(current_count);
182 /* the own header is always at recursion 0 - we don't need that */ 198 /* the own header is always at recursion 0 - we don't need that */
183 if (current_rec > 0) { 199 if (current_rec > 0) {
184 part.setPositionlist(countlist); 200 part.setPositionlist(countlist);
185 r = mailmessage_fetch_section(message,mime,&data,&len); 201 r = mailmessage_fetch_section(message,mime,&data,&len);
186 part.setSize(len); 202 part.setSize(len);
187 part.setPositionlist(countlist); 203 part.setPositionlist(countlist);
188 b = gen_attachment_id(); 204 b = gen_attachment_id();
189 part.setIdentifier(b); 205 part.setIdentifier(b);
190 part.setType("message"); 206 part.setType("message");
191 part.setSubtype("rfc822"); 207 part.setSubtype("rfc822");
192 bodyCache[b]=new encodedString(data,len); 208 bodyCache[b]=new encodedString(data,len);
193 target.addPart(part); 209 target.addPart(part);
194 } 210 }
195 if (mime->mm_data.mm_message.mm_msg_mime != NULL) { 211 if (mime->mm_data.mm_message.mm_msg_mime != NULL) {
196 traverseBody(target,message,mime->mm_data.mm_message.mm_msg_mime,countlist,current_rec+1); 212 traverseBody(target,message,mime->mm_data.mm_message.mm_msg_mime,countlist,current_rec+1);
197 } 213 }
198 } 214 }
199 break; 215 break;
200 } 216 }
201} 217}
202 218
203RecBody Genericwrapper::parseMail( mailmessage * msg ) 219RecBody Genericwrapper::parseMail( mailmessage * msg )
204{ 220{
205 int err = MAILIMF_NO_ERROR; 221 int err = MAILIMF_NO_ERROR;
206 mailmime_single_fields fields; 222 mailmime_single_fields fields;
207 /* is bound to msg and will be freed there */ 223 /* is bound to msg and will be freed there */
208 mailmime * mime=0; 224 mailmime * mime=0;
209 RecBody body; 225 RecBody body;
210 memset(&fields, 0, sizeof(struct mailmime_single_fields)); 226 memset(&fields, 0, sizeof(struct mailmime_single_fields));
211 err = mailmessage_get_bodystructure(msg,&mime); 227 err = mailmessage_get_bodystructure(msg,&mime);
212 QValueList<int>recList; 228 QValueList<int>recList;
213 traverseBody(body,msg,mime,recList); 229 traverseBody(body,msg,mime,recList);
214 return body; 230 return body;
215} 231}
216 232
217RecMail *Genericwrapper::parseHeader( const char *header ) 233RecMail *Genericwrapper::parseHeader( const char *header )
218{ 234{
219 int err = MAILIMF_NO_ERROR; 235 int err = MAILIMF_NO_ERROR;
220 size_t curTok = 0; 236 size_t curTok = 0;
221 RecMail *mail = new RecMail(); 237 RecMail *mail = new RecMail();
222 mailimf_fields *fields = 0; 238 mailimf_fields *fields = 0;
223 mailimf_references * refs = 0; 239 mailimf_references * refs = 0;
224 mailimf_keywords*keys = 0; 240 mailimf_keywords*keys = 0;
225 QString status; 241 QString status;
226 QString value; 242 QString value;
227 QBitArray mFlags(7); 243 QBitArray mFlags(7);
228 244
229 err = mailimf_fields_parse( (char *) header, strlen( header ), &curTok, &fields ); 245 err = mailimf_fields_parse( (char *) header, strlen( header ), &curTok, &fields );
230 for ( clistiter *current = clist_begin( fields->fld_list ); current != NULL; current = current->next ) { 246 for ( clistiter *current = clist_begin( fields->fld_list ); current != NULL; current = current->next ) {
231 mailimf_field *field = (mailimf_field *) current->data; 247 mailimf_field *field = (mailimf_field *) current->data;
232 switch ( field->fld_type ) { 248 switch ( field->fld_type ) {
233 case MAILIMF_FIELD_FROM: 249 case MAILIMF_FIELD_FROM:
234 mail->setFrom( parseMailboxList( field->fld_data.fld_from->frm_mb_list ) ); 250 mail->setFrom( parseMailboxList( field->fld_data.fld_from->frm_mb_list ) );
235 break; 251 break;
236 case MAILIMF_FIELD_TO: 252 case MAILIMF_FIELD_TO:
237 mail->setTo( parseAddressList( field->fld_data.fld_to->to_addr_list ) ); 253 mail->setTo( parseAddressList( field->fld_data.fld_to->to_addr_list ) );
238 break; 254 break;
239 case MAILIMF_FIELD_CC: 255 case MAILIMF_FIELD_CC:
240 mail->setCC( parseAddressList( field->fld_data.fld_cc->cc_addr_list ) ); 256 mail->setCC( parseAddressList( field->fld_data.fld_cc->cc_addr_list ) );
241 break; 257 break;
242 case MAILIMF_FIELD_BCC: 258 case MAILIMF_FIELD_BCC:
243 mail->setBcc( parseAddressList( field->fld_data.fld_bcc->bcc_addr_list ) ); 259 mail->setBcc( parseAddressList( field->fld_data.fld_bcc->bcc_addr_list ) );
244 break; 260 break;
245 case MAILIMF_FIELD_SUBJECT: 261 case MAILIMF_FIELD_SUBJECT:
246 mail->setSubject(convert_String( field->fld_data.fld_subject->sbj_value ) ); 262 mail->setSubject(convert_String( field->fld_data.fld_subject->sbj_value ) );
247 break; 263 break;
248 case MAILIMF_FIELD_ORIG_DATE: 264 case MAILIMF_FIELD_ORIG_DATE:
249 mail->setDate( parseDateTime( field->fld_data.fld_orig_date->dt_date_time ) ); 265 mail->setDate( parseDateTime( field->fld_data.fld_orig_date->dt_date_time ) );
250 break; 266 break;
251 case MAILIMF_FIELD_MESSAGE_ID: 267 case MAILIMF_FIELD_MESSAGE_ID:
252 mail->setMsgid(QString(field->fld_data.fld_message_id->mid_value)); 268 mail->setMsgid(QString(field->fld_data.fld_message_id->mid_value));
253 break; 269 break;
254 case MAILIMF_FIELD_REFERENCES: 270 case MAILIMF_FIELD_REFERENCES:
255 refs = field->fld_data.fld_references; 271 refs = field->fld_data.fld_references;
256 if (refs && refs->mid_list && clist_count(refs->mid_list)) { 272 if (refs && refs->mid_list && clist_count(refs->mid_list)) {
257 char * text = (char*)refs->mid_list->first->data; 273 char * text = (char*)refs->mid_list->first->data;
258 mail->setReplyto(QString(text)); 274 mail->setReplyto(QString(text));
259 } 275 }
260 break; 276 break;
261 case MAILIMF_FIELD_KEYWORDS: 277 case MAILIMF_FIELD_KEYWORDS:
262 keys = field->fld_data.fld_keywords; 278 keys = field->fld_data.fld_keywords;
263 for (clistcell*cur = clist_begin(keys->kw_list);cur!=0;cur=clist_next(cur)) { 279 for (clistcell*cur = clist_begin(keys->kw_list);cur!=0;cur=clist_next(cur)) {
264 qDebug("Keyword: %s",(char*)cur->data); 280 qDebug("Keyword: %s",(char*)cur->data);
265 } 281 }
266 break; 282 break;
267 case MAILIMF_FIELD_OPTIONAL_FIELD: 283 case MAILIMF_FIELD_OPTIONAL_FIELD:
268 status = field->fld_data.fld_optional_field->fld_name; 284 status = field->fld_data.fld_optional_field->fld_name;
269 value = field->fld_data.fld_optional_field->fld_value; 285 value = field->fld_data.fld_optional_field->fld_value;
270 if (status.lower()=="status") { 286 if (status.lower()=="status") {
271 if (value.lower()=="ro") { 287 if (value.lower()=="ro") {
272 mFlags.setBit(FLAG_SEEN); 288 mFlags.setBit(FLAG_SEEN);
273 } 289 }
274 } else if (status.lower()=="x-status") { 290 } else if (status.lower()=="x-status") {
275 qDebug("X-Status: %s",value.latin1()); 291 qDebug("X-Status: %s",value.latin1());
276 if (value.lower()=="a") { 292 if (value.lower()=="a") {
277 mFlags.setBit(FLAG_ANSWERED); 293 mFlags.setBit(FLAG_ANSWERED);
278 } 294 }
279 } else { 295 } else {
280// qDebug("Optionales feld: %s -> %s)",field->fld_data.fld_optional_field->fld_name, 296// qDebug("Optionales feld: %s -> %s)",field->fld_data.fld_optional_field->fld_name,
281// field->fld_data.fld_optional_field->fld_value); 297// field->fld_data.fld_optional_field->fld_value);
282 } 298 }
283 break; 299 break;
284 default: 300 default:
285 qDebug("Non parsed field"); 301 qDebug("Non parsed field");
286 break; 302 break;
287 } 303 }
288 } 304 }
289 if (fields) mailimf_fields_free(fields); 305 if (fields) mailimf_fields_free(fields);
290 mail->setFlags(mFlags); 306 mail->setFlags(mFlags);
291 return mail; 307 return mail;
292} 308}
293 309
294QString Genericwrapper::parseDateTime( mailimf_date_time *date ) 310QString Genericwrapper::parseDateTime( mailimf_date_time *date )
295{ 311{
296 char tmp[23]; 312 char tmp[23];
297 313
298 snprintf( tmp, 23, "%02i.%02i.%04i %02i:%02i:%02i %+05i", 314 snprintf( tmp, 23, "%02i.%02i.%04i %02i:%02i:%02i %+05i",
299 date->dt_day, date->dt_month, date->dt_year, date->dt_hour, date->dt_min, date->dt_sec, date->dt_zone ); 315 date->dt_day, date->dt_month, date->dt_year, date->dt_hour, date->dt_min, date->dt_sec, date->dt_zone );
300 316
301 return QString( tmp ); 317 return QString( tmp );
302} 318}
303 319
304QString Genericwrapper::parseAddressList( mailimf_address_list *list ) 320QString Genericwrapper::parseAddressList( mailimf_address_list *list )
305{ 321{
306 QString result( "" ); 322 QString result( "" );
307 323
308 bool first = true; 324 bool first = true;
309 if (list == 0) return result; 325 if (list == 0) return result;
310 for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) { 326 for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) {
311 mailimf_address *addr = (mailimf_address *) current->data; 327 mailimf_address *addr = (mailimf_address *) current->data;
312 328
313 if ( !first ) { 329 if ( !first ) {
314 result.append( "," ); 330 result.append( "," );
315 } else { 331 } else {
316 first = false; 332 first = false;
317 } 333 }
318 334
319 switch ( addr->ad_type ) { 335 switch ( addr->ad_type ) {
320 case MAILIMF_ADDRESS_MAILBOX: 336 case MAILIMF_ADDRESS_MAILBOX:
321 result.append( parseMailbox( addr->ad_data.ad_mailbox ) ); 337 result.append( parseMailbox( addr->ad_data.ad_mailbox ) );
322 break; 338 break;
323 case MAILIMF_ADDRESS_GROUP: 339 case MAILIMF_ADDRESS_GROUP:
324 result.append( parseGroup( addr->ad_data.ad_group ) ); 340 result.append( parseGroup( addr->ad_data.ad_group ) );
325 break; 341 break;
326 default: 342 default:
327 qDebug( "Generic: unkown mailimf address type" ); 343 qDebug( "Generic: unkown mailimf address type" );
328 break; 344 break;
329 } 345 }
330 } 346 }
331 347
332 return result; 348 return result;
333} 349}
334 350
335QString Genericwrapper::parseGroup( mailimf_group *group ) 351QString Genericwrapper::parseGroup( mailimf_group *group )
336{ 352{
337 QString result( "" ); 353 QString result( "" );
338 354
339 result.append( group->grp_display_name ); 355 result.append( group->grp_display_name );
340 result.append( ": " ); 356 result.append( ": " );
341 357
342 if ( group->grp_mb_list != NULL ) { 358 if ( group->grp_mb_list != NULL ) {
343 result.append( parseMailboxList( group->grp_mb_list ) ); 359 result.append( parseMailboxList( group->grp_mb_list ) );
344 } 360 }
345 361
346 result.append( ";" ); 362 result.append( ";" );
347 363
348 return result; 364 return result;
349} 365}
350 366
351QString Genericwrapper::parseMailbox( mailimf_mailbox *box ) 367QString Genericwrapper::parseMailbox( mailimf_mailbox *box )
352{ 368{
353 QString result( "" ); 369 QString result( "" );
354 370
355 if ( box->mb_display_name == NULL ) { 371 if ( box->mb_display_name == NULL ) {
356 result.append( box->mb_addr_spec ); 372 result.append( box->mb_addr_spec );
357 } else { 373 } else {
358 result.append( convert_String(box->mb_display_name).latin1() ); 374 result.append( convert_String(box->mb_display_name).latin1() );
359 result.append( " <" ); 375 result.append( " <" );
360 result.append( box->mb_addr_spec ); 376 result.append( box->mb_addr_spec );
361 result.append( ">" ); 377 result.append( ">" );
362 } 378 }
363 379
364 return result; 380 return result;
365} 381}
diff --git a/noncore/net/mail/genericwrapper.h b/noncore/net/mail/genericwrapper.h
index c00d864..32b75c8 100644
--- a/noncore/net/mail/genericwrapper.h
+++ b/noncore/net/mail/genericwrapper.h
@@ -1,59 +1,59 @@
1#ifndef __GENERIC_WRAPPER_H 1#ifndef __GENERIC_WRAPPER_H
2#define __GENERIC_WRAPPER_H 2#define __GENERIC_WRAPPER_H
3 3
4#include "abstractmail.h" 4#include "abstractmail.h"
5#include <qmap.h> 5#include <qmap.h>
6#include <qstring.h> 6#include <qstring.h>
7#include <libetpan/clist.h> 7#include <libetpan/clist.h>
8 8
9class RecMail; 9class RecMail;
10class RecBody; 10class RecBody;
11class encodedString; 11class encodedString;
12struct mailpop3; 12struct mailpop3;
13struct mailmessage; 13struct mailmessage;
14struct mailmime; 14struct mailmime;
15struct mailmime_mechanism; 15struct mailmime_mechanism;
16struct mailimf_mailbox_list; 16struct mailimf_mailbox_list;
17struct mailimf_mailbox; 17struct mailimf_mailbox;
18struct mailimf_date_time; 18struct mailimf_date_time;
19struct mailimf_group; 19struct mailimf_group;
20struct mailimf_address_list; 20struct mailimf_address_list;
21struct mailsession; 21struct mailsession;
22 22
23/* this class hold just the funs shared between 23/* this class hold just the funs shared between
24 * mbox and pop3 (later mh, too) mail access. 24 * mbox and pop3 (later mh, too) mail access.
25 * it is not desigend to make a instance of it! 25 * it is not desigend to make a instance of it!
26 */ 26 */
27class Genericwrapper : public AbstractMail 27class Genericwrapper : public AbstractMail
28{ 28{
29 Q_OBJECT 29 Q_OBJECT
30public: 30public:
31 Genericwrapper(); 31 Genericwrapper();
32 virtual ~Genericwrapper(); 32 virtual ~Genericwrapper();
33 33
34 virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); 34 virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part);
35 virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); 35 virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part);
36 virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); 36 virtual QString fetchTextPart(const RecMail&mail,const RecPart&part);
37 virtual void cleanMimeCache(); 37 virtual void cleanMimeCache();
38 38
39protected: 39protected:
40 RecMail *parseHeader( const char *header ); 40 RecMail *parseHeader( const char *header );
41 RecBody parseMail( mailmessage * msg ); 41 RecBody parseMail( mailmessage * msg );
42 QString parseMailboxList( mailimf_mailbox_list *list ); 42 QString parseMailboxList( mailimf_mailbox_list *list );
43 QString parseMailbox( mailimf_mailbox *box ); 43 QString parseMailbox( mailimf_mailbox *box );
44 QString parseGroup( mailimf_group *group ); 44 QString parseGroup( mailimf_group *group );
45 QString parseAddressList( mailimf_address_list *list ); 45 QString parseAddressList( mailimf_address_list *list );
46 QString parseDateTime( mailimf_date_time *date ); 46 QString parseDateTime( mailimf_date_time *date );
47 47
48 void traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rek=0,int current_count=0); 48 void traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rek=0,int current_count=1);
49 static void fillSingleBody(RecPart&target,mailmessage*message,mailmime*mime); 49 static void fillSingleBody(RecPart&target,mailmessage*message,mailmime*mime);
50 static void fillParameters(RecPart&target,clist*parameters); 50 static void fillParameters(RecPart&target,clist*parameters);
51 static QString getencoding(mailmime_mechanism*aEnc); 51 static QString getencoding(mailmime_mechanism*aEnc);
52 virtual void parseList(QList<RecMail> &target,mailsession*session,const QString&mailbox); 52 virtual void parseList(QList<RecMail> &target,mailsession*session,const QString&mailbox);
53 53
54 QString msgTempName; 54 QString msgTempName;
55 unsigned int last_msg_id; 55 unsigned int last_msg_id;
56 QMap<QString,encodedString*> bodyCache; 56 QMap<QString,encodedString*> bodyCache;
57}; 57};
58 58
59#endif 59#endif
diff --git a/noncore/net/mail/libmailwrapper/genericwrapper.cpp b/noncore/net/mail/libmailwrapper/genericwrapper.cpp
index 62116ba..714396b 100644
--- a/noncore/net/mail/libmailwrapper/genericwrapper.cpp
+++ b/noncore/net/mail/libmailwrapper/genericwrapper.cpp
@@ -1,365 +1,381 @@
1#include "genericwrapper.h" 1#include "genericwrapper.h"
2#include <libetpan/libetpan.h> 2#include <libetpan/libetpan.h>
3#include "mailtypes.h" 3#include "mailtypes.h"
4 4
5Genericwrapper::Genericwrapper() 5Genericwrapper::Genericwrapper()
6 : AbstractMail() 6 : AbstractMail()
7{ 7{
8 bodyCache.clear(); 8 bodyCache.clear();
9} 9}
10 10
11Genericwrapper::~Genericwrapper() 11Genericwrapper::~Genericwrapper()
12{ 12{
13 cleanMimeCache(); 13 cleanMimeCache();
14} 14}
15 15
16void Genericwrapper::fillSingleBody(RecPart&target,mailmessage*,mailmime*mime) 16void Genericwrapper::fillSingleBody(RecPart&target,mailmessage*,mailmime*mime)
17{ 17{
18 if (!mime) { 18 if (!mime) {
19 return; 19 return;
20 } 20 }
21 mailmime_field*field = 0; 21 mailmime_field*field = 0;
22 mailmime_single_fields fields; 22 mailmime_single_fields fields;
23 memset(&fields, 0, sizeof(struct mailmime_single_fields)); 23 memset(&fields, 0, sizeof(struct mailmime_single_fields));
24 if (mime->mm_mime_fields != NULL) { 24 if (mime->mm_mime_fields != NULL) {
25 mailmime_single_fields_init(&fields, mime->mm_mime_fields, 25 mailmime_single_fields_init(&fields, mime->mm_mime_fields,
26 mime->mm_content_type); 26 mime->mm_content_type);
27 } 27 }
28 28
29 mailmime_content*type = fields.fld_content; 29 mailmime_content*type = fields.fld_content;
30 clistcell*current; 30 clistcell*current;
31 if (!type) { 31 if (!type) {
32 target.setType("text"); 32 target.setType("text");
33 target.setSubtype("plain"); 33 target.setSubtype("plain");
34 } else { 34 } else {
35 target.setSubtype(type->ct_subtype); 35 target.setSubtype(type->ct_subtype);
36 switch(type->ct_type->tp_data.tp_discrete_type->dt_type) { 36 switch(type->ct_type->tp_data.tp_discrete_type->dt_type) {
37 case MAILMIME_DISCRETE_TYPE_TEXT: 37 case MAILMIME_DISCRETE_TYPE_TEXT:
38 target.setType("text"); 38 target.setType("text");
39 break; 39 break;
40 case MAILMIME_DISCRETE_TYPE_IMAGE: 40 case MAILMIME_DISCRETE_TYPE_IMAGE:
41 target.setType("image"); 41 target.setType("image");
42 break; 42 break;
43 case MAILMIME_DISCRETE_TYPE_AUDIO: 43 case MAILMIME_DISCRETE_TYPE_AUDIO:
44 target.setType("audio"); 44 target.setType("audio");
45 break; 45 break;
46 case MAILMIME_DISCRETE_TYPE_VIDEO: 46 case MAILMIME_DISCRETE_TYPE_VIDEO:
47 target.setType("video"); 47 target.setType("video");
48 break; 48 break;
49 case MAILMIME_DISCRETE_TYPE_APPLICATION: 49 case MAILMIME_DISCRETE_TYPE_APPLICATION:
50 target.setType("application"); 50 target.setType("application");
51 break; 51 break;
52 case MAILMIME_DISCRETE_TYPE_EXTENSION: 52 case MAILMIME_DISCRETE_TYPE_EXTENSION:
53 default: 53 default:
54 if (type->ct_type->tp_data.tp_discrete_type->dt_extension) { 54 if (type->ct_type->tp_data.tp_discrete_type->dt_extension) {
55 target.setType(type->ct_type->tp_data.tp_discrete_type->dt_extension); 55 target.setType(type->ct_type->tp_data.tp_discrete_type->dt_extension);
56 } 56 }
57 break; 57 break;
58 } 58 }
59 if (type->ct_parameters) { 59 if (type->ct_parameters) {
60 fillParameters(target,type->ct_parameters); 60 fillParameters(target,type->ct_parameters);
61 } 61 }
62 } 62 }
63 if (mime->mm_mime_fields && mime->mm_mime_fields->fld_list) { 63 if (mime->mm_mime_fields && mime->mm_mime_fields->fld_list) {
64 for (current=clist_begin(mime->mm_mime_fields->fld_list);current!=0;current=clist_next(current)) { 64 for (current=clist_begin(mime->mm_mime_fields->fld_list);current!=0;current=clist_next(current)) {
65 field = (mailmime_field*)current->data; 65 field = (mailmime_field*)current->data;
66 switch(field->fld_type) { 66 switch(field->fld_type) {
67 case MAILMIME_FIELD_TRANSFER_ENCODING: 67 case MAILMIME_FIELD_TRANSFER_ENCODING:
68 target.setEncoding(getencoding(field->fld_data.fld_encoding)); 68 target.setEncoding(getencoding(field->fld_data.fld_encoding));
69 break; 69 break;
70 case MAILMIME_FIELD_ID: 70 case MAILMIME_FIELD_ID:
71 target.setIdentifier(field->fld_data.fld_id); 71 target.setIdentifier(field->fld_data.fld_id);
72 break; 72 break;
73 case MAILMIME_FIELD_DESCRIPTION: 73 case MAILMIME_FIELD_DESCRIPTION:
74 target.setDescription(field->fld_data.fld_description); 74 target.setDescription(field->fld_data.fld_description);
75 break; 75 break;
76 default: 76 default:
77 break; 77 break;
78 } 78 }
79 } 79 }
80 } 80 }
81} 81}
82 82
83void Genericwrapper::fillParameters(RecPart&target,clist*parameters) 83void Genericwrapper::fillParameters(RecPart&target,clist*parameters)
84{ 84{
85 if (!parameters) {return;} 85 if (!parameters) {return;}
86 clistcell*current=0; 86 clistcell*current=0;
87 mailmime_parameter*param; 87 mailmime_parameter*param;
88 for (current=clist_begin(parameters);current!=0;current=clist_next(current)) { 88 for (current=clist_begin(parameters);current!=0;current=clist_next(current)) {
89 param = (mailmime_parameter*)current->data; 89 param = (mailmime_parameter*)current->data;
90 if (param) { 90 if (param) {
91 target.addParameter(QString(param->pa_name).lower(),QString(param->pa_value)); 91 target.addParameter(QString(param->pa_name).lower(),QString(param->pa_value));
92 } 92 }
93 } 93 }
94} 94}
95 95
96QString Genericwrapper::getencoding(mailmime_mechanism*aEnc) 96QString Genericwrapper::getencoding(mailmime_mechanism*aEnc)
97{ 97{
98 QString enc="7bit"; 98 QString enc="7bit";
99 if (!aEnc) return enc; 99 if (!aEnc) return enc;
100 switch(aEnc->enc_type) { 100 switch(aEnc->enc_type) {
101 case MAILMIME_MECHANISM_7BIT: 101 case MAILMIME_MECHANISM_7BIT:
102 enc = "7bit"; 102 enc = "7bit";
103 break; 103 break;
104 case MAILMIME_MECHANISM_8BIT: 104 case MAILMIME_MECHANISM_8BIT:
105 enc = "8bit"; 105 enc = "8bit";
106 break; 106 break;
107 case MAILMIME_MECHANISM_BINARY: 107 case MAILMIME_MECHANISM_BINARY:
108 enc = "binary"; 108 enc = "binary";
109 break; 109 break;
110 case MAILMIME_MECHANISM_QUOTED_PRINTABLE: 110 case MAILMIME_MECHANISM_QUOTED_PRINTABLE:
111 enc = "quoted-printable"; 111 enc = "quoted-printable";
112 break; 112 break;
113 case MAILMIME_MECHANISM_BASE64: 113 case MAILMIME_MECHANISM_BASE64:
114 enc = "base64"; 114 enc = "base64";
115 break; 115 break;
116 case MAILMIME_MECHANISM_TOKEN: 116 case MAILMIME_MECHANISM_TOKEN:
117 default: 117 default:
118 if (aEnc->enc_token) { 118 if (aEnc->enc_token) {
119 enc = QString(aEnc->enc_token); 119 enc = QString(aEnc->enc_token);
120 } 120 }
121 break; 121 break;
122 } 122 }
123 return enc; 123 return enc;
124} 124}
125 125
126void Genericwrapper::traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count) 126void Genericwrapper::traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rec,int current_count)
127{ 127{
128 if (current_rec >= 10) { 128 if (current_rec >= 10) {
129 qDebug("too deep recursion!"); 129 qDebug("too deep recursion!");
130 } 130 }
131 if (!message || !mime) { 131 if (!message || !mime) {
132 return; 132 return;
133 } 133 }
134 int r; 134 int r;
135 char*data = 0; 135 char*data = 0;
136 size_t len; 136 size_t len;
137 clistiter * cur = 0; 137 clistiter * cur = 0;
138 QString b; 138 QString b;
139 RecPart part; 139 RecPart part;
140 140
141 //current_count;
142
143 switch (mime->mm_type) { 141 switch (mime->mm_type) {
144 case MAILMIME_SINGLE: 142 case MAILMIME_SINGLE:
145 { 143 {
146 QValueList<int>countlist = recList; 144 QValueList<int>countlist = recList;
147 countlist.append(current_count); 145 countlist.append(current_count);
148 r = mailmessage_fetch_section(message,mime,&data,&len); 146 r = mailmessage_fetch_section(message,mime,&data,&len);
149 part.setSize(len); 147 part.setSize(len);
150 part.setPositionlist(countlist); 148 part.setPositionlist(countlist);
151 b = gen_attachment_id(); 149 b = gen_attachment_id();
152 part.setIdentifier(b); 150 part.setIdentifier(b);
153 fillSingleBody(part,message,mime); 151 fillSingleBody(part,message,mime);
154 if (part.Type()=="text" && target.Bodytext().isNull()) { 152 if (part.Type()=="text" && target.Bodytext().isNull()) {
155 encodedString*r = new encodedString(); 153 encodedString*r = new encodedString();
156 r->setContent(data,len); 154 r->setContent(data,len);
157 encodedString*res = decode_String(r,part.Encoding()); 155 encodedString*res = decode_String(r,part.Encoding());
156 if (countlist.count()>2) {
157 bodyCache[b]=r;
158 target.addPart(part);
159 } else {
160 delete r;
161 }
158 b = QString(res->Content()); 162 b = QString(res->Content());
159 delete r;
160 delete res; 163 delete res;
161 target.setBodytext(b); 164 target.setBodytext(b);
162 target.setDescription(part); 165 target.setDescription(part);
163 } else { 166 } else {
164 bodyCache[b]=new encodedString(data,len); 167 bodyCache[b]=new encodedString(data,len);
165 target.addPart(part); 168 target.addPart(part);
166 } 169 }
167 } 170 }
168 break; 171 break;
169 case MAILMIME_MULTIPLE: 172 case MAILMIME_MULTIPLE:
170 { 173 {
171 unsigned int ccount = current_count; 174 unsigned int ccount = 1;
175 mailmime*cbody=0;
176 QValueList<int>countlist = recList;
172 for (cur = clist_begin(mime->mm_data.mm_multipart.mm_mp_list) ; cur != NULL ; cur = clist_next(cur)) { 177 for (cur = clist_begin(mime->mm_data.mm_multipart.mm_mp_list) ; cur != NULL ; cur = clist_next(cur)) {
173 traverseBody(target,message, (mailmime*)clist_content(cur),recList,current_rec+1,ccount); 178 cbody = (mailmime*)clist_content(cur);
179 if (cbody->mm_type==MAILMIME_MULTIPLE) {
180 RecPart targetPart;
181 targetPart.setType("multipart");
182 countlist.append(current_count);
183 targetPart.setPositionlist(countlist);
184 target.addPart(targetPart);
185 }
186 traverseBody(target,message, cbody,countlist,current_rec+1,ccount);
187 if (cbody->mm_type==MAILMIME_MULTIPLE) {
188 countlist = recList;
189 }
174 ++ccount; 190 ++ccount;
175 } 191 }
176 } 192 }
177 break; 193 break;
178 case MAILMIME_MESSAGE: 194 case MAILMIME_MESSAGE:
179 { 195 {
180 QValueList<int>countlist = recList; 196 QValueList<int>countlist = recList;
181 countlist.append(current_count); 197 countlist.append(current_count);
182 /* the own header is always at recursion 0 - we don't need that */ 198 /* the own header is always at recursion 0 - we don't need that */
183 if (current_rec > 0) { 199 if (current_rec > 0) {
184 part.setPositionlist(countlist); 200 part.setPositionlist(countlist);
185 r = mailmessage_fetch_section(message,mime,&data,&len); 201 r = mailmessage_fetch_section(message,mime,&data,&len);
186 part.setSize(len); 202 part.setSize(len);
187 part.setPositionlist(countlist); 203 part.setPositionlist(countlist);
188 b = gen_attachment_id(); 204 b = gen_attachment_id();
189 part.setIdentifier(b); 205 part.setIdentifier(b);
190 part.setType("message"); 206 part.setType("message");
191 part.setSubtype("rfc822"); 207 part.setSubtype("rfc822");
192 bodyCache[b]=new encodedString(data,len); 208 bodyCache[b]=new encodedString(data,len);
193 target.addPart(part); 209 target.addPart(part);
194 } 210 }
195 if (mime->mm_data.mm_message.mm_msg_mime != NULL) { 211 if (mime->mm_data.mm_message.mm_msg_mime != NULL) {
196 traverseBody(target,message,mime->mm_data.mm_message.mm_msg_mime,countlist,current_rec+1); 212 traverseBody(target,message,mime->mm_data.mm_message.mm_msg_mime,countlist,current_rec+1);
197 } 213 }
198 } 214 }
199 break; 215 break;
200 } 216 }
201} 217}
202 218
203RecBody Genericwrapper::parseMail( mailmessage * msg ) 219RecBody Genericwrapper::parseMail( mailmessage * msg )
204{ 220{
205 int err = MAILIMF_NO_ERROR; 221 int err = MAILIMF_NO_ERROR;
206 mailmime_single_fields fields; 222 mailmime_single_fields fields;
207 /* is bound to msg and will be freed there */ 223 /* is bound to msg and will be freed there */
208 mailmime * mime=0; 224 mailmime * mime=0;
209 RecBody body; 225 RecBody body;
210 memset(&fields, 0, sizeof(struct mailmime_single_fields)); 226 memset(&fields, 0, sizeof(struct mailmime_single_fields));
211 err = mailmessage_get_bodystructure(msg,&mime); 227 err = mailmessage_get_bodystructure(msg,&mime);
212 QValueList<int>recList; 228 QValueList<int>recList;
213 traverseBody(body,msg,mime,recList); 229 traverseBody(body,msg,mime,recList);
214 return body; 230 return body;
215} 231}
216 232
217RecMail *Genericwrapper::parseHeader( const char *header ) 233RecMail *Genericwrapper::parseHeader( const char *header )
218{ 234{
219 int err = MAILIMF_NO_ERROR; 235 int err = MAILIMF_NO_ERROR;
220 size_t curTok = 0; 236 size_t curTok = 0;
221 RecMail *mail = new RecMail(); 237 RecMail *mail = new RecMail();
222 mailimf_fields *fields = 0; 238 mailimf_fields *fields = 0;
223 mailimf_references * refs = 0; 239 mailimf_references * refs = 0;
224 mailimf_keywords*keys = 0; 240 mailimf_keywords*keys = 0;
225 QString status; 241 QString status;
226 QString value; 242 QString value;
227 QBitArray mFlags(7); 243 QBitArray mFlags(7);
228 244
229 err = mailimf_fields_parse( (char *) header, strlen( header ), &curTok, &fields ); 245 err = mailimf_fields_parse( (char *) header, strlen( header ), &curTok, &fields );
230 for ( clistiter *current = clist_begin( fields->fld_list ); current != NULL; current = current->next ) { 246 for ( clistiter *current = clist_begin( fields->fld_list ); current != NULL; current = current->next ) {
231 mailimf_field *field = (mailimf_field *) current->data; 247 mailimf_field *field = (mailimf_field *) current->data;
232 switch ( field->fld_type ) { 248 switch ( field->fld_type ) {
233 case MAILIMF_FIELD_FROM: 249 case MAILIMF_FIELD_FROM:
234 mail->setFrom( parseMailboxList( field->fld_data.fld_from->frm_mb_list ) ); 250 mail->setFrom( parseMailboxList( field->fld_data.fld_from->frm_mb_list ) );
235 break; 251 break;
236 case MAILIMF_FIELD_TO: 252 case MAILIMF_FIELD_TO:
237 mail->setTo( parseAddressList( field->fld_data.fld_to->to_addr_list ) ); 253 mail->setTo( parseAddressList( field->fld_data.fld_to->to_addr_list ) );
238 break; 254 break;
239 case MAILIMF_FIELD_CC: 255 case MAILIMF_FIELD_CC:
240 mail->setCC( parseAddressList( field->fld_data.fld_cc->cc_addr_list ) ); 256 mail->setCC( parseAddressList( field->fld_data.fld_cc->cc_addr_list ) );
241 break; 257 break;
242 case MAILIMF_FIELD_BCC: 258 case MAILIMF_FIELD_BCC:
243 mail->setBcc( parseAddressList( field->fld_data.fld_bcc->bcc_addr_list ) ); 259 mail->setBcc( parseAddressList( field->fld_data.fld_bcc->bcc_addr_list ) );
244 break; 260 break;
245 case MAILIMF_FIELD_SUBJECT: 261 case MAILIMF_FIELD_SUBJECT:
246 mail->setSubject(convert_String( field->fld_data.fld_subject->sbj_value ) ); 262 mail->setSubject(convert_String( field->fld_data.fld_subject->sbj_value ) );
247 break; 263 break;
248 case MAILIMF_FIELD_ORIG_DATE: 264 case MAILIMF_FIELD_ORIG_DATE:
249 mail->setDate( parseDateTime( field->fld_data.fld_orig_date->dt_date_time ) ); 265 mail->setDate( parseDateTime( field->fld_data.fld_orig_date->dt_date_time ) );
250 break; 266 break;
251 case MAILIMF_FIELD_MESSAGE_ID: 267 case MAILIMF_FIELD_MESSAGE_ID:
252 mail->setMsgid(QString(field->fld_data.fld_message_id->mid_value)); 268 mail->setMsgid(QString(field->fld_data.fld_message_id->mid_value));
253 break; 269 break;
254 case MAILIMF_FIELD_REFERENCES: 270 case MAILIMF_FIELD_REFERENCES:
255 refs = field->fld_data.fld_references; 271 refs = field->fld_data.fld_references;
256 if (refs && refs->mid_list && clist_count(refs->mid_list)) { 272 if (refs && refs->mid_list && clist_count(refs->mid_list)) {
257 char * text = (char*)refs->mid_list->first->data; 273 char * text = (char*)refs->mid_list->first->data;
258 mail->setReplyto(QString(text)); 274 mail->setReplyto(QString(text));
259 } 275 }
260 break; 276 break;
261 case MAILIMF_FIELD_KEYWORDS: 277 case MAILIMF_FIELD_KEYWORDS:
262 keys = field->fld_data.fld_keywords; 278 keys = field->fld_data.fld_keywords;
263 for (clistcell*cur = clist_begin(keys->kw_list);cur!=0;cur=clist_next(cur)) { 279 for (clistcell*cur = clist_begin(keys->kw_list);cur!=0;cur=clist_next(cur)) {
264 qDebug("Keyword: %s",(char*)cur->data); 280 qDebug("Keyword: %s",(char*)cur->data);
265 } 281 }
266 break; 282 break;
267 case MAILIMF_FIELD_OPTIONAL_FIELD: 283 case MAILIMF_FIELD_OPTIONAL_FIELD:
268 status = field->fld_data.fld_optional_field->fld_name; 284 status = field->fld_data.fld_optional_field->fld_name;
269 value = field->fld_data.fld_optional_field->fld_value; 285 value = field->fld_data.fld_optional_field->fld_value;
270 if (status.lower()=="status") { 286 if (status.lower()=="status") {
271 if (value.lower()=="ro") { 287 if (value.lower()=="ro") {
272 mFlags.setBit(FLAG_SEEN); 288 mFlags.setBit(FLAG_SEEN);
273 } 289 }
274 } else if (status.lower()=="x-status") { 290 } else if (status.lower()=="x-status") {
275 qDebug("X-Status: %s",value.latin1()); 291 qDebug("X-Status: %s",value.latin1());
276 if (value.lower()=="a") { 292 if (value.lower()=="a") {
277 mFlags.setBit(FLAG_ANSWERED); 293 mFlags.setBit(FLAG_ANSWERED);
278 } 294 }
279 } else { 295 } else {
280// qDebug("Optionales feld: %s -> %s)",field->fld_data.fld_optional_field->fld_name, 296// qDebug("Optionales feld: %s -> %s)",field->fld_data.fld_optional_field->fld_name,
281// field->fld_data.fld_optional_field->fld_value); 297// field->fld_data.fld_optional_field->fld_value);
282 } 298 }
283 break; 299 break;
284 default: 300 default:
285 qDebug("Non parsed field"); 301 qDebug("Non parsed field");
286 break; 302 break;
287 } 303 }
288 } 304 }
289 if (fields) mailimf_fields_free(fields); 305 if (fields) mailimf_fields_free(fields);
290 mail->setFlags(mFlags); 306 mail->setFlags(mFlags);
291 return mail; 307 return mail;
292} 308}
293 309
294QString Genericwrapper::parseDateTime( mailimf_date_time *date ) 310QString Genericwrapper::parseDateTime( mailimf_date_time *date )
295{ 311{
296 char tmp[23]; 312 char tmp[23];
297 313
298 snprintf( tmp, 23, "%02i.%02i.%04i %02i:%02i:%02i %+05i", 314 snprintf( tmp, 23, "%02i.%02i.%04i %02i:%02i:%02i %+05i",
299 date->dt_day, date->dt_month, date->dt_year, date->dt_hour, date->dt_min, date->dt_sec, date->dt_zone ); 315 date->dt_day, date->dt_month, date->dt_year, date->dt_hour, date->dt_min, date->dt_sec, date->dt_zone );
300 316
301 return QString( tmp ); 317 return QString( tmp );
302} 318}
303 319
304QString Genericwrapper::parseAddressList( mailimf_address_list *list ) 320QString Genericwrapper::parseAddressList( mailimf_address_list *list )
305{ 321{
306 QString result( "" ); 322 QString result( "" );
307 323
308 bool first = true; 324 bool first = true;
309 if (list == 0) return result; 325 if (list == 0) return result;
310 for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) { 326 for ( clistiter *current = clist_begin( list->ad_list ); current != NULL; current = current->next ) {
311 mailimf_address *addr = (mailimf_address *) current->data; 327 mailimf_address *addr = (mailimf_address *) current->data;
312 328
313 if ( !first ) { 329 if ( !first ) {
314 result.append( "," ); 330 result.append( "," );
315 } else { 331 } else {
316 first = false; 332 first = false;
317 } 333 }
318 334
319 switch ( addr->ad_type ) { 335 switch ( addr->ad_type ) {
320 case MAILIMF_ADDRESS_MAILBOX: 336 case MAILIMF_ADDRESS_MAILBOX:
321 result.append( parseMailbox( addr->ad_data.ad_mailbox ) ); 337 result.append( parseMailbox( addr->ad_data.ad_mailbox ) );
322 break; 338 break;
323 case MAILIMF_ADDRESS_GROUP: 339 case MAILIMF_ADDRESS_GROUP:
324 result.append( parseGroup( addr->ad_data.ad_group ) ); 340 result.append( parseGroup( addr->ad_data.ad_group ) );
325 break; 341 break;
326 default: 342 default:
327 qDebug( "Generic: unkown mailimf address type" ); 343 qDebug( "Generic: unkown mailimf address type" );
328 break; 344 break;
329 } 345 }
330 } 346 }
331 347
332 return result; 348 return result;
333} 349}
334 350
335QString Genericwrapper::parseGroup( mailimf_group *group ) 351QString Genericwrapper::parseGroup( mailimf_group *group )
336{ 352{
337 QString result( "" ); 353 QString result( "" );
338 354
339 result.append( group->grp_display_name ); 355 result.append( group->grp_display_name );
340 result.append( ": " ); 356 result.append( ": " );
341 357
342 if ( group->grp_mb_list != NULL ) { 358 if ( group->grp_mb_list != NULL ) {
343 result.append( parseMailboxList( group->grp_mb_list ) ); 359 result.append( parseMailboxList( group->grp_mb_list ) );
344 } 360 }
345 361
346 result.append( ";" ); 362 result.append( ";" );
347 363
348 return result; 364 return result;
349} 365}
350 366
351QString Genericwrapper::parseMailbox( mailimf_mailbox *box ) 367QString Genericwrapper::parseMailbox( mailimf_mailbox *box )
352{ 368{
353 QString result( "" ); 369 QString result( "" );
354 370
355 if ( box->mb_display_name == NULL ) { 371 if ( box->mb_display_name == NULL ) {
356 result.append( box->mb_addr_spec ); 372 result.append( box->mb_addr_spec );
357 } else { 373 } else {
358 result.append( convert_String(box->mb_display_name).latin1() ); 374 result.append( convert_String(box->mb_display_name).latin1() );
359 result.append( " <" ); 375 result.append( " <" );
360 result.append( box->mb_addr_spec ); 376 result.append( box->mb_addr_spec );
361 result.append( ">" ); 377 result.append( ">" );
362 } 378 }
363 379
364 return result; 380 return result;
365} 381}
diff --git a/noncore/net/mail/libmailwrapper/genericwrapper.h b/noncore/net/mail/libmailwrapper/genericwrapper.h
index c00d864..32b75c8 100644
--- a/noncore/net/mail/libmailwrapper/genericwrapper.h
+++ b/noncore/net/mail/libmailwrapper/genericwrapper.h
@@ -1,59 +1,59 @@
1#ifndef __GENERIC_WRAPPER_H 1#ifndef __GENERIC_WRAPPER_H
2#define __GENERIC_WRAPPER_H 2#define __GENERIC_WRAPPER_H
3 3
4#include "abstractmail.h" 4#include "abstractmail.h"
5#include <qmap.h> 5#include <qmap.h>
6#include <qstring.h> 6#include <qstring.h>
7#include <libetpan/clist.h> 7#include <libetpan/clist.h>
8 8
9class RecMail; 9class RecMail;
10class RecBody; 10class RecBody;
11class encodedString; 11class encodedString;
12struct mailpop3; 12struct mailpop3;
13struct mailmessage; 13struct mailmessage;
14struct mailmime; 14struct mailmime;
15struct mailmime_mechanism; 15struct mailmime_mechanism;
16struct mailimf_mailbox_list; 16struct mailimf_mailbox_list;
17struct mailimf_mailbox; 17struct mailimf_mailbox;
18struct mailimf_date_time; 18struct mailimf_date_time;
19struct mailimf_group; 19struct mailimf_group;
20struct mailimf_address_list; 20struct mailimf_address_list;
21struct mailsession; 21struct mailsession;
22 22
23/* this class hold just the funs shared between 23/* this class hold just the funs shared between
24 * mbox and pop3 (later mh, too) mail access. 24 * mbox and pop3 (later mh, too) mail access.
25 * it is not desigend to make a instance of it! 25 * it is not desigend to make a instance of it!
26 */ 26 */
27class Genericwrapper : public AbstractMail 27class Genericwrapper : public AbstractMail
28{ 28{
29 Q_OBJECT 29 Q_OBJECT
30public: 30public:
31 Genericwrapper(); 31 Genericwrapper();
32 virtual ~Genericwrapper(); 32 virtual ~Genericwrapper();
33 33
34 virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part); 34 virtual encodedString* fetchDecodedPart(const RecMail&mail,const RecPart&part);
35 virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part); 35 virtual encodedString* fetchRawPart(const RecMail&mail,const RecPart&part);
36 virtual QString fetchTextPart(const RecMail&mail,const RecPart&part); 36 virtual QString fetchTextPart(const RecMail&mail,const RecPart&part);
37 virtual void cleanMimeCache(); 37 virtual void cleanMimeCache();
38 38
39protected: 39protected:
40 RecMail *parseHeader( const char *header ); 40 RecMail *parseHeader( const char *header );
41 RecBody parseMail( mailmessage * msg ); 41 RecBody parseMail( mailmessage * msg );
42 QString parseMailboxList( mailimf_mailbox_list *list ); 42 QString parseMailboxList( mailimf_mailbox_list *list );
43 QString parseMailbox( mailimf_mailbox *box ); 43 QString parseMailbox( mailimf_mailbox *box );
44 QString parseGroup( mailimf_group *group ); 44 QString parseGroup( mailimf_group *group );
45 QString parseAddressList( mailimf_address_list *list ); 45 QString parseAddressList( mailimf_address_list *list );
46 QString parseDateTime( mailimf_date_time *date ); 46 QString parseDateTime( mailimf_date_time *date );
47 47
48 void traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rek=0,int current_count=0); 48 void traverseBody(RecBody&target,mailmessage*message,mailmime*mime,QValueList<int>recList,unsigned int current_rek=0,int current_count=1);
49 static void fillSingleBody(RecPart&target,mailmessage*message,mailmime*mime); 49 static void fillSingleBody(RecPart&target,mailmessage*message,mailmime*mime);
50 static void fillParameters(RecPart&target,clist*parameters); 50 static void fillParameters(RecPart&target,clist*parameters);
51 static QString getencoding(mailmime_mechanism*aEnc); 51 static QString getencoding(mailmime_mechanism*aEnc);
52 virtual void parseList(QList<RecMail> &target,mailsession*session,const QString&mailbox); 52 virtual void parseList(QList<RecMail> &target,mailsession*session,const QString&mailbox);
53 53
54 QString msgTempName; 54 QString msgTempName;
55 unsigned int last_msg_id; 55 unsigned int last_msg_id;
56 QMap<QString,encodedString*> bodyCache; 56 QMap<QString,encodedString*> bodyCache;
57}; 57};
58 58
59#endif 59#endif