OSSP CVS Repository

ossp - ossp-pkg/petidomo/members.c 1.1.1.1
Not logged in
[Honeypot]  [Browse]  [Directory]  [Home]  [Login
[Reports]  [Search]  [Ticket]  [Timeline
  [Raw

ossp-pkg/petidomo/members.c 1.1.1.1
/*
 *      $Source: /v/ossp/cvs/ossp-pkg/petidomo/members.c,v $
 *      $Revision: 1.1.1.1 $
 *      $Date: 2000/12/13 13:19:24 $
 *
 *      Copyright (C) 1997 by CyberSolutions GmbH.
 *      All rights reserved.
 */

#include <sys/types.h>
#include <sys/stat.h>
#include <dirent.h>
#include <ctype.h>

#include <text.h>
#include <petidomo.h>

int
SendSubscriberList(struct Mail * MailStruct,
		   const char * param1,
		   const char * param2,
		   const char * defaultlist)
{
    const struct List_Config * ListConfig;
    FILE *         fh;
    const char *   address = NULL;
    const char *   listname = NULL;
    char           owner[4096];
    char           envelope[4096];
    char *         buffer;
    char *         p;
    int            i;

    debug((DEBUG_COMMAND, 3, "SendSubscriberList(\"%s\") with default list \"%s\".",
	   param1, defaultlist));

    /* Try to find out, which parameter is what. */

    if (param1 != NULL) {
	if (isValidListName(param1) == TRUE)
	  listname = param1;
    }

    address = (MailStruct->Reply_To) ? MailStruct->Reply_To : MailStruct->From;
    if (listname == NULL && defaultlist != NULL)
      listname = defaultlist;

    if (address == NULL || listname == NULL) {
	syslog(LOG_NOTICE, "%s: members-command invalid: No list specified.",
	    MailStruct->From);
	return 0;
    }

    /* Initialize internal stuff. */

    ListConfig = getListConfig(listname);
    sprintf(owner, "%s-owner@%s", listname, ListConfig->fqdn);
    sprintf(envelope, "%s-owner@%s", listname, ListConfig->fqdn);

    /* Check whether 'members' is allowed for this list. */

    if (isValidAdminPassword(getPassword(), listname) == FALSE &&
	ListConfig->allowmembers == FALSE) {

	syslog(LOG_NOTICE, "MEMBERS command from \"%s\" has been denied.", address);
	fh = vOpenMailer(envelope, address, owner, NULL);
	if (fh != NULL) {
	    fprintf(fh, "From: %s-request@%s (Petidomo Mailing List Server)\n",
		    listname, ListConfig->fqdn);
	    fprintf(fh, "To: %s\n", address);
	    fprintf(fh, "Cc: %s\n", owner);
	    fprintf(fh, "Subject: Request \"members %s\"\n", listname);
	    if (MailStruct->Message_Id != NULL)
	      fprintf(fh, "In-Reply-To: %s\n", MailStruct->Message_Id);
	    fprintf(fh, "Precedence: junk\n");
	    fprintf(fh, "Sender: %s\n", envelope);
	    fprintf(fh, "\n");
	    buffer = text_easy_sprintf(
"The MEMBERS command has been disabled for this mailing list, I am " \
"afraid. If there's a certain reason, why you need to know the list " \
"of subscribed addresses, please contact the mailing list administrator " \
"under the address \"%s\" instead.", owner);
	    text_wordwrap(buffer, 75);
	    fprintf(fh, "%s\n", buffer);
	    AppendSignature(fh);
	    CloseMailer(fh);
	}
	else

    syslog(LOG_ERR, "Failed to send mail to \"%s\"", address);
	return 0;
    }

    /* Okay, send the address list back. */

    debug((DEBUG_COMMAND, 1, "Sending list of subscribed addresses for list "
	   "\"%s\" to \"%s\".", listname, address));

    buffer = text_easy_sprintf("lists/%s/list", listname);
    buffer = loadfile(buffer);
    if (buffer == NULL) {
	syslog(LOG_ERR, "Failed to open file \"~petidomo/lists/%s/list\"", listname);
	return -1;
    }

    fh = vOpenMailer(envelope, address, NULL);
    if (fh != NULL) {
	fprintf(fh, "From: %s-request@%s (Petidomo Mailing List Server)\n",
		listname, ListConfig->fqdn);
	fprintf(fh, "To: %s\n", address);
	fprintf(fh, "Subject: Request \"members %s\"\n", listname);
	if (MailStruct->Message_Id != NULL)
	  fprintf(fh, "In-Reply-To: %s\n", MailStruct->Message_Id);
	fprintf(fh, "Precedence: junk\n");
	fprintf(fh, "Sender: %s\n", envelope);
	fprintf(fh, "\n");
	fprintf(fh, "Subscribers of list \"%s\":\n", listname);
	fprintf(fh, "=======================");
	fflush(fh);
	for (i = 0; i < strlen(listname); i++) {
	    fputc('=', fh);
	}
	fputc('\n', fh);
	for (p = buffer; *p; p++) {
	    if (isspace((int)*p)) {
		fputc('\n', fh);
		while (*p != '\0' && *p != '\n')
		  p++;
	    }
	    else {
	      fputc(*p, fh);
	    }
	}
	AppendSignature(fh);
	CloseMailer(fh);
    }
    else {
	free(buffer);
	syslog(LOG_ERR, "Failed to send email to \"%s\"!", address);
	return -1;
    }

    free(buffer);
    return 0;
}

CVSTrac 2.0.1