Package com.espertech.esper.dataflow.ops

Source Code of com.espertech.esper.dataflow.ops.EventBusSink

/*
* *************************************************************************************
*  Copyright (C) 2008 EsperTech, Inc. All rights reserved.                            *
*  http://esper.codehaus.org                                                          *
*  http://www.espertech.com                                                           *
*  ---------------------------------------------------------------------------------- *
*  The software in this package is published under the terms of the GPL license       *
*  a copy of which has been included with this distribution in the license.txt file.  *
* *************************************************************************************
*/

package com.espertech.esper.dataflow.ops;

import com.espertech.esper.client.EPException;
import com.espertech.esper.client.EventBean;
import com.espertech.esper.client.EventType;
import com.espertech.esper.client.dataflow.EPDataFlowEventCollector;
import com.espertech.esper.client.dataflow.EPDataFlowEventCollectorContext;
import com.espertech.esper.client.dataflow.EventBusCollector;
import com.espertech.esper.core.service.EPRuntimeEventSender;
import com.espertech.esper.dataflow.annotations.DataFlowOpParameter;
import com.espertech.esper.dataflow.annotations.DataFlowOperator;
import com.espertech.esper.dataflow.interfaces.*;
import com.espertech.esper.event.EventAdapterService;
import com.espertech.esper.event.EventBeanAdapterFactory;
import org.w3c.dom.Node;

import java.util.Map;

@DataFlowOperator
public class EventBusSink implements DataFlowOpLifecycle {

    private EventAdapterService eventAdapterService;
    private EPRuntimeEventSender runtimeEventSender;

    @DataFlowOpParameter
    private EPDataFlowEventCollector collector;

    private EventBusCollector eventBusCollector;
    private EventBeanAdapterFactory adapterFactories[];
    private ThreadLocal<EPDataFlowEventCollectorContext> collectorDataTL = new ThreadLocal<EPDataFlowEventCollectorContext>() {
        protected synchronized EPDataFlowEventCollectorContext initialValue() {
            return null;
        }
    };

    public DataFlowOpInitializeResult initialize(DataFlowOpInitializateContext context) throws Exception {
        if (!context.getOutputPorts().isEmpty()) {
            throw new IllegalArgumentException("EventBusSink operator does not provide an output stream");
        }

        EventType[] eventTypes = new EventType[context.getInputPorts().size()];
        for (int i = 0; i < eventTypes.length; i++) {
            eventTypes[i] = context.getInputPorts().get(i).getTypeDesc().getEventType();
        }
        runtimeEventSender = context.getRuntimeEventSender();
        eventAdapterService = context.getStatementContext().getEventAdapterService();

        if (collector != null) {
            eventBusCollector = new EventBusCollector() {
                public void sendEvent(Object object) throws EPException {
                    EventBean event = eventAdapterService.adapterForBean(object);
                    runtimeEventSender.processWrappedEvent(event);
                }

                public void sendEvent(Map map, String eventTypeName) throws EPException {
                    EventBean event = eventAdapterService.adapterForMap(map, eventTypeName);
                    runtimeEventSender.processWrappedEvent(event);
                }

                public void sendEvent(Object[] objectArray, String eventTypeName) throws EPException {
                    EventBean event = eventAdapterService.adapterForObjectArray(objectArray, eventTypeName);
                    runtimeEventSender.processWrappedEvent(event);
                }

                public void sendEvent(Node node) throws EPException {
                    EventBean event = eventAdapterService.adapterForDOM(node);
                    runtimeEventSender.processWrappedEvent(event);
                }
            };
        }
        else {
            adapterFactories = new EventBeanAdapterFactory[eventTypes.length];
            for (int i = 0; i < eventTypes.length; i++) {
                adapterFactories[i] = context.getServicesContext().getEventAdapterService().getAdapterFactoryForType(eventTypes[i]);
            }
        }
        return null;
    }

    public void onInput(int port, Object data) {
        if (eventBusCollector != null) {
            EPDataFlowEventCollectorContext holder = collectorDataTL.get();
            if (holder == null) {
                holder = new EPDataFlowEventCollectorContext(eventBusCollector, data);
                collectorDataTL.set(holder);
            }
            else {
                holder.setEvent(data);
            }
            collector.collect(holder);
        }
        else {
            if (data instanceof EventBean) {
                runtimeEventSender.processWrappedEvent( (EventBean) data);
            }
            else {
                EventBean event = adapterFactories[port].makeAdapter(data);
                runtimeEventSender.processWrappedEvent(event);
            }
        }
    }

    public void open(DataFlowOpOpenContext openContext) {
        // no action
    }

    public void close(DataFlowOpCloseContext openContext) {
        // no action
    }
}
TOP

Related Classes of com.espertech.esper.dataflow.ops.EventBusSink

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.