/* * Copyright (C) 2014 GG-Net GmbH - Oliver Günther * * 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 3 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, see <http://www.gnu.org/licenses/>. */ package eu.ggnet.dwoss.mandator.api.value; import java.io.Serializable; import java.net.URL; import java.util.*; import javax.validation.Valid; import javax.validation.constraints.NotNull; import org.apache.commons.mail.EmailException; import org.apache.commons.mail.MultiPartEmail; import org.metawidget.inspector.annotation.UiLarge; import eu.ggnet.dwoss.mandator.api.value.partial.*; import eu.ggnet.dwoss.rules.DocumentType; import eu.ggnet.dwoss.rules.TradeName; import lombok.Value; import lombok.experimental.Builder; /** * * @author oliver.guenther */ @Value @Builder public class Mandator implements Serializable { /** * The default Signature below mails. */ @UiLarge @NotNull private final String defaultMailSignature; /** * A Smtp Configuration, used for direct mailing. */ @Valid @NotNull private final SmtpConfiguration smtpConfiguration; /** * A generic velocity template for emails. * Available Parameters are: * <ul> * <li>$parameter.neutralTitle - Boolean, is true if neither Herr nor Frau is set.</li> * <li>$parameter.name - last name of the customer</li> * <li>$parameter.title - the title of the customer</li> * <li>$parameter.documentType - the documentType</li> * </ul> */ @NotNull private final URL mailDocumentTemplate; /** * File used as default attachment when sending mails. */ @NotNull private Set<MandatorMailAttachment> defaultMailAttachment; /** * The company master data information. */ @NotNull private final Company company; /** * The Prefix for Dossiers. */ @NotNull private final String dossierPrefix; @NotNull private final DocumentIntermix documentIntermix; @NotNull private final Map<DocumentType, DocumentIdentifierGeneratorConfiguration> documentIdentifierGeneratorConfigurations; /** * The default Mode for Receipt, for now may be null,Acer or Apple. */ private final TradeName receiptMode; @Deprecated // Remove if ServicePositionTemplate cleanup complete public TradeName getReceiptMode() { return receiptMode; } /** * Defines, if the primary sales channel should be set on roll in. */ private final boolean applyDefaultChannelOnRollIn; @NotNull private final String matchCode; private String bugMail; /** * Prepares a eMail to be send direct over the mandator smtp configuration. * The email is missing: to, subject, message and optional attachments. * * @return the email * @throws EmailException if something is wrong in the subsystem. */ public MultiPartEmail prepareDirectMail() throws EmailException { MultiPartEmail email = new MultiPartEmail(); email.setHostName(smtpConfiguration.getHostname()); email.addBcc(company.getEmail()); email.setFrom(company.getEmail(), company.getEmailName()); email.setAuthentication(smtpConfiguration.getSmtpAuthenticationUser(), smtpConfiguration.getSmtpAuthenticationPass()); email.setStartTLSEnabled(false); email.setSSLCheckServerIdentity(false); email.setSSLOnConnect(false); email.setCharset(smtpConfiguration.getCharset()); return email; } }