Implement server authentication methods
This commit is contained in:
parent
e3d99bf687
commit
eb054d7179
@ -20,27 +20,87 @@ package us.camin.api;
|
|||||||
|
|
||||||
import java.io.BufferedReader;
|
import java.io.BufferedReader;
|
||||||
import java.io.BufferedInputStream;
|
import java.io.BufferedInputStream;
|
||||||
|
import java.io.DataOutputStream;
|
||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.MalformedURLException;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.net.HttpURLConnection;
|
import java.net.HttpURLConnection;
|
||||||
|
import java.net.MalformedURLException;
|
||||||
|
import java.net.ProtocolException;
|
||||||
|
import java.net.URL;
|
||||||
|
import java.net.URLEncoder;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
import java.util.logging.Level;
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.security.MessageDigest;
|
||||||
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
|
||||||
import org.json.JSONArray;
|
import org.json.JSONArray;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
import org.json.JSONException;
|
import org.json.JSONException;
|
||||||
|
|
||||||
|
import java.util.Random;
|
||||||
|
import org.apache.commons.codec.binary.Hex;
|
||||||
|
|
||||||
public class Server {
|
public class Server {
|
||||||
Logger log = Logger.getLogger("Caminus.API");
|
Logger log = Logger.getLogger("Caminus.API");
|
||||||
private String m_url;
|
private String m_url;
|
||||||
|
private String m_name;
|
||||||
|
private String m_secret;
|
||||||
|
|
||||||
public ValidationResponse validatePlayer(String name) throws IOException {
|
private String genToken() {
|
||||||
ValidationResponse resp = new ValidationResponse();
|
Random r = new Random();
|
||||||
URL authServer = new URL(m_url+"validate/"+name);
|
int salt = r.nextInt();
|
||||||
log.info("Authing "+name+" against "+authServer);
|
MessageDigest crypt;
|
||||||
|
try {
|
||||||
|
crypt = MessageDigest.getInstance("SHA-1");
|
||||||
|
} catch (NoSuchAlgorithmException e) {
|
||||||
|
log.warning("Could not find SHA-1 algorithm");
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
crypt.reset();
|
||||||
|
String token = m_name+salt+m_secret;
|
||||||
|
crypt.update(token.getBytes());
|
||||||
|
token = m_name+"$"+salt+"$"+Hex.encodeHexString(crypt.digest());
|
||||||
|
log.info("Generated token "+token+" from "+m_name+salt+m_secret);
|
||||||
|
return token;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JSONObject exec(String path, String method, HashMap<String, String> params) throws MalformedURLException, ProtocolException, IOException {
|
||||||
|
HttpURLConnection conn = open(path);
|
||||||
|
conn.setRequestMethod(method);
|
||||||
|
if (params.size() > 0) {
|
||||||
|
conn.setDoOutput(true);
|
||||||
|
DataOutputStream out = new DataOutputStream(conn.getOutputStream());
|
||||||
|
Set<Map.Entry<String, String>> values = params.entrySet();
|
||||||
|
Iterator<Map.Entry<String, String>> it = values.iterator();
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
while(it.hasNext()) {
|
||||||
|
Map.Entry<String, String> param = it.next();
|
||||||
|
sb.append(URLEncoder.encode(param.getKey(), "UTF-8"));
|
||||||
|
sb.append("=");
|
||||||
|
sb.append(URLEncoder.encode(param.getValue(), "UTF-8"));
|
||||||
|
sb.append("&");
|
||||||
|
}
|
||||||
|
String postData = sb.substring(0, sb.length()-1);
|
||||||
|
conn.setFixedLengthStreamingMode(postData.length());
|
||||||
|
conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
|
||||||
|
out.writeBytes(postData);
|
||||||
|
}
|
||||||
|
return readJSON(conn);
|
||||||
|
}
|
||||||
|
|
||||||
|
public HttpURLConnection open(String path) throws MalformedURLException, IOException {
|
||||||
|
URL authServer = new URL(m_url+path);
|
||||||
HttpURLConnection conn = (HttpURLConnection)authServer.openConnection();
|
HttpURLConnection conn = (HttpURLConnection)authServer.openConnection();
|
||||||
|
conn.setRequestProperty("Authorization", "X-Caminus "+genToken());
|
||||||
|
return conn;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JSONObject readJSON(HttpURLConnection conn) throws IOException {
|
||||||
BufferedInputStream in = new BufferedInputStream(conn.getInputStream());
|
BufferedInputStream in = new BufferedInputStream(conn.getInputStream());
|
||||||
String jsonStr;
|
String jsonStr;
|
||||||
try {
|
try {
|
||||||
@ -51,9 +111,38 @@ public class Server {
|
|||||||
in.close();
|
in.close();
|
||||||
try {
|
try {
|
||||||
JSONObject jsonObj = new JSONObject(jsonStr);
|
JSONObject jsonObj = new JSONObject(jsonStr);
|
||||||
resp.valid = jsonObj.optBoolean("valid");
|
return jsonObj;
|
||||||
if (!resp.valid)
|
} catch (JSONException e) {
|
||||||
return resp;
|
throw new IOException("JSON parse error", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Convienence methods
|
||||||
|
public JSONObject exec(String path, String method) throws MalformedURLException, ProtocolException, IOException {
|
||||||
|
return exec(path, method, new HashMap<String, String>());
|
||||||
|
}
|
||||||
|
|
||||||
|
public JSONObject get(String path) throws IOException {
|
||||||
|
return exec(path, "GET");
|
||||||
|
}
|
||||||
|
|
||||||
|
public JSONObject put(String path, HashMap<String, String> params) throws MalformedURLException, IOException {
|
||||||
|
try {
|
||||||
|
return exec(path, "PUT", params);
|
||||||
|
} catch (ProtocolException e) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public ValidationResponse validatePlayer(String name) throws IOException {
|
||||||
|
log.info("Validating "+name+" against "+m_url);
|
||||||
|
ValidationResponse resp = new ValidationResponse();
|
||||||
|
JSONObject jsonObj = get("validate/"+name);
|
||||||
|
resp.valid = jsonObj.optBoolean("valid");
|
||||||
|
if (!resp.valid)
|
||||||
|
return resp;
|
||||||
|
|
||||||
|
try {
|
||||||
JSONArray perms = jsonObj.getJSONArray("permissions");
|
JSONArray perms = jsonObj.getJSONArray("permissions");
|
||||||
resp.permissions = new String[perms.length()];
|
resp.permissions = new String[perms.length()];
|
||||||
for (int i = 0;i<perms.length();i++) {
|
for (int i = 0;i<perms.length();i++) {
|
||||||
@ -62,6 +151,7 @@ public class Server {
|
|||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
throw new IOException("JSON parse error", e);
|
throw new IOException("JSON parse error", e);
|
||||||
}
|
}
|
||||||
|
|
||||||
return resp;
|
return resp;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,22 +163,19 @@ public class Server {
|
|||||||
m_url = url;
|
m_url = url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setServerName(String name) {
|
||||||
|
m_name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setServerSecret(String secret) {
|
||||||
|
m_secret = secret;
|
||||||
|
}
|
||||||
|
|
||||||
public String[] fetchMOTD(String user) throws IOException {
|
public String[] fetchMOTD(String user) throws IOException {
|
||||||
URL motdService = new URL(m_url+"motd/"+user);
|
log.info("Fetching motd for "+user);
|
||||||
log.info("Fetching MOTD for "+user+" from "+motdService);
|
|
||||||
HttpURLConnection conn = (HttpURLConnection)motdService.openConnection();
|
|
||||||
BufferedInputStream in = new BufferedInputStream(conn.getInputStream());
|
|
||||||
String jsonStr;
|
|
||||||
// Stupid scanner trick. \A means "beginning of input boundary".
|
|
||||||
try {
|
|
||||||
jsonStr = new java.util.Scanner(in).useDelimiter("\\A").next();
|
|
||||||
} catch (java.util.NoSuchElementException e) {
|
|
||||||
jsonStr = "";
|
|
||||||
}
|
|
||||||
in.close();
|
|
||||||
String[] ret = new String[0];
|
String[] ret = new String[0];
|
||||||
|
JSONObject jsonObj = get("motd/"+user);
|
||||||
try {
|
try {
|
||||||
JSONObject jsonObj = new JSONObject(jsonStr);
|
|
||||||
JSONArray motd = jsonObj.getJSONArray("motd");
|
JSONArray motd = jsonObj.getJSONArray("motd");
|
||||||
ret = new String[motd.length()];
|
ret = new String[motd.length()];
|
||||||
for (int i = 0;i<motd.length();i++) {
|
for (int i = 0;i<motd.length();i++) {
|
||||||
@ -99,4 +186,33 @@ public class Server {
|
|||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public double getBalance(String player) throws IOException {
|
||||||
|
log.info("Fetching balance for "+player);
|
||||||
|
JSONObject jsonObj = get("server/economy/"+player);
|
||||||
|
return jsonObj.optDouble("balance", 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public BalanceAdjustResponse adjustBalance(String player, double delta) throws IOException {
|
||||||
|
log.info("Adjusting balance for "+player+" by "+delta);
|
||||||
|
HashMap<String, String> params = new HashMap<String, String>();
|
||||||
|
params.put("delta", ""+delta);
|
||||||
|
JSONObject jsonObj = put("server/economy/"+player, params);
|
||||||
|
BalanceAdjustResponse resp = new BalanceAdjustResponse();
|
||||||
|
resp.success = jsonObj.optBoolean("success", false);
|
||||||
|
resp.newBalance = jsonObj.optDouble("balance", 0);
|
||||||
|
resp.message = jsonObj.optString("message", "");
|
||||||
|
return resp;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean pingAPI() {
|
||||||
|
log.info("Pinging API server to verify credentials");
|
||||||
|
try {
|
||||||
|
get("server/whoami");
|
||||||
|
} catch (IOException e) {
|
||||||
|
log.log(Level.SEVERE, "Could not ping API server.", e);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user