
net.sourceforge.peers.FileLogger Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of phone Show documentation
Show all versions of phone Show documentation
This Java SoftPhone base on Peers
/*
This file is part of Peers, a java SIP softphone.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
Copyright 2007-2013 Yohann Martineau
*/
package net.sourceforge.peers;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;
import net.sourceforge.peers.sip.Utils;
public class FileLogger implements Logger {
public final static String LOG_FILE = File.separator + "logs"
+ File.separator + "peers.log";
public final static String NETWORK_FILE = File.separator + "logs"
+ File.separator + "transport.log";
private PrintWriter logWriter;
private PrintWriter networkWriter;
private Object logMutex;
private Object networkMutex;
private SimpleDateFormat logFormatter;
private SimpleDateFormat networkFormatter;
public FileLogger(String peersHome) {
if (peersHome == null) {
peersHome = Utils.DEFAULT_PEERS_HOME;
}
try {
logWriter = new PrintWriter(new BufferedWriter(
new FileWriter(peersHome + LOG_FILE)));
networkWriter = new PrintWriter(new BufferedWriter(
new FileWriter(peersHome + NETWORK_FILE)));
} catch (IOException e) {
System.out.println("logging to stdout");
logWriter = new PrintWriter(System.out);
networkWriter = new PrintWriter(System.out);
}
logMutex = new Object();
networkMutex = new Object();
logFormatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss,SSS");
networkFormatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss,SSS");
}
@Override
public final void debug(String message) {
synchronized (logMutex) {
logWriter.write(genericLog(message.toString(), "DEBUG"));
logWriter.flush();
}
}
@Override
public final void info(String message) {
synchronized (logMutex) {
logWriter.write(genericLog(message.toString(), "INFO "));
logWriter.flush();
}
}
@Override
public final void error(String message) {
synchronized (logMutex) {
logWriter.write(genericLog(message.toString(), "ERROR"));
logWriter.flush();
}
}
@Override
public final void error(String message, Exception exception) {
synchronized (logMutex) {
logWriter.write(genericLog(message, "ERROR"));
exception.printStackTrace(logWriter);
logWriter.flush();
}
}
private final String genericLog(String message, String level) {
StringBuffer buf = new StringBuffer();
buf.append(logFormatter.format(new Date()));
buf.append(" ");
buf.append(level);
buf.append(" [");
buf.append(Thread.currentThread().getName());
buf.append("] ");
buf.append(message);
buf.append("\n");
return buf.toString();
}
@Override
public final void traceNetwork(String message, String direction) {
synchronized (networkMutex) {
StringBuffer buf = new StringBuffer();
buf.append(networkFormatter.format(new Date()));
buf.append(" ");
buf.append(direction);
buf.append(" [");
buf.append(Thread.currentThread().getName());
buf.append("]\n\n");
buf.append(message);
buf.append("\n");
networkWriter.write(buf.toString());
networkWriter.flush();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy