2020-09-17 02:03:56 +02:00
|
|
|
/*
|
2021-02-05 03:43:01 +01:00
|
|
|
* Copyright (C) 2020-2021 Christian Pierre MOMON <christian@momon.org>
|
2020-09-17 02:03:56 +02:00
|
|
|
*
|
|
|
|
* 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 <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
package fr.devinsy.statoolinfos.htmlize;
|
|
|
|
|
2020-10-28 15:32:05 +01:00
|
|
|
import java.io.File;
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.nio.charset.StandardCharsets;
|
|
|
|
|
|
|
|
import org.apache.commons.io.FileUtils;
|
2020-09-17 02:03:56 +02:00
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
2020-10-28 15:32:05 +01:00
|
|
|
import fr.devinsy.catgenerator.core.BirdGenerator;
|
|
|
|
import fr.devinsy.statoolinfos.HtmlizerContext;
|
2021-05-20 16:03:29 +02:00
|
|
|
import fr.devinsy.statoolinfos.core.Metrics;
|
2020-09-17 02:03:56 +02:00
|
|
|
import fr.devinsy.statoolinfos.core.Service;
|
|
|
|
import fr.devinsy.statoolinfos.core.StatoolInfosException;
|
2020-10-28 15:32:05 +01:00
|
|
|
import fr.devinsy.statoolinfos.crawl.CrawlCache;
|
2020-09-17 02:03:56 +02:00
|
|
|
import fr.devinsy.xidyn.XidynException;
|
|
|
|
import fr.devinsy.xidyn.data.TagDataManager;
|
|
|
|
import fr.devinsy.xidyn.presenters.PresenterUtils;
|
|
|
|
|
|
|
|
/**
|
2020-10-28 15:32:05 +01:00
|
|
|
* The Class ServicePage.
|
2020-09-17 02:03:56 +02:00
|
|
|
*/
|
|
|
|
public class ServicePage
|
|
|
|
{
|
|
|
|
private static Logger logger = LoggerFactory.getLogger(ServicePage.class);
|
|
|
|
|
2020-10-28 15:32:05 +01:00
|
|
|
/**
|
|
|
|
* 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(),
|
2021-05-20 16:03:29 +02:00
|
|
|
new File(htmlizeDirectory, service.getLocalFileBaseName() + ".properties"));
|
|
|
|
|
|
|
|
//
|
|
|
|
for (Metrics metrics : service.getMetrics())
|
|
|
|
{
|
|
|
|
FileUtils.copyFile(metrics.getInputFile(),
|
|
|
|
new File(htmlizeDirectory, metrics.getLocalFileBaseName() + ".properties"));
|
|
|
|
}
|
2020-10-28 15:32:05 +01:00
|
|
|
|
|
|
|
//
|
|
|
|
logger.info("Htmlize service page: {}.", service.getName());
|
2021-05-24 17:46:07 +02:00
|
|
|
String page = ServicePage.htmlize(service);
|
2021-05-20 16:03:29 +02:00
|
|
|
FileUtils.write(new File(htmlizeDirectory, service.getLocalFileBaseName() + ".xhtml"), page, StandardCharsets.UTF_8);
|
2021-05-24 17:46:07 +02:00
|
|
|
|
2021-05-26 02:06:15 +02:00
|
|
|
//
|
2021-05-27 05:08:19 +02:00
|
|
|
logger.info("Htmlize service summary metric page: {}.", service.getName());
|
|
|
|
page = ServiceSummaryMetricPage.htmlize(service);
|
|
|
|
FileUtils.write(new File(htmlizeDirectory, service.getLocalFileBaseName() + "-stats-summarymetrics.xhtml"), page, StandardCharsets.UTF_8);
|
2021-05-26 02:06:15 +02:00
|
|
|
|
2021-05-24 17:46:07 +02:00
|
|
|
//
|
|
|
|
logger.info("Htmlize service generic metric page: {}.", service.getName());
|
|
|
|
page = ServiceGenericMetricPage.htmlize(service);
|
2021-05-27 05:08:19 +02:00
|
|
|
FileUtils.write(new File(htmlizeDirectory, service.getLocalFileBaseName() + "-stats-genericmetrics.xhtml"), page, StandardCharsets.UTF_8);
|
2021-05-24 17:46:07 +02:00
|
|
|
|
|
|
|
logger.info("Htmlize service web metric page: {}.", service.getName());
|
|
|
|
page = ServiceWebMetricPage.htmlize(service);
|
2021-05-27 05:08:19 +02:00
|
|
|
FileUtils.write(new File(htmlizeDirectory, service.getLocalFileBaseName() + "-stats-webmetrics.xhtml"), page, StandardCharsets.UTF_8);
|
2021-05-24 17:46:07 +02:00
|
|
|
|
|
|
|
logger.info("Htmlize service specific metric page: {}.", service.getName());
|
|
|
|
page = ServiceSpecificMetricPage.htmlize(service);
|
2021-05-27 05:08:19 +02:00
|
|
|
FileUtils.write(new File(htmlizeDirectory, service.getLocalFileBaseName() + "-stats-specificmetrics.xhtml"), page, StandardCharsets.UTF_8);
|
2020-10-28 15:32:05 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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().getAllServices())
|
|
|
|
{
|
|
|
|
build(service);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-17 02:03:56 +02:00
|
|
|
/**
|
|
|
|
* Builds the.
|
|
|
|
*
|
|
|
|
* @param service
|
|
|
|
* the service
|
|
|
|
* @return the string
|
|
|
|
* @throws StatoolInfosException
|
|
|
|
* the statool infos exception
|
|
|
|
*/
|
2021-05-24 17:46:07 +02:00
|
|
|
public static String htmlize(final Service service) throws StatoolInfosException
|
2020-09-17 02:03:56 +02:00
|
|
|
{
|
|
|
|
String result;
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
2021-05-14 02:40:15 +02:00
|
|
|
logger.debug("Building service page {}…", service.get("service.name"));
|
2020-09-17 02:03:56 +02:00
|
|
|
|
|
|
|
TagDataManager data = new TagDataManager();
|
|
|
|
|
2020-10-04 00:18:38 +02:00
|
|
|
//
|
2021-05-24 17:46:07 +02:00
|
|
|
data.setContent("headerView", ServiceHeaderView.htmlize(service));
|
2021-05-27 05:08:19 +02:00
|
|
|
data.setContent("statsView", ServiceStatsView.htmlize(service));
|
2021-02-05 03:43:01 +01:00
|
|
|
|
2020-10-07 04:33:30 +02:00
|
|
|
//
|
|
|
|
// data.setContent("fooChart", graphicIndex++,
|
|
|
|
// LineMonthsChartView.build());
|
|
|
|
|
2021-05-22 01:38:55 +02:00
|
|
|
// service.getPrefixes();
|
2020-10-07 04:33:30 +02:00
|
|
|
|
2020-10-04 00:18:38 +02:00
|
|
|
//
|
2020-09-21 03:41:46 +02:00
|
|
|
String content = PresenterUtils.dynamize("/fr/devinsy/statoolinfos/htmlize/service.xhtml", data).toString();
|
2020-09-17 02:03:56 +02:00
|
|
|
|
2020-09-24 02:45:31 +02:00
|
|
|
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);
|
2020-09-17 02:03:56 +02:00
|
|
|
}
|
|
|
|
catch (XidynException exception)
|
|
|
|
{
|
|
|
|
throw new StatoolInfosException("Error building service page: " + exception.getMessage(), exception);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
return result;
|
|
|
|
}
|
2020-10-28 15:32:05 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param service
|
|
|
|
* @param cache
|
|
|
|
* @param htmlizeDirectory
|
|
|
|
* @throws IOException
|
|
|
|
*/
|
|
|
|
private static void htmlizeServiceLogo(final Service service, final CrawlCache cache, final File htmlizeDirectory) throws IOException
|
|
|
|
{
|
|
|
|
logger.info("Htmlize organization logo.");
|
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
2020-09-17 02:03:56 +02:00
|
|
|
}
|