/* * 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 java.time.format.DateTimeFormatter; import org.apache.commons.io.FileUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import fr.devinsy.catgenerator.core.CatGenerator; import fr.devinsy.statoolinfos.HtmlizerContext; import fr.devinsy.statoolinfos.core.Federation; import fr.devinsy.statoolinfos.core.Organization; import fr.devinsy.statoolinfos.core.StatoolInfosException; import fr.devinsy.statoolinfos.crawl.CrawlCache; import fr.devinsy.xidyn.XidynException; import fr.devinsy.xidyn.data.TagDataManager; import fr.devinsy.xidyn.presenters.PresenterUtils; /** * The Class FederationPage. */ public class FederationPage { private static Logger logger = LoggerFactory.getLogger(FederationPage.class); /** * Builds the. * * @throws StatoolInfosException * the statool infos exception * @throws IOException */ public static void build() throws StatoolInfosException, IOException { Federation federation = HtmlizerContext.instance().getFederation(); CrawlCache cache = HtmlizerContext.instance().getCache(); File htmlizeDirectory = HtmlizerContext.instance().getHtmlizeDirectory(); // logger.info("PAGE FEDERATION Htmlize federation logo."); htmlizeFederationLogo(federation, cache, htmlizeDirectory); // logger.info("PAGE FEDERATION Htmlize federation properties files."); FileUtils.copyFile(federation.getInputFile(), new File(htmlizeDirectory, federation.getTechnicalName() + ".properties")); logger.info("PAGE FEDERATION federation page: {}.", federation.getName()); String page = htmlize(federation); FileUtils.write(new File(htmlizeDirectory, "index.xhtml"), page, StandardCharsets.UTF_8); // page = PropertyFilesCheckPage.htmlize(federation.getName(), federation.getInputChecksAll().getAlertLines()); FileUtils.write(new File(htmlizeDirectory, federation.getTechnicalName() + "-checkalerts.xhtml"), page, StandardCharsets.UTF_8); // logger.info("Htmlize organization summarty metric page: {}.", federation.getName()); page = FederationMetricSummaryPage.htmlize(federation); FileUtils.write(new File(htmlizeDirectory, federation.getLocalFileBaseName() + "-metrics.xhtml"), page, StandardCharsets.UTF_8); logger.info("Htmlize organization generic metric page: {}.", federation.getName()); page = FederationMetricGenericPage.htmlize(federation); FileUtils.write(new File(htmlizeDirectory, federation.getLocalFileBaseName() + "-metrics-generic.xhtml"), page, StandardCharsets.UTF_8); logger.info("Htmlize organization web metric page: {}.", federation.getName()); page = FederationMetricWebPage.htmlize(federation); FileUtils.write(new File(htmlizeDirectory, federation.getLocalFileBaseName() + "-metrics-web.xhtml"), page, StandardCharsets.UTF_8); logger.info("Htmlize service specific metric page: {}.", federation.getName()); page = FederationMetricSpecificPage.htmlize(federation); FileUtils.write(new File(htmlizeDirectory, federation.getLocalFileBaseName() + "-metrics-specific.xhtml"), page, StandardCharsets.UTF_8); } /** * Builds the. * * @param federation * the organization * @return the string * @throws StatoolInfosException * the statool infos exception * @throws IOException */ public static String htmlize(final Federation federation) throws StatoolInfosException, IOException { String result; try { logger.debug("Building federation page {}…", federation.getName()); TagDataManager data = new TagDataManager(); data.setContent("federationHeaderView", FederationHeaderView.htmlize(federation)); data.setContent("organizationCount", federation.getOrganizations().size()); data.setContent("serviceCount", federation.getServiceCount()); int index = 0; for (Organization organization : federation.getOrganizations().sortByReverseServiceCount()) { data.setAttribute("organizationListLine", index, "organizationListLineNameLink", "href", organization.getTechnicalName() + ".xhtml"); data.setAttribute("organizationListLine", index, "organizationListLineLogo", "src", organization.getLogoFileName()); data.setAttribute("organizationListLine", index, "organizationListLineLogo", "alt", organization.getName()); data.setEscapedContent("organizationListLine", index, "organizationListLineNameValue", organization.getName()); data.setEscapedContent("organizationListLine", index, "organizationListLineUrlLink", organization.getWebsite()); data.setEscapedAttribute("organizationListLine", index, "organizationListLineUrlLink", "href", organization.getWebsite()); data.setContent("organizationListLine", index, "organizationListLineServiceCount", organization.getServiceCount()); long count = organization.getPreviousMonthUserCount(); if (count == 0) { data.setContent("organizationListLine", index, "organizationListLineUserCount", "n/a"); } else { data.setContent("organizationListLine", index, "organizationListLineUserCount", count); } count = organization.getPreviousMonthVisitCount(); if (count == 0) { data.setContent("organizationListLine", index, "organizationListLineVisitCount", "n/a"); } else { data.setContent("organizationListLine", index, "organizationListLineVisitCount", count); } data.setContent("organizationListLine", index, "organizationListLineDate", organization.getCrawledDate().format(DateTimeFormatter.ofPattern("dd/MM/YYYY"))); data.setAttribute("organizationListLine", index, "organizationListLineDate", "title", organization.getCrawledDate().format(DateTimeFormatter.ofPattern("HH:mm:ss"))); index += 1; } String content = PresenterUtils.dynamize("/fr/devinsy/statoolinfos/htmlize/federation.xhtml", data).toString(); BreadcrumbTrail trail = new BreadcrumbTrail(); result = WebCharterView.build(content, trail); } catch (XidynException exception) { throw new StatoolInfosException("Error building federation page: " + exception.getMessage(), exception); } // return result; } /** * Htmlize federation logo. * * @param federation * the federation * @param cache * the cache * @param htmlizeDirectory * the htmlize directory * @throws IOException * Signals that an I/O exception has occurred. */ private static void htmlizeFederationLogo(final Federation federation, final CrawlCache cache, final File htmlizeDirectory) throws IOException { logger.info("Htmlize federation logo."); File target = new File(htmlizeDirectory, federation.getLogoFileName()); File logoFile = cache.restoreFile(federation.getLogoURL()); if (logoFile == null) { logger.info("CatGeneratoring cat avatar: {}", target.getAbsoluteFile()); CatGenerator.buildAvatarTo(federation.getTechnicalName(), target); } else { FileUtils.copyFile(logoFile, target); } } }