001/* 002 * JGrapes Event Driven Framework 003 * Copyright (C) 2022 Michael N. Lipp 004 * 005 * This program is free software; you can redistribute it and/or modify it 006 * under the terms of the GNU General Public License as published by 007 * the Free Software Foundation; either version 3 of the License, or 008 * (at your option) any later version. 009 * 010 * This program is distributed in the hope that it will be useful, but 011 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 012 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 013 * for more details. 014 * 015 * You should have received a copy of the GNU General Public License along 016 * with this program; if not, see <http://www.gnu.org/licenses/>. 017 */ 018 019package org.jgrapes.mail.events; 020 021import jakarta.mail.Message; 022import org.jgrapes.core.Channel; 023import org.jgrapes.core.Event; 024 025/** 026 * Indicates the arrival of a new message. Handler should delete 027 * the message after successful processing. 028 */ 029public class ReceivedMailMessage extends Event<Void> { 030 031 private final Message message; 032 033 /** 034 * Creates a new event. 035 * 036 * @param message the message 037 * @param channels the channels 038 */ 039 public ReceivedMailMessage(Message message, Channel... channels) { 040 super(channels); 041 this.message = message; 042 } 043 044 /** 045 * Returns the message. 046 * 047 * @return the message 048 */ 049 public Message message() { 050 return message; 051 } 052 053}