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.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.AppenderWizard;
import org.safehaus.penrose.log.LogManagerClient;
import org.safehaus.penrose.client.PenroseClient;
import org.apache.log4j.Logger;
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;
/**
* @author Endi S. Dewata
*/
public class AppendersNode extends Node {
Logger log = Logger.getLogger(getClass());
ServersView view;
LogsNode logsNode;
public AppendersNode(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();
for (String appenderName : logManagerClient.getAppenderNames()) {
AppenderNode appenderNode = new AppenderNode(
view,
appenderName,
this
);
addChild(appenderNode);
}
}
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 Appender...") {
public void run() {
try {
createAppender();
} 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 createAppender() throws Exception {
PenroseClient client = logsNode.getServerNode().getServer().getClient();
LogManagerClient logManagerClient = client.getLogManagerClient();
AppenderWizard wizard = new AppenderWizard();
WizardDialog dialog = new WizardDialog(view.getSite().getShell(), wizard);
dialog.setPageSize(600, 300);
int rc = dialog.open();
if (rc == Window.CANCEL) return;
logManagerClient.addAppender(wizard.getAppenderConfig());
logManagerClient.store();
ServersView serversView = ServersView.getInstance();
serversView.refresh(this);
}
public LogsNode getLogsNode() {
return logsNode;
}
public void setLogsNode(LogsNode logsNode) {
this.logsNode = logsNode;
}
}