/*
* Sone - AbstractCommand.java - Copyright © 2011–2016 David Roden
*
* This program 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.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
*/
package net.pterodactylus.sone.freenet.fcp;
import freenet.node.FSParseException;
import freenet.support.SimpleFieldSet;
/**
* Basic implementation of a {@link Command} with various helper methods to
* simplify processing of input parameters.
*
* @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
*/
public abstract class AbstractCommand implements Command {
//
// PROTECTED METHODS
//
/**
* Returns a String value from the given simple field set.
*
* @param simpleFieldSet
* The simple field set to get the value from
* @param key
* The key of the value
* @return The String value
* @throws FcpException
* if there is no value for the given key in the simple field
* set, or the value can not be converted to a String
*/
protected static String getString(SimpleFieldSet simpleFieldSet, String key) throws FcpException {
try {
return simpleFieldSet.getString(key);
} catch (FSParseException fspe1) {
throw new FcpException("Could not get parameter “" + key + "” as String.", fspe1);
}
}
/**
* Returns an int value from the given simple field set.
*
* @param simpleFieldSet
* The simple field set to get the value from
* @param key
* The key of the value
* @return The int value
* @throws FcpException
* if there is no value for the given key in the simple field
* set, or the value can not be converted to an int
*/
protected static int getInt(SimpleFieldSet simpleFieldSet, String key) throws FcpException {
try {
return simpleFieldSet.getInt(key);
} catch (FSParseException fspe1) {
throw new FcpException("Could not get parameter “" + key + "” as int.", fspe1);
}
}
/**
* Returns an int value from the given simple field set, returning a default
* value if the value can not be found or converted.
*
* @param simpleFieldSet
* The simple field set to get the value from
* @param key
* The key of the value
* @param defaultValue
* The default value
* @return The int value
*/
protected static int getInt(SimpleFieldSet simpleFieldSet, String key, int defaultValue) {
return simpleFieldSet.getInt(key, defaultValue);
}
/**
* Returns a boolean value from the given simple field set.
*
* @param simpleFieldSet
* The simple field set to get the value from
* @param key
* The key of the value
* @return The boolean value
* @throws FcpException
* if there is no value for the given key in the simple field
* set, or the value can not be converted to a boolean
*/
protected static boolean getBoolean(SimpleFieldSet simpleFieldSet, String key) throws FcpException {
try {
return simpleFieldSet.getBoolean(key);
} catch (FSParseException fspe1) {
throw new FcpException("Could not get parameter “" + key + "” as boolean.", fspe1);
}
}
/**
* Returns a boolean value from the given simple field set, returning a
* default value if the value can not be found or converted.
*
* @param simpleFieldSet
* The simple field set to get the value from
* @param key
* The key of the value
* @param defaultValue
* The default value
* @return The boolean value
*/
protected static boolean getBoolean(SimpleFieldSet simpleFieldSet, String key, boolean defaultValue) {
return simpleFieldSet.getBoolean(key, defaultValue);
}
}