Compare commits
	
		
			11 Commits
		
	
	
		
			v2.0.2-cxf
			...
			v2.0.5-cxf
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 458cdad213 | |||
| 8b03d251e8 | |||
| a1acb3f9d9 | |||
| 00f25ff054 | |||
| 003afc208e | |||
| 85df5d3ea4 | |||
| 9a9a958913 | |||
| 37e8b63179 | |||
| 255a9c8e85 | |||
| c9833bb4b1 | |||
| bcb7d4a7ed | 
							
								
								
									
										2
									
								
								pom.xml
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								pom.xml
									
									
									
									
									
								
							| @@ -6,7 +6,7 @@ | |||||||
| 	 | 	 | ||||||
| 	<groupId>com.inteligr8</groupId> | 	<groupId>com.inteligr8</groupId> | ||||||
| 	<artifactId>common-rest-client</artifactId> | 	<artifactId>common-rest-client</artifactId> | ||||||
| 	<version>2.0.2-cxf</version> | 	<version>2.0.5-cxf</version> | ||||||
| 	<packaging>jar</packaging> | 	<packaging>jar</packaging> | ||||||
|  |  | ||||||
| 	<name>ReST API Client for Java</name> | 	<name>ReST API Client for Java</name> | ||||||
|   | |||||||
| @@ -14,6 +14,8 @@ | |||||||
|  */ |  */ | ||||||
| package com.inteligr8.rs; | package com.inteligr8.rs; | ||||||
|  |  | ||||||
|  | import org.apache.cxf.jaxrs.client.WebClient; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * This interface defines additional configurations specific to the Apache CXF |  * This interface defines additional configurations specific to the Apache CXF | ||||||
|  * JAX-RS library and its nuances. |  * JAX-RS library and its nuances. | ||||||
| @@ -35,4 +37,12 @@ public interface ClientCxfConfiguration extends ClientConfiguration { | |||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * A Jackson provider, logging filter, and authentication filter are already registered. | ||||||
|  |      *  | ||||||
|  |      * @param client A CXF client to configure. | ||||||
|  |      */ | ||||||
|  | 	default void configureClient(WebClient client) { | ||||||
|  | 	} | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -29,6 +29,8 @@ import org.slf4j.LoggerFactory; | |||||||
| import org.springframework.beans.factory.annotation.Autowired; | import org.springframework.beans.factory.annotation.Autowired; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.ObjectMapper; | ||||||
|  | import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; | ||||||
| import com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider; | import com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -42,7 +44,9 @@ public class ClientCxfImpl extends Client { | |||||||
| 	 | 	 | ||||||
| 	private final Logger logger = LoggerFactory.getLogger(ClientCxfImpl.class); | 	private final Logger logger = LoggerFactory.getLogger(ClientCxfImpl.class); | ||||||
|  |  | ||||||
|  |     private final Object sync = new Object(); | ||||||
| 	private ClientCxfConfiguration config; | 	private ClientCxfConfiguration config; | ||||||
|  |     private WebClient client; | ||||||
| 	 | 	 | ||||||
| 	/** | 	/** | ||||||
| 	 * This constructor is for Spring or POJO use. | 	 * This constructor is for Spring or POJO use. | ||||||
| @@ -77,16 +81,40 @@ public class ClientCxfImpl extends Client { | |||||||
| 	 * @return A CXF client (not JAX-RS). | 	 * @return A CXF client (not JAX-RS). | ||||||
| 	 */ | 	 */ | ||||||
| 	public WebClient getCxfClient() { | 	public WebClient getCxfClient() { | ||||||
| 		return this.getCxfClient(null); |         synchronized (this.sync) { | ||||||
|  |             if (this.client == null) | ||||||
|  |                 this.client = this.buildCxfClient(null); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return this.client; | ||||||
|  | 	} | ||||||
|  |      | ||||||
|  |     /** | ||||||
|  |      * @param authFilter A dynamic authorization filter. | ||||||
|  |      * @return A pre-configured CXF client (no URL) with the specified authorization. | ||||||
|  |      */ | ||||||
|  |     public WebClient getCxfClient(AuthorizationFilter authFilter) { | ||||||
|  |         if (authFilter == null) { | ||||||
|  |             return this.getCxfClient(); | ||||||
|  |         } else { | ||||||
|  |             return this.buildCxfClient(authFilter); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 	 | 	 | ||||||
| 	/** | 	/** | ||||||
| 	 * @param authFilter A post-configuration authorization filter. | 	 * @param authFilter A post-configuration authorization filter. | ||||||
| 	 * @return A CXF client (not JAX-RS). | 	 * @return A CXF client (not JAX-RS). | ||||||
| 	 */ | 	 */ | ||||||
| 	public WebClient getCxfClient(AuthorizationFilter authFilter) { | 	public WebClient buildCxfClient(AuthorizationFilter authFilter) { | ||||||
|  |         ObjectMapper om = new ObjectMapper(); | ||||||
|  |         om.registerModules(new JavaTimeModule()); | ||||||
|  |         this.getConfig().configureJacksonMapper(om); | ||||||
|  |  | ||||||
|  |         JacksonJaxbJsonProvider jacksonProvider = new JacksonJaxbJsonProvider(om, JacksonJaxbJsonProvider.DEFAULT_ANNOTATIONS); | ||||||
|  |         this.getConfig().configureJacksonProvider(jacksonProvider); | ||||||
|  |          | ||||||
| 		List<Object> providersAndFilters = new LinkedList<Object>(); | 		List<Object> providersAndFilters = new LinkedList<Object>(); | ||||||
| 		providersAndFilters.add(new JacksonJaxbJsonProvider()); | 		providersAndFilters.add(jacksonProvider); | ||||||
| 		providersAndFilters.add(new CxfLoggingFilter()); | 		providersAndFilters.add(new CxfLoggingFilter()); | ||||||
| 		providersAndFilters.add(new CxfMultipartProvider()); | 		providersAndFilters.add(new CxfMultipartProvider()); | ||||||
| 		 | 		 | ||||||
| @@ -109,6 +137,8 @@ public class ClientCxfImpl extends Client { | |||||||
| 			config.setBus(BusFactory.newInstance().createBus()); | 			config.setBus(BusFactory.newInstance().createBus()); | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
|  | 		this.config.configureClient(client); | ||||||
|  | 		 | ||||||
| 		return client; | 		return client; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|   | |||||||
| @@ -18,9 +18,10 @@ import javax.ws.rs.client.ClientBuilder; | |||||||
| import javax.ws.rs.client.WebTarget; | import javax.ws.rs.client.WebTarget; | ||||||
|  |  | ||||||
| import com.fasterxml.jackson.databind.DeserializationFeature; | import com.fasterxml.jackson.databind.DeserializationFeature; | ||||||
|  | import com.fasterxml.jackson.databind.ObjectMapper; | ||||||
| import com.fasterxml.jackson.databind.SerializationFeature; | import com.fasterxml.jackson.databind.SerializationFeature; | ||||||
|  | import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule; | ||||||
| import com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider; | import com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider; | ||||||
| import com.fasterxml.jackson.jaxrs.json.JacksonJsonProvider; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * A class that provides pre-configured JAX-RS Client & WebTarget objects. |  * A class that provides pre-configured JAX-RS Client & WebTarget objects. | ||||||
| @@ -66,7 +67,15 @@ public abstract class Client { | |||||||
| 	 * @return A pre-configured JAX-RS client (no URL) with the specified authorization. | 	 * @return A pre-configured JAX-RS client (no URL) with the specified authorization. | ||||||
| 	 */ | 	 */ | ||||||
| 	public final javax.ws.rs.client.Client buildClient(AuthorizationFilter authFilter) { | 	public final javax.ws.rs.client.Client buildClient(AuthorizationFilter authFilter) { | ||||||
| 		JacksonJsonProvider provider = new JacksonJaxbJsonProvider(); | 	    ObjectMapper om = new ObjectMapper(); | ||||||
|  | 	    om.registerModules(new JavaTimeModule()); | ||||||
|  | 	    this.getConfig().configureJacksonMapper(om); | ||||||
|  | 	     | ||||||
|  | 	    JacksonJaxbJsonProvider provider = new JacksonJaxbJsonProvider(om, JacksonJaxbJsonProvider.DEFAULT_ANNOTATIONS); | ||||||
|  |         provider.enable(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_AS_NULL); | ||||||
|  | 	    provider.disable(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_USING_DEFAULT_VALUE); | ||||||
|  | 	     | ||||||
|  | 		this.getConfig().configureJacksonProvider(provider); | ||||||
|          |          | ||||||
| 		if (this.getConfig().isWrapRootValueEnabled()) | 		if (this.getConfig().isWrapRootValueEnabled()) | ||||||
| 			provider.enable(SerializationFeature.WRAP_ROOT_VALUE); | 			provider.enable(SerializationFeature.WRAP_ROOT_VALUE); | ||||||
| @@ -83,6 +92,8 @@ public abstract class Client { | |||||||
| 			clientBuilder.register(authFilter); | 			clientBuilder.register(authFilter); | ||||||
| 		this.buildClient(clientBuilder); | 		this.buildClient(clientBuilder); | ||||||
| 		 | 		 | ||||||
|  | 		this.getConfig().configureClient(clientBuilder); | ||||||
|  | 		 | ||||||
| 		return clientBuilder.build(); | 		return clientBuilder.build(); | ||||||
| 	} | 	} | ||||||
|      |      | ||||||
|   | |||||||
| @@ -16,6 +16,11 @@ package com.inteligr8.rs; | |||||||
|  |  | ||||||
| import java.net.URI; | import java.net.URI; | ||||||
|  |  | ||||||
|  | import javax.ws.rs.client.ClientBuilder; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.ObjectMapper; | ||||||
|  | import com.fasterxml.jackson.jaxrs.json.JacksonJaxbJsonProvider; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * This interface defines the configurable parameters of the clients; primarily |  * This interface defines the configurable parameters of the clients; primarily | ||||||
|  * their default authentication and authorization. |  * their default authentication and authorization. | ||||||
| @@ -129,6 +134,18 @@ public interface ClientConfiguration { | |||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
|      |      | ||||||
|  |     /** | ||||||
|  |      * @param mapper A Jackson object mapper to configure. | ||||||
|  |      */ | ||||||
|  |     default void configureJacksonMapper(ObjectMapper mapper) { | ||||||
|  |     } | ||||||
|  | 	 | ||||||
|  | 	/** | ||||||
|  | 	 * @param provider A Jackson JAX-RS provider to configure. | ||||||
|  | 	 */ | ||||||
|  | 	default void configureJacksonProvider(JacksonJaxbJsonProvider provider) { | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| 	 | 	 | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| @@ -170,4 +187,12 @@ public interface ClientConfiguration { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|      |      | ||||||
|  |     /** | ||||||
|  |      * A Jackson provider, logging filter, and authentication filter are already registered. | ||||||
|  |      *  | ||||||
|  |      * @param clientBuilder A JAX-RS client builder to configure. | ||||||
|  |      */ | ||||||
|  |     default void configureClient(ClientBuilder clientBuilder) { | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user