Implement Sell only mode and Sell only mode for specified currency
Improve checkSetup page and implement special linux version MaxRetries is now configurable.
This commit is contained in:
parent
361b0f4d80
commit
194890b022
|
@ -7,7 +7,6 @@
|
|||
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
|
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
|
||||
<sourceFolder url="file://$MODULE_DIR$/src/test/java" isTestSource="true" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/.idea" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/target" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
sellOnlyMode=true
|
|
@ -7,9 +7,11 @@ import org.springframework.stereotype.Controller;
|
|||
import org.springframework.ui.ModelMap;
|
||||
import org.springframework.util.StringUtils;
|
||||
import org.springframework.web.bind.annotation.RequestMapping;
|
||||
import org.springframework.web.bind.annotation.ResponseBody;
|
||||
import org.springframework.web.servlet.ModelAndView;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.net.InetAddress;
|
||||
import java.net.UnknownHostException;
|
||||
import java.util.HashMap;
|
||||
|
@ -19,17 +21,35 @@ import java.util.Map;
|
|||
* Created by Elroy on 10-7-2017.
|
||||
*/
|
||||
@Controller
|
||||
@RequestMapping("/checkSetup/**")
|
||||
|
||||
public class CheckSetupController {
|
||||
|
||||
@Autowired
|
||||
private GunbotProxyService gunbotProxyService;
|
||||
@Autowired
|
||||
private Util util;
|
||||
private Map<String, String> setupData = new HashMap<>();
|
||||
|
||||
@RequestMapping
|
||||
@RequestMapping("/checkSetup/**")
|
||||
public ModelAndView checkSetup(ModelMap modelMap) {
|
||||
modelMap.put("setupData", setupData());
|
||||
return new ModelAndView("setupData", modelMap);
|
||||
}
|
||||
|
||||
@ResponseBody
|
||||
@RequestMapping("/checkSetupLinux/**")
|
||||
public String checkSetupLinux() throws IOException {
|
||||
StringBuilder stringData = new StringBuilder();
|
||||
stringData.append("\n\n");
|
||||
Map<String, String> setupData = setupData();
|
||||
for (Map.Entry entry : setupData.entrySet()) {
|
||||
stringData.append(String.format("%s -- %s \n", entry.getKey(), entry.getValue()));
|
||||
}
|
||||
return stringData.toString();
|
||||
}
|
||||
|
||||
private Map<String, String> setupData() {
|
||||
Map<String, String> setupData = new HashMap<>();
|
||||
|
||||
try {
|
||||
String keyName = "default_apiKey";
|
||||
String secretName = "default_apiSecret";
|
||||
|
@ -69,9 +89,9 @@ public class CheckSetupController {
|
|||
try {
|
||||
InetAddress address = InetAddress.getByName("poloniex.com");
|
||||
if (address.getHostAddress().equals("127.0.0.1")) {
|
||||
setupData.put("hostfile", "Looking good!");
|
||||
setupData.put(String.format("hostfile (%s)", address.getHostAddress()), "Looking good!");
|
||||
} else {
|
||||
setupData.put("hostfile", "poloniex.com is not pointing to 127.0.0.1");
|
||||
setupData.put(String.format("hostfile (%s)", address.getHostAddress()), "poloniex.com is not pointing to 127.0.0.1");
|
||||
}
|
||||
} catch (UnknownHostException e) {
|
||||
setupData.put("hostfile", e.getMessage());
|
||||
|
@ -80,9 +100,9 @@ public class CheckSetupController {
|
|||
try {
|
||||
InetAddress address = InetAddress.getByName("www.poloniex.com");
|
||||
if (!address.getHostAddress().equals("127.0.0.1")) {
|
||||
setupData.put("www.poloniex.com", "Looking good!");
|
||||
setupData.put(String.format("www.poloniex.com (%s)", address.getHostAddress()), "Looking good!");
|
||||
} else {
|
||||
setupData.put("www.poloniex.com", "www.poloniex.com should not point to 127.0.0.1");
|
||||
setupData.put(String.format("www.poloniex.com (%s)", address.getHostAddress()), "www.poloniex.com should not point to 127.0.0.1");
|
||||
}
|
||||
} catch (UnknownHostException e) {
|
||||
setupData.put("www.poloniex.com", e.getMessage());
|
||||
|
@ -91,20 +111,18 @@ public class CheckSetupController {
|
|||
String gunbotLocation = util.getEnvProperty("gunbot.location");
|
||||
if (!StringUtils.isEmpty(gunbotLocation.length())) {
|
||||
if (!gunbotLocation.startsWith("file://")) {
|
||||
setupData.put("Gunbot location", "Your file location should start with 'file://'");
|
||||
setupData.put("Gunbot location (Optional)", "Your file location should start with 'file://'");
|
||||
} else {
|
||||
File file = new File(gunbotLocation.replace("file://", ""));
|
||||
if (file.exists()) {
|
||||
setupData.put("Gunbot location", "Looking good!");
|
||||
setupData.put("Gunbot location (Optional)", "Looking good!");
|
||||
} else {
|
||||
setupData.put("Gunbot location", "The specified location does not exist");
|
||||
setupData.put("Gunbot location (Optional)", "The specified location does not exist");
|
||||
}
|
||||
}
|
||||
} else {
|
||||
setupData.put("Gunbot location", "You cannot use monitoring without this");
|
||||
setupData.put("Gunbot location (Optional)", "You cannot use monitoring without this");
|
||||
}
|
||||
|
||||
modelMap.put("setupData", setupData);
|
||||
return new ModelAndView("setupData", modelMap);
|
||||
return setupData;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -8,6 +8,7 @@ import com.google.gson.JsonElement;
|
|||
import com.google.gson.JsonObject;
|
||||
import com.google.gson.JsonParser;
|
||||
import nl.komtek.gpi.services.GunbotProxyService;
|
||||
import nl.komtek.gpi.utils.Util;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
|
@ -18,6 +19,7 @@ import org.springframework.web.bind.annotation.RequestParam;
|
|||
import org.springframework.web.bind.annotation.ResponseBody;
|
||||
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
import java.math.BigDecimal;
|
||||
import java.time.ZoneOffset;
|
||||
import java.util.List;
|
||||
|
@ -35,6 +37,8 @@ public class GunbotProxyController {
|
|||
private boolean doubleBuyProtection;
|
||||
@Value("${doubleBuyProtectionSeconds:0}")
|
||||
private int doubleBuyProtectionSeconds;
|
||||
@Autowired
|
||||
private Util util;
|
||||
private Logger logger = LogManager.getLogger(GunbotProxyController.class);
|
||||
private PoloniexDataMapper mapper = new PoloniexDataMapper();
|
||||
|
||||
|
@ -138,10 +142,20 @@ public class GunbotProxyController {
|
|||
@RequestMapping(value = "/tradingApi/**", params = "command=buy")
|
||||
@ResponseBody
|
||||
public String tradingRequestBuy(HttpServletRequest request,
|
||||
HttpServletResponse response,
|
||||
@RequestParam String currencyPair,
|
||||
@RequestParam BigDecimal rate,
|
||||
@RequestParam BigDecimal amount) {
|
||||
|
||||
boolean globalSellOnlyMode = Boolean.parseBoolean(util.getConfigurationProperty("sellOnlyMode"));
|
||||
boolean pairSellOnlyMode = Boolean.parseBoolean(util.getConfigurationProperty(String.format("%s_sellOnlyMode", currencyPair)));
|
||||
if (globalSellOnlyMode || pairSellOnlyMode) {
|
||||
String message = String.format("You are not allowed to buy. Sell Only mode is active for %s", currencyPair);
|
||||
logger.info(message);
|
||||
response.setStatus(403);
|
||||
return message;
|
||||
}
|
||||
|
||||
String key = request.getHeader("key");
|
||||
if (doubleBuyProtection || doubleBuyProtectionSeconds > 0) {
|
||||
return gunbotProxyService.buyOrderWithProtection(key, currencyPair, rate, amount);
|
||||
|
|
|
@ -13,6 +13,7 @@ import nl.komtek.gpi.utils.Util;
|
|||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.beans.factory.annotation.Value;
|
||||
import org.springframework.boot.SpringApplication;
|
||||
import org.springframework.cache.annotation.CacheEvict;
|
||||
import org.springframework.cache.annotation.CachePut;
|
||||
|
@ -40,6 +41,8 @@ public class GunbotProxyService {
|
|||
private ApplicationContext applicationContext;
|
||||
@Autowired
|
||||
private Util util;
|
||||
@Value("${connection.maxRetries:6}")
|
||||
private int maxRetries;
|
||||
private Map<String, PoloniexTradingAPIClient> poloniexDefaultAPIClients = new HashMap<>();
|
||||
private Map<String, PoloniexTradingAPIClient> poloniexTradingAPIClients = new HashMap<>();
|
||||
private Map<String, String> marketMapping = new HashMap<>();
|
||||
|
@ -81,7 +84,7 @@ public class GunbotProxyService {
|
|||
retryPolicy = new RetryPolicy()
|
||||
.retryOn(failure -> failure instanceof Exception)
|
||||
.withDelay(500, TimeUnit.MILLISECONDS)
|
||||
.withMaxRetries(6);
|
||||
.withMaxRetries(maxRetries);
|
||||
}
|
||||
|
||||
private boolean createMarketDefaultApiClients(String market) {
|
||||
|
|
|
@ -0,0 +1,24 @@
|
|||
package nl.komtek.gpi.utils;
|
||||
|
||||
/**
|
||||
* Created by Elroy on 13-7-2017.
|
||||
*/
|
||||
import java.util.Properties;
|
||||
|
||||
public class CaseLessProperties extends Properties {
|
||||
|
||||
public Object put(Object key, Object value) {
|
||||
String lowercase = ((String) key).toLowerCase();
|
||||
return super.put(lowercase, value);
|
||||
}
|
||||
|
||||
public String getProperty(String key) {
|
||||
String lowercase = key.toLowerCase();
|
||||
return super.getProperty(lowercase);
|
||||
}
|
||||
|
||||
public String getProperty(String key, String defaultValue) {
|
||||
String lowercase = key.toLowerCase();
|
||||
return super.getProperty(lowercase, defaultValue);
|
||||
}
|
||||
}
|
|
@ -1,10 +1,16 @@
|
|||
package nl.komtek.gpi.utils;
|
||||
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.core.env.Environment;
|
||||
import org.springframework.stereotype.Component;
|
||||
import org.springframework.util.StringUtils;
|
||||
|
||||
import java.io.FileInputStream;
|
||||
import java.io.InputStream;
|
||||
import java.util.Properties;
|
||||
|
||||
/**
|
||||
* Created by Elroy on 10-7-2017.
|
||||
*/
|
||||
|
@ -13,9 +19,23 @@ public class Util {
|
|||
|
||||
@Autowired
|
||||
private Environment environment;
|
||||
private Logger logger = LogManager.getLogger(Util.class);
|
||||
|
||||
public String getEnvProperty(String key) {
|
||||
String value = StringUtils.trimAllWhitespace(environment.getProperty(key));
|
||||
return StringUtils.replace(value, "\"", "");
|
||||
}
|
||||
|
||||
public String getConfigurationProperty(String key) {
|
||||
CaseLessProperties prop = new CaseLessProperties();
|
||||
String value = null;
|
||||
try (InputStream input = new FileInputStream("configuration.properties")) {
|
||||
prop.load(input);
|
||||
value = prop.getProperty(key);
|
||||
logger.debug(String.format("reading property key %s -- value %s"), key, value);
|
||||
} catch (Exception e) {
|
||||
logger.error("Error reading configuration file", e.getMessage());
|
||||
}
|
||||
return value;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue