# Copyright (C) 2008-2017 by the Free Software Foundation, Inc. # # This file is part of GNU Mailman. # # GNU Mailman 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 3 of the License, or (at your option) # any later version. # # GNU Mailman 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 # GNU Mailman. If not, see . """Base class for terminal chains.""" from mailman.config import config from mailman.core.i18n import _ from mailman.interfaces.chain import ( IChain, IChainIterator, IChainLink, IMutableChain, LinkAction) from mailman.interfaces.rules import IRule from mailman.utilities.modules import abstract_component from public import public from zope.interface import implementer @public def format_reasons(reasons): """Translate and format hold and rejection reasons. :param reasons: A list of reasons from the rules that hit. Each reason is a string to be translated or a tuple consisting of a string with {} replacements and one or more replacement values. :returns: A list of the translated and formatted strings. """ new_reasons = [] for reason in reasons: if isinstance(reason, tuple): new_reasons.append(_(reason[0]).format(*reason[1:])) else: new_reasons.append(_(reason)) return new_reasons @public @implementer(IChainLink) class Link: """A chain link.""" def __init__(self, rule, action=None, chain=None, function=None): self.rule = (rule if IRule.providedBy(rule) else config.rules[rule]) self.action = (LinkAction.defer if action is None else action) self.chain = (chain if chain is None or IChain.providedBy(chain) else config.chains[chain]) self.function = function def __repr__(self): message = '