/**
* 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.tree.Node;
import org.safehaus.penrose.studio.server.ServersView;
import org.safehaus.penrose.studio.server.Server;
import org.safehaus.penrose.studio.PenroseImage;
import org.safehaus.penrose.studio.PenroseStudio;
import org.safehaus.penrose.studio.dialog.ErrorDialog;
import org.safehaus.penrose.studio.log.editor.LoggerEditorInput;
import org.safehaus.penrose.studio.log.editor.LoggerEditor;
import org.safehaus.penrose.log.LogManagerClient;
import org.safehaus.penrose.client.PenroseClient;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.jface.action.IMenuManager;
import org.eclipse.jface.action.Action;
import org.eclipse.jface.dialogs.MessageDialog;
import org.eclipse.ui.IWorkbenchWindow;
import org.eclipse.ui.PlatformUI;
import org.eclipse.ui.IWorkbenchPage;
import org.apache.log4j.Logger;
/**
* @author Endi S. Dewata
*/
public class LoggerNode extends Node {
Logger log = Logger.getLogger(getClass());
ServersView view;
LoggersNode loggersNode;
String loggerName;
public LoggerNode(ServersView view, String loggerName, LoggersNode loggersNode) {
super(loggerName, PenroseStudio.getImage(PenroseImage.LOGGER), null, loggersNode);
this.view = view;
this.loggersNode = loggersNode;
this.loggerName = loggerName;
}
public void showMenu(IMenuManager manager) {
manager.add(new Action("Open") {
public void run() {
try {
open();
} catch (Exception e) {
log.error(e.getMessage(), e);
ErrorDialog.open(e);
}
}
});
manager.add(new Action("Delete", PenroseStudio.getImageDescriptor(PenroseImage.DELETE_SMALL)) {
public void run() {
try {
remove();
} catch (Exception e) {
log.error(e.getMessage(), e);
ErrorDialog.open(e);
}
}
});
}
public void open() throws Exception {
LoggerEditorInput ei = new LoggerEditorInput();
ei.setLoggersNode(loggersNode);
ei.setLoggerName(loggerName);
IWorkbenchWindow window = PlatformUI.getWorkbench().getActiveWorkbenchWindow();
IWorkbenchPage page = window.getActivePage();
page.openEditor(ei, LoggerEditor.class.getName());
}
public void remove() throws Exception {
Shell shell = view.getSite().getShell();
boolean confirm = MessageDialog.openQuestion(
shell,
"Confirmation",
"Remove Logger \""+loggerName+"\"?");
if (!confirm) return;
Server server = loggersNode.getLogsNode().getServerNode().getServer();
PenroseClient client = server.getClient();
LogManagerClient logManagerClient = client.getLogManagerClient();
for (Node node : view.getSelectedNodes()) {
if (!(node instanceof LoggerNode)) continue;
LoggerNode loggerNode = (LoggerNode)node;
logManagerClient.removeLogger(loggerNode.getLoggerName());
}
logManagerClient.store();
ServersView serversView = ServersView.getInstance();
serversView.refresh(parent);
}
public String getLoggerName() {
return loggerName;
}
public void setLoggerName(String loggerName) {
this.loggerName = loggerName;
}
public boolean hasChildren() {
return false;
}
}