package io.lumify.web.routes.edge; import com.google.inject.Inject; import io.lumify.core.config.Configuration; import io.lumify.core.model.SourceInfo; import io.lumify.core.model.audit.AuditAction; import io.lumify.core.model.audit.AuditRepository; import io.lumify.core.model.ontology.OntologyRepository; import io.lumify.core.model.termMention.TermMentionRepository; 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.security.VisibilityTranslator; import io.lumify.core.user.User; import io.lumify.core.util.*; import io.lumify.miniweb.HandlerChain; import io.lumify.web.BaseRequestHandler; import org.securegraph.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class EdgeCreate extends BaseRequestHandler { private static final LumifyLogger LOGGER = LumifyLoggerFactory.getLogger(EdgeCreate.class); private final Graph graph; private final AuditRepository auditRepository; private final VisibilityTranslator visibilityTranslator; private final WorkQueueRepository workQueueRepository; private final TermMentionRepository termMentionRepository; @Inject public EdgeCreate( final Graph graph, final AuditRepository auditRepository, final OntologyRepository ontologyRepository, final VisibilityTranslator visibilityTranslator, final WorkspaceRepository workspaceRepository, final WorkQueueRepository workQueueRepository, final UserRepository userRepository, final Configuration configuration, final TermMentionRepository termMentionRepository ) { super(userRepository, workspaceRepository, configuration); this.graph = graph; this.auditRepository = auditRepository; this.visibilityTranslator = visibilityTranslator; this.workQueueRepository = workQueueRepository; this.termMentionRepository = termMentionRepository; } @Override public void handle(HttpServletRequest request, HttpServletResponse response, HandlerChain chain) throws Exception { final String sourceGraphVertexId = getRequiredParameter(request, "sourceGraphVertexId"); final String destGraphVertexId = getRequiredParameter(request, "destGraphVertexId"); final String predicateLabel = getRequiredParameter(request, "predicateLabel"); final String visibilitySource = getRequiredParameter(request, "visibilitySource"); final String justificationText = getOptionalParameter(request, "justificationText"); final String sourceInfoString = getOptionalParameter(request, "sourceInfo"); String workspaceId = getActiveWorkspaceId(request); User user = getUser(request); Authorizations authorizations = getAuthorizations(request, user); Vertex destVertex = graph.getVertex(destGraphVertexId, authorizations); Vertex sourceVertex = graph.getVertex(sourceGraphVertexId, authorizations); if (!graph.isVisibilityValid(new Visibility(visibilitySource), authorizations)) { LOGGER.warn("%s is not a valid visibility for %s user", visibilitySource, user.getDisplayName()); respondWithBadRequest(response, "visibilitySource", getString(request, "visibility.invalid")); chain.next(request, response); return; } Edge edge = GraphUtil.addEdge( graph, sourceVertex, destVertex, predicateLabel, justificationText, SourceInfo.fromString(sourceInfoString), visibilitySource, workspaceId, visibilityTranslator, termMentionRepository, user, authorizations ); // TODO: replace second "" when we implement commenting on ui auditRepository.auditRelationship(AuditAction.CREATE, sourceVertex, destVertex, edge, "", "", user, edge.getVisibility()); graph.flush(); if (LOGGER.isInfoEnabled()) { LOGGER.info("Statement created:\n" + JsonSerializer.toJson(edge, workspaceId, authorizations).toString(2)); } workQueueRepository.pushElement(edge); respondWithClientApiObject(response, ClientApiConverter.toClientApi(edge, workspaceId, authorizations)); } }