/*
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU General Public License, version 2 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/gpl-2.0.html
* or from the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
*
* Copyright 2008 Pentaho Corporation. All rights reserved.
*
* @created Jun 25, 2008
* @author wseyler
*
*/
package org.pentaho.platform.repository.subscription;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.pentaho.platform.api.engine.IPentahoSession;
import org.pentaho.platform.api.repository.ISubscriptionRepository;
import org.pentaho.platform.engine.core.system.BasePublisher;
import org.pentaho.platform.engine.core.system.PentahoSystem;
import org.pentaho.platform.repository.messages.Messages;
import org.pentaho.platform.util.xml.dom4j.XmlDom4JHelper;
/**
* @author wseyler
*
*/
public class SubscriptionPublisher extends BasePublisher {
private static final long serialVersionUID = -2578938864526146490L;
private static final Log logger = LogFactory.getLog(SubscriptionPublisher.class);
public Log getLogger() {
return logger;
}
/* (non-Javadoc)
* @see org.pentaho.platform.engine.core.system.BasePublisher#publish(org.pentaho.platform.api.engine.IPentahoSession)
*/
@Override
public String publish(IPentahoSession session) {
String publishSrcPath = PentahoSystem.getApplicationContext().getSolutionPath("") + "system/ScheduleAndContentImport.xml"; //$NON-NLS-1$ //$NON-NLS-2$
Document document = DocumentHelper.createDocument();
Element root = DocumentHelper.createElement("importContentResults"); //$NON-NLS-1$
document.add(root);
try {
ISubscriptionRepository subscriptionRepository = PentahoSystem.get(ISubscriptionRepository.class, session);
File file = new File(publishSrcPath);
if ( !file.canRead() ) {
throw new FileNotFoundException( "SubscriptionPublisher.publish() requires the file \""
+ publishSrcPath
+ "\" to exist. The file does not exist." );
}
Document importDoc = XmlDom4JHelper.getDocFromFile(file, null);
root.add(subscriptionRepository.importSchedules(importDoc));
root.add(subscriptionRepository.importContent(importDoc));
} catch (FileNotFoundException e) {
getLogger().error(Messages.getInstance().getString("SubscriptionPublisher.ERROR_0001", publishSrcPath), e); //$NON-NLS-1$
return Messages.getInstance().getString("SubscriptionPublisher.ERROR_0002", publishSrcPath); //$NON-NLS-1$
} catch (DocumentException e) {
getLogger().error(Messages.getInstance().getString("SubscriptionPublisher.ERROR_0003", publishSrcPath), e); //$NON-NLS-1$
return Messages.getInstance().getString("SubscriptionPublisher.ERROR_0004") + publishSrcPath; //$NON-NLS-1$
} catch (IOException e) {
getLogger().error(Messages.getInstance().getString("SubscriptionPublisher.ERROR_0005", publishSrcPath), e); //$NON-NLS-1$
return Messages.getInstance().getString("SubscriptionPublisher.ERROR_0006", publishSrcPath); //$NON-NLS-1$
}
List resultNodes = document.selectNodes("//@result"); //$NON-NLS-1$
for (Iterator iter = resultNodes.iterator(); iter.hasNext(); ) {
Attribute attribute = (Attribute) iter.next();
if ("ERROR".equalsIgnoreCase(attribute.getValue())) { //$NON-NLS-1$
return Messages.getInstance().getString("SubscriptionPublisher.ERROR_0007"); //$NON-NLS-1$
}
}
return Messages.getInstance().getString("SubscriptionPublisher.INFO_0001"); //$NON-NLS-1$
}
/* (non-Javadoc)
* @see org.pentaho.platform.api.engine.IPentahoPublisher#getDescription()
*/
public String getDescription() {
return Messages.getInstance().getString("SubscriptionPublisher.INFO_0002"); //$NON-NLS-1$
}
/* (non-Javadoc)
* @see org.pentaho.platform.api.engine.IPentahoPublisher#getName()
*/
public String getName() {
return Messages.getInstance().getString("SubscriptionPublisher.INFO_0003"); //$NON-NLS-1$
}
}