/
codebase/
codebase/area/
codebase/doc/
codebase/etc/
codebase/src/net/sourceforge/pain/data/trigger/
codebase/src/net/sourceforge/pain/logic/
codebase/src/net/sourceforge/pain/logic/affect/
codebase/src/net/sourceforge/pain/logic/event/
codebase/src/net/sourceforge/pain/logic/event/deploy/
codebase/src/net/sourceforge/pain/logic/event/guitool/
codebase/src/net/sourceforge/pain/logic/event/guitool/event/
codebase/src/net/sourceforge/pain/logic/fn/util/
codebase/src/net/sourceforge/pain/logic/trigger/
codebase/src/net/sourceforge/pain/logic/trigger/impl/
codebase/src/net/sourceforge/pain/network/console/
codebase/src/net/sourceforge/pain/network/console/telnet/
codebase/src/net/sourceforge/pain/network/guitool/
codebase/src/net/sourceforge/pain/plugin/
codebase/src/net/sourceforge/pain/plugin/command/
codebase/src/net/sourceforge/pain/plugin/reset/
codebase/src/net/sourceforge/pain/plugin/shutdown/
codebase/src/net/sourceforge/pain/plugin/social/
codebase/src/net/sourceforge/pain/util/
db/doc/javadoc/resources/
db/src/net/sourceforge/pain/util/
gui/
gui/lib/
gui/src/net/sourceforge/pain/tools/guitool/dbbrowse/
gui/src/net/sourceforge/pain/tools/guitool/dialog/
gui/src/net/sourceforge/pain/tools/guitool/menu/
gui/src/net/sourceforge/pain/tools/guitool/resources/
gui/src/net/sourceforge/pain/tools/guitool/resources/images/
gui/src/net/sourceforge/pain/tools/guitool/resources/images/explorer/
tests/
tests/src/
tests/src/net/sourceforge/pain/db/data/
package net.sourceforge.pain.logic.event.guitool;

import net.sourceforge.pain.*;
import net.sourceforge.pain.data.*;
import net.sourceforge.pain.logic.event.*;
import net.sourceforge.pain.network.guitool.*;
import net.sourceforge.pain.util.*;

public class GuiToolEvent extends AbstractEvent {

    public Object execute(Object param) throws Exception {
        GuiToolConnection c = (GuiToolConnection) param;
        GTNetPacket packet = (GTNetPacket) c.inputEvents.removeFirst();
        try {
            if (packet == null) {
                Log.warn("GTNetPacket is null??");
                return null;
            }

            if (c.guiAdminId == null) {
                if (!"Login".equals(packet.eventClassName)) {
                    processFailedEvent(c, "Not logged in", packet.sequence_id);
                    return null;
                }
            }
            GuiEventHandler handler = getGuiEventHandler(packet);
            if (handler == null) {
                processFailedEvent(c, "Event handler is not found:" + packet.eventClassName, packet.sequence_id);
            } else {
                handler.connection = c;
                handler.admin = c.guiAdminId == null ? null : (GuiToolAdmin) Core.getDB().getObject(c.guiAdminId);
                handler.processEvent();
            }
        } catch (Exception e) {
            Log.error(e);
            processFailedEvent(c, "Internal Error:" + e.getMessage(), packet.sequence_id);
        }

        return null;
    }

    private GuiEventHandler getGuiEventHandler(GTNetPacket packet) {
        try {
            GuiEventHandler h = (GuiEventHandler) Class.forName("net.sourceforge.pain.logic.event.guitool.event." + packet.eventClassName).newInstance();
            h.packet = packet;
            return h;
        } catch (Exception e) {
            Log.error(e);
        }
        return null;
    }

    public static void processFailedEvent(GuiToolConnection c, Object note, int sequenceId) {
        c.send(new GTNetPacket("ERROR", note, sequenceId));
    }

    public static void sendInfoMessage(GuiToolConnection c, Object message, int sequenceId) {
        c.send(new GTNetPacket("INFO", message, sequenceId));
    }
}