All Downloads are FREE. Search and download functionalities are using the official Maven repository.

java.fedora.server.journal.recoverylog.RenamingJournalRecoveryLog Maven / Gradle / Ivy

Go to download

The Fedora Client is a Java Library that allows API access to a Fedora Repository. The client is typically one part of a full Fedora installation.

The newest version!
/*
 * -----------------------------------------------------------------------------
 *
 * 

License and Copyright: The contents of this file are subject to the * Apache License, Version 2.0 (the "License"); you may not use * this file except in compliance with the License. You may obtain a copy of * the License at * http://www.fedora-commons.org/licenses.

* *

Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for * the specific language governing rights and limitations under the License.

* *

The entire file consists of original code.

*

Copyright © 2008 Fedora Commons, Inc.
*

Copyright © 2002-2007 The Rector and Visitors of the University of * Virginia and Cornell University
* All rights reserved.

* * ----------------------------------------------------------------------------- */ package fedora.server.journal.recoverylog; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.Date; import java.util.Map; import org.apache.log4j.Logger; import fedora.server.errors.ModuleInitializationException; import fedora.server.journal.ServerInterface; import fedora.server.journal.helpers.JournalHelper; /** * A production-oriented implementation of {@link JournalRecoveryLog}. The name * of the log file contains a time-stamp, so we can be sure that it won't * over-write an existing log file. Also, the name is prefixed with an '_' * (underscore) while the recovery is in progress, so we can see when it * finishes. * * @author [email protected] * @version $Id: RenamingJournalRecoveryLog.java 5367 2006-12-08 08:51:00 +0000 * (Fri, 08 Dec 2006) cwilper $ */ public class RenamingJournalRecoveryLog extends JournalRecoveryLog { /** Logger for this class. */ private static final Logger LOG = Logger.getLogger(RenamingJournalRecoveryLog.class.getName()); /** The name of the log file, when it is complete. */ String fileName; /** The name of the log file, while it is running. */ String tempFileName; private final File logFile; private final FileWriter writer; private boolean open = true; /** * @param parameters * @param role * @param server * @throws ModuleInitializationException */ public RenamingJournalRecoveryLog(Map parameters, String role, ServerInterface server) throws ModuleInitializationException { super(parameters, role, server); try { if (!parameters.containsKey(PARAMETER_RECOVERY_LOG_FILENAME)) { throw new ModuleInitializationException("Parameter '" + PARAMETER_RECOVERY_LOG_FILENAME + "' is not set.", role); } String fileNameTemplate = parameters.get(PARAMETER_RECOVERY_LOG_FILENAME); fileName = JournalHelper.createTimestampedFilename(fileNameTemplate, new Date()); tempFileName = insertHyphenBeforeFilename(fileName); logFile = new File(tempFileName); writer = new FileWriter(logFile); super.logHeaderInfo(parameters); } catch (IOException e) { throw new ModuleInitializationException("Problem writing to the recovery log", role, e); } } private String insertHyphenBeforeFilename(String name) { int lastSlash = name.lastIndexOf(File.separatorChar); if (lastSlash == -1) { return '_' + name; } else { return name.substring(0, lastSlash + 1) + '_' + name.substring(lastSlash + 1); } } /** * A request to log a message just writes it to the log file and flushes it * (if shutdown has not been called). */ @Override public synchronized void log(String message) { try { if (open) { super.log(message, writer); writer.flush(); } } catch (IOException e) { LOG.error("Unable to write journal log message", e); } } /** * On the first call to this method, close the log file and rename it. Set * the flag so no more logging calls will be accepted. */ @Override public synchronized void shutdown() { try { if (open) { open = false; writer.close(); logFile.renameTo(new File(fileName)); } } catch (IOException e) { LOG.error("Error shutting down", e); } } @Override public String toString() { return super.toString() + ", logFile='" + logFile.getPath() + "'"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy