/*
* Copyright 2014 Avanza Bank AB
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.avanza.astrix.remoting.client;
import java.lang.reflect.Method;
import java.util.Objects;
import com.avanza.astrix.core.remoting.RoutingKey;
import com.avanza.astrix.core.util.ReflectionUtil;
/**
*
* @author Elias Lindholm (elilin)
*
*/
abstract class PartitionedRouter {
private PartitionedRouter() {
}
abstract RoutingKey getRoutingKey(Object element);
/**
* Uses the given argument as routing key.<p>
*
* @return
*/
public static PartitionedRouter identity() {
return new Identity();
}
public static PartitionedRouter routingMethod(Method routingMethod) {
return new RoutingMethod(routingMethod);
}
private static class Identity extends PartitionedRouter {
@Override
RoutingKey getRoutingKey(Object element) {
return RoutingKey.create(element);
}
}
private static class RoutingMethod extends PartitionedRouter {
private final Method method;
public RoutingMethod(Method method) {
this.method = Objects.requireNonNull(method);
}
@Override
RoutingKey getRoutingKey(Object element) {
try {
Object result = ReflectionUtil.invokeMethod(method, element, null);
return RoutingKey.create(result);
} catch (Throwable e) {
throw new RuntimeException("Failed to invoke routing Method on: " + element, e);
}
}
}
}