1 package com.woorea.openstack.connector;
5 import java.util.logging.Logger;
7 import javax.ws.rs.ClientErrorException;
8 import javax.ws.rs.client.Client;
9 import javax.ws.rs.client.Entity;
10 import javax.ws.rs.client.Invocation;
11 import javax.ws.rs.client.WebTarget;
12 import javax.ws.rs.core.MediaType;
14 import org.glassfish.jersey.filter.LoggingFilter;
16 import com.woorea.openstack.base.client.HttpMethod;
17 import com.woorea.openstack.base.client.OpenStackClientConnector;
18 import com.woorea.openstack.base.client.OpenStackRequest;
19 import com.woorea.openstack.base.client.OpenStackResponse;
20 import com.woorea.openstack.base.client.OpenStackResponseException;
22 public class JaxRs20Connector implements OpenStackClientConnector {
24 protected Client client = OpenStack.CLIENT;
25 private LoggingFilter logger = new LoggingFilter(Logger.getLogger("os"), 10000);
28 public <T> OpenStackResponse request(OpenStackRequest<T> request) {
29 WebTarget target = client.target(request.endpoint()).path(request.path());
31 for(Map.Entry<String, List<Object> > entry : request.queryParams().entrySet()) {
32 for (Object o : entry.getValue()) {
33 target = target.queryParam(entry.getKey(), o);
36 target.register(logger);
37 Invocation.Builder invocation = target.request();
39 for(Map.Entry<String, List<Object>> h : request.headers().entrySet()) {
40 StringBuilder sb = new StringBuilder();
41 for(Object v : h.getValue()) {
42 sb.append(String.valueOf(v));
44 invocation.header(h.getKey(), sb);
47 Entity<?> entity = (request.entity() == null) ? null :
48 Entity.entity(request.entity().getEntity(), request.entity().getContentType());
52 return new JaxRs20Response(invocation.method(request.method().name(), entity));
54 if(HttpMethod.PUT == request.method()) {
55 return new JaxRs20Response(invocation.method(request.method().name(), Entity.entity("", MediaType.APPLICATION_JSON)));
57 return new JaxRs20Response(invocation.method(request.method().name()));
60 } catch (ClientErrorException e) {
61 throw new OpenStackResponseException(e.getResponse()
62 .getStatusInfo().toString(), e.getResponse().getStatus());