本文整理匯總了Java中eu.unifiedviews.helpers.dpu.context.ContextUtils類的典型用法代碼示例。如果您正苦於以下問題:Java ContextUtils類的具體用法?Java ContextUtils怎麽用?Java ContextUtils使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
ContextUtils類屬於eu.unifiedviews.helpers.dpu.context包,在下文中一共展示了ContextUtils類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: loadGraphStatements
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Read all the statements in the given graph
* @param graphUri URI of the graph
* @throws DPUException
*/
private void loadGraphStatements(final URI graphUri) throws DPUException {
faultTolerance.execute(rdfInput, new FaultTolerance.ConnectionAction() {
@Override
public void action(RepositoryConnection connection) throws Exception {
RepositoryResult<Statement> repositoryResult = connection.getStatements(null, null, null, false, graphUri);
try {
rdfStringWriter.flush();
rdfWriter.startRDF();
while (repositoryResult.hasNext()) {
if (ctx.canceled()) {
throw ContextUtils.dpuExceptionCancelled(ctx);
}
rdfWriter.handleStatement(repositoryResult.next());
}
rdfWriter.endRDF();
} catch (RDFHandlerException e) {
throw new DPUException("Encountered an exception when parsing RDF statements from graph: " + graphUri.stringValue(), e);
}
}
});
}
示例2: loadGraphStatements
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Read all the statements in the given graph
* @param graphUri URI of the graph
* @throws DPUException
*/
private void loadGraphStatements(final URI graphUri) throws DPUException {
graphStatements = new HashSet<>();
faultTolerance.execute(rdfInput, new FaultTolerance.ConnectionAction() {
@Override
public void action(RepositoryConnection connection) throws Exception {
RepositoryResult<Statement> repositoryResult = connection.getStatements(null, null, null, false, graphUri);
graphStatements.clear();
while (repositoryResult.hasNext()) {
if (ctx.canceled()) {
throw ContextUtils.dpuExceptionCancelled(ctx);
}
graphStatements.add(repositoryResult.next());
}
}
});
}
示例3: loadFilenameUriMappings
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Read filename to URI mappings from the given graph
* @param graphUri URI of the graph
* @throws DPUException
*/
private void loadFilenameUriMappings(final URI graphUri) throws DPUException {
filenameUriMappings = new HashMap<>();
faultTolerance.execute(rdfInput, new FaultTolerance.ConnectionAction() {
@Override
public void action(RepositoryConnection connection) throws Exception {
RepositoryResult<Statement> repositoryResult = connection.getStatements(null, null, null, false, graphUri);
filenameUriMappings.clear();
while (repositoryResult.hasNext()) {
if (ctx.canceled()) {
throw ContextUtils.dpuExceptionCancelled(ctx);
}
Statement filenameStmt = repositoryResult.next();
filenameUriMappings.put(filenameStmt.getObject().stringValue(), filenameStmt.getSubject().stringValue());
}
}
});
}
示例4: zipFiles
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Pack files in given iterator into zip file and add metadata.
*
* @param zipFile
* @param filesIteration
*/
private void zipFiles(File zipFile, List<FilesDataUnit.Entry> filesIteration) throws DPUException {
final byte[] buffer = new byte[8196];
// Used to publish the error mesage only for the first time.
boolean firstFailure = true;
try (FileOutputStream fos = new FileOutputStream(zipFile); ZipOutputStream zos = new ZipOutputStream(fos)) {
// Itarate over files and zip them.
int counter = 0;
for (FilesDataUnit.Entry entry : filesIteration) {
LOG.info("Processing: {}/{}", counter++, filesIteration.size());
if (ctx.canceled()) {
break;
}
if (!addZipEntry(zos, buffer, entry)) {
if (firstFailure) {
// TODO This needs rework, we fail but not instantly?
ContextUtils.sendError(ctx, "zipper.errors.zip.failed", "");
}
firstFailure = false;
}
}
} catch (IOException ex) {
throw new DPUException(ex);
}
}
示例5: XsltExecutor
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
public XsltExecutor(XsltConfig_V2 config,
BlockingQueue<Task> taskQueue, FaultTolerance faultTolerance, UserExecContext ctx,
Integer totalFileCounter)
throws DPUException {
LOG.info("New executor created!");
this.proc = new Processor(false);
// register UUID extension function
proc.registerExtensionFunction(UUIDGenerator.getInstance());
this.compiler = proc.newXsltCompiler();
try {
this.executable = compiler.compile(
new StreamSource(new StringReader(config.getXsltTemplate())));
} catch (SaxonApiException ex) {
throw ContextUtils.dpuException(ctx, ex, "xslt.dpu.executor.errors.xsltCompile");
}
this.config = config;
this.taskQueue = taskQueue;
this.ctx = ctx;
this.totalFileCounter = totalFileCounter;
}
示例6: checkGraph
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
protected void checkGraph(RepositoryConnection connection, final List<RDFDataUnit.Entry> entries) throws DPUException {
SparqlUtils.SparqlAskObject ask = null;
try {
ask = SparqlUtils.createAsk(config.getAskQuery(), entries);
SparqlUtils.execute(connection, ask);
} catch (RepositoryException | MalformedQueryException | UpdateExecutionException | QueryEvaluationException | SparqlProblemException | DataUnitException e) {
throw new DPUException(e.getLocalizedMessage(), e);
}
if (!ask.result) {
reportFailure();
}
else {
//everything OK:
ContextUtils.sendShortInfo(ctx, "rdfvalidation.finished.ok");
}
}
示例7: getScriptWithPath
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
private String getScriptWithPath() throws DPUException {
DPUContext dpuContext = ctx.getExecMasterContext().getDpuContext();
Map<String, String> environment = dpuContext.getEnvironment();
String pathToScript = environment.get(SHELL_SCRIPT_PATH);
if (pathToScript == null || pathToScript.trim().equals("")) {
LOG.error("Directory with shell scripts is not set in beckend configuration file!");
throw ContextUtils.dpuException(ctx, "errors.pathToScriptsNotSet.backend");
}
File scriptDirFile = new File(pathToScript);
if (!scriptDirFile.exists()) {
LOG.error(String.format("Directory with shell scripts %s doesn't exist!", pathToScript));
throw ContextUtils.dpuException(ctx, "errors.pathToScriptsDoesntExist.backend");
}
File scriptFile = new File(pathToScript, config.getScriptName());
if (scriptFile == null || !scriptFile.exists()) {
LOG.error(String.format("Script %s doesn't exist!", config.getScriptName()));
throw ContextUtils.dpuException(ctx, "errors.scriptDoesntExist");
}
return scriptFile.getAbsolutePath();
}
示例8: innerExecute
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
@Override
protected void innerExecute() throws DPUException {
if (useDataset()) {
ContextUtils.sendShortInfo(ctx, "SparqlConstruct.execute.openrdfMode");
} else {
ContextUtils.sendShortInfo(ctx, "SparqlConstruct.execute.virtuosoMode");
}
// Update query ie. substitute constract with insert.
String query = config.getQuery();
if (query == null || query.isEmpty()) {
throw ContextUtils.dpuException(ctx, "SparqlConstruct.execute.exception.emptyQuery");
}
// Modify query - we always do inserts.
query = query.replaceFirst("(?i)CONSTRUCT", "INSERT");
// Get graphs.
final List<RDFDataUnit.Entry> sourceEntries = getInputEntries(rdfInput);
// Execute.
executeUpdateQuery(query, sourceEntries);
}
示例9: prepareUsingClause
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* @param entries
* List of entries to use.
* @return Using clause for SPARQL insert, based on input graphs.
* @throws DPUException
*/
protected String prepareUsingClause(final List<RDFDataUnit.Entry> entries) throws DPUException {
return faultTolerance.execute(new FaultTolerance.ActionReturn<String>() {
@Override
public String action() throws Exception {
final StringBuilder usingClause = new StringBuilder();
for (RDFDataUnit.Entry entry : entries) {
usingClause.append("USING <");
try {
usingClause.append(entry.getDataGraphURI().stringValue());
} catch (DataUnitException ex) {
throw ContextUtils.dpuException(ctx, ex, "SparqlConstruct.execute.exception.internal");
}
usingClause.append("> \n");
}
return usingClause.toString();
}
});
}
示例10: generateGraphFile
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Check if file graph should be generated and if so, then generate new graph file.
*
* @param rdfFile
* @param graphName
* Name of the graph, that will be written into .graph file.
* @throws DPUException
*/
private void generateGraphFile(final FilesDataUnit.Entry rdfFile, String graphName) throws DPUException {
final FilesDataUnit.Entry graphFileEntry = faultTolerance.execute(new FaultTolerance.ActionReturn<FilesDataUnit.Entry>() {
@Override
public FilesDataUnit.Entry action() throws Exception {
final String rdfFilePath = MetadataUtils.get(inRdfData, rdfFile, FilesVocabulary.UV_VIRTUAL_PATH);
return FilesDataUnitUtils.createFile(outFilesData, rdfFilePath + ".graph");
}
});
try {
FileUtils.writeStringToFile(FaultToleranceUtils.asFile(faultTolerance, graphFileEntry), graphName);
} catch (IOException ex) {
throw ContextUtils.dpuException(ctx, ex, "rdfToFiles.error.graphFile");
}
}
示例11: innerExecute
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
@Override
protected void innerExecute() throws DPUException {
ContextUtils.sendShortInfo(ctx, "ExcelToCsv.message");
try {
sheetNameSet = new TreeSet<>(String.CASE_INSENSITIVE_ORDER); // case-insensitive sheet names
String sheetNames = config.getSheetNames();
if (sheetNames != null && sheetNames.length() > 0) {
sheetNameSet.addAll(Arrays.asList(sheetNames.split(Pattern.quote(":"))));
}
Set<FilesDataUnit.Entry> entries = FilesHelper.getFiles(input);
for (FilesDataUnit.Entry entry : entries) {
excelToCsv(entry);
}
} catch (DataUnitException | EncryptedDocumentException | InvalidFormatException | IOException ex) {
throw ContextUtils.dpuException(ctx, ex, "ExcelToCsv.dpuFailed");
}
}
示例12: afterInit
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
@Override
public void afterInit(Context context) {
this.context = context;
if (context instanceof ExecContext) {
this.dpuContext = ((ExecContext) context).getDpuContext();
LOG.debug("\tcontext set to: {}", this.dpuContext);
}
// Load configuration.
try {
this.config = context.getConfigManager().get(USED_CONFIG_NAME, configHistory);
} catch (ConfigException ex) {
LOG.warn("Can't load configuration.", ex);
ContextUtils.sendInfo(context.asUserContext(), "Addon failed to load configuration",
"Failed to load configuration for: {0} default configuration is used.", ADDON_NAME);
this.config = new Configuration_V1();
}
if (this.config == null) {
ContextUtils.sendInfo(context.asUserContext(), "Addon failed to load configuration",
"Failed to load configuration for: {0} default configuration is used.", ADDON_NAME);
this.config = new Configuration_V1();
}
// Add exception for Virtuoso
this.config.exceptionNames.add("java.sql.BatchUpdateException");
// Virtuoso Communications Link Failure (timeout) : Connection to the server lost
this.config.exceptionNames.add("virtuoso.jdbc4.VirtuosoException");
}
示例13: executeAddons
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Execute all {@link ExecutableAddon}s of this DPU.
*
* @param execPoint
* @return If exception is thrown then return false.
*/
private boolean executeAddons(Extension.ExecutionPoint execPoint) {
boolean result = true;
for (Extension item : this.masterContext.getExtensions()) {
if (item instanceof Extension.Executable) {
final Extension.Executable executable = (Extension.Executable) item;
try {
LOG.debug("Executing '{}' with on '{}' point", executable.getClass().getSimpleName(),
execPoint.toString());
executable.execute(execPoint);
} catch (ExtensionException ex) {
ContextUtils.sendError(this.ctx, "Addon execution failed",
ex, "Addon: s", item.getClass().getSimpleName());
result = false;
}
}
}
return result;
}
示例14: requestExtractionModelUpdateService
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Check and refresh extraction model of the PoolParty project
* @param wrapper Wrapped HTTP state used for requests
*/
private void requestExtractionModelUpdateService(HttpStateWrapper wrapper) {
try {
String modelStatus = null;
String requestUrl = config.getExtractionModelServiceUrl() + "/" + config.getProjectId();
HttpGet httpGet = new HttpGet(requestUrl);
CloseableHttpResponse response = wrapper.client.execute(wrapper.host, httpGet, wrapper.context);
int status = response.getStatusLine().getStatusCode();
if (status == HttpStatus.SC_OK) {
modelStatus = EntityUtils.toString(response.getEntity(), StandardCharsets.UTF_8);
}
response.close();
if (modelStatus != null && modelStatus.contains("\"upToDate\" : true")) {
LOG.info("Extraction model is up-to-date");
return;
} else {
LOG.info("Start to update extraction model because its status is unknown");
requestUrl = requestUrl + "/refresh";
httpGet = new HttpGet(requestUrl);
response = wrapper.client.execute(wrapper.host, httpGet, wrapper.context);
status = response.getStatusLine().getStatusCode();
if (status != HttpStatus.SC_OK) {
ContextUtils.sendShortInfo(ctx, "Extraction model update failed, extraction result may be outdated");
LOG.warn("Extraction model update failed, extraction result may be outdated");
}
}
} catch (Exception e) {
LOG.warn("Encountered an exception when requesting extraction model update service", e);
}
}
示例15: createOutputGraph
import eu.unifiedviews.helpers.dpu.context.ContextUtils; //導入依賴的package包/類
/**
* Creates new output graph. Symbolic name is completely new (using time stamp in suffix).
* Data graph IRI is generated.
* @return New output graph.
* @throws DPUException
*/
protected IRI createOutputGraph() throws DPUException {
// Register new output graph
final String symbolicName = "http://unifiedviews.eu/resource/sparql-construct/"
+ Long.toString((new Date()).getTime());
try {
return rdfOutput.addNewDataGraph(symbolicName);
} catch (DataUnitException ex) {
throw ContextUtils.dpuException(ctx, ex, "sparqlUpdate.dpu.error.cantAddGraph");
}
}