/* * Copyright (C) 2020-2021 Christian Pierre MOMON * * This file is part of StatoolInfos, simple service statistics tool. * * StatoolInfos is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * StatoolInfos 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 Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with StatoolInfos. If not, see . */ package fr.devinsy.statoolinfos.htmlize; import java.io.File; import java.io.IOException; import java.nio.charset.StandardCharsets; import org.apache.commons.io.FileUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import fr.devinsy.catgenerator.core.BirdGenerator; import fr.devinsy.statoolinfos.HtmlizerContext; import fr.devinsy.statoolinfos.core.Metrics; import fr.devinsy.statoolinfos.core.Service; import fr.devinsy.statoolinfos.core.StatoolInfosException; import fr.devinsy.statoolinfos.crawl.CrawlCache; import fr.devinsy.statoolinfos.htmlize.ServiceMetricMenuView.PeriodMenu; import fr.devinsy.statoolinfos.htmlize.ServiceMetricMenuView.ViewMenu; import fr.devinsy.xidyn.XidynException; import fr.devinsy.xidyn.data.TagDataManager; import fr.devinsy.xidyn.presenters.PresenterUtils; /** * The Class ServicePage. */ public class ServicePage { private static Logger logger = LoggerFactory.getLogger(ServicePage.class); /** * Builds the view. * * @throws IOException * @throws StatoolInfosException */ public static void build(final Service service) throws IOException, StatoolInfosException { CrawlCache cache = HtmlizerContext.instance().getCache(); File htmlizeDirectory = HtmlizerContext.instance().getHtmlizeDirectory(); // Manage the logo file. logger.info("Htmlize service logo: {}.", service.getName()); htmlizeServiceLogo(service, cache, htmlizeDirectory); // logger.info("Htmlize service properties file: {}.", service.getName()); FileUtils.copyFile(service.getInputFile(), new File(htmlizeDirectory, service.getLocalFileBaseName() + ".properties")); // for (Metrics metrics : service.getMetrics()) { FileUtils.copyFile(metrics.getInputFile(), new File(htmlizeDirectory, metrics.getLocalFileBaseName() + ".properties")); } // logger.info("Htmlize service page: {}.", service.getName()); String page = ServicePage.htmlize(service); FileUtils.write(new File(htmlizeDirectory, service.getLocalFileBaseName() + ".xhtml"), page, StandardCharsets.UTF_8); ServiceServicesPage.build(service); // logger.info("Htmlize service metric pages: {}.", service.getName()); for (ViewMenu view : ViewMenu.values()) { for (PeriodMenu period : PeriodMenu.values()) { if ((view != ViewMenu.YEARS) || (period == PeriodMenu.FULL)) { if (view != ViewMenu.DAYS) { ServiceMetricSummaryPage.build(htmlizeDirectory, service, view, period); ServiceMetricGenericPage.build(htmlizeDirectory, service, view, period); ServiceMetricSpecificPage.build(htmlizeDirectory, service, view, period); ServiceMetricWebPage.build(htmlizeDirectory, service, view, period); } } } } } /** * Builds the all. * * @throws IOException * Signals that an I/O exception has occurred. * @throws StatoolInfosException * the statool infos exception */ public static void buildAll() throws IOException, StatoolInfosException { for (Service service : HtmlizerContext.instance().getFederation().getServicesAll()) { build(service); } } /** * Builds the. * * @param service * the service * @return the string * @throws StatoolInfosException * the statool infos exception */ public static String htmlize(final Service service) throws StatoolInfosException { String result; try { logger.debug("Building service page {}…", service.get("service.name")); TagDataManager data = new TagDataManager(); // data.setContent("headerView", ServiceHeaderView.htmlize(service)); data.setContent("statsView", ServiceStatsView.htmlize(service)); // // data.setContent("fooChart", graphicIndex++, // LineMonthsChartView.build()); // service.getPrefixes(); // String content = PresenterUtils.dynamize("/fr/devinsy/statoolinfos/htmlize/service.xhtml", data).toString(); BreadcrumbTrail trail = new BreadcrumbTrail(); trail.add(service.getOrganization().getName(), service.getOrganization().getTechnicalName() + ".xhtml"); trail.add(service.getName(), service.getOrganization().getTechnicalName() + "-" + service.getTechnicalName() + ".xhtml"); result = WebCharterView.build(content, trail); } catch (XidynException exception) { throw new StatoolInfosException("Error building service page: " + exception.getMessage(), exception); } // return result; } /** * @param service * @param cache * @param htmlizeDirectory * @throws IOException */ private static void htmlizeServiceLogo(final Service service, final CrawlCache cache, final File htmlizeDirectory) throws IOException { File target = new File(htmlizeDirectory, service.getLogoFileName()); File logoFile = cache.restoreFile(service.getLogoURL()); if (logoFile == null) { logger.info("BirdGeneratoring cat avatar: {}", target.getAbsoluteFile()); BirdGenerator.buildAvatarTo(service.getTechnicalName(), target); } else { FileUtils.copyFile(logoFile, target); } } }