/* * Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com * The software in this package is published under the terms of the CPAL v1.0 * license, a copy of which has been included with this distribution in the * LICENSE.txt file. */ package org.mule.runtime.core.streaming; import org.mule.runtime.api.streaming.Cursor; import org.mule.runtime.api.streaming.CursorProvider; import org.mule.runtime.core.api.Event; /** * Creates instances of {@link org.mule.runtime.api.streaming.bytes.CursorStreamProvider} * * @param <T> the generic type of the streams being cursored * @since 4.0 */ public interface CursorProviderFactory<T> { /** * Optionally creates a new {@link CursorProvider} to buffer the given {@code value}. * <p> * Implementations might resolve that the given stream is/should not be buffered and thus * it will return the same given stream. In that case, the stream will be unaltered. * * @param event the event on which buffering is talking place * @param value the stream to be cursored * @return A {@link CursorProvider} or the same given {@code inputStream} */ Object of(Event event, T value); /** * @param value a stream * @return whether this factory can create a {@link Cursor} out of the given {@code value} */ boolean accepts(Object value); }