/**
* Copyright 2013-2015 Seagate Technology LLC.
*
* This Source Code Form is subject to the terms of the Mozilla
* Public License, v. 2.0. If a copy of the MPL was not
* distributed with this file, You can obtain one at
* https://mozilla.org/MP:/2.0/.
*
* This program is distributed in the hope that it will be useful,
* but is provided AS-IS, WITHOUT ANY WARRANTY; including without
* the implied warranty of MERCHANTABILITY, NON-INFRINGEMENT or
* FITNESS FOR A PARTICULAR PURPOSE. See the Mozilla Public
* License for more details.
*
* See www.openkinetic.org for more project information
*/
package com.seagate.kinetic.simulator.io.provider.spi;
import java.io.IOException;
/**
*
* A Kinetic transport provider must provide a no-arg constructor and implement
* all the life-cycle methods defined in this interface.
* <p>
*
* The simulator engine will invoke each transport provider instance with the
* following sequences.
* <p>
* 1. Loads the provider class with its provided no-arg constructor.
* <p>
* 2. calls {@link #init(MessageService)} with the specified
* <code>MessageService</code>
* <p>
* 3. calls {@link #start()} to start the transport.
* <p>
* 4. calls {@link #stop()} to stop the transport. after this, the transport
* instance will not be used by the simulator.
* <p>
* 5. calls {@link #close()} method. a provider may choose to implement and
* release extra resources in this method.
*
* @see MessageService
*
* @author chiaming
*/
public interface TransportProvider {
/**
* initialize the transport service with the specified message service
* resource.
*
* @param messageService
* the services provided by the simulator.
*/
public void init(MessageService messageService);
/**
* Start the transport service.
*
* @throws IOException
* if the transport cannot be started, such as service port is
* in use.
*/
public void start() throws IOException;
/**
* Stop the transport service. the simulator engine will not use this
* transport instance after this call returns.
*/
public void stop();
/**
* Close the transport service. the provider may release extra resources
* when this is invoked.
*/
public void close();
}