/* * DSS - Digital Signature Services * * Copyright (C) 2013 European Commission, Directorate-General Internal Market and Services (DG MARKT), B-1049 Bruxelles/Brussel * * Developed by: 2013 ARHS Developments S.A. (rue Nicolas Bové 2B, L-1253 Luxembourg) http://www.arhs-developments.com * * This file is part of the "DSS - Digital Signature Services" project. * * "DSS - Digital Signature Services" is free software: you can redistribute it and/or modify it under the terms of * the GNU Lesser General Public License as published by the Free Software Foundation, either version 2.1 of the * License, or (at your option) any later version. * * DSS 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License along with * "DSS - Digital Signature Services". If not, see <http://www.gnu.org/licenses/>. */ package eu.europa.ec.markt.dss.validation102853.tsl; import java.util.List; import java.util.Map; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import eu.europa.ec.markt.dss.exception.DSSEncodingException; import eu.europa.ec.markt.dss.validation102853.CertificatePool; import eu.europa.ec.markt.dss.validation102853.CertificateToken; /** * This CertificateSource keep a list of trusted certificates extracted from the trusted list. To populate this list {@link * TrustedListsCertificateSource} class is used. This list is refreshed when the method refresh * is called. * * @version $Revision$ - $Date$ */ public class ReloadableTrustedListCertificateSource extends TrustedListsCertificateSource { private static final Logger LOG = LoggerFactory.getLogger(ReloadableTrustedListCertificateSource.class); private TrustedListsCertificateSource currentSource = new TrustedListsCertificateSource(); public ReloadableTrustedListCertificateSource() { super(); } static class Reloader implements Runnable { private TrustedListsCertificateSource underlyingSource; Reloader(final TrustedListsCertificateSource underlyingSource) { this.underlyingSource = underlyingSource; } @Override public void run() { try { LOG.info("--> run(): START LOADING"); underlyingSource.init(); LOG.info("--> run(): END LOADING"); } catch (DSSEncodingException e) { makeATrace(e); } } private static void makeATrace(final Exception e) { LOG.error(e.getMessage(), e); } } public synchronized void refresh() { final TrustedListsCertificateSource newSource = new TrustedListsCertificateSource(this); final Reloader target = new Reloader(newSource); final Thread reloader = new Thread(target); LOG.debug("--> refresh(): START"); reloader.start(); LOG.debug("--> refresh(): END"); currentSource = newSource; } public Map<String, String> getDiagnosticInfo() { return currentSource.getDiagnosticInfo(); } @Override public CertificatePool getCertificatePool() { return currentSource.getCertificatePool(); } @Override /** * Retrieves the list of all certificate tokens from this source. * * @return */ public List<CertificateToken> getCertificates() { return currentSource.getCertificatePool().getCertificateTokens(); } }