MetricManager.INSTANCE.getGuage(sessions::size, name(GremlinServer.class, "sessions"));
}
public static void evalOp(final Context context) throws OpProcessorException {
final Timer.Context timerContext = evalOpTimer.time();
final ChannelHandlerContext ctx = context.getChannelHandlerContext();
final RequestMessage msg = context.getRequestMessage();
final Session session = getSession(context, msg);
// place the session on the channel context so that it can be used during serialization. in this way
// the serialization can occur on the same thread used to execute the gremlin within the session. this
// is important given the threadlocal nature of Graph implementation transactions.
context.getChannelHandlerContext().channel().attr(StateKey.SESSION).set(session);
final String script = (String) msg.getArgs().get(Tokens.ARGS_GREMLIN);
final Optional<String> language = Optional.ofNullable((String) msg.getArgs().get(Tokens.ARGS_LANGUAGE));
final Bindings bindings = session.getBindings();
final Map<String, Object> requestBindings = Optional.ofNullable((Map<String, Object>) msg.getArgs().get(Tokens.ARGS_BINDINGS)).orElse(new HashMap<>());
// parameter bindings override session bindings
bindings.putAll(requestBindings);
final CompletableFuture<Object> future = session.getGremlinExecutor().eval(script, language, bindings);
future.handle((v, t) -> timerContext.stop());
future.thenAccept(o -> ctx.write(Pair.with(msg, IteratorUtil.convertToIterator(o))));
future.exceptionally(se -> {
logger.warn(String.format("Exception processing a script on request [%s].", msg), se);
ctx.writeAndFlush(ResponseMessage.build(msg).code(ResponseStatusCode.SERVER_ERROR_SCRIPT_EVALUATION).statusMessage(se.getMessage()).create());
return null;
});
}