org.snmp4j.smi.TlsAddress Maven / Gradle / Ivy
/*_############################################################################
_##
_## SNMP4J - TlsAddress.java
_##
_## Copyright (C) 2003-2018 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.smi;
import org.snmp4j.log.LogAdapter;
import org.snmp4j.log.LogFactory;
import java.net.InetAddress;
/**
* The TlsAddress
represents a TLS transport addresses as defined
* by RFC 5953 SnmpTSLAddress textual convention.
*
* @author Frank Fock
* @version 3.2.1
* @since 2.0
*/
public class TlsAddress extends TcpAddress {
static final long serialVersionUID = 0L;
private static final LogAdapter logger = LogFactory.getLogger(TlsAddress.class);
public TlsAddress() {
super();
}
public TlsAddress(InetAddress inetAddress, int port) {
super(inetAddress, port);
}
public TlsAddress(String address) {
if (!parseAddress(address)) {
throw new IllegalArgumentException(address);
}
}
/**
* Create a {@link TlsAddress} from a {@link TcpAddress}.
* @param tcpAddress
* the {@link TcpAddress} for the new {@link TlsAddress}.
* @since 3.0.5
*/
public TlsAddress(TcpAddress tcpAddress) {
super(tcpAddress.getInetAddress(), tcpAddress.getPort());
}
public static Address parse(String address) {
try {
TlsAddress a = new TlsAddress();
if (a.parseAddress(address)) {
return a;
}
} catch (Exception ex) {
logger.error(ex);
}
return null;
}
public boolean equals(Object o) {
return (o instanceof TlsAddress) && super.equals(o);
}
/**
* Checks if the supplied address class is compatible with this class. For example, secure transport classes like
* TLS are not compatible with TCP because the latter is not able to provide the required security characteristics.
*
* @param other
* the {@link Address} class to check for compatibility.
*
* @return {@code true} if the provided address class has the same (compatible) on-the-wire characteristics than
* this address class. By default this is {@code true} if the provided class {@code other} is the same or a sub
* class than this class.
* @since 3.2.1
*/
@Override
public boolean isTransportCompatible(Class> other) {
return this.getClass().isAssignableFrom(other);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy