com.epam.deltix.data.stream.DXChannel Maven / Gradle / Ivy
/*
* Copyright 2024 EPAM Systems, Inc
*
* See the NOTICE file distributed with this work for additional information
* regarding copyright ownership. Licensed under the Apache License,
* Version 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.epam.deltix.data.stream;
import com.epam.deltix.qsrv.hf.pub.md.RecordClassDescriptor;
import com.epam.deltix.streaming.MessageChannel;
import com.epam.deltix.streaming.MessageSource;
import com.epam.deltix.util.security.AuthorizationController;
public interface DXChannel extends AuthorizationController.ProtectedResource {
/**
* Returns the key, which uniquely identifies the channel
*/
String getKey();
/**
* Returns a user-readable short name.
*/
String getName();
/**
* Returns a user-readable multi-line description.
*/
String getDescription();
/**
* Returns the class descriptors associated with this channel
*/
RecordClassDescriptor[] getTypes();
/**
* Opens a source for reading data from this channel, according to the
* specified preferences. Iterator-like approach to consume messages:
*
* while (source.next())
* source.getMessage()
*
*
*
* @return A message source to read messages from.
*/
MessageSource createConsumer(ChannelPreferences options);
/**
* Creates a channel for loading data. The publisher must be closed
* when the loading process is finished.
*
* @return A consumer of messages to be loaded into the channel.
*/
MessageChannel createPublisher(ChannelPreferences options);
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy