All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.aguacate.function.spi.impl.FunctionScript Maven / Gradle / Ivy

There is a newer version: 0.10.9
Show newest version
package net.sf.aguacate.function.spi.impl;

import java.util.Collection;
import java.util.List;
import java.util.Map;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

import net.sf.aguacate.function.FunctionContext;
import net.sf.aguacate.function.FunctionEvalResult;
import net.sf.aguacate.function.Parameter;
import net.sf.aguacate.function.spi.AbstractFunctionN;
import net.sf.aguacate.script.DynamicCacheCoupling;
import net.sf.aguacate.util.dynamic.bridge.Dynamic;

public class FunctionScript extends AbstractFunctionN {

	private static final Logger LOGGER = LogManager.getLogger(FunctionScript.class);

	private final String[] outputContext;

	private final String outputName;

	private Dynamic dynamic;

	private String functionName;

	public FunctionScript(Collection methods, String name, String message, List parameters,
			List outputContext, String outputName, String scriptName, String functionName) {
		super(methods, name, message, parameters);
		dynamic = DynamicCacheCoupling.get(scriptName);
		assert dynamic != null;
		this.outputContext = outputContext.toArray(new String[outputContext.size()]);
		this.outputName = outputName;
		this.functionName = functionName;
	}

	@Override
	public FunctionEvalResult evaluate(FunctionContext functionContext, Object[] values, String msg) {
		Object value = dynamic.exec(functionName, values);
		if (value instanceof Map) {
			@SuppressWarnings("unchecked")
			Map map = (Map) value;
			String message = (String) map.get("message");
			Object val = map.get("value");
			if (message == null) {
				if (val == null) {
					logFailure(msg);
					return new FunctionEvalResult("Missing state", null);
				} else {
					logSuccess(msg);
					return new FunctionEvalResult(null, val);
				}
			} else {
				if (val == null) {
					logFailure(msg);
					return new FunctionEvalResult(message, null);
				} else {
					logFailure(msg);
					LOGGER.warn("Invalid state: message = {} & value = {}", message, val);
					return new FunctionEvalResult("Invalid state", null);
				}
			}
		} else {
			logFailure(msg);
			LOGGER.warn("Invalid state: {}", value);
			return new FunctionEvalResult("Invalid state", null);
		}
	}

	@Override
	public String getOutputName() {
		return outputName;
	}

	@Override
	public String[] getOutputContext() {
		return outputContext;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy