/*
*
* 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 2005 - 2008 Pentaho Corporation. All rights reserved.
*
* @created Sep 21, 2005
* @author James Dixon
*/
package org.pentaho.platform.uifoundation.component;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.util.List;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.pentaho.platform.api.engine.IPentahoSession;
import org.pentaho.platform.api.engine.IPentahoUrlFactory;
import org.pentaho.platform.api.engine.IRuntimeContext;
import org.pentaho.platform.api.engine.ISolutionEngine;
import org.pentaho.platform.engine.core.output.SimpleOutputHandler;
import org.pentaho.platform.engine.core.solution.ActionInfo;
import org.pentaho.platform.engine.core.system.PentahoSystem;
import org.pentaho.platform.uifoundation.messages.Messages;
import org.pentaho.platform.util.messages.LocaleHelper;
public class ActionComponent extends BaseUIComponent {
private static final long serialVersionUID = 1217363866006312765L;
private static final Log logger = LogFactory.getLog(ActionComponent.class);
private String solutionName;
private String actionPath;
private String actionName;
private String instanceId;
private int outputPreference;
public ActionComponent(final String solutionName, final String actionPath, final String actionName,
final String instanceId, final int outputPreference, final IPentahoUrlFactory urlFactory, final List messages) {
super(urlFactory, messages, solutionName + File.separator + actionPath);
this.solutionName = solutionName;
this.actionName = actionName;
this.actionPath = actionPath;
this.instanceId = instanceId;
this.outputPreference = outputPreference;
}
public ActionComponent(final String actionString, final String instanceId, final int outputPreference,
final IPentahoUrlFactory urlFactory, final List messages) {
super(urlFactory, messages, null);
ActionInfo info = ActionInfo.parseActionString(actionString);
if (info != null) {
solutionName = info.getSolutionName();
actionPath = info.getPath();
actionName = info.getActionName();
}
setSourcePath(solutionName + File.separator + actionPath);
this.instanceId = instanceId;
this.outputPreference = outputPreference;
}
@Override
public Log getLogger() {
return ActionComponent.logger;
}
@Override
public boolean validate() {
return true;
}
protected ByteArrayOutputStream getContentAsStream(final String mimeType) {
IPentahoSession userSession = getSession();
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
SimpleOutputHandler outputHandler = new SimpleOutputHandler(outputStream, true);
outputHandler.setOutputPreference(outputPreference);
ISolutionEngine solutionEngine = PentahoSystem.get(ISolutionEngine.class, getSession());
solutionEngine.setLoggingLevel(getLoggingLevel());
solutionEngine.init(userSession);
IRuntimeContext context = null;
try {
context = solutionEngine
.execute(
solutionName,
actionPath,
actionName,
Messages.getInstance().getString("BaseTest.DEBUG_JUNIT_TEST"), false, true, instanceId, false, getParameterProviders(), outputHandler, null, urlFactory, getMessages()); //$NON-NLS-1$
} finally {
if (context != null) {
context.dispose();
}
}
return outputStream;
}
@Override
public String getContent(final String mimeType) {
ByteArrayOutputStream outputStream = getContentAsStream(mimeType);
// TODO test the return result
String result = ""; //$NON-NLS-1$
try {
result = outputStream.toString(LocaleHelper.getSystemEncoding());
} catch (Exception e) {
return outputStream.toString();
}
return result;
}
}