001/**
002 * Logback: the reliable, generic, fast and flexible logging framework.
003 * Copyright (C) 1999-2015, QOS.ch. All rights reserved.
004 *
005 * This program and the accompanying materials are dual-licensed under
006 * either the terms of the Eclipse Public License v1.0 as published by
007 * the Eclipse Foundation
008 *
009 *   or (per the licensee's choosing)
010 *
011 * under the terms of the GNU Lesser General Public License version 2.1
012 * as published by the Free Software Foundation.
013 */
014package ch.qos.logback.classic.net;
015
016import ch.qos.logback.core.spi.ContextAwareBase;
017import ch.qos.logback.core.spi.LifeCycle;
018
019/**
020 * An abstract base for components that receive logging events from a remote
021 * peer and log according to local policy
022 *
023 * @author Carl Harris
024 */
025public abstract class ReceiverBase extends ContextAwareBase implements LifeCycle {
026
027    private boolean started;
028
029    /**
030     * {@inheritDoc}
031     */
032    public final void start() {
033        if (isStarted())
034            return;
035        if (getContext() == null) {
036            throw new IllegalStateException("context not set");
037        }
038        if (shouldStart()) {
039            getContext().getScheduledExecutorService().execute(getRunnableTask());
040            started = true;
041        }
042    }
043
044    /**
045     * {@inheritDoc}
046     */
047    public final void stop() {
048        if (!isStarted())
049            return;
050        try {
051            onStop();
052        } catch (RuntimeException ex) {
053            addError("on stop: " + ex, ex);
054        }
055        started = false;
056    }
057
058    /**
059     * {@inheritDoc}
060     */
061    public final boolean isStarted() {
062        return started;
063    }
064
065    /**
066     * Determines whether this receiver should start.
067     * <p>
068     * Subclasses will implement this method to do any subclass-specific validation.
069     * The subclass's {@link #getRunnableTask()} method will be invoked (and the
070     * task returned will be submitted to the executor) if and only if this method
071     * returns {@code true}
072     * 
073     * @return flag indicating whether this receiver should start
074     */
075    protected abstract boolean shouldStart();
076
077    /**
078     * Allows a subclass to participate in receiver shutdown.
079     */
080    protected abstract void onStop();
081
082    /**
083     * Provides the runnable task this receiver will execute.
084     * 
085     * @return runnable task
086     */
087    protected abstract Runnable getRunnableTask();
088
089}