View Javadoc

1   /**
2    *
3    * Copyright (C) 2011 Cloud Conscious, LLC. <info@cloudconscious.com>
4    *
5    * ====================================================================
6    * Licensed under the Apache License, Version 2.0 (the "License");
7    * you may not use this file except in compliance with the License.
8    * You may obtain a copy of the License at
9    *
10   * http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing, software
13   * distributed under the License is distributed on an "AS IS" BASIS,
14   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15   * See the License for the specific language governing permissions and
16   * limitations under the License.
17   * ====================================================================
18   */
19  package org.jclouds.compute.callables;
20  
21  import java.util.concurrent.Callable;
22  
23  import org.jclouds.compute.domain.ExecResponse;
24  import org.jclouds.compute.domain.NodeMetadata;
25  import org.jclouds.compute.options.RunScriptOptions;
26  import org.jclouds.scriptbuilder.domain.Statement;
27  
28  import com.google.common.annotations.Beta;
29  
30  /**
31   * Separates out how one implements the ability to run a script on a node.
32   * 
33   * @author Adrian Cole
34   */
35  @Beta
36  public interface RunScriptOnNode extends Callable<ExecResponse> {
37  
38     public interface Factory {
39        RunScriptOnNode create(NodeMetadata node, String script);
40  
41        RunScriptOnNode create(NodeMetadata node, Statement script);
42  
43        RunScriptOnNode create(NodeMetadata node, Statement script, RunScriptOptions options);
44     }
45  
46     /**
47      * Note that {@link #init} must be called first.
48      */
49     @Override
50     ExecResponse call();
51  
52     /**
53      * verifies that the command can execute on the node. For example, if this is ssh, it may attempt
54      * to find a reachable socket. If this is using an API, it may attempt to validate that
55      * connection.
56      */
57     RunScriptOnNode init();
58  
59     /**
60      * the node this command is being executed on.
61      */
62     NodeMetadata getNode();
63  
64  }