Package org.wso2.siddhi.core.event.remove

Examples of org.wso2.siddhi.core.event.remove.RemoveEvent


* TODO: class description
*/
public final class Util {

    public static void checkAccess(String ownerTenantDomain, int ownerTenantId) {
        CarbonContext carbonContext = getCarbonContext();
        String callerTenantDomain = carbonContext.getTenantDomain();
        if (callerTenantDomain == null) {
            throw new IllegalStateException("Caller tenant domain cannot be null");
        }
        int callerTenantId = carbonContext.getTenantId();
        if (callerTenantId == MultitenantConstants.INVALID_TENANT_ID) {
            throw new IllegalStateException("Caller Tenant ID cannot be " + MultitenantConstants.INVALID_TENANT_ID);
        }

        if (callerTenantDomain.equals(MultitenantConstants.SUPER_TENANT_DOMAIN_NAME) &&
View Full Code Here


                                        "],[" + callerTenantId + "]}");
        }
    }

    private static CarbonContext getCarbonContext() {
        CarbonContext carbonContext = CarbonContext.getThreadLocalCarbonContext();
        if (carbonContext == null) {
            throw new IllegalStateException("CarbonContext cannot be null");
        }
        return carbonContext;
    }
View Full Code Here

            PrivilegedCarbonContext.endTenantFlow();
        }
    }

    private void setTenantCredentialsInCarbonContext() {
        PrivilegedCarbonContext cc = PrivilegedCarbonContext.getThreadLocalCarbonContext();
        cc.setTenantId(ownerTenantId);
        cc.setTenantDomain(ownerTenantDomain);
    }
