/* * Copyright 2012 Research Studios Austria Forschungsges.m.b.H. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package won.bot.framework.eventbot.action.impl.debugbot; import org.apache.jena.query.Dataset; import won.bot.framework.eventbot.EventListenerContext; import won.bot.framework.eventbot.action.BaseEventBotAction; import won.bot.framework.eventbot.event.Event; import won.bot.framework.eventbot.event.impl.debugbot.SendNDebugCommandEvent; import won.bot.framework.eventbot.listener.EventListener; import won.protocol.exception.WonMessageBuilderException; import won.protocol.message.WonMessage; import won.protocol.message.WonMessageBuilder; import won.protocol.service.WonNodeInformationService; import won.protocol.util.WonRdfUtils; import java.net.URI; import java.util.Date; /** * Created by fkleedorfer on 09.06.2016. */ public class SendNDebugMessagesAction extends BaseEventBotAction { String[] messages = {"one", "two"}; private long delayBetweenMessages = 1000; public SendNDebugMessagesAction(final EventListenerContext eventListenerContext, long delayBetweenMessages, String... messages) { super(eventListenerContext); this.delayBetweenMessages = delayBetweenMessages; this.messages = messages; } @Override protected void doRun(final Event event, EventListener executingListener) throws Exception { int n = this.messages.length; if (event instanceof SendNDebugCommandEvent){ SendNDebugCommandEvent sendNDebugCommandEvent = (SendNDebugCommandEvent) event; n = Math.min(n,((SendNDebugCommandEvent)event).getNumberOfMessagesToSend()); long delay = 0; URI connUri = sendNDebugCommandEvent.getConnectionURI(); for (int i = 0; i < n; i++){ delay += delayBetweenMessages; String messageText = this.messages[i]; getEventListenerContext().getTaskScheduler().schedule(createMessageTask(connUri, messageText),new Date(System .currentTimeMillis()+delay)); } } } private Runnable createMessageTask(final URI connectionURI, final String messageText) { return new Runnable() { @Override public void run() { getEventListenerContext().getWonMessageSender().sendWonMessage(createWonMessage(connectionURI, messageText)); } }; } private WonMessage createWonMessage(URI connectionURI, String message) throws WonMessageBuilderException { WonNodeInformationService wonNodeInformationService = getEventListenerContext().getWonNodeInformationService(); Dataset connectionRDF = getEventListenerContext().getLinkedDataSource().getDataForResource(connectionURI); URI remoteNeed = WonRdfUtils.ConnectionUtils.getRemoteNeedURIFromConnection(connectionRDF, connectionURI); URI localNeed = WonRdfUtils.ConnectionUtils.getLocalNeedURIFromConnection(connectionRDF, connectionURI); URI wonNode = WonRdfUtils.ConnectionUtils.getWonNodeURIFromConnection(connectionRDF, connectionURI); Dataset remoteNeedRDF = getEventListenerContext().getLinkedDataSource().getDataForResource(remoteNeed); URI messageURI = wonNodeInformationService.generateEventURI(wonNode); return WonMessageBuilder .setMessagePropertiesForConnectionMessage( messageURI, connectionURI, localNeed, wonNode, WonRdfUtils.ConnectionUtils.getRemoteConnectionURIFromConnection(connectionRDF, connectionURI), remoteNeed, WonRdfUtils.NeedUtils.getWonNodeURIFromNeed(remoteNeedRDF, remoteNeed), message) .build(); } }