Skip to content

Commit fd65dec

Browse files
committed
GH-944 Remove deprecations and update documentation for MessageRoutingCallback
Resolves #944
1 parent e5302f2 commit fd65dec

File tree

5 files changed

+9
-67
lines changed

5 files changed

+9
-67
lines changed

docs/src/main/asciidoc/spring-cloud-function.adoc

-11
Original file line numberDiff line numberDiff line change
@@ -193,17 +193,6 @@ public MessageRoutingCallback customRouter() {
193193
In the preceding example you can see a very simple implementation of `MessageRoutingCallback` which determines the function definition from
194194
`func_name` Message header of the incoming Message and returns the instance of `FunctionRoutingResult` containing the definition of function to invoke.
195195

196-
Additionally, the `FunctionRoutingResult` provides another constructor allowing you to provide an instance of `Message` as second argument to be used down stream.
197-
This is primarily for runtime optimizations. To better understand this case let's look at the following scenario.
198-
You need to route based on the payoload type. However, an input Message typically comes in as let's say JSON payload (as `byte[]`) . In order
199-
to determine the route-to function definition you need to first process such JSON and potentially create an instance of the target type.
200-
Once that determination is done you can pass it to `RoutingFunction` which still has a reference to the original Message with un-processed payload
201-
This means that somewhere downstream, type conversion/transformation would need to be repeated.
202-
203-
Allowing you to create a new `Message` with converted payload as part of the `FunctionRoutingResult` will instruct `RoutingFunction` to use such `Message`
204-
downstream. So effectively you letting the framework to benefit from the work you already did.
205-
206-
207196
*Message Headers*
208197

209198
If the input argument is of type `Message<?>`, you can communicate routing instruction by setting one of

spring-cloud-function-context/src/main/java/org/springframework/cloud/function/context/MessageRoutingCallback.java

+3-43
Original file line numberDiff line numberDiff line change
@@ -32,17 +32,9 @@
3232
*/
3333
public interface MessageRoutingCallback {
3434

35-
/**
36-
* @deprecated in 3.1 in favor of {@link #routingResult(Message)}
37-
*/
38-
@Deprecated
39-
default String functionDefinition(Message<?> message) {
40-
return null;
41-
}
42-
4335
/**
4436
* Computes and returns the instance of {@link FunctionRoutingResult} which encapsulates,
45-
* at the very minimum, function definition and optionally Message to be used downstream.
37+
* at the very minimum, function definition.
4638
* <br><br>
4739
* Providing such message is primarily an optimization feature. It could be useful for cases
4840
* where routing procedure is complex and results in, let's say, conversion of the payload to
@@ -52,39 +44,7 @@ default String functionDefinition(Message<?> message) {
5244
* @param message input message
5345
* @return instance of {@link FunctionRoutingResult} containing the result of the routing computation
5446
*/
55-
default FunctionRoutingResult routingResult(Message<?> message) {
56-
return new FunctionRoutingResult(functionDefinition(message));
57-
}
58-
59-
/**
60-
* Domain object that represents the result of the {@link MessageRoutingCallback#routingResult(Message)}
61-
* computation. It consists of function definition and optional Message to be used downstream
62-
* (see {@link MessageRoutingCallback#routingResult(Message)} for more details.
63-
*
64-
* @author Oleg Zhurakousky
65-
*
66-
*/
67-
final class FunctionRoutingResult {
68-
69-
private final String functionDefinition;
70-
71-
private final Message<?> message;
72-
73-
FunctionRoutingResult(String functionDefinition, Message<?> message) {
74-
this.functionDefinition = functionDefinition;
75-
this.message = message;
76-
}
77-
78-
public FunctionRoutingResult(String functionDefinition) {
79-
this(functionDefinition, null);
80-
}
81-
82-
public String getFunctionDefinition() {
83-
return functionDefinition;
84-
}
85-
86-
public Message<?> getMessage() {
87-
return message;
88-
}
47+
default String routingResult(Message<?> message) {
48+
return (String) message.getHeaders().get(FunctionProperties.FUNCTION_DEFINITION);
8949
}
9050
}

spring-cloud-function-context/src/main/java/org/springframework/cloud/function/context/config/RoutingFunction.java

+3-9
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,6 @@
2828
import org.springframework.cloud.function.context.FunctionCatalog;
2929
import org.springframework.cloud.function.context.FunctionProperties;
3030
import org.springframework.cloud.function.context.MessageRoutingCallback;
31-
import org.springframework.cloud.function.context.MessageRoutingCallback.FunctionRoutingResult;
3231
import org.springframework.cloud.function.context.catalog.SimpleFunctionRegistry.FunctionInvocationWrapper;
3332
import org.springframework.cloud.function.context.message.MessageUtils;
3433
import org.springframework.context.expression.MapAccessor;
@@ -123,14 +122,9 @@ private Object route(Object input, boolean originalInputIsPublisher) {
123122
if (input instanceof Message) {
124123
Message<?> message = (Message<?>) input;
125124
if (this.routingCallback != null) {
126-
FunctionRoutingResult routingResult = this.routingCallback.routingResult(message);
127-
if (routingResult != null) {
128-
if (StringUtils.hasText(routingResult.getFunctionDefinition())) {
129-
function = this.functionFromDefinition(routingResult.getFunctionDefinition());
130-
}
131-
if (routingResult.getMessage() != null) {
132-
message = routingResult.getMessage();
133-
}
125+
String functionDefinition = this.routingCallback.routingResult(message);
126+
if (StringUtils.hasText(functionDefinition)) {
127+
function = this.functionFromDefinition(functionDefinition);
134128
}
135129
}
136130
if (function == null) {

spring-cloud-function-context/src/test/java/org/springframework/cloud/function/context/MessageRoutingCallbackTests.java

+2-3
Original file line numberDiff line numberDiff line change
@@ -80,7 +80,7 @@ public MessageRoutingCallback messageRoutingCallback(JsonMapper jsonMapper) {
8080
return new MessageRoutingCallback() {
8181

8282
@Override
83-
public FunctionRoutingResult routingResult(Message<?> message) {
83+
public String routingResult(Message<?> message) {
8484
String payload = new String((byte[]) message.getPayload());
8585

8686
MessageBuilder<?> builder;
@@ -95,8 +95,7 @@ public FunctionRoutingResult routingResult(Message<?> message) {
9595
}
9696
Message<?> m = builder.copyHeaders(message.getHeaders()).build();
9797
createdMessageIds.put(functionDefinition, m.getHeaders().getId());
98-
FunctionRoutingResult functionRoutingResult = new FunctionRoutingResult(functionDefinition, m);
99-
return functionRoutingResult;
98+
return functionDefinition;
10099
}
101100
};
102101
}

spring-cloud-function-rsocket/src/test/java/org/springframework/cloud/function/rsocket/MessageRoutingCallbackRSocketTests.java

+1-1
Original file line numberDiff line numberDiff line change
@@ -109,7 +109,7 @@ public static class RoutingCallbackFunctionConfiguration {
109109
public MessageRoutingCallback customRouter() {
110110
return new MessageRoutingCallback() {
111111
@Override
112-
public String functionDefinition(Message<?> message) {
112+
public String routingResult(Message<?> message) {
113113
return (String) message.getHeaders().get("func_name");
114114
}
115115
};

0 commit comments

Comments
 (0)