[DSL] Add the ability to send HTTP headers in sendHttpXXXRequest (#1272)
* Add the ability to send HTTP headers in HTTP.sendHttpXXXRequest actions Signed-off-by: Jimmy Tanagra <jcode@tanagra.id.au>pull/1284/head
parent
7130988901
commit
ec2958a072
|
@ -45,6 +45,7 @@ Import-Package: \
|
||||||
javax.measure.*,\
|
javax.measure.*,\
|
||||||
org.apache.*,\
|
org.apache.*,\
|
||||||
org.eclipse.jdt.annotation;resolution:=optional,\
|
org.eclipse.jdt.annotation;resolution:=optional,\
|
||||||
|
org.eclipse.jetty.http.*,\
|
||||||
org.eclipse.xtext.xbase.lib,\
|
org.eclipse.xtext.xbase.lib,\
|
||||||
org.joda.*,\
|
org.joda.*,\
|
||||||
org.osgi.*,\
|
org.osgi.*,\
|
||||||
|
|
|
@ -13,8 +13,11 @@
|
||||||
package org.eclipse.smarthome.model.script.actions;
|
package org.eclipse.smarthome.model.script.actions;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
|
import org.eclipse.jetty.http.HttpMethod;
|
||||||
import org.eclipse.smarthome.io.net.http.HttpUtil;
|
import org.eclipse.smarthome.io.net.http.HttpUtil;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
@ -53,13 +56,32 @@ public class HTTP {
|
||||||
static public String sendHttpGetRequest(String url, int timeout) {
|
static public String sendHttpGetRequest(String url, int timeout) {
|
||||||
String response = null;
|
String response = null;
|
||||||
try {
|
try {
|
||||||
return HttpUtil.executeUrl("GET", url, timeout);
|
return HttpUtil.executeUrl(HttpMethod.GET.name(), url, timeout);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("Fatal transport error: {}", e.getMessage());
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send out a GET-HTTP request. Errors will be logged, returned values just ignored.
|
||||||
|
*
|
||||||
|
* @param url the URL to be used for the GET request.
|
||||||
|
* @param headers the HTTP headers to be sent in the request.
|
||||||
|
* @param timeout timeout in ms
|
||||||
|
* @return the response body or <code>NULL</code> when the request went wrong
|
||||||
|
*/
|
||||||
|
public static String sendHttpGetRequest(String url, Map<String, String> headers, int timeout) {
|
||||||
|
try {
|
||||||
|
Properties headerProperties = new Properties();
|
||||||
|
headerProperties.putAll(headers);
|
||||||
|
return HttpUtil.executeUrl(HttpMethod.GET.name(), url, headerProperties, null, null, timeout);
|
||||||
|
} catch (IOException e) {
|
||||||
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send out a PUT-HTTP request. Errors will be logged, returned values just ignored.
|
* Send out a PUT-HTTP request. Errors will be logged, returned values just ignored.
|
||||||
*
|
*
|
||||||
|
@ -80,7 +102,7 @@ public class HTTP {
|
||||||
static public String sendHttpPutRequest(String url, int timeout) {
|
static public String sendHttpPutRequest(String url, int timeout) {
|
||||||
String response = null;
|
String response = null;
|
||||||
try {
|
try {
|
||||||
response = HttpUtil.executeUrl("PUT", url, timeout);
|
response = HttpUtil.executeUrl(HttpMethod.PUT.name(), url, timeout);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("Fatal transport error: {}", e.getMessage());
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
@ -113,13 +135,34 @@ public class HTTP {
|
||||||
static public String sendHttpPutRequest(String url, String contentType, String content, int timeout) {
|
static public String sendHttpPutRequest(String url, String contentType, String content, int timeout) {
|
||||||
String response = null;
|
String response = null;
|
||||||
try {
|
try {
|
||||||
response = HttpUtil.executeUrl("PUT", url, IOUtils.toInputStream(content), contentType, timeout);
|
response = HttpUtil.executeUrl(HttpMethod.PUT.name(), url, IOUtils.toInputStream(content), contentType, timeout);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("Fatal transport error: {}", e.getMessage());
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send out a PUT-HTTP request. Errors will be logged, returned values just ignored.
|
||||||
|
*
|
||||||
|
* @param url the URL to be used for the PUT request.
|
||||||
|
* @param contentType the content type of the given <code>content</code>
|
||||||
|
* @param content the content to be send to the given <code>url</code> or <code>null</code> if no content should be sent.
|
||||||
|
* @param headers the HTTP headers to be sent in the request.
|
||||||
|
* @param timeout timeout in ms
|
||||||
|
* @return the response body or <code>NULL</code> when the request went wrong
|
||||||
|
*/
|
||||||
|
static public String sendHttpPutRequest(String url, String contentType, String content, Map<String, String> headers, int timeout) {
|
||||||
|
try {
|
||||||
|
Properties headerProperties = new Properties();
|
||||||
|
headerProperties.putAll(headers);
|
||||||
|
return HttpUtil.executeUrl(HttpMethod.PUT.name(), url, headerProperties, IOUtils.toInputStream(content), contentType, timeout);
|
||||||
|
} catch (IOException e) {
|
||||||
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send out a POST-HTTP request. Errors will be logged, returned values just ignored.
|
* Send out a POST-HTTP request. Errors will be logged, returned values just ignored.
|
||||||
*
|
*
|
||||||
|
@ -140,7 +183,7 @@ public class HTTP {
|
||||||
static public String sendHttpPostRequest(String url, int timeout) {
|
static public String sendHttpPostRequest(String url, int timeout) {
|
||||||
String response = null;
|
String response = null;
|
||||||
try {
|
try {
|
||||||
response = HttpUtil.executeUrl("POST", url, timeout);
|
response = HttpUtil.executeUrl(HttpMethod.POST.name(), url, timeout);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("Fatal transport error: {}", e.getMessage());
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
|
@ -173,13 +216,34 @@ public class HTTP {
|
||||||
static public String sendHttpPostRequest(String url, String contentType, String content, int timeout) {
|
static public String sendHttpPostRequest(String url, String contentType, String content, int timeout) {
|
||||||
String response = null;
|
String response = null;
|
||||||
try {
|
try {
|
||||||
response = HttpUtil.executeUrl("POST", url, IOUtils.toInputStream(content), contentType, timeout);
|
response = HttpUtil.executeUrl(HttpMethod.POST.name(), url, IOUtils.toInputStream(content), contentType, timeout);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("Fatal transport error: {}", e.getMessage());
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send out a POST-HTTP request. Errors will be logged, returned values just ignored.
|
||||||
|
*
|
||||||
|
* @param url the URL to be used for the GET request.
|
||||||
|
* @param contentType the content type of the given <code>content</code>
|
||||||
|
* @param content the content to be send to the given <code>url</code> or <code>null</code> if no content should be sent.
|
||||||
|
* @param headers the HTTP headers to be sent in the request.
|
||||||
|
* @param timeout timeout in ms
|
||||||
|
* @return the response body or <code>NULL</code> when the request went wrong
|
||||||
|
*/
|
||||||
|
public static String sendHttpPostRequest(String url, String contentType, String content, Map<String, String> headers, int timeout) {
|
||||||
|
try {
|
||||||
|
Properties headerProperties = new Properties();
|
||||||
|
headerProperties.putAll(headers);
|
||||||
|
return HttpUtil.executeUrl(HttpMethod.POST.name(), url, headerProperties, IOUtils.toInputStream(content), contentType, timeout);
|
||||||
|
} catch (IOException e) {
|
||||||
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Send out a DELETE-HTTP request. Errors will be logged, returned values just ignored.
|
* Send out a DELETE-HTTP request. Errors will be logged, returned values just ignored.
|
||||||
*
|
*
|
||||||
|
@ -200,11 +264,29 @@ public class HTTP {
|
||||||
static public String sendHttpDeleteRequest(String url, int timeout) {
|
static public String sendHttpDeleteRequest(String url, int timeout) {
|
||||||
String response = null;
|
String response = null;
|
||||||
try {
|
try {
|
||||||
response = HttpUtil.executeUrl("DELETE", url, timeout);
|
response = HttpUtil.executeUrl(HttpMethod.DELETE.name(), url, timeout);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("Fatal transport error: {}", e.getMessage());
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
}
|
}
|
||||||
return response;
|
return response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Send out a DELETE-HTTP request. Errors will be logged, returned values just ignored.
|
||||||
|
*
|
||||||
|
* @param url the URL to be used for the DELETE request.
|
||||||
|
* @param headers the HTTP headers to be sent in the request.
|
||||||
|
* @param timeout timeout in ms
|
||||||
|
* @return the response body or <code>NULL</code> when the request went wrong
|
||||||
|
*/
|
||||||
|
static public String sendHttpDeleteRequest(String url, Map<String, String> headers, int timeout) {
|
||||||
|
try {
|
||||||
|
Properties headerProperties = new Properties();
|
||||||
|
headerProperties.putAll(headers);
|
||||||
|
return HttpUtil.executeUrl(HttpMethod.DELETE.name(), url, headerProperties, null, null, timeout);
|
||||||
|
} catch (IOException e) {
|
||||||
|
logger.error("Fatal transport error: {}", e.getMessage());
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue