diff options
author | lresende <lresende@13f79535-47bb-0310-9956-ffa450edef68> | 2012-06-20 00:31:38 +0000 |
---|---|---|
committer | lresende <lresende@13f79535-47bb-0310-9956-ffa450edef68> | 2012-06-20 00:31:38 +0000 |
commit | d10dbf4a6cb9a549ba8edca1805592b09e5585b8 (patch) | |
tree | f67a5c8eeac2e378e18ce226ea338070f1fb7803 /sca-java-2.x/trunk/modules/binding-rest-runtime/src/main/java/org/apache/tuscany/sca/binding/rest/provider/TuscanyRESTServlet.java | |
parent | 0841514e8aca337df394fcd5acae78a730812233 (diff) |
TUSCANY-4065 - Properly retrieving binding context within the response handlers
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1351908 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to '')
-rw-r--r-- | sca-java-2.x/trunk/modules/binding-rest-runtime/src/main/java/org/apache/tuscany/sca/binding/rest/provider/TuscanyRESTServlet.java | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/sca-java-2.x/trunk/modules/binding-rest-runtime/src/main/java/org/apache/tuscany/sca/binding/rest/provider/TuscanyRESTServlet.java b/sca-java-2.x/trunk/modules/binding-rest-runtime/src/main/java/org/apache/tuscany/sca/binding/rest/provider/TuscanyRESTServlet.java index 35c46ac56b..17756a7f23 100644 --- a/sca-java-2.x/trunk/modules/binding-rest-runtime/src/main/java/org/apache/tuscany/sca/binding/rest/provider/TuscanyRESTServlet.java +++ b/sca-java-2.x/trunk/modules/binding-rest-runtime/src/main/java/org/apache/tuscany/sca/binding/rest/provider/TuscanyRESTServlet.java @@ -94,6 +94,7 @@ public class TuscanyRESTServlet extends RestServlet { try { //store in thread local ThreadHTTPContext.setHTTPContext(bindingContext); + ThreadBindingContext.setBindingContext(binding); // handle special ?wadl request String query = request.getQueryString(); @@ -105,6 +106,7 @@ public class TuscanyRESTServlet extends RestServlet { } finally { //remove ThreadHTTPContext.removeHTTPContext(); + ThreadBindingContext.removeBindingContext(); } } @@ -209,6 +211,10 @@ public class TuscanyRESTServlet extends RestServlet { /** * TuscanyResponseHandler + * + * The response handler is shared, that's why we need to get the + * binding from the thread context otherwise different components + * might get wrong binding configuration (e.g. headers) * * Required to support declarative HTTP Headers */ @@ -222,6 +228,8 @@ public class TuscanyRESTServlet extends RestServlet { return; } + RESTBinding binding = ThreadBindingContext.getBindingContext(); + //process declarative headers for(HTTPHeader header : binding.getHttpHeaders()) { //treat special headers that need to be calculated |