meillo@0: /* MasqMail meillo@0: Copyright (C) 1999 Oliver Kurth meillo@0: meillo@0: This program is free software; you can redistribute it and/or modify meillo@0: it under the terms of the GNU General Public License as published by meillo@0: the Free Software Foundation; either version 2 of the License, or meillo@0: (at your option) any later version. meillo@0: meillo@0: This program is distributed in the hope that it will be useful, meillo@0: but WITHOUT ANY WARRANTY; without even the implied warranty of meillo@0: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the meillo@0: GNU General Public License for more details. meillo@0: meillo@0: You should have received a copy of the GNU General Public License meillo@0: along with this program; if not, write to the Free Software meillo@0: Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. meillo@0: */ meillo@0: meillo@0: #include meillo@0: #include meillo@0: #include meillo@0: #include meillo@0: #include meillo@0: meillo@0: #include meillo@0: meillo@0: #include "masqmail.h" meillo@0: #include "smtp_out.h" meillo@0: meillo@0: masqmail_conf conf; meillo@0: meillo@0: extern char *optarg; meillo@0: extern int optind, opterr, optopt; meillo@0: meillo@10: void meillo@10: logwrite(int pri, const char *fmt, ...) meillo@0: { meillo@10: va_list args; meillo@10: va_start(args, fmt); meillo@0: meillo@10: vfprintf(stdout, fmt, args); meillo@0: meillo@10: va_end(args); meillo@0: } meillo@0: meillo@10: void meillo@10: debugf(const char *fmt, ...) meillo@0: { meillo@10: va_list args; meillo@10: va_start(args, fmt); meillo@0: meillo@10: vfprintf(stdout, fmt, args); meillo@0: meillo@10: va_end(args); meillo@0: } meillo@0: meillo@0: int meillo@0: main(int argc, char *argv[]) meillo@0: { meillo@10: gchar *helo_name = g_malloc(64); meillo@10: gchar *server_name = g_strdup("localhost"); meillo@10: gint server_port = 25; meillo@10: GList *resolve_list = g_list_append(NULL, resolve_byname); meillo@0: meillo@10: gethostname(helo_name, 63); meillo@0: meillo@10: conf.host_name = g_strdup(helo_name); meillo@0: meillo@10: while (1) { meillo@10: int c; meillo@10: c = getopt(argc, argv, "d:p:s:H:"); meillo@10: if (c == -1) meillo@10: break; meillo@10: switch (c) { meillo@10: case 'd': meillo@10: conf.debug_level = atoi(optarg); meillo@10: break; meillo@10: case 'p': meillo@10: server_port = atoi(optarg); meillo@10: break; meillo@10: case 's': meillo@10: g_free(server_name); meillo@10: server_name = g_strdup(optarg); meillo@10: break; meillo@10: case 'H': meillo@10: g_free(helo_name); meillo@10: helo_name = g_strdup(optarg); meillo@10: break; meillo@10: default: meillo@10: break; meillo@10: } meillo@10: } meillo@0: meillo@10: if (optind < argc) { meillo@10: gint ret; meillo@10: message *msg = create_message(); meillo@0: meillo@10: while (optind < argc) { meillo@10: msg->rcpt_list = g_list_append(msg->rcpt_list, create_address_qualified(argv[optind++], TRUE, conf.host_name)); meillo@10: } meillo@10: meillo@10: if ((ret = accept_message(stdin, msg, ACC_NODOT_TERM | ACC_HEAD_FROM_RCPT)) == AERR_OK) { meillo@10: if ((ret = smtp_deliver(server_name, server_port, resolve_list, msg, NULL, NULL)) == smtp_ok) { meillo@10: exit(EXIT_SUCCESS); meillo@10: } meillo@10: fprintf(stderr, "deliver failed: %d\n", ret); meillo@10: } meillo@10: fprintf(stderr, "accept failed: %d\n", ret); meillo@10: exit(ret); meillo@10: } else { meillo@10: fprintf(stderr, "no recipients given.\n"); meillo@10: exit(-1); meillo@10: } meillo@0: }