2021-05-17 13:24:10 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2021 Christian Pierre MOMON <christian@momon.org>
|
|
|
|
*
|
|
|
|
* 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;
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.nio.charset.StandardCharsets;
|
2021-05-18 19:40:29 +02:00
|
|
|
import java.time.format.DateTimeFormatter;
|
2021-05-17 13:24:10 +02:00
|
|
|
|
|
|
|
import org.apache.commons.io.FileUtils;
|
2021-05-18 19:40:29 +02:00
|
|
|
import org.apache.commons.lang3.StringUtils;
|
2021-05-17 13:24:10 +02:00
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
import fr.devinsy.statoolinfos.HtmlizerContext;
|
|
|
|
import fr.devinsy.statoolinfos.core.Federation;
|
2021-05-18 19:40:29 +02:00
|
|
|
import fr.devinsy.statoolinfos.core.Organization;
|
|
|
|
import fr.devinsy.statoolinfos.core.Service;
|
2021-05-17 13:24:10 +02:00
|
|
|
import fr.devinsy.statoolinfos.core.StatoolInfosException;
|
|
|
|
import fr.devinsy.statoolinfos.crawl.CrawlCache;
|
|
|
|
import fr.devinsy.statoolinfos.crawl.CrawlJournal;
|
|
|
|
import fr.devinsy.statoolinfos.crawl.CrawlLog;
|
|
|
|
import fr.devinsy.xidyn.XidynException;
|
|
|
|
import fr.devinsy.xidyn.data.TagDataManager;
|
|
|
|
import fr.devinsy.xidyn.presenters.PresenterUtils;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The Class CrawlJournalPage.
|
|
|
|
*/
|
|
|
|
public class CrawlJournalPage
|
|
|
|
{
|
|
|
|
private static Logger logger = LoggerFactory.getLogger(CrawlJournalPage.class);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Builds the all.
|
|
|
|
*
|
|
|
|
* @throws StatoolInfosException
|
|
|
|
* @throws IOException
|
|
|
|
*/
|
|
|
|
public static void buildAll() throws StatoolInfosException, IOException
|
|
|
|
{
|
|
|
|
Federation federation = HtmlizerContext.instance().getFederation();
|
|
|
|
CrawlCache cache = HtmlizerContext.instance().getCache();
|
|
|
|
File htmlizeDirectory = HtmlizerContext.instance().getHtmlizeDirectory();
|
|
|
|
|
|
|
|
logger.info("Htmlize Crawl Journal pages.");
|
2021-05-18 19:40:29 +02:00
|
|
|
String page = htmlize("Journal des téléchargements", federation.getCrawlJournal());
|
2021-05-17 13:24:10 +02:00
|
|
|
FileUtils.write(new File(htmlizeDirectory, federation.getTechnicalName() + "-crawl.xhtml"), page, StandardCharsets.UTF_8);
|
2021-05-18 19:40:29 +02:00
|
|
|
|
|
|
|
for (Organization organization : federation.getOrganizations())
|
|
|
|
{
|
|
|
|
page = htmlize("Journal des téléchargements de " + organization.getName(), organization.getCrawlJournal());
|
|
|
|
FileUtils.write(new File(htmlizeDirectory, organization.getTechnicalName() + "-crawl.xhtml"), page, StandardCharsets.UTF_8);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (Service service : federation.getAllServices())
|
|
|
|
{
|
|
|
|
page = htmlize("Journal des téléchargements de " + service.getName(), service.getCrawlJournal());
|
|
|
|
FileUtils.write(new File(htmlizeDirectory, service.getOrganization().getTechnicalName() + "-" + service.getTechnicalName() + "-crawl.xhtml"), page, StandardCharsets.UTF_8);
|
|
|
|
}
|
2021-05-17 13:24:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Htmlize.
|
|
|
|
*
|
|
|
|
* @param title
|
|
|
|
* the title
|
|
|
|
* @param journal
|
|
|
|
* the journal
|
|
|
|
* @return the string
|
|
|
|
* @throws StatoolInfosException
|
|
|
|
* the statool infos exception
|
|
|
|
*/
|
|
|
|
public static String htmlize(final String title, final CrawlJournal journal) throws StatoolInfosException
|
|
|
|
{
|
|
|
|
String result;
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
logger.debug("Building Crawl journal page…");
|
|
|
|
|
|
|
|
TagDataManager data = new TagDataManager();
|
|
|
|
|
|
|
|
data.setEscapedContent("title", title);
|
2021-05-18 19:40:29 +02:00
|
|
|
data.setContent("date", journal.getDatetime().format(DateTimeFormatter.ofPattern("dd/MM/YYYY HH:mm")));
|
2021-05-17 13:24:10 +02:00
|
|
|
data.setContent("totalCount", journal.size());
|
|
|
|
data.setContent("errorCount", journal.getErrors().size());
|
|
|
|
|
|
|
|
int index = 0;
|
|
|
|
for (CrawlLog log : journal)
|
|
|
|
{
|
|
|
|
data.setEscapedContent("crawlLogLine", index, "crawlLogLineUrlLink", log.getUrl().toString());
|
|
|
|
data.setEscapedAttribute("crawlLogLine", index, "crawlLogLineUrlLink", "href", log.getUrl().toString());
|
2021-05-18 19:40:29 +02:00
|
|
|
data.setEscapedContent("crawlLogLine", index, "crawlLogLineParentUrlLink", StringUtils.abbreviate(log.getParentUrlValue(), 35));
|
|
|
|
data.setEscapedAttribute("crawlLogLine", index, "crawlLogLineParentUrlLink", "href", StringUtils.defaultString(log.getParentUrlValue(), "#"));
|
2021-05-17 13:24:10 +02:00
|
|
|
data.setContent("crawlLogLine", index, "crawlLogLineStatus", log.getStatus().toString());
|
|
|
|
|
|
|
|
if (log.getStatus().isError())
|
|
|
|
{
|
|
|
|
data.setAttribute("crawlLogLine", index, "crawlLogLineStatus", "style", "background-color: red;");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
data.setAttribute("crawlLogLine", index, "crawlLogLineStatus", "style", "background-color: lime;");
|
|
|
|
}
|
|
|
|
|
|
|
|
index += 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
String content = PresenterUtils.dynamize("/fr/devinsy/statoolinfos/htmlize/crawlJournal.xhtml", data).toString();
|
|
|
|
|
|
|
|
BreadcrumbTrail trail = new BreadcrumbTrail();
|
|
|
|
result = WebCharterView.build(content, trail);
|
|
|
|
}
|
|
|
|
catch (XidynException exception)
|
|
|
|
{
|
|
|
|
throw new StatoolInfosException("Error building crawl journal page: " + exception.getMessage(), exception);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|