X-Git-Url: https://jfr.im/git/irc/evilnet/x3.git/blobdiff_plain/636654954bff7c860eed0c2695c3ae436fe53674..4c26ef3e790edce6fda894be1ff64806bbddf1c9:/src/sendmail.c diff --git a/src/sendmail.c b/src/sendmail.c index 0661281..8c211e7 100644 --- a/src/sendmail.c +++ b/src/sendmail.c @@ -100,6 +100,24 @@ send_flowed_text(FILE *where, const char *para) } } +/* moved to tools.c +int +valid_email(email) +{ + for (i=0;iemail_addr[i]) && + to->email_addr[i] != '.' && + to->email_addr[i] != '@' && + to->email_addr[i] != '-' && + to->email_addr[i] != '+' && + to->email_addr[i] != '_' ) + return false; + } + return true; +} +*/ + void sendmail(struct userNode *from, struct handle_info *to, const char *subject, const char *body, int first_time) { @@ -227,6 +245,12 @@ sendmail(struct userNode *from, struct handle_info *to, const char *subject, con argv[argc++] = "-f"; argv[argc++] = fromaddr; } + if(!valid_email(to->email_addr)) + { + log_module(MAIN_LOG, LOG_ERROR, "email address contained illegal chars. Refusing to execv() sendmail."); + _exit(1); + } + argv[argc++] = to->email_addr; argv[argc++] = NULL; if (execv(mpath, (char**)argv) < 0) {