Search in sources :

Example 1 with OpenOfficeException

use of com.haulmont.yarg.exception.OpenOfficeException in project jmix by jmix-framework.

the class ReportRunnerImpl method createReportDocumentInternal.

protected ReportOutputDocument createReportDocumentInternal(ReportRunContext context) {
    Report report = context.getReport();
    ReportTemplate template = context.getReportTemplate();
    ReportOutputType outputType = context.getOutputType();
    Map<String, Object> params = context.getParams();
    String outputNamePattern = context.getOutputNamePattern();
    StopWatch stopWatch = null;
    MDC.put("user", SecurityContextHolder.getContext().getAuthentication().getName());
    // executions.startExecution(report.getId().toString(), "Reporting");
    try {
        // TODO Slf4JStopWatch
        // stopWatch = new Slf4JStopWatch("Reporting#" + report.getName());
        Map<String, Object> resultParams = new HashMap<>(params);
        params.entrySet().stream().filter(param -> param.getValue() instanceof ParameterPrototype).forEach(param -> {
            ParameterPrototype prototype = (ParameterPrototype) param.getValue();
            List data = prototypesLoader.loadData(prototype);
            resultParams.put(param.getKey(), data);
        });
        if (template.isCustom()) {
            CustomFormatter customFormatter = applicationContext.getBean(CustomFormatter.class, report, template);
            template.setCustomReport(customFormatter);
        }
        com.haulmont.yarg.structure.ReportOutputType resultOutputType = (outputType != null) ? outputType.getOutputType() : template.getOutputType();
        return reportingAPI.runReport(new RunParams(report).template(template).params(resultParams).output(resultOutputType).outputNamePattern(outputNamePattern));
    } catch (NoFreePortsException nfe) {
        throw new NoOpenOfficeFreePortsException(nfe.getMessage());
    } catch (OpenOfficeException ooe) {
        throw new FailedToConnectToOpenOfficeException(ooe.getMessage());
    } catch (com.haulmont.yarg.exception.UnsupportedFormatException fe) {
        throw new UnsupportedFormatException(fe.getMessage());
    } catch (com.haulmont.yarg.exception.ValidationException ve) {
        throw new ValidationException(ve.getMessage());
    } catch (ReportingInterruptedException ie) {
        throw new ReportCanceledException(String.format("Report is canceled. %s", ie.getMessage()));
    } catch (com.haulmont.yarg.exception.ReportingException re) {
        // todo https://github.com/Haulmont/jmix-reports/issues/22
        // Throwable rootCause = ExceptionUtils.getRootCause(re);
        // if (rootCause instanceof ResourceCanceledException) {
        // throw new ReportCanceledException(String.format("Report is canceled. %s", rootCause.getMessage()));
        // }
        // noinspection unchecked
        List<Throwable> list = ExceptionUtils.getThrowableList(re);
        StringBuilder sb = new StringBuilder();
        for (Iterator<Throwable> it = list.iterator(); it.hasNext(); ) {
            // noinspection ThrowableResultOfMethodCallIgnored
            sb.append(it.next().getMessage());
            if (it.hasNext())
                sb.append("\n");
        }
        throw new ReportingException(sb.toString());
    } finally {
        // todo https://github.com/Haulmont/jmix-reports/issues/22
        // executions.endExecution();
        MDC.remove("user");
        MDC.remove("webContextName");
        if (stopWatch != null) {
            stopWatch.stop();
        }
    }
}
Also used : ReportingInterruptedException(com.haulmont.yarg.exception.ReportingInterruptedException) Id(io.jmix.core.Id) Autowired(org.springframework.beans.factory.annotation.Autowired) HashMap(java.util.HashMap) PrototypesLoader(io.jmix.reports.PrototypesLoader) ObjectProvider(org.springframework.beans.factory.ObjectProvider) FluentReportRunner(io.jmix.reports.runner.FluentReportRunner) ReportRunner(io.jmix.reports.runner.ReportRunner) ReportsUtils(io.jmix.reports.util.ReportsUtils) ReportsProperties(io.jmix.reports.ReportsProperties) ParameterPrototype(io.jmix.reports.app.ParameterPrototype) Map(java.util.Map) SecurityContextHolder(org.springframework.security.core.context.SecurityContextHolder) NoFreePortsException(com.haulmont.yarg.formatters.impl.doc.connector.NoFreePortsException) ReportExecutionHistoryRecorder(io.jmix.reports.ReportExecutionHistoryRecorder) DataManager(io.jmix.core.DataManager) ReportTemplate(io.jmix.reports.entity.ReportTemplate) Iterator(java.util.Iterator) ReportExecution(io.jmix.reports.entity.ReportExecution) io.jmix.reports.exception(io.jmix.reports.exception) ReportOutputType(io.jmix.reports.entity.ReportOutputType) StopWatch(org.apache.commons.lang3.time.StopWatch) ReportRunContext(io.jmix.reports.runner.ReportRunContext) ApplicationContext(org.springframework.context.ApplicationContext) Component(org.springframework.stereotype.Component) List(java.util.List) RunParams(com.haulmont.yarg.reporting.RunParams) MDC(org.slf4j.MDC) EntityStates(io.jmix.core.EntityStates) ReportOutputDocument(com.haulmont.yarg.reporting.ReportOutputDocument) ReportingAPI(com.haulmont.yarg.reporting.ReportingAPI) CustomFormatter(io.jmix.reports.libintegration.CustomFormatter) Report(io.jmix.reports.entity.Report) OpenOfficeException(com.haulmont.yarg.exception.OpenOfficeException) ExceptionUtils(org.apache.commons.lang3.exception.ExceptionUtils) io.jmix.reports.exception(io.jmix.reports.exception) ParameterPrototype(io.jmix.reports.app.ParameterPrototype) OpenOfficeException(com.haulmont.yarg.exception.OpenOfficeException) RunParams(com.haulmont.yarg.reporting.RunParams) HashMap(java.util.HashMap) ReportTemplate(io.jmix.reports.entity.ReportTemplate) ReportingInterruptedException(com.haulmont.yarg.exception.ReportingInterruptedException) ReportOutputType(io.jmix.reports.entity.ReportOutputType) Iterator(java.util.Iterator) List(java.util.List) NoFreePortsException(com.haulmont.yarg.formatters.impl.doc.connector.NoFreePortsException) Report(io.jmix.reports.entity.Report) StopWatch(org.apache.commons.lang3.time.StopWatch) CustomFormatter(io.jmix.reports.libintegration.CustomFormatter)

