author | alwin <alwin> | 2003-12-25 02:10:29 (UTC) |
---|---|---|
committer | alwin <alwin> | 2003-12-25 02:10:29 (UTC) |
commit | af6b80a3d184e8984575a2cf7741058302c1c30b (patch) (unidiff) | |
tree | f6f66284fd9f1fd3403b188c1a1afae58ec951dc | |
parent | 52ccb19535d332f38dcd49f9d115192668c45357 (diff) | |
download | opie-af6b80a3d184e8984575a2cf7741058302c1c30b.zip opie-af6b80a3d184e8984575a2cf7741058302c1c30b.tar.gz opie-af6b80a3d184e8984575a2cf7741058302c1c30b.tar.bz2 |
fixed an address parsing bug
-rw-r--r-- | noncore/net/mail/libmailwrapper/smtpwrapper.cpp | 39 | ||||
-rw-r--r-- | noncore/net/mail/smtpwrapper.cpp | 39 |
2 files changed, 70 insertions, 8 deletions
diff --git a/noncore/net/mail/libmailwrapper/smtpwrapper.cpp b/noncore/net/mail/libmailwrapper/smtpwrapper.cpp index 21992b4..285561c 100644 --- a/noncore/net/mail/libmailwrapper/smtpwrapper.cpp +++ b/noncore/net/mail/libmailwrapper/smtpwrapper.cpp | |||
@@ -68,46 +68,74 @@ QString SMTPwrapper::mailsmtpError( int errnum ) | |||
68 | } | 68 | } |
69 | 69 | ||
70 | mailimf_mailbox *SMTPwrapper::newMailbox(const QString&name, const QString&mail ) | 70 | mailimf_mailbox *SMTPwrapper::newMailbox(const QString&name, const QString&mail ) |
71 | { | 71 | { |
72 | return mailimf_mailbox_new( strdup( name.latin1() ), | 72 | return mailimf_mailbox_new( strdup( name.latin1() ), |
73 | strdup( mail.latin1() ) ); | 73 | strdup( mail.latin1() ) ); |
74 | } | 74 | } |
75 | 75 | ||
76 | mailimf_address_list *SMTPwrapper::parseAddresses(const QString&addr ) | 76 | mailimf_address_list *SMTPwrapper::parseAddresses(const QString&addr ) |
77 | { | 77 | { |
78 | mailimf_address_list *addresses; | 78 | mailimf_address_list *addresses; |
79 | 79 | ||
80 | if ( addr.isEmpty() ) return NULL; | 80 | if ( addr.isEmpty() ) return NULL; |
81 | 81 | ||
82 | addresses = mailimf_address_list_new_empty(); | 82 | addresses = mailimf_address_list_new_empty(); |
83 | 83 | ||
84 | QStringList list = QStringList::split( ',', addr ); | 84 | bool literal_open = false; |
85 | unsigned int startpos = 0; | ||
86 | QStringList list; | ||
87 | QString s; | ||
88 | unsigned int i = 0; | ||
89 | for (; i < addr.length();++i) { | ||
90 | switch (addr[i]) { | ||
91 | case '\"': | ||
92 | literal_open = !literal_open; | ||
93 | break; | ||
94 | case ',': | ||
95 | if (!literal_open) { | ||
96 | s = addr.mid(startpos,i-startpos); | ||
97 | if (!s.isEmpty()) { | ||
98 | list.append(s); | ||
99 | qDebug("Appended %s",s.latin1()); | ||
100 | } | ||
101 | // !!!! this is a MUST BE! | ||
102 | startpos = ++i; | ||
103 | } | ||
104 | break; | ||
105 | default: | ||
106 | break; | ||
107 | } | ||
108 | } | ||
109 | s = addr.mid(startpos,i-startpos); | ||
110 | if (!s.isEmpty()) { | ||
111 | list.append(s); | ||
112 | qDebug("Appended %s",s.latin1()); | ||
113 | } | ||
85 | QStringList::Iterator it; | 114 | QStringList::Iterator it; |
86 | for ( it = list.begin(); it != list.end(); it++ ) { | 115 | for ( it = list.begin(); it != list.end(); it++ ) { |
87 | char *str = strdup( (*it).latin1() ); | 116 | char *str = strdup( (*it).latin1() ); |
88 | int err = mailimf_address_list_add_parse( addresses, str ); | 117 | int err = mailimf_address_list_add_parse( addresses, str ); |
89 | if ( err != MAILIMF_NO_ERROR ) { | 118 | if ( err != MAILIMF_NO_ERROR ) { |
90 | qDebug( "Error parsing" ); | 119 | qDebug( "Error parsing" ); |
91 | qDebug( *it ); | 120 | qDebug( *it ); |
92 | free( str ); | 121 | free( str ); |
93 | } else { | 122 | } else { |
94 | qDebug( "Parse success! :)" ); | 123 | qDebug( "Parse success! %s",(*it).latin1()); |
95 | } | 124 | } |
96 | } | 125 | } |
97 | |||
98 | return addresses; | 126 | return addresses; |
99 | } | 127 | } |
100 | 128 | ||
101 | mailimf_fields *SMTPwrapper::createImfFields(const Mail&mail ) | 129 | mailimf_fields *SMTPwrapper::createImfFields(const Mail&mail ) |
102 | { | 130 | { |
103 | mailimf_fields *fields; | 131 | mailimf_fields *fields; |
104 | mailimf_field *xmailer; | 132 | mailimf_field *xmailer; |
105 | mailimf_mailbox *sender, *fromBox; | 133 | mailimf_mailbox *sender, *fromBox; |
106 | mailimf_mailbox_list *from; | 134 | mailimf_mailbox_list *from; |
107 | mailimf_address_list *to, *cc, *bcc, *reply; | 135 | mailimf_address_list *to, *cc, *bcc, *reply; |
108 | char *subject = strdup( mail.getSubject().latin1() ); | 136 | char *subject = strdup( mail.getSubject().latin1() ); |
109 | int err; | 137 | int err; |
110 | 138 | ||
111 | sender = newMailbox( mail.getName(), mail.getMail() ); | 139 | sender = newMailbox( mail.getName(), mail.getMail() ); |
112 | if ( sender == NULL ) goto err_free; | 140 | if ( sender == NULL ) goto err_free; |
113 | 141 | ||
@@ -612,33 +640,36 @@ int SMTPwrapper::smtpSend(char*from,clist*rcpts,char*data,size_t size, SMTPaccou | |||
612 | user = strdup( login.getUser().latin1() ); | 640 | user = strdup( login.getUser().latin1() ); |
613 | pass = strdup( login.getPassword().latin1() ); | 641 | pass = strdup( login.getPassword().latin1() ); |
614 | } else { | 642 | } else { |
615 | result = 0; goto free_con_session; | 643 | result = 0; goto free_con_session; |
616 | } | 644 | } |
617 | } else { | 645 | } else { |
618 | user = strdup( smtp->getUser().latin1() ); | 646 | user = strdup( smtp->getUser().latin1() ); |
619 | pass = strdup( smtp->getPassword().latin1() ); | 647 | pass = strdup( smtp->getPassword().latin1() ); |
620 | } | 648 | } |
621 | qDebug( "session->auth: %i", session->auth); | 649 | qDebug( "session->auth: %i", session->auth); |
622 | err = mailsmtp_auth( session, user, pass ); | 650 | err = mailsmtp_auth( session, user, pass ); |
623 | if ( err == MAILSMTP_NO_ERROR ) qDebug("auth ok"); | 651 | if ( err == MAILSMTP_NO_ERROR ) qDebug("auth ok"); |
624 | qDebug( "Done auth!" ); | 652 | qDebug( "Done auth!" ); |
625 | } | 653 | } |
626 | 654 | ||
627 | err = mailsmtp_send( session, from, rcpts, data, size ); | 655 | err = mailsmtp_send( session, from, rcpts, data, size ); |
628 | if ( err != MAILSMTP_NO_ERROR ) {result = 0; goto free_con_session;} | 656 | if ( err != MAILSMTP_NO_ERROR ) { |
657 | qDebug("Error sending mail: %s",mailsmtpError(err).latin1()); | ||
658 | result = 0; goto free_con_session; | ||
659 | } | ||
629 | 660 | ||
630 | qDebug( "Mail sent." ); | 661 | qDebug( "Mail sent." ); |
631 | storeMail(data,size,"Sent"); | 662 | storeMail(data,size,"Sent"); |
632 | 663 | ||
633 | free_con_session: | 664 | free_con_session: |
634 | mailsmtp_quit( session ); | 665 | mailsmtp_quit( session ); |
635 | free_mem_session: | 666 | free_mem_session: |
636 | mailsmtp_free( session ); | 667 | mailsmtp_free( session ); |
637 | free_mem: | 668 | free_mem: |
638 | if (server) free( server ); | 669 | if (server) free( server ); |
639 | if ( smtp->getLogin() ) { | 670 | if ( smtp->getLogin() ) { |
640 | free( user ); | 671 | free( user ); |
641 | free( pass ); | 672 | free( pass ); |
642 | } | 673 | } |
643 | return result; | 674 | return result; |
644 | } | 675 | } |
diff --git a/noncore/net/mail/smtpwrapper.cpp b/noncore/net/mail/smtpwrapper.cpp index 21992b4..285561c 100644 --- a/noncore/net/mail/smtpwrapper.cpp +++ b/noncore/net/mail/smtpwrapper.cpp | |||
@@ -68,46 +68,74 @@ QString SMTPwrapper::mailsmtpError( int errnum ) | |||
68 | } | 68 | } |
69 | 69 | ||
70 | mailimf_mailbox *SMTPwrapper::newMailbox(const QString&name, const QString&mail ) | 70 | mailimf_mailbox *SMTPwrapper::newMailbox(const QString&name, const QString&mail ) |
71 | { | 71 | { |
72 | return mailimf_mailbox_new( strdup( name.latin1() ), | 72 | return mailimf_mailbox_new( strdup( name.latin1() ), |
73 | strdup( mail.latin1() ) ); | 73 | strdup( mail.latin1() ) ); |
74 | } | 74 | } |
75 | 75 | ||
76 | mailimf_address_list *SMTPwrapper::parseAddresses(const QString&addr ) | 76 | mailimf_address_list *SMTPwrapper::parseAddresses(const QString&addr ) |
77 | { | 77 | { |
78 | mailimf_address_list *addresses; | 78 | mailimf_address_list *addresses; |
79 | 79 | ||
80 | if ( addr.isEmpty() ) return NULL; | 80 | if ( addr.isEmpty() ) return NULL; |
81 | 81 | ||
82 | addresses = mailimf_address_list_new_empty(); | 82 | addresses = mailimf_address_list_new_empty(); |
83 | 83 | ||
84 | QStringList list = QStringList::split( ',', addr ); | 84 | bool literal_open = false; |
85 | unsigned int startpos = 0; | ||
86 | QStringList list; | ||
87 | QString s; | ||
88 | unsigned int i = 0; | ||
89 | for (; i < addr.length();++i) { | ||
90 | switch (addr[i]) { | ||
91 | case '\"': | ||
92 | literal_open = !literal_open; | ||
93 | break; | ||
94 | case ',': | ||
95 | if (!literal_open) { | ||
96 | s = addr.mid(startpos,i-startpos); | ||
97 | if (!s.isEmpty()) { | ||
98 | list.append(s); | ||
99 | qDebug("Appended %s",s.latin1()); | ||
100 | } | ||
101 | // !!!! this is a MUST BE! | ||
102 | startpos = ++i; | ||
103 | } | ||
104 | break; | ||
105 | default: | ||
106 | break; | ||
107 | } | ||
108 | } | ||
109 | s = addr.mid(startpos,i-startpos); | ||
110 | if (!s.isEmpty()) { | ||
111 | list.append(s); | ||
112 | qDebug("Appended %s",s.latin1()); | ||
113 | } | ||
85 | QStringList::Iterator it; | 114 | QStringList::Iterator it; |
86 | for ( it = list.begin(); it != list.end(); it++ ) { | 115 | for ( it = list.begin(); it != list.end(); it++ ) { |
87 | char *str = strdup( (*it).latin1() ); | 116 | char *str = strdup( (*it).latin1() ); |
88 | int err = mailimf_address_list_add_parse( addresses, str ); | 117 | int err = mailimf_address_list_add_parse( addresses, str ); |
89 | if ( err != MAILIMF_NO_ERROR ) { | 118 | if ( err != MAILIMF_NO_ERROR ) { |
90 | qDebug( "Error parsing" ); | 119 | qDebug( "Error parsing" ); |
91 | qDebug( *it ); | 120 | qDebug( *it ); |
92 | free( str ); | 121 | free( str ); |
93 | } else { | 122 | } else { |
94 | qDebug( "Parse success! :)" ); | 123 | qDebug( "Parse success! %s",(*it).latin1()); |
95 | } | 124 | } |
96 | } | 125 | } |
97 | |||
98 | return addresses; | 126 | return addresses; |
99 | } | 127 | } |
100 | 128 | ||
101 | mailimf_fields *SMTPwrapper::createImfFields(const Mail&mail ) | 129 | mailimf_fields *SMTPwrapper::createImfFields(const Mail&mail ) |
102 | { | 130 | { |
103 | mailimf_fields *fields; | 131 | mailimf_fields *fields; |
104 | mailimf_field *xmailer; | 132 | mailimf_field *xmailer; |
105 | mailimf_mailbox *sender, *fromBox; | 133 | mailimf_mailbox *sender, *fromBox; |
106 | mailimf_mailbox_list *from; | 134 | mailimf_mailbox_list *from; |
107 | mailimf_address_list *to, *cc, *bcc, *reply; | 135 | mailimf_address_list *to, *cc, *bcc, *reply; |
108 | char *subject = strdup( mail.getSubject().latin1() ); | 136 | char *subject = strdup( mail.getSubject().latin1() ); |
109 | int err; | 137 | int err; |
110 | 138 | ||
111 | sender = newMailbox( mail.getName(), mail.getMail() ); | 139 | sender = newMailbox( mail.getName(), mail.getMail() ); |
112 | if ( sender == NULL ) goto err_free; | 140 | if ( sender == NULL ) goto err_free; |
113 | 141 | ||
@@ -612,33 +640,36 @@ int SMTPwrapper::smtpSend(char*from,clist*rcpts,char*data,size_t size, SMTPaccou | |||
612 | user = strdup( login.getUser().latin1() ); | 640 | user = strdup( login.getUser().latin1() ); |
613 | pass = strdup( login.getPassword().latin1() ); | 641 | pass = strdup( login.getPassword().latin1() ); |
614 | } else { | 642 | } else { |
615 | result = 0; goto free_con_session; | 643 | result = 0; goto free_con_session; |
616 | } | 644 | } |
617 | } else { | 645 | } else { |
618 | user = strdup( smtp->getUser().latin1() ); | 646 | user = strdup( smtp->getUser().latin1() ); |
619 | pass = strdup( smtp->getPassword().latin1() ); | 647 | pass = strdup( smtp->getPassword().latin1() ); |
620 | } | 648 | } |
621 | qDebug( "session->auth: %i", session->auth); | 649 | qDebug( "session->auth: %i", session->auth); |
622 | err = mailsmtp_auth( session, user, pass ); | 650 | err = mailsmtp_auth( session, user, pass ); |
623 | if ( err == MAILSMTP_NO_ERROR ) qDebug("auth ok"); | 651 | if ( err == MAILSMTP_NO_ERROR ) qDebug("auth ok"); |
624 | qDebug( "Done auth!" ); | 652 | qDebug( "Done auth!" ); |
625 | } | 653 | } |
626 | 654 | ||
627 | err = mailsmtp_send( session, from, rcpts, data, size ); | 655 | err = mailsmtp_send( session, from, rcpts, data, size ); |
628 | if ( err != MAILSMTP_NO_ERROR ) {result = 0; goto free_con_session;} | 656 | if ( err != MAILSMTP_NO_ERROR ) { |
657 | qDebug("Error sending mail: %s",mailsmtpError(err).latin1()); | ||
658 | result = 0; goto free_con_session; | ||
659 | } | ||
629 | 660 | ||
630 | qDebug( "Mail sent." ); | 661 | qDebug( "Mail sent." ); |
631 | storeMail(data,size,"Sent"); | 662 | storeMail(data,size,"Sent"); |
632 | 663 | ||
633 | free_con_session: | 664 | free_con_session: |
634 | mailsmtp_quit( session ); | 665 | mailsmtp_quit( session ); |
635 | free_mem_session: | 666 | free_mem_session: |
636 | mailsmtp_free( session ); | 667 | mailsmtp_free( session ); |
637 | free_mem: | 668 | free_mem: |
638 | if (server) free( server ); | 669 | if (server) free( server ); |
639 | if ( smtp->getLogin() ) { | 670 | if ( smtp->getLogin() ) { |
640 | free( user ); | 671 | free( user ); |
641 | free( pass ); | 672 | free( pass ); |
642 | } | 673 | } |
643 | return result; | 674 | return result; |
644 | } | 675 | } |