/****************************************************************************** * 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.Token; import org.json.simple.JSONObject; import org.json.simple.JSONStreamAware; import javax.servlet.http.HttpServletRequest; import static nxt.http.JSONResponses.INCORRECT_WEBSITE; import static nxt.http.JSONResponses.MISSING_SECRET_PHRASE; import static nxt.http.JSONResponses.MISSING_WEBSITE; public final class GenerateToken extends APIServlet.APIRequestHandler { static final GenerateToken instance = new GenerateToken(); private GenerateToken() { super(new APITag[] {APITag.TOKENS}, "website", "secretPhrase"); } @Override JSONStreamAware processRequest(HttpServletRequest req) { String secretPhrase = req.getParameter("secretPhrase"); String website = req.getParameter("website"); if (secretPhrase == null) { return MISSING_SECRET_PHRASE; } else if (website == null) { return MISSING_WEBSITE; } try { String tokenString = Token.generateToken(secretPhrase, website.trim()); JSONObject response = JSONData.token(Token.parseToken(tokenString, website)); response.put("token", tokenString); return response; } catch (RuntimeException e) { return INCORRECT_WEBSITE; } } @Override boolean requirePost() { return true; } @Override boolean allowRequiredBlockParameters() { return false; } @Override boolean requireBlockchain() { return false; } }