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"); } }