package io.lumify.web.devTools;
import io.lumify.miniweb.HandlerChain;
import com.google.inject.Inject;
import io.lumify.core.config.Configuration;
import io.lumify.core.model.user.UserRepository;
import io.lumify.core.model.workQueue.WorkQueueRepository;
import io.lumify.core.model.workspace.WorkspaceRepository;
import io.lumify.core.user.User;
import io.lumify.core.util.LumifyLogger;
import io.lumify.core.util.LumifyLoggerFactory;
import io.lumify.web.BaseRequestHandler;
import org.securegraph.Authorizations;
import org.securegraph.Graph;
import org.securegraph.Vertex;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class DeleteVertex extends BaseRequestHandler {
private static final LumifyLogger LOGGER = LumifyLoggerFactory.getLogger(DeleteVertex.class);
private final Graph graph;
private final WorkQueueRepository workQueueRepository;
@Inject
public DeleteVertex(
UserRepository userRepository,
WorkspaceRepository workspaceRepository,
Configuration configuration,
Graph graph,
WorkQueueRepository workQueueRepository) {
super(userRepository, workspaceRepository, configuration);
this.graph = graph;
this.workQueueRepository = workQueueRepository;
}
@Override
public void handle(HttpServletRequest request, HttpServletResponse response, HandlerChain chain) throws Exception {
final String graphVertexId = getAttributeString(request, "graphVertexId");
User user = getUser(request);
Authorizations authorizations = getAuthorizations(request, user);
LOGGER.debug("deleting vertex: %s", graphVertexId);
Vertex vertex = graph.getVertex(graphVertexId, authorizations);
graph.removeVertex(vertex, authorizations);
graph.flush();
LOGGER.info("deleted vertex: %s", graphVertexId);
respondWithHtml(response, "Deleted vertex");
}
}