}
memory_pool_delete (session->pool);
close (session->sock);
+ if (session->temp_name != NULL) {
+ unlink (session->temp_name);
+ }
if (session->temp_fd != -1) {
close (session->temp_fd);
}
rspamd_dispatcher_pause (session->dispatcher);
rspamd_dispatcher_restore (session->upstream_dispatcher);
+ session->upstream_state = SMTP_STATE_IN_SENDFILE;
+ session->state = SMTP_STATE_WAIT_UPSTREAM;
if (! rspamd_dispatcher_sendfile (session->upstream_dispatcher, session->temp_fd, session->temp_size)) {
goto err;
}
- session->upstream_state = SMTP_STATE_IN_SENDFILE;
- session->state = SMTP_STATE_WAIT_UPSTREAM;
return TRUE;
err:
destroy_session (session->s);
return FALSE;
}
- memcpy (session->data_end, p - sizeof (session->data_end) + 1, sizeof (session->data_end));
+ memcpy (session->data_end, p - sizeof (session->data_end), sizeof (session->data_end));
session->data_idx = 5;
}
else if (session->data_idx + in->len < sizeof (session->data_end)){
session->data_idx = 5;
}
if (do_write) {
+ if (session->data_idx < in->len) {
+ if (in->len - session->data_idx != 0 &&
+ write (session->temp_fd, in->begin, in->len - session->data_idx) != in->len - session->data_idx) {
+ msg_err ("cannot write to temp file: %s", strerror (errno));
+ session->error = SMTP_ERROR_FILE;
+ session->state = SMTP_STATE_CRITICAL_ERROR;
+ rspamd_dispatcher_write (session->dispatcher, session->error, 0, FALSE, TRUE);
+ destroy_session (session->s);
+ return FALSE;
+ }
+ }
if (memcmp (session->data_end, DATA_END_TRAILER, sizeof (session->data_end)) == 0) {
return process_smtp_data (session);
}
- else {
- if (session->data_idx < in->len) {
- if (in->len - session->data_idx != 0 &&
- write (session->temp_fd, in->begin, in->len - session->data_idx) != in->len - session->data_idx) {
- msg_err ("cannot write to temp file: %s", strerror (errno));
- session->error = SMTP_ERROR_FILE;
- session->state = SMTP_STATE_CRITICAL_ERROR;
- rspamd_dispatcher_write (session->dispatcher, session->error, 0, FALSE, TRUE);
- destroy_session (session->s);
- return FALSE;
- }
- }
- }
}
break;
case SMTP_STATE_WAIT_UPSTREAM:
smtp_upstream_read_socket (f_str_t * in, void *arg)
{
struct smtp_session *session = arg;
- char outbuf[BUFSIZ], *tmppattern;
+ char outbuf[BUFSIZ];
int r;
switch (session->upstream_state) {
}
else if (r == 1) {
r = strlen (session->cfg->temp_dir) + sizeof ("/rspamd-XXXXXX.tmp");
- tmppattern = alloca (r);
- snprintf (tmppattern, r, "%s/rspamd-XXXXXX.tmp", session->cfg->temp_dir);
- session->temp_fd = g_mkstemp_full (tmppattern, O_RDWR, S_IWUSR | S_IRUSR);
+ session->temp_name = memory_pool_alloc (session->pool, r);
+ snprintf (session->temp_name, r, "%s%crspamd-XXXXXX.tmp", session->cfg->temp_dir, G_DIR_SEPARATOR);
+ session->temp_fd = g_mkstemp_full (session->temp_name, O_RDWR, S_IWUSR | S_IRUSR);
if (session->temp_fd == -1) {
session->error = SMTP_ERROR_FILE;
session->state = SMTP_STATE_CRITICAL_ERROR;