add printed errors to mailer part 2

This commit is contained in:
Anthony Minessale 2012-01-27 13:52:15 -06:00
parent 0b21064a05
commit 7471ec17ed
1 changed files with 121 additions and 113 deletions

View File

@ -595,7 +595,7 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
char *bound = "XXXX_boundary_XXXX"; char *bound = "XXXX_boundary_XXXX";
const char *mime_type = "audio/inline"; const char *mime_type = "audio/inline";
char filename[80], buf[B64BUFFLEN]; char filename[80], buf[B64BUFFLEN];
int fd = 0, ifd = 0; int fd = -1, ifd = -1;
int x = 0, y = 0, bytes = 0, ilen = 0; int x = 0, y = 0, bytes = 0, ilen = 0;
unsigned int b = 0, l = 0; unsigned int b = 0, l = 0;
unsigned char in[B64BUFFLEN]; unsigned char in[B64BUFFLEN];
@ -604,8 +604,17 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
char *newfile = NULL; char *newfile = NULL;
switch_bool_t rval = SWITCH_FALSE; switch_bool_t rval = SWITCH_FALSE;
const char *err = NULL; const char *err = NULL;
const char *stipped_file;
const char *new_type;
char *xext;
if (!zstr(file) && !zstr(convert_cmd) && !zstr(convert_ext)) { if (zstr(file)) {
err = "Missing file";
rval = SWITCH_FALSE;
goto end;
}
if (!zstr(convert_cmd) && !zstr(convert_ext)) {
if ((ext = strrchr(file, '.'))) { if ((ext = strrchr(file, '.'))) {
dupfile = strdup(file); dupfile = strdup(file);
if ((ext = strrchr(dupfile, '.'))) { if ((ext = strrchr(dupfile, '.'))) {
@ -630,14 +639,18 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
switch_snprintf(filename, 80, "%s%smail.%d%04x", SWITCH_GLOBAL_dirs.temp_dir, SWITCH_PATH_SEPARATOR, (int) switch_epoch_time_now(NULL), rand() & 0xffff); switch_snprintf(filename, 80, "%s%smail.%d%04x", SWITCH_GLOBAL_dirs.temp_dir, SWITCH_PATH_SEPARATOR, (int) switch_epoch_time_now(NULL), rand() & 0xffff);
if ((fd = open(filename, O_WRONLY | O_CREAT | O_TRUNC, 0644))) { if ((fd = open(filename, O_WRONLY | O_CREAT | O_TRUNC, 0644)) < 0) {
if (file) { err = "Failed to open temp file";
if ((ifd = open(file, O_RDONLY | O_BINARY)) < 1) {
rval = SWITCH_FALSE; rval = SWITCH_FALSE;
err = "Cannot open tmp file\n";
goto end; goto end;
} }
if ((ifd = open(file, O_RDONLY | O_BINARY)) < 0) {
rval = SWITCH_FALSE;
err = "Failed to open source file\n";
goto end;
} }
switch_snprintf(buf, B64BUFFLEN, "MIME-Version: 1.0\nContent-Type: multipart/mixed; boundary=\"%s\"\n", bound); switch_snprintf(buf, B64BUFFLEN, "MIME-Version: 1.0\nContent-Type: multipart/mixed; boundary=\"%s\"\n", bound);
if (!write_buf(fd, buf)) { if (!write_buf(fd, buf)) {
rval = SWITCH_FALSE; rval = SWITCH_FALSE;
@ -676,14 +689,11 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
} }
} }
if (file) { stipped_file = switch_cut_path(file);
const char *stipped_file = switch_cut_path(file);
const char *new_type;
char *ext;
if ((ext = strrchr(stipped_file, '.'))) { if ((xext = strrchr(stipped_file, '.'))) {
ext++; xext++;
if ((new_type = switch_core_mime_ext2type(ext))) { if ((new_type = switch_core_mime_ext2type(xext))) {
mime_type = new_type; mime_type = new_type;
} }
} }
@ -724,6 +734,7 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
if (l > 0) { if (l > 0) {
out[bytes++] = switch_b64_table[((b % 16) << (6 - l)) % 64]; out[bytes++] = switch_b64_table[((b % 16) << (6 - l)) % 64];
} }
if (l != 0) if (l != 0)
while (l < 6) { while (l < 6) {
out[bytes++] = '=', l += 2; out[bytes++] = '=', l += 2;
@ -732,8 +743,6 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
rval = -1; rval = -1;
} }
}
switch_snprintf(buf, B64BUFFLEN, "\n\n--%s--\n.\n", bound); switch_snprintf(buf, B64BUFFLEN, "\n\n--%s--\n.\n", bound);
if (!write_buf(fd, buf)) { if (!write_buf(fd, buf)) {
@ -741,14 +750,6 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
err = "write error."; err = "write error.";
goto end; goto end;
} }
}
if (fd) {
close(fd);
}
if (ifd) {
close(ifd);
}
if (zstr(from)) { if (zstr(from)) {
from = "freeswitch"; from = "freeswitch";
@ -780,6 +781,13 @@ SWITCH_DECLARE(switch_bool_t) switch_simple_email(const char *to,
end: end:
if (fd > -1) {
close(fd);
}
if (ifd > -1) {
close(ifd);
}
if (newfile) { if (newfile) {
unlink(newfile); unlink(newfile);
free(newfile); free(newfile);