/****************************************************************************** * Copyright © 2013-2016 The Nxt Core Developers. * * * * See the AUTHORS.txt, DEVELOPER-AGREEMENT.txt and LICENSE.txt files at * * the top-level directory of this distribution for the individual copyright * * holder information and the developer policies on copyright and licensing. * * * * Unless otherwise agreed in a custom licensing agreement, no part of the * * Nxt software, including this file, may be copied, modified, propagated, * * or distributed except according to the terms contained in the LICENSE.txt * * file. * * * * Removal or modification of this copyright notice is prohibited. * * * ******************************************************************************/ package nxt.http; import nxt.crypto.HashFunction; import nxt.util.Convert; import org.json.simple.JSONObject; import org.json.simple.JSONStreamAware; import javax.servlet.http.HttpServletRequest; public final class Hash extends APIServlet.APIRequestHandler { static final Hash instance = new Hash(); private Hash() { super(new APITag[] {APITag.UTILS}, "hashAlgorithm", "secret", "secretIsText"); } @Override JSONStreamAware processRequest(HttpServletRequest req) throws ParameterException { byte algorithm = ParameterParser.getByte(req, "hashAlgorithm", (byte) 0, Byte.MAX_VALUE, false); HashFunction hashFunction = null; try { hashFunction = HashFunction.getHashFunction(algorithm); } catch (IllegalArgumentException ignore) {} if (hashFunction == null) { return JSONResponses.INCORRECT_HASH_ALGORITHM; } boolean secretIsText = "true".equalsIgnoreCase(req.getParameter("secretIsText")); byte[] secret; try { secret = secretIsText ? Convert.toBytes(req.getParameter("secret")) : Convert.parseHexString(req.getParameter("secret")); } catch (RuntimeException e) { return JSONResponses.INCORRECT_SECRET; } if (secret == null || secret.length == 0) { return JSONResponses.MISSING_SECRET; } JSONObject response = new JSONObject(); response.put("hash", Convert.toHexString(hashFunction.hash(secret))); return response; } @Override boolean allowRequiredBlockParameters() { return false; } @Override boolean requireBlockchain() { return false; } }