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