IOExitRecordChannel.java interface


IOExitRecordChannel.java

/*
 *   Licensed Materials - Property of IBM
 *
 *   "Restricted Materials of IBM"
 *
 *   5724-H72
 * 
 *    Copyright IBM Corp. 2011, 2020. All Rights Reserved.
 * 
 *   disclosure restricted by GSA ADP Schedule Contract with
 *   IBM Corp.
 */
package com.ibm.wmqfte.exitroutine.api;

import java.io.IOException;
import java.nio.ByteBuffer;

/**
 * Represents a channel that enables records of data to be read from or written
 * to an {@link IOExitRecordResourcePath} resource.
 * <p>
 * This is an extension of the {@link IOExitChannel} interface such that the
 * {@link #read(java.nio.ByteBuffer)} and {@link #write(java.nio.ByteBuffer)}
 * methods are expected to deal in whole records of data only. That is, the
 * {@link java.nio.ByteBuffer} returned from the read method and passed to the
 * write method is assumed to contain one or more complete records.
 */
public interface IOExitRecordChannel extends IOExitChannel {

	/**
	 * Reads records from this channel into the given buffer, starting at this
	 * channel's current position, and updates the current position by the
	 * amount of data read.
	 * <p>
	 * Record data is copied into the buffer starting at its current position
	 * and up to its limit. On return, the buffer's position is updated to
	 * reflect the number of bytes read.
	 * <p>
	 * Only whole records are copied into the buffer.
	 * <p>
	 * For a fixed-record-format resource, this might be multiple records. The
	 * amount of data in the return buffer does not necessarily need to be a
	 * multiple of the record length, but the last record is still to be treated
	 * as a complete record and padded as required by the caller.
	 * <p>
	 * For a variable-format resource, this is a single whole record of a size
	 * corresponding to the amount of return data or multiple whole records with
	 * all except the last being treated as records of maximum size.
	 * 
	 * @param buffer
	 *            The buffer that the record data is to be copied into.
	 * @return The number of bytes read, which might be zero, or -1 if the end of
	 *         data has been reached.
	 * @throws RecoverableIOException
	 *             If a recoverable problem occurs while reading the data. For a
	 *             WMQFTE transfer this means that it will attempt to recover.
	 * @throws IOException
	 *             If some other I/O problem occurs, for example, if the passed
	 *             buffer is insufficient to contain at least one complete
	 *             record). For a WMQFTE transfer this means that it will be
	 *             failed.
	 */
	int read(ByteBuffer buffer) throws RecoverableIOException, IOException;

	/**
	 * Writes records to this channel from the given buffer, starting at this
	 * channel's current position, and updates the current position by the
	 * amount of data written. The channel's resource is grown to accommodate
	 * the data, if necessary.
	 * <p>
	 * Record data is copied from the buffer starting at its current position
	 * and up to its limit. On return, the buffer's position is updated to
	 * reflect the number of bytes written.
	 * <p>
	 * The buffer is expected to contain only whole records.
	 * <p>
	 * For a fixed-record-format resource, this might be multiple records and if
	 * there is insufficient data in the buffer for a complete record, the
	 * record is to be padded as required to complete the record.
	 * <p>
	 * For a variable-record format resource the buffer is normally expected to
	 * contain a single record of length corresponding to the amount of data
	 * within the buffer. However, if the amount of data within the buffer
	 * exceeds the maximum record length, the implementation can either:
	 * <ol>
	 * <li>throw an {@link IOException} indicating that it cannot handle the
	 * situation.</li>
	 * <li>Consume a record's worth of data from the buffer, leaving the remaining
	 * data within the buffer.</li>
	 * <li>Consume all the buffer data and just write what it can to the current
	 * record. This effectively truncates the data.</li>
	 * <li>Consume all the buffer data and write to multiple records.</li>
	 * </ol>
	 * 
	 * @param buffer
	 *            The buffer containing the data to be written.
	 * @return The number of bytes written, which might be zero.
	 * @throws RecoverableIOException
	 *             If a recoverable problem occurs while writing the data. For a
	 *             WMQFTE transfer this means that it will attempt to recover.
	 * @throws IOException
	 *             If some other I/O problem occurs. For a WMQFTE transfer this
	 *             means that it will be failed.
	 */
	int write(ByteBuffer buffer) throws RecoverableIOException, IOException;

}