Search in sources :

Example 1 with NoFreePortsException

use of com.haulmont.yarg.formatters.impl.doc.connector.NoFreePortsException 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)

Aggregations

OpenOfficeException (com.haulmont.yarg.exception.OpenOfficeException)1 ReportingInterruptedException (com.haulmont.yarg.exception.ReportingInterruptedException)1 NoFreePortsException (com.haulmont.yarg.formatters.impl.doc.connector.NoFreePortsException)1 ReportOutputDocument (com.haulmont.yarg.reporting.ReportOutputDocument)1 ReportingAPI (com.haulmont.yarg.reporting.ReportingAPI)1 RunParams (com.haulmont.yarg.reporting.RunParams)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 CustomFormatter (io.jmix.reports.libintegration.CustomFormatter)1 FluentReportRunner (io.jmix.reports.runner.FluentReportRunner)1