org.jclouds.elasticstack.compute
Class ElasticStackComputeServiceAdapter

java.lang.Object
  extended by org.jclouds.elasticstack.compute.ElasticStackComputeServiceAdapter
All Implemented Interfaces:
ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

@Singleton
public class ElasticStackComputeServiceAdapter
extends Object
implements ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

defines the connection between the ElasticStackClient implementation and the jclouds ComputeService


Field Summary
protected  Logger logger
           
 
Constructor Summary
ElasticStackComputeServiceAdapter(ElasticStackClient client, com.google.common.base.Predicate<DriveInfo> driveNotClaimed, JustProvider locationSupplier, Map<String,WellKnownImage> preinstalledImages, com.google.common.cache.Cache<String,DriveInfo> cache, String defaultVncPassword, ExecutorService executor)
           
 
Method Summary
 ServerInfo createNodeWithGroupEncodedIntoNameThenStoreCredentials(String tag, String name, Template template, Map<String,Credentials> credentialStore)
          ComputeService.runNodesWithTag(String, int, Template) generates the parameters passed into this method such that each node in the set has a unique name.
 void destroyNode(String id)
           
 ServerInfo getNode(String id)
           
 Iterable<Hardware> listHardwareProfiles()
          Hardware profiles describe available cpu, memory, and disk configurations that can be used to run a node.
 Iterable<DriveInfo> listImages()
          look up the current standard images and do not error out, if they are not found.
 Iterable<Location> listLocations()
           
 Iterable<ServerInfo> listNodes()
           
 void rebootNode(String id)
           
 void resumeNode(String id)
           
 void suspendNode(String id)
           
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

logger

@Named(value="jclouds.compute")
protected Logger logger
Constructor Detail

ElasticStackComputeServiceAdapter

@Inject
public ElasticStackComputeServiceAdapter(ElasticStackClient client,
                                                com.google.common.base.Predicate<DriveInfo> driveNotClaimed,
                                                JustProvider locationSupplier,
                                                Map<String,WellKnownImage> preinstalledImages,
                                                com.google.common.cache.Cache<String,DriveInfo> cache,
                                                @Named(value="jclouds.elasticstack.vnc-password")
                                                String defaultVncPassword,
                                                @Named(value="jclouds.user-threads")
                                                ExecutorService executor)
Method Detail

createNodeWithGroupEncodedIntoNameThenStoreCredentials

public ServerInfo createNodeWithGroupEncodedIntoNameThenStoreCredentials(String tag,
                                                                         String name,
                                                                         Template template,
                                                                         Map<String,Credentials> credentialStore)
Description copied from interface: ComputeServiceAdapter
ComputeService.runNodesWithTag(String, int, Template) generates the parameters passed into this method such that each node in the set has a unique name.

note

It is intentional to return the library native node object, as generic type N. If you are not using library-native objects (such as libvirt Domain) use JCloudsNativeComputeServiceAdapter instead.

note

Your responsibility is to create a node with the underlying library and return after storing its credentials in the supplied map corresponding to credentialStore

Specified by:
createNodeWithGroupEncodedIntoNameThenStoreCredentials in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>
Parameters:
tag - used to aggregate nodes with identical configuration
name - unique supplied name for the node, which has the tag encoded into it.
template - includes imageId, locationId, and hardwareId used to resume the instance.
credentialStore - once the node is resumeed, its login user and password must be stored keyed on node#id.
Returns:
library-native representation of a node.
See Also:
ComputeService.runNodesWithTag(String, int, Template), ComputeServiceContext.getCredentialStore()

listHardwareProfiles

public Iterable<Hardware> listHardwareProfiles()
Description copied from interface: ComputeServiceAdapter
Hardware profiles describe available cpu, memory, and disk configurations that can be used to run a node.

To implement this method, return the library native hardware profiles available to the user. These will be used to launch nodes as a part of the template.

Specified by:
listHardwareProfiles in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>
Returns:
a non-null iterable of available hardware profiles.
See Also:
ComputeService.listHardwareProfiles()

listImages

public Iterable<DriveInfo> listImages()
look up the current standard images and do not error out, if they are not found.

Specified by:
listImages in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>
Returns:
a non-null iterable of available images.
See Also:
ComputeService.listImages()

listNodes

public Iterable<ServerInfo> listNodes()
Specified by:
listNodes in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

listLocations

public Iterable<Location> listLocations()
Specified by:
listLocations in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

getNode

public ServerInfo getNode(String id)
Specified by:
getNode in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

destroyNode

public void destroyNode(String id)
Specified by:
destroyNode in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

rebootNode

public void rebootNode(String id)
Specified by:
rebootNode in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

resumeNode

public void resumeNode(String id)
Specified by:
resumeNode in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>

suspendNode

public void suspendNode(String id)
Specified by:
suspendNode in interface ComputeServiceAdapter<ServerInfo,Hardware,DriveInfo,Location>


Copyright © 2009-2011 jclouds. All Rights Reserved.