Example 2 with OpenOfficeException

use of com.haulmont.yarg.exception.OpenOfficeException in project jmix by jmix-framework.

the class JmixOfficeIntegration method runTaskWithTimeout.

@Override
public void runTaskWithTimeout(final OfficeTask officeTask, int timeoutInSeconds) throws NoFreePortsException {
    final SecurityContext securityContext = SecurityContextHolder.getContext();
    final OfficeConnection connection = acquireConnection();
    Future future = null;
    try {
        Callable<Void> task = () -> {
            SecurityContextHolder.setContext(securityContext);
            connection.open();
            officeTask.processTaskInOpenOffice(connection.getOOResourceProvider());
            SecurityContextHolder.clearContext();
            return null;
        };
        future = executor.submit(task);
        future.get(timeoutInSeconds, TimeUnit.SECONDS);
    } catch (InterruptedException ex) {
        throw new ReportingInterruptedException("LibreOffice task interrupted");
    } catch (ExecutionException ex) {
        connection.close();
        if (ex.getCause() instanceof BootstrapException) {
            throw new OpenOfficeException("Failed to connect to LibreOffice. Please check LibreOffice path " + openOfficePath, ex);
        }
        if (ex.getCause() instanceof OpenOfficeException) {
            throw (OpenOfficeException) ex.getCause();
        }
        throw new RuntimeException(ex.getCause());
    } catch (OpenOfficeException ex) {
        connection.close();
        throw ex;
    } catch (TimeoutException tex) {
        try {
            if (Thread.interrupted()) {
                throw new ReportingInterruptedException("LibreOffice task interrupted");
            }
        } finally {
            connection.close();
        }
        if (tex.getCause() instanceof BootstrapException) {
            throw new OpenOfficeException("Failed to connect to LibreOffice. Please check LibreOffice path " + openOfficePath, tex);
        }
        throw new OpenOfficeException(tex);
    } catch (Throwable ex) {
        connection.close();
        if (ex.getCause() instanceof BootstrapException) {
            throw new OpenOfficeException("Failed to connect to LibreOffice. Please check LibreOffice path " + openOfficePath, ex);
        }
        throw new OpenOfficeException(ex);
    } finally {
        if (future != null) {
            future.cancel(true);
        }
        releaseConnection(connection);
    }
}
Also used : OpenOfficeException(com.haulmont.yarg.exception.OpenOfficeException) ReportingInterruptedException(com.haulmont.yarg.exception.ReportingInterruptedException) ReportingInterruptedException(com.haulmont.yarg.exception.ReportingInterruptedException) OfficeConnection(com.haulmont.yarg.formatters.impl.doc.connector.OfficeConnection) BootstrapException(com.sun.star.comp.helper.BootstrapException) SecurityContext(org.springframework.security.core.context.SecurityContext)

Aggregations

OpenOfficeException (com.haulmont.yarg.exception.OpenOfficeException)2 ReportingInterruptedException (com.haulmont.yarg.exception.ReportingInterruptedException)2 NoFreePortsException (com.haulmont.yarg.formatters.impl.doc.connector.NoFreePortsException)1 OfficeConnection (com.haulmont.yarg.formatters.impl.doc.connector.OfficeConnection)1 ReportOutputDocument (com.haulmont.yarg.reporting.ReportOutputDocument)1 ReportingAPI (com.haulmont.yarg.reporting.ReportingAPI)1 RunParams (com.haulmont.yarg.reporting.RunParams)1 BootstrapException (com.sun.star.comp.helper.BootstrapException)1 DataManager (io.jmix.core.DataManager)1 EntityStates (io.jmix.core.EntityStates)1 Id (io.jmix.core.Id)1 PrototypesLoader (io.jmix.reports.PrototypesLoader)1 ReportExecutionHistoryRecorder (io.jmix.reports.ReportExecutionHistoryRecorder)1 ReportsProperties (io.jmix.reports.ReportsProperties)1 ParameterPrototype (io.jmix.reports.app.ParameterPrototype)1 Report (io.jmix.reports.entity.Report)1 ReportExecution (io.jmix.reports.entity.ReportExecution)1 ReportOutputType (io.jmix.reports.entity.ReportOutputType)1 ReportTemplate (io.jmix.reports.entity.ReportTemplate)1 io.jmix.reports.exception (io.jmix.reports.exception)1