package nl.knaw.huygens.alexandria.textgraph; /* * #%L * alexandria-main * ======= * Copyright (C) 2015 - 2017 Huygens ING (KNAW) * ======= * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program. If not, see * <http://www.gnu.org/licenses/gpl-3.0.html>. * #L% */ import java.util.UUID; import com.google.common.base.Joiner; import nl.knaw.huygens.alexandria.api.EndpointPaths; import nl.knaw.huygens.alexandria.api.model.text.TextImportStatus; import nl.knaw.huygens.alexandria.endpoint.LocationBuilder; import nl.knaw.huygens.alexandria.model.AlexandriaResource; import nl.knaw.huygens.alexandria.service.AlexandriaService; public class TextGraphImportTask implements Runnable { private AlexandriaService service; private LocationBuilder locationBuilder; private String xml; private AlexandriaResource resource; private TextImportStatus status; private UUID resourceId; public TextGraphImportTask(AlexandriaService service, LocationBuilder locationBuilder, String xml, AlexandriaResource resource) { this.service = service; this.locationBuilder = locationBuilder; this.xml = xml; this.resource = resource; this.resourceId = resource.getId(); this.status = new TextImportStatus(); } public TextImportStatus getStatus() { return status; } @Override public void run() { status.setStarted(); try { ParseResult result = TextGraphUtil.parse(xml); boolean success = service.storeTextGraph(resourceId, result); if (success) { status.setTextURI(locationBuilder.locationOf(resource, EndpointPaths.TEXT, "xml")); } else { status.getValidationErrors().add("textgraph store failed"); } } catch (Exception e) { e.printStackTrace(); status.getValidationErrors().add("Exception thrown: " + e); status.getValidationErrors().add("Exception message: " + e.getMessage()); status.getValidationErrors().add("Stacktrace: " + Joiner.on("\n").join(e.getStackTrace())); } status.setDone(); } }