/*
* Copyright (c) 2006-2011 Nuxeo SA (http://nuxeo.com/) and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* bstefanescu
*/
package org.eclipse.ecr.automation;
import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
import org.eclipse.ecr.automation.core.annotations.Param;
/**
* An object holding the runtime parameters that should be used by an operation
* when run.
* <p>
* Parameters are injected at runtime into the operation using {@link Param}
* annotation.
*
* @author <a href="mailto:bs@nuxeo.com">Bogdan Stefanescu</a>
*/
public class OperationParameters implements Serializable {
private static final long serialVersionUID = -3215180388563955264L;
protected final String oid;
protected final Map<String, Object> params;
public OperationParameters(String oid) {
this(oid, new HashMap<String, Object>());
}
public OperationParameters(String oid, Map<String, Object> params) {
this.oid = oid;
this.params = params;
}
/**
* The operation ID.
*/
public String id() {
return oid;
}
/**
* The map of runtime parameters.
*/
public final Map<String, Object> map() {
return params;
}
public OperationParameters set(String key, Object valueRef) {
params.put(key, valueRef);
return this;
}
public OperationParameters from(Map<String, Object> params) {
this.params.putAll(params);
return this;
}
}