/*
* Copyright 2009-2014 Jagornet Technologies, LLC. All Rights Reserved.
*
* This software is the proprietary information of Jagornet Technologies, LLC.
* Use is subject to license terms.
*
*/
/*
* This file BaseUnsignedByteOption.java is part of Jagornet DHCP.
*
* Jagornet DHCP is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Jagornet DHCP is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Jagornet DHCP. If not, see <http://www.gnu.org/licenses/>.
*
*/
package com.jagornet.dhcp.option.base;
import java.io.IOException;
import java.nio.ByteBuffer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.jagornet.dhcp.option.DhcpComparableOption;
import com.jagornet.dhcp.util.Util;
import com.jagornet.dhcp.xml.OpaqueData;
import com.jagornet.dhcp.xml.OpaqueDataOptionType;
import com.jagornet.dhcp.xml.Operator;
import com.jagornet.dhcp.xml.OptionExpression;
import com.jagornet.dhcp.xml.UnsignedByteOptionType;
/**
* Title: BaseUnsignedByteOption
* Description: The abstract base class for unsigned byte DHCP options.
*
* @author A. Gregory Rabil
*/
public abstract class BaseUnsignedByteOption extends BaseDhcpOption implements DhcpComparableOption
{
private static Logger log = LoggerFactory.getLogger(BaseUnsignedByteOption.class);
protected short unsignedByte;
/**
* Instantiates a new unsigned byte option.
*/
public BaseUnsignedByteOption()
{
this(null);
}
/**
* Instantiates a new unsigned byte option.
*
* @param uByteOption the unsigned byte option
*/
public BaseUnsignedByteOption(UnsignedByteOptionType uByteOption)
{
super();
if (uByteOption != null) {
unsignedByte = uByteOption.getUnsignedByte();
}
}
public short getUnsignedByte() {
return unsignedByte;
}
public void setUnsignedByte(short unsignedByte) {
this.unsignedByte = unsignedByte;
}
/* (non-Javadoc)
* @see com.jagornet.dhcpv6.option.DhcpOption#getLength()
*/
public int getLength()
{
return 1; // always one bytes
}
/* (non-Javadoc)
* @see com.jagornet.dhcpv6.option.Encodable#encode()
*/
public ByteBuffer encode() throws IOException
{
ByteBuffer buf = super.encodeCodeAndLength();
buf.put((byte)unsignedByte);
return (ByteBuffer) buf.flip();
}
/* (non-Javadoc)
* @see com.jagornet.dhcpv6.option.Decodable#decode(java.nio.ByteBuffer)
*/
public void decode(ByteBuffer buf) throws IOException
{
int len = super.decodeLength(buf);
if ((len > 0) && (len <= buf.remaining())) {
unsignedByte = Util.getUnsignedByte(buf);
}
}
/* (non-Javadoc)
* @see com.jagornet.dhcpv6.option.DhcpComparableOption#matches(com.jagornet.dhcp.xml.OptionExpression)
*/
public boolean matches(OptionExpression expression)
{
if (expression == null)
return false;
if (expression.getCode() != this.getCode())
return false;
UnsignedByteOptionType exprOption = expression.getUByteOption();
if (exprOption != null) {
short exprUbyte = exprOption.getUnsignedByte();
Operator.Enum op = expression.getOperator();
if (op.equals(Operator.EQUALS)) {
return (unsignedByte == exprUbyte);
}
else if (op.equals(Operator.LESS_THAN)) {
return (unsignedByte < exprUbyte);
}
else if (op.equals(Operator.LESS_THAN_OR_EQUAL)) {
return (unsignedByte <= exprUbyte);
}
else if (op.equals(Operator.GREATER_THAN)) {
return (unsignedByte > exprUbyte);
}
else if (op.equals(Operator.GREATER_THAN_OR_EQUAL)) {
return (unsignedByte >= exprUbyte);
}
else {
log.warn("Unsupported expression operator: " + op);
}
}
// then see if we have an opaque option
OpaqueDataOptionType opaqueOption = expression.getOpaqueDataOption();
if (opaqueOption != null) {
OpaqueData opaque = opaqueOption.getOpaqueData();
if (opaque != null) {
String ascii = opaque.getAsciiValue();
if (ascii != null) {
try {
// need an Short to handle unsigned byte
if (unsignedByte == Short.parseShort(ascii)) {
return true;
}
}
catch (NumberFormatException ex) {
log.error("Invalid unsigned byte ASCII value for OpaqueData: " + ascii, ex);
}
}
else {
byte[] hex = opaque.getHexValue();
if ((hex != null) && (hex.length == 1)) {
int hexUnsignedByte = Short.valueOf(Util.toHexString(hex), 16);
if (unsignedByte == hexUnsignedByte) {
return true;
}
}
}
}
}
return false;
}
/* (non-Javadoc)
* @see java.lang.Object#toString()
*/
public String toString()
{
StringBuilder sb = new StringBuilder(Util.LINE_SEPARATOR);
sb.append(super.getName());
sb.append(": unsignedByte=");
sb.append(unsignedByte);
return sb.toString();
}
}