From b132a73f15e432eaf43310fce9196ca0c0651465 Mon Sep 17 00:00:00 2001 From: <> Date: Thu, 2 Jan 2003 05:25:50 +0000 Subject: This commit was manufactured by cvs2svn to create branch 'Release_2_1-maint'. --- scripts/join | 61 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100755 scripts/join (limited to 'scripts/join') diff --git a/scripts/join b/scripts/join new file mode 100755 index 00000000..77ca506b --- /dev/null +++ b/scripts/join @@ -0,0 +1,61 @@ +# -*- python -*- +# +# Copyright (C) 2001,2002 by the Free Software Foundation, Inc. +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +"""Simple join-a-list email address. + +Called by the wrapper, stdin is the mail message, and argv[1] is the name +of the target mailing list. + +Errors are redirected to logs/errors. +""" + +import sys + +import paths +from Mailman import mm_cfg +from Mailman import Utils +from Mailman.i18n import _ +from Mailman.Queue.sbcache import get_switchboard +from Mailman.Logging.Utils import LogStdErr + +LogStdErr('error', 'join') + + + +def main(): + try: + listname = sys.argv[1] + except IndexError: + print >> sys.stderr, _('join script got no listname.') + sys.exit(1) + # Make sure the list exists + if not Utils.list_exists(listname): + print >> sys.stderr, _('join script, list not found: %(listname)s') + sys.exit(1) + # Immediately queue the message for the bounce/cmd qrunner to process. + # The advantage to this approach is that messages should never get lost -- + # some MTAs have a hard limit to the time a filter prog can run. Postfix + # is a good example; if the limit is hit, the proc is SIGKILL'd giving us + # no chance to save the message. + cmdq = get_switchboard(mm_cfg.CMDQUEUE_DIR) + cmdq.enqueue(sys.stdin.read(), listname=listname, tojoin=1, _plaintext=1) + + + +if __name__ == '__main__': + main() -- cgit v1.2.3