/**
* Copyright 2009 Red Hat, Inc.
*
* 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 2 of the License, or
* (at your option) 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, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.safehaus.penrose.studio.log.tree;
import org.safehaus.penrose.studio.PenroseStudio;
import org.safehaus.penrose.studio.PenroseImage;
import org.safehaus.penrose.studio.dialog.ErrorDialog;
import org.safehaus.penrose.studio.action.RefreshAction;
import org.safehaus.penrose.studio.log.wizard.LoggerWizard;
import org.safehaus.penrose.studio.server.ServersView;
import org.safehaus.penrose.studio.server.Server;
import org.safehaus.penrose.studio.tree.Node;
import org.safehaus.penrose.log.log4j.LoggerConfig;
import org.safehaus.penrose.log.LogManagerClient;
import org.safehaus.penrose.client.PenroseClient;
import org.eclipse.jface.action.IMenuManager;
import org.eclipse.jface.action.Action;
import org.eclipse.jface.action.Separator;
import org.eclipse.jface.wizard.WizardDialog;
import org.eclipse.jface.window.Window;
import org.eclipse.ui.IWorkbenchActionConstants;
import org.apache.log4j.Logger;
/**
* @author Endi S. Dewata
*/
public class LoggersNode extends Node {
Logger log = Logger.getLogger(getClass());
ServersView view;
LogsNode logsNode;
public LoggersNode(ServersView view, String name, LogsNode logsNode) {
super(name, PenroseStudio.getImage(PenroseImage.FOLDER), null, logsNode);
this.view = view;
this.logsNode = logsNode;
}
public void update() throws Exception {
Server server = logsNode.getServerNode().getServer();
PenroseClient client = server.getClient();
LogManagerClient logManagerClient = client.getLogManagerClient();
RootLoggerNode rootLoggerNode = new RootLoggerNode(view, this);
addChild(rootLoggerNode);
for (String loggerName : logManagerClient.getLoggerNames()) {
LoggerNode loggerNode = new LoggerNode(
view,
loggerName,
this
);
addChild(loggerNode);
}
}
public void expand() throws Exception {
if (children == null) update();
}
public void refresh() throws Exception {
removeChildren();
update();
}
public void showMenu(IMenuManager manager) {
manager.add(new Action("New Logger...") {
public void run() {
try {
createLogger();
} catch (Exception e) {
log.error(e.getMessage(), e);
ErrorDialog.open(e);
}
}
});
manager.add(new Separator(IWorkbenchActionConstants.MB_ADDITIONS));
manager.add(new RefreshAction(this));
}
public void createLogger() throws Exception {
PenroseClient client = logsNode.getServerNode().getServer().getClient();
LogManagerClient logManagerClient = client.getLogManagerClient();
LoggerConfig loggerConfig = new LoggerConfig();
LoggerWizard wizard = new LoggerWizard();
wizard.setLogManagerClient(logManagerClient);
wizard.setLoggerConfig(loggerConfig);
WizardDialog dialog = new WizardDialog(view.getSite().getShell(), wizard);
dialog.setPageSize(600, 300);
int rc = dialog.open();
if (rc == Window.CANCEL) return;
logManagerClient.addLogger(loggerConfig);
logManagerClient.store();
ServersView serversView = ServersView.getInstance();
serversView.refresh(this);
}
public LogsNode getLogsNode() {
return logsNode;
}
public void setLogsNode(LogsNode logsNode) {
this.logsNode = logsNode;
}
}