}
@Override
public Void call() throws Exception {
try {
final Notification notification = simplePushServer.handleNotification(endpoint, payload.toString(UTF_8));
final String uaid = notification.uaid();
final SockJsSessionContext session = userAgents.get(uaid).context();
if (logger.isDebugEnabled()) {
logger.debug("Sending notification for UAID [ " + notification.uaid() + "] " +
toJson(new NotificationMessageImpl(notification.ack())));
}
session.send(toJson(new NotificationMessageImpl(notification.ack())));
userAgents.updateAccessedTime(uaid);
} catch (final ChannelNotFoundException e) {
logger.debug("Could not find channel for [" + endpoint + "]");
} catch (final VersionException e) {
logger.debug(e.getMessage());