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}