View Full Code Here

        }

        public void run() {
            try {
                MessageContext msgCtx = ((Axis2MessageContext) synCtx).getAxis2MessageContext();
                Event<MessageContext> event = new Event(msgCtx);
                subscriptions = subscriptionManager.getMatchingSubscriptions(event);
            } catch (EventException e) {
                handleException("Matching subscriptions fetching error", e);
            }
View Full Code Here

     * @throws EventException event
     */
    private void processGetStatusRequest(MessageContext mc,
                                         ResponseMessageBuilder messageBuilder)
            throws AxisFault, EventException {
        Subscription subscription =
                SubscriptionMessageBuilder.createGetStatusMessage(mc);
        if (log.isDebugEnabled()) {
            log.debug("GetStatus request recived for SynapseSubscription ID : " +
                    subscription.getId());
        }
        subscription = subscriptionManager.getSubscription(subscription.getId());
        if (subscription != null) {
            if (log.isDebugEnabled()) {
                log.debug("Sending GetStatus responce for SynapseSubscription ID : " +
                        subscription.getId());
            }
            //send the responce
            SOAPEnvelope soapEnvelope = messageBuilder.genGetStatusResponse(subscription);
            dispatchResponse(soapEnvelope, EventingConstants.WSE_GET_STATUS_RESPONSE,
                    mc, false);
View Full Code Here

            // Adding static subscriptions
            List<Subscription> staticSubscriptionList =
                    eventSource.getSubscriptionManager().getStaticSubscriptions();
            for (Iterator<Subscription> iterator = staticSubscriptionList.iterator();
                 iterator.hasNext();) {
                Subscription staticSubscription = iterator.next();
                OMElement staticSubElem =
                        fac.createOMElement("subscription", XMLConfigConstants.SYNAPSE_OMNAMESPACE);
                staticSubElem.addAttribute(
                        fac.createOMAttribute("id", nullNS, staticSubscription.getId()));
                OMElement filterElem =
                        fac.createOMElement("filter", XMLConfigConstants.SYNAPSE_OMNAMESPACE);
                filterElem.addAttribute(fac.createOMAttribute("source", nullNS,
                        (String) staticSubscription.getFilterValue()));
                filterElem.addAttribute(fac.createOMAttribute("dialect", nullNS,
                        (String) staticSubscription.getFilterDialect()));
                staticSubElem.addChild(filterElem);
                OMElement endpointElem =
                        fac.createOMElement("endpoint", XMLConfigConstants.SYNAPSE_OMNAMESPACE);
                OMElement addressElem =
                        fac.createOMElement("address", XMLConfigConstants.SYNAPSE_OMNAMESPACE);
                addressElem.addAttribute(
                        fac.createOMAttribute("uri", nullNS, staticSubscription.getEndpointUrl()));
                endpointElem.addChild(addressElem);
                staticSubElem.addChild(endpointElem);
                if (staticSubscription.getExpires() != null) {
                    OMElement expiresElem =
                            fac.createOMElement("expires", XMLConfigConstants.SYNAPSE_OMNAMESPACE);
                    fac.createOMText(expiresElem,
                            ConverterUtil.convertToString(staticSubscription.getExpires()));
                    staticSubElem.addChild(expiresElem);
                }
                evenSourceElem.addChild(staticSubElem);
            }
View Full Code Here


    public SynapseSubscription() {
        this.setId(UIDGenerator.generateURNString());
        this.setDeliveryMode(EventingConstants.WSE_DEFAULT_DELIVERY_MODE);
        SubscriptionData subscriptionData = new SubscriptionData();
        subscriptionData.setProperty(SynapseEventingConstants.STATIC_ENTRY, "false");
        this.setSubscriptionData(subscriptionData);
    }
View Full Code Here

                    .getAttribute(new QName(XMLConfigConstants.NULL_NAMESPACE, "class"));
            if (clazz != null) {
                String className = clazz.getAttributeValue();
                try {
                    Class subscriptionManagerClass = Class.forName(className);
                    SubscriptionManager manager =
                            (SubscriptionManager) subscriptionManagerClass.newInstance();
                    Iterator itr = subscriptionManagerElem.getChildrenWithName(PROPERTIES_QNAME);
                    while (itr.hasNext()) {
                        OMElement propElem = (OMElement) itr.next();
                        String propName =
                                propElem.getAttribute(new QName("name")).getAttributeValue();
                        String propValue =
                                propElem.getAttribute(new QName("value")).getAttributeValue();
                        if (propName != null && !"".equals(propName.trim()) &&
                                propValue != null && !"".equals(propValue.trim())) {

                            propName = propName.trim();
                            propValue = propValue.trim();

                            PasswordManager passwordManager =
                                    PasswordManager.getInstance();
                            String key = eventSource.getName() + "." + propName;

                            if (passwordManager.isInitialized()
                                    && passwordManager.isTokenProtected(key)) {
                                eventSource.putConfigurationProperty(propName, propValue);
                                propValue = passwordManager.resolve(propValue);
                            }

                            manager.addProperty(propName, propValue);
                        }
                    }
                    eventSource.setSubscriptionManager(manager);
                    eventSource.getSubscriptionManager()
                            .init(); // Initialise before doing further processing, required for static subscriptions
View Full Code Here

      long scheduledTime = System.currentTimeMillis();
      try {
        oldEventList.clear();
        while (true) {
          threadBarrier.pass();
          RemoveEvent removeEvent = (RemoveEvent) window.poll();
          if (removeEvent == null) {
            if (oldEventList.size() > 0) {
              nextProcessor.process(new RemoveListEvent(
                                                        oldEventList.toArray(new RemoveEvent[oldEventList.size()])));
              oldEventList.clear();
            }

            if (newEventList.size() > 0) {
              InEvent[] inEvents =
                                   newEventList.toArray(new InEvent[newEventList.size()]);
              for (InEvent inEvent : inEvents) {
                window.put(new RemoveEvent(inEvent, -1));
              }
             
              // in order to find second derivative, we need at least 3 events.
              if (newEventList.size() > 2) {

                InEvent firstDerivative1 =
                                           gradient(inEvents[0],
                                                    inEvents[(newEventList.size() / 2) - 1],
                                                    null)[0];
                InEvent firstDerivative2 =
                                           gradient(inEvents[newEventList.size() / 2],
                                                    inEvents[newEventList.size() - 1],
                                                    null)[0];
                InEvent[] secondDerivative =
                                             gradient(firstDerivative1,
                                                      firstDerivative2, Type.DOUBLE);

                for (InEvent inEvent : secondDerivative) {
                  window.put(new RemoveEvent(inEvent, -1));
                }
                nextProcessor.process(new InListEvent(secondDerivative));
              } else {
                log.debug("Insufficient events to calculate second derivative. We need at least 3 events. Current event count: " +
                          newEventList.size());
              }

              newEventList.clear();
            }

            long diff = timeToKeep - (System.currentTimeMillis() - scheduledTime);
            if (diff > 0) {
              try {
                eventRemoverScheduler.schedule(this, diff, TimeUnit.MILLISECONDS);
              } catch (RejectedExecutionException ex) {
                log.warn("scheduling cannot be accepted for execution: elementID " +
                         elementId);
              }
              break;
            }
            scheduledTime = System.currentTimeMillis();
          } else {
            oldEventList.add(new RemoveEvent(removeEvent, System.currentTimeMillis()));
          }
        }
      } catch (Throwable t) {
        log.error(t.getMessage(), t);
      }
View Full Code Here

      long scheduledTime = System.currentTimeMillis();
      try {
        oldEventList.clear();
        while (true) {
          threadBarrier.pass();
          RemoveEvent removeEvent = (RemoveEvent) window.poll();
          if (removeEvent == null) {
            if (oldEventList.size() > 0) {
              nextProcessor.process(new RemoveListEvent(
                                                        oldEventList.toArray(new RemoveEvent[oldEventList.size()])));
              oldEventList.clear();
            }

            if (newEventList.size() > 0) {
              InEvent[] inEvents =
                                   newEventList.toArray(new InEvent[newEventList.size()]);
              for (InEvent inEvent : inEvents) {
                window.put(new RemoveEvent(inEvent, -1));
              }
             
              InEvent[] gradientEvents = gradient(inEvents[0], inEvents[newEventList.size() - 1]);
             
              for (InEvent inEvent : gradientEvents) {
                              window.put(new RemoveEvent(inEvent, -1));
                            }
              nextProcessor.process(new InListEvent(gradientEvents));

              newEventList.clear();
            }

            long diff = timeToKeep - (System.currentTimeMillis() - scheduledTime);
            if (diff > 0) {
              try {
                eventRemoverScheduler.schedule(this, diff, TimeUnit.MILLISECONDS);
              } catch (RejectedExecutionException ex) {
                log.warn("scheduling cannot be accepted for execution: elementID " +
                         elementId);
              }
              break;
            }
            scheduledTime = System.currentTimeMillis();
          } else {
            oldEventList.add(new RemoveEvent(removeEvent, System.currentTimeMillis()));
          }
        }
      } catch (Throwable t) {
        log.error(t.getMessage(), t);
      }
View Full Code Here

TOP

Related Classes of org.wso2.siddhi.core.event.remove.RemoveEvent

Copyright © 2018 www.massapicom. 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.