|
10 | 10 | import com.netflix.client.config.IClientConfigKey;
|
11 | 11 | import com.netflix.client.netty.RibbonTransport;
|
12 | 12 | import com.netflix.loadbalancer.ILoadBalancer;
|
| 13 | +import com.netflix.ribbonclientextensions.ClientOptions; |
| 14 | +import com.netflix.ribbonclientextensions.RequestTemplate; |
13 | 15 | import com.netflix.ribbonclientextensions.ResourceGroup;
|
14 | 16 |
|
15 |
| -public class HttpResourceGroup implements ResourceGroup { |
16 |
| - |
17 |
| - private String groupName; |
18 |
| - private IClientConfig config; |
19 |
| - private ILoadBalancer loadBalancer; |
20 |
| - |
21 |
| - public class HttpRequestTemplateBuilder extends RequestTemplateBuilder<HttpRequestTemplate<?>>{ |
22 |
| - private HttpClient<ByteBuf, ByteBuf> client; |
23 |
| - HttpRequestTemplateBuilder() { |
24 |
| - if (loadBalancer == null) { |
25 |
| - client = RibbonTransport.newHttpClient(config); |
26 |
| - } else { |
27 |
| - client = RibbonTransport.newHttpClient(loadBalancer, config); |
28 |
| - } |
29 |
| - } |
30 |
| - @Override |
31 |
| - public <T> HttpRequestTemplate<T> newRequestTemplate(String name, Class<? extends T> type) { |
32 |
| - return new HttpRequestTemplate<T>(name, HttpResourceGroup.this, client, type); |
33 |
| - } |
34 |
| - |
35 |
| - public HttpRequestTemplate<ByteBuf> newRequestTemplate(String name) { |
36 |
| - return newRequestTemplate(name, ByteBuf.class); |
37 |
| - } |
38 |
| - |
39 |
| - } |
| 17 | +public class HttpResourceGroup extends ResourceGroup<HttpRequestTemplate<?>> { |
| 18 | + private final HttpClient<ByteBuf, ByteBuf> client; |
40 | 19 |
|
41 |
| - @Override |
42 |
| - public String name() { |
43 |
| - return groupName; |
| 20 | + public HttpResourceGroup(String groupName) { |
| 21 | + this(groupName, null); |
44 | 22 | }
|
45 | 23 |
|
46 |
| - public HttpResourceGroup(String groupName) { |
47 |
| - this.groupName = groupName; |
48 |
| - config = getDefaultConfig(groupName); |
| 24 | + public HttpResourceGroup(String groupName, ClientOptions options) { |
| 25 | + super(groupName, options); |
| 26 | + client = RibbonTransport.newHttpClient(getClientConfig()); |
49 | 27 | }
|
50 | 28 |
|
51 |
| - protected IClientConfig getDefaultConfig(String groupName) { |
| 29 | + protected IClientConfig loadDefaultConfig(String groupName) { |
52 | 30 | return ClientConfigBuilder.newBuilderWithArchaiusProperties(groupName).build();
|
53 | 31 | }
|
54 | 32 |
|
55 | 33 | public HttpResourceGroup withCommonHeader(String name, String value) {
|
56 | 34 | return this;
|
57 | 35 | }
|
58 |
| - |
59 |
| - @SuppressWarnings({"rawtypes", "unchecked"}) |
| 36 | + |
60 | 37 | @Override
|
61 |
| - public HttpResourceGroup withClientConfig(IClientConfig overrideConfig) { |
62 |
| - if (config instanceof DefaultClientConfigImpl) { |
63 |
| - ((DefaultClientConfigImpl) config).applyOverride(overrideConfig); |
64 |
| - } else { |
65 |
| - for (IClientConfigKey key: CommonClientConfigKey.keys()) { |
66 |
| - Object value = overrideConfig.getPropertyWithType(key); |
67 |
| - if (value != null) { |
68 |
| - config.setPropertyWithType(key, value); |
69 |
| - } |
70 |
| - } |
71 |
| - } |
72 |
| - return this; |
| 38 | + public <T> HttpRequestTemplate<T> newRequestTemplate(String name, |
| 39 | + Class<? extends T> classType) { |
| 40 | + return new HttpRequestTemplate<T>(name, HttpResourceGroup.this, client, classType); |
73 | 41 | }
|
74 | 42 |
|
75 |
| - public HttpResourceGroup withLoadBalancer(ILoadBalancer loadBalancer) { |
76 |
| - this.loadBalancer = loadBalancer; |
77 |
| - return this; |
| 43 | + public HttpRequestTemplate<ByteBuf> newRequestTemplate(String name) { |
| 44 | + return newRequestTemplate(name, ByteBuf.class); |
78 | 45 | }
|
79 | 46 |
|
80 |
| - @SuppressWarnings("unchecked") |
81 |
| - @Override |
82 |
| - public HttpRequestTemplateBuilder requestTemplateBuilder() { |
83 |
| - return new HttpRequestTemplateBuilder(); |
84 |
| - } |
85 | 47 | }
|
0 commit comments