/*
* Copyright (c) 2014, WSO2 Inc. (http://www.wso2.org) All Rights Reserved.
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.wso2.carbon.event.sink;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.impl.builder.StAXOMBuilder;
import org.apache.axis2.context.ConfigurationContext;
import org.apache.axis2.deployment.AbstractDeployer;
import org.apache.axis2.deployment.DeploymentException;
import org.apache.axis2.deployment.repository.util.DeploymentFileData;
import org.apache.commons.io.FilenameUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.wso2.carbon.event.sink.internal.EventSinkStore;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader;
import java.io.*;
/**
* Axis2 deployer which deploys event sinks
*/
public class EventSinkDeployer extends AbstractDeployer {
private static final Log log = LogFactory.getLog(EventSinkDeployer.class);
@Override
public void init(ConfigurationContext configurationContext) {
}
/**
* Deploys event sink specified by deploymentFileData. This is called whenever an event sink artifact
* is added, modified, deleted from the event sink artifact directory
*
* @param deploymentFileData File data about the event sink artifact to be deployed
* @throws DeploymentException
*/
@Override
public void deploy(DeploymentFileData deploymentFileData) throws DeploymentException {
BufferedInputStream inputStream = null;
try {
inputStream = new BufferedInputStream(new FileInputStream(new File(deploymentFileData.getAbsolutePath())));
XMLStreamReader reader = XMLInputFactory.newInstance().createXMLStreamReader(inputStream);
StAXOMBuilder builder = new StAXOMBuilder(reader);
OMElement eventSink = builder.getDocumentElement();
String eventSinkName = FilenameUtils.getBaseName(deploymentFileData.getFile().getName());
EventSinkStore.getInstance().addEventSink(EventSink.createEventSink(eventSink, eventSinkName));
log.info("Deploying event sink: " + eventSinkName + " - file: " + deploymentFileData.getAbsolutePath());
} catch (FileNotFoundException e) {
throw new DeploymentException(
"Deployment artifact file \"" + deploymentFileData.getAbsolutePath() + "\" not found", e);
} catch (XMLStreamException e) {
throw new DeploymentException(
"Event sink XML in \"" + deploymentFileData.getAbsolutePath() + "\" is malformed", e);
} catch (EventSinkException e) {
throw new DeploymentException(
"Event sink configuration in \"" + deploymentFileData.getAbsolutePath() + "\" is invalid", e);
} finally {
if (inputStream != null) {
try {
inputStream.close();
} catch (IOException e) {
log.warn("Failed to close file input stream after deploying event sink from file "
+ deploymentFileData.getAbsolutePath());
}
}
}
}
@Override
public void setDirectory(String s) {
}
@Override
public void setExtension(String s) {
}
/**
* Undeploys previously deployed event sink artifact. This is called whenever an event sink artifact is deleted
* from event sink artifact directory. Also, this is called when an already existing artifact is modified, followed
* by a call to deploy()
*
* @param fileName File name of the artifact to be undeployed
* @throws DeploymentException
*/
@Override
public void undeploy(String fileName) throws DeploymentException {
String eventSinkName = FilenameUtils.getBaseName(fileName);
try {
EventSink.stopDataPublisher(EventSinkStore.getInstance().getEventSink(eventSinkName));
} catch (EventSinkException e) {
throw new DeploymentException("Error un-deploying event sink " + eventSinkName, e);
}
EventSinkStore.getInstance().removeEventSink(eventSinkName);
log.info("Event sink named '" + eventSinkName + "' has been undeployed");
}
@Override
public void cleanup() throws DeploymentException {
}
}