masqmail
changeset 270:0c44b239c7fe
refactoring in the small
author | markus schnalke <meillo@marmaro.de> |
---|---|
date | Fri, 03 Dec 2010 13:02:45 -0300 (2010-12-03) |
parents | fd1d77e5a5da |
children | 899175e8dff0 |
files | src/accept.c |
diffstat | 1 files changed, 73 insertions(+), 65 deletions(-) [+] |
line diff
1.1 --- a/src/accept.c Fri Dec 03 12:55:44 2010 -0300 1.2 +++ b/src/accept.c Fri Dec 03 13:02:45 2010 -0300 1.3 @@ -48,10 +48,10 @@ 1.4 address *addr2 = (address *) b; 1.5 int ret; 1.6 1.7 - if ((ret = strcasecmp(addr1->domain, addr2->domain)) == 0) 1.8 + if ((ret = strcasecmp(addr1->domain, addr2->domain)) == 0) { 1.9 return strcmp(addr1->local_part, addr2->local_part); 1.10 - else 1.11 - return ret; 1.12 + } 1.13 + return ret; 1.14 } 1.15 1.16 /* accept message from anywhere. 1.17 @@ -88,70 +88,76 @@ 1.18 line1++; 1.19 } 1.20 1.21 - if (len <= 0) { 1.22 - if ((len == -1) && (flags & (ACC_DOT_IGNORE | ACC_NODOT_RELAX))) { 1.23 - /* we got an EOF, and the last line was not terminated by a CR */ 1.24 - gint len1 = strlen(line1); 1.25 - if (len1 > 0) { /* == 0 is 'normal' (EOF after a CR) */ 1.26 - if (line1[len1 - 1] != '\n') { /* some mail clients allow unterminated lines */ 1.27 - line1[len1] = '\n'; 1.28 - line1[len1 + 1] = '\0'; 1.29 - msg->data_list = g_list_prepend(msg->data_list, g_strdup(line1)); 1.30 - data_size += strlen(line1); 1.31 - line_cnt++; 1.32 - } 1.33 + if ((len == -1) && (flags & (ACC_DOT_IGNORE | ACC_NODOT_RELAX))) { 1.34 + /* we got an EOF, and the last line was not terminated by a CR */ 1.35 + gint len1 = strlen(line1); 1.36 + if (len1 > 0) { /* == 0 is 'normal' (EOF after a CR) */ 1.37 + if (line1[len1 - 1] != '\n') { /* some mail clients allow unterminated lines */ 1.38 + line1[len1] = '\n'; 1.39 + line1[len1 + 1] = '\0'; 1.40 + msg->data_list = g_list_prepend(msg->data_list, g_strdup(line1)); 1.41 + data_size += strlen(line1); 1.42 + line_cnt++; 1.43 } 1.44 - break; 1.45 + } 1.46 + break; 1.47 + 1.48 + } else if (len == -1) { 1.49 + g_free(line); 1.50 + return AERR_EOF; 1.51 + 1.52 + } else if (len == -2) { 1.53 + /* should not happen any more */ 1.54 + g_free(line); 1.55 + return AERR_OVERFLOW; 1.56 + 1.57 + } else if (len == -3) { 1.58 + g_free(line); 1.59 + return AERR_TIMEOUT; 1.60 + 1.61 + } else if (len <= 0) { 1.62 + /* does not happen */ 1.63 + g_free(line); 1.64 + DEBUG(5) debugf("read_sockline returned %d\n", len); 1.65 + return AERR_UNKNOWN; 1.66 + 1.67 + } 1.68 + 1.69 + if (in_headers) { 1.70 + 1.71 + /* some pop servers send the 'From ' line, skip it: */ 1.72 + if (!msg->hdr_list && strncmp(line1, "From ", 5) == 0) { 1.73 + continue; 1.74 + } 1.75 + 1.76 + if (line1[0] == ' ' || line1[0] == '\t') { 1.77 + /* continuation of 'folded' header: */ 1.78 + if (hdr) { 1.79 + hdr->header = g_strconcat(hdr->header, line1, NULL); 1.80 + } 1.81 + 1.82 + } else if (line1[0] == '\n') { 1.83 + /* an empty line marks end of headers */ 1.84 + in_headers = FALSE; 1.85 } else { 1.86 - g_free(line); 1.87 - if (len == -1) { 1.88 - return AERR_EOF; 1.89 - } else if (len == -2) { 1.90 - /* should not happen any more */ 1.91 - return AERR_OVERFLOW; 1.92 - } else if (len == -3) { 1.93 - return AERR_TIMEOUT; 1.94 + /* in all other cases we expect another header */ 1.95 + if ((hdr = get_header(line1))) { 1.96 + msg->hdr_list = g_list_append(msg->hdr_list, hdr); 1.97 } else { 1.98 - /* does not happen */ 1.99 - DEBUG(5) debugf("read_sockline returned %d\n", len); 1.100 - return AERR_UNKNOWN; 1.101 + /* if get_header() returns NULL, no header was recognized, 1.102 + so this seems to be the first data line of a broken mailer 1.103 + which does not send an empty line after the headers */ 1.104 + in_headers = FALSE; 1.105 + msg->data_list = g_list_prepend(msg->data_list, g_strdup(line1)); 1.106 } 1.107 } 1.108 } else { 1.109 - if (in_headers) { 1.110 + /* message body */ 1.111 + msg->data_list = g_list_prepend(msg->data_list, g_strdup(line1)); 1.112 + data_size += strlen(line1); 1.113 + line_cnt++; 1.114 + } 1.115 1.116 - /* some pop servers send the 'From ' line, skip it: */ 1.117 - if (msg->hdr_list == NULL) 1.118 - if (strncmp(line1, "From ", 5) == 0) 1.119 - continue; 1.120 - 1.121 - if (line1[0] == ' ' || line1[0] == '\t') { 1.122 - /* continuation of 'folded' header: */ 1.123 - if (hdr) { 1.124 - hdr->header = g_strconcat(hdr->header, line1, NULL); 1.125 - } 1.126 - 1.127 - } else if (line1[0] == '\n') { 1.128 - /* an empty line marks end of headers */ 1.129 - in_headers = FALSE; 1.130 - } else { 1.131 - /* in all other cases we expect another header */ 1.132 - if ((hdr = get_header(line1))) 1.133 - msg->hdr_list = g_list_append(msg->hdr_list, hdr); 1.134 - else { 1.135 - /* if get_header() returns NULL, no header was recognized, 1.136 - so this seems to be the first data line of a broken mailer 1.137 - which does not send an empty line after the headers */ 1.138 - in_headers = FALSE; 1.139 - msg->data_list = g_list_prepend(msg->data_list, g_strdup(line1)); 1.140 - } 1.141 - } 1.142 - } else { 1.143 - msg->data_list = g_list_prepend(msg->data_list, g_strdup(line1)); 1.144 - data_size += strlen(line1); 1.145 - line_cnt++; 1.146 - } 1.147 - } 1.148 if (conf.max_msg_size && (data_size > conf.max_msg_size)) { 1.149 DEBUG(4) debugf("accept_message_stream(): " 1.150 "received %d bytes (conf.max_msg_size=%d)\n", 1.151 @@ -161,13 +167,14 @@ 1.152 1.153 } 1.154 1.155 - if (msg->data_list != NULL) 1.156 - msg->data_list = g_list_reverse(msg->data_list); 1.157 - else 1.158 + DEBUG(4) debugf("received %d lines of data (%d bytes)\n", line_cnt, data_size); 1.159 + 1.160 + if (!msg->data_list) { 1.161 /* make sure data list is not NULL: */ 1.162 msg->data_list = g_list_append(NULL, g_strdup("")); 1.163 + } 1.164 + msg->data_list = g_list_reverse(msg->data_list); 1.165 1.166 - DEBUG(4) debugf("received %d lines of data (%d bytes)\n", line_cnt, data_size); 1.167 /* we get here after we succesfully received the mail data */ 1.168 1.169 msg->data_size = data_size; 1.170 @@ -421,8 +428,9 @@ 1.171 accept_error err; 1.172 1.173 err = accept_message_stream(in, msg, flags); 1.174 - if (err == AERR_OK) 1.175 + if (err == AERR_OK) { 1.176 err = accept_message_prepare(msg, flags); 1.177 + } 1.178 1.179 return err; 1.180 }