org.jclouds.elasticstack.compute
Class ElasticStackComputeServiceAdapter
java.lang.Object
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
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
logger
@Named(value="jclouds.compute")
protected Logger logger
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)
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 configurationname
- 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.