// We've already exceeded the maximum number of server redirects
// so consider this as an error condition for the client.
// Invoke the operationFailed callback and just return.
if (logger.isDebugEnabled())
logger.debug("Exceeded the number of server redirects (" + curNumServerRedirects + ") so error out.");
pubSubData.callback.operationFailed(pubSubData.context, new ServiceDownException(
new TooManyServerRedirectsException("Already reached max number of redirects: "
+ curNumServerRedirects)));
return;
}
// We will redirect and try to connect to the correct server
// stored in the StatusMsg of the response. First store the
// server that we sent the PubSub request to for the topic.
ByteString triedServer = ByteString.copyFromUtf8(HedwigSocketAddress.sockAddrStr(HedwigClientImpl
.getHostFromChannel(channel)));
if (pubSubData.triedServers == null)
pubSubData.triedServers = new LinkedList<ByteString>();
pubSubData.shouldClaim = true;
pubSubData.triedServers.add(triedServer);
// Now get the redirected server host (expected format is
// Hostname:Port:SSLPort) from the server's response message. If one is
// not given for some reason, then redirect to the default server
// host/VIP to repost the request.
String statusMsg = response.getStatusMsg();
InetSocketAddress redirectedHost;
if (statusMsg != null && statusMsg.length() > 0) {
if (cfg.isSSLEnabled()) {
redirectedHost = new HedwigSocketAddress(statusMsg).getSSLSocketAddress();
} else {
redirectedHost = new HedwigSocketAddress(statusMsg).getSocketAddress();
}
} else {
redirectedHost = cfg.getDefaultServerHost();
}
// Make sure the redirected server is not one we've already attempted
// already before in this PubSub request.
if (pubSubData.triedServers.contains(ByteString.copyFromUtf8(HedwigSocketAddress.sockAddrStr(redirectedHost)))) {
logger.error("We've already sent this PubSubRequest before to redirectedHost: " + redirectedHost
+ ", pubSubData: " + pubSubData);
pubSubData.callback.operationFailed(pubSubData.context, new ServiceDownException(
new ServerRedirectLoopException("Already made the request before to redirected host: "
+ redirectedHost)));
return;
}