📄 transportmapping.java
字号:
/*_############################################################################
_##
_## SNMP4J - TransportMapping.java
_##
_## Copyright 2003-2007 Frank Fock and Jochen Katz (SNMP4J.org)
_##
_## 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 org.snmp4j;
import java.io.IOException;
import org.snmp4j.smi.Address;
import org.snmp4j.transport.TransportListener;
/**
* The <code>TransportMapping</code> defines the common interface for SNMP
* transport mappings. A transport mapping can only support a single
* transport protocol.
*
* @author Frank Fock
* @version 1.6
*/
public interface TransportMapping {
/**
* Gets the <code>Address</code> class that is this transport mapping
* supports.
* @return
* a subclass of {@link Address}.
*/
Class getSupportedAddressClass();
/**
* Returns the address that represents the incoming address this transport
* mapping uses to listen for incoming packets.
*
* @return
* the address for incoming packets or <code>null</code> this transport
* mapping is not configured to listen for incoming packets.
* @since 1.6
*/
Address getListenAddress();
/**
* Sends a message to the supplied address using this transport.
* @param address
* an <code>Address</code> instance denoting the target address.
* @param message
* the whole message as an array of bytes.
* @throws IOException
*/
void sendMessage(Address address, byte[] message) throws IOException;
/**
* Adds a message dispatcher to the transport. Normally, at least one
* message dispatcher needs to be added to process responses (or requests).
* @param dispatcher
* a MessageDispatcher instance.
* @see MessageDispatcherImpl
* @deprecated
* Use {@link #addTransportListener} instead. This method has
* been deprecated because the direct coupling between MessageDispatcher
* and TransportMappings is not flexible enough and prevents reusing
* TransportMappings for other purposes. This method will be removed
* with SNMP4J 2.0.
*/
void addMessageDispatcher(MessageDispatcher dispatcher);
/**
* Removes a message dispatcher. Incoming messages will no longer be
* propagated to the supplied message dispatcher.
* @param dispatcher
* a previously added MessageDispatcher instance.
* @see #addMessageDispatcher
* @deprecated
* Use {@link #removeTransportListener} instead.
*/
void removeMessageDispatcher(MessageDispatcher dispatcher);
/**
* Adds a transport listener to the transport. Normally, at least one
* transport listener needs to be added to process incoming messages.
* @param transportListener
* a <code>TransportListener</code> instance.
* @since 1.6
*/
void addTransportListener(TransportListener transportListener);
/**
* Removes a transport listener. Incoming messages will no longer be
* propagated to the supplied <code>TransportListener</code>.
* @param transportListener
* a <code>TransportListener</code> instance.
* @since 1.6
*/
void removeTransportListener(TransportListener transportListener);
/**
* Closes the transport an releases all bound resources synchronously.
* @throws IOException
*/
void close() throws IOException;
/**
* Listen for incoming messages. For connection oriented transports, this
* method needs to be called before {@link #sendMessage} is called for the
* first time.
* @throws IOException
*/
void listen() throws IOException;
/**
* Returns <code>true</code> if the transport mapping is listening for
* incoming messages. For connection oriented transport mappings this
* is a prerequisite to be able to send SNMP messages. For connectionless
* transport mappings it is a prerequisite to be able to receive responses.
* @return
* <code>true</code> if this transport mapping is listening for messages.
* @since 1.1
*/
boolean isListening();
/**
* Gets the maximum length of an incoming message that can be successfully
* processed by this transport mapping implementation.
* @return
* an integer > 484.
*/
int getMaxInboundMessageSize();
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -